# @memberjunction/scheduling-base-types
Core type definitions for MemberJunction's scheduled jobs system. This lightweight package provides interfaces and type aliases used throughout the scheduling stack, with no heavy dependencies.
## Architecture
```mermaid
graph TD
A["@memberjunction/scheduling-base-types
(Types Only)"]
B["@memberjunction/scheduling-engine-base
(Metadata Cache)"] --> A
C["@memberjunction/scheduling-engine
(Execution)"] --> A
D["@memberjunction/scheduling-actions
(Agentic Tools)"] --> A
style A fill:#2d6a9f,stroke:#1a4971,color:#fff
style B fill:#2d8659,stroke:#1a5c3a,color:#fff
style C fill:#7c5295,stroke:#563a6b,color:#fff
style D fill:#b8762f,stroke:#8a5722,color:#fff
```
## Overview
This package defines the shared type contracts used across the entire scheduling subsystem. It is designed to be imported anywhere (client or server) without pulling in execution logic or heavy framework dependencies.
**Exported types:**
- **ScheduledJobResult**: Result returned by a scheduled job execution, including success/failure, error messages, and job-type-specific details
- **ScheduledJobConfiguration**: Base interface for job-specific configuration JSON
- **AgentJobConfiguration**: Configuration for AI Agent scheduled jobs (AgentID, ConversationID, etc.)
- **ActionJobConfiguration**: Configuration for Action scheduled jobs (ActionID, Params, etc.)
- **NotificationContent**: Structure for job notification messages (Subject, Body, Priority)
- **ScheduledJobRunStatus**: Union type for run statuses (`Running`, `Completed`, `Failed`, `Cancelled`, `Timeout`)
- **ScheduledJobStatus**: Union type for schedule statuses (`Pending`, `Active`, `Paused`, `Disabled`, `Expired`)
- **NotificationChannel**: Union type for notification delivery (`Email`, `InApp`)
## Installation
```bash
npm install @memberjunction/scheduling-base-types
```
## Usage
```typescript
import {
ScheduledJobResult,
AgentJobConfiguration,
ActionJobConfiguration,
ScheduledJobRunStatus,
NotificationContent
} from '@memberjunction/scheduling-base-types';
// Job result from execution
const result: ScheduledJobResult = {
Success: true,
Details: {
AgentRunID: 'run-guid',
TokensUsed: 1500,
Cost: 0.023
}
};
// Agent job configuration
const agentConfig: AgentJobConfiguration = {
AgentID: 'agent-guid',
InitialMessage: 'Generate daily report',
ConfigurationID: 'config-guid'
};
// Action job configuration
const actionConfig: ActionJobConfiguration = {
ActionID: 'action-guid',
Params: [
{ ActionParamID: 'param-1', ValueType: 'Static', Value: '42' },
{ ActionParamID: 'param-2', ValueType: 'SQL Statement', Value: 'SELECT TOP 1 ID FROM Users' }
]
};
```
## Type Reference
### ScheduledJobResult
| Property | Type | Description |
|----------|------|-------------|
| `Success` | boolean | Whether the job completed successfully |
| `ErrorMessage` | string (optional) | Error message if the job failed |
| `Details` | Record (optional) | Job-type-specific execution details |
### Status Types
| Type | Values |
|------|--------|
| `ScheduledJobRunStatus` | `Running`, `Completed`, `Failed`, `Cancelled`, `Timeout` |
| `ScheduledJobStatus` | `Pending`, `Active`, `Paused`, `Disabled`, `Expired` |
| `NotificationChannel` | `Email`, `InApp` |
## Dependencies
| Package | Purpose |
|---------|---------|
| `@memberjunction/global` | MJGlobal shared utilities |
## License
ISC