diff --git a/docs/api/admin-spec3.json b/docs/api/admin-spec3.json
index 1cb1236186..b3a3a5a979 100644
--- a/docs/api/admin-spec3.json
+++ b/docs/api/admin-spec3.json
@@ -435,40 +435,19 @@ paths:
$ref: '#/components/responses/invalid_request_error'
'500':
$ref: '#/components/responses/500_error'
- /currencies:
- get:
- operationId: GetCurrencies
- summary: List Currency
- description: Retrieves a list of Currency
+ '/batch-jobs/{id}/cancel':
+ post:
+ operationId: PostBatchJobsBatchJobCancel
+ summary: Cancel a Batch Job
+ description: Marks a batch job as canceled
x-authenticated: true
parameters:
- - in: query
- name: code
- description: Code of the currency to search for.
+ - in: path
+ name: id
+ required: true
+ description: The ID of the batch job.
schema:
type: string
- - in: query
- name: includes_tax
- description: Search for tax inclusive currencies.
- schema:
- type: boolean
- - in: query
- name: order
- description: order to retrieve products in.
- schema:
- type: string
- - in: query
- name: offset
- description: How many products to skip in the result.
- schema:
- type: number
- default: '0'
- - in: query
- name: limit
- description: Limit the number of products returned.
- schema:
- type: number
- default: '20'
x-codeSamples:
- lang: JavaScript
label: JS Client
@@ -480,20 +459,23 @@ paths:
// must be previously logged in or use api token
- medusa.admin.currencies.list()
+ medusa.admin.batchJobs.cancel(batch_job_id)
- .then(({ currencies, count, offset, limit }) => {
- console.log(currencies.length);
+ .then(({ batch_job }) => {
+ console.log(batch_job.id);
});
- lang: Shell
label: cURL
source: >
curl --location --request POST
- 'https://medusa-url.com/admin/currencies' \
+ 'https://medusa-url.com/admin/batch-jobs/{id}/cancel' \
--header 'Authorization: Bearer {api_token}'
+ security:
+ - api_token: []
+ - cookie_auth: []
tags:
- - Currency
+ - Batch Job
responses:
'200':
description: OK
@@ -502,10 +484,434 @@ paths:
schema:
type: object
properties:
- currencies:
+ batch_job:
+ $ref: '#/components/schemas/BatchJob'
+ '400':
+ $ref: '#/components/responses/400_error'
+ '401':
+ $ref: '#/components/responses/unauthorized'
+ '404':
+ $ref: '#/components/responses/not_found_error'
+ '409':
+ $ref: '#/components/responses/invalid_state_error'
+ '422':
+ $ref: '#/components/responses/invalid_request_error'
+ '500':
+ $ref: '#/components/responses/500_error'
+ '/batch-jobs/{id}/confirm':
+ post:
+ operationId: PostBatchJobsBatchJobConfirmProcessing
+ summary: Confirm a Batch Job
+ description: Confirms that a previously requested batch job should be executed.
+ x-authenticated: true
+ parameters:
+ - in: path
+ name: id
+ required: true
+ description: The ID of the batch job.
+ schema:
+ type: string
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source: >
+ import Medusa from "@medusajs/medusa-js"
+
+ const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
+ 3 })
+
+ // must be previously logged in or use api token
+
+ medusa.admin.batchJobs.confirm(batch_job_id)
+
+ .then(({ batch_job }) => {
+ console.log(batch_job.id);
+ });
+ - lang: Shell
+ label: cURL
+ source: >
+ curl --location --request POST
+ 'https://medusa-url.com/admin/batch-jobs/{id}/confirm' \
+
+ --header 'Authorization: Bearer {api_token}'
+ security:
+ - api_token: []
+ - cookie_auth: []
+ tags:
+ - Batch Job
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ batch_job:
+ $ref: '#/components/schemas/BatchJob'
+ '400':
+ $ref: '#/components/responses/400_error'
+ '401':
+ $ref: '#/components/responses/unauthorized'
+ '404':
+ $ref: '#/components/responses/not_found_error'
+ '409':
+ $ref: '#/components/responses/invalid_state_error'
+ '422':
+ $ref: '#/components/responses/invalid_request_error'
+ '500':
+ $ref: '#/components/responses/500_error'
+ /batch-jobs:
+ post:
+ operationId: PostBatchJobs
+ summary: Create a Batch Job
+ description: Creates a Batch Job.
+ x-authenticated: true
+ requestBody:
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/AdminPostBatchesReq'
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source: >
+ import Medusa from "@medusajs/medusa-js"
+
+ const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
+ 3 })
+
+ // must be previously logged in or use api token
+
+ medusa.admin.batchJobs.create({
+ type: 'product-export',
+ context: {},
+ dry_run: false
+ }).then((({ batch_job }) => {
+ console.log(batch_job.id);
+ });
+ - lang: Shell
+ label: cURL
+ source: >
+ curl --location --request POST
+ 'https://medusa-url.com/admin/batch-jobs' \
+
+ --header 'Content-Type: application/json' \
+
+ --header 'Authorization: Bearer {api_token}' \
+
+ --data-raw '{
+ "type": "product-export",
+ "context": { }
+ }'
+ security:
+ - api_token: []
+ - cookie_auth: []
+ tags:
+ - Batch Job
+ responses:
+ '201':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ batch_job:
+ $ref: '#/components/schemas/BatchJob'
+ '400':
+ $ref: '#/components/responses/400_error'
+ '401':
+ $ref: '#/components/responses/unauthorized'
+ '404':
+ $ref: '#/components/responses/not_found_error'
+ '409':
+ $ref: '#/components/responses/invalid_state_error'
+ '422':
+ $ref: '#/components/responses/invalid_request_error'
+ '500':
+ $ref: '#/components/responses/500_error'
+ get:
+ operationId: GetBatchJobs
+ summary: List Batch Jobs
+ description: Retrieve a list of Batch Jobs.
+ x-authenticated: true
+ parameters:
+ - in: query
+ name: limit
+ description: The number of batch jobs to return.
+ schema:
+ type: integer
+ default: 10
+ - in: query
+ name: offset
+ description: The number of batch jobs to skip before results.
+ schema:
+ type: integer
+ default: 0
+ - in: query
+ name: id
+ style: form
+ explode: false
+ description: Filter by the batch ID
+ schema:
+ oneOf:
+ - type: string
+ description: batch job ID
+ - type: array
+ description: multiple batch job IDs
+ items:
+ type: string
+ - in: query
+ name: type
+ style: form
+ explode: false
+ description: Filter by the batch type
+ schema:
+ type: array
+ items:
+ type: string
+ - in: query
+ name: confirmed_at
+ style: form
+ explode: false
+ description: >-
+ Date comparison for when resulting collections was confirmed, i.e.
+ less than, greater than etc.
+ schema:
+ type: object
+ properties:
+ lt:
+ type: string
+ description: filter by dates less than this date
+ format: date
+ gt:
+ type: string
+ description: filter by dates greater than this date
+ format: date
+ lte:
+ type: string
+ description: filter by dates less than or equal to this date
+ format: date
+ gte:
+ type: string
+ description: filter by dates greater than or equal to this date
+ format: date
+ - in: query
+ name: pre_processed_at
+ style: form
+ explode: false
+ description: >-
+ Date comparison for when resulting collections was pre processed,
+ i.e. less than, greater than etc.
+ schema:
+ type: object
+ properties:
+ lt:
+ type: string
+ description: filter by dates less than this date
+ format: date
+ gt:
+ type: string
+ description: filter by dates greater than this date
+ format: date
+ lte:
+ type: string
+ description: filter by dates less than or equal to this date
+ format: date
+ gte:
+ type: string
+ description: filter by dates greater than or equal to this date
+ format: date
+ - in: query
+ name: completed_at
+ style: form
+ explode: false
+ description: >-
+ Date comparison for when resulting collections was completed, i.e.
+ less than, greater than etc.
+ schema:
+ type: object
+ properties:
+ lt:
+ type: string
+ description: filter by dates less than this date
+ format: date
+ gt:
+ type: string
+ description: filter by dates greater than this date
+ format: date
+ lte:
+ type: string
+ description: filter by dates less than or equal to this date
+ format: date
+ gte:
+ type: string
+ description: filter by dates greater than or equal to this date
+ format: date
+ - in: query
+ name: failed_at
+ style: form
+ explode: false
+ description: >-
+ Date comparison for when resulting collections was failed, i.e. less
+ than, greater than etc.
+ schema:
+ type: object
+ properties:
+ lt:
+ type: string
+ description: filter by dates less than this date
+ format: date
+ gt:
+ type: string
+ description: filter by dates greater than this date
+ format: date
+ lte:
+ type: string
+ description: filter by dates less than or equal to this date
+ format: date
+ gte:
+ type: string
+ description: filter by dates greater than or equal to this date
+ format: date
+ - in: query
+ name: canceled_at
+ style: form
+ explode: false
+ description: >-
+ Date comparison for when resulting collections was canceled, i.e.
+ less than, greater than etc.
+ schema:
+ type: object
+ properties:
+ lt:
+ type: string
+ description: filter by dates less than this date
+ format: date
+ gt:
+ type: string
+ description: filter by dates greater than this date
+ format: date
+ lte:
+ type: string
+ description: filter by dates less than or equal to this date
+ format: date
+ gte:
+ type: string
+ description: filter by dates greater than or equal to this date
+ format: date
+ - in: query
+ name: order
+ description: Field used to order retrieved batch jobs
+ schema:
+ type: string
+ - in: query
+ name: expand
+ description: >-
+ (Comma separated) Which fields should be expanded in each order of
+ the result.
+ schema:
+ type: string
+ - in: query
+ name: fields
+ description: >-
+ (Comma separated) Which fields should be included in each order of
+ the result.
+ schema:
+ type: string
+ - in: query
+ name: created_at
+ style: form
+ explode: false
+ description: >-
+ Date comparison for when resulting collections was created, i.e.
+ less than, greater than etc.
+ schema:
+ type: object
+ properties:
+ lt:
+ type: string
+ description: filter by dates less than this date
+ format: date
+ gt:
+ type: string
+ description: filter by dates greater than this date
+ format: date
+ lte:
+ type: string
+ description: filter by dates less than or equal to this date
+ format: date
+ gte:
+ type: string
+ description: filter by dates greater than or equal to this date
+ format: date
+ - in: query
+ name: updated_at
+ style: form
+ explode: false
+ description: >-
+ Date comparison for when resulting collections was updated, i.e.
+ less than, greater than etc.
+ schema:
+ type: object
+ properties:
+ lt:
+ type: string
+ description: filter by dates less than this date
+ format: date
+ gt:
+ type: string
+ description: filter by dates greater than this date
+ format: date
+ lte:
+ type: string
+ description: filter by dates less than or equal to this date
+ format: date
+ gte:
+ type: string
+ description: filter by dates greater than or equal to this date
+ format: date
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source: >
+ import Medusa from "@medusajs/medusa-js"
+
+ const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
+ 3 })
+
+ // must be previously logged in or use api token
+
+ medusa.admin.batchJobs.list()
+
+ .then(({ batch_jobs, limit, offset, count }) => {
+ console.log(batch_jobs.length);
+ });
+ - lang: Shell
+ label: cURL
+ source: >
+ curl --location --request GET
+ 'https://medusa-url.com/admin/batch-jobs' \
+
+ --header 'Authorization: Bearer {api_token}'
+ security:
+ - api_token: []
+ - cookie_auth: []
+ tags:
+ - Batch Job
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ batch_jobs:
type: array
items:
- $ref: '#/components/schemas/Currency'
+ $ref: '#/components/schemas/BatchJob'
count:
type: integer
description: The total number of items available
@@ -515,24 +921,31 @@ paths:
limit:
type: integer
description: The number of items per page
- '/currencies/{code}':
- post:
- operationId: PostCurrenciesCurrency
- summary: Update a Currency
- description: Update a Currency
+ '400':
+ $ref: '#/components/responses/400_error'
+ '401':
+ $ref: '#/components/responses/unauthorized'
+ '404':
+ $ref: '#/components/responses/not_found_error'
+ '409':
+ $ref: '#/components/responses/invalid_state_error'
+ '422':
+ $ref: '#/components/responses/invalid_request_error'
+ '500':
+ $ref: '#/components/responses/500_error'
+ '/batch-jobs/{id}':
+ get:
+ operationId: GetBatchJobsBatchJob
+ summary: Get a Batch Job
+ description: Retrieves a Batch Job.
x-authenticated: true
parameters:
- in: path
- name: code
+ name: id
required: true
- description: The code of the Currency.
+ description: The ID of the Batch Job
schema:
type: string
- requestBody:
- content:
- application/json:
- schema:
- $ref: '#/components/schemas/AdminPostCurrenciesCurrencyReq'
x-codeSamples:
- lang: JavaScript
label: JS Client
@@ -544,28 +957,23 @@ paths:
// must be previously logged in or use api token
- medusa.admin.currencies.update(code, {
- includes_tax: true
- })
+ medusa.admin.batchJobs.retrieve(batch_job_id)
- .then(({ currency }) => {
- console.log(currency.id);
+ .then(({ batch_job }) => {
+ console.log(batch_job.id);
});
- lang: Shell
label: cURL
source: >
- curl --location --request POST
- 'https://medusa-url.com/admin/currencies/{code}' \
+ curl --location --request GET
+ 'https://medusa-url.com/admin/batch-jobs/{id}' \
- --header 'Authorization: Bearer {api_token}' \
-
- --header 'Content-Type: application/json' \
-
- --data-raw '{
- "includes_tax": true
- }'
+ --header 'Authorization: Bearer {api_token}'
+ security:
+ - api_token: []
+ - cookie_auth: []
tags:
- - Currency
+ - Batch Job
responses:
'200':
description: OK
@@ -574,8 +982,20 @@ paths:
schema:
type: object
properties:
- currency:
- $ref: '#/components/schemas/Currency'
+ batch_job:
+ $ref: '#/components/schemas/BatchJob'
+ '400':
+ $ref: '#/components/responses/400_error'
+ '401':
+ $ref: '#/components/responses/unauthorized'
+ '404':
+ $ref: '#/components/responses/not_found_error'
+ '409':
+ $ref: '#/components/responses/invalid_state_error'
+ '422':
+ $ref: '#/components/responses/invalid_request_error'
+ '500':
+ $ref: '#/components/responses/500_error'
'/collections/{id}/products/batch':
post:
operationId: PostProductsToCollection
@@ -1153,6 +1573,147 @@ paths:
$ref: '#/components/responses/invalid_request_error'
'500':
$ref: '#/components/responses/500_error'
+ /currencies:
+ get:
+ operationId: GetCurrencies
+ summary: List Currency
+ description: Retrieves a list of Currency
+ x-authenticated: true
+ parameters:
+ - in: query
+ name: code
+ description: Code of the currency to search for.
+ schema:
+ type: string
+ - in: query
+ name: includes_tax
+ description: Search for tax inclusive currencies.
+ schema:
+ type: boolean
+ - in: query
+ name: order
+ description: order to retrieve products in.
+ schema:
+ type: string
+ - in: query
+ name: offset
+ description: How many products to skip in the result.
+ schema:
+ type: number
+ default: '0'
+ - in: query
+ name: limit
+ description: Limit the number of products returned.
+ schema:
+ type: number
+ default: '20'
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source: >
+ import Medusa from "@medusajs/medusa-js"
+
+ const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
+ 3 })
+
+ // must be previously logged in or use api token
+
+ medusa.admin.currencies.list()
+
+ .then(({ currencies, count, offset, limit }) => {
+ console.log(currencies.length);
+ });
+ - lang: Shell
+ label: cURL
+ source: >
+ curl --location --request POST
+ 'https://medusa-url.com/admin/currencies' \
+
+ --header 'Authorization: Bearer {api_token}'
+ tags:
+ - Currency
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ currencies:
+ type: array
+ items:
+ $ref: '#/components/schemas/Currency'
+ count:
+ type: integer
+ description: The total number of items available
+ offset:
+ type: integer
+ description: The number of items skipped before these items
+ limit:
+ type: integer
+ description: The number of items per page
+ '/currencies/{code}':
+ post:
+ operationId: PostCurrenciesCurrency
+ summary: Update a Currency
+ description: Update a Currency
+ x-authenticated: true
+ parameters:
+ - in: path
+ name: code
+ required: true
+ description: The code of the Currency.
+ schema:
+ type: string
+ requestBody:
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/AdminPostCurrenciesCurrencyReq'
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source: >
+ import Medusa from "@medusajs/medusa-js"
+
+ const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
+ 3 })
+
+ // must be previously logged in or use api token
+
+ medusa.admin.currencies.update(code, {
+ includes_tax: true
+ })
+
+ .then(({ currency }) => {
+ console.log(currency.id);
+ });
+ - lang: Shell
+ label: cURL
+ source: >
+ curl --location --request POST
+ 'https://medusa-url.com/admin/currencies/{code}' \
+
+ --header 'Authorization: Bearer {api_token}' \
+
+ --header 'Content-Type: application/json' \
+
+ --data-raw '{
+ "includes_tax": true
+ }'
+ tags:
+ - Currency
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ currency:
+ $ref: '#/components/schemas/Currency'
'/customer-groups/{id}/customers/batch':
post:
operationId: PostCustomerGroupsGroupCustomersBatch
@@ -1885,567 +2446,6 @@ paths:
$ref: '#/components/responses/invalid_request_error'
'500':
$ref: '#/components/responses/500_error'
- '/batch-jobs/{id}/cancel':
- post:
- operationId: PostBatchJobsBatchJobCancel
- summary: Cancel a Batch Job
- description: Marks a batch job as canceled
- x-authenticated: true
- parameters:
- - in: path
- name: id
- required: true
- description: The ID of the batch job.
- schema:
- type: string
- x-codeSamples:
- - lang: JavaScript
- label: JS Client
- source: >
- import Medusa from "@medusajs/medusa-js"
-
- const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
- 3 })
-
- // must be previously logged in or use api token
-
- medusa.admin.batchJobs.cancel(batch_job_id)
-
- .then(({ batch_job }) => {
- console.log(batch_job.id);
- });
- - lang: Shell
- label: cURL
- source: >
- curl --location --request POST
- 'https://medusa-url.com/admin/batch-jobs/{id}/cancel' \
-
- --header 'Authorization: Bearer {api_token}'
- security:
- - api_token: []
- - cookie_auth: []
- tags:
- - Batch Job
- responses:
- '200':
- description: OK
- content:
- application/json:
- schema:
- type: object
- properties:
- batch_job:
- $ref: '#/components/schemas/BatchJob'
- '400':
- $ref: '#/components/responses/400_error'
- '401':
- $ref: '#/components/responses/unauthorized'
- '404':
- $ref: '#/components/responses/not_found_error'
- '409':
- $ref: '#/components/responses/invalid_state_error'
- '422':
- $ref: '#/components/responses/invalid_request_error'
- '500':
- $ref: '#/components/responses/500_error'
- '/batch-jobs/{id}/confirm':
- post:
- operationId: PostBatchJobsBatchJobConfirmProcessing
- summary: Confirm a Batch Job
- description: Confirms that a previously requested batch job should be executed.
- x-authenticated: true
- parameters:
- - in: path
- name: id
- required: true
- description: The ID of the batch job.
- schema:
- type: string
- x-codeSamples:
- - lang: JavaScript
- label: JS Client
- source: >
- import Medusa from "@medusajs/medusa-js"
-
- const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
- 3 })
-
- // must be previously logged in or use api token
-
- medusa.admin.batchJobs.confirm(batch_job_id)
-
- .then(({ batch_job }) => {
- console.log(batch_job.id);
- });
- - lang: Shell
- label: cURL
- source: >
- curl --location --request POST
- 'https://medusa-url.com/admin/batch-jobs/{id}/confirm' \
-
- --header 'Authorization: Bearer {api_token}'
- security:
- - api_token: []
- - cookie_auth: []
- tags:
- - Batch Job
- responses:
- '200':
- description: OK
- content:
- application/json:
- schema:
- type: object
- properties:
- batch_job:
- $ref: '#/components/schemas/BatchJob'
- '400':
- $ref: '#/components/responses/400_error'
- '401':
- $ref: '#/components/responses/unauthorized'
- '404':
- $ref: '#/components/responses/not_found_error'
- '409':
- $ref: '#/components/responses/invalid_state_error'
- '422':
- $ref: '#/components/responses/invalid_request_error'
- '500':
- $ref: '#/components/responses/500_error'
- /batch-jobs:
- post:
- operationId: PostBatchJobs
- summary: Create a Batch Job
- description: Creates a Batch Job.
- x-authenticated: true
- requestBody:
- content:
- application/json:
- schema:
- $ref: '#/components/schemas/AdminPostBatchesReq'
- x-codeSamples:
- - lang: JavaScript
- label: JS Client
- source: >
- import Medusa from "@medusajs/medusa-js"
-
- const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
- 3 })
-
- // must be previously logged in or use api token
-
- medusa.admin.batchJobs.create({
- type: 'product-export',
- context: {},
- dry_run: false
- }).then((({ batch_job }) => {
- console.log(batch_job.id);
- });
- - lang: Shell
- label: cURL
- source: >
- curl --location --request POST
- 'https://medusa-url.com/admin/batch-jobs' \
-
- --header 'Content-Type: application/json' \
-
- --header 'Authorization: Bearer {api_token}' \
-
- --data-raw '{
- "type": "product-export",
- "context": { }
- }'
- security:
- - api_token: []
- - cookie_auth: []
- tags:
- - Batch Job
- responses:
- '201':
- description: OK
- content:
- application/json:
- schema:
- type: object
- properties:
- batch_job:
- $ref: '#/components/schemas/BatchJob'
- '400':
- $ref: '#/components/responses/400_error'
- '401':
- $ref: '#/components/responses/unauthorized'
- '404':
- $ref: '#/components/responses/not_found_error'
- '409':
- $ref: '#/components/responses/invalid_state_error'
- '422':
- $ref: '#/components/responses/invalid_request_error'
- '500':
- $ref: '#/components/responses/500_error'
- get:
- operationId: GetBatchJobs
- summary: List Batch Jobs
- description: Retrieve a list of Batch Jobs.
- x-authenticated: true
- parameters:
- - in: query
- name: limit
- description: The number of batch jobs to return.
- schema:
- type: integer
- default: 10
- - in: query
- name: offset
- description: The number of batch jobs to skip before results.
- schema:
- type: integer
- default: 0
- - in: query
- name: id
- style: form
- explode: false
- description: Filter by the batch ID
- schema:
- oneOf:
- - type: string
- description: batch job ID
- - type: array
- description: multiple batch job IDs
- items:
- type: string
- - in: query
- name: type
- style: form
- explode: false
- description: Filter by the batch type
- schema:
- type: array
- items:
- type: string
- - in: query
- name: confirmed_at
- style: form
- explode: false
- description: >-
- Date comparison for when resulting collections was confirmed, i.e.
- less than, greater than etc.
- schema:
- type: object
- properties:
- lt:
- type: string
- description: filter by dates less than this date
- format: date
- gt:
- type: string
- description: filter by dates greater than this date
- format: date
- lte:
- type: string
- description: filter by dates less than or equal to this date
- format: date
- gte:
- type: string
- description: filter by dates greater than or equal to this date
- format: date
- - in: query
- name: pre_processed_at
- style: form
- explode: false
- description: >-
- Date comparison for when resulting collections was pre processed,
- i.e. less than, greater than etc.
- schema:
- type: object
- properties:
- lt:
- type: string
- description: filter by dates less than this date
- format: date
- gt:
- type: string
- description: filter by dates greater than this date
- format: date
- lte:
- type: string
- description: filter by dates less than or equal to this date
- format: date
- gte:
- type: string
- description: filter by dates greater than or equal to this date
- format: date
- - in: query
- name: completed_at
- style: form
- explode: false
- description: >-
- Date comparison for when resulting collections was completed, i.e.
- less than, greater than etc.
- schema:
- type: object
- properties:
- lt:
- type: string
- description: filter by dates less than this date
- format: date
- gt:
- type: string
- description: filter by dates greater than this date
- format: date
- lte:
- type: string
- description: filter by dates less than or equal to this date
- format: date
- gte:
- type: string
- description: filter by dates greater than or equal to this date
- format: date
- - in: query
- name: failed_at
- style: form
- explode: false
- description: >-
- Date comparison for when resulting collections was failed, i.e. less
- than, greater than etc.
- schema:
- type: object
- properties:
- lt:
- type: string
- description: filter by dates less than this date
- format: date
- gt:
- type: string
- description: filter by dates greater than this date
- format: date
- lte:
- type: string
- description: filter by dates less than or equal to this date
- format: date
- gte:
- type: string
- description: filter by dates greater than or equal to this date
- format: date
- - in: query
- name: canceled_at
- style: form
- explode: false
- description: >-
- Date comparison for when resulting collections was canceled, i.e.
- less than, greater than etc.
- schema:
- type: object
- properties:
- lt:
- type: string
- description: filter by dates less than this date
- format: date
- gt:
- type: string
- description: filter by dates greater than this date
- format: date
- lte:
- type: string
- description: filter by dates less than or equal to this date
- format: date
- gte:
- type: string
- description: filter by dates greater than or equal to this date
- format: date
- - in: query
- name: order
- description: Field used to order retrieved batch jobs
- schema:
- type: string
- - in: query
- name: expand
- description: >-
- (Comma separated) Which fields should be expanded in each order of
- the result.
- schema:
- type: string
- - in: query
- name: fields
- description: >-
- (Comma separated) Which fields should be included in each order of
- the result.
- schema:
- type: string
- - in: query
- name: created_at
- style: form
- explode: false
- description: >-
- Date comparison for when resulting collections was created, i.e.
- less than, greater than etc.
- schema:
- type: object
- properties:
- lt:
- type: string
- description: filter by dates less than this date
- format: date
- gt:
- type: string
- description: filter by dates greater than this date
- format: date
- lte:
- type: string
- description: filter by dates less than or equal to this date
- format: date
- gte:
- type: string
- description: filter by dates greater than or equal to this date
- format: date
- - in: query
- name: updated_at
- style: form
- explode: false
- description: >-
- Date comparison for when resulting collections was updated, i.e.
- less than, greater than etc.
- schema:
- type: object
- properties:
- lt:
- type: string
- description: filter by dates less than this date
- format: date
- gt:
- type: string
- description: filter by dates greater than this date
- format: date
- lte:
- type: string
- description: filter by dates less than or equal to this date
- format: date
- gte:
- type: string
- description: filter by dates greater than or equal to this date
- format: date
- x-codeSamples:
- - lang: JavaScript
- label: JS Client
- source: >
- import Medusa from "@medusajs/medusa-js"
-
- const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
- 3 })
-
- // must be previously logged in or use api token
-
- medusa.admin.batchJobs.list()
-
- .then(({ batch_jobs, limit, offset, count }) => {
- console.log(batch_jobs.length);
- });
- - lang: Shell
- label: cURL
- source: >
- curl --location --request GET
- 'https://medusa-url.com/admin/batch-jobs' \
-
- --header 'Authorization: Bearer {api_token}'
- security:
- - api_token: []
- - cookie_auth: []
- tags:
- - Batch Job
- responses:
- '200':
- description: OK
- content:
- application/json:
- schema:
- type: object
- properties:
- batch_jobs:
- type: array
- items:
- $ref: '#/components/schemas/BatchJob'
- count:
- type: integer
- description: The total number of items available
- offset:
- type: integer
- description: The number of items skipped before these items
- limit:
- type: integer
- description: The number of items per page
- '400':
- $ref: '#/components/responses/400_error'
- '401':
- $ref: '#/components/responses/unauthorized'
- '404':
- $ref: '#/components/responses/not_found_error'
- '409':
- $ref: '#/components/responses/invalid_state_error'
- '422':
- $ref: '#/components/responses/invalid_request_error'
- '500':
- $ref: '#/components/responses/500_error'
- '/batch-jobs/{id}':
- get:
- operationId: GetBatchJobsBatchJob
- summary: Get a Batch Job
- description: Retrieves a Batch Job.
- x-authenticated: true
- parameters:
- - in: path
- name: id
- required: true
- description: The ID of the Batch Job
- schema:
- type: string
- x-codeSamples:
- - lang: JavaScript
- label: JS Client
- source: >
- import Medusa from "@medusajs/medusa-js"
-
- const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
- 3 })
-
- // must be previously logged in or use api token
-
- medusa.admin.batchJobs.retrieve(batch_job_id)
-
- .then(({ batch_job }) => {
- console.log(batch_job.id);
- });
- - lang: Shell
- label: cURL
- source: >
- curl --location --request GET
- 'https://medusa-url.com/admin/batch-jobs/{id}' \
-
- --header 'Authorization: Bearer {api_token}'
- security:
- - api_token: []
- - cookie_auth: []
- tags:
- - Batch Job
- responses:
- '200':
- description: OK
- content:
- application/json:
- schema:
- type: object
- properties:
- batch_job:
- $ref: '#/components/schemas/BatchJob'
- '400':
- $ref: '#/components/responses/400_error'
- '401':
- $ref: '#/components/responses/unauthorized'
- '404':
- $ref: '#/components/responses/not_found_error'
- '409':
- $ref: '#/components/responses/invalid_state_error'
- '422':
- $ref: '#/components/responses/invalid_request_error'
- '500':
- $ref: '#/components/responses/500_error'
/customers:
post:
operationId: PostCustomers
@@ -9047,6 +9047,276 @@ paths:
$ref: '#/components/responses/invalid_request_error'
'500':
$ref: '#/components/responses/500_error'
+ '/payment-collections/{id}':
+ delete:
+ operationId: DeletePaymentCollectionsPaymentCollection
+ summary: Del a PaymentCollection
+ description: Deletes a Payment Collection
+ x-authenticated: true
+ parameters:
+ - in: path
+ name: id
+ required: true
+ description: The ID of the Payment Collection to delete.
+ schema:
+ type: string
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source: >
+ import Medusa from "@medusajs/medusa-js"
+
+ const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
+ 3 })
+
+ // must be previously logged in or use api token
+
+ medusa.admin.paymentCollections.delete(payment_collection_id)
+ .then(({ id, object, deleted }) => {
+ console.log(id)
+ })
+ - lang: Shell
+ label: cURL
+ source: >
+ curl --location --request DELETE
+ 'https://medusa-url.com/admin/payment-collections/{id}' \
+
+ --header 'Authorization: Bearer {api_token}'
+ security:
+ - api_token: []
+ - cookie_auth: []
+ tags:
+ - PaymentCollection
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ id:
+ type: string
+ description: The ID of the deleted Payment Collection.
+ object:
+ type: string
+ description: The type of the object that was deleted.
+ format: payment_collection
+ deleted:
+ type: boolean
+ description: Whether or not the Payment Collection was deleted.
+ default: true
+ '400':
+ $ref: '#/components/responses/400_error'
+ '401':
+ $ref: '#/components/responses/unauthorized'
+ get:
+ operationId: GetPaymentCollectionsPaymentCollection
+ summary: Get a PaymentCollection
+ description: Retrieves a PaymentCollection.
+ x-authenticated: true
+ parameters:
+ - in: path
+ name: id
+ required: true
+ description: The ID of the PaymentCollection.
+ schema:
+ type: string
+ - in: query
+ name: expand
+ description: Comma separated list of relations to include in the results.
+ schema:
+ type: string
+ - in: query
+ name: fields
+ description: Comma separated list of fields to include in the results.
+ schema:
+ type: string
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source: >
+ import Medusa from "@medusajs/medusa-js"
+
+ const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
+ 3 })
+
+ // must be previously logged in or use api token
+
+ medusa.admin.paymentCollections.retrieve(paymentCollectionId)
+ .then(({ payment_collection }) => {
+ console.log(payment_collection.id)
+ })
+ - lang: Shell
+ label: cURL
+ source: >
+ curl --location --request GET
+ 'https://medusa-url.com/admin/payment-collections/{id}' \
+
+ --header 'Authorization: Bearer {api_token}'
+ security:
+ - api_token: []
+ - cookie_auth: []
+ tags:
+ - PaymentCollection
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ payment_collection:
+ $ref: '#/components/schemas/PaymentCollection'
+ '400':
+ $ref: '#/components/responses/400_error'
+ '401':
+ $ref: '#/components/responses/unauthorized'
+ '404':
+ $ref: '#/components/responses/not_found_error'
+ '409':
+ $ref: '#/components/responses/invalid_state_error'
+ '422':
+ $ref: '#/components/responses/invalid_request_error'
+ '500':
+ $ref: '#/components/responses/500_error'
+ post:
+ operationId: PostPaymentCollectionsPaymentCollection
+ summary: Update PaymentCollection
+ description: Updates a PaymentCollection.
+ x-authenticated: true
+ parameters:
+ - in: path
+ name: id
+ required: true
+ description: The ID of the PaymentCollection.
+ schema:
+ type: string
+ requestBody:
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/AdminUpdatePaymentCollectionsReq'
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source: >
+ import Medusa from "@medusajs/medusa-js"
+
+ const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
+ 3 })
+
+ // must be previously logged in or use api token
+
+ medusa.admin.paymentCollections.update(payment_collection_id, {
+ description: "Description of payCol"
+ })
+ .then(({ payment_collection }) => {
+ console.log(payment_collection.id)
+ })
+ - lang: Shell
+ label: cURL
+ source: >
+ curl --location --request POST
+ 'https://medusa-url.com/admin/payment-collections/{id}' \
+
+ --header 'Authorization: Bearer {api_token}' \
+
+ --header 'Content-Type: application/json' \
+
+ --data-raw '{
+ "description": "Description of payCol"
+ }'
+ security:
+ - api_token: []
+ - cookie_auth: []
+ tags:
+ - PaymentCollection
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ payment_collection:
+ $ref: '#/components/schemas/PaymentCollection'
+ '400':
+ $ref: '#/components/responses/400_error'
+ '401':
+ $ref: '#/components/responses/unauthorized'
+ '404':
+ $ref: '#/components/responses/not_found_error'
+ '409':
+ $ref: '#/components/responses/invalid_state_error'
+ '422':
+ $ref: '#/components/responses/invalid_request_error'
+ '500':
+ $ref: '#/components/responses/500_error'
+ '/payment-collections/{id}/authorize':
+ post:
+ operationId: PostPaymentCollectionsPaymentCollectionAuthorize
+ summary: Mark Authorized
+ description: Sets the status of PaymentCollection as Authorized.
+ x-authenticated: true
+ parameters:
+ - in: path
+ name: id
+ required: true
+ description: The ID of the PaymentCollection.
+ schema:
+ type: string
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source: >
+ import Medusa from "@medusajs/medusa-js"
+
+ const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
+ 3 })
+
+ // must be previously logged in or use api token
+
+ medusa.admin.paymentCollections.markAsAuthorized(payment_collection_id)
+ .then(({ payment_collection }) => {
+ console.log(payment_collection.id)
+ })
+ - lang: Shell
+ label: cURL
+ source: >
+ curl --location --request POST
+ 'https://medusa-url.com/admin/payment-collections/{id}/authorize' \
+
+ --header 'Authorization: Bearer {api_token}'
+ security:
+ - api_token: []
+ - cookie_auth: []
+ tags:
+ - PaymentCollection
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ payment_collection:
+ $ref: '#/components/schemas/PaymentCollection'
+ '400':
+ $ref: '#/components/responses/400_error'
+ '401':
+ $ref: '#/components/responses/unauthorized'
+ '404':
+ $ref: '#/components/responses/not_found_error'
+ '409':
+ $ref: '#/components/responses/invalid_state_error'
+ '422':
+ $ref: '#/components/responses/invalid_request_error'
+ '500':
+ $ref: '#/components/responses/500_error'
'/payments/{id}/capture':
post:
operationId: PostPaymentsPaymentCapture
@@ -10312,7 +10582,7 @@ paths:
- api_token: []
- cookie_auth: []
tags:
- - Product
+ - Price List
responses:
'200':
description: OK
@@ -10346,276 +10616,6 @@ paths:
$ref: '#/components/responses/invalid_request_error'
'500':
$ref: '#/components/responses/500_error'
- '/payment-collections/{id}':
- delete:
- operationId: DeletePaymentCollectionsPaymentCollection
- summary: Del a PaymentCollection
- description: Deletes a Payment Collection
- x-authenticated: true
- parameters:
- - in: path
- name: id
- required: true
- description: The ID of the Payment Collection to delete.
- schema:
- type: string
- x-codeSamples:
- - lang: JavaScript
- label: JS Client
- source: >
- import Medusa from "@medusajs/medusa-js"
-
- const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
- 3 })
-
- // must be previously logged in or use api token
-
- medusa.admin.paymentCollections.delete(payment_collection_id)
- .then(({ id, object, deleted }) => {
- console.log(id)
- })
- - lang: Shell
- label: cURL
- source: >
- curl --location --request DELETE
- 'https://medusa-url.com/admin/payment-collections/{id}' \
-
- --header 'Authorization: Bearer {api_token}'
- security:
- - api_token: []
- - cookie_auth: []
- tags:
- - PaymentCollection
- responses:
- '200':
- description: OK
- content:
- application/json:
- schema:
- type: object
- properties:
- id:
- type: string
- description: The ID of the deleted Payment Collection.
- object:
- type: string
- description: The type of the object that was deleted.
- format: payment_collection
- deleted:
- type: boolean
- description: Whether or not the Payment Collection was deleted.
- default: true
- '400':
- $ref: '#/components/responses/400_error'
- '401':
- $ref: '#/components/responses/unauthorized'
- get:
- operationId: GetPaymentCollectionsPaymentCollection
- summary: Get a PaymentCollection
- description: Retrieves a PaymentCollection.
- x-authenticated: true
- parameters:
- - in: path
- name: id
- required: true
- description: The ID of the PaymentCollection.
- schema:
- type: string
- - in: query
- name: expand
- description: Comma separated list of relations to include in the results.
- schema:
- type: string
- - in: query
- name: fields
- description: Comma separated list of fields to include in the results.
- schema:
- type: string
- x-codeSamples:
- - lang: JavaScript
- label: JS Client
- source: >
- import Medusa from "@medusajs/medusa-js"
-
- const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
- 3 })
-
- // must be previously logged in or use api token
-
- medusa.admin.paymentCollections.retrieve(paymentCollectionId)
- .then(({ payment_collection }) => {
- console.log(payment_collection.id)
- })
- - lang: Shell
- label: cURL
- source: >
- curl --location --request GET
- 'https://medusa-url.com/admin/payment-collections/{id}' \
-
- --header 'Authorization: Bearer {api_token}'
- security:
- - api_token: []
- - cookie_auth: []
- tags:
- - PaymentCollection
- responses:
- '200':
- description: OK
- content:
- application/json:
- schema:
- type: object
- properties:
- payment_collection:
- $ref: '#/components/schemas/PaymentCollection'
- '400':
- $ref: '#/components/responses/400_error'
- '401':
- $ref: '#/components/responses/unauthorized'
- '404':
- $ref: '#/components/responses/not_found_error'
- '409':
- $ref: '#/components/responses/invalid_state_error'
- '422':
- $ref: '#/components/responses/invalid_request_error'
- '500':
- $ref: '#/components/responses/500_error'
- post:
- operationId: PostPaymentCollectionsPaymentCollection
- summary: Update PaymentCollection
- description: Updates a PaymentCollection.
- x-authenticated: true
- parameters:
- - in: path
- name: id
- required: true
- description: The ID of the PaymentCollection.
- schema:
- type: string
- requestBody:
- content:
- application/json:
- schema:
- $ref: '#/components/schemas/AdminUpdatePaymentCollectionsReq'
- x-codeSamples:
- - lang: JavaScript
- label: JS Client
- source: >
- import Medusa from "@medusajs/medusa-js"
-
- const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
- 3 })
-
- // must be previously logged in or use api token
-
- medusa.admin.paymentCollections.update(payment_collection_id, {
- description: "Description of payCol"
- })
- .then(({ payment_collection }) => {
- console.log(payment_collection.id)
- })
- - lang: Shell
- label: cURL
- source: >
- curl --location --request POST
- 'https://medusa-url.com/admin/payment-collections/{id}' \
-
- --header 'Authorization: Bearer {api_token}' \
-
- --header 'Content-Type: application/json' \
-
- --data-raw '{
- "description": "Description of payCol"
- }'
- security:
- - api_token: []
- - cookie_auth: []
- tags:
- - PaymentCollection
- responses:
- '200':
- description: OK
- content:
- application/json:
- schema:
- type: object
- properties:
- payment_collection:
- $ref: '#/components/schemas/PaymentCollection'
- '400':
- $ref: '#/components/responses/400_error'
- '401':
- $ref: '#/components/responses/unauthorized'
- '404':
- $ref: '#/components/responses/not_found_error'
- '409':
- $ref: '#/components/responses/invalid_state_error'
- '422':
- $ref: '#/components/responses/invalid_request_error'
- '500':
- $ref: '#/components/responses/500_error'
- '/payment-collections/{id}/authorize':
- post:
- operationId: PostPaymentCollectionsPaymentCollectionAuthorize
- summary: Mark Authorized
- description: Sets the status of PaymentCollection as Authorized.
- x-authenticated: true
- parameters:
- - in: path
- name: id
- required: true
- description: The ID of the PaymentCollection.
- schema:
- type: string
- x-codeSamples:
- - lang: JavaScript
- label: JS Client
- source: >
- import Medusa from "@medusajs/medusa-js"
-
- const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
- 3 })
-
- // must be previously logged in or use api token
-
- medusa.admin.paymentCollections.markAsAuthorized(payment_collection_id)
- .then(({ payment_collection }) => {
- console.log(payment_collection.id)
- })
- - lang: Shell
- label: cURL
- source: >
- curl --location --request POST
- 'https://medusa-url.com/admin/payment-collections/{id}/authorize' \
-
- --header 'Authorization: Bearer {api_token}'
- security:
- - api_token: []
- - cookie_auth: []
- tags:
- - PaymentCollection
- responses:
- '200':
- description: OK
- content:
- application/json:
- schema:
- type: object
- properties:
- payment_collection:
- $ref: '#/components/schemas/PaymentCollection'
- '400':
- $ref: '#/components/responses/400_error'
- '401':
- $ref: '#/components/responses/unauthorized'
- '404':
- $ref: '#/components/responses/not_found_error'
- '409':
- $ref: '#/components/responses/invalid_state_error'
- '422':
- $ref: '#/components/responses/invalid_request_error'
- '500':
- $ref: '#/components/responses/500_error'
/product-tags:
get:
operationId: GetProductTags
@@ -14418,6 +14418,638 @@ paths:
$ref: '#/components/responses/invalid_request_error'
'500':
$ref: '#/components/responses/500_error'
+ '/sales-channels/{id}/products/batch':
+ post:
+ operationId: PostSalesChannelsChannelProductsBatch
+ summary: Add Products
+ description: Assign a batch of product to a sales channel.
+ x-authenticated: true
+ parameters:
+ - in: path
+ name: id
+ required: true
+ description: The ID of the Sales channel.
+ schema:
+ type: string
+ requestBody:
+ content:
+ application/json:
+ schema:
+ $ref: >-
+ #/components/schemas/AdminPostSalesChannelsChannelProductsBatchReq
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source: >
+ import Medusa from "@medusajs/medusa-js"
+
+ const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
+ 3 })
+
+ // must be previously logged in or use api token
+
+ medusa.admin.salesChannels.addProducts(sales_channel_id, {
+ product_ids: [
+ {
+ id: product_id
+ }
+ ]
+ })
+
+ .then(({ sales_channel }) => {
+ console.log(sales_channel.id);
+ });
+ - lang: Shell
+ label: cURL
+ source: >
+ curl --location --request POST
+ 'https://medusa-url.com/admin/sales-channels/afasf/products/batch' \
+
+ --header 'Authorization: Bearer {api_token}' \
+
+ --header 'Content-Type: application/json' \
+
+ --data-raw '{
+ "product_ids": [
+ {
+ "id": "{product_id}"
+ }
+ ]
+ }'
+ security:
+ - api_token: []
+ - cookie_auth: []
+ tags:
+ - Sales Channel
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ sales_channel:
+ $ref: '#/components/schemas/SalesChannel'
+ '400':
+ $ref: '#/components/responses/400_error'
+ '401':
+ $ref: '#/components/responses/unauthorized'
+ '404':
+ $ref: '#/components/responses/not_found_error'
+ '409':
+ $ref: '#/components/responses/invalid_state_error'
+ '422':
+ $ref: '#/components/responses/invalid_request_error'
+ '500':
+ $ref: '#/components/responses/500_error'
+ delete:
+ operationId: DeleteSalesChannelsChannelProductsBatch
+ summary: Delete Products
+ description: Remove a list of products from a sales channel.
+ x-authenticated: true
+ parameters:
+ - in: path
+ name: id
+ required: true
+ description: The ID of the Sales Channel
+ schema:
+ type: string
+ requestBody:
+ content:
+ application/json:
+ schema:
+ $ref: >-
+ #/components/schemas/AdminDeleteSalesChannelsChannelProductsBatchReq
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source: >
+ import Medusa from "@medusajs/medusa-js"
+
+ const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
+ 3 })
+
+ // must be previously logged in or use api token
+
+ medusa.admin.salesChannels.removeProducts(sales_channel_id, {
+ product_ids: [
+ {
+ id: product_id
+ }
+ ]
+ })
+
+ .then(({ sales_channel }) => {
+ console.log(sales_channel.id);
+ });
+ - lang: Shell
+ label: cURL
+ source: >
+ curl --location --request DELETE
+ 'https://medusa-url.com/admin/sales-channels/{id}/products/batch' \
+
+ --header 'Authorization: Bearer {api_token}' \
+
+ --header 'Content-Type: application/json' \
+
+ --data-raw '{
+ "product_ids": [
+ {
+ "id": "{product_id}"
+ }
+ ]
+ }'
+ security:
+ - api_token: []
+ - cookie_auth: []
+ tags:
+ - Sales Channel
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ sales_channel:
+ $ref: '#/components/schemas/SalesChannel'
+ '400':
+ $ref: '#/components/responses/400_error'
+ '401':
+ $ref: '#/components/responses/unauthorized'
+ '404':
+ $ref: '#/components/responses/not_found_error'
+ '409':
+ $ref: '#/components/responses/invalid_state_error'
+ '422':
+ $ref: '#/components/responses/invalid_request_error'
+ '500':
+ $ref: '#/components/responses/500_error'
+ /sales-channels:
+ post:
+ operationId: PostSalesChannels
+ summary: Create a Sales Channel
+ description: Creates a Sales Channel.
+ x-authenticated: true
+ requestBody:
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/AdminPostSalesChannelsReq'
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source: >
+ import Medusa from "@medusajs/medusa-js"
+
+ const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
+ 3 })
+
+ // must be previously logged in or use api token
+
+ medusa.admin.salesChannels.create({
+ name: 'App',
+ description: 'Mobile app'
+ })
+
+ .then(({ sales_channel }) => {
+ console.log(sales_channel.id);
+ });
+ - lang: Shell
+ label: cURL
+ source: >
+ curl --location --request POST
+ 'https://medusa-url.com/admin/sales-channels' \
+
+ --header 'Authorization: Bearer {api_token}' \
+
+ --header 'Content-Type: application/json' \
+
+ --data-raw '{
+ "name": "App"
+ }'
+ security:
+ - api_token: []
+ - cookie_auth: []
+ tags:
+ - Sales Channel
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ sales_channel:
+ $ref: '#/components/schemas/SalesChannel'
+ '400':
+ $ref: '#/components/responses/400_error'
+ '401':
+ $ref: '#/components/responses/unauthorized'
+ '404':
+ $ref: '#/components/responses/not_found_error'
+ '409':
+ $ref: '#/components/responses/invalid_state_error'
+ '422':
+ $ref: '#/components/responses/invalid_request_error'
+ '500':
+ $ref: '#/components/responses/500_error'
+ get:
+ operationId: GetSalesChannels
+ summary: List Sales Channels
+ description: Retrieves a list of sales channels
+ x-authenticated: true
+ parameters:
+ - in: query
+ name: id
+ description: ID of the sales channel
+ schema:
+ type: string
+ - in: query
+ name: name
+ description: Name of the sales channel
+ schema:
+ type: string
+ - in: query
+ name: description
+ description: Description of the sales channel
+ schema:
+ type: string
+ - in: query
+ name: q
+ description: Query used for searching sales channels' names and descriptions.
+ schema:
+ type: string
+ - in: query
+ name: order
+ description: The field to order the results by.
+ schema:
+ type: string
+ - in: query
+ name: created_at
+ description: Date comparison for when resulting collections were created.
+ schema:
+ type: object
+ properties:
+ lt:
+ type: string
+ description: filter by dates less than this date
+ format: date
+ gt:
+ type: string
+ description: filter by dates greater than this date
+ format: date
+ lte:
+ type: string
+ description: filter by dates less than or equal to this date
+ format: date
+ gte:
+ type: string
+ description: filter by dates greater than or equal to this date
+ format: date
+ - in: query
+ name: updated_at
+ description: Date comparison for when resulting collections were updated.
+ schema:
+ type: object
+ properties:
+ lt:
+ type: string
+ description: filter by dates less than this date
+ format: date
+ gt:
+ type: string
+ description: filter by dates greater than this date
+ format: date
+ lte:
+ type: string
+ description: filter by dates less than or equal to this date
+ format: date
+ gte:
+ type: string
+ description: filter by dates greater than or equal to this date
+ format: date
+ - in: query
+ name: deleted_at
+ description: Date comparison for when resulting collections were deleted.
+ schema:
+ type: object
+ properties:
+ lt:
+ type: string
+ description: filter by dates less than this date
+ format: date
+ gt:
+ type: string
+ description: filter by dates greater than this date
+ format: date
+ lte:
+ type: string
+ description: filter by dates less than or equal to this date
+ format: date
+ gte:
+ type: string
+ description: filter by dates greater than or equal to this date
+ format: date
+ - in: query
+ name: offset
+ description: How many sales channels to skip in the result.
+ schema:
+ type: integer
+ default: 0
+ - in: query
+ name: limit
+ description: Limit the number of sales channels returned.
+ schema:
+ type: integer
+ default: 20
+ - in: query
+ name: expand
+ description: >-
+ (Comma separated) Which fields should be expanded in each sales
+ channel of the result.
+ schema:
+ type: string
+ - in: query
+ name: fields
+ description: >-
+ (Comma separated) Which fields should be included in each sales
+ channel of the result.
+ schema:
+ type: string
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source: >
+ import Medusa from "@medusajs/medusa-js"
+
+ const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
+ 3 })
+
+ // must be previously logged in or use api token
+
+ medusa.admin.salesChannels.list()
+
+ .then(({ sales_channels, limit, offset, count }) => {
+ console.log(sales_channels.length);
+ });
+ - lang: Shell
+ label: cURL
+ source: >
+ curl --location --request GET
+ 'https://medusa-url.com/admin/sales-channels' \
+
+ --header 'Authorization: Bearer {api_token}'
+ security:
+ - api_token: []
+ - cookie_auth: []
+ tags:
+ - Sales Channel
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ sales_channels:
+ type: array
+ items:
+ $ref: '#/components/schemas/SalesChannel'
+ count:
+ type: integer
+ description: The total number of items available
+ offset:
+ type: integer
+ description: The number of items skipped before these items
+ limit:
+ type: integer
+ description: The number of items per page
+ '400':
+ $ref: '#/components/responses/400_error'
+ '401':
+ $ref: '#/components/responses/unauthorized'
+ '404':
+ $ref: '#/components/responses/not_found_error'
+ '409':
+ $ref: '#/components/responses/invalid_state_error'
+ '422':
+ $ref: '#/components/responses/invalid_request_error'
+ '500':
+ $ref: '#/components/responses/500_error'
+ '/sales-channels/{id}':
+ delete:
+ operationId: DeleteSalesChannelsSalesChannel
+ summary: Delete a Sales Channel
+ description: Deletes the sales channel.
+ x-authenticated: true
+ parameters:
+ - in: path
+ name: id
+ required: true
+ description: The ID of the Sales channel.
+ schema:
+ type: string
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source: >
+ import Medusa from "@medusajs/medusa-js"
+
+ const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
+ 3 })
+
+ // must be previously logged in or use api token
+
+ medusa.admin.salesChannels.delete(sales_channel_id)
+
+ .then(({ id, object, deleted }) => {
+ console.log(id);
+ });
+ - lang: Shell
+ label: cURL
+ source: >
+ curl --location --request DELETE
+ 'https://medusa-url.com/admin/sales-channels/{id}' \
+
+ --header 'Authorization: Bearer {api_token}'
+ security:
+ - api_token: []
+ - cookie_auth: []
+ tags:
+ - Sales Channel
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ id:
+ type: string
+ description: The ID of the deleted sales channel
+ object:
+ type: string
+ description: The type of the object that was deleted.
+ default: sales-channel
+ deleted:
+ type: boolean
+ description: Whether or not the items were deleted.
+ default: true
+ '400':
+ $ref: '#/components/responses/400_error'
+ '401':
+ $ref: '#/components/responses/unauthorized'
+ '404':
+ $ref: '#/components/responses/not_found_error'
+ '409':
+ $ref: '#/components/responses/invalid_state_error'
+ '422':
+ $ref: '#/components/responses/invalid_request_error'
+ '500':
+ $ref: '#/components/responses/500_error'
+ get:
+ operationId: GetSalesChannelsSalesChannel
+ summary: Get a Sales Channel
+ description: Retrieves the sales channel.
+ x-authenticated: true
+ parameters:
+ - in: path
+ name: id
+ required: true
+ description: The ID of the Sales channel.
+ schema:
+ type: string
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source: >
+ import Medusa from "@medusajs/medusa-js"
+
+ const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
+ 3 })
+
+ // must be previously logged in or use api token
+
+ medusa.admin.salesChannels.retrieve(sales_channel_id)
+
+ .then(({ sales_channel }) => {
+ console.log(sales_channel.id);
+ });
+ - lang: Shell
+ label: cURL
+ source: >
+ curl --location --request GET
+ 'https://medusa-url.com/admin/sales-channels/{id}' \
+
+ --header 'Authorization: Bearer {api_token}'
+ security:
+ - api_token: []
+ - cookie_auth: []
+ tags:
+ - Sales Channel
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ sales_channel:
+ $ref: '#/components/schemas/SalesChannel'
+ '400':
+ $ref: '#/components/responses/400_error'
+ '401':
+ $ref: '#/components/responses/unauthorized'
+ '404':
+ $ref: '#/components/responses/not_found_error'
+ '409':
+ $ref: '#/components/responses/invalid_state_error'
+ '422':
+ $ref: '#/components/responses/invalid_request_error'
+ '500':
+ $ref: '#/components/responses/500_error'
+ post:
+ operationId: PostSalesChannelsSalesChannel
+ summary: Update a Sales Channel
+ description: Updates a Sales Channel.
+ x-authenticated: true
+ parameters:
+ - in: path
+ name: id
+ required: true
+ description: The ID of the Sales Channel.
+ schema:
+ type: string
+ requestBody:
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/AdminPostSalesChannelsSalesChannelReq'
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source: >
+ import Medusa from "@medusajs/medusa-js"
+
+ const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
+ 3 })
+
+ // must be previously logged in or use api token
+
+ medusa.admin.salesChannels.update(sales_channel_id, {
+ name: 'App'
+ })
+
+ .then(({ sales_channel }) => {
+ console.log(sales_channel.id);
+ });
+ - lang: Shell
+ label: cURL
+ source: >
+ curl --location --request POST
+ 'https://medusa-url.com/admin/sales-channels/{id}' \
+
+ --header 'Authorization: Bearer {api_token}' \
+
+ --header 'Content-Type: application/json' \
+
+ --data-raw '{
+ "name": "App"
+ }'
+ security:
+ - api_token: []
+ - cookie_auth: []
+ tags:
+ - Sales Channel
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ sales_channel:
+ $ref: '#/components/schemas/SalesChannel'
+ '400':
+ $ref: '#/components/responses/400_error'
+ '401':
+ $ref: '#/components/responses/unauthorized'
+ '404':
+ $ref: '#/components/responses/not_found_error'
+ '409':
+ $ref: '#/components/responses/invalid_state_error'
+ '422':
+ $ref: '#/components/responses/invalid_request_error'
+ '500':
+ $ref: '#/components/responses/500_error'
/shipping-options:
post:
operationId: PostShippingOptions
@@ -15127,638 +15759,6 @@ paths:
$ref: '#/components/responses/invalid_request_error'
'500':
$ref: '#/components/responses/500_error'
- '/sales-channels/{id}/products/batch':
- post:
- operationId: PostSalesChannelsChannelProductsBatch
- summary: Add Products
- description: Assign a batch of product to a sales channel.
- x-authenticated: true
- parameters:
- - in: path
- name: id
- required: true
- description: The ID of the Sales channel.
- schema:
- type: string
- requestBody:
- content:
- application/json:
- schema:
- $ref: >-
- #/components/schemas/AdminPostSalesChannelsChannelProductsBatchReq
- x-codeSamples:
- - lang: JavaScript
- label: JS Client
- source: >
- import Medusa from "@medusajs/medusa-js"
-
- const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
- 3 })
-
- // must be previously logged in or use api token
-
- medusa.admin.salesChannels.addProducts(sales_channel_id, {
- product_ids: [
- {
- id: product_id
- }
- ]
- })
-
- .then(({ sales_channel }) => {
- console.log(sales_channel.id);
- });
- - lang: Shell
- label: cURL
- source: >
- curl --location --request POST
- 'https://medusa-url.com/admin/sales-channels/afasf/products/batch' \
-
- --header 'Authorization: Bearer {api_token}' \
-
- --header 'Content-Type: application/json' \
-
- --data-raw '{
- "product_ids": [
- {
- "id": "{product_id}"
- }
- ]
- }'
- security:
- - api_token: []
- - cookie_auth: []
- tags:
- - Sales Channel
- responses:
- '200':
- description: OK
- content:
- application/json:
- schema:
- type: object
- properties:
- sales_channel:
- $ref: '#/components/schemas/SalesChannel'
- '400':
- $ref: '#/components/responses/400_error'
- '401':
- $ref: '#/components/responses/unauthorized'
- '404':
- $ref: '#/components/responses/not_found_error'
- '409':
- $ref: '#/components/responses/invalid_state_error'
- '422':
- $ref: '#/components/responses/invalid_request_error'
- '500':
- $ref: '#/components/responses/500_error'
- delete:
- operationId: DeleteSalesChannelsChannelProductsBatch
- summary: Delete Products
- description: Remove a list of products from a sales channel.
- x-authenticated: true
- parameters:
- - in: path
- name: id
- required: true
- description: The ID of the Sales Channel
- schema:
- type: string
- requestBody:
- content:
- application/json:
- schema:
- $ref: >-
- #/components/schemas/AdminDeleteSalesChannelsChannelProductsBatchReq
- x-codeSamples:
- - lang: JavaScript
- label: JS Client
- source: >
- import Medusa from "@medusajs/medusa-js"
-
- const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
- 3 })
-
- // must be previously logged in or use api token
-
- medusa.admin.salesChannels.removeProducts(sales_channel_id, {
- product_ids: [
- {
- id: product_id
- }
- ]
- })
-
- .then(({ sales_channel }) => {
- console.log(sales_channel.id);
- });
- - lang: Shell
- label: cURL
- source: >
- curl --location --request DELETE
- 'https://medusa-url.com/admin/sales-channels/{id}/products/batch' \
-
- --header 'Authorization: Bearer {api_token}' \
-
- --header 'Content-Type: application/json' \
-
- --data-raw '{
- "product_ids": [
- {
- "id": "{product_id}"
- }
- ]
- }'
- security:
- - api_token: []
- - cookie_auth: []
- tags:
- - Sales Channel
- responses:
- '200':
- description: OK
- content:
- application/json:
- schema:
- type: object
- properties:
- sales_channel:
- $ref: '#/components/schemas/SalesChannel'
- '400':
- $ref: '#/components/responses/400_error'
- '401':
- $ref: '#/components/responses/unauthorized'
- '404':
- $ref: '#/components/responses/not_found_error'
- '409':
- $ref: '#/components/responses/invalid_state_error'
- '422':
- $ref: '#/components/responses/invalid_request_error'
- '500':
- $ref: '#/components/responses/500_error'
- /sales-channels:
- post:
- operationId: PostSalesChannels
- summary: Create a Sales Channel
- description: Creates a Sales Channel.
- x-authenticated: true
- requestBody:
- content:
- application/json:
- schema:
- $ref: '#/components/schemas/AdminPostSalesChannelsReq'
- x-codeSamples:
- - lang: JavaScript
- label: JS Client
- source: >
- import Medusa from "@medusajs/medusa-js"
-
- const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
- 3 })
-
- // must be previously logged in or use api token
-
- medusa.admin.salesChannels.create({
- name: 'App',
- description: 'Mobile app'
- })
-
- .then(({ sales_channel }) => {
- console.log(sales_channel.id);
- });
- - lang: Shell
- label: cURL
- source: >
- curl --location --request POST
- 'https://medusa-url.com/admin/sales-channels' \
-
- --header 'Authorization: Bearer {api_token}' \
-
- --header 'Content-Type: application/json' \
-
- --data-raw '{
- "name": "App"
- }'
- security:
- - api_token: []
- - cookie_auth: []
- tags:
- - Sales Channel
- responses:
- '200':
- description: OK
- content:
- application/json:
- schema:
- type: object
- properties:
- sales_channel:
- $ref: '#/components/schemas/SalesChannel'
- '400':
- $ref: '#/components/responses/400_error'
- '401':
- $ref: '#/components/responses/unauthorized'
- '404':
- $ref: '#/components/responses/not_found_error'
- '409':
- $ref: '#/components/responses/invalid_state_error'
- '422':
- $ref: '#/components/responses/invalid_request_error'
- '500':
- $ref: '#/components/responses/500_error'
- get:
- operationId: GetSalesChannels
- summary: List Sales Channels
- description: Retrieves a list of sales channels
- x-authenticated: true
- parameters:
- - in: query
- name: id
- description: ID of the sales channel
- schema:
- type: string
- - in: query
- name: name
- description: Name of the sales channel
- schema:
- type: string
- - in: query
- name: description
- description: Description of the sales channel
- schema:
- type: string
- - in: query
- name: q
- description: Query used for searching sales channels' names and descriptions.
- schema:
- type: string
- - in: query
- name: order
- description: The field to order the results by.
- schema:
- type: string
- - in: query
- name: created_at
- description: Date comparison for when resulting collections were created.
- schema:
- type: object
- properties:
- lt:
- type: string
- description: filter by dates less than this date
- format: date
- gt:
- type: string
- description: filter by dates greater than this date
- format: date
- lte:
- type: string
- description: filter by dates less than or equal to this date
- format: date
- gte:
- type: string
- description: filter by dates greater than or equal to this date
- format: date
- - in: query
- name: updated_at
- description: Date comparison for when resulting collections were updated.
- schema:
- type: object
- properties:
- lt:
- type: string
- description: filter by dates less than this date
- format: date
- gt:
- type: string
- description: filter by dates greater than this date
- format: date
- lte:
- type: string
- description: filter by dates less than or equal to this date
- format: date
- gte:
- type: string
- description: filter by dates greater than or equal to this date
- format: date
- - in: query
- name: deleted_at
- description: Date comparison for when resulting collections were deleted.
- schema:
- type: object
- properties:
- lt:
- type: string
- description: filter by dates less than this date
- format: date
- gt:
- type: string
- description: filter by dates greater than this date
- format: date
- lte:
- type: string
- description: filter by dates less than or equal to this date
- format: date
- gte:
- type: string
- description: filter by dates greater than or equal to this date
- format: date
- - in: query
- name: offset
- description: How many sales channels to skip in the result.
- schema:
- type: integer
- default: 0
- - in: query
- name: limit
- description: Limit the number of sales channels returned.
- schema:
- type: integer
- default: 20
- - in: query
- name: expand
- description: >-
- (Comma separated) Which fields should be expanded in each sales
- channel of the result.
- schema:
- type: string
- - in: query
- name: fields
- description: >-
- (Comma separated) Which fields should be included in each sales
- channel of the result.
- schema:
- type: string
- x-codeSamples:
- - lang: JavaScript
- label: JS Client
- source: >
- import Medusa from "@medusajs/medusa-js"
-
- const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
- 3 })
-
- // must be previously logged in or use api token
-
- medusa.admin.salesChannels.list()
-
- .then(({ sales_channels, limit, offset, count }) => {
- console.log(sales_channels.length);
- });
- - lang: Shell
- label: cURL
- source: >
- curl --location --request GET
- 'https://medusa-url.com/admin/sales-channels' \
-
- --header 'Authorization: Bearer {api_token}'
- security:
- - api_token: []
- - cookie_auth: []
- tags:
- - Sales Channel
- responses:
- '200':
- description: OK
- content:
- application/json:
- schema:
- type: object
- properties:
- sales_channels:
- type: array
- items:
- $ref: '#/components/schemas/SalesChannel'
- count:
- type: integer
- description: The total number of items available
- offset:
- type: integer
- description: The number of items skipped before these items
- limit:
- type: integer
- description: The number of items per page
- '400':
- $ref: '#/components/responses/400_error'
- '401':
- $ref: '#/components/responses/unauthorized'
- '404':
- $ref: '#/components/responses/not_found_error'
- '409':
- $ref: '#/components/responses/invalid_state_error'
- '422':
- $ref: '#/components/responses/invalid_request_error'
- '500':
- $ref: '#/components/responses/500_error'
- '/sales-channels/{id}':
- delete:
- operationId: DeleteSalesChannelsSalesChannel
- summary: Delete a Sales Channel
- description: Deletes the sales channel.
- x-authenticated: true
- parameters:
- - in: path
- name: id
- required: true
- description: The ID of the Sales channel.
- schema:
- type: string
- x-codeSamples:
- - lang: JavaScript
- label: JS Client
- source: >
- import Medusa from "@medusajs/medusa-js"
-
- const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
- 3 })
-
- // must be previously logged in or use api token
-
- medusa.admin.salesChannels.delete(sales_channel_id)
-
- .then(({ id, object, deleted }) => {
- console.log(id);
- });
- - lang: Shell
- label: cURL
- source: >
- curl --location --request DELETE
- 'https://medusa-url.com/admin/sales-channels/{id}' \
-
- --header 'Authorization: Bearer {api_token}'
- security:
- - api_token: []
- - cookie_auth: []
- tags:
- - Sales Channel
- responses:
- '200':
- description: OK
- content:
- application/json:
- schema:
- type: object
- properties:
- id:
- type: string
- description: The ID of the deleted sales channel
- object:
- type: string
- description: The type of the object that was deleted.
- default: sales-channel
- deleted:
- type: boolean
- description: Whether or not the items were deleted.
- default: true
- '400':
- $ref: '#/components/responses/400_error'
- '401':
- $ref: '#/components/responses/unauthorized'
- '404':
- $ref: '#/components/responses/not_found_error'
- '409':
- $ref: '#/components/responses/invalid_state_error'
- '422':
- $ref: '#/components/responses/invalid_request_error'
- '500':
- $ref: '#/components/responses/500_error'
- get:
- operationId: GetSalesChannelsSalesChannel
- summary: Get a Sales Channel
- description: Retrieves the sales channel.
- x-authenticated: true
- parameters:
- - in: path
- name: id
- required: true
- description: The ID of the Sales channel.
- schema:
- type: string
- x-codeSamples:
- - lang: JavaScript
- label: JS Client
- source: >
- import Medusa from "@medusajs/medusa-js"
-
- const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
- 3 })
-
- // must be previously logged in or use api token
-
- medusa.admin.salesChannels.retrieve(sales_channel_id)
-
- .then(({ sales_channel }) => {
- console.log(sales_channel.id);
- });
- - lang: Shell
- label: cURL
- source: >
- curl --location --request GET
- 'https://medusa-url.com/admin/sales-channels/{id}' \
-
- --header 'Authorization: Bearer {api_token}'
- security:
- - api_token: []
- - cookie_auth: []
- tags:
- - Sales Channel
- responses:
- '200':
- description: OK
- content:
- application/json:
- schema:
- type: object
- properties:
- sales_channel:
- $ref: '#/components/schemas/SalesChannel'
- '400':
- $ref: '#/components/responses/400_error'
- '401':
- $ref: '#/components/responses/unauthorized'
- '404':
- $ref: '#/components/responses/not_found_error'
- '409':
- $ref: '#/components/responses/invalid_state_error'
- '422':
- $ref: '#/components/responses/invalid_request_error'
- '500':
- $ref: '#/components/responses/500_error'
- post:
- operationId: PostSalesChannelsSalesChannel
- summary: Update a Sales Channel
- description: Updates a Sales Channel.
- x-authenticated: true
- parameters:
- - in: path
- name: id
- required: true
- description: The ID of the Sales Channel.
- schema:
- type: string
- requestBody:
- content:
- application/json:
- schema:
- $ref: '#/components/schemas/AdminPostSalesChannelsSalesChannelReq'
- x-codeSamples:
- - lang: JavaScript
- label: JS Client
- source: >
- import Medusa from "@medusajs/medusa-js"
-
- const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
- 3 })
-
- // must be previously logged in or use api token
-
- medusa.admin.salesChannels.update(sales_channel_id, {
- name: 'App'
- })
-
- .then(({ sales_channel }) => {
- console.log(sales_channel.id);
- });
- - lang: Shell
- label: cURL
- source: >
- curl --location --request POST
- 'https://medusa-url.com/admin/sales-channels/{id}' \
-
- --header 'Authorization: Bearer {api_token}' \
-
- --header 'Content-Type: application/json' \
-
- --data-raw '{
- "name": "App"
- }'
- security:
- - api_token: []
- - cookie_auth: []
- tags:
- - Sales Channel
- responses:
- '200':
- description: OK
- content:
- application/json:
- schema:
- type: object
- properties:
- sales_channel:
- $ref: '#/components/schemas/SalesChannel'
- '400':
- $ref: '#/components/responses/400_error'
- '401':
- $ref: '#/components/responses/unauthorized'
- '404':
- $ref: '#/components/responses/not_found_error'
- '409':
- $ref: '#/components/responses/invalid_state_error'
- '422':
- $ref: '#/components/responses/invalid_request_error'
- '500':
- $ref: '#/components/responses/500_error'
'/store/currencies/{code}':
post:
operationId: PostStoreCurrenciesCode
@@ -17494,6 +17494,153 @@ paths:
$ref: '#/components/responses/invalid_request_error'
'500':
$ref: '#/components/responses/500_error'
+ delete:
+ operationId: AdminDeleteUploads
+ summary: Delete an Uploaded File
+ description: Removes an uploaded file using the installed fileservice
+ x-authenticated: true
+ requestBody:
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/AdminDeleteUploadsReq'
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source: >
+ import Medusa from "@medusajs/medusa-js"
+
+ const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
+ 3 })
+
+ // must be previously logged in or use api token
+
+ medusa.admin.uploads.delete({
+ file_key
+ })
+
+ .then(({ id, object, deleted }) => {
+ console.log(id);
+ });
+ - lang: Shell
+ label: cURL
+ source: >
+ curl --location --request DELETE
+ 'https://medusa-url.com/admin/uploads' \
+
+ --header 'Authorization: Bearer {api_token}' \
+
+ --header 'Content-Type: application/json' \
+
+ --data-raw '{
+ "file_key": "{file_key}"
+ }'
+ security:
+ - api_token: []
+ - cookie_auth: []
+ tags:
+ - Upload
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ id:
+ type: string
+ description: The file key of the upload deleted
+ object:
+ type: string
+ description: The type of the object that was deleted.
+ default: file
+ deleted:
+ type: boolean
+ description: Whether or not the items were deleted.
+ default: true
+ '400':
+ $ref: '#/components/responses/400_error'
+ '401':
+ $ref: '#/components/responses/unauthorized'
+ '404':
+ $ref: '#/components/responses/not_found_error'
+ '409':
+ $ref: '#/components/responses/invalid_state_error'
+ '422':
+ $ref: '#/components/responses/invalid_request_error'
+ '500':
+ $ref: '#/components/responses/500_error'
+ /uploads/download-url:
+ post:
+ operationId: PostUploadsDownloadUrl
+ summary: Get a File's Download URL
+ description: Creates a presigned download url for a file
+ x-authenticated: true
+ requestBody:
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/AdminPostUploadsDownloadUrlReq'
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source: >
+ import Medusa from "@medusajs/medusa-js"
+
+ const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
+ 3 })
+
+ // must be previously logged in or use api token
+
+ medusa.admin.uploads.getPresignedDownloadUrl({
+ file_key
+ })
+
+ .then(({ download_url }) => {
+ console.log(download_url);
+ });
+ - lang: Shell
+ label: cURL
+ source: >
+ curl --location --request POST
+ 'https://medusa-url.com/admin/uploads/download-url' \
+
+ --header 'Authorization: Bearer {api_token}' \
+
+ --header 'Content-Type: application/json' \
+
+ --data-raw '{
+ "file_key": "{file_key}"
+ }'
+ security:
+ - api_token: []
+ - cookie_auth: []
+ tags:
+ - Upload
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ download_url:
+ type: string
+ description: The Download URL of the file
+ '400':
+ $ref: '#/components/responses/400_error'
+ '401':
+ $ref: '#/components/responses/unauthorized'
+ '404':
+ $ref: '#/components/responses/not_found_error'
+ '409':
+ $ref: '#/components/responses/invalid_state_error'
+ '422':
+ $ref: '#/components/responses/invalid_request_error'
+ '500':
+ $ref: '#/components/responses/500_error'
/users:
post:
operationId: PostUsers
@@ -23831,12 +23978,43 @@ components:
type: string
description: The User's password.
format: password
- AdminPostCurrenciesCurrencyReq:
+ AdminPostBatchesReq:
type: object
+ required:
+ - type
+ - context
properties:
- includes_tax:
+ type:
+ type: string
+ description: The type of batch job to start.
+ example: product-export
+ context:
+ type: object
+ description: >-
+ Additional infomration regarding the batch to be used for
+ processing.
+ example:
+ shape:
+ prices:
+ - region: null
+ currency_code: eur
+ dynamicImageColumnCount: 4
+ dynamicOptionColumnCount: 2
+ list_config:
+ skip: 0
+ take: 50
+ order:
+ created_at: DESC
+ relations:
+ - variants
+ - variant.prices
+ - images
+ dry_run:
type: boolean
- description: '[EXPERIMENTAL] Tax included in prices of currency.'
+ description: >-
+ Set a batch job in dry_run mode to get some information on what will
+ be done without applying any modifications.
+ default: false
AdminPostProductsToCollectionReq:
type: object
required:
@@ -23889,6 +24067,12 @@ components:
metadata:
description: An optional set of key-value pairs to hold additional information.
type: object
+ AdminPostCurrenciesCurrencyReq:
+ type: object
+ properties:
+ includes_tax:
+ type: boolean
+ description: '[EXPERIMENTAL] Tax included in prices of currency.'
AdminPostCustomerGroupsGroupCustomersBatchReq:
type: object
required:
@@ -23928,43 +24112,6 @@ components:
metadata:
description: Metadata for the customer.
type: object
- AdminPostBatchesReq:
- type: object
- required:
- - type
- - context
- properties:
- type:
- type: string
- description: The type of batch job to start.
- example: product-export
- context:
- type: object
- description: >-
- Additional infomration regarding the batch to be used for
- processing.
- example:
- shape:
- prices:
- - region: null
- currency_code: eur
- dynamicImageColumnCount: 4
- dynamicOptionColumnCount: 2
- list_config:
- skip: 0
- take: 50
- order:
- created_at: DESC
- relations:
- - variants
- - variant.prices
- - images
- dry_run:
- type: boolean
- description: >-
- Set a batch job in dry_run mode to get some information on what will
- be done without applying any modifications.
- default: false
AdminPostCustomersReq:
type: object
required:
@@ -25216,6 +25363,15 @@ components:
A flag to indicate if no notifications should be emitted related to
the updated order.
type: boolean
+ AdminUpdatePaymentCollectionsReq:
+ type: object
+ properties:
+ description:
+ description: An optional description to create or update the payment collection.
+ type: string
+ metadata:
+ description: An optional set of key-value pairs to hold additional information.
+ type: object
AdminPostPaymentRefundsReq:
type: object
required:
@@ -25441,15 +25597,6 @@ components:
includes_tax:
description: '[EXPERIMENTAL] Tax included in prices of price list'
type: boolean
- AdminUpdatePaymentCollectionsReq:
- type: object
- properties:
- description:
- description: An optional description to create or update the payment collection.
- type: string
- metadata:
- description: An optional set of key-value pairs to hold additional information.
- type: object
AdminPostProductsProductOptionsReq:
type: object
required:
@@ -26364,6 +26511,64 @@ components:
refund:
description: The amount to refund.
type: number
+ AdminPostSalesChannelsChannelProductsBatchReq:
+ type: object
+ required:
+ - product_ids
+ properties:
+ product_ids:
+ description: The IDs of the products to add to the Sales Channel
+ type: array
+ items:
+ type: object
+ required:
+ - id
+ properties:
+ id:
+ type: string
+ description: The ID of the product
+ AdminPostSalesChannelsReq:
+ type: object
+ required:
+ - name
+ properties:
+ name:
+ description: The name of the Sales Channel
+ type: string
+ description:
+ description: The description of the Sales Channel
+ type: string
+ is_disabled:
+ description: Whether the Sales Channel is disabled or not.
+ type: boolean
+ AdminDeleteSalesChannelsChannelProductsBatchReq:
+ type: object
+ required:
+ - product_ids
+ properties:
+ product_ids:
+ description: The IDs of the products to delete from the Sales Channel.
+ type: array
+ items:
+ type: object
+ required:
+ - id
+ properties:
+ id:
+ description: The ID of a product
+ type: string
+ AdminPostSalesChannelsSalesChannelReq:
+ type: object
+ properties:
+ name:
+ type: string
+ description: Name of the sales channel.
+ description:
+ type: string
+ description: Sales Channel description.
+ is_disabled:
+ type: boolean
+ description: Indication of if the sales channel is active.
AdminPostShippingOptionsReq:
type: object
required:
@@ -26488,64 +26693,6 @@ components:
name:
description: The name of the Shipping Profile
type: string
- AdminPostSalesChannelsChannelProductsBatchReq:
- type: object
- required:
- - product_ids
- properties:
- product_ids:
- description: The IDs of the products to add to the Sales Channel
- type: array
- items:
- type: object
- required:
- - id
- properties:
- id:
- type: string
- description: The ID of the product
- AdminPostSalesChannelsReq:
- type: object
- required:
- - name
- properties:
- name:
- description: The name of the Sales Channel
- type: string
- description:
- description: The description of the Sales Channel
- type: string
- is_disabled:
- description: Whether the Sales Channel is disabled or not.
- type: boolean
- AdminDeleteSalesChannelsChannelProductsBatchReq:
- type: object
- required:
- - product_ids
- properties:
- product_ids:
- description: The IDs of the products to delete from the Sales Channel.
- type: array
- items:
- type: object
- required:
- - id
- properties:
- id:
- description: The ID of a product
- type: string
- AdminPostSalesChannelsSalesChannelReq:
- type: object
- properties:
- name:
- type: string
- description: Name of the sales channel.
- description:
- type: string
- description: Sales Channel description.
- is_disabled:
- type: boolean
- description: Indication of if the sales channel is active.
AdminPostStoreReq:
type: object
properties:
diff --git a/docs/api/admin-spec3.yaml b/docs/api/admin-spec3.yaml
index a6037a8437..b3a3a5a979 100644
--- a/docs/api/admin-spec3.yaml
+++ b/docs/api/admin-spec3.yaml
@@ -1573,6 +1573,147 @@ paths:
$ref: '#/components/responses/invalid_request_error'
'500':
$ref: '#/components/responses/500_error'
+ /currencies:
+ get:
+ operationId: GetCurrencies
+ summary: List Currency
+ description: Retrieves a list of Currency
+ x-authenticated: true
+ parameters:
+ - in: query
+ name: code
+ description: Code of the currency to search for.
+ schema:
+ type: string
+ - in: query
+ name: includes_tax
+ description: Search for tax inclusive currencies.
+ schema:
+ type: boolean
+ - in: query
+ name: order
+ description: order to retrieve products in.
+ schema:
+ type: string
+ - in: query
+ name: offset
+ description: How many products to skip in the result.
+ schema:
+ type: number
+ default: '0'
+ - in: query
+ name: limit
+ description: Limit the number of products returned.
+ schema:
+ type: number
+ default: '20'
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source: >
+ import Medusa from "@medusajs/medusa-js"
+
+ const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
+ 3 })
+
+ // must be previously logged in or use api token
+
+ medusa.admin.currencies.list()
+
+ .then(({ currencies, count, offset, limit }) => {
+ console.log(currencies.length);
+ });
+ - lang: Shell
+ label: cURL
+ source: >
+ curl --location --request POST
+ 'https://medusa-url.com/admin/currencies' \
+
+ --header 'Authorization: Bearer {api_token}'
+ tags:
+ - Currency
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ currencies:
+ type: array
+ items:
+ $ref: '#/components/schemas/Currency'
+ count:
+ type: integer
+ description: The total number of items available
+ offset:
+ type: integer
+ description: The number of items skipped before these items
+ limit:
+ type: integer
+ description: The number of items per page
+ '/currencies/{code}':
+ post:
+ operationId: PostCurrenciesCurrency
+ summary: Update a Currency
+ description: Update a Currency
+ x-authenticated: true
+ parameters:
+ - in: path
+ name: code
+ required: true
+ description: The code of the Currency.
+ schema:
+ type: string
+ requestBody:
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/AdminPostCurrenciesCurrencyReq'
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source: >
+ import Medusa from "@medusajs/medusa-js"
+
+ const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
+ 3 })
+
+ // must be previously logged in or use api token
+
+ medusa.admin.currencies.update(code, {
+ includes_tax: true
+ })
+
+ .then(({ currency }) => {
+ console.log(currency.id);
+ });
+ - lang: Shell
+ label: cURL
+ source: >
+ curl --location --request POST
+ 'https://medusa-url.com/admin/currencies/{code}' \
+
+ --header 'Authorization: Bearer {api_token}' \
+
+ --header 'Content-Type: application/json' \
+
+ --data-raw '{
+ "includes_tax": true
+ }'
+ tags:
+ - Currency
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ currency:
+ $ref: '#/components/schemas/Currency'
'/customer-groups/{id}/customers/batch':
post:
operationId: PostCustomerGroupsGroupCustomersBatch
@@ -2305,147 +2446,6 @@ paths:
$ref: '#/components/responses/invalid_request_error'
'500':
$ref: '#/components/responses/500_error'
- /currencies:
- get:
- operationId: GetCurrencies
- summary: List Currency
- description: Retrieves a list of Currency
- x-authenticated: true
- parameters:
- - in: query
- name: code
- description: Code of the currency to search for.
- schema:
- type: string
- - in: query
- name: includes_tax
- description: Search for tax inclusive currencies.
- schema:
- type: boolean
- - in: query
- name: order
- description: order to retrieve products in.
- schema:
- type: string
- - in: query
- name: offset
- description: How many products to skip in the result.
- schema:
- type: number
- default: '0'
- - in: query
- name: limit
- description: Limit the number of products returned.
- schema:
- type: number
- default: '20'
- x-codeSamples:
- - lang: JavaScript
- label: JS Client
- source: >
- import Medusa from "@medusajs/medusa-js"
-
- const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
- 3 })
-
- // must be previously logged in or use api token
-
- medusa.admin.currencies.list()
-
- .then(({ currencies, count, offset, limit }) => {
- console.log(currencies.length);
- });
- - lang: Shell
- label: cURL
- source: >
- curl --location --request POST
- 'https://medusa-url.com/admin/currencies' \
-
- --header 'Authorization: Bearer {api_token}'
- tags:
- - Currency
- responses:
- '200':
- description: OK
- content:
- application/json:
- schema:
- type: object
- properties:
- currencies:
- type: array
- items:
- $ref: '#/components/schemas/Currency'
- count:
- type: integer
- description: The total number of items available
- offset:
- type: integer
- description: The number of items skipped before these items
- limit:
- type: integer
- description: The number of items per page
- '/currencies/{code}':
- post:
- operationId: PostCurrenciesCurrency
- summary: Update a Currency
- description: Update a Currency
- x-authenticated: true
- parameters:
- - in: path
- name: code
- required: true
- description: The code of the Currency.
- schema:
- type: string
- requestBody:
- content:
- application/json:
- schema:
- $ref: '#/components/schemas/AdminPostCurrenciesCurrencyReq'
- x-codeSamples:
- - lang: JavaScript
- label: JS Client
- source: >
- import Medusa from "@medusajs/medusa-js"
-
- const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
- 3 })
-
- // must be previously logged in or use api token
-
- medusa.admin.currencies.update(code, {
- includes_tax: true
- })
-
- .then(({ currency }) => {
- console.log(currency.id);
- });
- - lang: Shell
- label: cURL
- source: >
- curl --location --request POST
- 'https://medusa-url.com/admin/currencies/{code}' \
-
- --header 'Authorization: Bearer {api_token}' \
-
- --header 'Content-Type: application/json' \
-
- --data-raw '{
- "includes_tax": true
- }'
- tags:
- - Currency
- responses:
- '200':
- description: OK
- content:
- application/json:
- schema:
- type: object
- properties:
- currency:
- $ref: '#/components/schemas/Currency'
/customers:
post:
operationId: PostCustomers
@@ -4170,372 +4170,6 @@ paths:
$ref: '#/components/responses/invalid_request_error'
'500':
$ref: '#/components/responses/500_error'
- /gift-cards:
- post:
- operationId: PostGiftCards
- summary: Create a Gift Card
- description: >-
- Creates a Gift Card that can redeemed by its unique code. The Gift Card
- is only valid within 1 region.
- x-authenticated: true
- requestBody:
- content:
- application/json:
- schema:
- $ref: '#/components/schemas/AdminPostGiftCardsReq'
- x-codeSamples:
- - lang: JavaScript
- label: JS Client
- source: >
- import Medusa from "@medusajs/medusa-js"
-
- const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
- 3 })
-
- // must be previously logged in or use api token
-
- medusa.admin.giftCards.create({
- region_id
- })
-
- .then(({ gift_card }) => {
- console.log(gift_card.id);
- });
- - lang: Shell
- label: cURL
- source: >
- curl --location --request POST
- 'https://medusa-url.com/admin/gift-cards' \
-
- --header 'Authorization: Bearer {api_token}' \
-
- --header 'Content-Type: application/json' \
-
- --data-raw '{
- "region_id": "{region_id}"
- }'
- security:
- - api_token: []
- - cookie_auth: []
- tags:
- - Gift Card
- responses:
- '200':
- description: OK
- content:
- application/json:
- schema:
- type: object
- properties:
- gift_card:
- $ref: '#/components/schemas/GiftCard'
- '400':
- $ref: '#/components/responses/400_error'
- '401':
- $ref: '#/components/responses/unauthorized'
- '404':
- $ref: '#/components/responses/not_found_error'
- '409':
- $ref: '#/components/responses/invalid_state_error'
- '422':
- $ref: '#/components/responses/invalid_request_error'
- '500':
- $ref: '#/components/responses/500_error'
- get:
- operationId: GetGiftCards
- summary: List Gift Cards
- description: Retrieves a list of Gift Cards.
- x-authenticated: true
- parameters:
- - in: query
- name: offset
- description: The number of items to skip before the results.
- schema:
- type: number
- default: '0'
- - in: query
- name: limit
- description: Limit the number of items returned.
- schema:
- type: number
- default: '50'
- - in: query
- name: q
- description: a search term to search by code or display ID
- schema:
- type: string
- x-codeSamples:
- - lang: JavaScript
- label: JS Client
- source: >
- import Medusa from "@medusajs/medusa-js"
-
- const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
- 3 })
-
- // must be previously logged in or use api token
-
- medusa.admin.giftCards.list()
-
- .then(({ gift_cards, limit, offset, count }) => {
- console.log(gift_cards.length);
- });
- - lang: Shell
- label: cURL
- source: >
- curl --location --request GET
- 'https://medusa-url.com/admin/gift-cards' \
-
- --header 'Authorization: Bearer {api_token}'
- security:
- - api_token: []
- - cookie_auth: []
- tags:
- - Gift Card
- responses:
- '200':
- description: OK
- content:
- application/json:
- schema:
- type: object
- properties:
- gift_cards:
- type: array
- items:
- $ref: '#/components/schemas/GiftCard'
- count:
- type: integer
- description: The total number of items available
- offset:
- type: integer
- description: The number of items skipped before these items
- limit:
- type: integer
- description: The number of items per page
- '400':
- $ref: '#/components/responses/400_error'
- '401':
- $ref: '#/components/responses/unauthorized'
- '404':
- $ref: '#/components/responses/not_found_error'
- '409':
- $ref: '#/components/responses/invalid_state_error'
- '422':
- $ref: '#/components/responses/invalid_request_error'
- '500':
- $ref: '#/components/responses/500_error'
- '/gift-cards/{id}':
- delete:
- operationId: DeleteGiftCardsGiftCard
- summary: Delete a Gift Card
- description: Deletes a Gift Card
- x-authenticated: true
- parameters:
- - in: path
- name: id
- required: true
- description: The ID of the Gift Card to delete.
- schema:
- type: string
- x-codeSamples:
- - lang: JavaScript
- label: JS Client
- source: >
- import Medusa from "@medusajs/medusa-js"
-
- const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
- 3 })
-
- // must be previously logged in or use api token
-
- medusa.admin.giftCards.delete(gift_card_id)
-
- .then(({ id, object, deleted }) => {
- console.log(id);
- });
- - lang: Shell
- label: cURL
- source: >
- curl --location --request DELETE
- 'https://medusa-url.com/admin/gift-cards/{id}' \
-
- --header 'Authorization: Bearer {api_token}'
- security:
- - api_token: []
- - cookie_auth: []
- tags:
- - Gift Card
- responses:
- '200':
- description: OK
- content:
- application/json:
- schema:
- type: object
- properties:
- id:
- type: string
- description: The ID of the deleted Gift Card
- object:
- type: string
- description: The type of the object that was deleted.
- default: gift-card
- deleted:
- type: boolean
- description: Whether the gift card was deleted successfully or not.
- default: true
- '400':
- $ref: '#/components/responses/400_error'
- '401':
- $ref: '#/components/responses/unauthorized'
- '404':
- $ref: '#/components/responses/not_found_error'
- '409':
- $ref: '#/components/responses/invalid_state_error'
- '422':
- $ref: '#/components/responses/invalid_request_error'
- '500':
- $ref: '#/components/responses/500_error'
- get:
- operationId: GetGiftCardsGiftCard
- summary: Get a Gift Card
- description: Retrieves a Gift Card.
- x-authenticated: true
- parameters:
- - in: path
- name: id
- required: true
- description: The ID of the Gift Card.
- schema:
- type: string
- x-codeSamples:
- - lang: JavaScript
- label: JS Client
- source: >
- import Medusa from "@medusajs/medusa-js"
-
- const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
- 3 })
-
- // must be previously logged in or use api token
-
- medusa.admin.giftCards.retrieve(gift_card_id)
-
- .then(({ gift_card }) => {
- console.log(gift_card.id);
- });
- - lang: Shell
- label: cURL
- source: >
- curl --location --request GET
- 'https://medusa-url.com/admin/gift-cards/{id}' \
-
- --header 'Authorization: Bearer {api_token}'
- security:
- - api_token: []
- - cookie_auth: []
- tags:
- - Gift Card
- responses:
- '200':
- description: OK
- content:
- application/json:
- schema:
- type: object
- properties:
- gift_card:
- $ref: '#/components/schemas/GiftCard'
- '400':
- $ref: '#/components/responses/400_error'
- '401':
- $ref: '#/components/responses/unauthorized'
- '404':
- $ref: '#/components/responses/not_found_error'
- '409':
- $ref: '#/components/responses/invalid_state_error'
- '422':
- $ref: '#/components/responses/invalid_request_error'
- '500':
- $ref: '#/components/responses/500_error'
- post:
- operationId: PostGiftCardsGiftCard
- summary: Update a Gift Card
- description: >-
- Update a Gift Card that can redeemed by its unique code. The Gift Card
- is only valid within 1 region.
- x-authenticated: true
- parameters:
- - in: path
- name: id
- required: true
- description: The ID of the Gift Card.
- schema:
- type: string
- requestBody:
- content:
- application/json:
- schema:
- $ref: '#/components/schemas/AdminPostGiftCardsGiftCardReq'
- x-codeSamples:
- - lang: JavaScript
- label: JS Client
- source: >
- import Medusa from "@medusajs/medusa-js"
-
- const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
- 3 })
-
- // must be previously logged in or use api token
-
- medusa.admin.giftCards.update(gift_card_id, {
- region_id
- })
-
- .then(({ gift_card }) => {
- console.log(gift_card.id);
- });
- - lang: Shell
- label: cURL
- source: >
- curl --location --request POST
- 'https://medusa-url.com/admin/gift-cards/{id}' \
-
- --header 'Authorization: Bearer {api_token}' \
-
- --header 'Content-Type: application/json' \
-
- --data-raw '{
- "region_id": "{region_id}"
- }'
- security:
- - api_token: []
- - cookie_auth: []
- tags:
- - Gift Card
- responses:
- '200':
- description: OK
- content:
- application/json:
- schema:
- type: object
- properties:
- gift_card:
- $ref: '#/components/schemas/GiftCard'
- '400':
- $ref: '#/components/responses/400_error'
- '401':
- $ref: '#/components/responses/unauthorized'
- '404':
- $ref: '#/components/responses/not_found_error'
- '409':
- $ref: '#/components/responses/invalid_state_error'
- '422':
- $ref: '#/components/responses/invalid_request_error'
- '500':
- $ref: '#/components/responses/500_error'
/draft-orders:
post:
operationId: PostDraftOrders
@@ -5215,6 +4849,372 @@ paths:
$ref: '#/components/responses/invalid_request_error'
'500':
$ref: '#/components/responses/500_error'
+ /gift-cards:
+ post:
+ operationId: PostGiftCards
+ summary: Create a Gift Card
+ description: >-
+ Creates a Gift Card that can redeemed by its unique code. The Gift Card
+ is only valid within 1 region.
+ x-authenticated: true
+ requestBody:
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/AdminPostGiftCardsReq'
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source: >
+ import Medusa from "@medusajs/medusa-js"
+
+ const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
+ 3 })
+
+ // must be previously logged in or use api token
+
+ medusa.admin.giftCards.create({
+ region_id
+ })
+
+ .then(({ gift_card }) => {
+ console.log(gift_card.id);
+ });
+ - lang: Shell
+ label: cURL
+ source: >
+ curl --location --request POST
+ 'https://medusa-url.com/admin/gift-cards' \
+
+ --header 'Authorization: Bearer {api_token}' \
+
+ --header 'Content-Type: application/json' \
+
+ --data-raw '{
+ "region_id": "{region_id}"
+ }'
+ security:
+ - api_token: []
+ - cookie_auth: []
+ tags:
+ - Gift Card
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ gift_card:
+ $ref: '#/components/schemas/GiftCard'
+ '400':
+ $ref: '#/components/responses/400_error'
+ '401':
+ $ref: '#/components/responses/unauthorized'
+ '404':
+ $ref: '#/components/responses/not_found_error'
+ '409':
+ $ref: '#/components/responses/invalid_state_error'
+ '422':
+ $ref: '#/components/responses/invalid_request_error'
+ '500':
+ $ref: '#/components/responses/500_error'
+ get:
+ operationId: GetGiftCards
+ summary: List Gift Cards
+ description: Retrieves a list of Gift Cards.
+ x-authenticated: true
+ parameters:
+ - in: query
+ name: offset
+ description: The number of items to skip before the results.
+ schema:
+ type: number
+ default: '0'
+ - in: query
+ name: limit
+ description: Limit the number of items returned.
+ schema:
+ type: number
+ default: '50'
+ - in: query
+ name: q
+ description: a search term to search by code or display ID
+ schema:
+ type: string
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source: >
+ import Medusa from "@medusajs/medusa-js"
+
+ const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
+ 3 })
+
+ // must be previously logged in or use api token
+
+ medusa.admin.giftCards.list()
+
+ .then(({ gift_cards, limit, offset, count }) => {
+ console.log(gift_cards.length);
+ });
+ - lang: Shell
+ label: cURL
+ source: >
+ curl --location --request GET
+ 'https://medusa-url.com/admin/gift-cards' \
+
+ --header 'Authorization: Bearer {api_token}'
+ security:
+ - api_token: []
+ - cookie_auth: []
+ tags:
+ - Gift Card
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ gift_cards:
+ type: array
+ items:
+ $ref: '#/components/schemas/GiftCard'
+ count:
+ type: integer
+ description: The total number of items available
+ offset:
+ type: integer
+ description: The number of items skipped before these items
+ limit:
+ type: integer
+ description: The number of items per page
+ '400':
+ $ref: '#/components/responses/400_error'
+ '401':
+ $ref: '#/components/responses/unauthorized'
+ '404':
+ $ref: '#/components/responses/not_found_error'
+ '409':
+ $ref: '#/components/responses/invalid_state_error'
+ '422':
+ $ref: '#/components/responses/invalid_request_error'
+ '500':
+ $ref: '#/components/responses/500_error'
+ '/gift-cards/{id}':
+ delete:
+ operationId: DeleteGiftCardsGiftCard
+ summary: Delete a Gift Card
+ description: Deletes a Gift Card
+ x-authenticated: true
+ parameters:
+ - in: path
+ name: id
+ required: true
+ description: The ID of the Gift Card to delete.
+ schema:
+ type: string
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source: >
+ import Medusa from "@medusajs/medusa-js"
+
+ const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
+ 3 })
+
+ // must be previously logged in or use api token
+
+ medusa.admin.giftCards.delete(gift_card_id)
+
+ .then(({ id, object, deleted }) => {
+ console.log(id);
+ });
+ - lang: Shell
+ label: cURL
+ source: >
+ curl --location --request DELETE
+ 'https://medusa-url.com/admin/gift-cards/{id}' \
+
+ --header 'Authorization: Bearer {api_token}'
+ security:
+ - api_token: []
+ - cookie_auth: []
+ tags:
+ - Gift Card
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ id:
+ type: string
+ description: The ID of the deleted Gift Card
+ object:
+ type: string
+ description: The type of the object that was deleted.
+ default: gift-card
+ deleted:
+ type: boolean
+ description: Whether the gift card was deleted successfully or not.
+ default: true
+ '400':
+ $ref: '#/components/responses/400_error'
+ '401':
+ $ref: '#/components/responses/unauthorized'
+ '404':
+ $ref: '#/components/responses/not_found_error'
+ '409':
+ $ref: '#/components/responses/invalid_state_error'
+ '422':
+ $ref: '#/components/responses/invalid_request_error'
+ '500':
+ $ref: '#/components/responses/500_error'
+ get:
+ operationId: GetGiftCardsGiftCard
+ summary: Get a Gift Card
+ description: Retrieves a Gift Card.
+ x-authenticated: true
+ parameters:
+ - in: path
+ name: id
+ required: true
+ description: The ID of the Gift Card.
+ schema:
+ type: string
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source: >
+ import Medusa from "@medusajs/medusa-js"
+
+ const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
+ 3 })
+
+ // must be previously logged in or use api token
+
+ medusa.admin.giftCards.retrieve(gift_card_id)
+
+ .then(({ gift_card }) => {
+ console.log(gift_card.id);
+ });
+ - lang: Shell
+ label: cURL
+ source: >
+ curl --location --request GET
+ 'https://medusa-url.com/admin/gift-cards/{id}' \
+
+ --header 'Authorization: Bearer {api_token}'
+ security:
+ - api_token: []
+ - cookie_auth: []
+ tags:
+ - Gift Card
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ gift_card:
+ $ref: '#/components/schemas/GiftCard'
+ '400':
+ $ref: '#/components/responses/400_error'
+ '401':
+ $ref: '#/components/responses/unauthorized'
+ '404':
+ $ref: '#/components/responses/not_found_error'
+ '409':
+ $ref: '#/components/responses/invalid_state_error'
+ '422':
+ $ref: '#/components/responses/invalid_request_error'
+ '500':
+ $ref: '#/components/responses/500_error'
+ post:
+ operationId: PostGiftCardsGiftCard
+ summary: Update a Gift Card
+ description: >-
+ Update a Gift Card that can redeemed by its unique code. The Gift Card
+ is only valid within 1 region.
+ x-authenticated: true
+ parameters:
+ - in: path
+ name: id
+ required: true
+ description: The ID of the Gift Card.
+ schema:
+ type: string
+ requestBody:
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/AdminPostGiftCardsGiftCardReq'
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source: >
+ import Medusa from "@medusajs/medusa-js"
+
+ const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
+ 3 })
+
+ // must be previously logged in or use api token
+
+ medusa.admin.giftCards.update(gift_card_id, {
+ region_id
+ })
+
+ .then(({ gift_card }) => {
+ console.log(gift_card.id);
+ });
+ - lang: Shell
+ label: cURL
+ source: >
+ curl --location --request POST
+ 'https://medusa-url.com/admin/gift-cards/{id}' \
+
+ --header 'Authorization: Bearer {api_token}' \
+
+ --header 'Content-Type: application/json' \
+
+ --data-raw '{
+ "region_id": "{region_id}"
+ }'
+ security:
+ - api_token: []
+ - cookie_auth: []
+ tags:
+ - Gift Card
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ gift_card:
+ $ref: '#/components/schemas/GiftCard'
+ '400':
+ $ref: '#/components/responses/400_error'
+ '401':
+ $ref: '#/components/responses/unauthorized'
+ '404':
+ $ref: '#/components/responses/not_found_error'
+ '409':
+ $ref: '#/components/responses/invalid_state_error'
+ '422':
+ $ref: '#/components/responses/invalid_request_error'
+ '500':
+ $ref: '#/components/responses/500_error'
/invites/accept:
post:
operationId: PostInvitesInviteAccept
@@ -9317,6 +9317,212 @@ paths:
$ref: '#/components/responses/invalid_request_error'
'500':
$ref: '#/components/responses/500_error'
+ '/payments/{id}/capture':
+ post:
+ operationId: PostPaymentsPaymentCapture
+ summary: Capture a Payment
+ description: Captures a Payment.
+ x-authenticated: true
+ parameters:
+ - in: path
+ name: id
+ required: true
+ description: The ID of the Payment.
+ schema:
+ type: string
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source: >
+ import Medusa from "@medusajs/medusa-js"
+
+ const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
+ 3 })
+
+ // must be previously logged in or use api token
+
+ medusa.admin.payments.capturePayment(payment_id)
+
+ .then(({ payment }) => {
+ console.log(payment.id);
+ });
+ - lang: Shell
+ label: cURL
+ source: >
+ curl --location --request POST
+ 'https://medusa-url.com/admin/payments/{id}/capture' \
+
+ --header 'Authorization: Bearer {api_token}'
+ security:
+ - api_token: []
+ - cookie_auth: []
+ tags:
+ - Payment
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ payment:
+ $ref: '#/components/schemas/Payment'
+ '400':
+ $ref: '#/components/responses/400_error'
+ '401':
+ $ref: '#/components/responses/unauthorized'
+ '404':
+ $ref: '#/components/responses/not_found_error'
+ '409':
+ $ref: '#/components/responses/invalid_state_error'
+ '422':
+ $ref: '#/components/responses/invalid_request_error'
+ '500':
+ $ref: '#/components/responses/500_error'
+ '/payments/{id}':
+ get:
+ operationId: GetPaymentsPayment
+ summary: Get Payment details
+ description: Retrieves the Payment details
+ x-authenticated: true
+ parameters:
+ - in: path
+ name: id
+ required: true
+ description: The ID of the Payment.
+ schema:
+ type: string
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source: >
+ import Medusa from "@medusajs/medusa-js"
+
+ const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
+ 3 })
+
+ // must be previously logged in or use api token
+
+ medusa.admin.payments.retrieve(payment_id)
+
+ .then(({ payment }) => {
+ console.log(payment.id);
+ });
+ - lang: Shell
+ label: cURL
+ source: >
+ curl --location --request GET
+ 'https://medusa-url.com/admin/payments/{id}' \
+
+ --header 'Authorization: Bearer {api_token}'
+ security:
+ - api_token: []
+ - cookie_auth: []
+ tags:
+ - Payment
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ payment:
+ $ref: '#/components/schemas/Payment'
+ '400':
+ $ref: '#/components/responses/400_error'
+ '401':
+ $ref: '#/components/responses/unauthorized'
+ '404':
+ $ref: '#/components/responses/not_found_error'
+ '409':
+ $ref: '#/components/responses/invalid_state_error'
+ '422':
+ $ref: '#/components/responses/invalid_request_error'
+ '500':
+ $ref: '#/components/responses/500_error'
+ '/payments/{id}/refund':
+ post:
+ operationId: PostPaymentsPaymentRefunds
+ summary: Create a Refund
+ description: Issues a Refund.
+ x-authenticated: true
+ parameters:
+ - in: path
+ name: id
+ required: true
+ description: The ID of the Payment.
+ schema:
+ type: string
+ requestBody:
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/AdminPostPaymentRefundsReq'
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source: >
+ import Medusa from "@medusajs/medusa-js"
+
+ const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
+ 3 })
+
+ // must be previously logged in or use api token
+
+ medusa.admin.payments.refundPayment(payment_id, {
+ amount: 1000,
+ reason: 'return',
+ note: 'Do not like it',
+ })
+
+ .then(({ payment }) => {
+ console.log(payment.id);
+ });
+ - lang: Shell
+ label: cURL
+ source: >
+ curl --location --request POST
+ 'https://medusa-url.com/admin/payments/pay_123/refund' \
+
+ --header 'Authorization: Bearer {api_token}' \
+
+ --header 'Content-Type: application/json' \
+
+ --data-raw '{
+ "amount": 1000,
+ "reason": "return",
+ "note": "Do not like it"
+ }'
+ security:
+ - api_token: []
+ - cookie_auth: []
+ tags:
+ - Payment
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ refund:
+ $ref: '#/components/schemas/Refund'
+ '400':
+ $ref: '#/components/responses/400_error'
+ '401':
+ $ref: '#/components/responses/unauthorized'
+ '404':
+ $ref: '#/components/responses/not_found_error'
+ '409':
+ $ref: '#/components/responses/invalid_state_error'
+ '422':
+ $ref: '#/components/responses/invalid_request_error'
+ '500':
+ $ref: '#/components/responses/500_error'
'/price-lists/{id}/prices/batch':
post:
operationId: PostPriceListsPriceListPricesBatch
@@ -10376,7 +10582,7 @@ paths:
- api_token: []
- cookie_auth: []
tags:
- - Product
+ - Price List
responses:
'200':
description: OK
@@ -10410,161 +10616,6 @@ paths:
$ref: '#/components/responses/invalid_request_error'
'500':
$ref: '#/components/responses/500_error'
- /product-types:
- get:
- operationId: GetProductTypes
- summary: List Product Types
- description: Retrieve a list of Product Types.
- x-authenticated: true
- parameters:
- - in: query
- name: limit
- description: The number of types to return.
- schema:
- type: integer
- default: 20
- - in: query
- name: offset
- description: The number of items to skip before the results.
- schema:
- type: integer
- default: 0
- - in: query
- name: order
- description: The field to sort items by.
- schema:
- type: string
- - in: query
- name: discount_condition_id
- description: The discount condition id on which to filter the product types.
- schema:
- type: string
- - in: query
- name: value
- style: form
- explode: false
- description: The type values to search for
- schema:
- type: array
- items:
- type: string
- - in: query
- name: id
- style: form
- explode: false
- description: The type IDs to search for
- schema:
- type: array
- items:
- type: string
- - in: query
- name: q
- description: A query string to search values for
- schema:
- type: string
- - in: query
- name: created_at
- description: Date comparison for when resulting product types were created.
- schema:
- type: object
- properties:
- lt:
- type: string
- description: filter by dates less than this date
- format: date
- gt:
- type: string
- description: filter by dates greater than this date
- format: date
- lte:
- type: string
- description: filter by dates less than or equal to this date
- format: date
- gte:
- type: string
- description: filter by dates greater than or equal to this date
- format: date
- - in: query
- name: updated_at
- description: Date comparison for when resulting product types were updated.
- schema:
- type: object
- properties:
- lt:
- type: string
- description: filter by dates less than this date
- format: date
- gt:
- type: string
- description: filter by dates greater than this date
- format: date
- lte:
- type: string
- description: filter by dates less than or equal to this date
- format: date
- gte:
- type: string
- description: filter by dates greater than or equal to this date
- format: date
- x-codeSamples:
- - lang: JavaScript
- label: JS Client
- source: >
- import Medusa from "@medusajs/medusa-js"
-
- const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
- 3 })
-
- // must be previously logged in or use api token
-
- medusa.admin.productTypes.list()
-
- .then(({ product_types }) => {
- console.log(product_types.length);
- });
- - lang: Shell
- label: cURL
- source: >
- curl --location --request GET
- 'https://medusa-url.com/admin/product-types' \
-
- --header 'Authorization: Bearer {api_token}'
- security:
- - api_token: []
- - cookie_auth: []
- tags:
- - Product Type
- responses:
- '200':
- description: OK
- content:
- application/json:
- schema:
- type: object
- properties:
- product_types:
- $ref: '#/components/schemas/ProductType'
- count:
- type: integer
- description: The total number of items available
- offset:
- type: integer
- description: The number of items skipped before these items
- limit:
- type: integer
- description: The number of items per page
- '400':
- $ref: '#/components/responses/400_error'
- '401':
- $ref: '#/components/responses/unauthorized'
- '404':
- $ref: '#/components/responses/not_found_error'
- '409':
- $ref: '#/components/responses/invalid_state_error'
- '422':
- $ref: '#/components/responses/invalid_request_error'
- '500':
- $ref: '#/components/responses/500_error'
/product-tags:
get:
operationId: GetProductTags
@@ -10720,6 +10771,161 @@ paths:
$ref: '#/components/responses/invalid_request_error'
'500':
$ref: '#/components/responses/500_error'
+ /product-types:
+ get:
+ operationId: GetProductTypes
+ summary: List Product Types
+ description: Retrieve a list of Product Types.
+ x-authenticated: true
+ parameters:
+ - in: query
+ name: limit
+ description: The number of types to return.
+ schema:
+ type: integer
+ default: 20
+ - in: query
+ name: offset
+ description: The number of items to skip before the results.
+ schema:
+ type: integer
+ default: 0
+ - in: query
+ name: order
+ description: The field to sort items by.
+ schema:
+ type: string
+ - in: query
+ name: discount_condition_id
+ description: The discount condition id on which to filter the product types.
+ schema:
+ type: string
+ - in: query
+ name: value
+ style: form
+ explode: false
+ description: The type values to search for
+ schema:
+ type: array
+ items:
+ type: string
+ - in: query
+ name: id
+ style: form
+ explode: false
+ description: The type IDs to search for
+ schema:
+ type: array
+ items:
+ type: string
+ - in: query
+ name: q
+ description: A query string to search values for
+ schema:
+ type: string
+ - in: query
+ name: created_at
+ description: Date comparison for when resulting product types were created.
+ schema:
+ type: object
+ properties:
+ lt:
+ type: string
+ description: filter by dates less than this date
+ format: date
+ gt:
+ type: string
+ description: filter by dates greater than this date
+ format: date
+ lte:
+ type: string
+ description: filter by dates less than or equal to this date
+ format: date
+ gte:
+ type: string
+ description: filter by dates greater than or equal to this date
+ format: date
+ - in: query
+ name: updated_at
+ description: Date comparison for when resulting product types were updated.
+ schema:
+ type: object
+ properties:
+ lt:
+ type: string
+ description: filter by dates less than this date
+ format: date
+ gt:
+ type: string
+ description: filter by dates greater than this date
+ format: date
+ lte:
+ type: string
+ description: filter by dates less than or equal to this date
+ format: date
+ gte:
+ type: string
+ description: filter by dates greater than or equal to this date
+ format: date
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source: >
+ import Medusa from "@medusajs/medusa-js"
+
+ const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
+ 3 })
+
+ // must be previously logged in or use api token
+
+ medusa.admin.productTypes.list()
+
+ .then(({ product_types }) => {
+ console.log(product_types.length);
+ });
+ - lang: Shell
+ label: cURL
+ source: >
+ curl --location --request GET
+ 'https://medusa-url.com/admin/product-types' \
+
+ --header 'Authorization: Bearer {api_token}'
+ security:
+ - api_token: []
+ - cookie_auth: []
+ tags:
+ - Product Type
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ product_types:
+ $ref: '#/components/schemas/ProductType'
+ count:
+ type: integer
+ description: The total number of items available
+ offset:
+ type: integer
+ description: The number of items skipped before these items
+ limit:
+ type: integer
+ description: The number of items per page
+ '400':
+ $ref: '#/components/responses/400_error'
+ '401':
+ $ref: '#/components/responses/unauthorized'
+ '404':
+ $ref: '#/components/responses/not_found_error'
+ '409':
+ $ref: '#/components/responses/invalid_state_error'
+ '422':
+ $ref: '#/components/responses/invalid_request_error'
+ '500':
+ $ref: '#/components/responses/500_error'
'/products/{id}/options':
post:
operationId: PostProductsProductOptions
@@ -12078,212 +12284,6 @@ paths:
$ref: '#/components/responses/invalid_request_error'
'500':
$ref: '#/components/responses/500_error'
- '/payments/{id}/capture':
- post:
- operationId: PostPaymentsPaymentCapture
- summary: Capture a Payment
- description: Captures a Payment.
- x-authenticated: true
- parameters:
- - in: path
- name: id
- required: true
- description: The ID of the Payment.
- schema:
- type: string
- x-codeSamples:
- - lang: JavaScript
- label: JS Client
- source: >
- import Medusa from "@medusajs/medusa-js"
-
- const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
- 3 })
-
- // must be previously logged in or use api token
-
- medusa.admin.payments.capturePayment(payment_id)
-
- .then(({ payment }) => {
- console.log(payment.id);
- });
- - lang: Shell
- label: cURL
- source: >
- curl --location --request POST
- 'https://medusa-url.com/admin/payments/{id}/capture' \
-
- --header 'Authorization: Bearer {api_token}'
- security:
- - api_token: []
- - cookie_auth: []
- tags:
- - Payment
- responses:
- '200':
- description: OK
- content:
- application/json:
- schema:
- type: object
- properties:
- payment:
- $ref: '#/components/schemas/Payment'
- '400':
- $ref: '#/components/responses/400_error'
- '401':
- $ref: '#/components/responses/unauthorized'
- '404':
- $ref: '#/components/responses/not_found_error'
- '409':
- $ref: '#/components/responses/invalid_state_error'
- '422':
- $ref: '#/components/responses/invalid_request_error'
- '500':
- $ref: '#/components/responses/500_error'
- '/payments/{id}':
- get:
- operationId: GetPaymentsPayment
- summary: Get Payment details
- description: Retrieves the Payment details
- x-authenticated: true
- parameters:
- - in: path
- name: id
- required: true
- description: The ID of the Payment.
- schema:
- type: string
- x-codeSamples:
- - lang: JavaScript
- label: JS Client
- source: >
- import Medusa from "@medusajs/medusa-js"
-
- const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
- 3 })
-
- // must be previously logged in or use api token
-
- medusa.admin.payments.retrieve(payment_id)
-
- .then(({ payment }) => {
- console.log(payment.id);
- });
- - lang: Shell
- label: cURL
- source: >
- curl --location --request GET
- 'https://medusa-url.com/admin/payments/{id}' \
-
- --header 'Authorization: Bearer {api_token}'
- security:
- - api_token: []
- - cookie_auth: []
- tags:
- - Payment
- responses:
- '200':
- description: OK
- content:
- application/json:
- schema:
- type: object
- properties:
- payment:
- $ref: '#/components/schemas/Payment'
- '400':
- $ref: '#/components/responses/400_error'
- '401':
- $ref: '#/components/responses/unauthorized'
- '404':
- $ref: '#/components/responses/not_found_error'
- '409':
- $ref: '#/components/responses/invalid_state_error'
- '422':
- $ref: '#/components/responses/invalid_request_error'
- '500':
- $ref: '#/components/responses/500_error'
- '/payments/{id}/refund':
- post:
- operationId: PostPaymentsPaymentRefunds
- summary: Create a Refund
- description: Issues a Refund.
- x-authenticated: true
- parameters:
- - in: path
- name: id
- required: true
- description: The ID of the Payment.
- schema:
- type: string
- requestBody:
- content:
- application/json:
- schema:
- $ref: '#/components/schemas/AdminPostPaymentRefundsReq'
- x-codeSamples:
- - lang: JavaScript
- label: JS Client
- source: >
- import Medusa from "@medusajs/medusa-js"
-
- const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
- 3 })
-
- // must be previously logged in or use api token
-
- medusa.admin.payments.refundPayment(payment_id, {
- amount: 1000,
- reason: 'return',
- note: 'Do not like it',
- })
-
- .then(({ payment }) => {
- console.log(payment.id);
- });
- - lang: Shell
- label: cURL
- source: >
- curl --location --request POST
- 'https://medusa-url.com/admin/payments/pay_123/refund' \
-
- --header 'Authorization: Bearer {api_token}' \
-
- --header 'Content-Type: application/json' \
-
- --data-raw '{
- "amount": 1000,
- "reason": "return",
- "note": "Do not like it"
- }'
- security:
- - api_token: []
- - cookie_auth: []
- tags:
- - Payment
- responses:
- '200':
- description: OK
- content:
- application/json:
- schema:
- type: object
- properties:
- refund:
- $ref: '#/components/schemas/Refund'
- '400':
- $ref: '#/components/responses/400_error'
- '401':
- $ref: '#/components/responses/unauthorized'
- '404':
- $ref: '#/components/responses/not_found_error'
- '409':
- $ref: '#/components/responses/invalid_state_error'
- '422':
- $ref: '#/components/responses/invalid_request_error'
- '500':
- $ref: '#/components/responses/500_error'
'/publishable-api-keys/{id}/sales-channels/batch':
post:
operationId: PostPublishableApiKeySalesChannelsChannelsBatch
@@ -14190,6 +14190,234 @@ paths:
$ref: '#/components/responses/invalid_request_error'
'500':
$ref: '#/components/responses/500_error'
+ '/returns/{id}/cancel':
+ post:
+ operationId: PostReturnsReturnCancel
+ summary: Cancel a Return
+ description: Registers a Return as canceled.
+ parameters:
+ - in: path
+ name: id
+ required: true
+ description: The ID of the Return.
+ schema:
+ type: string
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source: >
+ import Medusa from "@medusajs/medusa-js"
+
+ const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
+ 3 })
+
+ // must be previously logged in or use api token
+
+ medusa.admin.returns.cancel(return_id)
+
+ .then(({ order }) => {
+ console.log(order.id);
+ });
+ - lang: Shell
+ label: cURL
+ source: >
+ curl --location --request POST
+ 'https://medusa-url.com/admin/returns/{id}/cancel' \
+
+ --header 'Authorization: Bearer {api_token}'
+ security:
+ - api_token: []
+ - cookie_auth: []
+ tags:
+ - Return
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ order:
+ $ref: '#/components/schemas/Order'
+ '400':
+ $ref: '#/components/responses/400_error'
+ '401':
+ $ref: '#/components/responses/unauthorized'
+ '404':
+ $ref: '#/components/responses/not_found_error'
+ '409':
+ $ref: '#/components/responses/invalid_state_error'
+ '422':
+ $ref: '#/components/responses/invalid_request_error'
+ '500':
+ $ref: '#/components/responses/500_error'
+ /returns:
+ get:
+ operationId: GetReturns
+ summary: List Returns
+ description: Retrieves a list of Returns
+ parameters:
+ - in: query
+ name: limit
+ description: The upper limit for the amount of responses returned.
+ schema:
+ type: number
+ default: '50'
+ - in: query
+ name: offset
+ description: The offset of the list returned.
+ schema:
+ type: number
+ default: '0'
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source: >
+ import Medusa from "@medusajs/medusa-js"
+
+ const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
+ 3 })
+
+ // must be previously logged in or use api token
+
+ medusa.admin.returns.list()
+
+ .then(({ returns, limit, offset, count }) => {
+ console.log(returns.length);
+ });
+ - lang: Shell
+ label: cURL
+ source: >
+ curl --location --request GET 'https://medusa-url.com/admin/returns'
+ \
+
+ --header 'Authorization: Bearer {api_token}'
+ security:
+ - api_token: []
+ - cookie_auth: []
+ tags:
+ - Return
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ returns:
+ type: array
+ items:
+ $ref: '#/components/schemas/Return'
+ count:
+ type: integer
+ description: The total number of items available
+ offset:
+ type: integer
+ description: The number of items skipped before these items
+ limit:
+ type: integer
+ description: The number of items per page
+ '400':
+ $ref: '#/components/responses/400_error'
+ '401':
+ $ref: '#/components/responses/unauthorized'
+ '404':
+ $ref: '#/components/responses/not_found_error'
+ '409':
+ $ref: '#/components/responses/invalid_state_error'
+ '422':
+ $ref: '#/components/responses/invalid_request_error'
+ '500':
+ $ref: '#/components/responses/500_error'
+ '/returns/{id}/receive':
+ post:
+ operationId: PostReturnsReturnReceive
+ summary: Receive a Return
+ description: >-
+ Registers a Return as received. Updates statuses on Orders and Swaps
+ accordingly.
+ parameters:
+ - in: path
+ name: id
+ required: true
+ description: The ID of the Return.
+ schema:
+ type: string
+ requestBody:
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/AdminPostReturnsReturnReceiveReq'
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source: >
+ import Medusa from "@medusajs/medusa-js"
+
+ const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
+ 3 })
+
+ // must be previously logged in or use api token
+
+ medusa.admin.returns.receive(return_id, {
+ items: [
+ {
+ item_id,
+ quantity: 1
+ }
+ ]
+ })
+
+ .then((data) => {
+ console.log(data.return.id);
+ });
+ - lang: Shell
+ label: cURL
+ source: >
+ curl --location --request POST
+ 'https://medusa-url.com/admin/returns/{id}/receive' \
+
+ --header 'Authorization: Bearer {api_token}' \
+
+ --header 'Content-Type: application/json' \
+
+ --data-raw '{
+ "items": [
+ {
+ "item_id": "asafg",
+ "quantity": 1
+ }
+ ]
+ }'
+ security:
+ - api_token: []
+ - cookie_auth: []
+ tags:
+ - Return
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ return:
+ $ref: '#/components/schemas/Return'
+ '400':
+ $ref: '#/components/responses/400_error'
+ '401':
+ $ref: '#/components/responses/unauthorized'
+ '404':
+ $ref: '#/components/responses/not_found_error'
+ '409':
+ $ref: '#/components/responses/invalid_state_error'
+ '422':
+ $ref: '#/components/responses/invalid_request_error'
+ '500':
+ $ref: '#/components/responses/500_error'
'/sales-channels/{id}/products/batch':
post:
operationId: PostSalesChannelsChannelProductsBatch
@@ -14822,234 +15050,6 @@ paths:
$ref: '#/components/responses/invalid_request_error'
'500':
$ref: '#/components/responses/500_error'
- '/returns/{id}/cancel':
- post:
- operationId: PostReturnsReturnCancel
- summary: Cancel a Return
- description: Registers a Return as canceled.
- parameters:
- - in: path
- name: id
- required: true
- description: The ID of the Return.
- schema:
- type: string
- x-codeSamples:
- - lang: JavaScript
- label: JS Client
- source: >
- import Medusa from "@medusajs/medusa-js"
-
- const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
- 3 })
-
- // must be previously logged in or use api token
-
- medusa.admin.returns.cancel(return_id)
-
- .then(({ order }) => {
- console.log(order.id);
- });
- - lang: Shell
- label: cURL
- source: >
- curl --location --request POST
- 'https://medusa-url.com/admin/returns/{id}/cancel' \
-
- --header 'Authorization: Bearer {api_token}'
- security:
- - api_token: []
- - cookie_auth: []
- tags:
- - Return
- responses:
- '200':
- description: OK
- content:
- application/json:
- schema:
- type: object
- properties:
- order:
- $ref: '#/components/schemas/Order'
- '400':
- $ref: '#/components/responses/400_error'
- '401':
- $ref: '#/components/responses/unauthorized'
- '404':
- $ref: '#/components/responses/not_found_error'
- '409':
- $ref: '#/components/responses/invalid_state_error'
- '422':
- $ref: '#/components/responses/invalid_request_error'
- '500':
- $ref: '#/components/responses/500_error'
- /returns:
- get:
- operationId: GetReturns
- summary: List Returns
- description: Retrieves a list of Returns
- parameters:
- - in: query
- name: limit
- description: The upper limit for the amount of responses returned.
- schema:
- type: number
- default: '50'
- - in: query
- name: offset
- description: The offset of the list returned.
- schema:
- type: number
- default: '0'
- x-codeSamples:
- - lang: JavaScript
- label: JS Client
- source: >
- import Medusa from "@medusajs/medusa-js"
-
- const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
- 3 })
-
- // must be previously logged in or use api token
-
- medusa.admin.returns.list()
-
- .then(({ returns, limit, offset, count }) => {
- console.log(returns.length);
- });
- - lang: Shell
- label: cURL
- source: >
- curl --location --request GET 'https://medusa-url.com/admin/returns'
- \
-
- --header 'Authorization: Bearer {api_token}'
- security:
- - api_token: []
- - cookie_auth: []
- tags:
- - Return
- responses:
- '200':
- description: OK
- content:
- application/json:
- schema:
- type: object
- properties:
- returns:
- type: array
- items:
- $ref: '#/components/schemas/Return'
- count:
- type: integer
- description: The total number of items available
- offset:
- type: integer
- description: The number of items skipped before these items
- limit:
- type: integer
- description: The number of items per page
- '400':
- $ref: '#/components/responses/400_error'
- '401':
- $ref: '#/components/responses/unauthorized'
- '404':
- $ref: '#/components/responses/not_found_error'
- '409':
- $ref: '#/components/responses/invalid_state_error'
- '422':
- $ref: '#/components/responses/invalid_request_error'
- '500':
- $ref: '#/components/responses/500_error'
- '/returns/{id}/receive':
- post:
- operationId: PostReturnsReturnReceive
- summary: Receive a Return
- description: >-
- Registers a Return as received. Updates statuses on Orders and Swaps
- accordingly.
- parameters:
- - in: path
- name: id
- required: true
- description: The ID of the Return.
- schema:
- type: string
- requestBody:
- content:
- application/json:
- schema:
- $ref: '#/components/schemas/AdminPostReturnsReturnReceiveReq'
- x-codeSamples:
- - lang: JavaScript
- label: JS Client
- source: >
- import Medusa from "@medusajs/medusa-js"
-
- const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
- 3 })
-
- // must be previously logged in or use api token
-
- medusa.admin.returns.receive(return_id, {
- items: [
- {
- item_id,
- quantity: 1
- }
- ]
- })
-
- .then((data) => {
- console.log(data.return.id);
- });
- - lang: Shell
- label: cURL
- source: >
- curl --location --request POST
- 'https://medusa-url.com/admin/returns/{id}/receive' \
-
- --header 'Authorization: Bearer {api_token}' \
-
- --header 'Content-Type: application/json' \
-
- --data-raw '{
- "items": [
- {
- "item_id": "asafg",
- "quantity": 1
- }
- ]
- }'
- security:
- - api_token: []
- - cookie_auth: []
- tags:
- - Return
- responses:
- '200':
- description: OK
- content:
- application/json:
- schema:
- type: object
- properties:
- return:
- $ref: '#/components/schemas/Return'
- '400':
- $ref: '#/components/responses/400_error'
- '401':
- $ref: '#/components/responses/unauthorized'
- '404':
- $ref: '#/components/responses/not_found_error'
- '409':
- $ref: '#/components/responses/invalid_state_error'
- '422':
- $ref: '#/components/responses/invalid_request_error'
- '500':
- $ref: '#/components/responses/500_error'
/shipping-options:
post:
operationId: PostShippingOptions
@@ -15425,6 +15425,340 @@ paths:
$ref: '#/components/responses/invalid_request_error'
'500':
$ref: '#/components/responses/500_error'
+ /shipping-profiles:
+ post:
+ operationId: PostShippingProfiles
+ summary: Create a Shipping Profile
+ description: Creates a Shipping Profile
+ x-authenticated: true
+ requestBody:
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/AdminPostShippingProfilesReq'
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source: >
+ import Medusa from "@medusajs/medusa-js"
+
+ const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
+ 3 })
+
+ // must be previously logged in or use api token
+
+ medusa.admin.shippingProfiles.create({
+ name: 'Large Products'
+ })
+
+ .then(({ shipping_profile }) => {
+ console.log(shipping_profile.id);
+ });
+ - lang: Shell
+ label: cURL
+ source: >
+ curl --location --request POST
+ 'https://medusa-url.com/admin/shipping-profiles' \
+
+ --header 'Authorization: Bearer {api_token}' \
+
+ --header 'Content-Type: application/json' \
+
+ --data-raw '{
+ "name": "Large Products"
+ }'
+ security:
+ - api_token: []
+ - cookie_auth: []
+ tags:
+ - Shipping Profile
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ shipping_profile:
+ $ref: '#/components/schemas/ShippingProfile'
+ '400':
+ $ref: '#/components/responses/400_error'
+ '401':
+ $ref: '#/components/responses/unauthorized'
+ '404':
+ $ref: '#/components/responses/not_found_error'
+ '409':
+ $ref: '#/components/responses/invalid_state_error'
+ '422':
+ $ref: '#/components/responses/invalid_request_error'
+ '500':
+ $ref: '#/components/responses/500_error'
+ get:
+ operationId: GetShippingProfiles
+ summary: List Shipping Profiles
+ description: Retrieves a list of Shipping Profile.
+ x-authenticated: true
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source: >
+ import Medusa from "@medusajs/medusa-js"
+
+ const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
+ 3 })
+
+ // must be previously logged in or use api token
+
+ medusa.admin.shippingProfiles.list()
+
+ .then(({ shipping_profiles }) => {
+ console.log(shipping_profiles.length);
+ });
+ - lang: Shell
+ label: cURL
+ source: >
+ curl --location --request GET
+ 'https://medusa-url.com/admin/shipping-profiles' \
+
+ --header 'Authorization: Bearer {api_token}'
+ security:
+ - api_token: []
+ - cookie_auth: []
+ tags:
+ - Shipping Profile
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ shipping_profiles:
+ type: array
+ items:
+ $ref: '#/components/schemas/ShippingProfile'
+ '400':
+ $ref: '#/components/responses/400_error'
+ '401':
+ $ref: '#/components/responses/unauthorized'
+ '404':
+ $ref: '#/components/responses/not_found_error'
+ '409':
+ $ref: '#/components/responses/invalid_state_error'
+ '422':
+ $ref: '#/components/responses/invalid_request_error'
+ '500':
+ $ref: '#/components/responses/500_error'
+ '/shipping-profiles/{id}':
+ delete:
+ operationId: DeleteShippingProfilesProfile
+ summary: Delete a Shipping Profile
+ description: Deletes a Shipping Profile.
+ x-authenticated: true
+ parameters:
+ - in: path
+ name: id
+ required: true
+ description: The ID of the Shipping Profile.
+ schema:
+ type: string
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source: >
+ import Medusa from "@medusajs/medusa-js"
+
+ const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
+ 3 })
+
+ // must be previously logged in or use api token
+
+ medusa.admin.shippingProfiles.delete(profile_id)
+
+ .then(({ id, object, deleted }) => {
+ console.log(id);
+ });
+ - lang: Shell
+ label: cURL
+ source: >
+ curl --location --request DELETE
+ 'https://medusa-url.com/admin/shipping-profiles/{id}' \
+
+ --header 'Authorization: Bearer {api_token}'
+ security:
+ - api_token: []
+ - cookie_auth: []
+ tags:
+ - Shipping Profile
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ id:
+ type: string
+ description: The ID of the deleted Shipping Profile.
+ object:
+ type: string
+ description: The type of the object that was deleted.
+ default: shipping_profile
+ deleted:
+ type: boolean
+ description: Whether or not the items were deleted.
+ default: true
+ '400':
+ $ref: '#/components/responses/400_error'
+ '401':
+ $ref: '#/components/responses/unauthorized'
+ '404':
+ $ref: '#/components/responses/not_found_error'
+ '409':
+ $ref: '#/components/responses/invalid_state_error'
+ '422':
+ $ref: '#/components/responses/invalid_request_error'
+ '500':
+ $ref: '#/components/responses/500_error'
+ get:
+ operationId: GetShippingProfilesProfile
+ summary: Get a Shipping Profile
+ description: Retrieves a Shipping Profile.
+ x-authenticated: true
+ parameters:
+ - in: path
+ name: id
+ required: true
+ description: The ID of the Shipping Profile.
+ schema:
+ type: string
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source: >
+ import Medusa from "@medusajs/medusa-js"
+
+ const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
+ 3 })
+
+ // must be previously logged in or use api token
+
+ medusa.admin.shippingProfiles.retrieve(profile_id)
+
+ .then(({ shipping_profile }) => {
+ console.log(shipping_profile.id);
+ });
+ - lang: Shell
+ label: cURL
+ source: >
+ curl --location --request GET
+ 'https://medusa-url.com/admin/shipping-profiles/{id}' \
+
+ --header 'Authorization: Bearer {api_token}'
+ security:
+ - api_token: []
+ - cookie_auth: []
+ tags:
+ - Shipping Profile
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ shipping_profile:
+ $ref: '#/components/schemas/ShippingProfile'
+ '400':
+ $ref: '#/components/responses/400_error'
+ '401':
+ $ref: '#/components/responses/unauthorized'
+ '404':
+ $ref: '#/components/responses/not_found_error'
+ '409':
+ $ref: '#/components/responses/invalid_state_error'
+ '422':
+ $ref: '#/components/responses/invalid_request_error'
+ '500':
+ $ref: '#/components/responses/500_error'
+ post:
+ operationId: PostShippingProfilesProfile
+ summary: Update a Shipping Profile
+ description: Updates a Shipping Profile
+ parameters:
+ - in: path
+ name: id
+ required: true
+ description: The ID of the Shipping Profile.
+ schema:
+ type: string
+ requestBody:
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/AdminPostShippingProfilesProfileReq'
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source: >
+ import Medusa from "@medusajs/medusa-js"
+
+ const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
+ 3 })
+
+ // must be previously logged in or use api token
+
+ medusa.admin.shippingProfiles.update(shipping_profile_id, {
+ name: 'Large Products'
+ })
+
+ .then(({ shipping_profile }) => {
+ console.log(shipping_profile.id);
+ });
+ - lang: Shell
+ label: cURL
+ source: >
+ curl --location --request POST
+ 'https://medusa-url.com/admin/shipping-profiles/{id} \
+
+ --header 'Authorization: Bearer {api_token}' \
+
+ --header 'Content-Type: application/json' \
+
+ --data-raw '{
+ "name": "Large Products"
+ }'
+ security:
+ - api_token: []
+ - cookie_auth: []
+ tags:
+ - Shipping Profile
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ shipping_profile:
+ $ref: '#/components/schemas/ShippingProfile'
+ '400':
+ $ref: '#/components/responses/400_error'
+ '401':
+ $ref: '#/components/responses/unauthorized'
+ '404':
+ $ref: '#/components/responses/not_found_error'
+ '409':
+ $ref: '#/components/responses/invalid_state_error'
+ '422':
+ $ref: '#/components/responses/invalid_request_error'
+ '500':
+ $ref: '#/components/responses/500_error'
'/store/currencies/{code}':
post:
operationId: PostStoreCurrenciesCode
@@ -17000,340 +17334,6 @@ paths:
$ref: '#/components/responses/invalid_request_error'
'500':
$ref: '#/components/responses/500_error'
- /shipping-profiles:
- post:
- operationId: PostShippingProfiles
- summary: Create a Shipping Profile
- description: Creates a Shipping Profile
- x-authenticated: true
- requestBody:
- content:
- application/json:
- schema:
- $ref: '#/components/schemas/AdminPostShippingProfilesReq'
- x-codeSamples:
- - lang: JavaScript
- label: JS Client
- source: >
- import Medusa from "@medusajs/medusa-js"
-
- const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
- 3 })
-
- // must be previously logged in or use api token
-
- medusa.admin.shippingProfiles.create({
- name: 'Large Products'
- })
-
- .then(({ shipping_profile }) => {
- console.log(shipping_profile.id);
- });
- - lang: Shell
- label: cURL
- source: >
- curl --location --request POST
- 'https://medusa-url.com/admin/shipping-profiles' \
-
- --header 'Authorization: Bearer {api_token}' \
-
- --header 'Content-Type: application/json' \
-
- --data-raw '{
- "name": "Large Products"
- }'
- security:
- - api_token: []
- - cookie_auth: []
- tags:
- - Shipping Profile
- responses:
- '200':
- description: OK
- content:
- application/json:
- schema:
- type: object
- properties:
- shipping_profile:
- $ref: '#/components/schemas/ShippingProfile'
- '400':
- $ref: '#/components/responses/400_error'
- '401':
- $ref: '#/components/responses/unauthorized'
- '404':
- $ref: '#/components/responses/not_found_error'
- '409':
- $ref: '#/components/responses/invalid_state_error'
- '422':
- $ref: '#/components/responses/invalid_request_error'
- '500':
- $ref: '#/components/responses/500_error'
- get:
- operationId: GetShippingProfiles
- summary: List Shipping Profiles
- description: Retrieves a list of Shipping Profile.
- x-authenticated: true
- x-codeSamples:
- - lang: JavaScript
- label: JS Client
- source: >
- import Medusa from "@medusajs/medusa-js"
-
- const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
- 3 })
-
- // must be previously logged in or use api token
-
- medusa.admin.shippingProfiles.list()
-
- .then(({ shipping_profiles }) => {
- console.log(shipping_profiles.length);
- });
- - lang: Shell
- label: cURL
- source: >
- curl --location --request GET
- 'https://medusa-url.com/admin/shipping-profiles' \
-
- --header 'Authorization: Bearer {api_token}'
- security:
- - api_token: []
- - cookie_auth: []
- tags:
- - Shipping Profile
- responses:
- '200':
- description: OK
- content:
- application/json:
- schema:
- type: object
- properties:
- shipping_profiles:
- type: array
- items:
- $ref: '#/components/schemas/ShippingProfile'
- '400':
- $ref: '#/components/responses/400_error'
- '401':
- $ref: '#/components/responses/unauthorized'
- '404':
- $ref: '#/components/responses/not_found_error'
- '409':
- $ref: '#/components/responses/invalid_state_error'
- '422':
- $ref: '#/components/responses/invalid_request_error'
- '500':
- $ref: '#/components/responses/500_error'
- '/shipping-profiles/{id}':
- delete:
- operationId: DeleteShippingProfilesProfile
- summary: Delete a Shipping Profile
- description: Deletes a Shipping Profile.
- x-authenticated: true
- parameters:
- - in: path
- name: id
- required: true
- description: The ID of the Shipping Profile.
- schema:
- type: string
- x-codeSamples:
- - lang: JavaScript
- label: JS Client
- source: >
- import Medusa from "@medusajs/medusa-js"
-
- const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
- 3 })
-
- // must be previously logged in or use api token
-
- medusa.admin.shippingProfiles.delete(profile_id)
-
- .then(({ id, object, deleted }) => {
- console.log(id);
- });
- - lang: Shell
- label: cURL
- source: >
- curl --location --request DELETE
- 'https://medusa-url.com/admin/shipping-profiles/{id}' \
-
- --header 'Authorization: Bearer {api_token}'
- security:
- - api_token: []
- - cookie_auth: []
- tags:
- - Shipping Profile
- responses:
- '200':
- description: OK
- content:
- application/json:
- schema:
- type: object
- properties:
- id:
- type: string
- description: The ID of the deleted Shipping Profile.
- object:
- type: string
- description: The type of the object that was deleted.
- default: shipping_profile
- deleted:
- type: boolean
- description: Whether or not the items were deleted.
- default: true
- '400':
- $ref: '#/components/responses/400_error'
- '401':
- $ref: '#/components/responses/unauthorized'
- '404':
- $ref: '#/components/responses/not_found_error'
- '409':
- $ref: '#/components/responses/invalid_state_error'
- '422':
- $ref: '#/components/responses/invalid_request_error'
- '500':
- $ref: '#/components/responses/500_error'
- get:
- operationId: GetShippingProfilesProfile
- summary: Get a Shipping Profile
- description: Retrieves a Shipping Profile.
- x-authenticated: true
- parameters:
- - in: path
- name: id
- required: true
- description: The ID of the Shipping Profile.
- schema:
- type: string
- x-codeSamples:
- - lang: JavaScript
- label: JS Client
- source: >
- import Medusa from "@medusajs/medusa-js"
-
- const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
- 3 })
-
- // must be previously logged in or use api token
-
- medusa.admin.shippingProfiles.retrieve(profile_id)
-
- .then(({ shipping_profile }) => {
- console.log(shipping_profile.id);
- });
- - lang: Shell
- label: cURL
- source: >
- curl --location --request GET
- 'https://medusa-url.com/admin/shipping-profiles/{id}' \
-
- --header 'Authorization: Bearer {api_token}'
- security:
- - api_token: []
- - cookie_auth: []
- tags:
- - Shipping Profile
- responses:
- '200':
- description: OK
- content:
- application/json:
- schema:
- type: object
- properties:
- shipping_profile:
- $ref: '#/components/schemas/ShippingProfile'
- '400':
- $ref: '#/components/responses/400_error'
- '401':
- $ref: '#/components/responses/unauthorized'
- '404':
- $ref: '#/components/responses/not_found_error'
- '409':
- $ref: '#/components/responses/invalid_state_error'
- '422':
- $ref: '#/components/responses/invalid_request_error'
- '500':
- $ref: '#/components/responses/500_error'
- post:
- operationId: PostShippingProfilesProfile
- summary: Update a Shipping Profile
- description: Updates a Shipping Profile
- parameters:
- - in: path
- name: id
- required: true
- description: The ID of the Shipping Profile.
- schema:
- type: string
- requestBody:
- content:
- application/json:
- schema:
- $ref: '#/components/schemas/AdminPostShippingProfilesProfileReq'
- x-codeSamples:
- - lang: JavaScript
- label: JS Client
- source: >
- import Medusa from "@medusajs/medusa-js"
-
- const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
- 3 })
-
- // must be previously logged in or use api token
-
- medusa.admin.shippingProfiles.update(shipping_profile_id, {
- name: 'Large Products'
- })
-
- .then(({ shipping_profile }) => {
- console.log(shipping_profile.id);
- });
- - lang: Shell
- label: cURL
- source: >
- curl --location --request POST
- 'https://medusa-url.com/admin/shipping-profiles/{id} \
-
- --header 'Authorization: Bearer {api_token}' \
-
- --header 'Content-Type: application/json' \
-
- --data-raw '{
- "name": "Large Products"
- }'
- security:
- - api_token: []
- - cookie_auth: []
- tags:
- - Shipping Profile
- responses:
- '200':
- description: OK
- content:
- application/json:
- schema:
- type: object
- properties:
- shipping_profile:
- $ref: '#/components/schemas/ShippingProfile'
- '400':
- $ref: '#/components/responses/400_error'
- '401':
- $ref: '#/components/responses/unauthorized'
- '404':
- $ref: '#/components/responses/not_found_error'
- '409':
- $ref: '#/components/responses/invalid_state_error'
- '422':
- $ref: '#/components/responses/invalid_request_error'
- '500':
- $ref: '#/components/responses/500_error'
/uploads/protected:
post:
operationId: PostUploadsProtected
@@ -17494,6 +17494,153 @@ paths:
$ref: '#/components/responses/invalid_request_error'
'500':
$ref: '#/components/responses/500_error'
+ delete:
+ operationId: AdminDeleteUploads
+ summary: Delete an Uploaded File
+ description: Removes an uploaded file using the installed fileservice
+ x-authenticated: true
+ requestBody:
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/AdminDeleteUploadsReq'
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source: >
+ import Medusa from "@medusajs/medusa-js"
+
+ const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
+ 3 })
+
+ // must be previously logged in or use api token
+
+ medusa.admin.uploads.delete({
+ file_key
+ })
+
+ .then(({ id, object, deleted }) => {
+ console.log(id);
+ });
+ - lang: Shell
+ label: cURL
+ source: >
+ curl --location --request DELETE
+ 'https://medusa-url.com/admin/uploads' \
+
+ --header 'Authorization: Bearer {api_token}' \
+
+ --header 'Content-Type: application/json' \
+
+ --data-raw '{
+ "file_key": "{file_key}"
+ }'
+ security:
+ - api_token: []
+ - cookie_auth: []
+ tags:
+ - Upload
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ id:
+ type: string
+ description: The file key of the upload deleted
+ object:
+ type: string
+ description: The type of the object that was deleted.
+ default: file
+ deleted:
+ type: boolean
+ description: Whether or not the items were deleted.
+ default: true
+ '400':
+ $ref: '#/components/responses/400_error'
+ '401':
+ $ref: '#/components/responses/unauthorized'
+ '404':
+ $ref: '#/components/responses/not_found_error'
+ '409':
+ $ref: '#/components/responses/invalid_state_error'
+ '422':
+ $ref: '#/components/responses/invalid_request_error'
+ '500':
+ $ref: '#/components/responses/500_error'
+ /uploads/download-url:
+ post:
+ operationId: PostUploadsDownloadUrl
+ summary: Get a File's Download URL
+ description: Creates a presigned download url for a file
+ x-authenticated: true
+ requestBody:
+ content:
+ application/json:
+ schema:
+ $ref: '#/components/schemas/AdminPostUploadsDownloadUrlReq'
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source: >
+ import Medusa from "@medusajs/medusa-js"
+
+ const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
+ 3 })
+
+ // must be previously logged in or use api token
+
+ medusa.admin.uploads.getPresignedDownloadUrl({
+ file_key
+ })
+
+ .then(({ download_url }) => {
+ console.log(download_url);
+ });
+ - lang: Shell
+ label: cURL
+ source: >
+ curl --location --request POST
+ 'https://medusa-url.com/admin/uploads/download-url' \
+
+ --header 'Authorization: Bearer {api_token}' \
+
+ --header 'Content-Type: application/json' \
+
+ --data-raw '{
+ "file_key": "{file_key}"
+ }'
+ security:
+ - api_token: []
+ - cookie_auth: []
+ tags:
+ - Upload
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ download_url:
+ type: string
+ description: The Download URL of the file
+ '400':
+ $ref: '#/components/responses/400_error'
+ '401':
+ $ref: '#/components/responses/unauthorized'
+ '404':
+ $ref: '#/components/responses/not_found_error'
+ '409':
+ $ref: '#/components/responses/invalid_state_error'
+ '422':
+ $ref: '#/components/responses/invalid_request_error'
+ '500':
+ $ref: '#/components/responses/500_error'
/users:
post:
operationId: PostUsers
@@ -23920,6 +24067,12 @@ components:
metadata:
description: An optional set of key-value pairs to hold additional information.
type: object
+ AdminPostCurrenciesCurrencyReq:
+ type: object
+ properties:
+ includes_tax:
+ type: boolean
+ description: '[EXPERIMENTAL] Tax included in prices of currency.'
AdminPostCustomerGroupsGroupCustomersBatchReq:
type: object
required:
@@ -23959,12 +24112,6 @@ components:
metadata:
description: Metadata for the customer.
type: object
- AdminPostCurrenciesCurrencyReq:
- type: object
- properties:
- includes_tax:
- type: boolean
- description: '[EXPERIMENTAL] Tax included in prices of currency.'
AdminPostCustomersReq:
type: object
required:
@@ -24380,50 +24527,6 @@ components:
metadata:
description: An object containing metadata of the discount
type: object
- AdminPostGiftCardsReq:
- type: object
- required:
- - region_id
- properties:
- value:
- type: integer
- description: The value (excluding VAT) that the Gift Card should represent.
- is_disabled:
- type: boolean
- description: >-
- Whether the Gift Card is disabled on creation. You will have to
- enable it later to make it available to Customers.
- ends_at:
- type: string
- format: date-time
- description: The time at which the Gift Card should no longer be available.
- region_id:
- description: The ID of the Region in which the Gift Card can be used.
- type: string
- metadata:
- description: An optional set of key-value pairs to hold additional information.
- type: object
- AdminPostGiftCardsGiftCardReq:
- type: object
- properties:
- balance:
- type: integer
- description: The value (excluding VAT) that the Gift Card should represent.
- is_disabled:
- type: boolean
- description: >-
- Whether the Gift Card is disabled on creation. You will have to
- enable it later to make it available to Customers.
- ends_at:
- type: string
- format: date-time
- description: The time at which the Gift Card should no longer be available.
- region_id:
- description: The ID of the Region in which the Gift Card can be used.
- type: string
- metadata:
- description: An optional set of key-value pairs to hold additional information.
- type: object
AdminPostDraftOrdersReq:
type: object
required:
@@ -24606,6 +24709,50 @@ components:
The optional key-value map with additional details about the Line
Item.
type: object
+ AdminPostGiftCardsReq:
+ type: object
+ required:
+ - region_id
+ properties:
+ value:
+ type: integer
+ description: The value (excluding VAT) that the Gift Card should represent.
+ is_disabled:
+ type: boolean
+ description: >-
+ Whether the Gift Card is disabled on creation. You will have to
+ enable it later to make it available to Customers.
+ ends_at:
+ type: string
+ format: date-time
+ description: The time at which the Gift Card should no longer be available.
+ region_id:
+ description: The ID of the Region in which the Gift Card can be used.
+ type: string
+ metadata:
+ description: An optional set of key-value pairs to hold additional information.
+ type: object
+ AdminPostGiftCardsGiftCardReq:
+ type: object
+ properties:
+ balance:
+ type: integer
+ description: The value (excluding VAT) that the Gift Card should represent.
+ is_disabled:
+ type: boolean
+ description: >-
+ Whether the Gift Card is disabled on creation. You will have to
+ enable it later to make it available to Customers.
+ ends_at:
+ type: string
+ format: date-time
+ description: The time at which the Gift Card should no longer be available.
+ region_id:
+ description: The ID of the Region in which the Gift Card can be used.
+ type: string
+ metadata:
+ description: An optional set of key-value pairs to hold additional information.
+ type: object
AdminPostInvitesInviteAcceptReq:
type: object
required:
@@ -25225,6 +25372,21 @@ components:
metadata:
description: An optional set of key-value pairs to hold additional information.
type: object
+ AdminPostPaymentRefundsReq:
+ type: object
+ required:
+ - amount
+ - reason
+ properties:
+ amount:
+ description: The amount to refund.
+ type: integer
+ reason:
+ description: The reason for the Refund.
+ type: string
+ note:
+ description: A note with additional details about the Refund.
+ type: string
AdminPostPriceListPricesPricesReq:
type: object
properties:
@@ -26109,21 +26271,6 @@ components:
value:
description: The value to give for the Product Option.
type: string
- AdminPostPaymentRefundsReq:
- type: object
- required:
- - amount
- - reason
- properties:
- amount:
- description: The amount to refund.
- type: integer
- reason:
- description: The reason for the Refund.
- type: string
- note:
- description: A note with additional details about the Refund.
- type: string
AdminPostPublishableApiKeySalesChannelsBatchReq:
type: object
required:
@@ -26342,6 +26489,28 @@ components:
metadata:
description: An optional set of key-value pairs with additional information.
type: object
+ AdminPostReturnsReturnReceiveReq:
+ type: object
+ required:
+ - items
+ properties:
+ items:
+ description: The Line Items that have been received.
+ type: array
+ items:
+ required:
+ - item_id
+ - quantity
+ properties:
+ item_id:
+ description: The ID of the Line Item.
+ type: string
+ quantity:
+ description: The quantity of the Line Item.
+ type: integer
+ refund:
+ description: The amount to refund.
+ type: number
AdminPostSalesChannelsChannelProductsBatchReq:
type: object
required:
@@ -26400,28 +26569,6 @@ components:
is_disabled:
type: boolean
description: Indication of if the sales channel is active.
- AdminPostReturnsReturnReceiveReq:
- type: object
- required:
- - items
- properties:
- items:
- description: The Line Items that have been received.
- type: array
- items:
- required:
- - item_id
- - quantity
- properties:
- item_id:
- description: The ID of the Line Item.
- type: string
- quantity:
- description: The quantity of the Line Item.
- type: integer
- refund:
- description: The amount to refund.
- type: number
AdminPostShippingOptionsReq:
type: object
required:
@@ -26532,6 +26679,20 @@ components:
includes_tax:
description: '[EXPERIMENTAL] Tax included in prices of shipping option'
type: boolean
+ AdminPostShippingProfilesReq:
+ type: object
+ required:
+ - name
+ properties:
+ name:
+ description: The name of the Shipping Profile
+ type: string
+ AdminPostShippingProfilesProfileReq:
+ type: object
+ properties:
+ name:
+ description: The name of the Shipping Profile
+ type: string
AdminPostStoreReq:
type: object
properties:
@@ -26695,20 +26856,6 @@ components:
description: The IDs of the types of products associated with this tax rate
items:
type: string
- AdminPostShippingProfilesReq:
- type: object
- required:
- - name
- properties:
- name:
- description: The name of the Shipping Profile
- type: string
- AdminPostShippingProfilesProfileReq:
- type: object
- properties:
- name:
- description: The name of the Shipping Profile
- type: string
AdminDeleteUploadsReq:
type: object
required:
diff --git a/docs/api/admin/code_samples/JavaScript/uploads/deleteundefined b/docs/api/admin/code_samples/JavaScript/uploads/deleteundefined
new file mode 100644
index 0000000000..1b560d5144
--- /dev/null
+++ b/docs/api/admin/code_samples/JavaScript/uploads/deleteundefined
@@ -0,0 +1,9 @@
+import Medusa from "@medusajs/medusa-js"
+const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries: 3 })
+// must be previously logged in or use api token
+medusa.admin.uploads.delete({
+ file_key
+})
+.then(({ id, object, deleted }) => {
+ console.log(id);
+});
diff --git a/docs/api/admin/code_samples/JavaScript/uploads_download-url/postundefined b/docs/api/admin/code_samples/JavaScript/uploads_download-url/postundefined
new file mode 100644
index 0000000000..b84c168eff
--- /dev/null
+++ b/docs/api/admin/code_samples/JavaScript/uploads_download-url/postundefined
@@ -0,0 +1,9 @@
+import Medusa from "@medusajs/medusa-js"
+const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries: 3 })
+// must be previously logged in or use api token
+medusa.admin.uploads.getPresignedDownloadUrl({
+ file_key
+})
+.then(({ download_url }) => {
+ console.log(download_url);
+});
diff --git a/docs/api/admin/code_samples/Shell/uploads/deleteundefined b/docs/api/admin/code_samples/Shell/uploads/deleteundefined
new file mode 100644
index 0000000000..6f97468764
--- /dev/null
+++ b/docs/api/admin/code_samples/Shell/uploads/deleteundefined
@@ -0,0 +1,6 @@
+curl --location --request DELETE 'https://medusa-url.com/admin/uploads' \
+--header 'Authorization: Bearer {api_token}' \
+--header 'Content-Type: application/json' \
+--data-raw '{
+ "file_key": "{file_key}"
+}'
diff --git a/docs/api/admin/code_samples/Shell/uploads_download-url/postundefined b/docs/api/admin/code_samples/Shell/uploads_download-url/postundefined
new file mode 100644
index 0000000000..11f150c77c
--- /dev/null
+++ b/docs/api/admin/code_samples/Shell/uploads_download-url/postundefined
@@ -0,0 +1,6 @@
+curl --location --request POST 'https://medusa-url.com/admin/uploads/download-url' \
+--header 'Authorization: Bearer {api_token}' \
+--header 'Content-Type: application/json' \
+--data-raw '{
+ "file_key": "{file_key}"
+}'
diff --git a/docs/api/admin/openapi.yaml b/docs/api/admin/openapi.yaml
index 6ba3e06b4c..7f8928e73c 100644
--- a/docs/api/admin/openapi.yaml
+++ b/docs/api/admin/openapi.yaml
@@ -193,6 +193,10 @@ paths:
$ref: paths/collections.yaml
/collections/{id}:
$ref: paths/collections_{id}.yaml
+ /currencies:
+ $ref: paths/currencies.yaml
+ /currencies/{code}:
+ $ref: paths/currencies_{code}.yaml
/customer-groups/{id}/customers/batch:
$ref: paths/customer-groups_{id}_customers_batch.yaml
/customer-groups:
@@ -201,10 +205,6 @@ paths:
$ref: paths/customer-groups_{id}.yaml
/customer-groups/{id}/customers:
$ref: paths/customer-groups_{id}_customers.yaml
- /currencies:
- $ref: paths/currencies.yaml
- /currencies/{code}:
- $ref: paths/currencies_{code}.yaml
/customers:
$ref: paths/customers.yaml
/customers/{id}:
@@ -227,10 +227,6 @@ paths:
$ref: paths/discounts_{id}_dynamic-codes_{code}.yaml
/discounts/code/{code}:
$ref: paths/discounts_code_{code}.yaml
- /gift-cards:
- $ref: paths/gift-cards.yaml
- /gift-cards/{id}:
- $ref: paths/gift-cards_{id}.yaml
/draft-orders:
$ref: paths/draft-orders.yaml
/draft-orders/{id}/line-items:
@@ -243,6 +239,10 @@ paths:
$ref: paths/draft-orders_{id}_pay.yaml
/admin/draft-orders/{id}:
$ref: paths/admin_draft-orders_{id}.yaml
+ /gift-cards:
+ $ref: paths/gift-cards.yaml
+ /gift-cards/{id}:
+ $ref: paths/gift-cards_{id}.yaml
/invites/accept:
$ref: paths/invites_accept.yaml
/invites:
@@ -329,6 +329,12 @@ paths:
$ref: paths/payment-collections_{id}.yaml
/payment-collections/{id}/authorize:
$ref: paths/payment-collections_{id}_authorize.yaml
+ /payments/{id}/capture:
+ $ref: paths/payments_{id}_capture.yaml
+ /payments/{id}:
+ $ref: paths/payments_{id}.yaml
+ /payments/{id}/refund:
+ $ref: paths/payments_{id}_refund.yaml
/price-lists/{id}/prices/batch:
$ref: paths/price-lists_{id}_prices_batch.yaml
/price-lists:
@@ -341,10 +347,10 @@ paths:
$ref: paths/price-lists_{id}_variants_{variant_id}_prices.yaml
/price-lists/{id}/products:
$ref: paths/price-lists_{id}_products.yaml
- /product-types:
- $ref: paths/product-types.yaml
/product-tags:
$ref: paths/product-tags.yaml
+ /product-types:
+ $ref: paths/product-types.yaml
/products/{id}/options:
$ref: paths/products_{id}_options.yaml
/products:
@@ -363,12 +369,6 @@ paths:
$ref: paths/products_types.yaml
/products/{id}/metadata:
$ref: paths/products_{id}_metadata.yaml
- /payments/{id}/capture:
- $ref: paths/payments_{id}_capture.yaml
- /payments/{id}:
- $ref: paths/payments_{id}.yaml
- /payments/{id}/refund:
- $ref: paths/payments_{id}_refund.yaml
/publishable-api-keys/{id}/sales-channels/batch:
$ref: paths/publishable-api-keys_{id}_sales-channels_batch.yaml
/publishable-api-keys:
@@ -403,22 +403,26 @@ paths:
$ref: paths/return-reasons.yaml
/return-reasons/{id}:
$ref: paths/return-reasons_{id}.yaml
- /sales-channels/{id}/products/batch:
- $ref: paths/sales-channels_{id}_products_batch.yaml
- /sales-channels:
- $ref: paths/sales-channels.yaml
- /sales-channels/{id}:
- $ref: paths/sales-channels_{id}.yaml
/returns/{id}/cancel:
$ref: paths/returns_{id}_cancel.yaml
/returns:
$ref: paths/returns.yaml
/returns/{id}/receive:
$ref: paths/returns_{id}_receive.yaml
+ /sales-channels/{id}/products/batch:
+ $ref: paths/sales-channels_{id}_products_batch.yaml
+ /sales-channels:
+ $ref: paths/sales-channels.yaml
+ /sales-channels/{id}:
+ $ref: paths/sales-channels_{id}.yaml
/shipping-options:
$ref: paths/shipping-options.yaml
/shipping-options/{id}:
$ref: paths/shipping-options_{id}.yaml
+ /shipping-profiles:
+ $ref: paths/shipping-profiles.yaml
+ /shipping-profiles/{id}:
+ $ref: paths/shipping-profiles_{id}.yaml
/store/currencies/{code}:
$ref: paths/store_currencies_{code}.yaml
/store:
@@ -441,14 +445,12 @@ paths:
$ref: paths/tax-rates.yaml
/tax-rates/{id}:
$ref: paths/tax-rates_{id}.yaml
- /shipping-profiles:
- $ref: paths/shipping-profiles.yaml
- /shipping-profiles/{id}:
- $ref: paths/shipping-profiles_{id}.yaml
/uploads/protected:
$ref: paths/uploads_protected.yaml
/uploads:
$ref: paths/uploads.yaml
+ /uploads/download-url:
+ $ref: paths/uploads_download-url.yaml
/users:
$ref: paths/users.yaml
/users/{id}:
diff --git a/docs/api/admin/paths/price-lists_{id}_products.yaml b/docs/api/admin/paths/price-lists_{id}_products.yaml
index 66d89f48b1..7275b51bbe 100644
--- a/docs/api/admin/paths/price-lists_{id}_products.yaml
+++ b/docs/api/admin/paths/price-lists_{id}_products.yaml
@@ -189,7 +189,7 @@ get:
- api_token: []
- cookie_auth: []
tags:
- - Product
+ - Price List
responses:
'200':
description: OK
diff --git a/docs/api/admin/paths/uploads.yaml b/docs/api/admin/paths/uploads.yaml
index a926680735..97ded7f302 100644
--- a/docs/api/admin/paths/uploads.yaml
+++ b/docs/api/admin/paths/uploads.yaml
@@ -57,3 +57,58 @@ post:
$ref: ../components/responses/invalid_request_error.yaml
'500':
$ref: ../components/responses/500_error.yaml
+delete:
+ operationId: AdminDeleteUploads
+ summary: Delete an Uploaded File
+ description: Removes an uploaded file using the installed fileservice
+ x-authenticated: true
+ requestBody:
+ content:
+ application/json:
+ schema:
+ $ref: ../components/schemas/AdminDeleteUploadsReq.yaml
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source:
+ $ref: ../code_samples/JavaScript/uploads/deleteundefined
+ - lang: Shell
+ label: cURL
+ source:
+ $ref: ../code_samples/Shell/uploads/deleteundefined
+ security:
+ - api_token: []
+ - cookie_auth: []
+ tags:
+ - Upload
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ id:
+ type: string
+ description: The file key of the upload deleted
+ object:
+ type: string
+ description: The type of the object that was deleted.
+ default: file
+ deleted:
+ type: boolean
+ description: Whether or not the items were deleted.
+ default: true
+ '400':
+ $ref: ../components/responses/400_error.yaml
+ '401':
+ $ref: ../components/responses/unauthorized.yaml
+ '404':
+ $ref: ../components/responses/not_found_error.yaml
+ '409':
+ $ref: ../components/responses/invalid_state_error.yaml
+ '422':
+ $ref: ../components/responses/invalid_request_error.yaml
+ '500':
+ $ref: ../components/responses/500_error.yaml
diff --git a/docs/api/admin/paths/uploads_download-url.yaml b/docs/api/admin/paths/uploads_download-url.yaml
new file mode 100644
index 0000000000..fb6abd3a9a
--- /dev/null
+++ b/docs/api/admin/paths/uploads_download-url.yaml
@@ -0,0 +1,47 @@
+post:
+ operationId: PostUploadsDownloadUrl
+ summary: Get a File's Download URL
+ description: Creates a presigned download url for a file
+ x-authenticated: true
+ requestBody:
+ content:
+ application/json:
+ schema:
+ $ref: ../components/schemas/AdminPostUploadsDownloadUrlReq.yaml
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source:
+ $ref: ../code_samples/JavaScript/uploads_download-url/postundefined
+ - lang: Shell
+ label: cURL
+ source:
+ $ref: ../code_samples/Shell/uploads_download-url/postundefined
+ security:
+ - api_token: []
+ - cookie_auth: []
+ tags:
+ - Upload
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ download_url:
+ type: string
+ description: The Download URL of the file
+ '400':
+ $ref: ../components/responses/400_error.yaml
+ '401':
+ $ref: ../components/responses/unauthorized.yaml
+ '404':
+ $ref: ../components/responses/not_found_error.yaml
+ '409':
+ $ref: ../components/responses/invalid_state_error.yaml
+ '422':
+ $ref: ../components/responses/invalid_request_error.yaml
+ '500':
+ $ref: ../components/responses/500_error.yaml
diff --git a/docs/api/store-spec3.json b/docs/api/store-spec3.json
index ca4f530a96..4b3ac12e7f 100644
--- a/docs/api/store-spec3.json
+++ b/docs/api/store-spec3.json
@@ -1429,59 +1429,6 @@ paths:
$ref: '#/components/responses/invalid_request_error'
'500':
$ref: '#/components/responses/500_error'
- '/gift-cards/{code}':
- get:
- operationId: GetGiftCardsCode
- summary: Get Gift Card by Code
- description: Retrieves a Gift Card by its associated unqiue code.
- parameters:
- - in: path
- name: code
- required: true
- description: The unique Gift Card code.
- schema:
- type: string
- x-codeSamples:
- - lang: JavaScript
- label: JS Client
- source: >
- import Medusa from "@medusajs/medusa-js"
-
- const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
- 3 })
-
- medusa.giftCards.retrieve(code)
-
- .then(({ gift_card }) => {
- console.log(gift_card.id);
- });
- - lang: Shell
- label: cURL
- source: >
- curl --location --request GET
- 'https://medusa-url.com/store/gift-cards/{code}'
- tags:
- - Gift Card
- responses:
- '200':
- description: OK
- content:
- application/json:
- schema:
- type: object
- properties:
- gift_card:
- $ref: '#/components/schemas/GiftCard'
- '400':
- $ref: '#/components/responses/400_error'
- '404':
- $ref: '#/components/responses/not_found_error'
- '409':
- $ref: '#/components/responses/invalid_state_error'
- '422':
- $ref: '#/components/responses/invalid_request_error'
- '500':
- $ref: '#/components/responses/500_error'
/customers/me/addresses:
post:
operationId: PostCustomersCustomerAddresses
@@ -2344,6 +2291,59 @@ paths:
$ref: '#/components/responses/invalid_request_error'
'500':
$ref: '#/components/responses/500_error'
+ '/gift-cards/{code}':
+ get:
+ operationId: GetGiftCardsCode
+ summary: Get Gift Card by Code
+ description: Retrieves a Gift Card by its associated unqiue code.
+ parameters:
+ - in: path
+ name: code
+ required: true
+ description: The unique Gift Card code.
+ schema:
+ type: string
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source: >
+ import Medusa from "@medusajs/medusa-js"
+
+ const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
+ 3 })
+
+ medusa.giftCards.retrieve(code)
+
+ .then(({ gift_card }) => {
+ console.log(gift_card.id);
+ });
+ - lang: Shell
+ label: cURL
+ source: >
+ curl --location --request GET
+ 'https://medusa-url.com/store/gift-cards/{code}'
+ tags:
+ - Gift Card
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ gift_card:
+ $ref: '#/components/schemas/GiftCard'
+ '400':
+ $ref: '#/components/responses/400_error'
+ '404':
+ $ref: '#/components/responses/not_found_error'
+ '409':
+ $ref: '#/components/responses/invalid_state_error'
+ '422':
+ $ref: '#/components/responses/invalid_request_error'
+ '500':
+ $ref: '#/components/responses/500_error'
'/order-edits/{id}/complete':
post:
operationId: PostOrderEditsOrderEditComplete
diff --git a/docs/api/store-spec3.yaml b/docs/api/store-spec3.yaml
index 007084881c..4b3ac12e7f 100644
--- a/docs/api/store-spec3.yaml
+++ b/docs/api/store-spec3.yaml
@@ -343,175 +343,6 @@ paths:
$ref: '#/components/responses/invalid_request_error'
'500':
$ref: '#/components/responses/500_error'
- '/collections/{id}':
- get:
- operationId: GetCollectionsCollection
- summary: Get a Collection
- description: Retrieves a Product Collection.
- parameters:
- - in: path
- name: id
- required: true
- description: The id of the Product Collection
- schema:
- type: string
- x-codeSamples:
- - lang: JavaScript
- label: JS Client
- source: >
- import Medusa from "@medusajs/medusa-js"
-
- const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
- 3 })
-
- medusa.collections.retrieve(collection_id)
-
- .then(({ collection }) => {
- console.log(collection.id);
- });
- - lang: Shell
- label: cURL
- source: >
- curl --location --request GET
- 'https://medusa-url.com/store/collections/{id}'
- tags:
- - Collection
- responses:
- '200':
- description: OK
- content:
- application/json:
- schema:
- type: object
- properties:
- collection:
- $ref: '#/components/schemas/ProductCollection'
- '400':
- $ref: '#/components/responses/400_error'
- '404':
- $ref: '#/components/responses/not_found_error'
- '409':
- $ref: '#/components/responses/invalid_state_error'
- '422':
- $ref: '#/components/responses/invalid_request_error'
- '500':
- $ref: '#/components/responses/500_error'
- /collections:
- get:
- operationId: GetCollections
- summary: List Collections
- description: Retrieve a list of Product Collection.
- parameters:
- - in: query
- name: offset
- description: >-
- The number of collections to skip before starting to collect the
- collections set
- schema:
- type: integer
- default: 0
- - in: query
- name: limit
- description: The number of collections to return
- schema:
- type: integer
- default: 10
- - in: query
- name: created_at
- description: Date comparison for when resulting collections were created.
- schema:
- type: object
- properties:
- lt:
- type: string
- description: filter by dates less than this date
- format: date
- gt:
- type: string
- description: filter by dates greater than this date
- format: date
- lte:
- type: string
- description: filter by dates less than or equal to this date
- format: date
- gte:
- type: string
- description: filter by dates greater than or equal to this date
- format: date
- - in: query
- name: updated_at
- description: Date comparison for when resulting collections were updated.
- schema:
- type: object
- properties:
- lt:
- type: string
- description: filter by dates less than this date
- format: date
- gt:
- type: string
- description: filter by dates greater than this date
- format: date
- lte:
- type: string
- description: filter by dates less than or equal to this date
- format: date
- gte:
- type: string
- description: filter by dates greater than or equal to this date
- format: date
- x-codeSamples:
- - lang: JavaScript
- label: JS Client
- source: >
- import Medusa from "@medusajs/medusa-js"
-
- const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
- 3 })
-
- medusa.collections.list()
-
- .then(({ collections, limit, offset, count }) => {
- console.log(collections.length);
- });
- - lang: Shell
- label: cURL
- source: >
- curl --location --request GET
- 'https://medusa-url.com/store/collections'
- tags:
- - Collection
- responses:
- '200':
- description: OK
- content:
- application/json:
- schema:
- type: object
- properties:
- collections:
- type: array
- items:
- $ref: '#/components/schemas/ProductCollection'
- count:
- type: integer
- description: The total number of items available
- offset:
- type: integer
- description: The number of items skipped before these items
- limit:
- type: integer
- description: The number of items per page
- '400':
- $ref: '#/components/responses/400_error'
- '404':
- $ref: '#/components/responses/not_found_error'
- '409':
- $ref: '#/components/responses/invalid_state_error'
- '422':
- $ref: '#/components/responses/invalid_request_error'
- '500':
- $ref: '#/components/responses/500_error'
'/carts/{id}/shipping-methods':
post:
operationId: PostCartsCartShippingMethod
@@ -1429,6 +1260,175 @@ paths:
provider_id:
type: string
description: The ID of the Payment Provider.
+ '/collections/{id}':
+ get:
+ operationId: GetCollectionsCollection
+ summary: Get a Collection
+ description: Retrieves a Product Collection.
+ parameters:
+ - in: path
+ name: id
+ required: true
+ description: The id of the Product Collection
+ schema:
+ type: string
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source: >
+ import Medusa from "@medusajs/medusa-js"
+
+ const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
+ 3 })
+
+ medusa.collections.retrieve(collection_id)
+
+ .then(({ collection }) => {
+ console.log(collection.id);
+ });
+ - lang: Shell
+ label: cURL
+ source: >
+ curl --location --request GET
+ 'https://medusa-url.com/store/collections/{id}'
+ tags:
+ - Collection
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ collection:
+ $ref: '#/components/schemas/ProductCollection'
+ '400':
+ $ref: '#/components/responses/400_error'
+ '404':
+ $ref: '#/components/responses/not_found_error'
+ '409':
+ $ref: '#/components/responses/invalid_state_error'
+ '422':
+ $ref: '#/components/responses/invalid_request_error'
+ '500':
+ $ref: '#/components/responses/500_error'
+ /collections:
+ get:
+ operationId: GetCollections
+ summary: List Collections
+ description: Retrieve a list of Product Collection.
+ parameters:
+ - in: query
+ name: offset
+ description: >-
+ The number of collections to skip before starting to collect the
+ collections set
+ schema:
+ type: integer
+ default: 0
+ - in: query
+ name: limit
+ description: The number of collections to return
+ schema:
+ type: integer
+ default: 10
+ - in: query
+ name: created_at
+ description: Date comparison for when resulting collections were created.
+ schema:
+ type: object
+ properties:
+ lt:
+ type: string
+ description: filter by dates less than this date
+ format: date
+ gt:
+ type: string
+ description: filter by dates greater than this date
+ format: date
+ lte:
+ type: string
+ description: filter by dates less than or equal to this date
+ format: date
+ gte:
+ type: string
+ description: filter by dates greater than or equal to this date
+ format: date
+ - in: query
+ name: updated_at
+ description: Date comparison for when resulting collections were updated.
+ schema:
+ type: object
+ properties:
+ lt:
+ type: string
+ description: filter by dates less than this date
+ format: date
+ gt:
+ type: string
+ description: filter by dates greater than this date
+ format: date
+ lte:
+ type: string
+ description: filter by dates less than or equal to this date
+ format: date
+ gte:
+ type: string
+ description: filter by dates greater than or equal to this date
+ format: date
+ x-codeSamples:
+ - lang: JavaScript
+ label: JS Client
+ source: >
+ import Medusa from "@medusajs/medusa-js"
+
+ const medusa = new Medusa({ baseUrl: MEDUSA_BACKEND_URL, maxRetries:
+ 3 })
+
+ medusa.collections.list()
+
+ .then(({ collections, limit, offset, count }) => {
+ console.log(collections.length);
+ });
+ - lang: Shell
+ label: cURL
+ source: >
+ curl --location --request GET
+ 'https://medusa-url.com/store/collections'
+ tags:
+ - Collection
+ responses:
+ '200':
+ description: OK
+ content:
+ application/json:
+ schema:
+ type: object
+ properties:
+ collections:
+ type: array
+ items:
+ $ref: '#/components/schemas/ProductCollection'
+ count:
+ type: integer
+ description: The total number of items available
+ offset:
+ type: integer
+ description: The number of items skipped before these items
+ limit:
+ type: integer
+ description: The number of items per page
+ '400':
+ $ref: '#/components/responses/400_error'
+ '404':
+ $ref: '#/components/responses/not_found_error'
+ '409':
+ $ref: '#/components/responses/invalid_state_error'
+ '422':
+ $ref: '#/components/responses/invalid_request_error'
+ '500':
+ $ref: '#/components/responses/500_error'
/customers/me/addresses:
post:
operationId: PostCustomersCustomerAddresses
diff --git a/docs/api/store/openapi.yaml b/docs/api/store/openapi.yaml
index cee6d7286e..4b57d62e00 100644
--- a/docs/api/store/openapi.yaml
+++ b/docs/api/store/openapi.yaml
@@ -137,10 +137,6 @@ paths:
$ref: paths/auth.yaml
/auth/{email}:
$ref: paths/auth_{email}.yaml
- /collections/{id}:
- $ref: paths/collections_{id}.yaml
- /collections:
- $ref: paths/collections.yaml
/carts/{id}/shipping-methods:
$ref: paths/carts_{id}_shipping-methods.yaml
/carts/{id}/taxes:
@@ -163,6 +159,10 @@ paths:
$ref: paths/carts_{id}_payment-sessions_{provider_id}_refresh.yaml
/carts/{id}/payment-session:
$ref: paths/carts_{id}_payment-session.yaml
+ /collections/{id}:
+ $ref: paths/collections_{id}.yaml
+ /collections:
+ $ref: paths/collections.yaml
/customers/me/addresses:
$ref: paths/customers_me_addresses.yaml
/customers:
diff --git a/docs/content/add-plugins/minio.md b/docs/content/add-plugins/minio.md
index 0a0ff531f6..c66c61ed38 100644
--- a/docs/content/add-plugins/minio.md
+++ b/docs/content/add-plugins/minio.md
@@ -34,23 +34,14 @@ minio server ~/minio --console-address :9090 --address :9001
### Create a MinIO bucket
-After installing MinIO and logging into the Console, click on “Create Bucket” to create a new bucket that will store the files of your Medusa server.
+After installing MinIO and logging into the Console, you can create a bucket that will store the files of your Medusa server by following these steps:
-
-
-Then, in the form, enter a name for the bucket and click on Create Bucket. By MinIO’s requirement, the name can only consist of lower case characters, numbers, dots (`.`), and hyphens (`-`).
-
-
-
-After creating the bucket, click on the cog icon at the top right to configure the bucket.
-
-
-
-Then, click on the edit icon next to Access Policy. This will open a pop-up.
-
-
-
-In the pop-up, change the selected value to “public” and click Set.
+1. Click on the “Create Bucket” button
+2. For the Bucket Name field, enter a name for the bucket. By MinIO’s requirement, the name can only consist of lower case characters, numbers, dots (`.`), and hyphens (`-`).
+3. Click on the Create Bucket button.
+4. On the bucket's page, click on the cog icon at the top right to configure the bucket.
+5. Click on the edit icon next to Access Policy.
+6. In the pop-up that opens, change the selected value to “public” and click Set.
:::warning
@@ -60,19 +51,12 @@ Changing the Access Policy to public will allow anyone to access your bucket. Av
### Generate Access Keys
-From the sidebar of your MinIO console, click on Identity then Service Accounts.
+To generate access keys for your plugin:
-
-
-Then, click on Create Service Account.
-
-
-
-This will generate a random Access Key and Secret Key for you.
-
-
-
-Click on Create. A pop-up will then show the value for your Access Key and Secret Key. Copy them to use in the next section.
+1. From the sidebar of your MinIO console, click on Access Keys
+2. Click on the "Create access key" button
+3. This will open a new form with randomly-generated keys. Click on the Create button.
+4. A pop-up will then show the value for your Access Key and Secret Key. Copy them to use in the next section.
:::caution
diff --git a/docs/content/add-plugins/sendgrid.mdx b/docs/content/add-plugins/sendgrid.mdx
index 2b985b0f7e..0951af214f 100644
--- a/docs/content/add-plugins/sendgrid.mdx
+++ b/docs/content/add-plugins/sendgrid.mdx
@@ -78,7 +78,7 @@ You don’t have to create a template for every type in the reference. You can s
### Order Placed
-**Key in plugin options:** `order.placed`
+**Key in plugin options:** `order_placed_template`
**Description:** Template to be sent to the customer when they place a new order.
@@ -3977,4 +3977,4 @@ You can also track analytics related to emails sent from the SendGrid dashboard.
## See Also
- [Notifications Overview](../advanced/backend/notification/overview.md)
-- Install the [Medusa admin](../admin/quickstart.mdx) for functionalities like Gift Cards creation, swaps, claims, order return requests, and more.
\ No newline at end of file
+- Install the [Medusa admin](../admin/quickstart.mdx) for functionalities like Gift Cards creation, swaps, claims, order return requests, and more.
diff --git a/docs/content/admin/quickstart.mdx b/docs/content/admin/quickstart.mdx
index 9c164ad337..ccfd938266 100644
--- a/docs/content/admin/quickstart.mdx
+++ b/docs/content/admin/quickstart.mdx
@@ -100,7 +100,7 @@ By default, the admin runs on port 7000. So, in your browser, go to `localhost:7
Use your Medusa admin’s user credentials to log in.
-:::tip
+### Demo Credentials
If you installed the demo data when you installed the Medusa server by using the `--seed` option or running:
@@ -110,6 +110,10 @@ npm run seed
You can use the email `admin@medusa-test.com` and password `supersecret` to log in.
+:::info
+
+Passwords in Medusa are hashed using the [scrypt-kdf](https://www.npmjs.com/package/scrypt-kdf). The password hash is then stored in the database.
+
:::
---
diff --git a/docs/content/advanced/admin/manage-gift-cards.mdx b/docs/content/advanced/admin/manage-gift-cards.mdx
new file mode 100644
index 0000000000..64437c8114
--- /dev/null
+++ b/docs/content/advanced/admin/manage-gift-cards.mdx
@@ -0,0 +1,580 @@
+import Tabs from '@theme/Tabs';
+import TabItem from '@theme/TabItem';
+
+# How to Manage Gift Cards
+
+In this document, you’ll learn how to manage gift cards using the admin APIs.
+
+:::note
+
+You can learn more about what gift cards are and how they’re used in [this documentation](../backend/gift-cards/index.md)
+
+:::
+
+## Overview
+
+Using the gift cards’ admin APIs, you can manage gift cards including listing, updating, and deleting them.
+
+### Scenario
+
+You want to add or use the following admin functionalities:
+
+- Manage the gift card product including retrieving, adding, updating, and deleting it.
+- Managing custom gift cards including retrieving, adding, updating and deleting them.
+
+---
+
+## Prerequisites
+
+### Medusa Components
+
+It is assumed that you already have a Medusa server installed and set up. If not, you can follow the [quickstart guide](../../quickstart/quick-start.mdx) to get started.
+
+### JS Client
+
+This guide includes code snippets to send requests to your Medusa server using Medusa’s JS Client, JavaScript’s Fetch API, or cURL.
+
+If you follow the JS Client code blocks, it’s assumed you already have [Medusa’s JS Client](../../js-client/overview.md) installed and have [created an instance of the client](../../js-client/overview.md#configuration).
+
+### Authenticated Admin User
+
+You must be an authenticated admin user before following along with the steps in the tutorial.
+
+You can learn more about [authenticating as an admin user in the API reference](/api/admin/#section/Authentication).
+
+---
+
+## Manage Gift Card Product
+
+This section covers managing the gift card product. There can only be one gift card product in a store. The gift card can have unlimited denominations.
+
+As gift cards are, before purchase, essentially products, you’ll be using product endpoints to manage them.
+
+### Retrieve Gift Card Product
+
+You can retrieve the gift card product by sending a request to the [List Products](/api/admin/#tag/Product/operation/GetProducts) endpoint, but filtering by the `is_giftcard` flag:
+
+
+
+
+```ts
+medusa.admin.products.list({
+ is_giftcard: true,
+})
+.then(({ products, limit, offset, count }) => {
+ if (products.length) {
+ // gift card product exists
+ const giftcard = products[0]
+ } else {
+ // no gift card product is created
+ }
+})
+```
+
+
+
+
+```ts
+fetch(`/admin/products?is_giftcard=true`, {
+ credentials: "include",
+})
+.then((response) => response.json())
+.then(({ products, limit, offset, count }) => {
+ if (products.length) {
+ // gift card product exists
+ const giftcard = products[0]
+ } else {
+ // no gift card product is created
+ }
+})
+```
+
+
+
+
+```bash
+curl -L -X GET '/admin/products?is_giftcard=true' \
+-H 'Authorization: Bearer '
+```
+
+
+
+
+The List Products endpoint accepts a variety of query parameters that can be used to filter the products. One of them is `is_giftcard`. When set to `true`, it will only retrieve the gift card product.
+
+The request returns the `products` array in the response which holds the gift card in it, if it’s available. It also returns [pagination fields](/api/admin/#section/Pagination).
+
+### Create Gift Card Product
+
+You can create only one gift card product in a store. To create a gift card product, send a request to the [Create a Product](/api/admin/#tag/Product/operation/PostProducts) endpoint:
+
+
+
+
+```ts
+import { ProductStatus } from "@medusajs/medusa"
+// ...
+
+medusa.admin.products.create({
+ title: "My Gift Card",
+ is_giftcard: true,
+ discountable: false,
+ status: ProductStatus.PUBLISHED,
+ options: [
+ {
+ title: "Denomination",
+ },
+ ],
+ variants: [
+ {
+ title: "1",
+ inventory_quantity: 0,
+ manage_inventory: false,
+ prices: [
+ {
+ amount: 2000,
+ currency_code: "usd",
+ },
+ ],
+ options: [
+ {
+ value: "2000",
+ },
+ ],
+ },
+ ],
+})
+.then(({ product }) => {
+ console.log(product.id)
+})
+```
+
+
+
+
+```ts
+fetch(`/admin/products`, {
+ method: "POST",
+ credentials: "include",
+ headers: {
+ "Content-Type": "application/json",
+ },
+ body: JSON.stringify({
+ title: "My Gift Card",
+ is_giftcard: true,
+ discountable: false,
+ status: "published",
+ options: [
+ {
+ title: "Denomination",
+ },
+ ],
+ variants: [
+ {
+ title: "1",
+ inventory_quantity: 0,
+ manage_inventory: false,
+ prices: [
+ {
+ amount: 2000,
+ currency_code: "usd",
+ },
+ ],
+ options: [
+ {
+ value: "2000",
+ },
+ ],
+ },
+ ],
+ }),
+})
+.then((response) => response.json())
+.then(({ product }) => {
+ console.log(product.id)
+})
+```
+
+
+
+
+```bash
+curl -L -X POST '/admin/products' \
+-H 'Authorization: Bearer ' \
+-H 'Content-Type: application/json' \
+--data-raw '{
+ "title": "My Gift Card",
+ "is_giftcard": true,
+ "discountable": false,
+ "status": "published",
+ "options": [
+ {
+ "title": "Denomination"
+ }
+ ],
+ "variants": [
+ {
+ "title": "1",
+ "inventory_quantity": 0,
+ "manage_inventory": false,
+ "prices": [
+ {
+ "amount": 2000,
+ "currency_code": "usd"
+ }
+ ],
+ "options": [
+ {
+ "value": "2000"
+ }
+ ]
+ }
+ ]
+}'
+```
+
+
+
+
+This request requires the `title` body parameter, which is the name given to the gift card. To add the gift card product, you need to supply the following parameters:
+
+- `is_giftcard` set to `true`.
+- `discountable` set to `false`. It indicates that discounts don’t apply on this product.
+- `status`: a string indicating the status of the product. Can be `published`, `draft`, `proposed`, or `rejected`.
+- `options`: An array that includes available options of the product. For a gift card, you should add one option with the title “Denomination”.
+- `variants`: An array that includes the different variations of the product using the available options. For a gift card, you should pass each denomination value as an item in this array. The value is passed in the `prices` and `options` array. If you want to add prices for different currencies, you can pass them under `prices` and `options` as well.
+
+You can pass other body parameters to change the handle, add images, and more. Check the [API reference](/api/admin/#tag/Product/operation/PostProducts) for available body parameters.
+
+This request returns the created gift card product in the response.
+
+### Update Gift Card Product
+
+After creating a gift card, merchants can update it or its denomination.
+
+You can update a gift card product’s details by sending a request to the [Update a Product](/api/admin/#tag/Product/operation/PostProductsProduct) endpoint:
+
+
+
+
+```ts
+medusa.admin.products.update(giftCardId, {
+ description: "The best gift card",
+})
+.then(({ product }) => {
+ console.log(product.id)
+})
+```
+
+
+
+
+```ts
+fetch(`/admin/products/${giftCardId}`, {
+ method: "POST",
+ credentials: "include",
+ headers: {
+ "Content-Type": "application/json",
+ },
+ body: JSON.stringify({
+ description: "The best gift card",
+ }),
+})
+.then((response) => response.json())
+.then(({ product }) => {
+ console.log(product.id)
+})
+```
+
+
+
+
+```bash
+curl -L -X POST '/admin/products/' \
+-H 'Authorization: Bearer ' \
+-H 'Content-Type: application/json' \
+--data-raw '{
+ "description": "The best gift card"
+}'
+```
+
+
+
+
+This request requires the ID of the gift card product as a path parameter. You can pass in its body parameters, any of the gift card’s properties to update.
+
+In this example, you update the description of the gift card. You can check the [API reference](/api/admin/#tag/Product/operation/PostProductsProduct) for all the body parameters you can pass to this request.
+
+This request returns the updated gift card product in the response.
+
+### Delete Gift Card Product
+
+You can delete the gift card product by sending a request to the [Delete a Product](/api/admin/#tag/Product/operation/DeleteProductsProduct) endpoint:
+
+
+
+
+```ts
+medusa.admin.products.delete(giftCardId)
+.then(({ id, object, deleted }) => {
+ console.log(id)
+})
+```
+
+
+
+
+```ts
+fetch(`/admin/products/${giftCardId}`, {
+ method: "DELETE",
+ credentials: "include",
+})
+.then((response) => response.json())
+.then(({ id, object, deleted }) => {
+ console.log(id)
+})
+```
+
+
+
+
+```bash
+curl -L -X DELETE '/admin/products/' \
+-H 'Authorization: Bearer '
+```
+
+
+
+
+This request requires the ID of the gift card product as a path parameter.
+
+It returns the following fields in the response:
+
+- `id`: The ID of the deleted gift card.
+- `object`: A string indicating the type of object deleted. By default, its value is `product`.
+- `deleted`: A boolean value indicating whether the gift card was deleted or not.
+
+---
+
+## Manage Custom Gift Cards
+
+This section covers how to manage custom gift cards. You can create an unlimited number of custom gift cards.
+
+### List Custom Gift Cards
+
+You can retrieve all custom gift cards by sending a request to the [List Gift Cards](/api/admin/#tag/Gift-Card/operation/GetGiftCards) endpoint:
+
+
+
+
+```ts
+medusa.admin.giftCards.list()
+.then(({ gift_cards, limit, offset, count }) => {
+ console.log(gift_cards.length)
+})
+```
+
+
+
+
+```ts
+fetch(`/admin/gift-cards`, {
+ credentials: "include",
+})
+.then((response) => response.json())
+.then(({ gift_cards, limit, offset, count }) => {
+ console.log(gift_cards.length)
+})
+```
+
+
+
+
+```bash
+curl -L -X GET '/admin/gift-cards' \
+-H 'Authorization: Bearer '
+```
+
+
+
+
+This request does not require any parameters. It accepts parameters related to pagination, which you can check out in the [API reference](/api/admin/#tag/Gift-Card/operation/GetGiftCards).
+
+This request returns an array of `gift_cards` and [pagination fields](/api/admin/#section/Pagination) in the response.
+
+### Create a Custom Gift Card
+
+Merchants can create custom gift cards to send a reward or gift to the customer.
+
+You can create a custom gift card by sending a request to the [Create a Gift Card](/api/admin/#tag/Gift-Card/operation/PostGiftCards) endpoint:
+
+
+
+
+```ts
+medusa.admin.giftCards.create({
+ region_id,
+ value,
+})
+.then(({ gift_card }) => {
+ console.log(gift_card.id)
+})
+```
+
+
+
+
+```ts
+fetch(`/admin/gift-cards`, {
+ method: "POST",
+ credentials: "include",
+ headers: {
+ "Content-Type": "application/json",
+ },
+ body: JSON.stringify({
+ region_id,
+ value,
+ }),
+})
+.then((response) => response.json())
+.then(({ gift_card }) => {
+ console.log(gift_card.id)
+})
+```
+
+
+
+
+```bash
+curl -L -X POST '/admin/gift-cards' \
+-H 'Authorization: Bearer ' \
+-H 'Content-Type: application/json' \
+--data-raw '{
+ "region_id": "",
+ "value": 2000
+}'
+```
+
+
+
+
+This request requires the `region_id` body parameter. Its value should be the ID of the region that this gift card can be used in.
+
+It optionally accepts other body parameters, including the `value` parameter, which is the amount of the gift card. You can check the [API reference](/api/admin/#tag/Gift-Card/operation/PostGiftCards) for the rest of the body parameters.
+
+This request returns the created gift card object in the response.
+
+### Update Custom Gift Card
+
+Merchants can update any of the gift card’s properties, except for the value of the gift card.
+
+You can update a gift card by sending a request to the [Update a Gift Card](/api/admin/#tag/Gift-Card/operation/PostGiftCardsGiftCard) endpoint:
+
+
+
+
+```ts
+medusa.admin.giftCards.update(giftCardId, {
+ balance,
+})
+.then(({ gift_card }) => {
+ console.log(gift_card.id)
+})
+```
+
+
+
+
+```ts
+fetch(`/admin/gift-cards/${giftCardId}`, {
+ method: "POST",
+ credentials: "include",
+ headers: {
+ "Content-Type": "application/json",
+ },
+ body: JSON.stringify({
+ balance,
+ }),
+})
+.then((response) => response.json())
+.then(({ gift_card }) => {
+ console.log(gift_card.id)
+})
+```
+
+
+
+
+```bash
+curl -L -X POST '/admin/gift-cards/' \
+-H 'Authorization: Bearer ' \
+-H 'Content-Type: application/json' \
+--data-raw '{
+ "balance": 2000
+}'
+```
+
+
+
+
+This request requires the ID of the gift card as a path parameter. It accepts in its body parameters the gift card’s properties that you want to update.
+
+In this example, you update the balance of the gift card. The balance is the remaining amount in the gift card that the customer can use. You can check the [API reference](/api/admin/#tag/Gift-Card/operation/PostGiftCardsGiftCard) to learn what other parameters are allowed.
+
+This request returns the updated gift card object in the response.
+
+### Delete Custom Gift Card
+
+You can delete a custom gift card by sending a request to the [Delete a Gift Card](/api/admin/#tag/Gift-Card/operation/DeleteGiftCardsGiftCard) endpoint:
+
+
+
+
+```ts
+medusa.admin.giftCards.delete(giftCardId)
+.then(({ id, object, deleted }) => {
+ console.log(id)
+})
+```
+
+
+
+
+```ts
+fetch(`/admin/gift-cards/${giftCardId}`, {
+ method: "DELETE",
+ credentials: "include",
+})
+.then((response) => response.json())
+.then(({ id, object, deleted }) => {
+ console.log(id)
+})
+```
+
+
+
+
+```bash
+curl -L -X DELETE '/admin/gift-card/' \
+-H 'Authorization: Bearer '
+```
+
+
+
+
+This request requires the ID of the gift card as a path parameter.
+
+It returns the following fields in the response:
+
+- `id`: The ID of the deleted gift card.
+- `object`: A string indicating the type of object deleted. By default, its value is `gift-card`.
+- `deleted`: A boolean value indicating whether the gift card was deleted or not.
+
+---
+
+## See Also
+
+- [Gift cards overview](../backend/gift-cards/index.md)
+- [Use gift cards on the storefront](../storefront/use-gift-cards.mdx)
+- [Send the customer a gift card](../ecommerce/send-gift-card-to-customer.md)
+- Gift cards [store](/api/store/#tag/Gift-Card) and [admin](/api/admin/#tag/Gift-Card) APIs
diff --git a/docs/content/advanced/backend/gift-cards/index.md b/docs/content/advanced/backend/gift-cards/index.md
new file mode 100644
index 0000000000..6fe7773089
--- /dev/null
+++ b/docs/content/advanced/backend/gift-cards/index.md
@@ -0,0 +1,72 @@
+# Gift Cards
+
+In this document, you’ll learn about Gift Cards and how they work in Medusa.
+
+## Introduction
+
+Gift cards are products that customers can purchase and redeem in their future orders. Gift cards can have different amounts or denominations that a customer can choose from.
+
+When a customer purchases a gift card, they should receive the code for the gift card by email or other type of notification. Then, they can use the code in their future purchases.
+
+---
+
+## Gift Cards as Products
+
+Before a gift card is purchased, it’s essentially a `Product` entity. A store can have only one gift card with unlimited denominations.
+
+The gift card product has an attribute `is_giftcard` set to `true`. Its `options` property includes only one option, which is Denomination. The different denomination values are stored as `variants`.
+
+Once the customer purchases a gift card product, it is transformed into a usable gift card represented by the [GiftCard entity](#giftcard-entity-overview).
+
+---
+
+## Custom Gift Cards
+
+Aside from the gift card product, merchants can create usable gift cards and send directly to customers. These can be used as a reward sent to the customer or another form of discount.
+
+As custom gift cards can be used once they’re created, they’re also represented by the [GiftCard entity](#giftcard-entity-overview).
+
+---
+
+## GiftCard Entity Overview
+
+Some of the [GiftCard](../../../references/entities/classes/GiftCard.md) entity’s attributes are:
+
+- `code`: a unique string of random characters. This is the code that the customer can use during their checkout to redeem the gift card.
+- `value`: The amount of the gift card. This is the amount the customer purchased, or was gifted in the case of custom gift cards.
+- `balance`: The remaining amount of the gift card. If the customer uses the gift card on an order, and the order’s total does not exceed the amount available in the gift card, the remaining balance would be stored in this attribute. When the gift card is first created, `balance` and `value` have the same value.
+- `is_disabled`: A boolean value indicating whether a gift card is disabled or not.
+- `ends_at`: The expiry date and time of the gift card.
+- `tax_rate`: The tax rate applied when calculating the totals of an order. The tax rate’s value is determined based on the following conditions:
+ - If the value of `region.gift_cards_taxable` is `false`, the `tax_rate` is `null`;
+ - Otherwise, if the merchant or admin user has manually set the value of the tax rate, it is applied;
+ - Otherwise, if the region has a tax rate, it’s applied on the gift card. If not, the value of the tax rate is `null`.
+
+---
+
+## Relations to Other Entities
+
+### Region
+
+A gift card must belong to a region. When a customer purchases the gift card, the region they use to purchase the order is associated with the gift card.
+
+For custom gift cards, the merchant specifies the region manually.
+
+The ID of the region is stored in the attribute `region_id`. You can access the region by expanding the `region` relation and accessing `gift_card.region`.
+
+### Order
+
+If the gift card was created because the customer purchased it, it is associated with the placed order.
+
+The ID of the order is stored in the attribute `order_id`. You can access the order by expanding the `order` relation and accessing `gift_card.order`.
+
+You can also access the gift cards used in an order by expanding the `gift_cards` relation on the order and accessing `order.gift_cards`.
+
+---
+
+## See Also
+
+- Gift cards [store](/api/store/#tag/Gift-Card) and [admin](/api/admin/#tag/Gift-Card) APIs
+- [How to manage gift cards using admin APIs](../../admin/manage-gift-cards.mdx)
+- [How to use gift cards in the storefront](../../storefront/use-gift-cards.mdx)
+- [How to send the customer a gift card](../../ecommerce/send-gift-card-to-customer.md)
diff --git a/docs/content/advanced/backend/notification/overview.md b/docs/content/advanced/backend/notification/overview.md
index dd43920783..44b8261d7c 100644
--- a/docs/content/advanced/backend/notification/overview.md
+++ b/docs/content/advanced/backend/notification/overview.md
@@ -1,4 +1,4 @@
-# Architecture Overview
+# Notification Architecture Overview
This document gives an overview of the notification architecture and how it works.
@@ -93,4 +93,3 @@ An example of a flow that can be implemented using Medusa's Notification API is
- [SendGrid Plugin](../../../add-plugins/sendgrid.mdx)
- [Subscribers Overview](../subscribers/create-subscriber.md)
- [Services Overview](../services/create-service.md)
-
diff --git a/docs/content/advanced/backend/payment/how-to-create-payment-provider.md b/docs/content/advanced/backend/payment/how-to-create-payment-provider.md
index da374726c3..c204a1690d 100644
--- a/docs/content/advanced/backend/payment/how-to-create-payment-provider.md
+++ b/docs/content/advanced/backend/payment/how-to-create-payment-provider.md
@@ -50,54 +50,64 @@ The first step to create a payment provider is to create a JavaScript or TypeScr
For example, create the file `src/services/my-payment.ts` with the following content:
-
-
```ts title=src/services/my-payment.ts
import {
- AbstractPaymentService,
- Cart, Data, Payment, PaymentSession,
- PaymentSessionStatus, TransactionBaseService,
-} from "@medusajs/medusa"
+ AbstractPaymentService, PaymentContext, Data,
+ Payment, PaymentSession, PaymentSessionStatus,
+ PaymentSessionData, Cart, PaymentData,
+ PaymentSessionResponse } from "@medusajs/medusa"
+
import { EntityManager } from "typeorm"
-class MyPaymentService extends AbstractPaymentService {
+class MyPaymentService extends AbstractPaymentService {
protected manager_: EntityManager
- protected transactionManager_: EntityManager
+ protected transactionManager_: EntityManager | undefined
- getPaymentData(paymentSession: PaymentSession): Promise {
+ async getPaymentData(paymentSession: PaymentSession): Promise {
throw new Error("Method not implemented.")
}
- updatePaymentData(paymentSessionData: Data, data: Data): Promise {
+ async updatePaymentData(
+ paymentSessionData: PaymentSessionData,
+ data: Data
+ ): Promise {
throw new Error("Method not implemented.")
}
- createPayment(cart: Cart): Promise {
+ async createPayment(
+ context: Cart & PaymentContext
+ ): Promise {
throw new Error("Method not implemented.")
}
- retrievePayment(paymentData: Data): Promise {
+ async retrievePayment(paymentData: Data): Promise {
throw new Error("Method not implemented.")
}
- updatePayment(paymentSessionData: Data, cart: Cart): Promise {
+ async updatePayment(
+ paymentSessionData: PaymentSessionData,
+ cart: Cart
+ ): Promise {
throw new Error("Method not implemented.")
}
- authorizePayment(
+ async authorizePayment(
paymentSession: PaymentSession,
context: Data
- ): Promise<{ data: Data; status: PaymentSessionStatus; }> {
+ ): Promise<{ data: PaymentSessionData; status: PaymentSessionStatus }> {
throw new Error("Method not implemented.")
}
- capturePayment(payment: Payment): Promise {
+ async capturePayment(payment: Payment): Promise {
throw new Error("Method not implemented.")
}
- refundPayment(payment: Payment, refundAmount: number): Promise {
+ async refundPayment(
+ payment: Payment,
+ refundAmount: number
+ ): Promise {
throw new Error("Method not implemented.")
}
- cancelPayment(payment: Payment): Promise {
+ async cancelPayment(payment: Payment): Promise {
throw new Error("Method not implemented.")
}
- deletePayment(paymentSession: PaymentSession): Promise {
+ async deletePayment(paymentSession: PaymentSession): Promise {
throw new Error("Method not implemented.")
}
- getStatus(data: Data): Promise {
+ async getStatus(data: Data): Promise {
throw new Error("Method not implemented.")
}
@@ -132,13 +142,11 @@ You can also use the constructor to initialize your integration with the third-p
Additionally, if you’re creating your Payment Provider as an external plugin to be installed on any Medusa server and you want to access the options added for the plugin, you can access it in the constructor. The options are passed as a second parameter:
-
-
```ts
-class MyPaymentService extends AbstractPaymentService {
+class MyPaymentService extends AbstractPaymentService {
// ...
- constructor({ productService }, options) {
- super()
+ constructor(container, options) {
+ super(container)
// you can access options here
}
// ...
@@ -147,26 +155,62 @@ class MyPaymentService extends AbstractPaymentService {
### createPayment
-This method is called during checkout when [Payment Sessions are initialized](https://docs.medusajs.com/api/store/#tag/Cart/operation/PostCartsCartPaymentSessions) to present payment options to the customer. It is used to allow you to make any necessary calls to the third-party provider to initialize the payment. For example, in Stripe this method is used to initialize a Payment Intent for the customer.
+This method is called during checkout when [Payment Sessions are initialized](https://docs.medusajs.com/api/store/#tag/Cart/operation/PostCartsCartPaymentSessions) to present payment options to the customer. It is used to allow you to make any necessary calls to the third-party provider to initialize the payment.
-The method receives the cart as an object for its first parameter. It holds all the necessary information you need to know about the cart and the customer that owns this cart.
+For example, in Stripe this method is used to initialize a Payment Intent for the customer.
-This method must return an object that is going to be stored in the `data` field of the Payment Session to be created. As mentioned in the [Architecture Overview](./overview.md), the `data` field is useful to hold any data required by the third-party provider to process the payment or retrieve its details at a later point.
-
-An example of a minimal implementation of `createPayment` that does not interact with any third-party providers:
-
-
+The method receives a context object as a first parameter. This object is of type `PaymentContext` and has the following properties:
```ts
-import { Cart, Data } from "@medusajs/medusa"
-// ...
+type PaymentContext = {
+ cart: {
+ context: Record
+ id: string
+ email: string
+ shipping_address: Address | null
+ shipping_methods: ShippingMethod[]
+ }
+ currency_code: string
+ amount: number
+ resource_id?: string
+ customer?: Customer
+}
+```
-class MyPaymentService extends AbstractPaymentService {
+:::note
+
+Before v1.7.2, the first parameter was of type `Cart`. This method remains backwards compatible, but will be changed in the future. So, it's recommended to change the type of the first parameter to `PaymentContext`.
+
+:::
+
+This method must return an object of type `PaymentSessionResponse`. It should have the following properties:
+
+```ts
+type PaymentSessionResponse = {
+ update_requests: { customer_metadata: Record }
+ session_data: Record
+}
+```
+
+Where:
+
+- `session_data` is the data that is going to be stored in the `data` field of the Payment Session to be created. As mentioned in the [Architecture Overview](./overview.md), the `data` field is useful to hold any data required by the third-party provider to process the payment or retrieve its details at a later point.
+- `update_requests` is an object that can be used to pass data from the payment provider plugin to the core to update internal resources. Currently, it only has one attribute `customer_metadata` which allows updating the `metadata` field of the customer.
+
+An example of a minimal implementation of `createPayment`:
+
+```ts
+import { PaymentContext, PaymentSessionResponse } from "@medusajs/medusa"
+
+class MyPaymentService extends AbstractPaymentService {
// ...
- async createPayment(cart: Cart): Promise {
+ async createPayment(
+ context: Cart & PaymentContext
+ ): Promise {
+ // prepare data
return {
- id: "test-payment",
- status: "pending",
+ session_data,
+ update_requests,
}
}
}
@@ -182,13 +226,11 @@ This method must return an object containing the data from the third-party provi
An example of a minimal implementation of `retrievePayment` where you don’t need to interact with the third-party provider:
-
-
```ts
import { Data } from "@medusajs/medusa"
// ...
-class MyPaymentService extends AbstractPaymentService {
+class MyPaymentService extends AbstractPaymentService {
// ...
async retrievePayment(paymentData: Data): Promise {
return {}
@@ -214,13 +256,11 @@ This method returns a string that represents the status. The status must be one
An example of a minimal implementation of `getStatus` where you don’t need to interact with the third-party provider:
-
-
```ts
import { Data, PaymentSessionStatus } from "@medusajs/medusa"
// ...
-class MyPaymentService extends AbstractPaymentService {
+class MyPaymentService extends AbstractPaymentService {
// ...
async getStatus(data: Data): Promise {
return PaymentSessionStatus.AUTHORIZED
@@ -244,24 +284,68 @@ A line item refers to a product in the cart.
:::
-It accepts the `data` field of the Payment Session as the first parameter and the cart as an object for the second parameter.
+It accepts the `data` field of the Payment Session as the first parameter and a context object as a second parameter. This object is of type `PaymentContext` and has the following properties:
+
+```ts
+type PaymentContext = {
+ cart: {
+ context: Record
+ id: string
+ email: string
+ shipping_address: Address | null
+ shipping_methods: ShippingMethod[]
+ }
+ currency_code: string
+ amount: number
+ resource_id?: string
+ customer?: Customer
+}
+```
+
+:::note
+
+Before v1.7.2, the second parameter was of type `Cart`. This method remains backwards compatible, but will be changed in the future. So, it's recommended to change the type of the first parameter to `PaymentContext`.
+
+:::
You can utilize this method to interact with the third-party provider and update any details regarding the payment if necessary.
-This method must return an object that will be stored in the `data` field of the Payment Session.
-
-An example of a minimal implementation of `updatePayment` that does not need to make any updates on the third-party provider or the `data` field of the Payment Session:
-
-
+This method must return an object of type `PaymentSessionResponse`. It should have the following properties:
```ts
-import { Cart, Data } from "@medusajs/medusa"
+type PaymentSessionResponse = {
+ update_requests: { customer_metadata: Record }
+ session_data: Record
+}
+```
+
+Where:
+
+- `session_data` is the data that is going to be stored in the `data` field of the Payment Session to be created. As mentioned in the [Architecture Overview](./overview.md), the `data` field is useful to hold any data required by the third-party provider to process the payment or retrieve its details at a later point.
+- `update_requests` is an object that can be used to request from the Medusa core to update internal resources. Currently, it only has one attribute `customer_metadata` which allows updating the `metadata` field of the customer.
+
+An example of a minimal implementation of `updatePayment`:
+
+```ts
+import {
+ PaymentSessionData,
+ Cart,
+ PaymentContext,
+ PaymentSessionResponse,
+} from "@medusajs/medusa"
// ...
-class MyPaymentService extends AbstractPaymentService {
+class MyPaymentService extends AbstractPaymentService {
// ...
- async updatePayment(paymentSessionData: Data, cart: Cart): Promise {
- return paymentSessionData
+ async updatePayment(
+ paymentSessionData: PaymentSessionData,
+ cart: Cart
+ ): Promise {
+ // prepare data
+ return {
+ session_data,
+ update_requests,
+ }
}
}
```
@@ -278,18 +362,16 @@ This method must return an object that will be stored in the `data` field of the
An example of a minimal implementation of `updatePaymentData` that returns the `updatedData` passed in the body of the request as-is to update the `data` field of the Payment Session.
-
-
```ts
-import { Data } from "@medusajs/medusa"
+import { Data, PaymentSessionData } from "@medusajs/medusa"
// ...
-class MyPaymentService extends AbstractPaymentService {
+class MyPaymentService extends AbstractPaymentService {
// ...
async updatePaymentData(
- paymentSessionData: Data,
- updatedData: Data
- ): Promise {
+ paymentSessionData: PaymentSessionData,
+ data: Data
+ ): Promise {
return updatedData
}
}
@@ -310,13 +392,11 @@ You can use this method to interact with the third-party provider to delete data
An example of a minimal implementation of `deletePayment` where no interaction with a third-party provider is required:
-
-
```ts
import { PaymentSession } from "@medusajs/medusa"
// ...
-class MyPaymentService extends AbstractPaymentService {
+class MyPaymentService extends AbstractPaymentService {
// ...
async deletePayment(paymentSession: PaymentSession): Promise {
return
@@ -353,22 +433,21 @@ You can utilize this method to interact with the third-party provider and perfor
An example of a minimal implementation of `authorizePayment` that doesn’t need to interact with any third-party provider:
-
-
```ts
import {
Data,
PaymentSession,
PaymentSessionStatus,
+ PaymentSessionData,
} from "@medusajs/medusa"
// ...
-class MyPaymentService extends AbstractPaymentService {
+class MyPaymentService extends AbstractPaymentService {
// ...
async authorizePayment(
paymentSession: PaymentSession,
context: Data
- ): Promise<{ data: Data; status: PaymentSessionStatus; }> {
+ ): Promise<{ data: PaymentSessionData; status: PaymentSessionStatus }> {
return {
status: PaymentSessionStatus.AUTHORIZED,
data: {
@@ -389,13 +468,11 @@ This method must return an object to be stored in the `data` field of the Paymen
An example of a minimal implementation of `getPaymentData`:
-
-
```ts
import { Data, PaymentSession } from "@medusajs/medusa"
// ...
-class MyPaymentService extends AbstractPaymentService {
+class MyPaymentService extends AbstractPaymentService {
// ...
async getPaymentData(paymentSession: PaymentSession): Promise {
return paymentSession.data
@@ -417,13 +494,11 @@ This method must return an object that will be stored in the `data` field of the
An example of a minimal implementation of `capturePayment` that doesn’t need to interact with a third-party provider:
-
-
```ts
import { Data, Payment } from "@medusajs/medusa"
// ...
-class MyPaymentService extends AbstractPaymentService {
+class MyPaymentService extends AbstractPaymentService {
// ...
async capturePayment(payment: Payment): Promise {
return {
@@ -447,13 +522,11 @@ This method must return an object that is stored in the `data` field of the Paym
An example of a minimal implementation of `refundPayment` that doesn’t need to interact with a third-party provider:
-
-
```ts
import { Data, Payment } from "@medusajs/medusa"
// ...
-class MyPaymentService extends AbstractPaymentService {
+class MyPaymentService extends AbstractPaymentService {
// ...
async refundPayment(
payment: Payment,
@@ -483,13 +556,11 @@ This method must return an object that is stored in the `data` field of the Paym
An example of a minimal implementation of `cancelPayment` that doesn’t need to interact with a third-party provider:
-
-
```ts
import { Data, Payment } from "@medusajs/medusa"
// ...
-class MyPaymentService extends AbstractPaymentService {
+class MyPaymentService extends AbstractPaymentService {
// ...
async cancelPayment(payment: Payment): Promise {
return {
@@ -521,13 +592,11 @@ If you’re using Medusa’s [Next.js](../../../starters/nextjs-medusa-starter.m
An example of the implementation of `retrieveSavedMethods` taken from Stripe’s Payment Provider:
-
-
```ts
import { Customer, Data } from "@medusajs/medusa"
// ...
-class MyPaymentService extends AbstractPaymentService {
+class MyPaymentService extends AbstractPaymentService {
// ...
/**
* Fetches a customers saved payment methods if registered in Stripe.
diff --git a/docs/content/advanced/backend/subscribers/overview.md b/docs/content/advanced/backend/subscribers/overview.md
index 9babc0cdc0..c61fa9171e 100644
--- a/docs/content/advanced/backend/subscribers/overview.md
+++ b/docs/content/advanced/backend/subscribers/overview.md
@@ -22,6 +22,14 @@ Custom subscribers are TypeScript or JavaScript files in your project's `src/sub
Whenever an event is emitted, the subscriber’s registered handler method is executed. The handler method receives as a parameter an object that holds data related to the event. For example, if an order is placed the `order.placed` event will be emitted and all the handlers will receive the order id in the parameter object.
+### Example Use Cases
+
+Subscribers are useful in many use cases, including:
+
+- Send a confirmation email to the customer when they place an order by subscribing to the `order.placed` event.
+- Automatically assign new customers to a customer group by subscribing to the `customer.created`.
+- Handle custom events that you emit
+
---
## See Also
diff --git a/docs/content/advanced/backend/upgrade-guides/1-7-1.md b/docs/content/advanced/backend/upgrade-guides/1-7-1.md
index 1a1f2d617c..3ac0f87a97 100644
--- a/docs/content/advanced/backend/upgrade-guides/1-7-1.md
+++ b/docs/content/advanced/backend/upgrade-guides/1-7-1.md
@@ -76,20 +76,20 @@ Although this change is currently backwards compatible, it is recommended to cha
```ts
-import { PaymentContext, PaymentSessionResponse } from "@medusajs/medusa"
+import { Cart, PaymentSessionData, PaymentContext, PaymentSessionResponse } from "@medusajs/medusa"
// ...
class MyPaymentService extends AbstractPaymentService {
// ...
async createPayment(
- context: PaymentContext
+ context: Cart & PaymentContext
): Promise {
// ...
}
async updatePayment(
paymentSessionData: PaymentSessionData,
- context: PaymentContext
+ context: Cart & PaymentContext
): Promise {
// ...
}
diff --git a/docs/content/advanced/ecommerce/handle-order-claim-event.md b/docs/content/advanced/ecommerce/handle-order-claim-event.md
index 2b394871ba..c2d18c7be0 100644
--- a/docs/content/advanced/ecommerce/handle-order-claim-event.md
+++ b/docs/content/advanced/ecommerce/handle-order-claim-event.md
@@ -28,7 +28,7 @@ Redis is required for batch jobs to work. Make sure you [install Redis](../../t
### Notification Provider
-To send an email or another type of notification method, you must have a notification provider installed or configured.
+To send an email or another type of notification method, you must have a notification provider installed or configured. You can either install an existing plugin or [create your own](../backend/notification/how-to-create-notification-provider.md).
This document has an example using the [SendGrid](../../add-plugins/sendgrid.mdx) plugin.
@@ -47,26 +47,24 @@ You can learn more about subscribers in the [Subscribers](../backend/subscribers
Create the file `src/subscribers/claim-order.ts` with the following content:
```ts title=src/subscribers/claim-order.ts
-import { EventBusService } from "@medusajs/medusa"
-
type InjectedDependencies = {
- eventBusService: EventBusService,
+ // TODO add necessary dependencies
}
class ClaimOrderSubscriber {
- constructor({ eventBusService }: InjectedDependencies) {
-
+ constructor(container: InjectedDependencies) {
+ // TODO subscribe to event
}
}
export default ClaimOrderSubscriber
```
-If you want to add any other dependencies, you can add them to the `InjectedDependencies` type.
+You’ll be adding in the next step the necessary dependencies to the subscriber.
-:::tip
+:::info
-You can learn more about dependency injection in [this documentation](../backend/dependency-container/index.md).
+You can learn more about [dependency injection](../backend/dependency-container/index.md) in this documentation.
:::
@@ -74,29 +72,59 @@ You can learn more about dependency injection in [this documentation](../backend
## Step 2: Subscribe to the Event
-In the subscriber you created, add the following in the `constructor`:
+In this step, you’ll subscribe to the `order-update-token.created` event to send the customer a notification about their order edit.
+
+There are two ways to do this:
+
+### Method 1: Using the NotificationService
+
+If the notification provider you’re using already implements the logic to handle this event, you can subscribe to the event using the `NotificationService`:
```ts title=src/subscribers/claim-order.ts
+import { NotificationService } from "@medusajs/medusa"
+
+type InjectedDependencies = {
+ notificationService: NotificationService
+}
+
+class ClaimOrderSubscriber {
+ constructor({ notificationService }: InjectedDependencies) {
+ notificationService.subscribe(
+ "order-update-token.created",
+ ""
+ )
+ }
+}
+
+export default ClaimOrderSubscriber
+```
+
+Where `` is the identifier for your notification provider.
+
+:::info
+
+You can learn more about handling events with the Notification Service using [this documentation](../backend/notification/how-to-create-notification-provider.md).
+
+:::
+
+### Method 2: Using the EventBusService
+
+If the notification provider you’re using isn’t configured to handle this event, or you want to implement some other custom logic, you can subscribe to the event using the `EventBusService`:
+
+```ts title=src/subscribers/claim-order.ts
+import { EventBusService } from "@medusajs/medusa"
+
+type InjectedDependencies = {
+ eventBusService: EventBusService
+}
+
class ClaimOrderSubscriber {
constructor({ eventBusService }: InjectedDependencies) {
eventBusService.subscribe(
- "order-update-token.created",
+ "order-update-token.created",
this.handleRequestClaimOrder
)
}
- // ...
-}
-```
-
-You use the `eventBusService` to subscribe to the `order-update-token.created` event. You pass the method `handleRequestClaimOrder` as a handler to that event. You’ll create this method in the next step.
-
-## Step 3: Create Event Handler
-
-In the subscriber, add a new method `handleRequestClaimOrder`:
-
-```ts title=src/subscribers/claim-order.ts
-class ClaimOrderSubscriber {
- // ...
handleRequestClaimOrder = async (data) => {
// TODO: handle event
@@ -106,6 +134,8 @@ class ClaimOrderSubscriber {
export default ClaimOrderSubscriber
```
+When using this method, you’ll have to handle the logic of sending the confirmation email to the customer inside the handler function, which in this case is `handleRequestClaimOrder`.
+
The `handleRequestClaimOrder` event receives a `data` object as a parameter. This object holds the following properties:
1. `old_email`: The email associated with the orders.
diff --git a/docs/content/advanced/ecommerce/send-gift-card-to-customer.md b/docs/content/advanced/ecommerce/send-gift-card-to-customer.md
new file mode 100644
index 0000000000..d2b11bcc94
--- /dev/null
+++ b/docs/content/advanced/ecommerce/send-gift-card-to-customer.md
@@ -0,0 +1,149 @@
+# Send Gift Card Code to Customer
+
+In this document, you’ll learn how to send a customer the gift card code they purchased.
+
+## Overview
+
+Once the customer purchases a gift card, they should receive the code of the gift card so that they can use it in future purchases.
+
+Typically, the code would be sent by email, however, you’re free to choose how you deliver the gift card code to the customer.
+
+This document shows you how to track when a gift card has been purchased so that you can send its code to the customer.
+
+:::tip
+
+You can alternatively use the [SendGrid](../../add-plugins/sendgrid.mdx) plugin, which handles sending the email automatically.
+
+:::
+
+---
+
+## Prerequisites
+
+### Medusa Components
+
+It's assumed that you already have a Medusa server installed and set up. If not, you can follow the [quickstart guide](../../quickstart/quick-start.mdx) to get started.
+
+### Redis
+
+Redis is required for batch jobs to work. Make sure you [install Redis](../../tutorial/0-set-up-your-development-environment.mdx#redis) and [configure it with your Medusa server](../../usage/configurations.md#redis).
+
+### Notification Provider
+
+To send an email or another type of notification method, you must have a notification provider installed or configured. You can either install an existing plugin or [create your own](../backend/notification/how-to-create-notification-provider.md).
+
+---
+
+## Step 1: Create a Subscriber
+
+To subscribe to and handle an event, you must create a subscriber.
+
+:::info
+
+You can learn more about subscribers in the [Subscribers](../backend/subscribers/overview.md) documentation.
+
+:::
+
+Create the file `src/subscribers/gift-card.ts` with the following content:
+
+```ts title=src/subscribers/gift-card.ts
+type InjectedDependencies = {
+ // TODO add necessary dependencies
+}
+
+class GiftCardSubscriber {
+ constructor(container: InjectedDependencies) {
+ // TODO subscribe to event
+ }
+}
+
+export default GiftCardSubscriber
+```
+
+You’ll be adding in the next step the necessary dependencies to the subscriber.
+
+:::info
+
+You can learn more about [dependency injection](../backend/dependency-container/index.md) in this documentation.
+
+:::
+
+---
+
+## Step 2: Subscribe to the Event
+
+In this step, you’ll subscribe to the event `gift_card.created` to send the customer a notification about their gift card.
+
+There are two ways to do this:
+
+### Method 1: Using the NotificationService
+
+If the notification provider you’re using already implements the logic to handle this event, you can subscribe to the event using the `NotificationService`:
+
+```ts title=src/subscribers/gift-card.ts
+import { NotificationService } from "@medusajs/medusa"
+
+type InjectedDependencies = {
+ notificationService: NotificationService
+}
+
+class GiftCardSubscriber {
+ constructor({ notificationService }: InjectedDependencies) {
+ notificationService.subscribe(
+ "gift_card.created",
+ ""
+ )
+ }
+}
+
+export default GiftCardSubscriber
+```
+
+Where `` is the identifier for your notification provider. For example, if you’re using SendGrid, the identifier is `sendgrid`.
+
+:::info
+
+You can learn more about handling events with the Notification Service using [this documentation](../backend/notification/how-to-create-notification-provider.md).
+
+:::
+
+### Method 2: Using the EventBusService
+
+If the notification provider you’re using isn’t configured to handle this event, or you want to implement some other custom logic, you can subscribe to the event using the `EventBusService`:
+
+```ts title=src/subscribers/gift-card.ts
+import { EventBusService, GiftCardService } from "@medusajs/medusa"
+
+type InjectedDependencies = {
+ eventBusService: EventBusService
+ giftCardService: GiftCardService
+}
+
+class GiftCardSubscriber {
+ giftCardService: GiftCardService
+
+ constructor({ eventBusService, giftCardService }: InjectedDependencies) {
+ this.giftCardService = giftCardService
+ eventBusService.subscribe("gift_card.created", this.handleGiftCard)
+ }
+
+ handleGiftCard = async (data) => {
+ const giftCard = await this.giftCardService.retrieve(data.id)
+ // TODO send customer the gift card code
+ }
+}
+
+export default GiftCardSubscriber
+```
+
+When using this method, you’ll have to handle the logic of sending the code to the customer inside the handler function, which in this case is `handleGiftCard`.
+
+The `handleGiftCard` event receives a `data` object as a parameter. This object holds the `id` property which is the ID of the gift card. You can retrieve the full gift card object using the [GiftCardService](../../references/services/classes/GiftCardService.md)
+
+---
+
+## See Also
+
+- [Subscribers overview](../backend/subscribers/overview.md)
+- [Notification architecture overview](../backend/notification/overview.md)
+- [Gift cards overview](../backend/gift-cards/index.md)
\ No newline at end of file
diff --git a/docs/content/advanced/storefront/customer-profiles.mdx b/docs/content/advanced/storefront/customer-profiles.mdx
index d950a13b8d..7eb1b5bbd2 100644
--- a/docs/content/advanced/storefront/customer-profiles.mdx
+++ b/docs/content/advanced/storefront/customer-profiles.mdx
@@ -71,6 +71,9 @@ medusa.customers.create({
fetch(`/store/customers`, {
method: "POST",
credentials: "include",
+ headers: {
+ "Content-Type": "application/json",
+ },
body: JSON.stringify({
email,
password,
@@ -126,6 +129,9 @@ medusa.auth.authenticate({
fetch(`/store/auth`, {
method: "POST",
credentials: "include",
+ headers: {
+ "Content-Type": "application/json",
+ },
body: JSON.stringify({
email,
password,
@@ -214,6 +220,9 @@ medusa.customers.generatePasswordToken({
fetch(`/store/customers/password-token`, {
method: "POST",
credentials: "include",
+ headers: {
+ "Content-Type": "application/json",
+ },
body: JSON.stringify({
email,
}),
@@ -266,6 +275,9 @@ medusa.customers.resetPassword({
fetch(`/store/customers/password-reset`, {
method: "POST",
credentials: "include",
+ headers: {
+ "Content-Type": "application/json",
+ },
body: JSON.stringify({
email,
password,
@@ -316,6 +328,9 @@ medusa.customers.update({
fetch(`/store/customers/me`, {
method: "POST",
credentials: "include",
+ headers: {
+ "Content-Type": "application/json",
+ },
body: JSON.stringify({
first_name,
}),
@@ -380,6 +395,9 @@ medusa.customers.addresses.addAddress({
fetch(`/store/customers/me/addresses`, {
method: "POST",
credentials: "include",
+ headers: {
+ "Content-Type": "application/json",
+ },
body: JSON.stringify({
address: {
first_name,
@@ -441,6 +459,9 @@ medusa.customers.addresses.updateAddress(addressId, {
fetch(`/store/customers/me/addresses/${addressId}`, {
method: "POST",
credentials: "include",
+ headers: {
+ "Content-Type": "application/json",
+ },
body: JSON.stringify({
first_name,
}),
diff --git a/docs/content/advanced/storefront/use-discounts-in-checkout.mdx b/docs/content/advanced/storefront/use-discounts-in-checkout.mdx
index e7398ffaaa..b2a8273071 100644
--- a/docs/content/advanced/storefront/use-discounts-in-checkout.mdx
+++ b/docs/content/advanced/storefront/use-discounts-in-checkout.mdx
@@ -27,7 +27,7 @@ You want to implement discount functionality in your store to allow customers to
### Medusa Components
-It's assumed that you already have a Medusa server installed and set up. If not, you can follow our [quickstart guide](../../quickstart/quick-start.mdx) to get started.
+It's assumed that you already have a Medusa server installed and set up. If not, you can follow the [quickstart guide](../../quickstart/quick-start.mdx) to get started.
It is also assumed you already have a storefront set up. It can be a custom storefront or one of Medusa’s storefronts. If you don’t have a storefront set up, you can install either the [Next.js](../../starters/nextjs-medusa-starter.mdx) or [Gatsby](../../starters/gatsby-medusa-starter.mdx) storefronts.
diff --git a/docs/content/advanced/storefront/use-gift-cards.mdx b/docs/content/advanced/storefront/use-gift-cards.mdx
new file mode 100644
index 0000000000..71b34f3965
--- /dev/null
+++ b/docs/content/advanced/storefront/use-gift-cards.mdx
@@ -0,0 +1,239 @@
+import Tabs from '@theme/Tabs';
+import TabItem from '@theme/TabItem';
+
+# Use Gift Cards on the Storefront
+
+In this document, you’ll learn how to use gift cards on a storefront.
+
+## Overview
+
+Customers can view and purchase gift card products. Then, customers can redeem the gift card in a future order.
+
+### Scenario
+
+You want to implement the following features in a storefront:
+
+- Show the gift card product to the customer.
+- View details of a gift card by its code.
+- Redeem a gift card during checkout.
+
+---
+
+## Prerequisites
+
+### Medusa Components
+
+It's assumed that you already have a Medusa server installed and set up. If not, you can follow the [quickstart guide](../../quickstart/quick-start.mdx) to get started.
+
+It is also assumed you already have a storefront set up. It can be a custom storefront or one of Medusa’s storefronts. If you don’t have a storefront set up, you can install either the [Next.js](../../starters/nextjs-medusa-starter.mdx) or [Gatsby](../../starters/gatsby-medusa-starter.mdx) storefronts.
+
+### JS Client
+
+This guide includes code snippets to send requests to your Medusa server using Medusa’s JS Client and JavaScript’s Fetch API.
+
+If you follow the JS Client code blocks, it’s assumed you already have [Medusa’s JS Client installed](../../js-client/overview.md) and have [created an instance of the client](../../js-client/overview.md#configuration).
+
+### Previous Steps
+
+To use gift cards, you must have a gift card created first. You can follow this documentation to learn how to do it using the admin APIs.
+
+In addition, this document doesn't cover how to implement checkout functionality. You can follow [this document](./how-to-implement-checkout-flow.mdx) to learn how to implement that.
+
+---
+
+## Show the Gift Card Product
+
+Customers should be able to view gift cards before they make the purchase. Gift cards are essentially products like any other.
+
+You can retrieve the gift card product using the [List Products](/api/store/#tag/Product/operation/GetProducts) endpoint, but passing it the `is_giftcard` query parameter:
+
+
+
+
+```ts
+medusa.products.list({
+ is_giftcard: true,
+})
+.then(({ products, limit, offset, count }) => {
+ if (products.length) {
+ // gift card product exists
+ const giftcard = products[0]
+ } else {
+ // no gift card product is created
+ }
+})
+```
+
+
+
+
+```ts
+fetch(`/store/products?is_giftcard=true`, {
+ credentials: "include",
+})
+.then((response) => response.json())
+.then(({ products, limit, offset, count }) => {
+ if (products.length) {
+ // gift card product exists
+ const giftcard = products[0]
+ } else {
+ // no gift card product is created
+ }
+})
+```
+
+
+
+
+The request does not require any parameters. You can pass query parameters to filter the returned products.
+
+You can use the `is_giftcard` query parameter to retrieve only the gift card product by setting it to `true`. To view other available parameters, check out the [API reference](/api/store/#tag/Product/operation/GetProducts)
+
+The request returns the `products` array in the response, which holds the gift card in it, if it’s available. It also returns [pagination fields](/api/store/#section/Pagination).
+
+### Show Gift Card’s Denominations
+
+The gift card’s denominations are available under the `variants` array. Each variant resembles a denomination.
+
+The value of each denomination (or variant) is under the `prices` array. If you add the `region_id` query parameter, only prices for that specific regions are returned.
+
+---
+
+## View Details of a Gift Card by Code
+
+After the customer purchases the gift card, they’ll receive a code to redeem that gift card. Using that code, the customer can also view the details of that gift card.
+
+You can retrieve the details of a gift card by sending a request to the [Get Gift Card by Code](/api/store/#tag/Gift-Card/operation/GetGiftCardsCode) endpoint:
+
+
+
+
+```ts
+medusa.giftCards.retrieve(code)
+.then(({ gift_card }) => {
+ console.log(gift_card.id)
+})
+.catch((e) => {
+ // gift card doesn't exist or is disabled
+})
+```
+
+
+
+
+```ts
+fetch(`/store/gift-cards/${code}`, {
+ credentials: "include",
+})
+.then((response) => response.json())
+.then(({ gift_card }) => {
+ console.log(gift_card.id)
+})
+.catch((e) => {
+ // gift card doesn't exist or is disabled
+})
+```
+
+
+
+
+This request requires the code of the gift card passed as a path parameter.
+
+It returns the gift card if it exists in the response. Otherwise, an error is returned.
+
+### Show Gift Card Details
+
+In the returned gift card object, the following details can be shown to the customer:
+
+- `value`: The amount of the gift card.
+- `balance`: The remaining amount of the gift card. If the customer has previously used the gift card while purchasing an order but not its full value, this field shows how much is remaining in the card.
+- `ends_at`: The expiry date and time of the gift card.
+
+You can learn what other properties are available in the returned gift card object in the [API reference](/api/store/#tag/Gift-Card/operation/GetGiftCardsCode).
+
+---
+
+## Redeem Gift Card During Checkout
+
+A customer can redeem more than one gift card during checkout. The cart’s totals will then be adjusted based on the applied gift card. The gift card’s amount isn’t actually used until the order is placed.
+
+You can redeem a gift card during checkout by sending a request to the [Update Cart](/api/store/#tag/Cart/operation/PostCartsCart) endpoint:
+
+
+
+
+```ts
+medusa.carts.update(cartId, {
+ gift_cards: [
+ {
+ code,
+ },
+ ],
+})
+.then(({ cart }) => {
+ console.log(cart.gift_cards.length)
+})
+.catch((e) => {
+ // gift card doesn't exist or is disabled
+})
+```
+
+
+
+
+```ts
+fetch(`/store/cart/${cartId}`, {
+ method: "POST",
+ credentials: "include",
+ headers: {
+ "Content-Type": "application/json",
+ },
+ body: JSON.stringify({
+ gift_cards: [
+ {
+ code,
+ },
+ ],
+ }),
+})
+.then((response) => response.json())
+.then(({ cart }) => {
+ console.log(cart.gift_cards.length)
+})
+.catch((e) => {
+ // gift card doesn't exist or is disabled
+})
+```
+
+
+
+
+This request requires the ID of the cart as a path parameter. It allows passing any cart property you want to update in its body parameters.
+
+To add gift cards, you must pass the array `gift_cards`. Each item in the array should be an object having the property `code`, with its value being the code of the gift card to apply.
+
+:::tip
+
+The parameters passed in the update endpoint replace existing values. So, if you previously added a gift card, then tried adding another, you must include both in the `gift_cards` array.
+
+:::
+
+This request returns the card object in the response.
+
+### Show Gift Card Details in the Cart
+
+You can show the details of the applied gift cards by accessing `cart.gift_cards`. Its attributes are similar to those explained in [the previous section](#show-gft-card-details).
+
+You can also use the following properties to display changes on the cart’s totals:
+
+- `gift_card_total`: The total amount applied by all the gift cards.
+- `gift_card_tax_total`: The total tax applied for all gift cards.
+
+---
+
+## See Also
+
+- [Gift cards overview](../backend/gift-cards/index.md)
+- [Manage gift cards using admin APIs](../admin/manage-gift-cards.mdx)
+- [Send the customer a gift card](../ecommerce/send-gift-card-to-customer.md)
+- Gift cards [store](/api/store/#tag/Gift-Card) and [admin](/api/admin/#tag/Gift-Card) APIs
diff --git a/docs/content/homepage.mdx b/docs/content/homepage.mdx
index b99924ad24..c66f233f9e 100644
--- a/docs/content/homepage.mdx
+++ b/docs/content/homepage.mdx
@@ -37,7 +37,7 @@ Learn about Medusa basic features and kickstart your ecommerce project.
light: '/img/dev-env-icon.svg',
dark: '/img/dev-env-icon-dark.svg'
},
- description: 'Set up your dev environment.'
+ description: 'Prepare your setup for advanced development.'
}
},
{
diff --git a/docs/content/introduction.md b/docs/content/introduction.md
index df9764eed9..0f9993c4c2 100644
--- a/docs/content/introduction.md
+++ b/docs/content/introduction.md
@@ -2,13 +2,13 @@
## Architecture
-Medusa is composed of three components: The headless backend, the admin dashboard, and the storefront.
+Medusa is composed of three components: The Medusa server, the admin dashboard, and the storefront.

-### Headless Backend
+### Medusa Server
-This is the main component that holds all the logic and data of the store. Your admin dashboard and storefront interact with the backend to retrieve, create, and modify data through REST APIs.
+The Medusa server is a headless backend built on Node.js. This is the main component that holds all the logic and data of the store. Your admin dashboard and storefront interact with the backend to retrieve, create, and modify data through REST APIs.
Your Medusa server will include all functionalities related to your store’s checkout workflow. That includes cart management, shipping and payment providers, user management, and more. It also allows you to configure your store including your store’s region, tax rules, discounts, gift cards, and more.
@@ -36,6 +36,6 @@ Your customers use the Storefront to view products and make orders. Medusa provi
- [PriceList](./user-guide/price-lists/index.md) and [Discounts](./user-guide/discounts/): Advanced pricing for products with conditions based on the amount in the cart or promotions and discounts.
- [Taxes](./user-guide/taxes/index.md): Advanced tax configurations specific to multiple regions, with the capability of specifying taxes for specific products.
- [Sales Channels](./user-guide/sales-channels/index.md): Create multiple sales channels and control which sales channels products are available in.
-- [Bulk Import](./user-guide/products/import.mdx): Bulk import strategies for different entities including [products](./advanced/admin/import-prices.mdx) and [price lists](./advanced/admin/import-prices.mdx).
+- [Bulk Import](./user-guide/products/import.mdx): Bulk import strategies for different entities including [products](./advanced/admin/import-products.mdx) and [price lists](./advanced/admin/import-prices.mdx).
- [Bulk Export](./user-guide/products/export.mdx): Bulk export strategies for different entities including [products](./user-guide/products/export.mdx) and [orders](./user-guide/orders/export.mdx).
- Complete Customization Capabilities: Aside from all the features that Medusa provides, it is completely customizable providing capabilities to create custom [endpoints](./advanced/backend/endpoints/add.md), [services](./advanced/backend/services/create-service.md), [subscribers](./advanced/backend/subscribers/create-subscriber.md), [batch job strategies](./advanced/backend/batch-jobs/create.md), and much more!
diff --git a/docs/content/quickstart/quick-start-docker.mdx b/docs/content/quickstart/quick-start-docker.mdx
index c245445e51..c4d38500f8 100644
--- a/docs/content/quickstart/quick-start-docker.mdx
+++ b/docs/content/quickstart/quick-start-docker.mdx
@@ -81,19 +81,9 @@ Once done, your server will be accessible at `http://localhost:9000`.
You can test out your server using tools like Postman or by sending a cURL request:
```bash noReport
-curl -X GET localhost:9000/store/products | python -m json.tool
+curl -X GET localhost:9000/store/products
```
-:::note
-
-This command uses Python to format the result of the request better in your command line. If you don't want to use Python you can simply send a request without the formatting:
-
-```bash noReport
-curl localhost:9000/store/products
-```
-
-:::
-
---
## Additional steps
diff --git a/docs/content/quickstart/quick-start.mdx b/docs/content/quickstart/quick-start.mdx
index f3dc1c6ba4..e74085631b 100644
--- a/docs/content/quickstart/quick-start.mdx
+++ b/docs/content/quickstart/quick-start.mdx
@@ -66,20 +66,10 @@ If you run into any errors while installing the CLI tool, check out the [trouble
After these three steps and in only a couple of minutes, you now have a complete commerce engine running locally. You can test it out by sending a request using a tool like Postman or through the command line:
-```bash noReport
-curl localhost:9000/store/products | python -m json.tool
-```
-
-:::note
-
-This command uses Python to format the result of the request better in your command line. If you don't want to use Python you can simply send a request without the formatting:
-
```bash noReport
curl localhost:9000/store/products
```
-:::
-
---
## Additional Steps
diff --git a/docs/content/usage/create-medusa-app.mdx b/docs/content/usage/create-medusa-app.mdx
index adff4da8cd..60aa0354d1 100644
--- a/docs/content/usage/create-medusa-app.mdx
+++ b/docs/content/usage/create-medusa-app.mdx
@@ -42,9 +42,11 @@ In your terminal, run the following command:
You’ll then be asked to enter the name of the directory you want the project to be installed in. You can either leave the default value `my-medusa-store` or enter a new name.
-### Choose Medusa Starter
+### Choose Medusa Server Starter
-Next, you’ll be asked to choose the Medusa starter used to install the Medusa server. You can either pick the default Medusa starter, the Contentful starter or enter a starter URL by choosing `Other`:
+Next, you’ll be asked to choose the Medusa starter. The Medusa Server is created from a starter template. By default, it is created from the `medusa-starter-default` template.
+
+You can either pick the default Medusa starter, the Contentful starter or enter a starter URL by choosing `Other`:
```bash noReport
? Which Medusa starter would you like to install? …
diff --git a/packages/medusa/src/api/routes/admin/price-lists/list-price-list-products.ts b/packages/medusa/src/api/routes/admin/price-lists/list-price-list-products.ts
index 5ece8ef4e4..fe000db8bc 100644
--- a/packages/medusa/src/api/routes/admin/price-lists/list-price-list-products.ts
+++ b/packages/medusa/src/api/routes/admin/price-lists/list-price-list-products.ts
@@ -153,7 +153,7 @@ import { isDefined } from "medusa-core-utils"
* - api_token: []
* - cookie_auth: []
* tags:
- * - Product
+ * - Price List
* responses:
* 200:
* description: OK
diff --git a/packages/medusa/src/api/routes/admin/uploads/delete-upload.ts b/packages/medusa/src/api/routes/admin/uploads/delete-upload.ts
index 6d5f77049d..d8ee7adcf5 100644
--- a/packages/medusa/src/api/routes/admin/uploads/delete-upload.ts
+++ b/packages/medusa/src/api/routes/admin/uploads/delete-upload.ts
@@ -1,7 +1,7 @@
import { IsString } from "class-validator"
/**
- * [delete] /uploads
+ * @oas [delete] /uploads
* operationId: "AdminDeleteUploads"
* summary: "Delete an Uploaded File"
* description: "Removes an uploaded file using the installed fileservice"
diff --git a/packages/medusa/src/api/routes/admin/uploads/get-download-url.ts b/packages/medusa/src/api/routes/admin/uploads/get-download-url.ts
index e3aab51e12..41424954ba 100644
--- a/packages/medusa/src/api/routes/admin/uploads/get-download-url.ts
+++ b/packages/medusa/src/api/routes/admin/uploads/get-download-url.ts
@@ -2,7 +2,7 @@ import { AbstractFileService } from "../../../../interfaces"
import { IsString } from "class-validator"
/**
- * [post] /uploads/download-url
+ * @oas [post] /uploads/download-url
* operationId: "PostUploadsDownloadUrl"
* summary: "Get a File's Download URL"
* description: "Creates a presigned download url for a file"
diff --git a/www/docs/sidebars.js b/www/docs/sidebars.js
index 3f39e26167..c8fd3d0160 100644
--- a/www/docs/sidebars.js
+++ b/www/docs/sidebars.js
@@ -247,6 +247,11 @@ module.exports = {
id: "advanced/storefront/customer-profiles",
label: "Add Customer Profiles"
},
+ {
+ type: "doc",
+ id: "advanced/storefront/use-gift-cards",
+ label: "Use Gift Cards"
+ },
{
type: "doc",
id: "guides/carts-in-medusa",
@@ -323,6 +328,11 @@ module.exports = {
id: "advanced/admin/manage-discounts",
label: "Manage Discounts"
},
+ {
+ type: "doc",
+ id: "advanced/admin/manage-gift-cards",
+ label: "Manage Gift Cards"
+ },
{
type: "doc",
id: "advanced/admin/manage-regions",
@@ -409,12 +419,21 @@ module.exports = {
id: "advanced/ecommerce/handle-order-claim-event",
label: "Handle Order Claim Event"
},
+ {
+ type: "doc",
+ id: "advanced/ecommerce/send-gift-card-to-customer",
+ label: "Send Gift Card Code"
+ },
]
},
{
type: "category",
label: "Conceptual Guides",
items: [
+ {
+ type: "doc",
+ id: "advanced/backend/dependency-container/index"
+ },
{
type: "doc",
id: "advanced/backend/entities/overview",
@@ -478,6 +497,10 @@ module.exports = {
type: "doc",
id: "advanced/backend/customers/index"
},
+ {
+ type: "doc",
+ id: "advanced/backend/customer-groups/index"
+ },
{
type: "doc",
id: "advanced/backend/taxes/inclusive-pricing",
@@ -497,11 +520,7 @@ module.exports = {
},
{
type: "doc",
- id: "advanced/backend/customer-groups/index"
- },
- {
- type: "doc",
- id: "advanced/backend/dependency-container/index"
+ id: "advanced/backend/gift-cards/index"
},
]
},
diff --git a/www/docs/src/components/Feedback/index.js b/www/docs/src/components/Feedback/index.js
index 47ff900210..d1b13ccb6a 100644
--- a/www/docs/src/components/Feedback/index.js
+++ b/www/docs/src/components/Feedback/index.js
@@ -29,27 +29,34 @@ export default function Feedback ({
const location = useLocation();
function handleFeedback (e) {
+ submitFeedback()
setPositiveFeedbac(e.target.classList.contains('positive'));
setShowForm(true);
}
- function submitFeedback (e) {
+ function submitFeedback () {
if (isBrowser) {
if (window.analytics) {
- setLoading(true);
+ if (showForm) {
+ setLoading(true);
+ }
window.analytics.track(event, {
url: location.pathname,
label: document.title,
feedback: positiveFeedback ? 'yes' : 'no',
message
}, function () {
- setLoading(false);
- setShowForm(false);
- setSubmittedFeedback(true);
+ if (showForm) {
+ setLoading(false);
+ setShowForm(false);
+ setSubmittedFeedback(true);
+ }
})
} else {
- setShowForm(false);
- setSubmittedFeedback(true);
+ if (showForm) {
+ setShowForm(false);
+ setSubmittedFeedback(true);
+ }
}
}
}