- Add Activepieces fork with SmoothSchedule custom piece - Create integrations app with Activepieces service layer - Add embed token endpoint for iframe integration - Create Automations page with embedded workflow builder - Add sidebar visibility fix for embed mode - Add list inactive customers endpoint to Public API - Include SmoothSchedule triggers: event created/updated/cancelled - Include SmoothSchedule actions: create/update/cancel events, list resources/services/customers 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
113 lines
2.8 KiB
TypeScript
113 lines
2.8 KiB
TypeScript
import {
|
|
createCustomApiCallAction,
|
|
HttpError,
|
|
} from '@activepieces/pieces-common';
|
|
import {
|
|
createPiece,
|
|
PieceAuth,
|
|
Property,
|
|
} from '@activepieces/pieces-framework';
|
|
import { AppConnectionType, PieceCategory } from '@activepieces/shared';
|
|
import { kimaiCreateTimesheetAction } from './lib/actions/create-timesheet';
|
|
import { makeClient } from './lib/common';
|
|
import { z } from 'zod';
|
|
import { propsValidation } from '@activepieces/pieces-common';
|
|
|
|
export const kimaiAuth = PieceAuth.CustomAuth({
|
|
description: `
|
|
To configure API access:
|
|
|
|
1. Go to Kimai Web UI;
|
|
2. Click on your user profile and then go to "API Access";
|
|
3. Configure an API password (different from user password).
|
|
`,
|
|
props: {
|
|
base_url: Property.ShortText({
|
|
displayName: 'Server URL',
|
|
description: 'Kimai Instance URL (e.g. https://demo.kimai.org)',
|
|
required: true,
|
|
}),
|
|
user: Property.ShortText({
|
|
displayName: 'Username',
|
|
description: 'Kimai Username/Email',
|
|
required: true,
|
|
}),
|
|
api_password: PieceAuth.SecretText({
|
|
displayName: 'API Password',
|
|
description: 'Kimai API Password',
|
|
required: true,
|
|
}),
|
|
},
|
|
validate: async ({ auth }) => {
|
|
if (auth) {
|
|
await propsValidation.validateZod(auth, {
|
|
base_url: z.string().url(),
|
|
});
|
|
}
|
|
|
|
if (!auth) {
|
|
return {
|
|
valid: false,
|
|
error: 'Configuration missing!',
|
|
};
|
|
}
|
|
|
|
const client = await makeClient({
|
|
type: AppConnectionType.CUSTOM_AUTH,
|
|
props: auth,
|
|
});
|
|
|
|
try {
|
|
const pingResponse = await client.ping();
|
|
if (pingResponse.message !== 'pong') {
|
|
return {
|
|
valid: false,
|
|
error: pingResponse.message,
|
|
};
|
|
}
|
|
|
|
return {
|
|
valid: true,
|
|
};
|
|
} catch (e) {
|
|
if (e instanceof HttpError) {
|
|
if (e.response.body instanceof Object && 'message' in e.response.body) {
|
|
return {
|
|
valid: false,
|
|
error: e.response.body.message as string,
|
|
};
|
|
}
|
|
}
|
|
|
|
return {
|
|
valid: false,
|
|
error: 'Please check your server URL/credentials and try again.',
|
|
};
|
|
}
|
|
},
|
|
required: true,
|
|
});
|
|
|
|
export const kimai = createPiece({
|
|
displayName: 'Kimai',
|
|
description: 'Open-source time tracking software',
|
|
|
|
auth: kimaiAuth,
|
|
minimumSupportedRelease: '0.30.0',
|
|
logoUrl: 'https://cdn.activepieces.com/pieces/kimai.png',
|
|
categories: [PieceCategory.PRODUCTIVITY],
|
|
authors: ["facferreira","kishanprmr","MoShizzle","abuaboud"],
|
|
actions: [
|
|
kimaiCreateTimesheetAction,
|
|
createCustomApiCallAction({
|
|
baseUrl: (auth) => (auth?.props.base_url ?? ''),
|
|
auth: kimaiAuth,
|
|
authMapping: async (auth) => ({
|
|
'X-AUTH-USER': auth.props.user,
|
|
'X-AUTH-TOKEN': auth.props.api_password,
|
|
}),
|
|
}),
|
|
],
|
|
triggers: [],
|
|
});
|