From b1efe258974f93616c98485f2bcfb8b999f0e4ad Mon Sep 17 00:00:00 2001 From: Elizabeth Hunt Date: Fri, 25 Jul 2025 21:21:11 -0700 Subject: make jobtype a parameterized type; be smart about locking the vault --- model/job/index.ts | 15 +++++++++++++-- 1 file changed, 13 insertions(+), 2 deletions(-) (limited to 'model/job/index.ts') diff --git a/model/job/index.ts b/model/job/index.ts index b7fb3b0..473b61a 100644 --- a/model/job/index.ts +++ b/model/job/index.ts @@ -1,11 +1,22 @@ import { isObject } from '@emprespresso/pengueno'; export type JobArgT = Record; +export type JobType = 'fetch_code' | 'ci_pipeline' | 'build_docker_image.js' | 'ansible_playbook.js' | 'checkout_ci.js'; +export const JobTypes: Array = [ + 'fetch_code', + 'ci_pipeline', + 'build_docker_image.js', + 'ansible_playbook.js', + 'checkout_ci.js', +]; export interface Job { - readonly type: string; + readonly type: JobType; readonly arguments: JobArgT; } + +export const isJobType = (j: unknown): j is JobType => typeof j === 'string' && JobTypes.includes(j); + export const isJob = (j: unknown): j is Job => - !!(isObject(j) && 'arguments' in j && isObject(j.arguments) && 'type' in j && typeof j.type === 'string' && j); + !!(isObject(j) && 'arguments' in j && isObject(j.arguments) && 'type' in j && isJobType(j.type) && j); export * from './jobs.js'; -- cgit v1.2.3-70-g09d2