PSA/server/seeds/dev/44_schedule_entries.cjs
Hermes 284313f908
Some checks are pending
Bidi Control Character Guard / bidi-control-guard (push) Waiting to run
Circular Dependency Check / Check for new circular dependencies (push) Waiting to run
Citus Migration Smoke / Combined migrations on single-node Citus (push) Waiting to run
E2E Fresh Install Tests / fresh-install-e2e (push) Waiting to run
ext-v2 guardrails / Run ext-v2 guard and ESLint (push) Waiting to run
Integration Tests / Check for relevant changes (push) Waiting to run
Integration Tests / ${{ (github.event_name == 'schedule' || github.event.inputs.suite == 'full') && 'Full integration suite' || 'Tier-1 integration subset' }} (push) Blocked by required conditions
Mobile checks / Mobile lint + typecheck (push) Waiting to run
Mobile checks / Mobile unit tests (push) Waiting to run
Mobile checks / Mobile dependency audit (report) (push) Waiting to run
Mobile checks / Mobile reproducibility checks (push) Waiting to run
Secrets guard (env backups) / Ensure no tracked env backup files (push) Waiting to run
Temporal Readiness / fast-readiness (push) Waiting to run
Temporal Readiness / docker-parity (push) Waiting to run
TypeScript Type Check / Nx affected typecheck (push) Waiting to run
Unit Tests / Skipped-test budget (push) Waiting to run
Unit Tests / Nx affected unit tests (push) Waiting to run
Unit Tests / Server unit coverage (informational) (push) Waiting to run
Validate Tenant Management Schema / Check for relevant changes (push) Waiting to run
Validate Tenant Management Schema / Validate Tenant Management Schema (push) Blocked by required conditions
EE Workflows Build Guard / ee-workflows-build-guard (push) Waiting to run
Initial import of AlgaPSA codebase from PSA server
Excluded: .git, node_modules, secrets/, compose.env, assemblyscript tgz

Source: /opt/alga-psa on psa.joliet.tech
2026-06-22 16:12:17 -05:00

70 lines
2.7 KiB
JavaScript

exports.seed = async function (knex) {
// Get the tenant ID
const tenant = await knex('tenants').select('tenant').first();
if (!tenant) return;
// Create schedule entries
const entries = [
{
tenant: tenant.tenant,
title: 'Cheshire Cat Pathways',
work_item_id: knex('tickets').where({ tenant: tenant.tenant, title: 'Missing White Rabbit' }).select('ticket_id').first(),
scheduled_start: knex.raw("CURRENT_TIMESTAMP - INTERVAL '1 day'"),
scheduled_end: knex.raw("CURRENT_TIMESTAMP + INTERVAL '1 day'"),
status: 'Scheduled',
notes: 'Planning road network for Wonderland expansion',
work_item_type: 'project_task'
},
{
tenant: tenant.tenant,
title: 'Through the Looking Glass Expedition',
work_item_id: knex('tickets').where({ tenant: tenant.tenant, title: 'Missing White Rabbit' }).select('ticket_id').first(),
scheduled_start: knex.raw("CURRENT_TIMESTAMP + INTERVAL '2 days'"),
scheduled_end: knex.raw("CURRENT_TIMESTAMP + INTERVAL '2 days' + INTERVAL '2 hours'"),
status: 'Scheduled',
notes: 'Surveying uncharted areas in Wonderland',
work_item_type: 'ticket'
},
{
tenant: tenant.tenant,
title: 'Emerald City Garden Enchantment',
work_item_id: knex('tickets').where({ tenant: tenant.tenant, title: 'Enhance Emerald City Gardens' }).select('ticket_id').first(),
scheduled_start: knex.raw("CURRENT_TIMESTAMP + INTERVAL '3 days'"),
scheduled_end: knex.raw("CURRENT_TIMESTAMP + INTERVAL '3 days' + INTERVAL '3 hours'"),
status: 'Scheduled',
notes: 'Enhancing Emerald City gardens with magical flora',
work_item_type: 'ticket'
}
];
// Insert schedule entries and get their IDs
const [firstEntry, secondEntry, thirdEntry] = await knex('schedule_entries')
.insert(entries)
.returning(['tenant', 'entry_id']);
// Get user ID for glinda
const glinda = await knex('users')
.where({ tenant: tenant.tenant, username: 'glinda' })
.select('user_id')
.first();
// Create assignee relationships
await knex('schedule_entry_assignees').insert([
{
tenant: firstEntry.tenant,
entry_id: firstEntry.entry_id,
user_id: glinda.user_id
},
{
tenant: secondEntry.tenant,
entry_id: secondEntry.entry_id,
user_id: glinda.user_id
},
{
tenant: thirdEntry.tenant,
entry_id: thirdEntry.entry_id,
user_id: glinda.user_id
}
]);
};