Files
smoothschedule/activepieces-fork/packages/pieces/community/kimai/src/index.ts
poduck 3aa7199503 Add Activepieces integration for workflow automation
- 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>
2025-12-18 22:59:37 -05:00

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: [],
});