PluginProbe ʕ •ᴥ•ʔ
LatePoint – Calendar Booking Plugin for Appointments and Events / 5.5.2
LatePoint – Calendar Booking Plugin for Appointments and Events v5.5.2
5.6.6 5.6.5 5.6.4 5.6.3 5.6.2 5.6.1 5.6.0 5.5.2 5.5.1 5.5.0 5.4.2 trunk 5.1.0 5.1.1 5.1.2 5.1.3 5.1.4 5.1.5 5.1.6 5.1.7 5.1.8 5.1.9 5.1.91 5.1.92 5.1.93 5.1.94 5.2.0 5.2.1 5.2.10 5.2.11 5.2.2 5.2.3 5.2.4 5.2.5 5.2.6 5.2.7 5.2.8 5.2.9 5.3.0 5.3.1 5.3.2 5.4.0 5.4.1
latepoint / lib / abilities / orders / list-transactions.php
latepoint / lib / abilities / orders Last commit date
abstract-order-ability.php 3 months ago change-invoice-status.php 3 months ago change-order-status.php 3 months ago create-invoice.php 3 months ago create-order.php 3 months ago delete-order.php 3 months ago get-invoice.php 3 months ago get-order-price-breakdown.php 3 months ago get-order.php 3 months ago get-transaction.php 3 months ago list-invoices.php 3 months ago list-orders.php 3 months ago list-transactions.php 3 months ago refund-transaction.php 3 months ago update-order.php 3 months ago
list-transactions.php
73 lines
1 <?php
2 if ( ! defined( 'ABSPATH' ) ) {
3 exit;
4 }
5
6 class LatePointAbilityListTransactions extends LatePointAbstractOrderAbility {
7
8 protected function configure(): void {
9 $this->id = 'latepoint/list-transactions';
10 $this->label = __( 'List transactions', 'latepoint' );
11 $this->description = __( 'Returns a paginated list of payment transactions.', 'latepoint' );
12 $this->permission = 'transaction__view';
13 $this->read_only = true;
14 }
15
16 public function get_input_schema(): array {
17 return [
18 'type' => 'object',
19 'properties' => array_merge(
20 [
21 'order_id' => [ 'type' => 'integer' ],
22 'customer_id' => [ 'type' => 'integer' ],
23 ],
24 self::pagination()
25 ),
26 ];
27 }
28
29 public function get_output_schema(): array {
30 return [
31 'type' => 'object',
32 'properties' => [
33 'transactions' => [
34 'type' => 'array',
35 'items' => $this->transaction_output_schema(),
36 ],
37 'total' => [ 'type' => 'integer' ],
38 'page' => [ 'type' => 'integer' ],
39 'per_page' => [ 'type' => 'integer' ],
40 ],
41 ];
42 }
43
44 public function execute( array $args ) {
45 $page = max( 1, (int) ( $args['page'] ?? 1 ) );
46 $per_page = min( 100, max( 1, (int) ( $args['per_page'] ?? 20 ) ) );
47 $offset = ( $page - 1 ) * $per_page;
48
49 $query = new OsTransactionModel();
50
51 if ( ! empty( $args['order_id'] ) ) {
52 $query->where( [ 'order_id' => (int) $args['order_id'] ] );
53 }
54 if ( ! empty( $args['customer_id'] ) ) {
55 $query->where( [ 'customer_id' => (int) $args['customer_id'] ] );
56 }
57
58 $total = ( clone $query )->count();
59 $transactions = $query
60 ->order_by( 'created_at DESC' )
61 ->set_limit( $per_page )
62 ->set_offset( $offset )
63 ->get_results_as_models();
64
65 return [
66 'transactions' => array_map( [ $this, 'serialize_transaction' ], $transactions ),
67 'total' => (int) $total,
68 'page' => $page,
69 'per_page' => $per_page,
70 ];
71 }
72 }
73