Creating Custom Integrations
Mastra allows you to create custom integrations, if you want to integrate with a third-party API that isn’t supported already.
There are three things you need to configure:
- Basic integration details in
integrations/integrations.json
- Export an integration class from a folder in
integrations/
- Import the integration in
mastra-config.ts
Step 1: Add integration details
Mastra looks for an integrations
directory in the root of the repo, and expects to find a file called integrations.json
in there.
Here’s an example of what the file should look like:
[
{
"name": "Sample Integration",
"packageName": "sample-integration",
"logoUrl": "",
"authType": "OAUTH",
"availableScopes": ["read", "write"],
"config": {},
"isUserDefined": true
}
]
Step 2: Export an integration class
Create a folder named after the integration in integrations/
and add an index.ts
file.
import { Integration, IntegrationAuth, IntegrationCredentialType } from '@mastra/core';
export class SampleIntegration extends Integration {
constructor({ config }: { config: Record<string, any> }) {
super({
name: 'Sample Integration',
logoUrl:
'',
});
}
getAuthenticator() {
return new IntegrationAuth({
// @ts-ignore
onConnectionCreated: () => {
// TODO
},
config: {
INTEGRATION_NAME: this.name,
AUTH_TYPE: IntegrationCredentialType.OAUTH,
CLIENT_ID: this.config.CLIENT_ID,
CLIENT_SECRET: this.config.CLIENT_SECRET,
REDIRECT_URI: this.config.REDIRECT_URI || this.corePresets.redirectURI,
SERVER: 'https://app.iroko.com',
AUTHORIZATION_ENDPOINT: '/-/oauth_authorize/',
TOKEN_ENDPOINT: '/-/oauth_token/',
SCOPES: [],
},
dataAccess: this.dataLayer!,
});
}
}
Step 3: Import the integration
At this point, your custom integration will be available in your admin console, so you can either install it there, or import the integration directly in mastra.config.ts
:
import { SampleIntegration } from './integrations/sample-integration';
// rest of config
export const config: Config = {
...restOfConfig,
integrations: [
new SampleIntegration({
config: {
CLIENT_ID: process.env.SAMPLE_CLIENT_ID!,
CLIENT_SECRET: process.env.SAMPLE_CLIENT_SECRET!,
SCOPES: undefined,
},
}),
...restOfIntegrations,
],
};