- Get Started
- Product
- Resources
- Tools & SDKs
- Framework
- Reference
- Get Started
- Product
- Resources
- Tools & SDKs
- Framework
- Reference
How to Create a File Provider Module
In this document, you’ll learn how to create a file provider module and the methods you must implement in its main service.
1. Create Module Directory#
Start by creating a new directory for your module. For example, src/modules/my-file
.
2. Create the File Provider Service#
Create the file src/modules/my-file/service.ts
that holds the implementation of the module's main service. It must extend the AbstractFileProviderService
class imported from @medusajs/framework/utils
:
constructor#
The constructor allows you to access resources from the module's container using the first parameter, and the module's options using the second parameter.
If you're creating a client or establishing a connection with a third-party service, do it in the constructor.
Example
1import { Logger } from "@medusajs/framework/types"2import { AbstractFileProviderService } from "@medusajs/framework/utils"3 4type InjectedDependencies = {5 logger: Logger6}7 8type Options = {9 apiKey: string10}11 12class MyFileProviderService extends AbstractFileProviderService {13 protected logger_: Logger14 protected options_: Options15 static identifier = "my-file"16 // assuming you're initializing a client17 protected client18 19 constructor (20 { logger }: InjectedDependencies,21 options: Options22 ) {23 super()24 25 this.logger_ = logger26 this.options_ = options27 28 // assuming you're initializing a client29 this.client = new Client(options)30 }31}32 33export default MyFileProviderService
identifier#
Each file provider has a unique ID used to identify it. The provider's ID
will be stored as fs_{identifier}_{id}
, where {id}
is the provider's id
property in the medusa-config.ts
.
Example
validateOptions#
This method validates the options of the provider set in medusa-config.ts
.
Implementing this method is optional. It's useful if your provider requires custom validation.
If the options aren't valid, throw an error.
Example
Parameters
options
Record<any, any>Returns
upload#
This method uploads a file using your provider's custom logic.
Example
Parameters
The file to upload
Returns
Promise
Promise<ProviderFileResultDTO>The uploaded file's details.
Promise
Promise<ProviderFileResultDTO>delete#
This method deletes the file from storage.
Example
Parameters
The details of the file to delete.
Returns
Promise
Promise<void>getPresignedDownloadUrl#
This method is used to retrieve a download URL of the file. For some providers, such as S3, a presigned URL indicates a temporary URL to get access to a file.
If your provider doesn’t perform or offer a similar functionality, you can return the URL to download the file.
Example
1class MyFileProviderService extends AbstractFileProviderService {2 // ...3 async getPresignedDownloadUrl(4 fileData: ProviderGetFileDTO5 ): Promise<string> {6 // TODO logic to get the presigned URL7 // Use the `file.fileKey` to delete the file8 // for example:9 return this.client.getPresignedUrl(fileData.fileKey)10 }11}
Parameters
fileData
ProviderGetFileDTOThe details of the file to get its
presigned URL.
fileData
ProviderGetFileDTOReturns
Promise
Promise<string>The file's presigned URL.
Promise
Promise<string>3. Create Module Definition File#
Create the file src/modules/my-file/index.ts
with the following content:
This exports the module's definition, indicating that the MyFileProviderService
is the module's service.
4. Use Module#
To use your File Module Provider, add it to the providers
array of the File Module in medusa-config.ts
:
1module.exports = defineConfig({2 // ...3 modules: [4 {5 resolve: "@medusajs/medusa/file",6 options: {7 providers: [8 // default provider9 {10 resolve: "@medusajs/medusa/file-local",11 id: "local",12 },13 {14 resolve: "./src/modules/my-file",15 id: "my-file",16 options: {17 // provider options...18 },19 },20 ],21 },22 },23 ]24})
5. Test it Out#
To test out your file provider, use the Medusa Admin or the Upload API route to upload a file.