ProductService
constructor
Parameters
__namedParametersInjectedDependenciesRequiredProperties
manager_EntityManagerRequiredtransactionManager_undefined | EntityManagerRequired__container__anyRequiredfeatureFlagRouter_FlagRouterRequiredIndexName"products"RequiredEventsobjectRequiredEvents.UPDATEDstringRequiredDefault: "product.updated"
Events.CREATEDstringRequiredDefault: "product.created"
Events.DELETEDstringRequiredDefault: "product.deleted"
__configModule__Record<string, unknown>__moduleDeclaration__Record<string, unknown>Accessors
activeManager_
Returns
EntityManagerEntityManagerRequiredMethods
withTransaction
Parameters
transactionManagerEntityManagerReturns
thisthisRequiredshouldRetryTransaction_
Parameters
errRecord<string, unknown> | objectRequiredReturns
booleanbooleanRequiredatomicPhase_
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
TResultobjectRequiredTErrorobjectRequiredParameters
work(transactionManager: EntityManager) => Promise<TResult>RequiredisolationOrErrorHandlerIsolationLevel | (error: TError) => Promise<void | TResult>maybeErrorHandlerOrDontFail(error: TError) => Promise<void | TResult>Returns
PromisePromise<TResult>Requiredlist
Lists products based on the provided parameters.
Parameters
selectorProductSelectorRequiredconfigFindProductConfigRequiredReturns
listAndCount
Lists products based on the provided parameters and includes the count of products that match the query.
Parameters
selectorProductSelectorRequiredconfigFindProductConfigRequiredReturns
count
Return the total number of documents in database
Parameters
Returns
PromisePromise<number>Requiredretrieve
Gets a product by id. Throws in case of DB Error and if product was not found.
Parameters
productIdstringRequiredconfigFindProductConfigRequiredReturns
retrieveByHandle
Gets a product by handle. Throws in case of DB Error and if product was not found.
Parameters
productHandlestringRequiredconfigFindProductConfigRequiredDefault: {}
Returns
retrieveByExternalId
Gets a product by external id. Throws in case of DB Error and if product was not found.
Parameters
externalIdstringRequiredconfigFindProductConfigRequiredDefault: {}
Returns
retrieve_
Gets a product by selector. Throws in case of DB Error and if product was not found.
Parameters
Returns
retrieveVariants
Gets all variants belonging to a product.
Parameters
productIdstringRequiredconfigFindProductConfigRequiredReturns
filterProductsBySalesChannel
Parameters
productIdsstring[]RequiredsalesChannelIdstringRequiredconfigFindProductConfigRequiredReturns
listTypes
Returns
listTagsByUsage
Parameters
takenumberRequiredDefault: 10
Returns
isProductInSalesChannels
Check if the product is assigned to at least one of the provided sales channels.
Parameters
idstringRequiredsalesChannelIdsstring[]RequiredReturns
PromisePromise<boolean>Requiredcreate
Creates a product.
Parameters
productObjectCreateProductInputRequiredReturns
update
Updates a product. Product variant updates should use dedicated methods,
e.g. addVariant, etc. The function will throw errors if metadata or
product variant updates are attempted.
Parameters
productIdstringRequiredupdateUpdateProductInputRequiredReturns
delete
Deletes a product from a given product id. The product's associated variants will also be deleted.
Parameters
productIdstringRequiredReturns
PromisePromise<void>RequiredaddOption
Adds an option to a product. Options can, for example, be "Size", "Color", etc. Will update all the products variants with a dummy value for the newly created option. The same option cannot be added more than once.
Parameters
productIdstringRequiredoptionTitlestringRequiredReturns
reorderVariants
Parameters
productIdstringRequiredvariantOrderstring[]RequiredReturns
updateOption
Updates a product's option. Throws if the call tries to update an option not associated with the product. Throws if the updated title already exists.
Parameters
productIdstringRequiredoptionIdstringRequireddataProductOptionInputRequiredReturns
retrieveOptionByTitle
Retrieve product's option by title.
Parameters
titlestringRequiredproductIdstringRequiredReturns
deleteOption
Delete an option from a product.
Parameters
productIdstringRequiredoptionIdstringRequiredReturns
updateShippingProfile
Assign a product to a profile, if a profile id null is provided then detach the product from the profile
Parameters
productIdsstring | string[]RequiredprofileIdnull | stringRequiredReturns
prepareListQuery_
Temporary method to be used in place we need custom query strategy to prevent typeorm bug
Parameters
configFindProductConfigRequiredReturns
decorateProductsWithSalesChannels
Temporary method to join sales channels of a product using RemoteQuery while MedusaV2 FF is on.
Parameters
Returns
getSalesChannelModuleChannels
Temporary method to fetch sales channels of a product using RemoteQuery while MedusaV2 FF is on.
Parameters
productIdsstring[]Required