mirror of
https://github.com/nocobase/nocobase
synced 2024-11-15 18:37:04 +00:00
126 lines
2.5 KiB
Markdown
126 lines
2.5 KiB
Markdown
|
# Develop the first plugin
|
||
|
|
||
|
Before start, you need to install NocoBase:.
|
||
|
|
||
|
- [create-nocobase-app installation](/welcome/getting-started/installation/create-nocobase-app)
|
||
|
- [Git source installation](/welcome/getting-started/installation/git-clone)
|
||
|
|
||
|
Once NocoBase is installed, we can start our plugin development journey.
|
||
|
|
||
|
## Create a plugin
|
||
|
|
||
|
First, you can quickly create an empty plugin via the CLI with the following command.
|
||
|
|
||
|
```bash
|
||
|
yarn pm create hello
|
||
|
```
|
||
|
|
||
|
The directory where the plugin is located ``packages/plugins/hello`` and the plugin directory structure is
|
||
|
|
||
|
```bash
|
||
|
|- /hello
|
||
|
|- /src
|
||
|
|- /client # plugin client code
|
||
|
|- /server # plugin server code
|
||
|
|- client.d.ts
|
||
|
|- client.js
|
||
|
|- package.json # plugin package information
|
||
|
|- server.d.ts
|
||
|
|- server.js
|
||
|
package.json
|
||
|
|
||
|
package.json information
|
||
|
|
||
|
```json
|
||
|
{
|
||
|
"name": "@nocobase/plugin-hello",
|
||
|
"version": "0.1.0",
|
||
|
"main": "lib/server/index.js",
|
||
|
"devDependencies": {
|
||
|
"@nocobase/client": "0.8.0-alpha.1",
|
||
|
"@nocobase/test": "0.8.0-alpha.1"
|
||
|
}
|
||
|
}
|
||
|
```
|
||
|
|
||
|
A NocoBase plugin is also an NPM package, the correspondence rule between plugin name and NPM package name is `${PLUGIN_PACKAGE_PREFIX}-${pluginName}`.
|
||
|
|
||
|
`PLUGIN_PACKAGE_PREFIX` is the plugin package prefix, which can be customized in .env, [click here for PLUGIN_PACKAGE_PREFIX description](/api/env#plugin_package_prefix).
|
||
|
|
||
|
## Code the plugin
|
||
|
|
||
|
Look at the `packages/plugins/hello/src/server/plugin.ts` file and modify it to
|
||
|
|
||
|
```ts
|
||
|
import { InstallOptions, Plugin } from '@nocobase/server';
|
||
|
|
||
|
export class HelloPlugin extends Plugin {
|
||
|
afterAdd() {}
|
||
|
|
||
|
beforeLoad() {}
|
||
|
|
||
|
async load() {
|
||
|
this.db.collection({
|
||
|
name: 'hello',
|
||
|
fields: [
|
||
|
{ type: 'string', name: 'name' }
|
||
|
],
|
||
|
});
|
||
|
this.app.acl.allow('hello', '*');
|
||
|
}
|
||
|
|
||
|
async install(options?: InstallOptions) {}
|
||
|
|
||
|
async afterEnable() {}
|
||
|
|
||
|
async afterDisable() {}
|
||
|
|
||
|
async remove() {}
|
||
|
}
|
||
|
|
||
|
export default HelloPlugin;
|
||
|
```
|
||
|
|
||
|
## Register the plugin
|
||
|
|
||
|
```bash
|
||
|
yarn pm add hello
|
||
|
```
|
||
|
|
||
|
## Activate the plugin
|
||
|
|
||
|
When the plugin is activated, the hello table that you just configured is automatically created.
|
||
|
|
||
|
```bash
|
||
|
yarn pm enable hello
|
||
|
```
|
||
|
|
||
|
## Start the application
|
||
|
|
||
|
```bash
|
||
|
# for development
|
||
|
yarn dev
|
||
|
|
||
|
# for production
|
||
|
yarn build
|
||
|
yarn start
|
||
|
```
|
||
|
|
||
|
## Experience the plugin
|
||
|
|
||
|
Insert data into the hello table of the plugin
|
||
|
|
||
|
```bash
|
||
|
curl --location --request POST 'http://localhost:13000/api/hello:create' \
|
||
|
--header 'Content-Type: application/json' \
|
||
|
--data-raw '{
|
||
|
"name": "Hello world"
|
||
|
}'
|
||
|
```
|
||
|
|
||
|
View the data
|
||
|
|
||
|
```bash
|
||
|
curl --location --request GET 'http://localhost:13000/api/hello:list'
|
||
|
```
|