agrs-sequelize-sdk 1.4.19 → 1.4.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.
- package/.worktrees/ad-review-status/LICENSE +21 -0
- package/.worktrees/ad-review-status/README.md +179 -0
- package/.worktrees/ad-review-status/index.js +169 -0
- package/.worktrees/ad-review-status/jq.exe +0 -0
- package/.worktrees/ad-review-status/migrations/2026-05-17-PIXELS-FOLLOWUP.md +85 -0
- package/.worktrees/ad-review-status/migrations/2026-05-17-add-platform-to-ad.js +19 -0
- package/.worktrees/ad-review-status/migrations/2026-05-17-add-platform-to-adaccount.js +19 -0
- package/.worktrees/ad-review-status/migrations/2026-05-17-add-platform-to-adperformance.js +19 -0
- package/.worktrees/ad-review-status/migrations/2026-05-17-add-platform-to-adset.js +19 -0
- package/.worktrees/ad-review-status/migrations/2026-05-17-add-platform-to-adsetperformance.js +19 -0
- package/.worktrees/ad-review-status/migrations/2026-05-17-add-platform-to-aiarticleretryqueue.js +19 -0
- package/.worktrees/ad-review-status/migrations/2026-05-17-add-platform-to-aicampaignqueue.js +19 -0
- package/.worktrees/ad-review-status/migrations/2026-05-17-add-platform-to-article.js +19 -0
- package/.worktrees/ad-review-status/migrations/2026-05-17-add-platform-to-campaign.js +19 -0
- package/.worktrees/ad-review-status/migrations/2026-05-17-add-platform-to-codefuelcampaign.js +19 -0
- package/.worktrees/ad-review-status/migrations/2026-05-17-add-platform-to-dynamicfeed.js +19 -0
- package/.worktrees/ad-review-status/migrations/2026-05-17-add-platform-to-facebookretryqueue.js +19 -0
- package/.worktrees/ad-review-status/migrations/2026-05-17-add-platform-to-pages.js +19 -0
- package/.worktrees/ad-review-status/migrations/2026-05-17-add-platform-to-presets.js +19 -0
- package/.worktrees/ad-review-status/migrations/2026-05-18-add-review-status-to-ad.js +36 -0
- package/.worktrees/ad-review-status/migrations/RUN_ME_MANUALLY_2026-05-17.sql +99 -0
- package/.worktrees/ad-review-status/migrations/add-requested-from-dashboard-to-articles.js +17 -0
- package/.worktrees/ad-review-status/migrations/change-adset-name-to-text.js +79 -0
- package/.worktrees/ad-review-status/models/AICampaignQueue.js +144 -0
- package/.worktrees/ad-review-status/models/AIGenerationLog.js +85 -0
- package/.worktrees/ad-review-status/models/AIGenerationRequest.js +212 -0
- package/.worktrees/ad-review-status/models/ActivityHistory.js +73 -0
- package/.worktrees/ad-review-status/models/Ad.js +312 -0
- package/.worktrees/ad-review-status/models/AdAccount.js +97 -0
- package/.worktrees/ad-review-status/models/AdAccountValues.js +26 -0
- package/.worktrees/ad-review-status/models/AdHistory.js +30 -0
- package/.worktrees/ad-review-status/models/AdPerformance.js +100 -0
- package/.worktrees/ad-review-status/models/AdPerformanceHourly.js +71 -0
- package/.worktrees/ad-review-status/models/AdSet.js +295 -0
- package/.worktrees/ad-review-status/models/AdSetHistory.js +30 -0
- package/.worktrees/ad-review-status/models/AdsetPerformance.js +132 -0
- package/.worktrees/ad-review-status/models/AiArticleRetryQueue.js +157 -0
- package/.worktrees/ad-review-status/models/AiCreationRetryQueue.js +127 -0
- package/.worktrees/ad-review-status/models/Article.js +212 -0
- package/.worktrees/ad-review-status/models/AutomationRule.js +173 -0
- package/.worktrees/ad-review-status/models/BannerTemplate.js +129 -0
- package/.worktrees/ad-review-status/models/Buyers.js +26 -0
- package/.worktrees/ad-review-status/models/Campaign.js +163 -0
- package/.worktrees/ad-review-status/models/CampaignActionHistory.js +86 -0
- package/.worktrees/ad-review-status/models/CampaignCreationLog.js +309 -0
- package/.worktrees/ad-review-status/models/CampaignCreationLogV2.js +314 -0
- package/.worktrees/ad-review-status/models/CampaignHistory.js +33 -0
- package/.worktrees/ad-review-status/models/Channel.js +55 -0
- package/.worktrees/ad-review-status/models/CodefuelCampaign.js +175 -0
- package/.worktrees/ad-review-status/models/CodefuelCampaignKWHistory.js +41 -0
- package/.worktrees/ad-review-status/models/CodefuelKeywords.js +35 -0
- package/.worktrees/ad-review-status/models/CurrencyRate.js +27 -0
- package/.worktrees/ad-review-status/models/Domain.js +40 -0
- package/.worktrees/ad-review-status/models/DynamicFeed.js +219 -0
- package/.worktrees/ad-review-status/models/ExplorAdsChannel.js +62 -0
- package/.worktrees/ad-review-status/models/FacebookRetryQueue.js +163 -0
- package/.worktrees/ad-review-status/models/Feed.js +34 -0
- package/.worktrees/ad-review-status/models/FeedArticleConfiguration.js +81 -0
- package/.worktrees/ad-review-status/models/Files.js +73 -0
- package/.worktrees/ad-review-status/models/Folders.js +133 -0
- package/.worktrees/ad-review-status/models/FrontStoryChannel.js +60 -0
- package/.worktrees/ad-review-status/models/FrontStoryChannelV2.js +60 -0
- package/.worktrees/ad-review-status/models/GenericFlowRequest.js +115 -0
- package/.worktrees/ad-review-status/models/KeywordPerformance.js +106 -0
- package/.worktrees/ad-review-status/models/KeywordRotationState.js +51 -0
- package/.worktrees/ad-review-status/models/MidoWebChannel.js +47 -0
- package/.worktrees/ad-review-status/models/MineChannel.js +43 -0
- package/.worktrees/ad-review-status/models/Pages.js +105 -0
- package/.worktrees/ad-review-status/models/PipelineExecution.js +59 -0
- package/.worktrees/ad-review-status/models/PolicyDogsCreativeCache.js +50 -0
- package/.worktrees/ad-review-status/models/PolicyDogsImageCache.js +30 -0
- package/.worktrees/ad-review-status/models/Presets.js +40 -0
- package/.worktrees/ad-review-status/models/RSOCFeedCampaign.js +375 -0
- package/.worktrees/ad-review-status/models/RsocKeywordPerformance.js +111 -0
- package/.worktrees/ad-review-status/models/RuleAction.js +90 -0
- package/.worktrees/ad-review-status/models/RuleCondition.js +137 -0
- package/.worktrees/ad-review-status/models/RuleExecution.js +107 -0
- package/.worktrees/ad-review-status/models/RulesValues.js +56 -0
- package/.worktrees/ad-review-status/models/SupportedLocale.js +24 -0
- package/.worktrees/ad-review-status/models/SyncHistory.js +250 -0
- package/.worktrees/ad-review-status/models/TTQChannel.js +42 -0
- package/.worktrees/ad-review-status/models/TemplateMetadata.js +260 -0
- package/.worktrees/ad-review-status/models/Tier2_AdAccounts.js +110 -0
- package/.worktrees/ad-review-status/models/Tier2_Assets.js +70 -0
- package/.worktrees/ad-review-status/models/Tier2_BusinessManagers.js +105 -0
- package/.worktrees/ad-review-status/models/Tier2_CreditLines.js +99 -0
- package/.worktrees/ad-review-status/models/Tier2_Pages.js +91 -0
- package/.worktrees/ad-review-status/models/Tier2_Pixels.js +82 -0
- package/.worktrees/ad-review-status/models/Tier2_Tokens.js +64 -0
- package/.worktrees/ad-review-status/models/Tier2_UserAdAccounts.js +83 -0
- package/.worktrees/ad-review-status/models/TokenRotationState.js +121 -0
- package/.worktrees/ad-review-status/models/TonicCampaign.js +97 -0
- package/.worktrees/ad-review-status/models/TonicRSOCKeywordPerformance.js +123 -0
- package/.worktrees/ad-review-status/models/Users.js +148 -0
- package/.worktrees/ad-review-status/models/Vertical.js +26 -0
- package/.worktrees/ad-review-status/models/newFiles.js +137 -0
- package/.worktrees/ad-review-status/models/pixel.js +47 -0
- package/.worktrees/ad-review-status/package-lock.json +405 -0
- package/.worktrees/ad-review-status/package.json +19 -0
- package/.worktrees/ad-review-status/run.ps1 +98 -0
- package/.worktrees/ad-review-status/run.sh +214 -0
- package/.worktrees/ad-review-status/services/sequelizeService.js +110 -0
- package/.worktrees/add-platform-to-rule/LICENSE +21 -0
- package/.worktrees/add-platform-to-rule/README.md +179 -0
- package/.worktrees/add-platform-to-rule/index.js +169 -0
- package/.worktrees/add-platform-to-rule/jq.exe +0 -0
- package/.worktrees/add-platform-to-rule/migrations/2026-05-17-PIXELS-FOLLOWUP.md +85 -0
- package/.worktrees/add-platform-to-rule/migrations/2026-05-17-add-platform-to-ad.js +19 -0
- package/.worktrees/add-platform-to-rule/migrations/2026-05-17-add-platform-to-adaccount.js +19 -0
- package/.worktrees/add-platform-to-rule/migrations/2026-05-17-add-platform-to-adperformance.js +19 -0
- package/.worktrees/add-platform-to-rule/migrations/2026-05-17-add-platform-to-adset.js +19 -0
- package/.worktrees/add-platform-to-rule/migrations/2026-05-17-add-platform-to-adsetperformance.js +19 -0
- package/.worktrees/add-platform-to-rule/migrations/2026-05-17-add-platform-to-aiarticleretryqueue.js +19 -0
- package/.worktrees/add-platform-to-rule/migrations/2026-05-17-add-platform-to-aicampaignqueue.js +19 -0
- package/.worktrees/add-platform-to-rule/migrations/2026-05-17-add-platform-to-article.js +19 -0
- package/.worktrees/add-platform-to-rule/migrations/2026-05-17-add-platform-to-campaign.js +19 -0
- package/.worktrees/add-platform-to-rule/migrations/2026-05-17-add-platform-to-codefuelcampaign.js +19 -0
- package/.worktrees/add-platform-to-rule/migrations/2026-05-17-add-platform-to-dynamicfeed.js +19 -0
- package/.worktrees/add-platform-to-rule/migrations/2026-05-17-add-platform-to-facebookretryqueue.js +19 -0
- package/.worktrees/add-platform-to-rule/migrations/2026-05-17-add-platform-to-pages.js +19 -0
- package/.worktrees/add-platform-to-rule/migrations/2026-05-17-add-platform-to-presets.js +19 -0
- package/.worktrees/add-platform-to-rule/migrations/2026-05-17-add-platform-to-rule.js +19 -0
- package/.worktrees/add-platform-to-rule/migrations/RUN_ME_MANUALLY_2026-05-17.sql +99 -0
- package/.worktrees/add-platform-to-rule/migrations/add-requested-from-dashboard-to-articles.js +17 -0
- package/.worktrees/add-platform-to-rule/migrations/change-adset-name-to-text.js +79 -0
- package/.worktrees/add-platform-to-rule/models/AICampaignQueue.js +144 -0
- package/.worktrees/add-platform-to-rule/models/AIGenerationLog.js +85 -0
- package/.worktrees/add-platform-to-rule/models/AIGenerationRequest.js +212 -0
- package/.worktrees/add-platform-to-rule/models/ActivityHistory.js +73 -0
- package/.worktrees/add-platform-to-rule/models/Ad.js +300 -0
- package/.worktrees/add-platform-to-rule/models/AdAccount.js +97 -0
- package/.worktrees/add-platform-to-rule/models/AdAccountValues.js +26 -0
- package/.worktrees/add-platform-to-rule/models/AdHistory.js +30 -0
- package/.worktrees/add-platform-to-rule/models/AdPerformance.js +100 -0
- package/.worktrees/add-platform-to-rule/models/AdPerformanceHourly.js +71 -0
- package/.worktrees/add-platform-to-rule/models/AdSet.js +295 -0
- package/.worktrees/add-platform-to-rule/models/AdSetHistory.js +30 -0
- package/.worktrees/add-platform-to-rule/models/AdsetPerformance.js +132 -0
- package/.worktrees/add-platform-to-rule/models/AiArticleRetryQueue.js +157 -0
- package/.worktrees/add-platform-to-rule/models/AiCreationRetryQueue.js +127 -0
- package/.worktrees/add-platform-to-rule/models/Article.js +212 -0
- package/.worktrees/add-platform-to-rule/models/AutomationRule.js +179 -0
- package/.worktrees/add-platform-to-rule/models/BannerTemplate.js +129 -0
- package/.worktrees/add-platform-to-rule/models/Buyers.js +26 -0
- package/.worktrees/add-platform-to-rule/models/Campaign.js +163 -0
- package/.worktrees/add-platform-to-rule/models/CampaignActionHistory.js +86 -0
- package/.worktrees/add-platform-to-rule/models/CampaignCreationLog.js +309 -0
- package/.worktrees/add-platform-to-rule/models/CampaignCreationLogV2.js +314 -0
- package/.worktrees/add-platform-to-rule/models/CampaignHistory.js +33 -0
- package/.worktrees/add-platform-to-rule/models/Channel.js +55 -0
- package/.worktrees/add-platform-to-rule/models/CodefuelCampaign.js +175 -0
- package/.worktrees/add-platform-to-rule/models/CodefuelCampaignKWHistory.js +41 -0
- package/.worktrees/add-platform-to-rule/models/CodefuelKeywords.js +35 -0
- package/.worktrees/add-platform-to-rule/models/CurrencyRate.js +27 -0
- package/.worktrees/add-platform-to-rule/models/Domain.js +40 -0
- package/.worktrees/add-platform-to-rule/models/DynamicFeed.js +219 -0
- package/.worktrees/add-platform-to-rule/models/ExplorAdsChannel.js +62 -0
- package/.worktrees/add-platform-to-rule/models/FacebookRetryQueue.js +163 -0
- package/.worktrees/add-platform-to-rule/models/Feed.js +34 -0
- package/.worktrees/add-platform-to-rule/models/FeedArticleConfiguration.js +81 -0
- package/.worktrees/add-platform-to-rule/models/Files.js +73 -0
- package/.worktrees/add-platform-to-rule/models/Folders.js +133 -0
- package/.worktrees/add-platform-to-rule/models/FrontStoryChannel.js +60 -0
- package/.worktrees/add-platform-to-rule/models/FrontStoryChannelV2.js +60 -0
- package/.worktrees/add-platform-to-rule/models/GenericFlowRequest.js +115 -0
- package/.worktrees/add-platform-to-rule/models/KeywordPerformance.js +106 -0
- package/.worktrees/add-platform-to-rule/models/KeywordRotationState.js +51 -0
- package/.worktrees/add-platform-to-rule/models/MidoWebChannel.js +47 -0
- package/.worktrees/add-platform-to-rule/models/MineChannel.js +43 -0
- package/.worktrees/add-platform-to-rule/models/Pages.js +105 -0
- package/.worktrees/add-platform-to-rule/models/PipelineExecution.js +59 -0
- package/.worktrees/add-platform-to-rule/models/PolicyDogsCreativeCache.js +50 -0
- package/.worktrees/add-platform-to-rule/models/PolicyDogsImageCache.js +30 -0
- package/.worktrees/add-platform-to-rule/models/Presets.js +40 -0
- package/.worktrees/add-platform-to-rule/models/RSOCFeedCampaign.js +375 -0
- package/.worktrees/add-platform-to-rule/models/RsocKeywordPerformance.js +111 -0
- package/.worktrees/add-platform-to-rule/models/RuleAction.js +90 -0
- package/.worktrees/add-platform-to-rule/models/RuleCondition.js +137 -0
- package/.worktrees/add-platform-to-rule/models/RuleExecution.js +107 -0
- package/.worktrees/add-platform-to-rule/models/RulesValues.js +56 -0
- package/.worktrees/add-platform-to-rule/models/SupportedLocale.js +24 -0
- package/.worktrees/add-platform-to-rule/models/SyncHistory.js +250 -0
- package/.worktrees/add-platform-to-rule/models/TTQChannel.js +42 -0
- package/.worktrees/add-platform-to-rule/models/TemplateMetadata.js +260 -0
- package/.worktrees/add-platform-to-rule/models/Tier2_AdAccounts.js +110 -0
- package/.worktrees/add-platform-to-rule/models/Tier2_Assets.js +70 -0
- package/.worktrees/add-platform-to-rule/models/Tier2_BusinessManagers.js +105 -0
- package/.worktrees/add-platform-to-rule/models/Tier2_CreditLines.js +99 -0
- package/.worktrees/add-platform-to-rule/models/Tier2_Pages.js +91 -0
- package/.worktrees/add-platform-to-rule/models/Tier2_Pixels.js +82 -0
- package/.worktrees/add-platform-to-rule/models/Tier2_Tokens.js +64 -0
- package/.worktrees/add-platform-to-rule/models/Tier2_UserAdAccounts.js +83 -0
- package/.worktrees/add-platform-to-rule/models/TokenRotationState.js +121 -0
- package/.worktrees/add-platform-to-rule/models/TonicCampaign.js +97 -0
- package/.worktrees/add-platform-to-rule/models/TonicRSOCKeywordPerformance.js +123 -0
- package/.worktrees/add-platform-to-rule/models/Users.js +148 -0
- package/.worktrees/add-platform-to-rule/models/Vertical.js +26 -0
- package/.worktrees/add-platform-to-rule/models/newFiles.js +137 -0
- package/.worktrees/add-platform-to-rule/models/pixel.js +47 -0
- package/.worktrees/add-platform-to-rule/package-lock.json +405 -0
- package/.worktrees/add-platform-to-rule/package.json +19 -0
- package/.worktrees/add-platform-to-rule/run.ps1 +98 -0
- package/.worktrees/add-platform-to-rule/run.sh +214 -0
- package/.worktrees/add-platform-to-rule/services/sequelizeService.js +110 -0
- package/.worktrees/adperformance-platform/LICENSE +21 -0
- package/.worktrees/adperformance-platform/README.md +179 -0
- package/.worktrees/adperformance-platform/index.js +169 -0
- package/.worktrees/adperformance-platform/jq.exe +0 -0
- package/.worktrees/adperformance-platform/migrations/2026-05-17-PIXELS-FOLLOWUP.md +85 -0
- package/.worktrees/adperformance-platform/migrations/2026-05-17-add-platform-to-ad.js +19 -0
- package/.worktrees/adperformance-platform/migrations/2026-05-17-add-platform-to-adaccount.js +19 -0
- package/.worktrees/adperformance-platform/migrations/2026-05-17-add-platform-to-adperformance.js +19 -0
- package/.worktrees/adperformance-platform/migrations/2026-05-17-add-platform-to-adset.js +19 -0
- package/.worktrees/adperformance-platform/migrations/2026-05-17-add-platform-to-adsetperformance.js +19 -0
- package/.worktrees/adperformance-platform/migrations/2026-05-17-add-platform-to-aiarticleretryqueue.js +19 -0
- package/.worktrees/adperformance-platform/migrations/2026-05-17-add-platform-to-aicampaignqueue.js +19 -0
- package/.worktrees/adperformance-platform/migrations/2026-05-17-add-platform-to-article.js +19 -0
- package/.worktrees/adperformance-platform/migrations/2026-05-17-add-platform-to-campaign.js +19 -0
- package/.worktrees/adperformance-platform/migrations/2026-05-17-add-platform-to-codefuelcampaign.js +19 -0
- package/.worktrees/adperformance-platform/migrations/2026-05-17-add-platform-to-dynamicfeed.js +19 -0
- package/.worktrees/adperformance-platform/migrations/2026-05-17-add-platform-to-facebookretryqueue.js +19 -0
- package/.worktrees/adperformance-platform/migrations/2026-05-17-add-platform-to-pages.js +19 -0
- package/.worktrees/adperformance-platform/migrations/2026-05-17-add-platform-to-presets.js +19 -0
- package/.worktrees/adperformance-platform/migrations/2026-05-18-add-platform-date-index-to-adperformance.js +16 -0
- package/.worktrees/adperformance-platform/migrations/RUN_ME_MANUALLY_2026-05-17.sql +99 -0
- package/.worktrees/adperformance-platform/migrations/add-requested-from-dashboard-to-articles.js +17 -0
- package/.worktrees/adperformance-platform/migrations/change-adset-name-to-text.js +79 -0
- package/.worktrees/adperformance-platform/models/AICampaignQueue.js +144 -0
- package/.worktrees/adperformance-platform/models/AIGenerationLog.js +85 -0
- package/.worktrees/adperformance-platform/models/AIGenerationRequest.js +212 -0
- package/.worktrees/adperformance-platform/models/ActivityHistory.js +73 -0
- package/.worktrees/adperformance-platform/models/Ad.js +300 -0
- package/.worktrees/adperformance-platform/models/AdAccount.js +97 -0
- package/.worktrees/adperformance-platform/models/AdAccountValues.js +26 -0
- package/.worktrees/adperformance-platform/models/AdHistory.js +30 -0
- package/.worktrees/adperformance-platform/models/AdPerformance.js +104 -0
- package/.worktrees/adperformance-platform/models/AdPerformanceHourly.js +71 -0
- package/.worktrees/adperformance-platform/models/AdSet.js +295 -0
- package/.worktrees/adperformance-platform/models/AdSetHistory.js +30 -0
- package/.worktrees/adperformance-platform/models/AdsetPerformance.js +132 -0
- package/.worktrees/adperformance-platform/models/AiArticleRetryQueue.js +157 -0
- package/.worktrees/adperformance-platform/models/AiCreationRetryQueue.js +127 -0
- package/.worktrees/adperformance-platform/models/Article.js +212 -0
- package/.worktrees/adperformance-platform/models/AutomationRule.js +173 -0
- package/.worktrees/adperformance-platform/models/BannerTemplate.js +129 -0
- package/.worktrees/adperformance-platform/models/Buyers.js +26 -0
- package/.worktrees/adperformance-platform/models/Campaign.js +163 -0
- package/.worktrees/adperformance-platform/models/CampaignActionHistory.js +86 -0
- package/.worktrees/adperformance-platform/models/CampaignCreationLog.js +309 -0
- package/.worktrees/adperformance-platform/models/CampaignCreationLogV2.js +314 -0
- package/.worktrees/adperformance-platform/models/CampaignHistory.js +33 -0
- package/.worktrees/adperformance-platform/models/Channel.js +55 -0
- package/.worktrees/adperformance-platform/models/CodefuelCampaign.js +175 -0
- package/.worktrees/adperformance-platform/models/CodefuelCampaignKWHistory.js +41 -0
- package/.worktrees/adperformance-platform/models/CodefuelKeywords.js +35 -0
- package/.worktrees/adperformance-platform/models/CurrencyRate.js +27 -0
- package/.worktrees/adperformance-platform/models/Domain.js +40 -0
- package/.worktrees/adperformance-platform/models/DynamicFeed.js +219 -0
- package/.worktrees/adperformance-platform/models/ExplorAdsChannel.js +62 -0
- package/.worktrees/adperformance-platform/models/FacebookRetryQueue.js +163 -0
- package/.worktrees/adperformance-platform/models/Feed.js +34 -0
- package/.worktrees/adperformance-platform/models/FeedArticleConfiguration.js +81 -0
- package/.worktrees/adperformance-platform/models/Files.js +73 -0
- package/.worktrees/adperformance-platform/models/Folders.js +133 -0
- package/.worktrees/adperformance-platform/models/FrontStoryChannel.js +60 -0
- package/.worktrees/adperformance-platform/models/FrontStoryChannelV2.js +60 -0
- package/.worktrees/adperformance-platform/models/GenericFlowRequest.js +115 -0
- package/.worktrees/adperformance-platform/models/KeywordPerformance.js +106 -0
- package/.worktrees/adperformance-platform/models/KeywordRotationState.js +51 -0
- package/.worktrees/adperformance-platform/models/MidoWebChannel.js +47 -0
- package/.worktrees/adperformance-platform/models/MineChannel.js +43 -0
- package/.worktrees/adperformance-platform/models/Pages.js +105 -0
- package/.worktrees/adperformance-platform/models/PipelineExecution.js +59 -0
- package/.worktrees/adperformance-platform/models/PolicyDogsCreativeCache.js +50 -0
- package/.worktrees/adperformance-platform/models/PolicyDogsImageCache.js +30 -0
- package/.worktrees/adperformance-platform/models/Presets.js +40 -0
- package/.worktrees/adperformance-platform/models/RSOCFeedCampaign.js +375 -0
- package/.worktrees/adperformance-platform/models/RsocKeywordPerformance.js +111 -0
- package/.worktrees/adperformance-platform/models/RuleAction.js +90 -0
- package/.worktrees/adperformance-platform/models/RuleCondition.js +137 -0
- package/.worktrees/adperformance-platform/models/RuleExecution.js +107 -0
- package/.worktrees/adperformance-platform/models/RulesValues.js +56 -0
- package/.worktrees/adperformance-platform/models/SupportedLocale.js +24 -0
- package/.worktrees/adperformance-platform/models/SyncHistory.js +250 -0
- package/.worktrees/adperformance-platform/models/TTQChannel.js +42 -0
- package/.worktrees/adperformance-platform/models/TemplateMetadata.js +260 -0
- package/.worktrees/adperformance-platform/models/Tier2_AdAccounts.js +110 -0
- package/.worktrees/adperformance-platform/models/Tier2_Assets.js +70 -0
- package/.worktrees/adperformance-platform/models/Tier2_BusinessManagers.js +105 -0
- package/.worktrees/adperformance-platform/models/Tier2_CreditLines.js +99 -0
- package/.worktrees/adperformance-platform/models/Tier2_Pages.js +91 -0
- package/.worktrees/adperformance-platform/models/Tier2_Pixels.js +82 -0
- package/.worktrees/adperformance-platform/models/Tier2_Tokens.js +64 -0
- package/.worktrees/adperformance-platform/models/Tier2_UserAdAccounts.js +83 -0
- package/.worktrees/adperformance-platform/models/TokenRotationState.js +121 -0
- package/.worktrees/adperformance-platform/models/TonicCampaign.js +97 -0
- package/.worktrees/adperformance-platform/models/TonicRSOCKeywordPerformance.js +123 -0
- package/.worktrees/adperformance-platform/models/Users.js +148 -0
- package/.worktrees/adperformance-platform/models/Vertical.js +26 -0
- package/.worktrees/adperformance-platform/models/newFiles.js +137 -0
- package/.worktrees/adperformance-platform/models/pixel.js +47 -0
- package/.worktrees/adperformance-platform/package-lock.json +405 -0
- package/.worktrees/adperformance-platform/package.json +19 -0
- package/.worktrees/adperformance-platform/run.ps1 +98 -0
- package/.worktrees/adperformance-platform/run.sh +214 -0
- package/.worktrees/adperformance-platform/services/sequelizeService.js +110 -0
- package/.worktrees/adsetperformance-platform/LICENSE +21 -0
- package/.worktrees/adsetperformance-platform/README.md +179 -0
- package/.worktrees/adsetperformance-platform/index.js +169 -0
- package/.worktrees/adsetperformance-platform/jq.exe +0 -0
- package/.worktrees/adsetperformance-platform/migrations/2026-05-17-PIXELS-FOLLOWUP.md +85 -0
- package/.worktrees/adsetperformance-platform/migrations/2026-05-17-add-platform-to-ad.js +19 -0
- package/.worktrees/adsetperformance-platform/migrations/2026-05-17-add-platform-to-adaccount.js +19 -0
- package/.worktrees/adsetperformance-platform/migrations/2026-05-17-add-platform-to-adperformance.js +19 -0
- package/.worktrees/adsetperformance-platform/migrations/2026-05-17-add-platform-to-adset.js +19 -0
- package/.worktrees/adsetperformance-platform/migrations/2026-05-17-add-platform-to-adsetperformance.js +19 -0
- package/.worktrees/adsetperformance-platform/migrations/2026-05-17-add-platform-to-aiarticleretryqueue.js +19 -0
- package/.worktrees/adsetperformance-platform/migrations/2026-05-17-add-platform-to-aicampaignqueue.js +19 -0
- package/.worktrees/adsetperformance-platform/migrations/2026-05-17-add-platform-to-article.js +19 -0
- package/.worktrees/adsetperformance-platform/migrations/2026-05-17-add-platform-to-campaign.js +19 -0
- package/.worktrees/adsetperformance-platform/migrations/2026-05-17-add-platform-to-codefuelcampaign.js +19 -0
- package/.worktrees/adsetperformance-platform/migrations/2026-05-17-add-platform-to-dynamicfeed.js +19 -0
- package/.worktrees/adsetperformance-platform/migrations/2026-05-17-add-platform-to-facebookretryqueue.js +19 -0
- package/.worktrees/adsetperformance-platform/migrations/2026-05-17-add-platform-to-pages.js +19 -0
- package/.worktrees/adsetperformance-platform/migrations/2026-05-17-add-platform-to-presets.js +19 -0
- package/.worktrees/adsetperformance-platform/migrations/2026-05-18-add-platform-date-index-to-adsetperformance.js +16 -0
- package/.worktrees/adsetperformance-platform/migrations/RUN_ME_MANUALLY_2026-05-17.sql +99 -0
- package/.worktrees/adsetperformance-platform/migrations/add-requested-from-dashboard-to-articles.js +17 -0
- package/.worktrees/adsetperformance-platform/migrations/change-adset-name-to-text.js +79 -0
- package/.worktrees/adsetperformance-platform/models/AICampaignQueue.js +144 -0
- package/.worktrees/adsetperformance-platform/models/AIGenerationLog.js +85 -0
- package/.worktrees/adsetperformance-platform/models/AIGenerationRequest.js +212 -0
- package/.worktrees/adsetperformance-platform/models/ActivityHistory.js +73 -0
- package/.worktrees/adsetperformance-platform/models/Ad.js +300 -0
- package/.worktrees/adsetperformance-platform/models/AdAccount.js +97 -0
- package/.worktrees/adsetperformance-platform/models/AdAccountValues.js +26 -0
- package/.worktrees/adsetperformance-platform/models/AdHistory.js +30 -0
- package/.worktrees/adsetperformance-platform/models/AdPerformance.js +100 -0
- package/.worktrees/adsetperformance-platform/models/AdPerformanceHourly.js +71 -0
- package/.worktrees/adsetperformance-platform/models/AdSet.js +295 -0
- package/.worktrees/adsetperformance-platform/models/AdSetHistory.js +30 -0
- package/.worktrees/adsetperformance-platform/models/AdsetPerformance.js +137 -0
- package/.worktrees/adsetperformance-platform/models/AiArticleRetryQueue.js +157 -0
- package/.worktrees/adsetperformance-platform/models/AiCreationRetryQueue.js +127 -0
- package/.worktrees/adsetperformance-platform/models/ApiAuditLog.js +84 -0
- package/.worktrees/adsetperformance-platform/models/ApiToken.js +67 -0
- package/.worktrees/adsetperformance-platform/models/Article.js +212 -0
- package/.worktrees/adsetperformance-platform/models/AutomationRule.js +173 -0
- package/.worktrees/adsetperformance-platform/models/BannerTemplate.js +129 -0
- package/.worktrees/adsetperformance-platform/models/Buyers.js +26 -0
- package/.worktrees/adsetperformance-platform/models/Campaign.js +163 -0
- package/.worktrees/adsetperformance-platform/models/CampaignActionHistory.js +86 -0
- package/.worktrees/adsetperformance-platform/models/CampaignCreationLog.js +309 -0
- package/.worktrees/adsetperformance-platform/models/CampaignCreationLogV2.js +314 -0
- package/.worktrees/adsetperformance-platform/models/CampaignHistory.js +33 -0
- package/.worktrees/adsetperformance-platform/models/Channel.js +55 -0
- package/.worktrees/adsetperformance-platform/models/CodefuelCampaign.js +175 -0
- package/.worktrees/adsetperformance-platform/models/CodefuelCampaignKWHistory.js +41 -0
- package/.worktrees/adsetperformance-platform/models/CodefuelKeywords.js +35 -0
- package/.worktrees/adsetperformance-platform/models/CurrencyRate.js +27 -0
- package/.worktrees/adsetperformance-platform/models/Domain.js +40 -0
- package/.worktrees/adsetperformance-platform/models/DynamicFeed.js +219 -0
- package/.worktrees/adsetperformance-platform/models/ExplorAdsChannel.js +62 -0
- package/.worktrees/adsetperformance-platform/models/FacebookRetryQueue.js +163 -0
- package/.worktrees/adsetperformance-platform/models/Feed.js +34 -0
- package/.worktrees/adsetperformance-platform/models/FeedArticleConfiguration.js +81 -0
- package/.worktrees/adsetperformance-platform/models/Files.js +73 -0
- package/.worktrees/adsetperformance-platform/models/Folders.js +133 -0
- package/.worktrees/adsetperformance-platform/models/FrontStoryChannel.js +60 -0
- package/.worktrees/adsetperformance-platform/models/FrontStoryChannelV2.js +60 -0
- package/.worktrees/adsetperformance-platform/models/GenericFlowRequest.js +115 -0
- package/.worktrees/adsetperformance-platform/models/KeywordPerformance.js +106 -0
- package/.worktrees/adsetperformance-platform/models/KeywordRotationState.js +51 -0
- package/.worktrees/adsetperformance-platform/models/MidoWebChannel.js +47 -0
- package/.worktrees/adsetperformance-platform/models/MineChannel.js +43 -0
- package/.worktrees/adsetperformance-platform/models/Pages.js +105 -0
- package/.worktrees/adsetperformance-platform/models/PipelineExecution.js +59 -0
- package/.worktrees/adsetperformance-platform/models/PolicyDogsCreativeCache.js +50 -0
- package/.worktrees/adsetperformance-platform/models/PolicyDogsImageCache.js +30 -0
- package/.worktrees/adsetperformance-platform/models/Presets.js +40 -0
- package/.worktrees/adsetperformance-platform/models/RSOCFeedCampaign.js +375 -0
- package/.worktrees/adsetperformance-platform/models/RsocKeywordPerformance.js +111 -0
- package/.worktrees/adsetperformance-platform/models/RuleAction.js +90 -0
- package/.worktrees/adsetperformance-platform/models/RuleCondition.js +137 -0
- package/.worktrees/adsetperformance-platform/models/RuleExecution.js +107 -0
- package/.worktrees/adsetperformance-platform/models/RulesValues.js +56 -0
- package/.worktrees/adsetperformance-platform/models/SupportedLocale.js +24 -0
- package/.worktrees/adsetperformance-platform/models/SyncHistory.js +250 -0
- package/.worktrees/adsetperformance-platform/models/TTQChannel.js +42 -0
- package/.worktrees/adsetperformance-platform/models/TemplateMetadata.js +260 -0
- package/.worktrees/adsetperformance-platform/models/Tier2_AdAccounts.js +110 -0
- package/.worktrees/adsetperformance-platform/models/Tier2_Assets.js +70 -0
- package/.worktrees/adsetperformance-platform/models/Tier2_BusinessManagers.js +105 -0
- package/.worktrees/adsetperformance-platform/models/Tier2_CreditLines.js +99 -0
- package/.worktrees/adsetperformance-platform/models/Tier2_Pages.js +91 -0
- package/.worktrees/adsetperformance-platform/models/Tier2_Pixels.js +82 -0
- package/.worktrees/adsetperformance-platform/models/Tier2_Tokens.js +64 -0
- package/.worktrees/adsetperformance-platform/models/Tier2_UserAdAccounts.js +83 -0
- package/.worktrees/adsetperformance-platform/models/TokenRotationState.js +121 -0
- package/.worktrees/adsetperformance-platform/models/TonicCampaign.js +97 -0
- package/.worktrees/adsetperformance-platform/models/TonicRSOCKeywordPerformance.js +123 -0
- package/.worktrees/adsetperformance-platform/models/Users.js +148 -0
- package/.worktrees/adsetperformance-platform/models/Vertical.js +26 -0
- package/.worktrees/adsetperformance-platform/models/newFiles.js +137 -0
- package/.worktrees/adsetperformance-platform/models/pixel.js +47 -0
- package/.worktrees/adsetperformance-platform/package-lock.json +406 -0
- package/.worktrees/adsetperformance-platform/package.json +19 -0
- package/.worktrees/adsetperformance-platform/run.ps1 +98 -0
- package/.worktrees/adsetperformance-platform/run.sh +214 -0
- package/.worktrees/adsetperformance-platform/services/sequelizeService.js +110 -0
- package/.worktrees/aicampaign-queue-group-id/LICENSE +21 -0
- package/.worktrees/aicampaign-queue-group-id/README.md +179 -0
- package/.worktrees/aicampaign-queue-group-id/index.js +169 -0
- package/.worktrees/aicampaign-queue-group-id/jq.exe +0 -0
- package/.worktrees/aicampaign-queue-group-id/migrations/2026-05-17-PIXELS-FOLLOWUP.md +85 -0
- package/.worktrees/aicampaign-queue-group-id/migrations/2026-05-17-add-platform-to-ad.js +19 -0
- package/.worktrees/aicampaign-queue-group-id/migrations/2026-05-17-add-platform-to-adaccount.js +19 -0
- package/.worktrees/aicampaign-queue-group-id/migrations/2026-05-17-add-platform-to-adperformance.js +19 -0
- package/.worktrees/aicampaign-queue-group-id/migrations/2026-05-17-add-platform-to-adset.js +19 -0
- package/.worktrees/aicampaign-queue-group-id/migrations/2026-05-17-add-platform-to-adsetperformance.js +19 -0
- package/.worktrees/aicampaign-queue-group-id/migrations/2026-05-17-add-platform-to-aiarticleretryqueue.js +19 -0
- package/.worktrees/aicampaign-queue-group-id/migrations/2026-05-17-add-platform-to-aicampaignqueue.js +19 -0
- package/.worktrees/aicampaign-queue-group-id/migrations/2026-05-17-add-platform-to-article.js +19 -0
- package/.worktrees/aicampaign-queue-group-id/migrations/2026-05-17-add-platform-to-campaign.js +19 -0
- package/.worktrees/aicampaign-queue-group-id/migrations/2026-05-17-add-platform-to-codefuelcampaign.js +19 -0
- package/.worktrees/aicampaign-queue-group-id/migrations/2026-05-17-add-platform-to-dynamicfeed.js +19 -0
- package/.worktrees/aicampaign-queue-group-id/migrations/2026-05-17-add-platform-to-facebookretryqueue.js +19 -0
- package/.worktrees/aicampaign-queue-group-id/migrations/2026-05-17-add-platform-to-pages.js +19 -0
- package/.worktrees/aicampaign-queue-group-id/migrations/2026-05-17-add-platform-to-presets.js +19 -0
- package/.worktrees/aicampaign-queue-group-id/migrations/2026-05-18-add-group-id-to-ai-campaign-queue.js +18 -0
- package/.worktrees/aicampaign-queue-group-id/migrations/RUN_ME_MANUALLY_2026-05-17.sql +99 -0
- package/.worktrees/aicampaign-queue-group-id/migrations/add-requested-from-dashboard-to-articles.js +17 -0
- package/.worktrees/aicampaign-queue-group-id/migrations/change-adset-name-to-text.js +79 -0
- package/.worktrees/aicampaign-queue-group-id/models/AICampaignQueue.js +153 -0
- package/.worktrees/aicampaign-queue-group-id/models/AIGenerationLog.js +85 -0
- package/.worktrees/aicampaign-queue-group-id/models/AIGenerationRequest.js +212 -0
- package/.worktrees/aicampaign-queue-group-id/models/ActivityHistory.js +73 -0
- package/.worktrees/aicampaign-queue-group-id/models/Ad.js +300 -0
- package/.worktrees/aicampaign-queue-group-id/models/AdAccount.js +97 -0
- package/.worktrees/aicampaign-queue-group-id/models/AdAccountValues.js +26 -0
- package/.worktrees/aicampaign-queue-group-id/models/AdHistory.js +30 -0
- package/.worktrees/aicampaign-queue-group-id/models/AdPerformance.js +100 -0
- package/.worktrees/aicampaign-queue-group-id/models/AdPerformanceHourly.js +71 -0
- package/.worktrees/aicampaign-queue-group-id/models/AdSet.js +295 -0
- package/.worktrees/aicampaign-queue-group-id/models/AdSetHistory.js +30 -0
- package/.worktrees/aicampaign-queue-group-id/models/AdsetPerformance.js +132 -0
- package/.worktrees/aicampaign-queue-group-id/models/AiArticleRetryQueue.js +157 -0
- package/.worktrees/aicampaign-queue-group-id/models/AiCreationRetryQueue.js +127 -0
- package/.worktrees/aicampaign-queue-group-id/models/Article.js +212 -0
- package/.worktrees/aicampaign-queue-group-id/models/AutomationRule.js +173 -0
- package/.worktrees/aicampaign-queue-group-id/models/BannerTemplate.js +129 -0
- package/.worktrees/aicampaign-queue-group-id/models/Buyers.js +26 -0
- package/.worktrees/aicampaign-queue-group-id/models/Campaign.js +163 -0
- package/.worktrees/aicampaign-queue-group-id/models/CampaignActionHistory.js +86 -0
- package/.worktrees/aicampaign-queue-group-id/models/CampaignCreationLog.js +309 -0
- package/.worktrees/aicampaign-queue-group-id/models/CampaignCreationLogV2.js +314 -0
- package/.worktrees/aicampaign-queue-group-id/models/CampaignHistory.js +33 -0
- package/.worktrees/aicampaign-queue-group-id/models/Channel.js +55 -0
- package/.worktrees/aicampaign-queue-group-id/models/CodefuelCampaign.js +175 -0
- package/.worktrees/aicampaign-queue-group-id/models/CodefuelCampaignKWHistory.js +41 -0
- package/.worktrees/aicampaign-queue-group-id/models/CodefuelKeywords.js +35 -0
- package/.worktrees/aicampaign-queue-group-id/models/CurrencyRate.js +27 -0
- package/.worktrees/aicampaign-queue-group-id/models/Domain.js +40 -0
- package/.worktrees/aicampaign-queue-group-id/models/DynamicFeed.js +219 -0
- package/.worktrees/aicampaign-queue-group-id/models/ExplorAdsChannel.js +62 -0
- package/.worktrees/aicampaign-queue-group-id/models/FacebookRetryQueue.js +163 -0
- package/.worktrees/aicampaign-queue-group-id/models/Feed.js +34 -0
- package/.worktrees/aicampaign-queue-group-id/models/FeedArticleConfiguration.js +81 -0
- package/.worktrees/aicampaign-queue-group-id/models/Files.js +73 -0
- package/.worktrees/aicampaign-queue-group-id/models/Folders.js +133 -0
- package/.worktrees/aicampaign-queue-group-id/models/FrontStoryChannel.js +60 -0
- package/.worktrees/aicampaign-queue-group-id/models/FrontStoryChannelV2.js +60 -0
- package/.worktrees/aicampaign-queue-group-id/models/GenericFlowRequest.js +115 -0
- package/.worktrees/aicampaign-queue-group-id/models/KeywordPerformance.js +106 -0
- package/.worktrees/aicampaign-queue-group-id/models/KeywordRotationState.js +51 -0
- package/.worktrees/aicampaign-queue-group-id/models/MidoWebChannel.js +47 -0
- package/.worktrees/aicampaign-queue-group-id/models/MineChannel.js +43 -0
- package/.worktrees/aicampaign-queue-group-id/models/Pages.js +105 -0
- package/.worktrees/aicampaign-queue-group-id/models/PipelineExecution.js +59 -0
- package/.worktrees/aicampaign-queue-group-id/models/PolicyDogsCreativeCache.js +50 -0
- package/.worktrees/aicampaign-queue-group-id/models/PolicyDogsImageCache.js +30 -0
- package/.worktrees/aicampaign-queue-group-id/models/Presets.js +40 -0
- package/.worktrees/aicampaign-queue-group-id/models/RSOCFeedCampaign.js +375 -0
- package/.worktrees/aicampaign-queue-group-id/models/RsocKeywordPerformance.js +111 -0
- package/.worktrees/aicampaign-queue-group-id/models/RuleAction.js +90 -0
- package/.worktrees/aicampaign-queue-group-id/models/RuleCondition.js +137 -0
- package/.worktrees/aicampaign-queue-group-id/models/RuleExecution.js +107 -0
- package/.worktrees/aicampaign-queue-group-id/models/RulesValues.js +56 -0
- package/.worktrees/aicampaign-queue-group-id/models/SupportedLocale.js +24 -0
- package/.worktrees/aicampaign-queue-group-id/models/SyncHistory.js +250 -0
- package/.worktrees/aicampaign-queue-group-id/models/TTQChannel.js +42 -0
- package/.worktrees/aicampaign-queue-group-id/models/TemplateMetadata.js +260 -0
- package/.worktrees/aicampaign-queue-group-id/models/Tier2_AdAccounts.js +110 -0
- package/.worktrees/aicampaign-queue-group-id/models/Tier2_Assets.js +70 -0
- package/.worktrees/aicampaign-queue-group-id/models/Tier2_BusinessManagers.js +105 -0
- package/.worktrees/aicampaign-queue-group-id/models/Tier2_CreditLines.js +99 -0
- package/.worktrees/aicampaign-queue-group-id/models/Tier2_Pages.js +91 -0
- package/.worktrees/aicampaign-queue-group-id/models/Tier2_Pixels.js +82 -0
- package/.worktrees/aicampaign-queue-group-id/models/Tier2_Tokens.js +64 -0
- package/.worktrees/aicampaign-queue-group-id/models/Tier2_UserAdAccounts.js +83 -0
- package/.worktrees/aicampaign-queue-group-id/models/TokenRotationState.js +121 -0
- package/.worktrees/aicampaign-queue-group-id/models/TonicCampaign.js +97 -0
- package/.worktrees/aicampaign-queue-group-id/models/TonicRSOCKeywordPerformance.js +123 -0
- package/.worktrees/aicampaign-queue-group-id/models/Users.js +148 -0
- package/.worktrees/aicampaign-queue-group-id/models/Vertical.js +26 -0
- package/.worktrees/aicampaign-queue-group-id/models/newFiles.js +137 -0
- package/.worktrees/aicampaign-queue-group-id/models/pixel.js +47 -0
- package/.worktrees/aicampaign-queue-group-id/package-lock.json +405 -0
- package/.worktrees/aicampaign-queue-group-id/package.json +19 -0
- package/.worktrees/aicampaign-queue-group-id/run.ps1 +98 -0
- package/.worktrees/aicampaign-queue-group-id/run.sh +214 -0
- package/.worktrees/aicampaign-queue-group-id/services/sequelizeService.js +110 -0
- package/.worktrees/canonical-insights-model/LICENSE +21 -0
- package/.worktrees/canonical-insights-model/README.md +179 -0
- package/.worktrees/canonical-insights-model/index.js +169 -0
- package/.worktrees/canonical-insights-model/jq.exe +0 -0
- package/.worktrees/canonical-insights-model/migrations/2026-05-17-PIXELS-FOLLOWUP.md +85 -0
- package/.worktrees/canonical-insights-model/migrations/2026-05-17-add-platform-to-ad.js +19 -0
- package/.worktrees/canonical-insights-model/migrations/2026-05-17-add-platform-to-adaccount.js +19 -0
- package/.worktrees/canonical-insights-model/migrations/2026-05-17-add-platform-to-adperformance.js +19 -0
- package/.worktrees/canonical-insights-model/migrations/2026-05-17-add-platform-to-adset.js +19 -0
- package/.worktrees/canonical-insights-model/migrations/2026-05-17-add-platform-to-adsetperformance.js +19 -0
- package/.worktrees/canonical-insights-model/migrations/2026-05-17-add-platform-to-aiarticleretryqueue.js +19 -0
- package/.worktrees/canonical-insights-model/migrations/2026-05-17-add-platform-to-aicampaignqueue.js +19 -0
- package/.worktrees/canonical-insights-model/migrations/2026-05-17-add-platform-to-article.js +19 -0
- package/.worktrees/canonical-insights-model/migrations/2026-05-17-add-platform-to-campaign.js +19 -0
- package/.worktrees/canonical-insights-model/migrations/2026-05-17-add-platform-to-codefuelcampaign.js +19 -0
- package/.worktrees/canonical-insights-model/migrations/2026-05-17-add-platform-to-dynamicfeed.js +19 -0
- package/.worktrees/canonical-insights-model/migrations/2026-05-17-add-platform-to-facebookretryqueue.js +19 -0
- package/.worktrees/canonical-insights-model/migrations/2026-05-17-add-platform-to-pages.js +19 -0
- package/.worktrees/canonical-insights-model/migrations/2026-05-17-add-platform-to-presets.js +19 -0
- package/.worktrees/canonical-insights-model/migrations/2026-05-18-create-canonical-insights.js +84 -0
- package/.worktrees/canonical-insights-model/migrations/RUN_ME_MANUALLY_2026-05-17.sql +99 -0
- package/.worktrees/canonical-insights-model/migrations/add-requested-from-dashboard-to-articles.js +17 -0
- package/.worktrees/canonical-insights-model/migrations/change-adset-name-to-text.js +79 -0
- package/.worktrees/canonical-insights-model/models/AICampaignQueue.js +144 -0
- package/.worktrees/canonical-insights-model/models/AIGenerationLog.js +85 -0
- package/.worktrees/canonical-insights-model/models/AIGenerationRequest.js +212 -0
- package/.worktrees/canonical-insights-model/models/ActivityHistory.js +73 -0
- package/.worktrees/canonical-insights-model/models/Ad.js +300 -0
- package/.worktrees/canonical-insights-model/models/AdAccount.js +97 -0
- package/.worktrees/canonical-insights-model/models/AdAccountValues.js +26 -0
- package/.worktrees/canonical-insights-model/models/AdHistory.js +30 -0
- package/.worktrees/canonical-insights-model/models/AdPerformance.js +100 -0
- package/.worktrees/canonical-insights-model/models/AdPerformanceHourly.js +71 -0
- package/.worktrees/canonical-insights-model/models/AdSet.js +295 -0
- package/.worktrees/canonical-insights-model/models/AdSetHistory.js +30 -0
- package/.worktrees/canonical-insights-model/models/AdsetPerformance.js +132 -0
- package/.worktrees/canonical-insights-model/models/AiArticleRetryQueue.js +157 -0
- package/.worktrees/canonical-insights-model/models/AiCreationRetryQueue.js +127 -0
- package/.worktrees/canonical-insights-model/models/Article.js +212 -0
- package/.worktrees/canonical-insights-model/models/AutomationRule.js +173 -0
- package/.worktrees/canonical-insights-model/models/BannerTemplate.js +129 -0
- package/.worktrees/canonical-insights-model/models/Buyers.js +26 -0
- package/.worktrees/canonical-insights-model/models/Campaign.js +163 -0
- package/.worktrees/canonical-insights-model/models/CampaignActionHistory.js +86 -0
- package/.worktrees/canonical-insights-model/models/CampaignCreationLog.js +309 -0
- package/.worktrees/canonical-insights-model/models/CampaignCreationLogV2.js +314 -0
- package/.worktrees/canonical-insights-model/models/CampaignHistory.js +33 -0
- package/.worktrees/canonical-insights-model/models/CanonicalInsights.js +68 -0
- package/.worktrees/canonical-insights-model/models/Channel.js +55 -0
- package/.worktrees/canonical-insights-model/models/CodefuelCampaign.js +175 -0
- package/.worktrees/canonical-insights-model/models/CodefuelCampaignKWHistory.js +41 -0
- package/.worktrees/canonical-insights-model/models/CodefuelKeywords.js +35 -0
- package/.worktrees/canonical-insights-model/models/CurrencyRate.js +27 -0
- package/.worktrees/canonical-insights-model/models/Domain.js +40 -0
- package/.worktrees/canonical-insights-model/models/DynamicFeed.js +219 -0
- package/.worktrees/canonical-insights-model/models/ExplorAdsChannel.js +62 -0
- package/.worktrees/canonical-insights-model/models/FacebookRetryQueue.js +163 -0
- package/.worktrees/canonical-insights-model/models/Feed.js +34 -0
- package/.worktrees/canonical-insights-model/models/FeedArticleConfiguration.js +81 -0
- package/.worktrees/canonical-insights-model/models/Files.js +73 -0
- package/.worktrees/canonical-insights-model/models/Folders.js +133 -0
- package/.worktrees/canonical-insights-model/models/FrontStoryChannel.js +60 -0
- package/.worktrees/canonical-insights-model/models/FrontStoryChannelV2.js +60 -0
- package/.worktrees/canonical-insights-model/models/GenericFlowRequest.js +115 -0
- package/.worktrees/canonical-insights-model/models/KeywordPerformance.js +106 -0
- package/.worktrees/canonical-insights-model/models/KeywordRotationState.js +51 -0
- package/.worktrees/canonical-insights-model/models/MidoWebChannel.js +47 -0
- package/.worktrees/canonical-insights-model/models/MineChannel.js +43 -0
- package/.worktrees/canonical-insights-model/models/Pages.js +105 -0
- package/.worktrees/canonical-insights-model/models/PipelineExecution.js +59 -0
- package/.worktrees/canonical-insights-model/models/PolicyDogsCreativeCache.js +50 -0
- package/.worktrees/canonical-insights-model/models/PolicyDogsImageCache.js +30 -0
- package/.worktrees/canonical-insights-model/models/Presets.js +40 -0
- package/.worktrees/canonical-insights-model/models/RSOCFeedCampaign.js +375 -0
- package/.worktrees/canonical-insights-model/models/RsocKeywordPerformance.js +111 -0
- package/.worktrees/canonical-insights-model/models/RuleAction.js +90 -0
- package/.worktrees/canonical-insights-model/models/RuleCondition.js +137 -0
- package/.worktrees/canonical-insights-model/models/RuleExecution.js +107 -0
- package/.worktrees/canonical-insights-model/models/RulesValues.js +56 -0
- package/.worktrees/canonical-insights-model/models/SupportedLocale.js +24 -0
- package/.worktrees/canonical-insights-model/models/SyncHistory.js +250 -0
- package/.worktrees/canonical-insights-model/models/TTQChannel.js +42 -0
- package/.worktrees/canonical-insights-model/models/TemplateMetadata.js +260 -0
- package/.worktrees/canonical-insights-model/models/Tier2_AdAccounts.js +110 -0
- package/.worktrees/canonical-insights-model/models/Tier2_Assets.js +70 -0
- package/.worktrees/canonical-insights-model/models/Tier2_BusinessManagers.js +105 -0
- package/.worktrees/canonical-insights-model/models/Tier2_CreditLines.js +99 -0
- package/.worktrees/canonical-insights-model/models/Tier2_Pages.js +91 -0
- package/.worktrees/canonical-insights-model/models/Tier2_Pixels.js +82 -0
- package/.worktrees/canonical-insights-model/models/Tier2_Tokens.js +64 -0
- package/.worktrees/canonical-insights-model/models/Tier2_UserAdAccounts.js +83 -0
- package/.worktrees/canonical-insights-model/models/TokenRotationState.js +121 -0
- package/.worktrees/canonical-insights-model/models/TonicCampaign.js +97 -0
- package/.worktrees/canonical-insights-model/models/TonicRSOCKeywordPerformance.js +123 -0
- package/.worktrees/canonical-insights-model/models/Users.js +148 -0
- package/.worktrees/canonical-insights-model/models/Vertical.js +26 -0
- package/.worktrees/canonical-insights-model/models/newFiles.js +137 -0
- package/.worktrees/canonical-insights-model/models/pixel.js +47 -0
- package/.worktrees/canonical-insights-model/package-lock.json +405 -0
- package/.worktrees/canonical-insights-model/package.json +19 -0
- package/.worktrees/canonical-insights-model/run.ps1 +98 -0
- package/.worktrees/canonical-insights-model/run.sh +214 -0
- package/.worktrees/canonical-insights-model/services/sequelizeService.js +110 -0
- package/.worktrees/creation-logs-platform-code/LICENSE +21 -0
- package/.worktrees/creation-logs-platform-code/README.md +179 -0
- package/.worktrees/creation-logs-platform-code/index.js +169 -0
- package/.worktrees/creation-logs-platform-code/jq.exe +0 -0
- package/.worktrees/creation-logs-platform-code/migrations/2026-05-17-PIXELS-FOLLOWUP.md +85 -0
- package/.worktrees/creation-logs-platform-code/migrations/2026-05-17-add-platform-to-ad.js +19 -0
- package/.worktrees/creation-logs-platform-code/migrations/2026-05-17-add-platform-to-adaccount.js +19 -0
- package/.worktrees/creation-logs-platform-code/migrations/2026-05-17-add-platform-to-adperformance.js +19 -0
- package/.worktrees/creation-logs-platform-code/migrations/2026-05-17-add-platform-to-adset.js +19 -0
- package/.worktrees/creation-logs-platform-code/migrations/2026-05-17-add-platform-to-adsetperformance.js +19 -0
- package/.worktrees/creation-logs-platform-code/migrations/2026-05-17-add-platform-to-aiarticleretryqueue.js +19 -0
- package/.worktrees/creation-logs-platform-code/migrations/2026-05-17-add-platform-to-aicampaignqueue.js +19 -0
- package/.worktrees/creation-logs-platform-code/migrations/2026-05-17-add-platform-to-article.js +19 -0
- package/.worktrees/creation-logs-platform-code/migrations/2026-05-17-add-platform-to-campaign.js +19 -0
- package/.worktrees/creation-logs-platform-code/migrations/2026-05-17-add-platform-to-codefuelcampaign.js +19 -0
- package/.worktrees/creation-logs-platform-code/migrations/2026-05-17-add-platform-to-dynamicfeed.js +19 -0
- package/.worktrees/creation-logs-platform-code/migrations/2026-05-17-add-platform-to-facebookretryqueue.js +19 -0
- package/.worktrees/creation-logs-platform-code/migrations/2026-05-17-add-platform-to-pages.js +19 -0
- package/.worktrees/creation-logs-platform-code/migrations/2026-05-17-add-platform-to-presets.js +19 -0
- package/.worktrees/creation-logs-platform-code/migrations/2026-05-18-add-platform-code-to-creation-logs.js +65 -0
- package/.worktrees/creation-logs-platform-code/migrations/RUN_ME_MANUALLY_2026-05-17.sql +99 -0
- package/.worktrees/creation-logs-platform-code/migrations/add-requested-from-dashboard-to-articles.js +17 -0
- package/.worktrees/creation-logs-platform-code/migrations/change-adset-name-to-text.js +79 -0
- package/.worktrees/creation-logs-platform-code/models/AICampaignQueue.js +144 -0
- package/.worktrees/creation-logs-platform-code/models/AIGenerationLog.js +85 -0
- package/.worktrees/creation-logs-platform-code/models/AIGenerationRequest.js +212 -0
- package/.worktrees/creation-logs-platform-code/models/ActivityHistory.js +73 -0
- package/.worktrees/creation-logs-platform-code/models/Ad.js +300 -0
- package/.worktrees/creation-logs-platform-code/models/AdAccount.js +97 -0
- package/.worktrees/creation-logs-platform-code/models/AdAccountValues.js +26 -0
- package/.worktrees/creation-logs-platform-code/models/AdHistory.js +30 -0
- package/.worktrees/creation-logs-platform-code/models/AdPerformance.js +100 -0
- package/.worktrees/creation-logs-platform-code/models/AdPerformanceHourly.js +71 -0
- package/.worktrees/creation-logs-platform-code/models/AdSet.js +295 -0
- package/.worktrees/creation-logs-platform-code/models/AdSetHistory.js +30 -0
- package/.worktrees/creation-logs-platform-code/models/AdsetPerformance.js +132 -0
- package/.worktrees/creation-logs-platform-code/models/AiArticleRetryQueue.js +157 -0
- package/.worktrees/creation-logs-platform-code/models/AiCreationRetryQueue.js +127 -0
- package/.worktrees/creation-logs-platform-code/models/Article.js +212 -0
- package/.worktrees/creation-logs-platform-code/models/AutomationRule.js +173 -0
- package/.worktrees/creation-logs-platform-code/models/BannerTemplate.js +129 -0
- package/.worktrees/creation-logs-platform-code/models/Buyers.js +26 -0
- package/.worktrees/creation-logs-platform-code/models/Campaign.js +163 -0
- package/.worktrees/creation-logs-platform-code/models/CampaignActionHistory.js +86 -0
- package/.worktrees/creation-logs-platform-code/models/CampaignCreationLog.js +321 -0
- package/.worktrees/creation-logs-platform-code/models/CampaignCreationLogV2.js +322 -0
- package/.worktrees/creation-logs-platform-code/models/CampaignHistory.js +33 -0
- package/.worktrees/creation-logs-platform-code/models/Channel.js +55 -0
- package/.worktrees/creation-logs-platform-code/models/CodefuelCampaign.js +175 -0
- package/.worktrees/creation-logs-platform-code/models/CodefuelCampaignKWHistory.js +41 -0
- package/.worktrees/creation-logs-platform-code/models/CodefuelKeywords.js +35 -0
- package/.worktrees/creation-logs-platform-code/models/CurrencyRate.js +27 -0
- package/.worktrees/creation-logs-platform-code/models/Domain.js +40 -0
- package/.worktrees/creation-logs-platform-code/models/DynamicFeed.js +219 -0
- package/.worktrees/creation-logs-platform-code/models/ExplorAdsChannel.js +62 -0
- package/.worktrees/creation-logs-platform-code/models/FacebookRetryQueue.js +163 -0
- package/.worktrees/creation-logs-platform-code/models/Feed.js +34 -0
- package/.worktrees/creation-logs-platform-code/models/FeedArticleConfiguration.js +81 -0
- package/.worktrees/creation-logs-platform-code/models/Files.js +73 -0
- package/.worktrees/creation-logs-platform-code/models/Folders.js +133 -0
- package/.worktrees/creation-logs-platform-code/models/FrontStoryChannel.js +60 -0
- package/.worktrees/creation-logs-platform-code/models/FrontStoryChannelV2.js +60 -0
- package/.worktrees/creation-logs-platform-code/models/GenericFlowRequest.js +115 -0
- package/.worktrees/creation-logs-platform-code/models/KeywordPerformance.js +106 -0
- package/.worktrees/creation-logs-platform-code/models/KeywordRotationState.js +51 -0
- package/.worktrees/creation-logs-platform-code/models/MidoWebChannel.js +47 -0
- package/.worktrees/creation-logs-platform-code/models/MineChannel.js +43 -0
- package/.worktrees/creation-logs-platform-code/models/Pages.js +105 -0
- package/.worktrees/creation-logs-platform-code/models/PipelineExecution.js +59 -0
- package/.worktrees/creation-logs-platform-code/models/PolicyDogsCreativeCache.js +50 -0
- package/.worktrees/creation-logs-platform-code/models/PolicyDogsImageCache.js +30 -0
- package/.worktrees/creation-logs-platform-code/models/Presets.js +40 -0
- package/.worktrees/creation-logs-platform-code/models/RSOCFeedCampaign.js +375 -0
- package/.worktrees/creation-logs-platform-code/models/RsocKeywordPerformance.js +111 -0
- package/.worktrees/creation-logs-platform-code/models/RuleAction.js +90 -0
- package/.worktrees/creation-logs-platform-code/models/RuleCondition.js +137 -0
- package/.worktrees/creation-logs-platform-code/models/RuleExecution.js +107 -0
- package/.worktrees/creation-logs-platform-code/models/RulesValues.js +56 -0
- package/.worktrees/creation-logs-platform-code/models/SupportedLocale.js +24 -0
- package/.worktrees/creation-logs-platform-code/models/SyncHistory.js +250 -0
- package/.worktrees/creation-logs-platform-code/models/TTQChannel.js +42 -0
- package/.worktrees/creation-logs-platform-code/models/TemplateMetadata.js +260 -0
- package/.worktrees/creation-logs-platform-code/models/Tier2_AdAccounts.js +110 -0
- package/.worktrees/creation-logs-platform-code/models/Tier2_Assets.js +70 -0
- package/.worktrees/creation-logs-platform-code/models/Tier2_BusinessManagers.js +105 -0
- package/.worktrees/creation-logs-platform-code/models/Tier2_CreditLines.js +99 -0
- package/.worktrees/creation-logs-platform-code/models/Tier2_Pages.js +91 -0
- package/.worktrees/creation-logs-platform-code/models/Tier2_Pixels.js +82 -0
- package/.worktrees/creation-logs-platform-code/models/Tier2_Tokens.js +64 -0
- package/.worktrees/creation-logs-platform-code/models/Tier2_UserAdAccounts.js +83 -0
- package/.worktrees/creation-logs-platform-code/models/TokenRotationState.js +121 -0
- package/.worktrees/creation-logs-platform-code/models/TonicCampaign.js +97 -0
- package/.worktrees/creation-logs-platform-code/models/TonicRSOCKeywordPerformance.js +123 -0
- package/.worktrees/creation-logs-platform-code/models/Users.js +148 -0
- package/.worktrees/creation-logs-platform-code/models/Vertical.js +26 -0
- package/.worktrees/creation-logs-platform-code/models/newFiles.js +137 -0
- package/.worktrees/creation-logs-platform-code/models/pixel.js +47 -0
- package/.worktrees/creation-logs-platform-code/package-lock.json +405 -0
- package/.worktrees/creation-logs-platform-code/package.json +19 -0
- package/.worktrees/creation-logs-platform-code/run.ps1 +98 -0
- package/.worktrees/creation-logs-platform-code/run.sh +214 -0
- package/.worktrees/creation-logs-platform-code/services/sequelizeService.js +110 -0
- package/.worktrees/pixels-platform-code/LICENSE +21 -0
- package/.worktrees/pixels-platform-code/README.md +179 -0
- package/.worktrees/pixels-platform-code/index.js +169 -0
- package/.worktrees/pixels-platform-code/jq.exe +0 -0
- package/.worktrees/pixels-platform-code/migrations/2026-05-17-PIXELS-FOLLOWUP.md +85 -0
- package/.worktrees/pixels-platform-code/migrations/2026-05-17-add-platform-to-ad.js +19 -0
- package/.worktrees/pixels-platform-code/migrations/2026-05-17-add-platform-to-adaccount.js +19 -0
- package/.worktrees/pixels-platform-code/migrations/2026-05-17-add-platform-to-adperformance.js +19 -0
- package/.worktrees/pixels-platform-code/migrations/2026-05-17-add-platform-to-adset.js +19 -0
- package/.worktrees/pixels-platform-code/migrations/2026-05-17-add-platform-to-adsetperformance.js +19 -0
- package/.worktrees/pixels-platform-code/migrations/2026-05-17-add-platform-to-aiarticleretryqueue.js +19 -0
- package/.worktrees/pixels-platform-code/migrations/2026-05-17-add-platform-to-aicampaignqueue.js +19 -0
- package/.worktrees/pixels-platform-code/migrations/2026-05-17-add-platform-to-article.js +19 -0
- package/.worktrees/pixels-platform-code/migrations/2026-05-17-add-platform-to-campaign.js +19 -0
- package/.worktrees/pixels-platform-code/migrations/2026-05-17-add-platform-to-codefuelcampaign.js +19 -0
- package/.worktrees/pixels-platform-code/migrations/2026-05-17-add-platform-to-dynamicfeed.js +19 -0
- package/.worktrees/pixels-platform-code/migrations/2026-05-17-add-platform-to-facebookretryqueue.js +19 -0
- package/.worktrees/pixels-platform-code/migrations/2026-05-17-add-platform-to-pages.js +19 -0
- package/.worktrees/pixels-platform-code/migrations/2026-05-17-add-platform-to-presets.js +19 -0
- package/.worktrees/pixels-platform-code/migrations/2026-05-18-add-platform-code-to-pixels.js +55 -0
- package/.worktrees/pixels-platform-code/migrations/RUN_ME_MANUALLY_2026-05-17.sql +99 -0
- package/.worktrees/pixels-platform-code/migrations/add-requested-from-dashboard-to-articles.js +17 -0
- package/.worktrees/pixels-platform-code/migrations/change-adset-name-to-text.js +79 -0
- package/.worktrees/pixels-platform-code/models/AICampaignQueue.js +144 -0
- package/.worktrees/pixels-platform-code/models/AIGenerationLog.js +85 -0
- package/.worktrees/pixels-platform-code/models/AIGenerationRequest.js +212 -0
- package/.worktrees/pixels-platform-code/models/ActivityHistory.js +73 -0
- package/.worktrees/pixels-platform-code/models/Ad.js +300 -0
- package/.worktrees/pixels-platform-code/models/AdAccount.js +97 -0
- package/.worktrees/pixels-platform-code/models/AdAccountValues.js +26 -0
- package/.worktrees/pixels-platform-code/models/AdHistory.js +30 -0
- package/.worktrees/pixels-platform-code/models/AdPerformance.js +100 -0
- package/.worktrees/pixels-platform-code/models/AdPerformanceHourly.js +71 -0
- package/.worktrees/pixels-platform-code/models/AdSet.js +295 -0
- package/.worktrees/pixels-platform-code/models/AdSetHistory.js +30 -0
- package/.worktrees/pixels-platform-code/models/AdsetPerformance.js +132 -0
- package/.worktrees/pixels-platform-code/models/AiArticleRetryQueue.js +157 -0
- package/.worktrees/pixels-platform-code/models/AiCreationRetryQueue.js +127 -0
- package/.worktrees/pixels-platform-code/models/Article.js +212 -0
- package/.worktrees/pixels-platform-code/models/AutomationRule.js +173 -0
- package/.worktrees/pixels-platform-code/models/BannerTemplate.js +129 -0
- package/.worktrees/pixels-platform-code/models/Buyers.js +26 -0
- package/.worktrees/pixels-platform-code/models/Campaign.js +163 -0
- package/.worktrees/pixels-platform-code/models/CampaignActionHistory.js +86 -0
- package/.worktrees/pixels-platform-code/models/CampaignCreationLog.js +309 -0
- package/.worktrees/pixels-platform-code/models/CampaignCreationLogV2.js +314 -0
- package/.worktrees/pixels-platform-code/models/CampaignHistory.js +33 -0
- package/.worktrees/pixels-platform-code/models/Channel.js +55 -0
- package/.worktrees/pixels-platform-code/models/CodefuelCampaign.js +175 -0
- package/.worktrees/pixels-platform-code/models/CodefuelCampaignKWHistory.js +41 -0
- package/.worktrees/pixels-platform-code/models/CodefuelKeywords.js +35 -0
- package/.worktrees/pixels-platform-code/models/CurrencyRate.js +27 -0
- package/.worktrees/pixels-platform-code/models/Domain.js +40 -0
- package/.worktrees/pixels-platform-code/models/DynamicFeed.js +219 -0
- package/.worktrees/pixels-platform-code/models/ExplorAdsChannel.js +62 -0
- package/.worktrees/pixels-platform-code/models/FacebookRetryQueue.js +163 -0
- package/.worktrees/pixels-platform-code/models/Feed.js +34 -0
- package/.worktrees/pixels-platform-code/models/FeedArticleConfiguration.js +81 -0
- package/.worktrees/pixels-platform-code/models/Files.js +73 -0
- package/.worktrees/pixels-platform-code/models/Folders.js +133 -0
- package/.worktrees/pixels-platform-code/models/FrontStoryChannel.js +60 -0
- package/.worktrees/pixels-platform-code/models/FrontStoryChannelV2.js +60 -0
- package/.worktrees/pixels-platform-code/models/GenericFlowRequest.js +115 -0
- package/.worktrees/pixels-platform-code/models/KeywordPerformance.js +106 -0
- package/.worktrees/pixels-platform-code/models/KeywordRotationState.js +51 -0
- package/.worktrees/pixels-platform-code/models/MidoWebChannel.js +47 -0
- package/.worktrees/pixels-platform-code/models/MineChannel.js +43 -0
- package/.worktrees/pixels-platform-code/models/Pages.js +105 -0
- package/.worktrees/pixels-platform-code/models/PipelineExecution.js +59 -0
- package/.worktrees/pixels-platform-code/models/PolicyDogsCreativeCache.js +50 -0
- package/.worktrees/pixels-platform-code/models/PolicyDogsImageCache.js +30 -0
- package/.worktrees/pixels-platform-code/models/Presets.js +40 -0
- package/.worktrees/pixels-platform-code/models/RSOCFeedCampaign.js +375 -0
- package/.worktrees/pixels-platform-code/models/RsocKeywordPerformance.js +111 -0
- package/.worktrees/pixels-platform-code/models/RuleAction.js +90 -0
- package/.worktrees/pixels-platform-code/models/RuleCondition.js +137 -0
- package/.worktrees/pixels-platform-code/models/RuleExecution.js +107 -0
- package/.worktrees/pixels-platform-code/models/RulesValues.js +56 -0
- package/.worktrees/pixels-platform-code/models/SupportedLocale.js +24 -0
- package/.worktrees/pixels-platform-code/models/SyncHistory.js +250 -0
- package/.worktrees/pixels-platform-code/models/TTQChannel.js +42 -0
- package/.worktrees/pixels-platform-code/models/TemplateMetadata.js +260 -0
- package/.worktrees/pixels-platform-code/models/Tier2_AdAccounts.js +110 -0
- package/.worktrees/pixels-platform-code/models/Tier2_Assets.js +70 -0
- package/.worktrees/pixels-platform-code/models/Tier2_BusinessManagers.js +105 -0
- package/.worktrees/pixels-platform-code/models/Tier2_CreditLines.js +99 -0
- package/.worktrees/pixels-platform-code/models/Tier2_Pages.js +91 -0
- package/.worktrees/pixels-platform-code/models/Tier2_Pixels.js +82 -0
- package/.worktrees/pixels-platform-code/models/Tier2_Tokens.js +64 -0
- package/.worktrees/pixels-platform-code/models/Tier2_UserAdAccounts.js +83 -0
- package/.worktrees/pixels-platform-code/models/TokenRotationState.js +121 -0
- package/.worktrees/pixels-platform-code/models/TonicCampaign.js +97 -0
- package/.worktrees/pixels-platform-code/models/TonicRSOCKeywordPerformance.js +123 -0
- package/.worktrees/pixels-platform-code/models/Users.js +148 -0
- package/.worktrees/pixels-platform-code/models/Vertical.js +26 -0
- package/.worktrees/pixels-platform-code/models/newFiles.js +137 -0
- package/.worktrees/pixels-platform-code/models/pixel.js +53 -0
- package/.worktrees/pixels-platform-code/package-lock.json +405 -0
- package/.worktrees/pixels-platform-code/package.json +19 -0
- package/.worktrees/pixels-platform-code/run.ps1 +98 -0
- package/.worktrees/pixels-platform-code/run.sh +214 -0
- package/.worktrees/pixels-platform-code/services/sequelizeService.js +110 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/LICENSE +21 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/README.md +179 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/index.js +169 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/jq.exe +0 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/migrations/2026-05-17-PIXELS-FOLLOWUP.md +85 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/migrations/2026-05-17-add-platform-to-ad.js +19 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/migrations/2026-05-17-add-platform-to-adaccount.js +19 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/migrations/2026-05-17-add-platform-to-adperformance.js +19 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/migrations/2026-05-17-add-platform-to-adset.js +19 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/migrations/2026-05-17-add-platform-to-adsetperformance.js +19 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/migrations/2026-05-17-add-platform-to-aiarticleretryqueue.js +19 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/migrations/2026-05-17-add-platform-to-aicampaignqueue.js +19 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/migrations/2026-05-17-add-platform-to-article.js +19 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/migrations/2026-05-17-add-platform-to-campaign.js +19 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/migrations/2026-05-17-add-platform-to-codefuelcampaign.js +19 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/migrations/2026-05-17-add-platform-to-dynamicfeed.js +19 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/migrations/2026-05-17-add-platform-to-facebookretryqueue.js +19 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/migrations/2026-05-17-add-platform-to-pages.js +19 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/migrations/2026-05-17-add-platform-to-presets.js +19 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/migrations/2026-05-18-add-platform-code-to-rsoc-feed-campaigns.js +55 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/migrations/RUN_ME_MANUALLY_2026-05-17.sql +99 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/migrations/add-requested-from-dashboard-to-articles.js +17 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/migrations/change-adset-name-to-text.js +79 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/AICampaignQueue.js +144 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/AIGenerationLog.js +85 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/AIGenerationRequest.js +212 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/ActivityHistory.js +73 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/Ad.js +300 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/AdAccount.js +97 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/AdAccountValues.js +26 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/AdHistory.js +30 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/AdPerformance.js +100 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/AdPerformanceHourly.js +71 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/AdSet.js +295 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/AdSetHistory.js +30 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/AdsetPerformance.js +132 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/AiArticleRetryQueue.js +157 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/AiCreationRetryQueue.js +127 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/Article.js +212 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/AutomationRule.js +173 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/BannerTemplate.js +129 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/Buyers.js +26 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/Campaign.js +163 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/CampaignActionHistory.js +86 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/CampaignCreationLog.js +309 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/CampaignCreationLogV2.js +314 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/CampaignHistory.js +33 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/Channel.js +55 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/CodefuelCampaign.js +175 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/CodefuelCampaignKWHistory.js +41 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/CodefuelKeywords.js +35 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/CurrencyRate.js +27 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/Domain.js +40 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/DynamicFeed.js +219 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/ExplorAdsChannel.js +62 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/FacebookRetryQueue.js +163 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/Feed.js +34 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/FeedArticleConfiguration.js +81 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/Files.js +73 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/Folders.js +133 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/FrontStoryChannel.js +60 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/FrontStoryChannelV2.js +60 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/GenericFlowRequest.js +115 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/KeywordPerformance.js +106 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/KeywordRotationState.js +51 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/MidoWebChannel.js +47 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/MineChannel.js +43 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/Pages.js +105 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/PipelineExecution.js +59 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/PolicyDogsCreativeCache.js +50 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/PolicyDogsImageCache.js +30 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/Presets.js +40 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/RSOCFeedCampaign.js +381 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/RsocKeywordPerformance.js +111 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/RuleAction.js +90 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/RuleCondition.js +137 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/RuleExecution.js +107 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/RulesValues.js +56 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/SupportedLocale.js +24 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/SyncHistory.js +250 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/TTQChannel.js +42 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/TemplateMetadata.js +260 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/Tier2_AdAccounts.js +110 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/Tier2_Assets.js +70 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/Tier2_BusinessManagers.js +105 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/Tier2_CreditLines.js +99 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/Tier2_Pages.js +91 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/Tier2_Pixels.js +82 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/Tier2_Tokens.js +64 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/Tier2_UserAdAccounts.js +83 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/TokenRotationState.js +121 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/TonicCampaign.js +97 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/TonicRSOCKeywordPerformance.js +123 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/Users.js +148 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/Vertical.js +26 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/newFiles.js +137 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/models/pixel.js +47 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/package-lock.json +405 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/package.json +19 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/run.ps1 +98 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/run.sh +214 -0
- package/.worktrees/rsoc-feed-campaigns-platform-code/services/sequelizeService.js +110 -0
- package/.worktrees/tt-snp-adset-ad-tables/LICENSE +21 -0
- package/.worktrees/tt-snp-adset-ad-tables/README.md +179 -0
- package/.worktrees/tt-snp-adset-ad-tables/index.js +169 -0
- package/.worktrees/tt-snp-adset-ad-tables/jq.exe +0 -0
- package/.worktrees/tt-snp-adset-ad-tables/migrations/2026-05-17-PIXELS-FOLLOWUP.md +85 -0
- package/.worktrees/tt-snp-adset-ad-tables/migrations/2026-05-17-add-platform-to-ad.js +19 -0
- package/.worktrees/tt-snp-adset-ad-tables/migrations/2026-05-17-add-platform-to-adaccount.js +19 -0
- package/.worktrees/tt-snp-adset-ad-tables/migrations/2026-05-17-add-platform-to-adperformance.js +19 -0
- package/.worktrees/tt-snp-adset-ad-tables/migrations/2026-05-17-add-platform-to-adset.js +19 -0
- package/.worktrees/tt-snp-adset-ad-tables/migrations/2026-05-17-add-platform-to-adsetperformance.js +19 -0
- package/.worktrees/tt-snp-adset-ad-tables/migrations/2026-05-17-add-platform-to-aiarticleretryqueue.js +19 -0
- package/.worktrees/tt-snp-adset-ad-tables/migrations/2026-05-17-add-platform-to-aicampaignqueue.js +19 -0
- package/.worktrees/tt-snp-adset-ad-tables/migrations/2026-05-17-add-platform-to-article.js +19 -0
- package/.worktrees/tt-snp-adset-ad-tables/migrations/2026-05-17-add-platform-to-campaign.js +19 -0
- package/.worktrees/tt-snp-adset-ad-tables/migrations/2026-05-17-add-platform-to-codefuelcampaign.js +19 -0
- package/.worktrees/tt-snp-adset-ad-tables/migrations/2026-05-17-add-platform-to-dynamicfeed.js +19 -0
- package/.worktrees/tt-snp-adset-ad-tables/migrations/2026-05-17-add-platform-to-facebookretryqueue.js +19 -0
- package/.worktrees/tt-snp-adset-ad-tables/migrations/2026-05-17-add-platform-to-pages.js +19 -0
- package/.worktrees/tt-snp-adset-ad-tables/migrations/2026-05-17-add-platform-to-presets.js +19 -0
- package/.worktrees/tt-snp-adset-ad-tables/migrations/2026-05-18-create-tt-snp-adset-ad-tables.js +309 -0
- package/.worktrees/tt-snp-adset-ad-tables/migrations/RUN_ME_MANUALLY_2026-05-17.sql +99 -0
- package/.worktrees/tt-snp-adset-ad-tables/migrations/add-requested-from-dashboard-to-articles.js +17 -0
- package/.worktrees/tt-snp-adset-ad-tables/migrations/change-adset-name-to-text.js +79 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/AICampaignQueue.js +144 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/AIGenerationLog.js +85 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/AIGenerationRequest.js +212 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/ActivityHistory.js +73 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/Ad.js +300 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/AdAccount.js +97 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/AdAccountValues.js +26 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/AdHistory.js +30 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/AdPerformance.js +100 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/AdPerformanceHourly.js +71 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/AdSet.js +295 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/AdSetHistory.js +30 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/AdsetPerformance.js +132 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/AiArticleRetryQueue.js +157 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/AiCreationRetryQueue.js +127 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/Article.js +212 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/AutomationRule.js +173 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/BannerTemplate.js +129 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/Buyers.js +26 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/Campaign.js +163 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/CampaignActionHistory.js +86 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/CampaignCreationLog.js +309 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/CampaignCreationLogV2.js +314 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/CampaignHistory.js +33 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/Channel.js +55 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/CodefuelCampaign.js +175 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/CodefuelCampaignKWHistory.js +41 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/CodefuelKeywords.js +35 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/CurrencyRate.js +27 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/Domain.js +40 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/DynamicFeed.js +219 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/ExplorAdsChannel.js +62 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/FacebookRetryQueue.js +163 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/Feed.js +34 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/FeedArticleConfiguration.js +81 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/Files.js +73 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/Folders.js +133 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/FrontStoryChannel.js +60 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/FrontStoryChannelV2.js +60 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/GenericFlowRequest.js +115 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/KeywordPerformance.js +106 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/KeywordRotationState.js +51 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/MidoWebChannel.js +47 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/MineChannel.js +43 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/Pages.js +105 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/PipelineExecution.js +59 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/PolicyDogsCreativeCache.js +50 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/PolicyDogsImageCache.js +30 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/Presets.js +40 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/RSOCFeedCampaign.js +375 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/RsocKeywordPerformance.js +111 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/RuleAction.js +90 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/RuleCondition.js +137 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/RuleExecution.js +107 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/RulesValues.js +56 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/SnapchatAd.js +69 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/SnapchatAdSquad.js +92 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/SupportedLocale.js +24 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/SyncHistory.js +250 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/TTQChannel.js +42 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/TemplateMetadata.js +260 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/Tier2_AdAccounts.js +110 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/Tier2_Assets.js +70 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/Tier2_BusinessManagers.js +105 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/Tier2_CreditLines.js +99 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/Tier2_Pages.js +91 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/Tier2_Pixels.js +82 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/Tier2_Tokens.js +64 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/Tier2_UserAdAccounts.js +83 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/TikTokAd.js +71 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/TikTokAdGroup.js +82 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/TokenRotationState.js +121 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/TonicCampaign.js +97 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/TonicRSOCKeywordPerformance.js +123 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/Users.js +148 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/Vertical.js +26 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/newFiles.js +137 -0
- package/.worktrees/tt-snp-adset-ad-tables/models/pixel.js +47 -0
- package/.worktrees/tt-snp-adset-ad-tables/package-lock.json +405 -0
- package/.worktrees/tt-snp-adset-ad-tables/package.json +19 -0
- package/.worktrees/tt-snp-adset-ad-tables/run.ps1 +98 -0
- package/.worktrees/tt-snp-adset-ad-tables/run.sh +214 -0
- package/.worktrees/tt-snp-adset-ad-tables/services/sequelizeService.js +110 -0
- package/.worktrees/tt-snp-asset-tables/LICENSE +21 -0
- package/.worktrees/tt-snp-asset-tables/README.md +179 -0
- package/.worktrees/tt-snp-asset-tables/index.js +169 -0
- package/.worktrees/tt-snp-asset-tables/jq.exe +0 -0
- package/.worktrees/tt-snp-asset-tables/migrations/2026-05-17-PIXELS-FOLLOWUP.md +85 -0
- package/.worktrees/tt-snp-asset-tables/migrations/2026-05-17-add-platform-to-ad.js +19 -0
- package/.worktrees/tt-snp-asset-tables/migrations/2026-05-17-add-platform-to-adaccount.js +19 -0
- package/.worktrees/tt-snp-asset-tables/migrations/2026-05-17-add-platform-to-adperformance.js +19 -0
- package/.worktrees/tt-snp-asset-tables/migrations/2026-05-17-add-platform-to-adset.js +19 -0
- package/.worktrees/tt-snp-asset-tables/migrations/2026-05-17-add-platform-to-adsetperformance.js +19 -0
- package/.worktrees/tt-snp-asset-tables/migrations/2026-05-17-add-platform-to-aiarticleretryqueue.js +19 -0
- package/.worktrees/tt-snp-asset-tables/migrations/2026-05-17-add-platform-to-aicampaignqueue.js +19 -0
- package/.worktrees/tt-snp-asset-tables/migrations/2026-05-17-add-platform-to-article.js +19 -0
- package/.worktrees/tt-snp-asset-tables/migrations/2026-05-17-add-platform-to-campaign.js +19 -0
- package/.worktrees/tt-snp-asset-tables/migrations/2026-05-17-add-platform-to-codefuelcampaign.js +19 -0
- package/.worktrees/tt-snp-asset-tables/migrations/2026-05-17-add-platform-to-dynamicfeed.js +19 -0
- package/.worktrees/tt-snp-asset-tables/migrations/2026-05-17-add-platform-to-facebookretryqueue.js +19 -0
- package/.worktrees/tt-snp-asset-tables/migrations/2026-05-17-add-platform-to-pages.js +19 -0
- package/.worktrees/tt-snp-asset-tables/migrations/2026-05-17-add-platform-to-presets.js +19 -0
- package/.worktrees/tt-snp-asset-tables/migrations/2026-05-18-create-snapchat-public-profiles.js +68 -0
- package/.worktrees/tt-snp-asset-tables/migrations/2026-05-18-create-tiktok-identities.js +71 -0
- package/.worktrees/tt-snp-asset-tables/migrations/RUN_ME_MANUALLY_2026-05-17.sql +99 -0
- package/.worktrees/tt-snp-asset-tables/migrations/add-requested-from-dashboard-to-articles.js +17 -0
- package/.worktrees/tt-snp-asset-tables/migrations/change-adset-name-to-text.js +79 -0
- package/.worktrees/tt-snp-asset-tables/models/AICampaignQueue.js +144 -0
- package/.worktrees/tt-snp-asset-tables/models/AIGenerationLog.js +85 -0
- package/.worktrees/tt-snp-asset-tables/models/AIGenerationRequest.js +212 -0
- package/.worktrees/tt-snp-asset-tables/models/ActivityHistory.js +73 -0
- package/.worktrees/tt-snp-asset-tables/models/Ad.js +300 -0
- package/.worktrees/tt-snp-asset-tables/models/AdAccount.js +97 -0
- package/.worktrees/tt-snp-asset-tables/models/AdAccountValues.js +26 -0
- package/.worktrees/tt-snp-asset-tables/models/AdHistory.js +30 -0
- package/.worktrees/tt-snp-asset-tables/models/AdPerformance.js +100 -0
- package/.worktrees/tt-snp-asset-tables/models/AdPerformanceHourly.js +71 -0
- package/.worktrees/tt-snp-asset-tables/models/AdSet.js +295 -0
- package/.worktrees/tt-snp-asset-tables/models/AdSetHistory.js +30 -0
- package/.worktrees/tt-snp-asset-tables/models/AdsetPerformance.js +132 -0
- package/.worktrees/tt-snp-asset-tables/models/AiArticleRetryQueue.js +157 -0
- package/.worktrees/tt-snp-asset-tables/models/AiCreationRetryQueue.js +127 -0
- package/.worktrees/tt-snp-asset-tables/models/Article.js +212 -0
- package/.worktrees/tt-snp-asset-tables/models/AutomationRule.js +173 -0
- package/.worktrees/tt-snp-asset-tables/models/BannerTemplate.js +129 -0
- package/.worktrees/tt-snp-asset-tables/models/Buyers.js +26 -0
- package/.worktrees/tt-snp-asset-tables/models/Campaign.js +163 -0
- package/.worktrees/tt-snp-asset-tables/models/CampaignActionHistory.js +86 -0
- package/.worktrees/tt-snp-asset-tables/models/CampaignCreationLog.js +309 -0
- package/.worktrees/tt-snp-asset-tables/models/CampaignCreationLogV2.js +314 -0
- package/.worktrees/tt-snp-asset-tables/models/CampaignHistory.js +33 -0
- package/.worktrees/tt-snp-asset-tables/models/Channel.js +55 -0
- package/.worktrees/tt-snp-asset-tables/models/CodefuelCampaign.js +175 -0
- package/.worktrees/tt-snp-asset-tables/models/CodefuelCampaignKWHistory.js +41 -0
- package/.worktrees/tt-snp-asset-tables/models/CodefuelKeywords.js +35 -0
- package/.worktrees/tt-snp-asset-tables/models/CurrencyRate.js +27 -0
- package/.worktrees/tt-snp-asset-tables/models/Domain.js +40 -0
- package/.worktrees/tt-snp-asset-tables/models/DynamicFeed.js +219 -0
- package/.worktrees/tt-snp-asset-tables/models/ExplorAdsChannel.js +62 -0
- package/.worktrees/tt-snp-asset-tables/models/FacebookRetryQueue.js +163 -0
- package/.worktrees/tt-snp-asset-tables/models/Feed.js +34 -0
- package/.worktrees/tt-snp-asset-tables/models/FeedArticleConfiguration.js +81 -0
- package/.worktrees/tt-snp-asset-tables/models/Files.js +73 -0
- package/.worktrees/tt-snp-asset-tables/models/Folders.js +133 -0
- package/.worktrees/tt-snp-asset-tables/models/FrontStoryChannel.js +60 -0
- package/.worktrees/tt-snp-asset-tables/models/FrontStoryChannelV2.js +60 -0
- package/.worktrees/tt-snp-asset-tables/models/GenericFlowRequest.js +115 -0
- package/.worktrees/tt-snp-asset-tables/models/KeywordPerformance.js +106 -0
- package/.worktrees/tt-snp-asset-tables/models/KeywordRotationState.js +51 -0
- package/.worktrees/tt-snp-asset-tables/models/MidoWebChannel.js +47 -0
- package/.worktrees/tt-snp-asset-tables/models/MineChannel.js +43 -0
- package/.worktrees/tt-snp-asset-tables/models/Pages.js +105 -0
- package/.worktrees/tt-snp-asset-tables/models/PipelineExecution.js +59 -0
- package/.worktrees/tt-snp-asset-tables/models/PolicyDogsCreativeCache.js +50 -0
- package/.worktrees/tt-snp-asset-tables/models/PolicyDogsImageCache.js +30 -0
- package/.worktrees/tt-snp-asset-tables/models/Presets.js +40 -0
- package/.worktrees/tt-snp-asset-tables/models/RSOCFeedCampaign.js +375 -0
- package/.worktrees/tt-snp-asset-tables/models/RsocKeywordPerformance.js +111 -0
- package/.worktrees/tt-snp-asset-tables/models/RuleAction.js +90 -0
- package/.worktrees/tt-snp-asset-tables/models/RuleCondition.js +137 -0
- package/.worktrees/tt-snp-asset-tables/models/RuleExecution.js +107 -0
- package/.worktrees/tt-snp-asset-tables/models/RulesValues.js +56 -0
- package/.worktrees/tt-snp-asset-tables/models/SnapchatPublicProfiles.js +47 -0
- package/.worktrees/tt-snp-asset-tables/models/SupportedLocale.js +24 -0
- package/.worktrees/tt-snp-asset-tables/models/SyncHistory.js +250 -0
- package/.worktrees/tt-snp-asset-tables/models/TTQChannel.js +42 -0
- package/.worktrees/tt-snp-asset-tables/models/TemplateMetadata.js +260 -0
- package/.worktrees/tt-snp-asset-tables/models/Tier2_AdAccounts.js +110 -0
- package/.worktrees/tt-snp-asset-tables/models/Tier2_Assets.js +70 -0
- package/.worktrees/tt-snp-asset-tables/models/Tier2_BusinessManagers.js +105 -0
- package/.worktrees/tt-snp-asset-tables/models/Tier2_CreditLines.js +99 -0
- package/.worktrees/tt-snp-asset-tables/models/Tier2_Pages.js +91 -0
- package/.worktrees/tt-snp-asset-tables/models/Tier2_Pixels.js +82 -0
- package/.worktrees/tt-snp-asset-tables/models/Tier2_Tokens.js +64 -0
- package/.worktrees/tt-snp-asset-tables/models/Tier2_UserAdAccounts.js +83 -0
- package/.worktrees/tt-snp-asset-tables/models/TiktokIdentities.js +51 -0
- package/.worktrees/tt-snp-asset-tables/models/TokenRotationState.js +121 -0
- package/.worktrees/tt-snp-asset-tables/models/TonicCampaign.js +97 -0
- package/.worktrees/tt-snp-asset-tables/models/TonicRSOCKeywordPerformance.js +123 -0
- package/.worktrees/tt-snp-asset-tables/models/Users.js +148 -0
- package/.worktrees/tt-snp-asset-tables/models/Vertical.js +26 -0
- package/.worktrees/tt-snp-asset-tables/models/newFiles.js +137 -0
- package/.worktrees/tt-snp-asset-tables/models/pixel.js +47 -0
- package/.worktrees/tt-snp-asset-tables/package-lock.json +405 -0
- package/.worktrees/tt-snp-asset-tables/package.json +19 -0
- package/.worktrees/tt-snp-asset-tables/run.ps1 +98 -0
- package/.worktrees/tt-snp-asset-tables/run.sh +214 -0
- package/.worktrees/tt-snp-asset-tables/services/sequelizeService.js +110 -0
- package/.worktrees/tt-snp-campaign-tables/LICENSE +21 -0
- package/.worktrees/tt-snp-campaign-tables/README.md +179 -0
- package/.worktrees/tt-snp-campaign-tables/index.js +169 -0
- package/.worktrees/tt-snp-campaign-tables/jq.exe +0 -0
- package/.worktrees/tt-snp-campaign-tables/migrations/2026-05-17-PIXELS-FOLLOWUP.md +85 -0
- package/.worktrees/tt-snp-campaign-tables/migrations/2026-05-17-add-platform-to-ad.js +19 -0
- package/.worktrees/tt-snp-campaign-tables/migrations/2026-05-17-add-platform-to-adaccount.js +19 -0
- package/.worktrees/tt-snp-campaign-tables/migrations/2026-05-17-add-platform-to-adperformance.js +19 -0
- package/.worktrees/tt-snp-campaign-tables/migrations/2026-05-17-add-platform-to-adset.js +19 -0
- package/.worktrees/tt-snp-campaign-tables/migrations/2026-05-17-add-platform-to-adsetperformance.js +19 -0
- package/.worktrees/tt-snp-campaign-tables/migrations/2026-05-17-add-platform-to-aiarticleretryqueue.js +19 -0
- package/.worktrees/tt-snp-campaign-tables/migrations/2026-05-17-add-platform-to-aicampaignqueue.js +19 -0
- package/.worktrees/tt-snp-campaign-tables/migrations/2026-05-17-add-platform-to-article.js +19 -0
- package/.worktrees/tt-snp-campaign-tables/migrations/2026-05-17-add-platform-to-campaign.js +19 -0
- package/.worktrees/tt-snp-campaign-tables/migrations/2026-05-17-add-platform-to-codefuelcampaign.js +19 -0
- package/.worktrees/tt-snp-campaign-tables/migrations/2026-05-17-add-platform-to-dynamicfeed.js +19 -0
- package/.worktrees/tt-snp-campaign-tables/migrations/2026-05-17-add-platform-to-facebookretryqueue.js +19 -0
- package/.worktrees/tt-snp-campaign-tables/migrations/2026-05-17-add-platform-to-pages.js +19 -0
- package/.worktrees/tt-snp-campaign-tables/migrations/2026-05-17-add-platform-to-presets.js +19 -0
- package/.worktrees/tt-snp-campaign-tables/migrations/2026-05-18-create-tiktok-snapchat-campaigns.js +143 -0
- package/.worktrees/tt-snp-campaign-tables/migrations/RUN_ME_MANUALLY_2026-05-17.sql +99 -0
- package/.worktrees/tt-snp-campaign-tables/migrations/add-requested-from-dashboard-to-articles.js +17 -0
- package/.worktrees/tt-snp-campaign-tables/migrations/change-adset-name-to-text.js +79 -0
- package/.worktrees/tt-snp-campaign-tables/models/AICampaignQueue.js +144 -0
- package/.worktrees/tt-snp-campaign-tables/models/AIGenerationLog.js +85 -0
- package/.worktrees/tt-snp-campaign-tables/models/AIGenerationRequest.js +212 -0
- package/.worktrees/tt-snp-campaign-tables/models/ActivityHistory.js +73 -0
- package/.worktrees/tt-snp-campaign-tables/models/Ad.js +300 -0
- package/.worktrees/tt-snp-campaign-tables/models/AdAccount.js +97 -0
- package/.worktrees/tt-snp-campaign-tables/models/AdAccountValues.js +26 -0
- package/.worktrees/tt-snp-campaign-tables/models/AdHistory.js +30 -0
- package/.worktrees/tt-snp-campaign-tables/models/AdPerformance.js +100 -0
- package/.worktrees/tt-snp-campaign-tables/models/AdPerformanceHourly.js +71 -0
- package/.worktrees/tt-snp-campaign-tables/models/AdSet.js +295 -0
- package/.worktrees/tt-snp-campaign-tables/models/AdSetHistory.js +30 -0
- package/.worktrees/tt-snp-campaign-tables/models/AdsetPerformance.js +132 -0
- package/.worktrees/tt-snp-campaign-tables/models/AiArticleRetryQueue.js +157 -0
- package/.worktrees/tt-snp-campaign-tables/models/AiCreationRetryQueue.js +127 -0
- package/.worktrees/tt-snp-campaign-tables/models/Article.js +212 -0
- package/.worktrees/tt-snp-campaign-tables/models/AutomationRule.js +173 -0
- package/.worktrees/tt-snp-campaign-tables/models/BannerTemplate.js +129 -0
- package/.worktrees/tt-snp-campaign-tables/models/Buyers.js +26 -0
- package/.worktrees/tt-snp-campaign-tables/models/Campaign.js +163 -0
- package/.worktrees/tt-snp-campaign-tables/models/CampaignActionHistory.js +86 -0
- package/.worktrees/tt-snp-campaign-tables/models/CampaignCreationLog.js +309 -0
- package/.worktrees/tt-snp-campaign-tables/models/CampaignCreationLogV2.js +314 -0
- package/.worktrees/tt-snp-campaign-tables/models/CampaignHistory.js +33 -0
- package/.worktrees/tt-snp-campaign-tables/models/Channel.js +55 -0
- package/.worktrees/tt-snp-campaign-tables/models/CodefuelCampaign.js +175 -0
- package/.worktrees/tt-snp-campaign-tables/models/CodefuelCampaignKWHistory.js +41 -0
- package/.worktrees/tt-snp-campaign-tables/models/CodefuelKeywords.js +35 -0
- package/.worktrees/tt-snp-campaign-tables/models/CurrencyRate.js +27 -0
- package/.worktrees/tt-snp-campaign-tables/models/Domain.js +40 -0
- package/.worktrees/tt-snp-campaign-tables/models/DynamicFeed.js +219 -0
- package/.worktrees/tt-snp-campaign-tables/models/ExplorAdsChannel.js +62 -0
- package/.worktrees/tt-snp-campaign-tables/models/FacebookRetryQueue.js +163 -0
- package/.worktrees/tt-snp-campaign-tables/models/Feed.js +34 -0
- package/.worktrees/tt-snp-campaign-tables/models/FeedArticleConfiguration.js +81 -0
- package/.worktrees/tt-snp-campaign-tables/models/Files.js +73 -0
- package/.worktrees/tt-snp-campaign-tables/models/Folders.js +133 -0
- package/.worktrees/tt-snp-campaign-tables/models/FrontStoryChannel.js +60 -0
- package/.worktrees/tt-snp-campaign-tables/models/FrontStoryChannelV2.js +60 -0
- package/.worktrees/tt-snp-campaign-tables/models/GenericFlowRequest.js +115 -0
- package/.worktrees/tt-snp-campaign-tables/models/KeywordPerformance.js +106 -0
- package/.worktrees/tt-snp-campaign-tables/models/KeywordRotationState.js +51 -0
- package/.worktrees/tt-snp-campaign-tables/models/MidoWebChannel.js +47 -0
- package/.worktrees/tt-snp-campaign-tables/models/MineChannel.js +43 -0
- package/.worktrees/tt-snp-campaign-tables/models/Pages.js +105 -0
- package/.worktrees/tt-snp-campaign-tables/models/PipelineExecution.js +59 -0
- package/.worktrees/tt-snp-campaign-tables/models/PolicyDogsCreativeCache.js +50 -0
- package/.worktrees/tt-snp-campaign-tables/models/PolicyDogsImageCache.js +30 -0
- package/.worktrees/tt-snp-campaign-tables/models/Presets.js +40 -0
- package/.worktrees/tt-snp-campaign-tables/models/RSOCFeedCampaign.js +375 -0
- package/.worktrees/tt-snp-campaign-tables/models/RsocKeywordPerformance.js +111 -0
- package/.worktrees/tt-snp-campaign-tables/models/RuleAction.js +90 -0
- package/.worktrees/tt-snp-campaign-tables/models/RuleCondition.js +137 -0
- package/.worktrees/tt-snp-campaign-tables/models/RuleExecution.js +107 -0
- package/.worktrees/tt-snp-campaign-tables/models/RulesValues.js +56 -0
- package/.worktrees/tt-snp-campaign-tables/models/SnapchatCampaign.js +69 -0
- package/.worktrees/tt-snp-campaign-tables/models/SupportedLocale.js +24 -0
- package/.worktrees/tt-snp-campaign-tables/models/SyncHistory.js +250 -0
- package/.worktrees/tt-snp-campaign-tables/models/TTQChannel.js +42 -0
- package/.worktrees/tt-snp-campaign-tables/models/TemplateMetadata.js +260 -0
- package/.worktrees/tt-snp-campaign-tables/models/Tier2_AdAccounts.js +110 -0
- package/.worktrees/tt-snp-campaign-tables/models/Tier2_Assets.js +70 -0
- package/.worktrees/tt-snp-campaign-tables/models/Tier2_BusinessManagers.js +105 -0
- package/.worktrees/tt-snp-campaign-tables/models/Tier2_CreditLines.js +99 -0
- package/.worktrees/tt-snp-campaign-tables/models/Tier2_Pages.js +91 -0
- package/.worktrees/tt-snp-campaign-tables/models/Tier2_Pixels.js +82 -0
- package/.worktrees/tt-snp-campaign-tables/models/Tier2_Tokens.js +64 -0
- package/.worktrees/tt-snp-campaign-tables/models/Tier2_UserAdAccounts.js +83 -0
- package/.worktrees/tt-snp-campaign-tables/models/TikTokCampaign.js +71 -0
- package/.worktrees/tt-snp-campaign-tables/models/TokenRotationState.js +121 -0
- package/.worktrees/tt-snp-campaign-tables/models/TonicCampaign.js +97 -0
- package/.worktrees/tt-snp-campaign-tables/models/TonicRSOCKeywordPerformance.js +123 -0
- package/.worktrees/tt-snp-campaign-tables/models/Users.js +148 -0
- package/.worktrees/tt-snp-campaign-tables/models/Vertical.js +26 -0
- package/.worktrees/tt-snp-campaign-tables/models/newFiles.js +137 -0
- package/.worktrees/tt-snp-campaign-tables/models/pixel.js +47 -0
- package/.worktrees/tt-snp-campaign-tables/package-lock.json +405 -0
- package/.worktrees/tt-snp-campaign-tables/package.json +19 -0
- package/.worktrees/tt-snp-campaign-tables/run.ps1 +98 -0
- package/.worktrees/tt-snp-campaign-tables/run.sh +214 -0
- package/.worktrees/tt-snp-campaign-tables/services/sequelizeService.js +110 -0
- package/migrations/2026-05-18-add-group-id-to-ai-campaign-queue.js +18 -0
- package/migrations/2026-05-18-add-platform-code-to-creation-logs.js +65 -0
- package/migrations/2026-05-18-add-platform-code-to-pixels.js +55 -0
- package/migrations/2026-05-18-add-platform-code-to-rsoc-feed-campaigns.js +55 -0
- package/migrations/2026-05-18-add-platform-date-index-to-adperformance.js +16 -0
- package/migrations/2026-05-18-add-platform-date-index-to-adsetperformance.js +16 -0
- package/migrations/2026-05-18-add-review-status-to-ad.js +36 -0
- package/migrations/2026-05-18-create-canonical-insights.js +84 -0
- package/migrations/2026-05-18-create-snapchat-public-profiles.js +68 -0
- package/migrations/2026-05-18-create-tiktok-identities.js +71 -0
- package/migrations/2026-05-18-create-tiktok-snapchat-campaigns.js +143 -0
- package/migrations/2026-05-18-create-tt-snp-adset-ad-tables.js +309 -0
- package/models/AICampaignQueue.js +9 -0
- package/models/Ad.js +12 -0
- package/models/AdPerformance.js +4 -0
- package/models/AdsetPerformance.js +5 -0
- package/models/CampaignCreationLog.js +12 -0
- package/models/CampaignCreationLogV2.js +8 -0
- package/models/CanonicalInsights.js +68 -0
- package/models/RSOCFeedCampaign.js +6 -0
- package/models/SnapchatAd.js +69 -0
- package/models/SnapchatAdSquad.js +92 -0
- package/models/SnapchatCampaign.js +69 -0
- package/models/SnapchatPublicProfiles.js +47 -0
- package/models/TikTokAd.js +71 -0
- package/models/TikTokAdGroup.js +82 -0
- package/models/TikTokCampaign.js +71 -0
- package/models/TiktokIdentities.js +51 -0
- package/models/pixel.js +6 -0
- package/package.json +1 -1
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
# Platform column normalization — follow-on work
|
|
2
|
+
|
|
3
|
+
## Tables skipped from the 2026-05-17 platform rollout
|
|
4
|
+
|
|
5
|
+
The following 4 tables were intentionally OMITTED from the 2026-05-17 platform-column
|
|
6
|
+
rollout because each already has a `platform` column of type VARCHAR with
|
|
7
|
+
capitalized values (e.g. "Facebook"). Adding an ENUM column with the same name
|
|
8
|
+
would either fail outright or destructively override existing data.
|
|
9
|
+
|
|
10
|
+
| Table | Existing column type | Existing values seen |
|
|
11
|
+
|--------------------------------|----------------------|--------------------------------------------------------|
|
|
12
|
+
| `Pixels` | varchar | "Facebook", "Tiktok", "Taboola", "Outbrain", "Yahoo" |
|
|
13
|
+
| `CampaignCreationLogs` | varchar(50) | "Facebook", "fb", NULL |
|
|
14
|
+
| `CampaignCreationLogsV2` | varchar(50) | "Facebook", "fb", NULL |
|
|
15
|
+
| `rsoc_feed_campaigns` | varchar | "Facebook", "fb" |
|
|
16
|
+
|
|
17
|
+
The rest of the rollout uses lowercase short codes: `fb`, `tt`, `snp`.
|
|
18
|
+
|
|
19
|
+
## Why we did not "just add another column"
|
|
20
|
+
|
|
21
|
+
A naive `addColumn("platform")` collides with the existing column name. A naive
|
|
22
|
+
`UPDATE` to lowercase the values would touch production data and is destructive.
|
|
23
|
+
Both violate the safety constraint of this rollout (additive only).
|
|
24
|
+
|
|
25
|
+
## Recommended path (separate plan)
|
|
26
|
+
|
|
27
|
+
For each of the 4 tables:
|
|
28
|
+
|
|
29
|
+
1. Add a new column `platform_code` ENUM('fb','tt','snp','tab','out','yh') NOT NULL DEFAULT 'fb'
|
|
30
|
+
2. Backfill in a single transaction. Example for Pixels:
|
|
31
|
+
```sql
|
|
32
|
+
UPDATE "Pixels" SET platform_code = CASE platform
|
|
33
|
+
WHEN 'Facebook' THEN 'fb'
|
|
34
|
+
WHEN 'Tiktok' THEN 'tt'
|
|
35
|
+
WHEN 'Taboola' THEN 'tab'
|
|
36
|
+
WHEN 'Outbrain' THEN 'out'
|
|
37
|
+
WHEN 'Yahoo' THEN 'yh'
|
|
38
|
+
ELSE 'fb'
|
|
39
|
+
END;
|
|
40
|
+
```
|
|
41
|
+
For CampaignCreationLogs / CampaignCreationLogsV2 / rsoc_feed_campaigns the
|
|
42
|
+
backfill is simpler:
|
|
43
|
+
```sql
|
|
44
|
+
UPDATE "CampaignCreationLogs" SET platform_code = CASE LOWER(COALESCE(platform, 'fb'))
|
|
45
|
+
WHEN 'facebook' THEN 'fb'
|
|
46
|
+
WHEN 'fb' THEN 'fb'
|
|
47
|
+
WHEN 'tiktok' THEN 'tt'
|
|
48
|
+
WHEN 'tt' THEN 'tt'
|
|
49
|
+
ELSE 'fb'
|
|
50
|
+
END;
|
|
51
|
+
```
|
|
52
|
+
3. Update server code to read `platform_code` for new logic; leave the legacy
|
|
53
|
+
`platform` column untouched for backward compat.
|
|
54
|
+
4. Eventually deprecate the legacy `platform` column and rename `platform_code`
|
|
55
|
+
→ `platform` once all callers have migrated. That happens in a separate,
|
|
56
|
+
later cleanup plan.
|
|
57
|
+
|
|
58
|
+
## Until then
|
|
59
|
+
|
|
60
|
+
The dashboard's platform adapter (created in the Phase 0 backend plan) MUST
|
|
61
|
+
normalize legacy `platform` values when comparing to the canonical fb/tt/snp
|
|
62
|
+
codes. Example normalizer:
|
|
63
|
+
|
|
64
|
+
```javascript
|
|
65
|
+
function normalizeLegacyPlatform(legacy) {
|
|
66
|
+
if (!legacy) return "fb";
|
|
67
|
+
const map = {
|
|
68
|
+
Facebook: "fb",
|
|
69
|
+
facebook: "fb",
|
|
70
|
+
FB: "fb",
|
|
71
|
+
fb: "fb",
|
|
72
|
+
Tiktok: "tt",
|
|
73
|
+
TikTok: "tt",
|
|
74
|
+
tiktok: "tt",
|
|
75
|
+
tt: "tt",
|
|
76
|
+
Snapchat: "snp",
|
|
77
|
+
snapchat: "snp",
|
|
78
|
+
snp: "snp",
|
|
79
|
+
Taboola: "tab",
|
|
80
|
+
Outbrain: "out",
|
|
81
|
+
Yahoo: "yh",
|
|
82
|
+
};
|
|
83
|
+
return map[legacy] || "fb";
|
|
84
|
+
}
|
|
85
|
+
```
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
module.exports = {
|
|
4
|
+
up: async (queryInterface, Sequelize) => {
|
|
5
|
+
await queryInterface.addColumn("Ad", "platform", {
|
|
6
|
+
type: Sequelize.ENUM("fb", "tt", "snp"),
|
|
7
|
+
allowNull: false,
|
|
8
|
+
defaultValue: "fb",
|
|
9
|
+
comment: "Ad platform identifier: fb=Facebook, tt=TikTok, snp=Snapchat",
|
|
10
|
+
});
|
|
11
|
+
},
|
|
12
|
+
|
|
13
|
+
down: async (queryInterface, Sequelize) => {
|
|
14
|
+
await queryInterface.removeColumn("Ad", "platform");
|
|
15
|
+
await queryInterface.sequelize.query(
|
|
16
|
+
'DROP TYPE IF EXISTS "enum_Ad_platform";'
|
|
17
|
+
);
|
|
18
|
+
},
|
|
19
|
+
};
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
module.exports = {
|
|
4
|
+
up: async (queryInterface, Sequelize) => {
|
|
5
|
+
await queryInterface.addColumn("AdAccount", "platform", {
|
|
6
|
+
type: Sequelize.ENUM("fb", "tt", "snp"),
|
|
7
|
+
allowNull: false,
|
|
8
|
+
defaultValue: "fb",
|
|
9
|
+
comment: "Ad platform identifier: fb=Facebook, tt=TikTok, snp=Snapchat",
|
|
10
|
+
});
|
|
11
|
+
},
|
|
12
|
+
|
|
13
|
+
down: async (queryInterface, Sequelize) => {
|
|
14
|
+
await queryInterface.removeColumn("AdAccount", "platform");
|
|
15
|
+
await queryInterface.sequelize.query(
|
|
16
|
+
'DROP TYPE IF EXISTS "enum_AdAccount_platform";'
|
|
17
|
+
);
|
|
18
|
+
},
|
|
19
|
+
};
|
package/.worktrees/adperformance-platform/migrations/2026-05-17-add-platform-to-adperformance.js
ADDED
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
module.exports = {
|
|
4
|
+
up: async (queryInterface, Sequelize) => {
|
|
5
|
+
await queryInterface.addColumn("AdPerformance", "platform", {
|
|
6
|
+
type: Sequelize.ENUM("fb", "tt", "snp"),
|
|
7
|
+
allowNull: false,
|
|
8
|
+
defaultValue: "fb",
|
|
9
|
+
comment: "Ad platform identifier: fb=Facebook, tt=TikTok, snp=Snapchat",
|
|
10
|
+
});
|
|
11
|
+
},
|
|
12
|
+
|
|
13
|
+
down: async (queryInterface, Sequelize) => {
|
|
14
|
+
await queryInterface.removeColumn("AdPerformance", "platform");
|
|
15
|
+
await queryInterface.sequelize.query(
|
|
16
|
+
'DROP TYPE IF EXISTS "enum_AdPerformance_platform";'
|
|
17
|
+
);
|
|
18
|
+
},
|
|
19
|
+
};
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
module.exports = {
|
|
4
|
+
up: async (queryInterface, Sequelize) => {
|
|
5
|
+
await queryInterface.addColumn("AdSet", "platform", {
|
|
6
|
+
type: Sequelize.ENUM("fb", "tt", "snp"),
|
|
7
|
+
allowNull: false,
|
|
8
|
+
defaultValue: "fb",
|
|
9
|
+
comment: "Ad platform identifier: fb=Facebook, tt=TikTok, snp=Snapchat",
|
|
10
|
+
});
|
|
11
|
+
},
|
|
12
|
+
|
|
13
|
+
down: async (queryInterface, Sequelize) => {
|
|
14
|
+
await queryInterface.removeColumn("AdSet", "platform");
|
|
15
|
+
await queryInterface.sequelize.query(
|
|
16
|
+
'DROP TYPE IF EXISTS "enum_AdSet_platform";'
|
|
17
|
+
);
|
|
18
|
+
},
|
|
19
|
+
};
|
package/.worktrees/adperformance-platform/migrations/2026-05-17-add-platform-to-adsetperformance.js
ADDED
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
module.exports = {
|
|
4
|
+
up: async (queryInterface, Sequelize) => {
|
|
5
|
+
await queryInterface.addColumn("AdSetPerformance", "platform", {
|
|
6
|
+
type: Sequelize.ENUM("fb", "tt", "snp"),
|
|
7
|
+
allowNull: false,
|
|
8
|
+
defaultValue: "fb",
|
|
9
|
+
comment: "Ad platform identifier: fb=Facebook, tt=TikTok, snp=Snapchat",
|
|
10
|
+
});
|
|
11
|
+
},
|
|
12
|
+
|
|
13
|
+
down: async (queryInterface, Sequelize) => {
|
|
14
|
+
await queryInterface.removeColumn("AdSetPerformance", "platform");
|
|
15
|
+
await queryInterface.sequelize.query(
|
|
16
|
+
'DROP TYPE IF EXISTS "enum_AdSetPerformance_platform";'
|
|
17
|
+
);
|
|
18
|
+
},
|
|
19
|
+
};
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
module.exports = {
|
|
4
|
+
up: async (queryInterface, Sequelize) => {
|
|
5
|
+
await queryInterface.addColumn("ai_article_retry_queue", "platform", {
|
|
6
|
+
type: Sequelize.ENUM("fb", "tt", "snp"),
|
|
7
|
+
allowNull: false,
|
|
8
|
+
defaultValue: "fb",
|
|
9
|
+
comment: "Ad platform identifier: fb=Facebook, tt=TikTok, snp=Snapchat",
|
|
10
|
+
});
|
|
11
|
+
},
|
|
12
|
+
|
|
13
|
+
down: async (queryInterface, Sequelize) => {
|
|
14
|
+
await queryInterface.removeColumn("ai_article_retry_queue", "platform");
|
|
15
|
+
await queryInterface.sequelize.query(
|
|
16
|
+
'DROP TYPE IF EXISTS "enum_ai_article_retry_queue_platform";'
|
|
17
|
+
);
|
|
18
|
+
},
|
|
19
|
+
};
|
package/.worktrees/adperformance-platform/migrations/2026-05-17-add-platform-to-aicampaignqueue.js
ADDED
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
module.exports = {
|
|
4
|
+
up: async (queryInterface, Sequelize) => {
|
|
5
|
+
await queryInterface.addColumn("ai_campaign_queue", "platform", {
|
|
6
|
+
type: Sequelize.ENUM("fb", "tt", "snp"),
|
|
7
|
+
allowNull: false,
|
|
8
|
+
defaultValue: "fb",
|
|
9
|
+
comment: "Ad platform identifier: fb=Facebook, tt=TikTok, snp=Snapchat",
|
|
10
|
+
});
|
|
11
|
+
},
|
|
12
|
+
|
|
13
|
+
down: async (queryInterface, Sequelize) => {
|
|
14
|
+
await queryInterface.removeColumn("ai_campaign_queue", "platform");
|
|
15
|
+
await queryInterface.sequelize.query(
|
|
16
|
+
'DROP TYPE IF EXISTS "enum_ai_campaign_queue_platform";'
|
|
17
|
+
);
|
|
18
|
+
},
|
|
19
|
+
};
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
module.exports = {
|
|
4
|
+
up: async (queryInterface, Sequelize) => {
|
|
5
|
+
await queryInterface.addColumn("articles", "platform", {
|
|
6
|
+
type: Sequelize.ENUM("fb", "tt", "snp"),
|
|
7
|
+
allowNull: false,
|
|
8
|
+
defaultValue: "fb",
|
|
9
|
+
comment: "Ad platform identifier: fb=Facebook, tt=TikTok, snp=Snapchat",
|
|
10
|
+
});
|
|
11
|
+
},
|
|
12
|
+
|
|
13
|
+
down: async (queryInterface, Sequelize) => {
|
|
14
|
+
await queryInterface.removeColumn("articles", "platform");
|
|
15
|
+
await queryInterface.sequelize.query(
|
|
16
|
+
'DROP TYPE IF EXISTS "enum_articles_platform";'
|
|
17
|
+
);
|
|
18
|
+
},
|
|
19
|
+
};
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
module.exports = {
|
|
4
|
+
up: async (queryInterface, Sequelize) => {
|
|
5
|
+
await queryInterface.addColumn("Campaign", "platform", {
|
|
6
|
+
type: Sequelize.ENUM("fb", "tt", "snp"),
|
|
7
|
+
allowNull: false,
|
|
8
|
+
defaultValue: "fb",
|
|
9
|
+
comment: "Ad platform identifier: fb=Facebook, tt=TikTok, snp=Snapchat",
|
|
10
|
+
});
|
|
11
|
+
},
|
|
12
|
+
|
|
13
|
+
down: async (queryInterface, Sequelize) => {
|
|
14
|
+
await queryInterface.removeColumn("Campaign", "platform");
|
|
15
|
+
await queryInterface.sequelize.query(
|
|
16
|
+
'DROP TYPE IF EXISTS "enum_Campaign_platform";'
|
|
17
|
+
);
|
|
18
|
+
},
|
|
19
|
+
};
|
package/.worktrees/adperformance-platform/migrations/2026-05-17-add-platform-to-codefuelcampaign.js
ADDED
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
module.exports = {
|
|
4
|
+
up: async (queryInterface, Sequelize) => {
|
|
5
|
+
await queryInterface.addColumn("CodefuelCampaigns", "platform", {
|
|
6
|
+
type: Sequelize.ENUM("fb", "tt", "snp"),
|
|
7
|
+
allowNull: false,
|
|
8
|
+
defaultValue: "fb",
|
|
9
|
+
comment: "Ad platform identifier: fb=Facebook, tt=TikTok, snp=Snapchat",
|
|
10
|
+
});
|
|
11
|
+
},
|
|
12
|
+
|
|
13
|
+
down: async (queryInterface, Sequelize) => {
|
|
14
|
+
await queryInterface.removeColumn("CodefuelCampaigns", "platform");
|
|
15
|
+
await queryInterface.sequelize.query(
|
|
16
|
+
'DROP TYPE IF EXISTS "enum_CodefuelCampaigns_platform";'
|
|
17
|
+
);
|
|
18
|
+
},
|
|
19
|
+
};
|
package/.worktrees/adperformance-platform/migrations/2026-05-17-add-platform-to-dynamicfeed.js
ADDED
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
module.exports = {
|
|
4
|
+
up: async (queryInterface, Sequelize) => {
|
|
5
|
+
await queryInterface.addColumn("dynamic_feeds", "platform", {
|
|
6
|
+
type: Sequelize.ENUM("fb", "tt", "snp"),
|
|
7
|
+
allowNull: false,
|
|
8
|
+
defaultValue: "fb",
|
|
9
|
+
comment: "Ad platform identifier: fb=Facebook, tt=TikTok, snp=Snapchat",
|
|
10
|
+
});
|
|
11
|
+
},
|
|
12
|
+
|
|
13
|
+
down: async (queryInterface, Sequelize) => {
|
|
14
|
+
await queryInterface.removeColumn("dynamic_feeds", "platform");
|
|
15
|
+
await queryInterface.sequelize.query(
|
|
16
|
+
'DROP TYPE IF EXISTS "enum_dynamic_feeds_platform";'
|
|
17
|
+
);
|
|
18
|
+
},
|
|
19
|
+
};
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
module.exports = {
|
|
4
|
+
up: async (queryInterface, Sequelize) => {
|
|
5
|
+
await queryInterface.addColumn("facebook_retry_queue", "platform", {
|
|
6
|
+
type: Sequelize.ENUM("fb", "tt", "snp"),
|
|
7
|
+
allowNull: false,
|
|
8
|
+
defaultValue: "fb",
|
|
9
|
+
comment: "Ad platform identifier: fb=Facebook, tt=TikTok, snp=Snapchat",
|
|
10
|
+
});
|
|
11
|
+
},
|
|
12
|
+
|
|
13
|
+
down: async (queryInterface, Sequelize) => {
|
|
14
|
+
await queryInterface.removeColumn("facebook_retry_queue", "platform");
|
|
15
|
+
await queryInterface.sequelize.query(
|
|
16
|
+
'DROP TYPE IF EXISTS "enum_facebook_retry_queue_platform";'
|
|
17
|
+
);
|
|
18
|
+
},
|
|
19
|
+
};
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
module.exports = {
|
|
4
|
+
up: async (queryInterface, Sequelize) => {
|
|
5
|
+
await queryInterface.addColumn("Pages", "platform", {
|
|
6
|
+
type: Sequelize.ENUM("fb", "tt", "snp"),
|
|
7
|
+
allowNull: false,
|
|
8
|
+
defaultValue: "fb",
|
|
9
|
+
comment: "Ad platform identifier: fb=Facebook, tt=TikTok, snp=Snapchat",
|
|
10
|
+
});
|
|
11
|
+
},
|
|
12
|
+
|
|
13
|
+
down: async (queryInterface, Sequelize) => {
|
|
14
|
+
await queryInterface.removeColumn("Pages", "platform");
|
|
15
|
+
await queryInterface.sequelize.query(
|
|
16
|
+
'DROP TYPE IF EXISTS "enum_Pages_platform";'
|
|
17
|
+
);
|
|
18
|
+
},
|
|
19
|
+
};
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
module.exports = {
|
|
4
|
+
up: async (queryInterface, Sequelize) => {
|
|
5
|
+
await queryInterface.addColumn("Presets", "platform", {
|
|
6
|
+
type: Sequelize.ENUM("fb", "tt", "snp"),
|
|
7
|
+
allowNull: false,
|
|
8
|
+
defaultValue: "fb",
|
|
9
|
+
comment: "Ad platform identifier: fb=Facebook, tt=TikTok, snp=Snapchat",
|
|
10
|
+
});
|
|
11
|
+
},
|
|
12
|
+
|
|
13
|
+
down: async (queryInterface, Sequelize) => {
|
|
14
|
+
await queryInterface.removeColumn("Presets", "platform");
|
|
15
|
+
await queryInterface.sequelize.query(
|
|
16
|
+
'DROP TYPE IF EXISTS "enum_Presets_platform";'
|
|
17
|
+
);
|
|
18
|
+
},
|
|
19
|
+
};
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
module.exports = {
|
|
4
|
+
up: async (queryInterface) => {
|
|
5
|
+
await queryInterface.addIndex("AdPerformance", ["platform", "Date"], {
|
|
6
|
+
name: "AdPerformance_platform_Date_idx",
|
|
7
|
+
});
|
|
8
|
+
},
|
|
9
|
+
|
|
10
|
+
down: async (queryInterface) => {
|
|
11
|
+
await queryInterface.removeIndex(
|
|
12
|
+
"AdPerformance",
|
|
13
|
+
"AdPerformance_platform_Date_idx"
|
|
14
|
+
);
|
|
15
|
+
},
|
|
16
|
+
};
|
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
-- Platform column rollout — 14 tables (additive).
|
|
2
|
+
-- Generated 2026-05-17. Run against staging first, verify, then production.
|
|
3
|
+
-- All ops are additive. No data loss possible. Backfill happens automatically via DEFAULT 'fb'.
|
|
4
|
+
--
|
|
5
|
+
-- IMPORTANT — 4 tables intentionally OMITTED from this batch because they
|
|
6
|
+
-- already have a `platform` column of type VARCHAR with capitalized values
|
|
7
|
+
-- (e.g. "Facebook"). Adding an ENUM column with the same name would conflict.
|
|
8
|
+
-- These require a separate normalization plan (see migrations/2026-05-17-PIXELS-FOLLOWUP.md):
|
|
9
|
+
-- - CampaignCreationLogs (column platform varchar; values 'Facebook' / 'fb' / NULL)
|
|
10
|
+
-- - CampaignCreationLogsV2 (column platform varchar; values 'Facebook' / 'fb' / NULL)
|
|
11
|
+
-- - rsoc_feed_campaigns (column platform varchar; values 'Facebook' / 'fb')
|
|
12
|
+
-- - Pixels (column platform varchar; values 'Facebook' / 'Tiktok' / 'Yahoo' / etc.)
|
|
13
|
+
--
|
|
14
|
+
-- Tables included in this rollout (14):
|
|
15
|
+
-- 1 Campaign 6 ai_campaign_queue 11 articles
|
|
16
|
+
-- 2 AdSet 7 facebook_retry_queue 12 dynamic_feeds
|
|
17
|
+
-- 3 Ad 8 ai_article_retry_queue 13 CodefuelCampaigns
|
|
18
|
+
-- 4 AdAccount 9 AdSetPerformance 14 Presets
|
|
19
|
+
-- 5 Pages 10 AdPerformance
|
|
20
|
+
|
|
21
|
+
BEGIN;
|
|
22
|
+
|
|
23
|
+
DO $$
|
|
24
|
+
DECLARE
|
|
25
|
+
tbl text;
|
|
26
|
+
BEGIN
|
|
27
|
+
FOR tbl IN
|
|
28
|
+
SELECT unnest(ARRAY[
|
|
29
|
+
'Campaign', 'AdSet', 'Ad', 'AdAccount', 'Pages',
|
|
30
|
+
'ai_campaign_queue', 'facebook_retry_queue', 'ai_article_retry_queue',
|
|
31
|
+
'AdSetPerformance', 'AdPerformance',
|
|
32
|
+
'articles', 'dynamic_feeds', 'CodefuelCampaigns',
|
|
33
|
+
'Presets'
|
|
34
|
+
])
|
|
35
|
+
LOOP
|
|
36
|
+
-- Create the per-table ENUM type if it doesn't already exist
|
|
37
|
+
EXECUTE format(
|
|
38
|
+
'DO $inner$ BEGIN
|
|
39
|
+
CREATE TYPE %I AS ENUM (''fb'', ''tt'', ''snp'');
|
|
40
|
+
EXCEPTION
|
|
41
|
+
WHEN duplicate_object THEN NULL;
|
|
42
|
+
END $inner$;',
|
|
43
|
+
'enum_' || tbl || '_platform'
|
|
44
|
+
);
|
|
45
|
+
|
|
46
|
+
-- Add the column if it doesn't exist
|
|
47
|
+
EXECUTE format(
|
|
48
|
+
'ALTER TABLE %I ADD COLUMN IF NOT EXISTS platform %I NOT NULL DEFAULT ''fb'';',
|
|
49
|
+
tbl,
|
|
50
|
+
'enum_' || tbl || '_platform'
|
|
51
|
+
);
|
|
52
|
+
|
|
53
|
+
-- Comment
|
|
54
|
+
EXECUTE format(
|
|
55
|
+
'COMMENT ON COLUMN %I.platform IS ''Ad platform identifier: fb=Facebook, tt=TikTok, snp=Snapchat'';',
|
|
56
|
+
tbl
|
|
57
|
+
);
|
|
58
|
+
END LOOP;
|
|
59
|
+
END $$;
|
|
60
|
+
|
|
61
|
+
COMMIT;
|
|
62
|
+
|
|
63
|
+
-- Verification queries — run after COMMIT to confirm:
|
|
64
|
+
-- 1) Confirm 14 ENUM columns added (plus 4 pre-existing varchar columns = 18 total rows expected):
|
|
65
|
+
-- SELECT table_name, column_name, data_type, udt_name, column_default
|
|
66
|
+
-- FROM information_schema.columns
|
|
67
|
+
-- WHERE column_name = 'platform'
|
|
68
|
+
-- ORDER BY table_name;
|
|
69
|
+
--
|
|
70
|
+
-- 2) Confirm backfill: every row should have platform='fb':
|
|
71
|
+
-- SELECT 'Campaign' AS tbl, platform, COUNT(*) FROM "Campaign" GROUP BY platform
|
|
72
|
+
-- UNION ALL SELECT 'AdSet', platform, COUNT(*) FROM "AdSet" GROUP BY platform
|
|
73
|
+
-- UNION ALL SELECT 'Ad', platform, COUNT(*) FROM "Ad" GROUP BY platform
|
|
74
|
+
-- UNION ALL SELECT 'AdAccount', platform, COUNT(*) FROM "AdAccount" GROUP BY platform
|
|
75
|
+
-- UNION ALL SELECT 'Pages', platform, COUNT(*) FROM "Pages" GROUP BY platform
|
|
76
|
+
-- UNION ALL SELECT 'ai_campaign_queue', platform, COUNT(*) FROM ai_campaign_queue GROUP BY platform
|
|
77
|
+
-- UNION ALL SELECT 'facebook_retry_queue', platform, COUNT(*) FROM facebook_retry_queue GROUP BY platform
|
|
78
|
+
-- UNION ALL SELECT 'ai_article_retry_queue',platform, COUNT(*) FROM ai_article_retry_queue GROUP BY platform
|
|
79
|
+
-- UNION ALL SELECT 'AdSetPerformance', platform, COUNT(*) FROM "AdSetPerformance" GROUP BY platform
|
|
80
|
+
-- UNION ALL SELECT 'AdPerformance', platform, COUNT(*) FROM "AdPerformance" GROUP BY platform
|
|
81
|
+
-- UNION ALL SELECT 'articles', platform, COUNT(*) FROM articles GROUP BY platform
|
|
82
|
+
-- UNION ALL SELECT 'dynamic_feeds', platform, COUNT(*) FROM dynamic_feeds GROUP BY platform
|
|
83
|
+
-- UNION ALL SELECT 'CodefuelCampaigns',platform, COUNT(*) FROM "CodefuelCampaigns" GROUP BY platform
|
|
84
|
+
-- UNION ALL SELECT 'Presets', platform, COUNT(*) FROM "Presets" GROUP BY platform
|
|
85
|
+
-- ORDER BY tbl, platform;
|
|
86
|
+
|
|
87
|
+
-- ROLLBACK plan (separate transaction; only if needed):
|
|
88
|
+
-- BEGIN;
|
|
89
|
+
-- DO $$ DECLARE tbl text; BEGIN
|
|
90
|
+
-- FOR tbl IN SELECT unnest(ARRAY['Campaign','AdSet','Ad','AdAccount','Pages',
|
|
91
|
+
-- 'ai_campaign_queue','facebook_retry_queue','ai_article_retry_queue',
|
|
92
|
+
-- 'AdSetPerformance','AdPerformance',
|
|
93
|
+
-- 'articles','dynamic_feeds','CodefuelCampaigns','Presets'])
|
|
94
|
+
-- LOOP
|
|
95
|
+
-- EXECUTE format('ALTER TABLE %I DROP COLUMN IF EXISTS platform;', tbl);
|
|
96
|
+
-- EXECUTE format('DROP TYPE IF EXISTS %I;', 'enum_' || tbl || '_platform');
|
|
97
|
+
-- END LOOP;
|
|
98
|
+
-- END $$;
|
|
99
|
+
-- COMMIT;
|
package/.worktrees/adperformance-platform/migrations/add-requested-from-dashboard-to-articles.js
ADDED
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
module.exports = {
|
|
4
|
+
up: async (queryInterface, Sequelize) => {
|
|
5
|
+
await queryInterface.addColumn("articles", "requestedFromDashboard", {
|
|
6
|
+
type: Sequelize.BOOLEAN,
|
|
7
|
+
allowNull: false,
|
|
8
|
+
defaultValue: false,
|
|
9
|
+
comment:
|
|
10
|
+
"Indicates if the article was created through our dashboard (true) or imported from external sources (false)",
|
|
11
|
+
});
|
|
12
|
+
},
|
|
13
|
+
|
|
14
|
+
down: async (queryInterface, Sequelize) => {
|
|
15
|
+
await queryInterface.removeColumn("articles", "requestedFromDashboard");
|
|
16
|
+
},
|
|
17
|
+
};
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
module.exports = {
|
|
4
|
+
up: async (queryInterface, Sequelize) => {
|
|
5
|
+
// Change AdSetName column from VARCHAR(255) to TEXT
|
|
6
|
+
// This is a SAFE operation - PostgreSQL can convert VARCHAR to TEXT without data loss
|
|
7
|
+
// All existing data will be preserved
|
|
8
|
+
|
|
9
|
+
// First, check if column exists and get its current type
|
|
10
|
+
const [columns] = await queryInterface.sequelize.query(`
|
|
11
|
+
SELECT column_name, data_type, character_maximum_length
|
|
12
|
+
FROM information_schema.columns
|
|
13
|
+
WHERE table_name = 'AdSet' AND column_name = 'AdSetName'
|
|
14
|
+
`);
|
|
15
|
+
|
|
16
|
+
if (columns.length === 0) {
|
|
17
|
+
console.log("⚠️ AdSetName column not found, skipping migration");
|
|
18
|
+
return;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
const currentType = columns[0].data_type;
|
|
22
|
+
const currentMaxLength = columns[0].character_maximum_length;
|
|
23
|
+
|
|
24
|
+
console.log(
|
|
25
|
+
`Current AdSetName type: ${currentType}(${
|
|
26
|
+
currentMaxLength || "unlimited"
|
|
27
|
+
})`
|
|
28
|
+
);
|
|
29
|
+
|
|
30
|
+
// Only change if it's currently VARCHAR with length limit
|
|
31
|
+
if (currentType === "character varying" && currentMaxLength) {
|
|
32
|
+
console.log("Converting AdSetName from VARCHAR to TEXT...");
|
|
33
|
+
|
|
34
|
+
// Use direct SQL for more control
|
|
35
|
+
await queryInterface.sequelize.query(`
|
|
36
|
+
ALTER TABLE "AdSet"
|
|
37
|
+
ALTER COLUMN "AdSetName" TYPE TEXT
|
|
38
|
+
USING "AdSetName"::TEXT
|
|
39
|
+
`);
|
|
40
|
+
|
|
41
|
+
console.log("✅ AdSetName successfully converted to TEXT");
|
|
42
|
+
} else if (currentType === "text") {
|
|
43
|
+
console.log("✅ AdSetName is already TEXT, no change needed");
|
|
44
|
+
} else {
|
|
45
|
+
console.log(`⚠️ AdSetName is ${currentType}, not changing`);
|
|
46
|
+
}
|
|
47
|
+
},
|
|
48
|
+
|
|
49
|
+
down: async (queryInterface, Sequelize) => {
|
|
50
|
+
// Revert back to VARCHAR(255)
|
|
51
|
+
// WARNING: This might truncate existing long values if any exist
|
|
52
|
+
console.log(
|
|
53
|
+
"⚠️ Reverting AdSetName to VARCHAR(255) - this may truncate long values!"
|
|
54
|
+
);
|
|
55
|
+
|
|
56
|
+
// Check for any values longer than 255 characters
|
|
57
|
+
const [longValues] = await queryInterface.sequelize.query(`
|
|
58
|
+
SELECT COUNT(*) as count
|
|
59
|
+
FROM "AdSet"
|
|
60
|
+
WHERE LENGTH("AdSetName") > 255
|
|
61
|
+
`);
|
|
62
|
+
|
|
63
|
+
if (longValues[0].count > 0) {
|
|
64
|
+
console.log(
|
|
65
|
+
`⚠️ WARNING: ${longValues[0].count} rows have AdSetName longer than 255 characters!`
|
|
66
|
+
);
|
|
67
|
+
console.log(
|
|
68
|
+
"⚠️ These will be truncated if you proceed with the down migration."
|
|
69
|
+
);
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
await queryInterface.changeColumn("AdSet", "AdSetName", {
|
|
73
|
+
type: Sequelize.STRING(255),
|
|
74
|
+
allowNull: true,
|
|
75
|
+
});
|
|
76
|
+
|
|
77
|
+
console.log("✅ AdSetName reverted to VARCHAR(255)");
|
|
78
|
+
},
|
|
79
|
+
};
|