Files
medusa-store/www/apps/book/app/learn/fundamentals/plugins/page.mdx
2025-03-11 12:26:27 +02:00

57 lines
2.5 KiB
Plaintext

export const metadata = {
title: `${pageNumber} Plugins`,
}
# {metadata.title}
In this chapter, you'll learn what a plugin is in Medusa.
<Note>
Plugins are available starting from [Medusa v2.3.0](https://github.com/medusajs/medusa/releases/tag/v2.3.0).
</Note>
## What is a Plugin?
A plugin is a package of reusable Medusa customizations that you can install in any Medusa application. The supported customizations are [Modules](../modules/page.mdx), [API Routes](../api-routes/page.mdx), [Workflows](../workflows/page.mdx), [Workflow Hooks](../workflows/workflow-hooks/page.mdx), [Links](../module-links/page.mdx), [Subscribers](../events-and-subscribers/page.mdx), [Scheduled Jobs](../scheduled-jobs/page.mdx), and [Admin Extensions](../admin/page.mdx).
Plugins allow you to reuse your Medusa customizations across multiple projects or share them with the community. They can be published to npm and installed in any Medusa project.
![Diagram showcasing a wishlist plugin installed in a Medusa application](https://res.cloudinary.com/dza7lstvk/image/upload/v1737540762/Medusa%20Book/plugin-diagram_oepiis.jpg)
<Note title="Tip">
Learn how to create a wishlist plugin in [this guide](!resources!/plugins/guides/wishlist).
</Note>
---
## Plugin vs Module
A [module](../modules/page.mdx) is an isolated package related to a single domain or functionality, such as product reviews or integrating a Content Management System. A module can't access any resources in the Medusa application that are outside its codebase.
A plugin, on the other hand, can contain multiple Medusa customizations, including modules. Your plugin can define a module, then build flows around it.
For example, in a plugin, you can define a module that integrates a third-party service, then add a workflow that uses the module when a certain event occurs to sync data to that service.
<Note title="Use a plugin if" type="success">
- You want to reuse your Medusa customizations across multiple projects.
- You want to share your Medusa customizations with the community.
</Note>
<Note title="Don't use a plugin if" type="error">
- You want to build a custom feature related to a single domain or integrate a third-party service. Instead, use a [module](../modules/page.mdx). You can wrap that module in a plugin if it's used in other customizations, such as if it has a module link or it's used in a workflow.
</Note>
---
## How to Create a Plugin?
The next chapter explains how you can create and publish a plugin.