PluginProbe ʕ •ᴥ•ʔ
SureCart – Ecommerce Made Easy For Selling Physical Products, Digital Downloads, Subscriptions, Donations, & Payments / 2.13.0
SureCart – Ecommerce Made Easy For Selling Physical Products, Digital Downloads, Subscriptions, Donations, & Payments v2.13.0
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 / ProductsRestServiceProvider.php
surecart / app / src / Rest Last commit date
AbandonedCheckoutProtocolRestServiceProvider.php 3 years ago AbandonedCheckoutRestServiceProvider.php 2 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 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 2 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 ProductCollectionsRestServiceProvider.php 2 years ago ProductGroupsRestServiceProvider.php 3 years ago ProductMediaRestServiceProvider.php 3 years ago ProductsRestServiceProvider.php 2 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 ReturnItemsRestServiceProvider.php 2 years ago ReturnReasonsRestServiceProvider.php 2 years ago ReturnRequestsRestServiceProvider.php 2 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 VariantOptionsRestServiceProvider.php 2 years ago VariantValuesRestServiceProvider.php 2 years ago VariantsRestServiceProvider.php 2 years ago VerificationCodeRestServiceProvider.php 3 years ago WebhooksRestServiceProvider.php 3 years ago
ProductsRestServiceProvider.php
242 lines
1 <?php
2
3 namespace SureCart\Rest;
4
5 use SureCart\Rest\RestServiceInterface;
6 use SureCart\Controllers\Rest\ProductsController;
7
8 /**
9 * Service provider for Price Rest Requests
10 */
11 class ProductsRestServiceProvider extends RestServiceProvider implements RestServiceInterface {
12
13 /**
14 * Endpoint.
15 *
16 * @var string
17 */
18 protected $endpoint = 'products';
19
20 /**
21 * Rest Controller
22 *
23 * @var string
24 */
25 protected $controller = ProductsController::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 'file_upload_ids' => [
53 'description' => esc_html__( 'Files attached to the product.', 'surecart' ),
54 'context' => [ 'edit' ],
55 'type' => 'array',
56 'items' => [
57 'type' => 'string',
58 ],
59 ],
60 'metadata' => [
61 'description' => esc_html__( 'Stored product metadata', 'surecart' ),
62 'type' => 'object',
63 'properties' => [
64 'wp_created_by' => [
65 'type' => 'integer',
66 'context' => [ 'edit' ],
67 'readonly' => true,
68 ],
69 ],
70 ],
71 'metrics' => [
72 'description' => esc_html__( 'Top level metrics for the product.', 'surecart' ),
73 'readonly' => true,
74 'type' => 'object',
75 'properties' => [
76 'currency' => [
77 'type' => 'string',
78 ],
79 'max_price_amount' => [
80 'type' => 'integer',
81 ],
82 'min_price_amount' => [
83 'type' => 'integer',
84 ],
85 'prices_count' => [
86 'type' => 'integer',
87 ],
88 ],
89 'context' => [ 'edit' ],
90 ],
91 ],
92 ];
93
94 return $this->schema;
95 }
96
97 /**
98 * Get the collection params.
99 *
100 * @return array
101 */
102 public function get_collection_params() {
103 return [
104 'archived' => [
105 'description' => esc_html__( 'Whether to get archived products or not.', 'surecart' ),
106 'type' => 'boolean',
107 ],
108 'recurring' => [
109 'description' => esc_html__( 'Only return products that are recurring or not recurring (one time).', 'surecart' ),
110 'type' => 'boolean',
111 ],
112 'query' => [
113 'description' => __( 'The query to be used for full text search of this collection.', 'surecart' ),
114 'type' => 'string',
115 ],
116 'ids' => [
117 'description' => __( 'Ensure result set excludes specific IDs.', 'surecart' ),
118 'type' => 'array',
119 'items' => [
120 'type' => 'string',
121 ],
122 'default' => [],
123 ],
124 'product_group_ids' => [
125 'description' => __( 'Only return objects that belong to the given product groups.', 'surecart' ),
126 'type' => 'array',
127 'items' => [
128 'type' => 'string',
129 ],
130 'default' => [],
131 ],
132 'product_collection_ids' => [
133 'description' => __( 'Only return objects that belong to the given product collections.', 'surecart' ),
134 'type' => 'array',
135 'items' => [
136 'type' => 'string',
137 ],
138 'default' => [],
139 ],
140 'page' => [
141 'description' => esc_html__( 'The page of items you want returned.', 'surecart' ),
142 'type' => 'integer',
143 ],
144 'per_page' => [
145 'description' => esc_html__( 'A limit on the number of items to be returned, between 1 and 100.', 'surecart' ),
146 'type' => 'integer',
147 ],
148 ];
149 }
150
151 /**
152 * Anyone can get a specific product.
153 *
154 * @param \WP_REST_Request $request Full details about the request.
155 * @return true|\WP_Error True if the request has access to create items, WP_Error object otherwise.
156 */
157 public function get_item_permissions_check( $request ) {
158 if ( 'edit' === $request['context'] && ! current_user_can( 'edit_sc_products' ) ) {
159 return new \WP_Error(
160 'rest_forbidden_context',
161 __( 'Sorry, you are not allowed to edit products.', 'surecart' ),
162 array( 'status' => rest_authorization_required_code() )
163 );
164 }
165
166 return true;
167 }
168
169 /**
170 * Who can list products?
171 *
172 * @param \WP_REST_Request $request Full details about the request.
173 * @return true|\WP_Error True if the request has access to create items, WP_Error object otherwise.
174 */
175 public function get_items_permissions_check( $request ) {
176 if ( 'edit' === $request['context'] && ! current_user_can( 'edit_sc_products' ) ) {
177 return new \WP_Error(
178 'rest_forbidden_context',
179 __( 'Sorry, you are not allowed to edit products.', 'surecart' ),
180 array( 'status' => rest_authorization_required_code() )
181 );
182 }
183
184 if ( $request['archived'] ) {
185 return current_user_can( 'edit_sc_products' );
186 }
187
188 return true;
189 }
190
191 /**
192 * Create model.
193 *
194 * @param \WP_REST_Request $request Full details about the request.
195 * @return true|\WP_Error True if the request has access to create items, WP_Error object otherwise.
196 */
197 public function create_item_permissions_check( $request ) {
198 return current_user_can( 'publish_sc_products' );
199 }
200
201 /**
202 * Update model.
203 *
204 * @param \WP_REST_Request $request Full details about the request.
205 * @return true|\WP_Error True if the request has access to create items, WP_Error object otherwise.
206 */
207 public function update_item_permissions_check( $request ) {
208 return current_user_can( 'edit_sc_products' );
209 }
210
211 /**
212 * Delete model.
213 *
214 * @param \WP_REST_Request $request Full details about the request.
215 * @return true|\WP_Error True if the request has access to create items, WP_Error object otherwise.
216 */
217 public function delete_item_permissions_check( $request ) {
218 return current_user_can( 'delete_sc_products' );
219 }
220
221 /**
222 * If we are editing, let's make sure the data comes back directly.
223 *
224 * @param \SureCart\Models\Product $model Product model.
225 * @param string $context The context of the request.
226 *
227 * @return array The filtered response.
228 */
229 public function filter_response_by_context( $model, $context ) {
230 $response = parent::filter_response_by_context( $model, $context );
231
232 if ( 'edit' === $context && is_array( $response ) && ! empty( $response['id'] ) ) {
233 // Process the variants, it's in a data column, so we need to pull it out.
234 $response['variants'] = ! empty( $response['variants']['data'] ) ? $response['variants']['data'] : [];
235 // Process the variant_options, it's in a data column, so we need to pull it out.
236 $response['variant_options'] = ! empty( $response['variant_options']['data'] ) ? $response['variant_options']['data'] : [];
237 }
238
239 return $response;
240 }
241 }
242