Class: ShippingOptionService
Provides layer to manipulate profiles.
Hierarchy
TransactionBaseService
Copy to Clipboard↳
ShippingOptionService
Copy to Clipboard
Constructors
constructor
• new ShippingOptionService(__namedParameters
Copy to Clipboard)
Parameters
Name | Type |
---|---|
__namedParameters Copy to Clipboard | InjectedDependencies Copy to Clipboard |
Overrides
TransactionBaseService.constructor
Defined in
medusa/src/services/shipping-option.ts:52
Properties
__configModule__
• Protected
Copy to Clipboard Optional
Copy to Clipboard Readonly
Copy to Clipboard __configModule__: Record
Copy to Clipboard<string
Copy to Clipboard, unknown
Copy to Clipboard>
Inherited from
TransactionBaseService.__configModule__
Defined in
medusa/src/interfaces/transaction-base-service.ts:14
__container__
• Protected
Copy to Clipboard Readonly
Copy to Clipboard __container__: any
Copy to Clipboard
Inherited from
TransactionBaseService.__container__
Defined in
medusa/src/interfaces/transaction-base-service.ts:13
__moduleDeclaration__
• Protected
Copy to Clipboard Optional
Copy to Clipboard Readonly
Copy to Clipboard __moduleDeclaration__: Record
Copy to Clipboard<string
Copy to Clipboard, unknown
Copy to Clipboard>
Inherited from
TransactionBaseService.__moduleDeclaration__
Defined in
medusa/src/interfaces/transaction-base-service.ts:15
featureFlagRouter_
• Protected
Copy to Clipboard Readonly
Copy to Clipboard featureFlagRouter_: FlagRouter
Copy to Clipboard
Defined in
medusa/src/services/shipping-option.ts:50
manager_
• Protected
Copy to Clipboard manager_: EntityManager
Copy to Clipboard
Inherited from
TransactionBaseService.manager_
Defined in
medusa/src/interfaces/transaction-base-service.ts:5
methodRepository_
• Protected
Copy to Clipboard Readonly
Copy to Clipboard methodRepository_: Repository
Copy to Clipboard<ShippingMethod
Copy to Clipboard>
Defined in
medusa/src/services/shipping-option.ts:49
optionRepository_
• Protected
Copy to Clipboard Readonly
Copy to Clipboard optionRepository_: Repository
Copy to Clipboard<ShippingOption
Copy to Clipboard> & { upsertShippingProfile
Copy to Clipboard: (shippingOptionIds
Copy to Clipboard: string
Copy to Clipboard[], shippingProfileId
Copy to Clipboard: string
Copy to Clipboard) => Promise
Copy to Clipboard<ShippingOption
Copy to Clipboard[]> }
Defined in
medusa/src/services/shipping-option.ts:48
providerService_
• Protected
Copy to Clipboard Readonly
Copy to Clipboard providerService_: FulfillmentProviderService
Copy to Clipboard
Defined in
medusa/src/services/shipping-option.ts:44
regionService_
• Protected
Copy to Clipboard Readonly
Copy to Clipboard regionService_: RegionService
Copy to Clipboard
Defined in
medusa/src/services/shipping-option.ts:45
requirementRepository_
• Protected
Copy to Clipboard Readonly
Copy to Clipboard requirementRepository_: Repository
Copy to Clipboard<ShippingOptionRequirement
Copy to Clipboard>
Defined in
medusa/src/services/shipping-option.ts:47
transactionManager_
• Protected
Copy to Clipboard transactionManager_: undefined
Copy to Clipboard | EntityManager
Copy to Clipboard
Inherited from
TransactionBaseService.transactionManager_
Defined in
medusa/src/interfaces/transaction-base-service.ts:6
Accessors
activeManager_
• Protected
Copy to Clipboard get
Copy to Clipboard activeManager_(): EntityManager
Copy to Clipboard
Returns
EntityManager
Copy to Clipboard
Inherited from
TransactionBaseService.activeManager_
Defined in
medusa/src/interfaces/transaction-base-service.ts:8
Methods
addRequirement
▸ addRequirement(optionId
Copy to Clipboard, requirement
Copy to Clipboard): Promise
Copy to Clipboard<ShippingOption
Copy to Clipboard>
Adds a requirement to a shipping option. Only 1 requirement of each type is allowed.
Parameters
Name | Type | Description |
---|---|---|
optionId Copy to Clipboard | string Copy to Clipboard | the option to add the requirement to. |
requirement Copy to Clipboard | ShippingOptionRequirement Copy to Clipboard | the requirement for the option. |
Returns
Promise
Copy to Clipboard<ShippingOption
Copy to Clipboard>
the result of update
Defined in
medusa/src/services/shipping-option.ts:693
atomicPhase_
▸ Protected
Copy to Clipboard atomicPhase_<TResult
Copy to Clipboard, TError
Copy to Clipboard>(work
Copy to Clipboard, isolationOrErrorHandler?
Copy to Clipboard, maybeErrorHandlerOrDontFail?
Copy to Clipboard): Promise
Copy to Clipboard<TResult
Copy to Clipboard>
Wraps some work within a transactional block. If the service already has a transaction manager attached this will be reused, otherwise a new transaction manager is created.
Type parameters
Name |
---|
TResult Copy to Clipboard |
TError Copy to Clipboard |
Parameters
Name | Type | Description |
---|---|---|
work Copy to Clipboard | (transactionManager Copy to Clipboard: EntityManager Copy to Clipboard) => Promise Copy to Clipboard<TResult Copy to Clipboard> | the transactional work to be done |
isolationOrErrorHandler? Copy to Clipboard | IsolationLevel Copy to Clipboard | (error Copy to Clipboard: TError Copy to Clipboard) => Promise Copy to Clipboard<void Copy to Clipboard | TResult Copy to Clipboard> | the isolation level to be used for the work. |
maybeErrorHandlerOrDontFail? Copy to Clipboard | (error Copy to Clipboard: TError Copy to Clipboard) => Promise Copy to Clipboard<void Copy to Clipboard | TResult Copy to Clipboard> | Potential error handler |
Returns
Promise
Copy to Clipboard<TResult
Copy to Clipboard>
the result of the transactional work
Inherited from
TransactionBaseService.atomicPhase_
Defined in
medusa/src/interfaces/transaction-base-service.ts:56
create
▸ create(data
Copy to Clipboard): Promise
Copy to Clipboard<ShippingOption
Copy to Clipboard>
Creates a new shipping option. Used both for outbound and inbound shipping
options. The difference is registered by the is_return
Copy to Clipboard field which
defaults to false.
Parameters
Name | Type | Description |
---|---|---|
data Copy to Clipboard | CreateShippingOptionInput Copy to Clipboard | the data to create shipping options |
Returns
Promise
Copy to Clipboard<ShippingOption
Copy to Clipboard>
the result of the create operation
Defined in
medusa/src/services/shipping-option.ts:431
createShippingMethod
▸ createShippingMethod(optionId
Copy to Clipboard, data
Copy to Clipboard, config
Copy to Clipboard): Promise
Copy to Clipboard<ShippingMethod
Copy to Clipboard>
Creates a shipping method for a given cart.
Parameters
Name | Type | Description |
---|---|---|
optionId Copy to Clipboard | string Copy to Clipboard | the id of the option to use for the method. |
data Copy to Clipboard | Record Copy to Clipboard<string Copy to Clipboard, unknown Copy to Clipboard> | the optional provider data to use. |
config Copy to Clipboard | CreateShippingMethodDto Copy to Clipboard | the cart to create the shipping method for. |
Returns
Promise
Copy to Clipboard<ShippingMethod
Copy to Clipboard>
the resulting shipping method.
Defined in
medusa/src/services/shipping-option.ts:258
delete
▸ delete(optionId
Copy to Clipboard): Promise
Copy to Clipboard<void
Copy to Clipboard | ShippingOption
Copy to Clipboard>
Deletes a profile with a given profile id.
Parameters
Name | Type | Description |
---|---|---|
optionId Copy to Clipboard | string Copy to Clipboard | the id of the profile to delete. Must be castable as an ObjectId |
Returns
Promise
Copy to Clipboard<void
Copy to Clipboard | ShippingOption
Copy to Clipboard>
the result of the delete operation.
Defined in
medusa/src/services/shipping-option.ts:671
deleteShippingMethods
▸ deleteShippingMethods(shippingMethods
Copy to Clipboard): Promise
Copy to Clipboard<ShippingMethod
Copy to Clipboard[]>
Removes a given shipping method
Parameters
Name | Type | Description |
---|---|---|
shippingMethods Copy to Clipboard | ShippingMethod Copy to Clipboard | ShippingMethod Copy to Clipboard[] | the shipping method to remove |
Returns
Promise
Copy to Clipboard<ShippingMethod
Copy to Clipboard[]>
removed shipping methods
Defined in
medusa/src/services/shipping-option.ts:238
getPrice_
▸ getPrice_(option
Copy to Clipboard, data
Copy to Clipboard, cart
Copy to Clipboard): Promise
Copy to Clipboard<number
Copy to Clipboard>
Returns the amount to be paid for a shipping method. Will ask the fulfillment provider to calculate the price if the shipping option has the price type "calculated".
Parameters
Name | Type | Description |
---|---|---|
option Copy to Clipboard | ShippingOption Copy to Clipboard | the shipping option to retrieve the price for. |
data Copy to Clipboard | Record Copy to Clipboard<string Copy to Clipboard, unknown Copy to Clipboard> | the shipping data to retrieve the price. |
cart Copy to Clipboard | undefined Copy to Clipboard | Order Copy to Clipboard | Cart Copy to Clipboard | the context in which the price should be retrieved. |
Returns
Promise
Copy to Clipboard<number
Copy to Clipboard>
the price of the shipping option.
Defined in
medusa/src/services/shipping-option.ts:771
list
▸ list(selector
Copy to Clipboard, config?
Copy to Clipboard): Promise
Copy to Clipboard<ShippingOption
Copy to Clipboard[]>
Parameters
Name | Type | Description |
---|---|---|
selector Copy to Clipboard | Selector Copy to Clipboard<ShippingOption Copy to Clipboard> | the query object for find |
config Copy to Clipboard | FindConfig Copy to Clipboard<ShippingOption Copy to Clipboard> | config object |
Returns
Promise
Copy to Clipboard<ShippingOption
Copy to Clipboard[]>
the result of the find operation
Defined in
medusa/src/services/shipping-option.ts:145
listAndCount
▸ listAndCount(selector
Copy to Clipboard, config?
Copy to Clipboard): Promise
Copy to Clipboard<[ShippingOption
Copy to Clipboard[], number
Copy to Clipboard]>
Parameters
Name | Type | Description |
---|---|---|
selector Copy to Clipboard | Selector Copy to Clipboard<ShippingOption Copy to Clipboard> | the query object for find |
config Copy to Clipboard | FindConfig Copy to Clipboard<ShippingOption Copy to Clipboard> | config object |
Returns
Promise
Copy to Clipboard<[ShippingOption
Copy to Clipboard[], number
Copy to Clipboard]>
the result of the find operation
Defined in
medusa/src/services/shipping-option.ts:160
removeRequirement
▸ removeRequirement(requirementId
Copy to Clipboard): Promise
Copy to Clipboard<void
Copy to Clipboard | ShippingOptionRequirement
Copy to Clipboard>
Removes a requirement from a shipping option
Parameters
Name | Type | Description |
---|---|---|
requirementId Copy to Clipboard | any Copy to Clipboard | the id of the requirement to remove |
Returns
Promise
Copy to Clipboard<void
Copy to Clipboard | ShippingOptionRequirement
Copy to Clipboard>
the result of update
Defined in
medusa/src/services/shipping-option.ts:722
retrieve
▸ retrieve(optionId
Copy to Clipboard, options?
Copy to Clipboard): Promise
Copy to Clipboard<ShippingOption
Copy to Clipboard>
Gets a profile by id. Throws in case of DB Error and if profile was not found.
Parameters
Name | Type | Description |
---|---|---|
optionId Copy to Clipboard | any Copy to Clipboard | the id of the profile to get. |
options Copy to Clipboard | FindConfig Copy to Clipboard<ShippingOption Copy to Clipboard> | the options to get a profile |
Returns
Promise
Copy to Clipboard<ShippingOption
Copy to Clipboard>
the profile document.
Defined in
medusa/src/services/shipping-option.ts:177
shouldRetryTransaction_
▸ Protected
Copy to Clipboard shouldRetryTransaction_(err
Copy to Clipboard): boolean
Copy to Clipboard
Parameters
Name | Type |
---|---|
err Copy to Clipboard | Record Copy to Clipboard<string Copy to Clipboard, unknown Copy to Clipboard> | { code Copy to Clipboard: string Copy to Clipboard } |
Returns
boolean
Copy to Clipboard
Inherited from
TransactionBaseService.shouldRetryTransaction_
Defined in
medusa/src/interfaces/transaction-base-service.ts:37
update
▸ update(optionId
Copy to Clipboard, update
Copy to Clipboard): Promise
Copy to Clipboard<ShippingOption
Copy to Clipboard>
Updates a profile. Metadata updates and product updates should use
dedicated methods, e.g. setMetadata
Copy to Clipboard, etc. The function
will throw errors if metadata or product updates are attempted.
Parameters
Name | Type | Description |
---|---|---|
optionId Copy to Clipboard | string Copy to Clipboard | the id of the option. Must be a string that can be casted to an ObjectId |
update Copy to Clipboard | UpdateShippingOptionInput Copy to Clipboard | an object with the update values. |
Returns
Promise
Copy to Clipboard<ShippingOption
Copy to Clipboard>
resolves to the update result.
Defined in
medusa/src/services/shipping-option.ts:559
updateShippingMethod
▸ updateShippingMethod(id
Copy to Clipboard, update
Copy to Clipboard): Promise
Copy to Clipboard<undefined
Copy to Clipboard | ShippingMethod
Copy to Clipboard>
Updates a shipping method's associations. Useful when a cart is completed and its methods should be copied to an order/swap entity.
Parameters
Name | Type | Description |
---|---|---|
id Copy to Clipboard | string Copy to Clipboard | the id of the shipping method to update |
update Copy to Clipboard | ShippingMethodUpdate Copy to Clipboard | the values to update the method with |
Returns
Promise
Copy to Clipboard<undefined
Copy to Clipboard | ShippingMethod
Copy to Clipboard>
the resulting shipping method
Defined in
medusa/src/services/shipping-option.ts:211
updateShippingProfile
▸ updateShippingProfile(optionIds
Copy to Clipboard, profileId
Copy to Clipboard): Promise
Copy to Clipboard<ShippingOption
Copy to Clipboard[]>
Parameters
Name | Type | Description |
---|---|---|
optionIds Copy to Clipboard | string Copy to Clipboard | string Copy to Clipboard[] | ID or IDs of the shipping options to update |
profileId Copy to Clipboard | string Copy to Clipboard | Shipping profile ID to update the shipping options with |
Returns
Promise
Copy to Clipboard<ShippingOption
Copy to Clipboard[]>
updated shipping options
Defined in
medusa/src/services/shipping-option.ts:747
validateAndMutatePrice
▸ Private
Copy to Clipboard validateAndMutatePrice(option
Copy to Clipboard, priceInput
Copy to Clipboard): Promise
Copy to Clipboard<CreateShippingOptionInput
Copy to Clipboard | Omit
Copy to Clipboard<ShippingOption
Copy to Clipboard, "beforeInsert"
Copy to Clipboard>>
Parameters
Name | Type |
---|---|
option Copy to Clipboard | ShippingOption Copy to Clipboard | CreateShippingOptionInput Copy to Clipboard |
priceInput Copy to Clipboard | ValidatePriceTypeAndAmountInput Copy to Clipboard |
Returns
Promise
Copy to Clipboard<CreateShippingOptionInput
Copy to Clipboard | Omit
Copy to Clipboard<ShippingOption
Copy to Clipboard, "beforeInsert"
Copy to Clipboard>>
Defined in
medusa/src/services/shipping-option.ts:388
validateCartOption
▸ validateCartOption(option
Copy to Clipboard, cart
Copy to Clipboard): Promise
Copy to Clipboard<null
Copy to Clipboard | ShippingOption
Copy to Clipboard>
Checks if a given option id is a valid option for a cart. If it is the option is returned with the correct price. Throws when region_ids do not match, or when the shipping option requirements are not satisfied.
Parameters
Name | Type | Description |
---|---|---|
option Copy to Clipboard | ShippingOption Copy to Clipboard | the option object to check |
cart Copy to Clipboard | Cart Copy to Clipboard | the cart object to check against |
Returns
Promise
Copy to Clipboard<null
Copy to Clipboard | ShippingOption
Copy to Clipboard>
the validated shipping option
Defined in
medusa/src/services/shipping-option.ts:346
validatePriceType_
▸ validatePriceType_(priceType
Copy to Clipboard, option
Copy to Clipboard): Promise
Copy to Clipboard<ShippingOptionPriceType
Copy to Clipboard>
Validates a shipping option price
Parameters
Name | Type | Description |
---|---|---|
priceType Copy to Clipboard | ShippingOptionPriceType Copy to Clipboard | the price to validate |
option Copy to Clipboard | ShippingOption Copy to Clipboard | the option to validate against |
Returns
Promise
Copy to Clipboard<ShippingOptionPriceType
Copy to Clipboard>
the validated price
Defined in
medusa/src/services/shipping-option.ts:519
validateRequirement_
▸ validateRequirement_(requirement
Copy to Clipboard, optionId?
Copy to Clipboard): Promise
Copy to Clipboard<ShippingOptionRequirement
Copy to Clipboard>
Validates a requirement
Parameters
Name | Type | Default value | Description |
---|---|---|---|
requirement Copy to Clipboard | ShippingOptionRequirement Copy to Clipboard | undefined Copy to Clipboard | the requirement to validate |
optionId Copy to Clipboard | undefined Copy to Clipboard | string Copy to Clipboard | undefined Copy to Clipboard | the id to validate the requirement |
Returns
Promise
Copy to Clipboard<ShippingOptionRequirement
Copy to Clipboard>
a validated shipping requirement
Defined in
medusa/src/services/shipping-option.ts:77
withTransaction
▸ withTransaction(transactionManager?
Copy to Clipboard): ShippingOptionService
Copy to Clipboard
Parameters
Name | Type |
---|---|
transactionManager? Copy to Clipboard | EntityManager Copy to Clipboard |
Returns
ShippingOptionService
Copy to Clipboard
Inherited from
TransactionBaseService.withTransaction