PluginProbe ʕ •ᴥ•ʔ
SureCart – Ecommerce Made Easy For Selling Physical Products, Digital Downloads, Subscriptions, Donations, & Payments / 2.6.1
SureCart – Ecommerce Made Easy For Selling Physical Products, Digital Downloads, Subscriptions, Donations, & Payments v2.6.1
4.4.2 4.4.1 4.4.0 4.3.3 4.3.2 4.3.1 4.3.0 4.2.3 4.2.2 4.2.1 1.0.3 1.0.4 1.0.5 1.0.6 1.1.0 1.1.1 1.1.10 1.1.11 1.1.12 1.1.13 1.1.14 1.1.15 1.1.16 1.1.17 1.1.18 1.1.19 1.1.2 1.1.3 1.1.4 1.1.5 1.1.6 1.1.7 1.1.8 1.1.9 1.10.0 1.10.1 1.10.2 1.10.3 1.10.4 1.11.0 1.11.1 1.11.2 1.2.0 1.2.1 1.2.2 1.2.3 1.2.4 1.2.5 1.3.0 1.3.1 1.3.2 1.3.3 1.3.4 1.4.0 1.4.1 1.4.2 1.5.0 1.5.1 1.5.2 1.5.3 1.5.4 1.5.5 1.5.6 1.5.7 1.5.8 1.6.0 1.6.1 1.6.2 1.6.3 1.6.4 1.7.0 1.7.1 1.7.2 1.8.0 1.8.1 1.8.2 1.8.3 1.8.4 1.8.5 1.9.0 1.9.1 1.9.2 1.9.3 1.9.4 1.9.5 2.0.0 2.0.1 2.1.0 2.1.1 2.1.2 2.1.3 2.1.4 2.10.0 2.10.1 2.11.0 2.11.1 2.11.2 2.11.3 2.11.4 2.12.0 2.13.0 2.14.0 2.14.1 2.15.0 2.15.1 2.16.0 2.16.1 2.16.2 2.16.3 2.17.0 2.17.1 2.17.2 2.18.0 2.19.0 2.19.2 2.19.3 2.19.4 2.2.0 2.2.1 2.20.0 2.20.1 2.20.2 2.20.3 2.20.4 2.20.5 2.20.6 2.21.0 2.22.0 2.22.1 2.23.0 2.24.0 2.25.0 2.25.1 2.25.2 2.26.0 2.27.0 2.27.1 2.28.0 2.29.0 2.29.1 2.29.2 2.29.3 2.29.4 2.3.0 2.3.1 2.30.0 2.31.0 2.31.1 2.31.2 2.31.3 2.4.0 2.4.1 2.4.2 2.4.3 2.4.4 2.40.0 2.40.1 2.5.0 2.5.1 2.5.2 2.6.0 2.6.1 2.6.2 2.7.0 2.7.1 2.7.2 2.7.3 2.7.4 2.7.5 2.8.0 2.8.1 2.8.2 2.8.3 2.8.4 2.9.0 3.0.0 3.0.0-RC1 3.0.0-RC2 3.0.0-beta1 3.0.0-beta2 3.0.1 3.0.2 3.0.3 3.0.4 3.0.5 3.1.0 3.1.1 3.1.2 3.1.3 3.1.4 3.1.5 3.1.6 3.10.0 3.10.1 3.11.0 3.12.0 3.13.0 3.13.1 3.13.2 3.13.3 3.13.4 3.14.0 3.15.0 3.15.1 3.15.2 3.15.3 3.15.4 3.15.5 3.16.0 3.16.1 3.16.2 3.16.3 3.16.4 3.16.5 3.16.6 3.16.7 3.16.8 3.17.0 3.17.1 3.17.2 3.17.3 3.17.4 3.17.5 3.17.6 3.18.0 3.19.0 3.19.1 3.19.2 3.2.0 3.2.1 3.2.2 3.20.0 3.20.1 3.3.0 3.3.1 3.4.0 3.4.1 3.4.2 3.4.3 3.5.0 3.5.1 3.5.2 3.5.3 3.6.0 3.6.1 3.6.2 3.7.0 3.7.1 3.7.2 3.7.3 3.8.0 3.8.1 3.8.2 3.8.3 3.8.4 3.8.5 3.9.0 4.0.0 4.0.1 4.0.2 4.0.3 trunk 4.1.0 0.2.19.1 4.1.1 1.0.0 4.2.0 1.0.1 1.0.2
surecart / app / src / Rest / CustomerRestServiceProvider.php
surecart / app / src / Rest Last commit date
AbandonedCheckoutProtocolRestServiceProvider.php 3 years ago AbandonedCheckoutRestServiceProvider.php 3 years ago AccountRestServiceProvider.php 3 years ago ActivationRestServiceProvider.php 3 years ago BalanceTransactionRestServiceProvider.php 3 years ago BlockPatternsRestServiceProvider.php 3 years ago BrandRestServiceProvider.php 3 years ago BumpRestServiceProvider.php 3 years ago CancellationActRestServiceProvider.php 3 years ago CancellationReasonRestServiceProvider.php 3 years ago ChargesRestServiceProvider.php 3 years ago CheckEmailRestServiceProvider.php 3 years ago CheckoutRestServiceProvider.php 3 years ago CouponRestServiceProvider.php 3 years ago CustomerLinksRestServiceProvider.php 3 years ago CustomerNotificationProtocolRestServiceProvider.php 3 years ago CustomerRestServiceProvider.php 3 years ago DownloadRestServiceProvider.php 3 years ago DraftCheckoutRestServiceProvider.php 2 years ago FulfillmentRestServiceProvider.php 3 years ago IncomingWebhooksRestServiceProvider.php 2 years ago IntegrationProvidersRestServiceProvider.php 3 years ago IntegrationsRestServiceProvider.php 3 years ago InvoicesRestServiceProvider.php 3 years ago LicenseRestServiceProvider.php 3 years ago LineItemsRestServiceProvider.php 3 years ago LoginRestServiceProvider.php 3 years ago ManualPaymentMethodsRestServiceProvider.php 3 years ago MediaRestServiceProvider.php 3 years ago OrderProtocolRestServiceProvider.php 3 years ago OrderRestServiceProvider.php 3 years ago PaymentIntentsRestServiceProvider.php 3 years ago PaymentMethodsRestServiceProvider.php 2 years ago PeriodRestServiceProvider.php 3 years ago PortalProtocolRestServiceProvider.php 3 years ago PriceRestServiceProvider.php 3 years ago ProcessorRestServiceProvider.php 3 years ago ProductGroupsRestServiceProvider.php 3 years ago ProductMediaRestServiceProvider.php 3 years ago ProductsRestServiceProvider.php 3 years ago PromotionRestServiceProvider.php 3 years ago ProvisionalAccountRestServiceProvider.php 3 years ago PurchasesRestServiceProvider.php 3 years ago RefundsRestServiceProvider.php 3 years ago RegisteredWebhookRestServiceProvider.php 2 years ago RestServiceInterface.php 3 years ago RestServiceProvider.php 3 years ago SettingsRestServiceProvider.php 3 years ago ShippingMethodRestServiceProvider.php 3 years ago ShippingProfileRestServiceProvider.php 3 years ago ShippingProtocolRestServiceProvider.php 3 years ago ShippingRateRestServiceProvider.php 3 years ago ShippingZoneRestServiceProvider.php 3 years ago SiteHealthRestServiceProvider.php 2 years ago StatisticRestServiceProvider.php 3 years ago SubscriptionProtocolRestServiceProvider.php 3 years ago SubscriptionRestServiceProvider.php 3 years ago TaxProtocolRestServiceProvider.php 3 years ago TaxRegistrationRestServiceProvider.php 3 years ago TaxZoneRestServiceProvider.php 3 years ago UploadsRestServiceProvider.php 3 years ago VerificationCodeRestServiceProvider.php 3 years ago WebhooksRestServiceProvider.php 3 years ago
CustomerRestServiceProvider.php
223 lines
1 <?php
2
3 namespace SureCart\Rest;
4
5 use SureCart\Controllers\Rest\CustomerController;
6 use SureCart\Models\User;
7 use SureCart\Rest\RestServiceInterface;
8
9 /**
10 * Service provider for Price Rest Requests
11 */
12 class CustomerRestServiceProvider extends RestServiceProvider implements RestServiceInterface {
13 /**
14 * Endpoint.
15 *
16 * @var string
17 */
18 protected $endpoint = 'customers';
19
20 /**
21 * Rest Controller
22 *
23 * @var string
24 */
25 protected $controller = CustomerController::class;
26
27 /**
28 * Get our sample schema for a post.
29 *
30 * @return array The sample schema for a post
31 */
32 public function get_item_schema() {
33 if ( $this->schema ) {
34 // Since WordPress 5.3, the schema can be cached in the $schema property.
35 return $this->schema;
36 }
37
38 $this->schema = [
39 // This tells the spec of JSON Schema we are using which is draft 4.
40 '$schema' => 'http://json-schema.org/draft-04/schema#',
41 // The title property marks the identity of the resource.
42 'title' => $this->endpoint,
43 'type' => 'object',
44 // In JSON Schema you can specify object properties in the properties attribute.
45 'properties' => [
46 'id' => [
47 'description' => esc_html__( 'Unique identifier for the object.', 'surecart' ),
48 'type' => 'string',
49 'context' => [ 'view', 'edit', 'embed' ],
50 'readonly' => true,
51 ],
52 ],
53 ];
54
55 return $this->schema;
56 }
57
58 /**
59 * Get our sample schema for a post.
60 *
61 * @return array The sample schema for a post
62 */
63 public function sync_schema() {
64 if ( $this->sync_schema ) {
65 // Since WordPress 5.3, the schema can be cached in the $schema property.
66 return $this->sync_schema;
67 }
68
69 $this->schema = [
70 // This tells the spec of JSON Schema we are using which is draft 4.
71 '$schema' => 'http://json-schema.org/draft-04/schema#',
72 // The title property marks the identity of the resource.
73 'title' => $this->endpoint,
74 'type' => 'object',
75 // In JSON Schema you can specify object properties in the properties attribute.
76 'properties' => [
77 'create_user' => [
78 'description' => esc_html__( 'Create the WordPress user.', 'surecart' ),
79 'type' => 'boolean',
80 'context' => [ 'view', 'edit', 'embed' ],
81 'default' => true,
82 ],
83 'run_actions' => [
84 'description' => esc_html__( 'Run any purchase syncing actions.', 'surecart' ),
85 'type' => 'boolean',
86 'context' => [ 'view', 'edit', 'embed' ],
87 'default' => true,
88 ],
89 'dry_run' => [
90 'description' => esc_html__( 'Dry run the sync.', 'surecart' ),
91 'type' => 'boolean',
92 'context' => [ 'view', 'edit', 'embed' ],
93 'default' => false,
94 ],
95 ],
96 ];
97
98 return $this->schema;
99 }
100
101 /**
102 * Register REST Routes
103 *
104 * @return void
105 */
106 public function registerRoutes() {
107 register_rest_route(
108 "$this->name/v$this->version",
109 $this->endpoint . '/(?P<id>\S+)/connect/(?P<user_id>\S+)',
110 [
111 [
112 'methods' => \WP_REST_Server::EDITABLE,
113 'callback' => $this->callback( $this->controller, 'connect' ),
114 'permission_callback' => [ $this, 'connect_permissions_check' ],
115 ],
116 // Register our schema callback.
117 'schema' => [ $this, 'get_item_schema' ],
118 ]
119 );
120
121 // sync with SureCart.
122 register_rest_route(
123 "$this->name/v$this->version",
124 $this->endpoint . '/sync',
125 [
126 [
127 'methods' => \WP_REST_Server::EDITABLE,
128 'callback' => $this->callback( $this->controller, 'sync' ),
129 'permission_callback' => [ $this, 'sync_permissions_check' ],
130 ],
131 // Register our schema callback.
132 'schema' => [ $this, 'sync_schema' ],
133 ]
134 );
135
136 register_rest_route(
137 "$this->name/v$this->version",
138 $this->endpoint . '/(?P<id>\S+)/expose/(?P<media_id>\S+)',
139 [
140 [
141 'methods' => \WP_REST_Server::READABLE,
142 'callback' => $this->callback( $this->controller, 'exposeMedia' ),
143 'permission_callback' => [ $this, 'get_item_permissions_check' ],
144 ],
145 // Register our schema callback.
146 'schema' => [ $this, 'get_item_schema' ],
147 ]
148 );
149 }
150
151 /**
152 * A WordPress user can read their own customer record.
153 *
154 * @param \WP_REST_Request $request Full details about the request.
155 * @return boolean
156 */
157 public function connect_permissions_check( $request ) {
158 return current_user_can( 'edit_sc_customers' );
159 }
160
161 /**
162 * A WordPress user can read their own customer record.
163 *
164 * @param \WP_REST_Request $request Full details about the request.
165 * @return boolean
166 */
167 public function sync_permissions_check( $request ) {
168 return current_user_can( 'edit_sc_customers' );
169 }
170
171
172 /**
173 * A WordPress user can read their own customer record.
174 *
175 * @param \WP_REST_Request $request Full details about the request.
176 * @return true|\WP_Error True if the request has access to create items, WP_Error object otherwise.
177 */
178 public function get_item_permissions_check( $request ) {
179 return current_user_can( 'read_sc_customer', $request->get_params() );
180 }
181
182 /**
183 * Read permissions.
184 *
185 * @param \WP_REST_Request $request Full details about the request.
186 * @return true|\WP_Error True if the request has access to create items, WP_Error object otherwise.
187 */
188 public function get_items_permissions_check( $request ) {
189 return current_user_can( 'read_sc_customers' );
190 }
191
192
193 /**
194 * Create permissions.
195 *
196 * @param \WP_REST_Request $request Full details about the request.
197 * @return true|\WP_Error True if the request has access to create items, WP_Error object otherwise.
198 */
199 public function create_item_permissions_check( $request ) {
200 return current_user_can( 'publish_sc_customers' );
201 }
202
203 /**
204 * Update permissions.
205 *
206 * @param \WP_REST_Request $request Full details about the request.
207 * @return true|\WP_Error True if the request has access to create items, WP_Error object otherwise.
208 */
209 public function update_item_permissions_check( $request ) {
210 return current_user_can( 'edit_sc_customer', $request['id'], $request->get_params() );
211 }
212
213 /**
214 * Nobody can delete.
215 *
216 * @param \WP_REST_Request $request Full details about the request.
217 * @return false
218 */
219 public function delete_item_permissions_check( $request ) {
220 return current_user_can( 'delete_sc_customers' );
221 }
222 }
223