@appconda/nextjs 1.0.127 → 1.0.130
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/modules/scheduled-job/action.d.ts +5 -38
- package/dist/modules/scheduled-job/action.js +12 -12
- package/dist/modules/scheduled-job/schema.d.ts +2 -20
- package/dist/modules/scheduled-job/schema.js +4 -10
- package/dist/modules/scheduled-job/service.d.ts +4 -4
- package/dist/modules/scheduled-job/service.js +5 -5
- package/dist/modules/scheduled-job/types.d.ts +15 -5
- package/dist/modules/scheduled-job/types.js +1 -1
- package/dist/services/tenant.d.ts +32 -0
- package/dist/services/tenant.js +124 -0
- package/package.json +1 -1
- package/src/modules/scheduled-job/action.ts +19 -19
- package/src/modules/scheduled-job/schema.ts +5 -8
- package/src/modules/scheduled-job/service.ts +7 -8
- package/src/modules/scheduled-job/types.ts +15 -5
@@ -1,4 +1,4 @@
|
|
1
|
-
import {
|
1
|
+
import { Execution, ExecutionTrend, FailedJob, ScheduledJob } from './types';
|
2
2
|
export declare const CreateScheduledJob: import("next-safe-action").SafeActionFn<string, import("zod").ZodObject<{
|
3
3
|
id: import("zod").ZodOptional<import("zod").ZodString>;
|
4
4
|
name: import("zod").ZodString;
|
@@ -46,52 +46,19 @@ export declare const GetScheduledJob: import("next-safe-action").SafeActionFn<st
|
|
46
46
|
}, readonly [], ScheduledJob>;
|
47
47
|
export declare const ListExecutions: import("next-safe-action").SafeActionFn<string, import("zod").ZodObject<{
|
48
48
|
scheduledJobId: import("zod").ZodString;
|
49
|
-
status: import("zod").ZodOptional<import("zod").ZodString>;
|
50
49
|
}, "strip", import("zod").ZodTypeAny, {
|
51
50
|
scheduledJobId: string;
|
52
|
-
status?: string | undefined;
|
53
51
|
}, {
|
54
52
|
scheduledJobId: string;
|
55
|
-
status?: string | undefined;
|
56
53
|
}>, readonly [], {
|
57
54
|
_errors?: string[];
|
58
55
|
scheduledJobId?: {
|
59
56
|
_errors?: string[];
|
60
57
|
};
|
61
|
-
status?: {
|
62
|
-
_errors?: string[];
|
63
|
-
};
|
64
58
|
}, readonly [], Execution[]>;
|
65
|
-
export declare const
|
59
|
+
export declare const GetDailyExecutionTrend: import("next-safe-action").SafeActionFn<string, import("zod").ZodObject<{}, "strip", import("zod").ZodTypeAny, {}, {}>, readonly [], {
|
66
60
|
_errors?: string[];
|
67
|
-
}, readonly [],
|
68
|
-
export declare const
|
69
|
-
id: import("zod").ZodString;
|
70
|
-
name: import("zod").ZodOptional<import("zod").ZodString>;
|
71
|
-
cron: import("zod").ZodOptional<import("zod").ZodString>;
|
72
|
-
enabled: import("zod").ZodOptional<import("zod").ZodBoolean>;
|
73
|
-
}, "strip", import("zod").ZodTypeAny, {
|
74
|
-
id: string;
|
75
|
-
name?: string | undefined;
|
76
|
-
enabled?: boolean | undefined;
|
77
|
-
cron?: string | undefined;
|
78
|
-
}, {
|
79
|
-
id: string;
|
80
|
-
name?: string | undefined;
|
81
|
-
enabled?: boolean | undefined;
|
82
|
-
cron?: string | undefined;
|
83
|
-
}>, readonly [], {
|
61
|
+
}, readonly [], ExecutionTrend[]>;
|
62
|
+
export declare const GetTopFailedJobs: import("next-safe-action").SafeActionFn<string, import("zod").ZodObject<{}, "strip", import("zod").ZodTypeAny, {}, {}>, readonly [], {
|
84
63
|
_errors?: string[];
|
85
|
-
|
86
|
-
_errors?: string[];
|
87
|
-
};
|
88
|
-
name?: {
|
89
|
-
_errors?: string[];
|
90
|
-
};
|
91
|
-
enabled?: {
|
92
|
-
_errors?: string[];
|
93
|
-
};
|
94
|
-
cron?: {
|
95
|
-
_errors?: string[];
|
96
|
-
};
|
97
|
-
}, readonly [], ScheduledJob>;
|
64
|
+
}, readonly [], FailedJob>;
|
@@ -1,7 +1,7 @@
|
|
1
1
|
'use server';
|
2
2
|
import { actionClient } from '../../actions/actionClient';
|
3
3
|
import { getSDKForCurrentUser } from '../../getSDKForCurrentUser';
|
4
|
-
import { CreateScheduledJobSchema, GetScheduledJobSchema,
|
4
|
+
import { CreateScheduledJobSchema, GetDailyExecutionTrendSchema, GetScheduledJobSchema, GetTopFailedJobsSchema, ListExecutionsSchema, ListScheduledJobsSchema } from './schema';
|
5
5
|
export const CreateScheduledJob = actionClient
|
6
6
|
.schema(CreateScheduledJobSchema)
|
7
7
|
.action(async ({ parsedInput }) => {
|
@@ -50,28 +50,28 @@ export const ListExecutions = actionClient
|
|
50
50
|
throw new Error('Failed to fetch ListExecutions');
|
51
51
|
}
|
52
52
|
});
|
53
|
-
export const
|
54
|
-
.schema(
|
53
|
+
export const GetDailyExecutionTrend = actionClient
|
54
|
+
.schema(GetDailyExecutionTrendSchema)
|
55
55
|
.action(async ({ parsedInput }) => {
|
56
56
|
try {
|
57
57
|
const { scheduledJob } = await getSDKForCurrentUser();
|
58
|
-
return await scheduledJob.
|
58
|
+
return await scheduledJob.GetDailyExecutionTrend(parsedInput);
|
59
59
|
}
|
60
60
|
catch (error) {
|
61
|
-
console.error('Error in
|
62
|
-
throw new Error('Failed to fetch
|
61
|
+
console.error('Error in GetDailyExecutionTrend:', error);
|
62
|
+
throw new Error('Failed to fetch GetDailyExecutionTrend');
|
63
63
|
}
|
64
64
|
});
|
65
|
-
export const
|
66
|
-
.schema(
|
65
|
+
export const GetTopFailedJobs = actionClient
|
66
|
+
.schema(GetTopFailedJobsSchema)
|
67
67
|
.action(async ({ parsedInput }) => {
|
68
68
|
try {
|
69
69
|
const { scheduledJob } = await getSDKForCurrentUser();
|
70
|
-
return await scheduledJob.
|
70
|
+
return await scheduledJob.GetTopFailedJobs(parsedInput);
|
71
71
|
}
|
72
72
|
catch (error) {
|
73
|
-
console.error('Error in
|
74
|
-
throw new Error('Failed to fetch
|
73
|
+
console.error('Error in GetTopFailedJobs:', error);
|
74
|
+
throw new Error('Failed to fetch GetTopFailedJobs');
|
75
75
|
}
|
76
76
|
});
|
77
|
-
//# sourceMappingURL=data:application/json;base64,
|
77
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"action.js","sourceRoot":"","sources":["../../../src/modules/scheduled-job/action.ts"],"names":[],"mappings":"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","sourcesContent":["'use server';\n\n\nimport { actionClient } from '../../actions/actionClient';\nimport { getSDKForCurrentUser } from '../../getSDKForCurrentUser';\nimport { CreateScheduledJobSchema, GetDailyExecutionTrendSchema, GetScheduledJobSchema, GetTopFailedJobsSchema, ListExecutionsSchema, ListScheduledJobsSchema } from './schema';\nimport { Execution, ExecutionTrend, FailedJob, ScheduledJob } from './types';\n\nexport const CreateScheduledJob = actionClient\n    .schema(CreateScheduledJobSchema)\n    .action(async ({ parsedInput }): Promise<ScheduledJob> => {\n        try {\n\n            const { scheduledJob } = await getSDKForCurrentUser();\n            return await scheduledJob.CreateScheduledJob(parsedInput);\n\n        } catch (error) {\n            console.error('Error in CreateScheduledJob:', error);\n            throw new Error('Failed to fetch CreateScheduledJob');\n        }\n    });\n\n    export const ListScheduledJobs = actionClient\n    .schema(ListScheduledJobsSchema)\n    .action(async ({ parsedInput }): Promise<ScheduledJob[]> => {\n        try {\n\n            const { scheduledJob } = await getSDKForCurrentUser();\n            return await scheduledJob.ListScheduledJobs(parsedInput);\n\n        } catch (error) {\n            console.error('Error in ListScheduledJobs:', error);\n            throw new Error('Failed to fetch ListScheduledJobs');\n        }\n    });\n\n    export const GetScheduledJob = actionClient\n    .schema(GetScheduledJobSchema)\n    .action(async ({ parsedInput }): Promise<ScheduledJob> => {\n        try {\n\n            const { scheduledJob } = await getSDKForCurrentUser();\n            return await scheduledJob.GetScheduledJob(parsedInput);\n\n        } catch (error) {\n            console.error('Error in GetScheduledJob:', error);\n            throw new Error('Failed to fetch GetScheduledJob');\n        }\n    });\n    \n    export const ListExecutions = actionClient\n    .schema(ListExecutionsSchema)\n    .action(async ({ parsedInput }): Promise<Execution[]> => {\n        try {\n\n            const { scheduledJob } = await getSDKForCurrentUser();\n            return await scheduledJob.ListExecutions(parsedInput);\n\n        } catch (error) {\n            console.error('Error in ListExecutions:', error);\n            throw new Error('Failed to fetch ListExecutions');\n        }\n    });\n\n    export const GetDailyExecutionTrend = actionClient\n    .schema(GetDailyExecutionTrendSchema)\n    .action(async ({ parsedInput }): Promise<ExecutionTrend[]> => {\n        try {\n\n            const { scheduledJob } = await getSDKForCurrentUser();\n            return await scheduledJob.GetDailyExecutionTrend(parsedInput);\n\n        } catch (error) {\n            console.error('Error in GetDailyExecutionTrend:', error);\n            throw new Error('Failed to fetch GetDailyExecutionTrend');\n        }\n    });\n\n    export const GetTopFailedJobs = actionClient\n    .schema(GetTopFailedJobsSchema)\n    .action(async ({ parsedInput }): Promise<FailedJob> => {\n        try {\n\n            const { scheduledJob } = await getSDKForCurrentUser();\n            return await scheduledJob.GetTopFailedJobs(parsedInput);\n\n        } catch (error) {\n            console.error('Error in GetTopFailedJobs:', error);\n            throw new Error('Failed to fetch GetTopFailedJobs');\n        }\n    });\n    \n        \n    "]}
|
@@ -25,28 +25,10 @@ export declare const GetScheduledJobSchema: z.ZodObject<{
|
|
25
25
|
}>;
|
26
26
|
export declare const ListExecutionsSchema: z.ZodObject<{
|
27
27
|
scheduledJobId: z.ZodString;
|
28
|
-
status: z.ZodOptional<z.ZodString>;
|
29
28
|
}, "strip", z.ZodTypeAny, {
|
30
29
|
scheduledJobId: string;
|
31
|
-
status?: string | undefined;
|
32
30
|
}, {
|
33
31
|
scheduledJobId: string;
|
34
|
-
status?: string | undefined;
|
35
|
-
}>;
|
36
|
-
export declare const ListAvgExecutionsSchema: z.ZodObject<{}, "strip", z.ZodTypeAny, {}, {}>;
|
37
|
-
export declare const UpdateJobSchema: z.ZodObject<{
|
38
|
-
id: z.ZodString;
|
39
|
-
name: z.ZodOptional<z.ZodString>;
|
40
|
-
cron: z.ZodOptional<z.ZodString>;
|
41
|
-
enabled: z.ZodOptional<z.ZodBoolean>;
|
42
|
-
}, "strip", z.ZodTypeAny, {
|
43
|
-
id: string;
|
44
|
-
name?: string | undefined;
|
45
|
-
enabled?: boolean | undefined;
|
46
|
-
cron?: string | undefined;
|
47
|
-
}, {
|
48
|
-
id: string;
|
49
|
-
name?: string | undefined;
|
50
|
-
enabled?: boolean | undefined;
|
51
|
-
cron?: string | undefined;
|
52
32
|
}>;
|
33
|
+
export declare const GetDailyExecutionTrendSchema: z.ZodObject<{}, "strip", z.ZodTypeAny, {}, {}>;
|
34
|
+
export declare const GetTopFailedJobsSchema: z.ZodObject<{}, "strip", z.ZodTypeAny, {}, {}>;
|
@@ -10,14 +10,8 @@ export const GetScheduledJobSchema = z.object({
|
|
10
10
|
id: z.string()
|
11
11
|
});
|
12
12
|
export const ListExecutionsSchema = z.object({
|
13
|
-
scheduledJobId: z.string()
|
14
|
-
status: z.string().optional()
|
13
|
+
scheduledJobId: z.string()
|
15
14
|
});
|
16
|
-
export const
|
17
|
-
export const
|
18
|
-
|
19
|
-
name: z.string().optional(),
|
20
|
-
cron: z.string().optional(),
|
21
|
-
enabled: z.boolean().optional(),
|
22
|
-
});
|
23
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NoZW1hLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL21vZHVsZXMvc2NoZWR1bGVkLWpvYi9zY2hlbWEudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLENBQUMsRUFBRSxNQUFNLEtBQUssQ0FBQztBQUV4QixNQUFNLENBQUMsTUFBTSx3QkFBd0IsR0FBRyxDQUFDLENBQUMsTUFBTSxDQUFDO0lBQzdDLEVBQUUsRUFBRSxDQUFDLENBQUMsTUFBTSxFQUFFLENBQUMsUUFBUSxFQUFFO0lBQ3pCLElBQUksRUFBRSxDQUFDLENBQUMsTUFBTSxFQUFFO0lBQ2hCLElBQUksRUFBRSxDQUFDLENBQUMsTUFBTSxFQUFFO0lBQ2hCLE9BQU8sRUFBRSxDQUFDLENBQUMsT0FBTyxFQUFFLENBQUMsUUFBUSxFQUFFLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQztDQUNoRCxDQUFDLENBQUM7QUFFSCxNQUFNLENBQUMsTUFBTSx1QkFBdUIsR0FBRyxDQUFDLENBQUMsTUFBTSxDQUFDLEVBRS9DLENBQUMsQ0FBQztBQUVILE1BQU0sQ0FBQyxNQUFNLHFCQUFxQixHQUFHLENBQUMsQ0FBQyxNQUFNLENBQUM7SUFDMUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxNQUFNLEVBQUU7Q0FDakIsQ0FBQyxDQUFDO0FBRUgsTUFBTSxDQUFDLE1BQU0sb0JBQW9CLEdBQUcsQ0FBQyxDQUFDLE1BQU0sQ0FBQztJQUN6QyxjQUFjLEVBQUUsQ0FBQyxDQUFDLE1BQU0sRUFBRTtJQUMxQixNQUFNLEVBQUUsQ0FBQyxDQUFDLE1BQU0sRUFBRSxDQUFDLFFBQVEsRUFBRTtDQUNoQyxDQUFDLENBQUM7QUFFSCxNQUFNLENBQUMsTUFBTSx1QkFBdUIsR0FBRyxDQUFDLENBQUMsTUFBTSxDQUFDLEVBQy9DLENBQUMsQ0FBQztBQUVILE1BQU0sQ0FBQyxNQUFNLGVBQWUsR0FBRyxDQUFDLENBQUMsTUFBTSxDQUFDO0lBQ3BDLEVBQUUsRUFBRSxDQUFDLENBQUMsTUFBTSxFQUFFO0lBQ2QsSUFBSSxFQUFFLENBQUMsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxRQUFRLEVBQUU7SUFDM0IsSUFBSSxFQUFFLENBQUMsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxRQUFRLEVBQUU7SUFDM0IsT0FBTyxFQUFFLENBQUMsQ0FBQyxPQUFPLEVBQUUsQ0FBQyxRQUFRLEVBQUU7Q0FDbEMsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgeiB9IGZyb20gXCJ6b2RcIjtcblxuZXhwb3J0IGNvbnN0IENyZWF0ZVNjaGVkdWxlZEpvYlNjaGVtYSA9IHoub2JqZWN0KHtcbiAgICBpZDogei5zdHJpbmcoKS5vcHRpb25hbCgpLFxuICAgIG5hbWU6IHouc3RyaW5nKCksXG4gICAgY3Jvbjogei5zdHJpbmcoKSxcbiAgICBlbmFibGVkOiB6LmJvb2xlYW4oKS5vcHRpb25hbCgpLmRlZmF1bHQodHJ1ZSksXG59KTtcblxuZXhwb3J0IGNvbnN0IExpc3RTY2hlZHVsZWRKb2JzU2NoZW1hID0gei5vYmplY3Qoe1xuICAgXG59KTtcblxuZXhwb3J0IGNvbnN0IEdldFNjaGVkdWxlZEpvYlNjaGVtYSA9IHoub2JqZWN0KHtcbiAgICBpZDogei5zdHJpbmcoKVxufSk7XG5cbmV4cG9ydCBjb25zdCBMaXN0RXhlY3V0aW9uc1NjaGVtYSA9IHoub2JqZWN0KHtcbiAgICBzY2hlZHVsZWRKb2JJZDogei5zdHJpbmcoKSxcbiAgICBzdGF0dXM6IHouc3RyaW5nKCkub3B0aW9uYWwoKVxufSk7XG4gICAgXG5leHBvcnQgY29uc3QgTGlzdEF2Z0V4ZWN1dGlvbnNTY2hlbWEgPSB6Lm9iamVjdCh7XG59KTtcblxuZXhwb3J0IGNvbnN0IFVwZGF0ZUpvYlNjaGVtYSA9IHoub2JqZWN0KHtcbiAgICBpZDogei5zdHJpbmcoKSxcbiAgICBuYW1lOiB6LnN0cmluZygpLm9wdGlvbmFsKCksXG4gICAgY3Jvbjogei5zdHJpbmcoKS5vcHRpb25hbCgpLFxuICAgIGVuYWJsZWQ6IHouYm9vbGVhbigpLm9wdGlvbmFsKCksXG59KTtcbiJdfQ==
|
15
|
+
export const GetDailyExecutionTrendSchema = z.object({});
|
16
|
+
export const GetTopFailedJobsSchema = z.object({});
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NoZW1hLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL21vZHVsZXMvc2NoZWR1bGVkLWpvYi9zY2hlbWEudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLENBQUMsRUFBRSxNQUFNLEtBQUssQ0FBQztBQUV4QixNQUFNLENBQUMsTUFBTSx3QkFBd0IsR0FBRyxDQUFDLENBQUMsTUFBTSxDQUFDO0lBQzdDLEVBQUUsRUFBRSxDQUFDLENBQUMsTUFBTSxFQUFFLENBQUMsUUFBUSxFQUFFO0lBQ3pCLElBQUksRUFBRSxDQUFDLENBQUMsTUFBTSxFQUFFO0lBQ2hCLElBQUksRUFBRSxDQUFDLENBQUMsTUFBTSxFQUFFO0lBQ2hCLE9BQU8sRUFBRSxDQUFDLENBQUMsT0FBTyxFQUFFLENBQUMsUUFBUSxFQUFFLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQztDQUNoRCxDQUFDLENBQUM7QUFFSCxNQUFNLENBQUMsTUFBTSx1QkFBdUIsR0FBRyxDQUFDLENBQUMsTUFBTSxDQUFDLEVBRS9DLENBQUMsQ0FBQztBQUVILE1BQU0sQ0FBQyxNQUFNLHFCQUFxQixHQUFHLENBQUMsQ0FBQyxNQUFNLENBQUM7SUFDMUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxNQUFNLEVBQUU7Q0FDakIsQ0FBQyxDQUFDO0FBRUgsTUFBTSxDQUFDLE1BQU0sb0JBQW9CLEdBQUcsQ0FBQyxDQUFDLE1BQU0sQ0FBQztJQUN6QyxjQUFjLEVBQUUsQ0FBQyxDQUFDLE1BQU0sRUFBRTtDQUM3QixDQUFDLENBQUM7QUFFSCxNQUFNLENBQUMsTUFBTSw0QkFBNEIsR0FBRyxDQUFDLENBQUMsTUFBTSxDQUFDLEVBRXBELENBQUMsQ0FBQztBQUVILE1BQU0sQ0FBQyxNQUFNLHNCQUFzQixHQUFHLENBQUMsQ0FBQyxNQUFNLENBQUMsRUFFOUMsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgeiB9IGZyb20gXCJ6b2RcIjtcblxuZXhwb3J0IGNvbnN0IENyZWF0ZVNjaGVkdWxlZEpvYlNjaGVtYSA9IHoub2JqZWN0KHtcbiAgICBpZDogei5zdHJpbmcoKS5vcHRpb25hbCgpLFxuICAgIG5hbWU6IHouc3RyaW5nKCksXG4gICAgY3Jvbjogei5zdHJpbmcoKSxcbiAgICBlbmFibGVkOiB6LmJvb2xlYW4oKS5vcHRpb25hbCgpLmRlZmF1bHQodHJ1ZSksXG59KTtcblxuZXhwb3J0IGNvbnN0IExpc3RTY2hlZHVsZWRKb2JzU2NoZW1hID0gei5vYmplY3Qoe1xuICAgXG59KTtcblxuZXhwb3J0IGNvbnN0IEdldFNjaGVkdWxlZEpvYlNjaGVtYSA9IHoub2JqZWN0KHtcbiAgICBpZDogei5zdHJpbmcoKVxufSk7XG5cbmV4cG9ydCBjb25zdCBMaXN0RXhlY3V0aW9uc1NjaGVtYSA9IHoub2JqZWN0KHtcbiAgICBzY2hlZHVsZWRKb2JJZDogei5zdHJpbmcoKVxufSk7XG4gICAgXG5leHBvcnQgY29uc3QgR2V0RGFpbHlFeGVjdXRpb25UcmVuZFNjaGVtYSA9IHoub2JqZWN0KHtcbiAgIFxufSk7XG5cbmV4cG9ydCBjb25zdCBHZXRUb3BGYWlsZWRKb2JzU2NoZW1hID0gei5vYmplY3Qoe1xuICAgXG59KTtcbiJdfQ==
|
@@ -1,13 +1,13 @@
|
|
1
1
|
import z from "zod";
|
2
2
|
import { ServiceClient } from "../../service-client";
|
3
|
-
import { CreateScheduledJobSchema, ListScheduledJobsSchema, GetScheduledJobSchema, ListExecutionsSchema,
|
4
|
-
import {
|
3
|
+
import { CreateScheduledJobSchema, ListScheduledJobsSchema, GetScheduledJobSchema, ListExecutionsSchema, GetDailyExecutionTrendSchema, GetTopFailedJobsSchema } from "./schema";
|
4
|
+
import { Execution, ExecutionTrend, FailedJob, ScheduledJob } from "./types";
|
5
5
|
export declare class ScheduledJobService extends ServiceClient {
|
6
6
|
protected getServiceName(): string;
|
7
7
|
CreateScheduledJob(payload: z.infer<typeof CreateScheduledJobSchema>): Promise<ScheduledJob>;
|
8
8
|
ListScheduledJobs(payload: z.infer<typeof ListScheduledJobsSchema>): Promise<ScheduledJob[]>;
|
9
9
|
GetScheduledJob(payload: z.infer<typeof GetScheduledJobSchema>): Promise<ScheduledJob>;
|
10
10
|
ListExecutions(payload: z.infer<typeof ListExecutionsSchema>): Promise<Execution[]>;
|
11
|
-
|
12
|
-
|
11
|
+
GetDailyExecutionTrend(payload: z.infer<typeof GetDailyExecutionTrendSchema>): Promise<ExecutionTrend[]>;
|
12
|
+
GetTopFailedJobs(payload: z.infer<typeof GetTopFailedJobsSchema>): Promise<FailedJob[]>;
|
13
13
|
}
|
@@ -15,11 +15,11 @@ export class ScheduledJobService extends ServiceClient {
|
|
15
15
|
async ListExecutions(payload) {
|
16
16
|
return await this.actionCall('ListExecutions', payload);
|
17
17
|
}
|
18
|
-
async
|
19
|
-
return await this.actionCall('
|
18
|
+
async GetDailyExecutionTrend(payload) {
|
19
|
+
return await this.actionCall('GetDailyExecutionTrend', payload);
|
20
20
|
}
|
21
|
-
async
|
22
|
-
return await this.actionCall('
|
21
|
+
async GetTopFailedJobs(payload) {
|
22
|
+
return await this.actionCall('GetTopFailedJobs', payload);
|
23
23
|
}
|
24
24
|
}
|
25
|
-
//# sourceMappingURL=data:application/json;base64,
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9tb2R1bGVzL3NjaGVkdWxlZC1qb2Ivc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFJckQsTUFBTSxPQUFPLG1CQUFvQixTQUFRLGFBQWE7SUFDeEMsY0FBYztRQUNwQixPQUFPLHFDQUFxQyxDQUFDO0lBQ2pELENBQUM7SUFFTSxLQUFLLENBQUMsa0JBQWtCLENBQUMsT0FBaUQ7UUFDN0UsT0FBTyxNQUFNLElBQUksQ0FBQyxVQUFVLENBQUMsb0JBQW9CLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDaEUsQ0FBQztJQUVNLEtBQUssQ0FBQyxpQkFBaUIsQ0FBQyxPQUFnRDtRQUMzRSxPQUFPLE1BQU0sSUFBSSxDQUFDLFVBQVUsQ0FBQyxtQkFBbUIsRUFBRSxPQUFPLENBQUMsQ0FBQztJQUMvRCxDQUFDO0lBRU0sS0FBSyxDQUFDLGVBQWUsQ0FBQyxPQUE4QztRQUN2RSxPQUFPLE1BQU0sSUFBSSxDQUFDLFVBQVUsQ0FBQyxpQkFBaUIsRUFBRSxPQUFPLENBQUMsQ0FBQztJQUM3RCxDQUFDO0lBRU0sS0FBSyxDQUFDLGNBQWMsQ0FBQyxPQUE2QztRQUNyRSxPQUFPLE1BQU0sSUFBSSxDQUFDLFVBQVUsQ0FBQyxnQkFBZ0IsRUFBRSxPQUFPLENBQUMsQ0FBQztJQUM1RCxDQUFDO0lBRU0sS0FBSyxDQUFDLHNCQUFzQixDQUFDLE9BQXFEO1FBQ3JGLE9BQU8sTUFBTSxJQUFJLENBQUMsVUFBVSxDQUFDLHdCQUF3QixFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQ3BFLENBQUM7SUFFTSxLQUFLLENBQUMsZ0JBQWdCLENBQUMsT0FBK0M7UUFDekUsT0FBTyxNQUFNLElBQUksQ0FBQyxVQUFVLENBQUMsa0JBQWtCLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDOUQsQ0FBQztDQUVKIiwic291cmNlc0NvbnRlbnQiOlsiXG5pbXBvcnQgeiBmcm9tIFwiem9kXCI7XG5pbXBvcnQgeyBTZXJ2aWNlQ2xpZW50IH0gZnJvbSBcIi4uLy4uL3NlcnZpY2UtY2xpZW50XCI7XG5pbXBvcnQgeyBDcmVhdGVTY2hlZHVsZWRKb2JTY2hlbWEsIExpc3RTY2hlZHVsZWRKb2JzU2NoZW1hLCBHZXRTY2hlZHVsZWRKb2JTY2hlbWEsIExpc3RFeGVjdXRpb25zU2NoZW1hLCBHZXREYWlseUV4ZWN1dGlvblRyZW5kU2NoZW1hLCBHZXRUb3BGYWlsZWRKb2JzU2NoZW1hIH0gZnJvbSBcIi4vc2NoZW1hXCI7XG5pbXBvcnQgeyBFeGVjdXRpb24sIEV4ZWN1dGlvblRyZW5kLCBGYWlsZWRKb2IsIFNjaGVkdWxlZEpvYiB9IGZyb20gXCIuL3R5cGVzXCI7XG5cbmV4cG9ydCBjbGFzcyBTY2hlZHVsZWRKb2JTZXJ2aWNlIGV4dGVuZHMgU2VydmljZUNsaWVudCB7XG4gICAgcHJvdGVjdGVkIGdldFNlcnZpY2VOYW1lKCk6IHN0cmluZyB7XG4gICAgICAgIHJldHVybiAnY29tLmFwcGNvbmRhLnNlcnZpY2Uuc2NoZWR1bGVkLWpvYnMnO1xuICAgIH1cblxuICAgIHB1YmxpYyBhc3luYyBDcmVhdGVTY2hlZHVsZWRKb2IocGF5bG9hZDogei5pbmZlcjx0eXBlb2YgQ3JlYXRlU2NoZWR1bGVkSm9iU2NoZW1hPik6IFByb21pc2U8U2NoZWR1bGVkSm9iPiB7XG4gICAgICAgIHJldHVybiBhd2FpdCB0aGlzLmFjdGlvbkNhbGwoJ0NyZWF0ZVNjaGVkdWxlZEpvYicsIHBheWxvYWQpO1xuICAgIH1cblxuICAgIHB1YmxpYyBhc3luYyBMaXN0U2NoZWR1bGVkSm9icyhwYXlsb2FkOiB6LmluZmVyPHR5cGVvZiBMaXN0U2NoZWR1bGVkSm9ic1NjaGVtYT4pOiBQcm9taXNlPFNjaGVkdWxlZEpvYltdPiB7XG4gICAgICAgIHJldHVybiBhd2FpdCB0aGlzLmFjdGlvbkNhbGwoJ0xpc3RTY2hlZHVsZWRKb2JzJywgcGF5bG9hZCk7XG4gICAgfVxuXG4gICAgcHVibGljIGFzeW5jIEdldFNjaGVkdWxlZEpvYihwYXlsb2FkOiB6LmluZmVyPHR5cGVvZiBHZXRTY2hlZHVsZWRKb2JTY2hlbWE+KTogUHJvbWlzZTxTY2hlZHVsZWRKb2I+IHtcbiAgICAgICAgcmV0dXJuIGF3YWl0IHRoaXMuYWN0aW9uQ2FsbCgnR2V0U2NoZWR1bGVkSm9iJywgcGF5bG9hZCk7XG4gICAgfVxuXG4gICAgcHVibGljIGFzeW5jIExpc3RFeGVjdXRpb25zKHBheWxvYWQ6IHouaW5mZXI8dHlwZW9mIExpc3RFeGVjdXRpb25zU2NoZW1hPik6IFByb21pc2U8RXhlY3V0aW9uW10+IHtcbiAgICAgICAgcmV0dXJuIGF3YWl0IHRoaXMuYWN0aW9uQ2FsbCgnTGlzdEV4ZWN1dGlvbnMnLCBwYXlsb2FkKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgYXN5bmMgR2V0RGFpbHlFeGVjdXRpb25UcmVuZChwYXlsb2FkOiB6LmluZmVyPHR5cGVvZiBHZXREYWlseUV4ZWN1dGlvblRyZW5kU2NoZW1hPik6IFByb21pc2U8RXhlY3V0aW9uVHJlbmRbXT4ge1xuICAgICAgICByZXR1cm4gYXdhaXQgdGhpcy5hY3Rpb25DYWxsKCdHZXREYWlseUV4ZWN1dGlvblRyZW5kJywgcGF5bG9hZCk7XG4gICAgfVxuXG4gICAgcHVibGljIGFzeW5jIEdldFRvcEZhaWxlZEpvYnMocGF5bG9hZDogei5pbmZlcjx0eXBlb2YgR2V0VG9wRmFpbGVkSm9ic1NjaGVtYT4pOiBQcm9taXNlPEZhaWxlZEpvYltdPiB7XG4gICAgICAgIHJldHVybiBhd2FpdCB0aGlzLmFjdGlvbkNhbGwoJ0dldFRvcEZhaWxlZEpvYnMnLCBwYXlsb2FkKTtcbiAgICB9XG4gICAgXG59XG4iXX0=
|
@@ -21,9 +21,19 @@ export type Execution = {
|
|
21
21
|
updatedAt: Date;
|
22
22
|
status: string;
|
23
23
|
};
|
24
|
-
export type
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
24
|
+
export type ExecutionTrend = {
|
25
|
+
labels: string[];
|
26
|
+
datasets: {
|
27
|
+
label: string;
|
28
|
+
data: number[];
|
29
|
+
borderColor: string;
|
30
|
+
};
|
31
|
+
};
|
32
|
+
export type FailedJob = {
|
33
|
+
labels: string[];
|
34
|
+
datasets: {
|
35
|
+
label: string;
|
36
|
+
data: number[];
|
37
|
+
backgroundColor: string;
|
38
|
+
}[];
|
29
39
|
};
|
@@ -1,2 +1,2 @@
|
|
1
1
|
export {};
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbW9kdWxlcy9zY2hlZHVsZWQtam9iL3R5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJcblxuZXhwb3J0IHR5cGUgU2NoZWR1bGVkSm9iID0ge1xuICBpZDogc3RyaW5nO1xuICBuYW1lOiBzdHJpbmc7XG4gIGNyb246IHN0cmluZztcbiAgZW5hYmxlZDogYm9vbGVhbjtcbiAgbGFzdFJ1bj86IERhdGU7XG4gIG5leHRSdW4/
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbW9kdWxlcy9zY2hlZHVsZWQtam9iL3R5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJcblxuZXhwb3J0IHR5cGUgU2NoZWR1bGVkSm9iID0ge1xuICBpZDogc3RyaW5nO1xuICBuYW1lOiBzdHJpbmc7XG4gIGNyb246IHN0cmluZztcbiAgZW5hYmxlZDogYm9vbGVhbjtcbiAgbGFzdFJ1bj86IERhdGU7XG4gIG5leHRSdW4/OiBEYXRlO1xuICBjcmVhdGVkQXQ6IERhdGU7XG4gIHVwZGF0ZWRBdDogRGF0ZTtcbn1cblxuZXhwb3J0IHR5cGUgSm9iUnVuID0ge1xuICBpZDogc3RyaW5nO1xuICBqb2JJZDogc3RyaW5nO1xuICBjcmVhdGVkQXQ6IERhdGU7XG4gIHVwZGF0ZWRBdDogRGF0ZTtcbn1cblxuZXhwb3J0IHR5cGUgRXhlY3V0aW9uID0ge1xuICBpZDogc3RyaW5nO1xuICBzY2hlZHVsZWRKb2JJZDogc3RyaW5nO1xuICBjcmVhdGVkQXQ6IERhdGU7XG4gIHVwZGF0ZWRBdDogRGF0ZTtcbiAgc3RhdHVzOiBzdHJpbmc7XG59XG5cbmV4cG9ydCB0eXBlIEV4ZWN1dGlvblRyZW5kID0ge1xuICBsYWJlbHM6IHN0cmluZ1tdO1xuICBkYXRhc2V0czoge1xuICAgIGxhYmVsOiBzdHJpbmc7XG4gICAgZGF0YTogbnVtYmVyW107XG4gICAgYm9yZGVyQ29sb3I6IHN0cmluZztcbiAgfVxufVxuXG5leHBvcnQgdHlwZSBGYWlsZWRKb2IgPSB7XG4gIGxhYmVsczogc3RyaW5nW107XG4gIGRhdGFzZXRzOiB7XG4gICAgbGFiZWw6IHN0cmluZztcbiAgICBkYXRhOiBudW1iZXJbXTtcbiAgICBiYWNrZ3JvdW5kQ29sb3I6IHN0cmluZztcbiAgfVtdO1xufVxuIl19
|
@@ -0,0 +1,32 @@
|
|
1
|
+
import { Models } from "../client";
|
2
|
+
import { ServiceClient } from "../service-client";
|
3
|
+
export type TenantSimple = {
|
4
|
+
id: string;
|
5
|
+
name: string;
|
6
|
+
slug: string;
|
7
|
+
icon: string | null;
|
8
|
+
deactivatedReason: string | null;
|
9
|
+
types: any[];
|
10
|
+
active: boolean;
|
11
|
+
};
|
12
|
+
export declare class Tenant extends ServiceClient {
|
13
|
+
getServiceName(): string;
|
14
|
+
get(tenantId: string): Promise<Models.Tenant>;
|
15
|
+
/**
|
16
|
+
* Create account
|
17
|
+
*
|
18
|
+
* Use this endpoint to allow a new user to register a new account in your project. After the user registration completes successfully, you can use the [/account/verfication](https://appconda.io/docs/references/cloud/client-web/account#createVerification) route to start verifying the user email address. To allow the new user to login to their new account, you need to create a new [account session](https://appconda.io/docs/references/cloud/client-web/account#createEmailSession).
|
19
|
+
*
|
20
|
+
* @param {string} tenantId
|
21
|
+
* @param {string} name
|
22
|
+
* @param {string} slug
|
23
|
+
* @throws {AppcondaException}
|
24
|
+
* @returns {Promise<Models.User<Preferences>>}
|
25
|
+
*/
|
26
|
+
create({ $id, name, slug }: Models.Tenant): Promise<Models.Tenant>;
|
27
|
+
list(queries?: string[], search?: string): Promise<Models.TenantList>;
|
28
|
+
listUserTenants(userId: string, queries?: string[], search?: string): Promise<Models.TenantUserList>;
|
29
|
+
listTenantUsers(tenantId: string, queries?: string[], search?: string): Promise<Models.TenantUserList>;
|
30
|
+
createTenantUser({ tenantId, userId }: Models.TenantUser): Promise<Models.TenantUser>;
|
31
|
+
adminGetAllTenantsIdsAndNames(): Promise<TenantSimple[]>;
|
32
|
+
}
|
@@ -0,0 +1,124 @@
|
|
1
|
+
import { AppcondaException } from "../client";
|
2
|
+
import { ServiceClient } from "../service-client";
|
3
|
+
export class Tenant extends ServiceClient {
|
4
|
+
getServiceName() {
|
5
|
+
return 'com.appconda.service.tenant';
|
6
|
+
}
|
7
|
+
async get(tenantId) {
|
8
|
+
if (typeof tenantId === 'undefined') {
|
9
|
+
throw new AppcondaException('Missing required parameter: "tenantId"');
|
10
|
+
}
|
11
|
+
const apiPath = '/tenants/{tenantId}'.replace('{tenantId}', tenantId);
|
12
|
+
const payload = {};
|
13
|
+
const uri = new URL(this.client.config.endpoint + apiPath);
|
14
|
+
const apiHeaders = {
|
15
|
+
'content-type': 'application/json',
|
16
|
+
};
|
17
|
+
return await this.client.call('get', uri, apiHeaders, payload);
|
18
|
+
}
|
19
|
+
/**
|
20
|
+
* Create account
|
21
|
+
*
|
22
|
+
* Use this endpoint to allow a new user to register a new account in your project. After the user registration completes successfully, you can use the [/account/verfication](https://appconda.io/docs/references/cloud/client-web/account#createVerification) route to start verifying the user email address. To allow the new user to login to their new account, you need to create a new [account session](https://appconda.io/docs/references/cloud/client-web/account#createEmailSession).
|
23
|
+
*
|
24
|
+
* @param {string} tenantId
|
25
|
+
* @param {string} name
|
26
|
+
* @param {string} slug
|
27
|
+
* @throws {AppcondaException}
|
28
|
+
* @returns {Promise<Models.User<Preferences>>}
|
29
|
+
*/
|
30
|
+
async create({ $id, name, slug }) {
|
31
|
+
if (typeof $id === 'undefined') {
|
32
|
+
throw new AppcondaException('Missing required parameter: "tenantId"');
|
33
|
+
}
|
34
|
+
if (typeof name === 'undefined') {
|
35
|
+
throw new AppcondaException('Missing required parameter: "name"');
|
36
|
+
}
|
37
|
+
if (typeof slug === 'undefined') {
|
38
|
+
throw new AppcondaException('Missing required parameter: "slug"');
|
39
|
+
}
|
40
|
+
const apiPath = '/tenants';
|
41
|
+
const payload = {};
|
42
|
+
if (typeof $id !== 'undefined') {
|
43
|
+
payload['tenantId'] = $id;
|
44
|
+
}
|
45
|
+
if (typeof name !== 'undefined') {
|
46
|
+
payload['name'] = name;
|
47
|
+
}
|
48
|
+
if (typeof slug !== 'undefined') {
|
49
|
+
payload['slug'] = slug;
|
50
|
+
}
|
51
|
+
const uri = new URL(this.client.config.endpoint + apiPath);
|
52
|
+
const apiHeaders = {
|
53
|
+
'content-type': 'application/json',
|
54
|
+
};
|
55
|
+
return await this.client.call('post', uri, apiHeaders, payload);
|
56
|
+
}
|
57
|
+
async list(queries, search) {
|
58
|
+
const apiPath = '/tenants';
|
59
|
+
const payload = {};
|
60
|
+
if (typeof queries !== 'undefined') {
|
61
|
+
payload['queries'] = queries;
|
62
|
+
}
|
63
|
+
if (typeof search !== 'undefined') {
|
64
|
+
payload['search'] = search;
|
65
|
+
}
|
66
|
+
const uri = new URL(this.client.config.endpoint + apiPath);
|
67
|
+
const apiHeaders = {
|
68
|
+
'content-type': 'application/json',
|
69
|
+
};
|
70
|
+
return await this.client.call('get', uri, apiHeaders, payload);
|
71
|
+
}
|
72
|
+
async listUserTenants(userId, queries, search) {
|
73
|
+
const apiPath = `/tenants/${userId}/tenants`;
|
74
|
+
const payload = {};
|
75
|
+
if (typeof queries !== 'undefined') {
|
76
|
+
payload['queries'] = queries;
|
77
|
+
}
|
78
|
+
if (typeof search !== 'undefined') {
|
79
|
+
payload['search'] = search;
|
80
|
+
}
|
81
|
+
const uri = new URL(this.client.config.endpoint + apiPath);
|
82
|
+
const apiHeaders = {
|
83
|
+
'content-type': 'application/json',
|
84
|
+
};
|
85
|
+
return await this.client.call('get', uri, apiHeaders, payload);
|
86
|
+
}
|
87
|
+
async listTenantUsers(tenantId, queries, search) {
|
88
|
+
const apiPath = `/tenants/${tenantId}/users`;
|
89
|
+
const payload = {};
|
90
|
+
if (typeof queries !== 'undefined') {
|
91
|
+
payload['queries'] = queries;
|
92
|
+
}
|
93
|
+
if (typeof search !== 'undefined') {
|
94
|
+
payload['search'] = search;
|
95
|
+
}
|
96
|
+
const uri = new URL(this.client.config.endpoint + apiPath);
|
97
|
+
const apiHeaders = {
|
98
|
+
'content-type': 'application/json',
|
99
|
+
};
|
100
|
+
return await this.client.call('get', uri, apiHeaders, payload);
|
101
|
+
}
|
102
|
+
async createTenantUser({ tenantId, userId }) {
|
103
|
+
if (typeof tenantId === 'undefined') {
|
104
|
+
throw new AppcondaException('Missing required parameter: "tenantId"');
|
105
|
+
}
|
106
|
+
if (typeof userId === 'undefined') {
|
107
|
+
throw new AppcondaException('Missing required parameter: "userId"');
|
108
|
+
}
|
109
|
+
const apiPath = `/tenants/${tenantId}/users`;
|
110
|
+
const payload = {};
|
111
|
+
if (typeof userId !== 'undefined') {
|
112
|
+
payload['userId'] = userId;
|
113
|
+
}
|
114
|
+
const uri = new URL(this.client.config.endpoint + apiPath);
|
115
|
+
const apiHeaders = {
|
116
|
+
'content-type': 'application/json',
|
117
|
+
};
|
118
|
+
return await this.client.call('post', uri, apiHeaders, payload);
|
119
|
+
}
|
120
|
+
async adminGetAllTenantsIdsAndNames() {
|
121
|
+
const payload = {};
|
122
|
+
return await this.actionCall('AdminGetAllTenantsIdsAndNames', payload);
|
123
|
+
}
|
124
|
+
}
|
package/package.json
CHANGED
@@ -2,7 +2,7 @@
|
|
2
2
|
"name": "@appconda/nextjs",
|
3
3
|
"homepage": "https://appconda.io/support",
|
4
4
|
"description": "Appconda is an open-source self-hosted backend server that abstract and simplify complex and repetitive development tasks behind a very simple REST API",
|
5
|
-
"version": "1.0.
|
5
|
+
"version": "1.0.130",
|
6
6
|
"license": "BSD-3-Clause",
|
7
7
|
"main": "dist/index.js",
|
8
8
|
"types": "dist/index.d.ts",
|
@@ -3,8 +3,8 @@
|
|
3
3
|
|
4
4
|
import { actionClient } from '../../actions/actionClient';
|
5
5
|
import { getSDKForCurrentUser } from '../../getSDKForCurrentUser';
|
6
|
-
import { CreateScheduledJobSchema, GetScheduledJobSchema,
|
7
|
-
import {
|
6
|
+
import { CreateScheduledJobSchema, GetDailyExecutionTrendSchema, GetScheduledJobSchema, GetTopFailedJobsSchema, ListExecutionsSchema, ListScheduledJobsSchema } from './schema';
|
7
|
+
import { Execution, ExecutionTrend, FailedJob, ScheduledJob } from './types';
|
8
8
|
|
9
9
|
export const CreateScheduledJob = actionClient
|
10
10
|
.schema(CreateScheduledJobSchema)
|
@@ -61,34 +61,34 @@ export const CreateScheduledJob = actionClient
|
|
61
61
|
throw new Error('Failed to fetch ListExecutions');
|
62
62
|
}
|
63
63
|
});
|
64
|
-
|
65
|
-
export const
|
66
|
-
.schema(
|
67
|
-
.action(async ({ parsedInput }): Promise<
|
64
|
+
|
65
|
+
export const GetDailyExecutionTrend = actionClient
|
66
|
+
.schema(GetDailyExecutionTrendSchema)
|
67
|
+
.action(async ({ parsedInput }): Promise<ExecutionTrend[]> => {
|
68
68
|
try {
|
69
69
|
|
70
70
|
const { scheduledJob } = await getSDKForCurrentUser();
|
71
|
-
return await scheduledJob.
|
71
|
+
return await scheduledJob.GetDailyExecutionTrend(parsedInput);
|
72
72
|
|
73
73
|
} catch (error) {
|
74
|
-
console.error('Error in
|
75
|
-
throw new Error('Failed to fetch
|
74
|
+
console.error('Error in GetDailyExecutionTrend:', error);
|
75
|
+
throw new Error('Failed to fetch GetDailyExecutionTrend');
|
76
76
|
}
|
77
77
|
});
|
78
78
|
|
79
|
-
export const
|
80
|
-
.schema(
|
81
|
-
.action(async ({ parsedInput }): Promise<
|
79
|
+
export const GetTopFailedJobs = actionClient
|
80
|
+
.schema(GetTopFailedJobsSchema)
|
81
|
+
.action(async ({ parsedInput }): Promise<FailedJob> => {
|
82
82
|
try {
|
83
83
|
|
84
84
|
const { scheduledJob } = await getSDKForCurrentUser();
|
85
|
-
return await scheduledJob.
|
85
|
+
return await scheduledJob.GetTopFailedJobs(parsedInput);
|
86
86
|
|
87
87
|
} catch (error) {
|
88
|
-
console.error('Error in
|
89
|
-
throw new Error('Failed to fetch
|
88
|
+
console.error('Error in GetTopFailedJobs:', error);
|
89
|
+
throw new Error('Failed to fetch GetTopFailedJobs');
|
90
90
|
}
|
91
|
-
});
|
92
|
-
|
93
|
-
|
94
|
-
|
91
|
+
});
|
92
|
+
|
93
|
+
|
94
|
+
|
@@ -16,16 +16,13 @@ export const GetScheduledJobSchema = z.object({
|
|
16
16
|
});
|
17
17
|
|
18
18
|
export const ListExecutionsSchema = z.object({
|
19
|
-
scheduledJobId: z.string()
|
20
|
-
status: z.string().optional()
|
19
|
+
scheduledJobId: z.string()
|
21
20
|
});
|
22
21
|
|
23
|
-
export const
|
22
|
+
export const GetDailyExecutionTrendSchema = z.object({
|
23
|
+
|
24
24
|
});
|
25
25
|
|
26
|
-
export const
|
27
|
-
|
28
|
-
name: z.string().optional(),
|
29
|
-
cron: z.string().optional(),
|
30
|
-
enabled: z.boolean().optional(),
|
26
|
+
export const GetTopFailedJobsSchema = z.object({
|
27
|
+
|
31
28
|
});
|
@@ -1,8 +1,8 @@
|
|
1
1
|
|
2
2
|
import z from "zod";
|
3
3
|
import { ServiceClient } from "../../service-client";
|
4
|
-
import { CreateScheduledJobSchema, ListScheduledJobsSchema, GetScheduledJobSchema, ListExecutionsSchema,
|
5
|
-
import {
|
4
|
+
import { CreateScheduledJobSchema, ListScheduledJobsSchema, GetScheduledJobSchema, ListExecutionsSchema, GetDailyExecutionTrendSchema, GetTopFailedJobsSchema } from "./schema";
|
5
|
+
import { Execution, ExecutionTrend, FailedJob, ScheduledJob } from "./types";
|
6
6
|
|
7
7
|
export class ScheduledJobService extends ServiceClient {
|
8
8
|
protected getServiceName(): string {
|
@@ -25,13 +25,12 @@ export class ScheduledJobService extends ServiceClient {
|
|
25
25
|
return await this.actionCall('ListExecutions', payload);
|
26
26
|
}
|
27
27
|
|
28
|
-
public async
|
29
|
-
return await this.actionCall('
|
28
|
+
public async GetDailyExecutionTrend(payload: z.infer<typeof GetDailyExecutionTrendSchema>): Promise<ExecutionTrend[]> {
|
29
|
+
return await this.actionCall('GetDailyExecutionTrend', payload);
|
30
30
|
}
|
31
31
|
|
32
|
-
public async
|
33
|
-
return await this.actionCall('
|
32
|
+
public async GetTopFailedJobs(payload: z.infer<typeof GetTopFailedJobsSchema>): Promise<FailedJob[]> {
|
33
|
+
return await this.actionCall('GetTopFailedJobs', payload);
|
34
34
|
}
|
35
|
-
|
36
|
-
|
35
|
+
|
37
36
|
}
|
@@ -26,10 +26,20 @@ export type Execution = {
|
|
26
26
|
status: string;
|
27
27
|
}
|
28
28
|
|
29
|
-
export type
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
29
|
+
export type ExecutionTrend = {
|
30
|
+
labels: string[];
|
31
|
+
datasets: {
|
32
|
+
label: string;
|
33
|
+
data: number[];
|
34
|
+
borderColor: string;
|
35
|
+
}
|
34
36
|
}
|
35
37
|
|
38
|
+
export type FailedJob = {
|
39
|
+
labels: string[];
|
40
|
+
datasets: {
|
41
|
+
label: string;
|
42
|
+
data: number[];
|
43
|
+
backgroundColor: string;
|
44
|
+
}[];
|
45
|
+
}
|