From c5322996c19867f3e69aa201d2a4fae69cd99a19 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 | 21 +++++++++++++++++++-- 1 file changed, 19 insertions(+), 2 deletions(-) (limited to 'model/job') diff --git a/model/job/index.ts b/model/job/index.ts index b7fb3b0..2eea9cf 100644 --- a/model/job/index.ts +++ b/model/job/index.ts @@ -1,11 +1,28 @@ import { isObject } from '@emprespresso/pengueno'; export type JobArgT = Record; +export type JobType = 'fetch_code' | 'build_docker_image.js' | 'ansible_playbook.js' | 'checkout_ci.js'; +export const JobTypes: Array = [ + 'fetch_code', + '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