Plugin System
Ever Gauzy supports a plugin architecture for extending functionality.
Plugin Structureβ
packages/plugins/
βββ plugin-integration-github/ # GitHub integration
βββ plugin-integration-upwork/ # Upwork integration
βββ plugin-integration-hubstaff/ # HubStaff integration
βββ plugin-integration-jira/ # Jira integration
βββ plugin-integration-wakatime/ # Wakatime integration
βββ plugin-job-search/ # Job search
βββ plugin-job-matching/ # AI job matching
βββ plugin-knowledge-base/ # KB module
βββ plugin-changelog/ # Changelog tracking
βββ plugin-product-reviews/ # Product reviews
Creating a Pluginβ
1. Create Moduleβ
import { Module } from "@nestjs/common";
@Module({
imports: [],
providers: [CustomPluginService],
controllers: [CustomPluginController],
exports: [CustomPluginService],
})
export class CustomPluginModule {}
2. Register Pluginβ
// In PluginModule or AppModule
@Module({
imports: [
// ... core modules
CustomPluginModule,
],
})
export class AppModule {}
3. Add Entitiesβ
@MultiORMEntity("custom_plugin_data")
export class CustomPluginData extends TenantOrganizationBaseEntity {
@MultiORMColumn()
name: string;
@MultiORMColumn({ nullable: true })
value: string;
}
4. Register Entityβ
Add your entity to the plugin's module:
TypeOrmModule.forFeature([CustomPluginData]);
MikroOrmModule.forFeature([CustomPluginData]);
Plugin Guidelinesβ
- β
Extend
TenantOrganizationBaseEntityfor tenant scoping - β Use Multi-ORM decorators
- β
Define API contracts in
@gauzy/contracts - β Follow existing service/controller patterns
- β Don't modify core entities directly
- β Don't bypass tenant filtering