@xtr-dev/payload-automation 0.0.19 → 0.0.21

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.
@@ -13,6 +13,11 @@ let globalExecutor = null;
13
13
  const setWorkflowExecutor = (executor)=>{
14
14
  console.log('🚨 SETTING GLOBAL EXECUTOR');
15
15
  globalExecutor = executor;
16
+ // Also set on global object as fallback
17
+ if (typeof global !== 'undefined') {
18
+ global.__workflowExecutor = executor;
19
+ console.log('🚨 EXECUTOR ALSO SET ON GLOBAL OBJECT');
20
+ }
16
21
  };
17
22
  const getWorkflowExecutor = ()=>{
18
23
  return globalExecutor;
@@ -31,7 +36,71 @@ export const workflowsPlugin = (pluginOptions)=>(config)=>{
31
36
  return config;
32
37
  }
33
38
  applyCollectionsConfig(pluginOptions, config);
34
- // Revert: Don't apply hooks in config phase - user collections don't exist yet
39
+ // CRITICAL: Modify existing collection configs BEFORE PayloadCMS processes them
40
+ // This is the ONLY time we can add hooks that will actually work
41
+ const logger = getConfigLogger();
42
+ logger.info('Attempting to modify collection configs before PayloadCMS initialization...');
43
+ if (config.collections && pluginOptions.collectionTriggers) {
44
+ for (const [triggerSlug, triggerConfig] of Object.entries(pluginOptions.collectionTriggers)){
45
+ if (!triggerConfig) continue;
46
+ // Find the collection config that matches
47
+ const collectionIndex = config.collections.findIndex((c)=>c.slug === triggerSlug);
48
+ if (collectionIndex === -1) {
49
+ logger.warn(`Collection '${triggerSlug}' not found in config.collections`);
50
+ continue;
51
+ }
52
+ const collection = config.collections[collectionIndex];
53
+ logger.info(`Found collection '${triggerSlug}' - modifying its hooks...`);
54
+ // Initialize hooks if needed
55
+ if (!collection.hooks) {
56
+ collection.hooks = {};
57
+ }
58
+ if (!collection.hooks.afterChange) {
59
+ collection.hooks.afterChange = [];
60
+ }
61
+ // Create a properly bound hook function that doesn't rely on closures
62
+ // Use a simple function that PayloadCMS can definitely execute
63
+ const automationHook = Object.assign(async function payloadAutomationHook(args) {
64
+ try {
65
+ // Use global console to ensure output
66
+ global.console.log('🔥🔥🔥 AUTOMATION HOOK EXECUTED! 🔥🔥🔥');
67
+ global.console.log('Collection:', args?.collection?.slug);
68
+ global.console.log('Operation:', args?.operation);
69
+ global.console.log('Doc ID:', args?.doc?.id);
70
+ // Try multiple ways to get the executor
71
+ let executor = null;
72
+ // Method 1: Global registry
73
+ if (typeof getWorkflowExecutor === 'function') {
74
+ executor = getWorkflowExecutor();
75
+ }
76
+ // Method 2: Global variable fallback
77
+ if (!executor && typeof global !== 'undefined' && global.__workflowExecutor) {
78
+ executor = global.__workflowExecutor;
79
+ global.console.log('Got executor from global variable');
80
+ }
81
+ if (executor) {
82
+ global.console.log('✅ Executor found - executing workflows!');
83
+ await executor.executeTriggeredWorkflows(args.collection.slug, args.operation, args.doc, args.previousDoc, args.req);
84
+ global.console.log('✅ Workflow execution completed!');
85
+ } else {
86
+ global.console.log('⚠️ No executor available');
87
+ }
88
+ } catch (error) {
89
+ global.console.error('❌ Hook execution error:', error);
90
+ // Don't throw - just log
91
+ }
92
+ // Always return undefined to match other hooks
93
+ return undefined;
94
+ }, {
95
+ // Add metadata to help debugging
96
+ __isAutomationHook: true,
97
+ __version: '0.0.21'
98
+ });
99
+ // Add the hook to the collection config
100
+ collection.hooks.afterChange.push(automationHook);
101
+ logger.info(`Added automation hook to '${triggerSlug}' - hook count: ${collection.hooks.afterChange.length}`);
102
+ }
103
+ }
35
104
  if (!config.jobs) {
36
105
  config.jobs = {
37
106
  tasks: []
@@ -72,36 +141,8 @@ export const workflowsPlugin = (pluginOptions)=>(config)=>{
72
141
  console.log('🚨 EXECUTOR METHODS:', Object.getOwnPropertyNames(Object.getPrototypeOf(executor)));
73
142
  // Register executor globally
74
143
  setWorkflowExecutor(executor);
75
- // DIRECT RUNTIME HOOK REGISTRATION - bypass all abstractions
76
- logger.info('Applying hooks directly to runtime collections...');
77
- for (const [collectionSlug, triggerConfig] of Object.entries(pluginOptions.collectionTriggers || {})){
78
- if (!triggerConfig) continue;
79
- const collection = payload.collections[collectionSlug];
80
- if (!collection) {
81
- logger.warn(`Collection '${collectionSlug}' not found at runtime`);
82
- continue;
83
- }
84
- console.log(`🚨 DIRECTLY MANIPULATING ${collectionSlug} COLLECTION`);
85
- console.log(`🚨 Current afterChange hooks:`, collection.config.hooks?.afterChange?.length || 0);
86
- // Ensure hooks array exists
87
- if (!collection.config.hooks) {
88
- collection.config.hooks = {}; // PayloadCMS hooks type is complex, bypass for direct manipulation
89
- }
90
- if (!collection.config.hooks.afterChange) {
91
- collection.config.hooks.afterChange = [];
92
- }
93
- // Add ultra-simple test hook
94
- const ultraSimpleHook = async (change)=>{
95
- console.log('🎯 ULTRA SIMPLE HOOK EXECUTED! 🎯');
96
- console.log('🎯 Collection:', change.collection.slug);
97
- console.log('🎯 Operation:', change.operation);
98
- console.log('🎯 SUCCESS - Direct runtime registration works!');
99
- };
100
- // Insert at beginning to ensure it runs first
101
- collection.config.hooks.afterChange.unshift(ultraSimpleHook);
102
- console.log(`🚨 Added hook to ${collectionSlug} - new count:`, collection.config.hooks.afterChange.length);
103
- logger.info(`Direct hook registration completed for: ${collectionSlug}`);
104
- }
144
+ // Hooks are now registered during config phase - just log status
145
+ logger.info('Hooks were registered during config phase - executor now available');
105
146
  logger.info('Initializing global hooks...');
106
147
  initGlobalHooks(payload, logger, executor);
107
148
  logger.info('Initializing workflow hooks...');
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/plugin/index.ts"],"sourcesContent":["import type {Config} from 'payload'\n\nimport type {WorkflowsPluginConfig, CollectionTriggerConfigCrud} from \"./config-types.js\"\n\nimport {createWorkflowCollection} from '../collections/Workflow.js'\nimport {WorkflowRunsCollection} from '../collections/WorkflowRuns.js'\nimport {WorkflowExecutor} from '../core/workflow-executor.js'\nimport {generateCronTasks, registerCronJobs} from './cron-scheduler.js'\nimport {initCollectionHooks} from \"./init-collection-hooks.js\"\nimport {initGlobalHooks} from \"./init-global-hooks.js\"\nimport {initStepTasks} from \"./init-step-tasks.js\"\nimport {initWebhookEndpoint} from \"./init-webhook.js\"\nimport {initWorkflowHooks} from './init-workflow-hooks.js'\nimport {getConfigLogger, initializeLogger} from './logger.js'\n\nexport {getLogger} from './logger.js'\n\n// Global executor registry for config-phase hooks\nlet globalExecutor: WorkflowExecutor | null = null\n\nconst setWorkflowExecutor = (executor: WorkflowExecutor) => {\n console.log('🚨 SETTING GLOBAL EXECUTOR')\n globalExecutor = executor\n}\n\nconst getWorkflowExecutor = (): WorkflowExecutor | null => {\n return globalExecutor\n}\n\nconst applyCollectionsConfig = <T extends string>(pluginOptions: WorkflowsPluginConfig<T>, config: Config) => {\n // Add workflow collections\n if (!config.collections) {\n config.collections = []\n }\n\n config.collections.push(\n createWorkflowCollection(pluginOptions),\n WorkflowRunsCollection\n )\n}\n\n// Removed config-phase hook registration - user collections don't exist during config phase\n\n\nexport const workflowsPlugin =\n <TSlug extends string>(pluginOptions: WorkflowsPluginConfig<TSlug>) =>\n (config: Config): Config => {\n // If the plugin is disabled, return config unchanged\n if (pluginOptions.enabled === false) {\n return config\n }\n\n applyCollectionsConfig<TSlug>(pluginOptions, config)\n \n // Revert: Don't apply hooks in config phase - user collections don't exist yet\n\n if (!config.jobs) {\n config.jobs = {tasks: []}\n }\n\n const configLogger = getConfigLogger()\n configLogger.info(`Configuring workflow plugin with ${Object.keys(pluginOptions.collectionTriggers || {}).length} collection triggers`)\n\n // Generate cron tasks for workflows with cron triggers\n generateCronTasks(config)\n\n for (const step of pluginOptions.steps) {\n if (!config.jobs?.tasks?.find(task => task.slug === step.slug)) {\n configLogger.debug(`Registering task: ${step.slug}`)\n config.jobs?.tasks?.push(step)\n } else {\n configLogger.debug(`Task ${step.slug} already registered, skipping`)\n }\n }\n\n // Initialize webhook endpoint\n initWebhookEndpoint(config, pluginOptions.webhookPrefix || 'webhook')\n\n // Set up onInit to register collection hooks and initialize features\n const incomingOnInit = config.onInit\n config.onInit = async (payload) => {\n configLogger.info(`onInit called - collections: ${Object.keys(payload.collections).length}`)\n \n // Execute any existing onInit functions first\n if (incomingOnInit) {\n configLogger.debug('Executing existing onInit function')\n await incomingOnInit(payload)\n }\n\n // Initialize the logger with the payload instance\n const logger = initializeLogger(payload)\n logger.info('Logger initialized with payload instance')\n\n // Log collection trigger configuration\n logger.info(`Plugin configuration: ${Object.keys(pluginOptions.collectionTriggers || {}).length} collection triggers, ${pluginOptions.steps?.length || 0} steps`)\n\n // Create workflow executor instance\n console.log('🚨 CREATING WORKFLOW EXECUTOR INSTANCE')\n const executor = new WorkflowExecutor(payload, logger)\n console.log('🚨 EXECUTOR CREATED:', typeof executor)\n console.log('🚨 EXECUTOR METHODS:', Object.getOwnPropertyNames(Object.getPrototypeOf(executor)))\n \n // Register executor globally\n setWorkflowExecutor(executor)\n\n // DIRECT RUNTIME HOOK REGISTRATION - bypass all abstractions\n logger.info('Applying hooks directly to runtime collections...')\n \n for (const [collectionSlug, triggerConfig] of Object.entries(pluginOptions.collectionTriggers || {})) {\n if (!triggerConfig) continue\n \n const collection = payload.collections[collectionSlug as TSlug]\n if (!collection) {\n logger.warn(`Collection '${collectionSlug}' not found at runtime`)\n continue\n }\n\n console.log(`🚨 DIRECTLY MANIPULATING ${collectionSlug} COLLECTION`)\n console.log(`🚨 Current afterChange hooks:`, collection.config.hooks?.afterChange?.length || 0)\n \n // Ensure hooks array exists\n if (!collection.config.hooks) {\n collection.config.hooks = {} as any // PayloadCMS hooks type is complex, bypass for direct manipulation\n }\n if (!collection.config.hooks.afterChange) {\n collection.config.hooks.afterChange = []\n }\n \n // Add ultra-simple test hook\n const ultraSimpleHook = async (change: { collection: { slug: string }, operation: string, doc?: { id?: string } }) => {\n console.log('🎯 ULTRA SIMPLE HOOK EXECUTED! 🎯')\n console.log('🎯 Collection:', change.collection.slug)\n console.log('🎯 Operation:', change.operation)\n console.log('🎯 SUCCESS - Direct runtime registration works!')\n }\n \n // Insert at beginning to ensure it runs first\n collection.config.hooks.afterChange.unshift(ultraSimpleHook)\n \n console.log(`🚨 Added hook to ${collectionSlug} - new count:`, collection.config.hooks.afterChange.length)\n \n logger.info(`Direct hook registration completed for: ${collectionSlug}`)\n }\n \n logger.info('Initializing global hooks...')\n initGlobalHooks(payload, logger, executor)\n \n logger.info('Initializing workflow hooks...')\n initWorkflowHooks(payload, logger)\n \n logger.info('Initializing step tasks...')\n initStepTasks(pluginOptions, payload, logger)\n\n // Register cron jobs for workflows with cron triggers\n logger.info('Registering cron jobs...')\n await registerCronJobs(payload, logger)\n\n logger.info('Plugin initialized successfully - all hooks registered')\n }\n\n return config\n }\n"],"names":["createWorkflowCollection","WorkflowRunsCollection","WorkflowExecutor","generateCronTasks","registerCronJobs","initGlobalHooks","initStepTasks","initWebhookEndpoint","initWorkflowHooks","getConfigLogger","initializeLogger","getLogger","globalExecutor","setWorkflowExecutor","executor","console","log","getWorkflowExecutor","applyCollectionsConfig","pluginOptions","config","collections","push","workflowsPlugin","enabled","jobs","tasks","configLogger","info","Object","keys","collectionTriggers","length","step","steps","find","task","slug","debug","webhookPrefix","incomingOnInit","onInit","payload","logger","getOwnPropertyNames","getPrototypeOf","collectionSlug","triggerConfig","entries","collection","warn","hooks","afterChange","ultraSimpleHook","change","operation","unshift"],"mappings":"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"}
1
+ {"version":3,"sources":["../../src/plugin/index.ts"],"sourcesContent":["import type {Config} from 'payload'\n\nimport type {WorkflowsPluginConfig, CollectionTriggerConfigCrud} from \"./config-types.js\"\n\nimport {createWorkflowCollection} from '../collections/Workflow.js'\nimport {WorkflowRunsCollection} from '../collections/WorkflowRuns.js'\nimport {WorkflowExecutor} from '../core/workflow-executor.js'\nimport {generateCronTasks, registerCronJobs} from './cron-scheduler.js'\nimport {initCollectionHooks} from \"./init-collection-hooks.js\"\nimport {initGlobalHooks} from \"./init-global-hooks.js\"\nimport {initStepTasks} from \"./init-step-tasks.js\"\nimport {initWebhookEndpoint} from \"./init-webhook.js\"\nimport {initWorkflowHooks} from './init-workflow-hooks.js'\nimport {getConfigLogger, initializeLogger} from './logger.js'\n\nexport {getLogger} from './logger.js'\n\n// Global executor registry for config-phase hooks\nlet globalExecutor: WorkflowExecutor | null = null\n\nconst setWorkflowExecutor = (executor: WorkflowExecutor) => {\n console.log('🚨 SETTING GLOBAL EXECUTOR')\n globalExecutor = executor\n \n // Also set on global object as fallback\n if (typeof global !== 'undefined') {\n (global as any).__workflowExecutor = executor\n console.log('🚨 EXECUTOR ALSO SET ON GLOBAL OBJECT')\n }\n}\n\nconst getWorkflowExecutor = (): WorkflowExecutor | null => {\n return globalExecutor\n}\n\nconst applyCollectionsConfig = <T extends string>(pluginOptions: WorkflowsPluginConfig<T>, config: Config) => {\n // Add workflow collections\n if (!config.collections) {\n config.collections = []\n }\n\n config.collections.push(\n createWorkflowCollection(pluginOptions),\n WorkflowRunsCollection\n )\n}\n\n// Removed config-phase hook registration - user collections don't exist during config phase\n\n\nexport const workflowsPlugin =\n <TSlug extends string>(pluginOptions: WorkflowsPluginConfig<TSlug>) =>\n (config: Config): Config => {\n // If the plugin is disabled, return config unchanged\n if (pluginOptions.enabled === false) {\n return config\n }\n\n applyCollectionsConfig<TSlug>(pluginOptions, config)\n \n // CRITICAL: Modify existing collection configs BEFORE PayloadCMS processes them\n // This is the ONLY time we can add hooks that will actually work\n const logger = getConfigLogger()\n logger.info('Attempting to modify collection configs before PayloadCMS initialization...')\n \n if (config.collections && pluginOptions.collectionTriggers) {\n for (const [triggerSlug, triggerConfig] of Object.entries(pluginOptions.collectionTriggers)) {\n if (!triggerConfig) continue\n \n // Find the collection config that matches\n const collectionIndex = config.collections.findIndex(c => c.slug === triggerSlug)\n if (collectionIndex === -1) {\n logger.warn(`Collection '${triggerSlug}' not found in config.collections`)\n continue\n }\n \n const collection = config.collections[collectionIndex]\n logger.info(`Found collection '${triggerSlug}' - modifying its hooks...`)\n \n // Initialize hooks if needed\n if (!collection.hooks) {\n collection.hooks = {}\n }\n if (!collection.hooks.afterChange) {\n collection.hooks.afterChange = []\n }\n \n // Create a properly bound hook function that doesn't rely on closures\n // Use a simple function that PayloadCMS can definitely execute\n const automationHook = Object.assign(\n async function payloadAutomationHook(args: any) {\n try {\n // Use global console to ensure output\n global.console.log('🔥🔥🔥 AUTOMATION HOOK EXECUTED! 🔥🔥🔥')\n global.console.log('Collection:', args?.collection?.slug)\n global.console.log('Operation:', args?.operation)\n global.console.log('Doc ID:', args?.doc?.id)\n \n // Try multiple ways to get the executor\n let executor = null\n \n // Method 1: Global registry\n if (typeof getWorkflowExecutor === 'function') {\n executor = getWorkflowExecutor()\n }\n \n // Method 2: Global variable fallback\n if (!executor && typeof global !== 'undefined' && (global as any).__workflowExecutor) {\n executor = (global as any).__workflowExecutor\n global.console.log('Got executor from global variable')\n }\n \n if (executor) {\n global.console.log('✅ Executor found - executing workflows!')\n await executor.executeTriggeredWorkflows(\n args.collection.slug,\n args.operation,\n args.doc,\n args.previousDoc,\n args.req\n )\n global.console.log('✅ Workflow execution completed!')\n } else {\n global.console.log('⚠️ No executor available')\n }\n } catch (error) {\n global.console.error('❌ Hook execution error:', error)\n // Don't throw - just log\n }\n \n // Always return undefined to match other hooks\n return undefined\n },\n {\n // Add metadata to help debugging\n __isAutomationHook: true,\n __version: '0.0.21'\n }\n )\n \n // Add the hook to the collection config\n collection.hooks.afterChange.push(automationHook)\n logger.info(`Added automation hook to '${triggerSlug}' - hook count: ${collection.hooks.afterChange.length}`)\n }\n }\n\n if (!config.jobs) {\n config.jobs = {tasks: []}\n }\n\n const configLogger = getConfigLogger()\n configLogger.info(`Configuring workflow plugin with ${Object.keys(pluginOptions.collectionTriggers || {}).length} collection triggers`)\n\n // Generate cron tasks for workflows with cron triggers\n generateCronTasks(config)\n\n for (const step of pluginOptions.steps) {\n if (!config.jobs?.tasks?.find(task => task.slug === step.slug)) {\n configLogger.debug(`Registering task: ${step.slug}`)\n config.jobs?.tasks?.push(step)\n } else {\n configLogger.debug(`Task ${step.slug} already registered, skipping`)\n }\n }\n\n // Initialize webhook endpoint\n initWebhookEndpoint(config, pluginOptions.webhookPrefix || 'webhook')\n\n // Set up onInit to register collection hooks and initialize features\n const incomingOnInit = config.onInit\n config.onInit = async (payload) => {\n configLogger.info(`onInit called - collections: ${Object.keys(payload.collections).length}`)\n \n // Execute any existing onInit functions first\n if (incomingOnInit) {\n configLogger.debug('Executing existing onInit function')\n await incomingOnInit(payload)\n }\n\n // Initialize the logger with the payload instance\n const logger = initializeLogger(payload)\n logger.info('Logger initialized with payload instance')\n\n // Log collection trigger configuration\n logger.info(`Plugin configuration: ${Object.keys(pluginOptions.collectionTriggers || {}).length} collection triggers, ${pluginOptions.steps?.length || 0} steps`)\n\n // Create workflow executor instance\n console.log('🚨 CREATING WORKFLOW EXECUTOR INSTANCE')\n const executor = new WorkflowExecutor(payload, logger)\n console.log('🚨 EXECUTOR CREATED:', typeof executor)\n console.log('🚨 EXECUTOR METHODS:', Object.getOwnPropertyNames(Object.getPrototypeOf(executor)))\n \n // Register executor globally\n setWorkflowExecutor(executor)\n\n // Hooks are now registered during config phase - just log status\n logger.info('Hooks were registered during config phase - executor now available')\n \n logger.info('Initializing global hooks...')\n initGlobalHooks(payload, logger, executor)\n \n logger.info('Initializing workflow hooks...')\n initWorkflowHooks(payload, logger)\n \n logger.info('Initializing step tasks...')\n initStepTasks(pluginOptions, payload, logger)\n\n // Register cron jobs for workflows with cron triggers\n logger.info('Registering cron jobs...')\n await registerCronJobs(payload, logger)\n\n logger.info('Plugin initialized successfully - all hooks registered')\n }\n\n return config\n }\n"],"names":["createWorkflowCollection","WorkflowRunsCollection","WorkflowExecutor","generateCronTasks","registerCronJobs","initGlobalHooks","initStepTasks","initWebhookEndpoint","initWorkflowHooks","getConfigLogger","initializeLogger","getLogger","globalExecutor","setWorkflowExecutor","executor","console","log","global","__workflowExecutor","getWorkflowExecutor","applyCollectionsConfig","pluginOptions","config","collections","push","workflowsPlugin","enabled","logger","info","collectionTriggers","triggerSlug","triggerConfig","Object","entries","collectionIndex","findIndex","c","slug","warn","collection","hooks","afterChange","automationHook","assign","payloadAutomationHook","args","operation","doc","id","executeTriggeredWorkflows","previousDoc","req","error","undefined","__isAutomationHook","__version","length","jobs","tasks","configLogger","keys","step","steps","find","task","debug","webhookPrefix","incomingOnInit","onInit","payload","getOwnPropertyNames","getPrototypeOf"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@xtr-dev/payload-automation",
3
- "version": "0.0.19",
3
+ "version": "0.0.21",
4
4
  "description": "PayloadCMS Automation Plugin - Comprehensive workflow automation system with visual workflow building, execution tracking, and step types",
5
5
  "license": "MIT",
6
6
  "type": "module",