agrs-sequelize-sdk 1.2.99 → 1.3.1
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/migrations/add-requested-from-dashboard-to-articles.js +17 -17
- package/models/AdAccountValues.js +25 -25
- package/models/AdHistory.js +30 -30
- package/models/AdPerformance.js +94 -94
- package/models/AdSet.js +289 -289
- package/models/AdSetHistory.js +30 -30
- package/models/AdsetPerformance.js +126 -126
- package/models/Article.js +190 -190
- package/models/AutomationRule.js +161 -127
- package/models/Buyers.js +25 -25
- package/models/Campaign.js +157 -157
- package/models/CampaignActionHistory.js +86 -86
- package/models/CampaignCreationLog.js +309 -309
- package/models/CampaignHistory.js +33 -33
- package/models/Channel.js +55 -55
- package/models/Domain.js +25 -25
- package/models/DynamicFeed.js +212 -212
- package/models/ExplorAdsChannel.js +61 -61
- package/models/Feed.js +33 -33
- package/models/FrontStoryChannel.js +59 -59
- package/models/MineChannel.js +42 -42
- package/models/Pages.js +81 -81
- package/models/PipelineExecution.js +59 -59
- package/models/Presets.js +34 -34
- package/models/RSOCFeedCampaign.js +357 -357
- package/models/RsocKeywordPerformance.js +110 -110
- package/models/RuleAction.js +90 -90
- package/models/RuleCondition.js +98 -98
- package/models/RuleExecution.js +107 -107
- package/models/RulesValues.js +56 -56
- package/models/SupportedLocale.js +23 -23
- package/models/SyncHistory.js +249 -249
- package/models/Tier2_AdAccounts.js +110 -110
- package/models/Tier2_Assets.js +70 -70
- package/models/Tier2_BusinessManagers.js +105 -105
- package/models/Tier2_CreditLines.js +99 -99
- package/models/Tier2_Pages.js +91 -91
- package/models/Tier2_Pixels.js +82 -82
- package/models/Tier2_Tokens.js +64 -64
- package/models/Tier2_UserAdAccounts.js +83 -83
- package/models/TokenRotationState.js +121 -121
- package/models/TonicRSOCKeywordPerformance.js +122 -122
- package/models/Vertical.js +25 -25
- package/models/newFiles.js +110 -110
- package/package.json +19 -21
- package/run.sh +214 -214
- package/services/sequelizeService.js +63 -63
|
@@ -1,62 +1,62 @@
|
|
|
1
|
-
module.exports = (sequelize, DataTypes) => {
|
|
2
|
-
const ExplorAdsChannel = sequelize.define(
|
|
3
|
-
"ExplorAdsChannel",
|
|
4
|
-
{
|
|
5
|
-
channelId: {
|
|
6
|
-
type: DataTypes.STRING,
|
|
7
|
-
allowNull: false,
|
|
8
|
-
validate: {
|
|
9
|
-
// Validate channel format (br_vt_ch1401 to br_vt_ch1500)
|
|
10
|
-
is: /^br_vt_ch(14[0-9][0-9]|1500)$/
|
|
11
|
-
}
|
|
12
|
-
},
|
|
13
|
-
status: {
|
|
14
|
-
type: DataTypes.STRING,
|
|
15
|
-
allowNull: false,
|
|
16
|
-
defaultValue: "free",
|
|
17
|
-
validate: {
|
|
18
|
-
isIn: [["free", "used", "archived"]],
|
|
19
|
-
},
|
|
20
|
-
},
|
|
21
|
-
domain: {
|
|
22
|
-
type: DataTypes.STRING,
|
|
23
|
-
allowNull: false,
|
|
24
|
-
defaultValue: "nexoreach.com"
|
|
25
|
-
},
|
|
26
|
-
connectedCampaigns: {
|
|
27
|
-
type: DataTypes.JSONB,
|
|
28
|
-
allowNull: false,
|
|
29
|
-
defaultValue: [],
|
|
30
|
-
},
|
|
31
|
-
lastUsed: {
|
|
32
|
-
type: DataTypes.DATE,
|
|
33
|
-
allowNull: true
|
|
34
|
-
}
|
|
35
|
-
},
|
|
36
|
-
{
|
|
37
|
-
tableName: "explorads_channels",
|
|
38
|
-
timestamps: true,
|
|
39
|
-
indexes: [
|
|
40
|
-
{
|
|
41
|
-
unique: true,
|
|
42
|
-
fields: ["channelId"],
|
|
43
|
-
name: "unique_explorads_channel"
|
|
44
|
-
},
|
|
45
|
-
],
|
|
46
|
-
}
|
|
47
|
-
);
|
|
48
|
-
|
|
49
|
-
// Define associations
|
|
50
|
-
ExplorAdsChannel.associate = (models) => {
|
|
51
|
-
if (models.RSOCFeedCampaign) {
|
|
52
|
-
ExplorAdsChannel.hasMany(models.RSOCFeedCampaign, {
|
|
53
|
-
foreignKey: "channelId",
|
|
54
|
-
sourceKey: "channelId",
|
|
55
|
-
as: "RSOCFeedCampaigns",
|
|
56
|
-
constraints: false, // Disable FK constraint
|
|
57
|
-
});
|
|
58
|
-
}
|
|
59
|
-
};
|
|
60
|
-
|
|
61
|
-
return ExplorAdsChannel;
|
|
1
|
+
module.exports = (sequelize, DataTypes) => {
|
|
2
|
+
const ExplorAdsChannel = sequelize.define(
|
|
3
|
+
"ExplorAdsChannel",
|
|
4
|
+
{
|
|
5
|
+
channelId: {
|
|
6
|
+
type: DataTypes.STRING,
|
|
7
|
+
allowNull: false,
|
|
8
|
+
validate: {
|
|
9
|
+
// Validate channel format (br_vt_ch1401 to br_vt_ch1500)
|
|
10
|
+
is: /^br_vt_ch(14[0-9][0-9]|1500)$/
|
|
11
|
+
}
|
|
12
|
+
},
|
|
13
|
+
status: {
|
|
14
|
+
type: DataTypes.STRING,
|
|
15
|
+
allowNull: false,
|
|
16
|
+
defaultValue: "free",
|
|
17
|
+
validate: {
|
|
18
|
+
isIn: [["free", "used", "archived"]],
|
|
19
|
+
},
|
|
20
|
+
},
|
|
21
|
+
domain: {
|
|
22
|
+
type: DataTypes.STRING,
|
|
23
|
+
allowNull: false,
|
|
24
|
+
defaultValue: "nexoreach.com"
|
|
25
|
+
},
|
|
26
|
+
connectedCampaigns: {
|
|
27
|
+
type: DataTypes.JSONB,
|
|
28
|
+
allowNull: false,
|
|
29
|
+
defaultValue: [],
|
|
30
|
+
},
|
|
31
|
+
lastUsed: {
|
|
32
|
+
type: DataTypes.DATE,
|
|
33
|
+
allowNull: true
|
|
34
|
+
}
|
|
35
|
+
},
|
|
36
|
+
{
|
|
37
|
+
tableName: "explorads_channels",
|
|
38
|
+
timestamps: true,
|
|
39
|
+
indexes: [
|
|
40
|
+
{
|
|
41
|
+
unique: true,
|
|
42
|
+
fields: ["channelId"],
|
|
43
|
+
name: "unique_explorads_channel"
|
|
44
|
+
},
|
|
45
|
+
],
|
|
46
|
+
}
|
|
47
|
+
);
|
|
48
|
+
|
|
49
|
+
// Define associations
|
|
50
|
+
ExplorAdsChannel.associate = (models) => {
|
|
51
|
+
if (models.RSOCFeedCampaign) {
|
|
52
|
+
ExplorAdsChannel.hasMany(models.RSOCFeedCampaign, {
|
|
53
|
+
foreignKey: "channelId",
|
|
54
|
+
sourceKey: "channelId",
|
|
55
|
+
as: "RSOCFeedCampaigns",
|
|
56
|
+
constraints: false, // Disable FK constraint
|
|
57
|
+
});
|
|
58
|
+
}
|
|
59
|
+
};
|
|
60
|
+
|
|
61
|
+
return ExplorAdsChannel;
|
|
62
62
|
};
|
package/models/Feed.js
CHANGED
|
@@ -1,34 +1,34 @@
|
|
|
1
|
-
module.exports = (sequelize, DataTypes) => {
|
|
2
|
-
const Feed = sequelize.define(
|
|
3
|
-
"Feed",
|
|
4
|
-
{
|
|
5
|
-
id: {
|
|
6
|
-
type: DataTypes.UUID,
|
|
7
|
-
defaultValue: DataTypes.UUIDV4,
|
|
8
|
-
primaryKey: true,
|
|
9
|
-
},
|
|
10
|
-
label: {
|
|
11
|
-
type: DataTypes.STRING,
|
|
12
|
-
allowNull: false,
|
|
13
|
-
},
|
|
14
|
-
code: {
|
|
15
|
-
type: DataTypes.STRING,
|
|
16
|
-
allowNull: false,
|
|
17
|
-
unique: true,
|
|
18
|
-
},
|
|
19
|
-
sheet: {
|
|
20
|
-
type: DataTypes.STRING,
|
|
21
|
-
allowNull: false,
|
|
22
|
-
},
|
|
23
|
-
feedProvider: {
|
|
24
|
-
type: DataTypes.STRING,
|
|
25
|
-
allowNull: false,
|
|
26
|
-
},
|
|
27
|
-
},
|
|
28
|
-
{
|
|
29
|
-
tableName: "Feed",
|
|
30
|
-
}
|
|
31
|
-
);
|
|
32
|
-
|
|
33
|
-
return Feed;
|
|
1
|
+
module.exports = (sequelize, DataTypes) => {
|
|
2
|
+
const Feed = sequelize.define(
|
|
3
|
+
"Feed",
|
|
4
|
+
{
|
|
5
|
+
id: {
|
|
6
|
+
type: DataTypes.UUID,
|
|
7
|
+
defaultValue: DataTypes.UUIDV4,
|
|
8
|
+
primaryKey: true,
|
|
9
|
+
},
|
|
10
|
+
label: {
|
|
11
|
+
type: DataTypes.STRING,
|
|
12
|
+
allowNull: false,
|
|
13
|
+
},
|
|
14
|
+
code: {
|
|
15
|
+
type: DataTypes.STRING,
|
|
16
|
+
allowNull: false,
|
|
17
|
+
unique: true,
|
|
18
|
+
},
|
|
19
|
+
sheet: {
|
|
20
|
+
type: DataTypes.STRING,
|
|
21
|
+
allowNull: false,
|
|
22
|
+
},
|
|
23
|
+
feedProvider: {
|
|
24
|
+
type: DataTypes.STRING,
|
|
25
|
+
allowNull: false,
|
|
26
|
+
},
|
|
27
|
+
},
|
|
28
|
+
{
|
|
29
|
+
tableName: "Feed",
|
|
30
|
+
}
|
|
31
|
+
);
|
|
32
|
+
|
|
33
|
+
return Feed;
|
|
34
34
|
};
|
|
@@ -1,60 +1,60 @@
|
|
|
1
|
-
module.exports = (sequelize, DataTypes) => {
|
|
2
|
-
const FrontStoryChannel = sequelize.define(
|
|
3
|
-
"FrontStoryChannel",
|
|
4
|
-
{
|
|
5
|
-
channelId: {
|
|
6
|
-
type: DataTypes.STRING,
|
|
7
|
-
allowNull: false,
|
|
8
|
-
// Not setting as primary key or unique since duplicates are allowed
|
|
9
|
-
},
|
|
10
|
-
channelName: {
|
|
11
|
-
type: DataTypes.STRING,
|
|
12
|
-
allowNull: true,
|
|
13
|
-
comment: 'Human-readable name for the channel'
|
|
14
|
-
},
|
|
15
|
-
styleId: {
|
|
16
|
-
type: DataTypes.STRING,
|
|
17
|
-
allowNull: false,
|
|
18
|
-
},
|
|
19
|
-
status: {
|
|
20
|
-
type: DataTypes.STRING,
|
|
21
|
-
allowNull: false,
|
|
22
|
-
defaultValue: "free",
|
|
23
|
-
validate: {
|
|
24
|
-
isIn: [["free", "used", "archived"]],
|
|
25
|
-
},
|
|
26
|
-
},
|
|
27
|
-
connectedCampaigns: {
|
|
28
|
-
type: DataTypes.JSONB, // Use JSONB for better querying capabilities
|
|
29
|
-
allowNull: false,
|
|
30
|
-
defaultValue: [],
|
|
31
|
-
},
|
|
32
|
-
},
|
|
33
|
-
{
|
|
34
|
-
tableName: "front_story_channels",
|
|
35
|
-
timestamps: true,
|
|
36
|
-
// indexes: [
|
|
37
|
-
// // Add a composite unique index on channelId and styleId if needed
|
|
38
|
-
// {
|
|
39
|
-
// unique: true,
|
|
40
|
-
// fields: ["channelId", "styleId"],
|
|
41
|
-
// name: "unique_front_story_channel_style",
|
|
42
|
-
// },
|
|
43
|
-
// ],
|
|
44
|
-
}
|
|
45
|
-
);
|
|
46
|
-
|
|
47
|
-
// Define associations without enforcing constraints
|
|
48
|
-
FrontStoryChannel.associate = (models) => {
|
|
49
|
-
if (models.RSOCFeedCampaign) {
|
|
50
|
-
FrontStoryChannel.hasMany(models.RSOCFeedCampaign, {
|
|
51
|
-
foreignKey: "channelId",
|
|
52
|
-
sourceKey: "channelId",
|
|
53
|
-
as: "RSOCFeedCampaigns",
|
|
54
|
-
constraints: false, // Disable FK constraint
|
|
55
|
-
});
|
|
56
|
-
}
|
|
57
|
-
};
|
|
58
|
-
|
|
59
|
-
return FrontStoryChannel;
|
|
1
|
+
module.exports = (sequelize, DataTypes) => {
|
|
2
|
+
const FrontStoryChannel = sequelize.define(
|
|
3
|
+
"FrontStoryChannel",
|
|
4
|
+
{
|
|
5
|
+
channelId: {
|
|
6
|
+
type: DataTypes.STRING,
|
|
7
|
+
allowNull: false,
|
|
8
|
+
// Not setting as primary key or unique since duplicates are allowed
|
|
9
|
+
},
|
|
10
|
+
channelName: {
|
|
11
|
+
type: DataTypes.STRING,
|
|
12
|
+
allowNull: true,
|
|
13
|
+
comment: 'Human-readable name for the channel'
|
|
14
|
+
},
|
|
15
|
+
styleId: {
|
|
16
|
+
type: DataTypes.STRING,
|
|
17
|
+
allowNull: false,
|
|
18
|
+
},
|
|
19
|
+
status: {
|
|
20
|
+
type: DataTypes.STRING,
|
|
21
|
+
allowNull: false,
|
|
22
|
+
defaultValue: "free",
|
|
23
|
+
validate: {
|
|
24
|
+
isIn: [["free", "used", "archived"]],
|
|
25
|
+
},
|
|
26
|
+
},
|
|
27
|
+
connectedCampaigns: {
|
|
28
|
+
type: DataTypes.JSONB, // Use JSONB for better querying capabilities
|
|
29
|
+
allowNull: false,
|
|
30
|
+
defaultValue: [],
|
|
31
|
+
},
|
|
32
|
+
},
|
|
33
|
+
{
|
|
34
|
+
tableName: "front_story_channels",
|
|
35
|
+
timestamps: true,
|
|
36
|
+
// indexes: [
|
|
37
|
+
// // Add a composite unique index on channelId and styleId if needed
|
|
38
|
+
// {
|
|
39
|
+
// unique: true,
|
|
40
|
+
// fields: ["channelId", "styleId"],
|
|
41
|
+
// name: "unique_front_story_channel_style",
|
|
42
|
+
// },
|
|
43
|
+
// ],
|
|
44
|
+
}
|
|
45
|
+
);
|
|
46
|
+
|
|
47
|
+
// Define associations without enforcing constraints
|
|
48
|
+
FrontStoryChannel.associate = (models) => {
|
|
49
|
+
if (models.RSOCFeedCampaign) {
|
|
50
|
+
FrontStoryChannel.hasMany(models.RSOCFeedCampaign, {
|
|
51
|
+
foreignKey: "channelId",
|
|
52
|
+
sourceKey: "channelId",
|
|
53
|
+
as: "RSOCFeedCampaigns",
|
|
54
|
+
constraints: false, // Disable FK constraint
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
};
|
|
58
|
+
|
|
59
|
+
return FrontStoryChannel;
|
|
60
60
|
};
|
package/models/MineChannel.js
CHANGED
|
@@ -1,43 +1,43 @@
|
|
|
1
|
-
module.exports = (sequelize, DataTypes) => {
|
|
2
|
-
const MineChannel = sequelize.define(
|
|
3
|
-
"MineChannel",
|
|
4
|
-
{
|
|
5
|
-
channelId: {
|
|
6
|
-
type: DataTypes.STRING,
|
|
7
|
-
allowNull: false,
|
|
8
|
-
// Not setting as primary key or unique since duplicates are allowed
|
|
9
|
-
},
|
|
10
|
-
status: {
|
|
11
|
-
type: DataTypes.STRING,
|
|
12
|
-
allowNull: false,
|
|
13
|
-
defaultValue: "free",
|
|
14
|
-
validate: {
|
|
15
|
-
isIn: [["free", "used", "archived"]],
|
|
16
|
-
},
|
|
17
|
-
},
|
|
18
|
-
connectedCampaigns: {
|
|
19
|
-
type: DataTypes.JSONB, // Use JSONB for better querying capabilities
|
|
20
|
-
allowNull: false,
|
|
21
|
-
defaultValue: [],
|
|
22
|
-
},
|
|
23
|
-
},
|
|
24
|
-
{
|
|
25
|
-
tableName: "mine_channels",
|
|
26
|
-
timestamps: true,
|
|
27
|
-
}
|
|
28
|
-
);
|
|
29
|
-
|
|
30
|
-
// Define associations without enforcing constraints
|
|
31
|
-
MineChannel.associate = (models) => {
|
|
32
|
-
if (models.RSOCFeedCampaign) {
|
|
33
|
-
MineChannel.hasMany(models.RSOCFeedCampaign, {
|
|
34
|
-
foreignKey: "channelId",
|
|
35
|
-
sourceKey: "channelId",
|
|
36
|
-
as: "RSOCFeedCampaigns",
|
|
37
|
-
constraints: false, // Disable FK constraint
|
|
38
|
-
});
|
|
39
|
-
}
|
|
40
|
-
};
|
|
41
|
-
|
|
42
|
-
return MineChannel;
|
|
1
|
+
module.exports = (sequelize, DataTypes) => {
|
|
2
|
+
const MineChannel = sequelize.define(
|
|
3
|
+
"MineChannel",
|
|
4
|
+
{
|
|
5
|
+
channelId: {
|
|
6
|
+
type: DataTypes.STRING,
|
|
7
|
+
allowNull: false,
|
|
8
|
+
// Not setting as primary key or unique since duplicates are allowed
|
|
9
|
+
},
|
|
10
|
+
status: {
|
|
11
|
+
type: DataTypes.STRING,
|
|
12
|
+
allowNull: false,
|
|
13
|
+
defaultValue: "free",
|
|
14
|
+
validate: {
|
|
15
|
+
isIn: [["free", "used", "archived"]],
|
|
16
|
+
},
|
|
17
|
+
},
|
|
18
|
+
connectedCampaigns: {
|
|
19
|
+
type: DataTypes.JSONB, // Use JSONB for better querying capabilities
|
|
20
|
+
allowNull: false,
|
|
21
|
+
defaultValue: [],
|
|
22
|
+
},
|
|
23
|
+
},
|
|
24
|
+
{
|
|
25
|
+
tableName: "mine_channels",
|
|
26
|
+
timestamps: true,
|
|
27
|
+
}
|
|
28
|
+
);
|
|
29
|
+
|
|
30
|
+
// Define associations without enforcing constraints
|
|
31
|
+
MineChannel.associate = (models) => {
|
|
32
|
+
if (models.RSOCFeedCampaign) {
|
|
33
|
+
MineChannel.hasMany(models.RSOCFeedCampaign, {
|
|
34
|
+
foreignKey: "channelId",
|
|
35
|
+
sourceKey: "channelId",
|
|
36
|
+
as: "RSOCFeedCampaigns",
|
|
37
|
+
constraints: false, // Disable FK constraint
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
};
|
|
41
|
+
|
|
42
|
+
return MineChannel;
|
|
43
43
|
};
|
package/models/Pages.js
CHANGED
|
@@ -1,81 +1,81 @@
|
|
|
1
|
-
module.exports = (sequelize, DataTypes) => {
|
|
2
|
-
const Pages = sequelize.define(
|
|
3
|
-
"Pages",
|
|
4
|
-
{
|
|
5
|
-
id: {
|
|
6
|
-
type: DataTypes.UUID,
|
|
7
|
-
defaultValue: DataTypes.UUIDV4,
|
|
8
|
-
primaryKey: true,
|
|
9
|
-
},
|
|
10
|
-
name: {
|
|
11
|
-
type: DataTypes.STRING,
|
|
12
|
-
allowNull: false,
|
|
13
|
-
},
|
|
14
|
-
code: {
|
|
15
|
-
type: DataTypes.STRING,
|
|
16
|
-
allowNull: false,
|
|
17
|
-
unique: true,
|
|
18
|
-
},
|
|
19
|
-
link: {
|
|
20
|
-
type: DataTypes.STRING,
|
|
21
|
-
allowNull: true,
|
|
22
|
-
},
|
|
23
|
-
feedProvider: {
|
|
24
|
-
type: DataTypes.ARRAY(DataTypes.STRING),
|
|
25
|
-
allowNull: false,
|
|
26
|
-
defaultValue: [], // Default value is an empty array
|
|
27
|
-
},
|
|
28
|
-
tasks: {
|
|
29
|
-
type: DataTypes.ARRAY(DataTypes.STRING),
|
|
30
|
-
allowNull: false,
|
|
31
|
-
defaultValue: [], // Default value is an empty array
|
|
32
|
-
},
|
|
33
|
-
is_published: {
|
|
34
|
-
type: DataTypes.BOOLEAN,
|
|
35
|
-
allowNull: false,
|
|
36
|
-
defaultValue: true,
|
|
37
|
-
},
|
|
38
|
-
Category: {
|
|
39
|
-
type: DataTypes.STRING,
|
|
40
|
-
allowNull: true,
|
|
41
|
-
},
|
|
42
|
-
Owner: {
|
|
43
|
-
type: DataTypes.STRING,
|
|
44
|
-
allowNull: true,
|
|
45
|
-
},
|
|
46
|
-
Status: {
|
|
47
|
-
type: DataTypes.STRING,
|
|
48
|
-
allowNull: true,
|
|
49
|
-
},
|
|
50
|
-
AdLibrary: {
|
|
51
|
-
type: DataTypes.STRING,
|
|
52
|
-
allowNull: true,
|
|
53
|
-
},
|
|
54
|
-
BusinessManager: {
|
|
55
|
-
type: DataTypes.STRING,
|
|
56
|
-
allowNull: true,
|
|
57
|
-
},
|
|
58
|
-
Users: {
|
|
59
|
-
type: DataTypes.ARRAY(DataTypes.STRING),
|
|
60
|
-
allowNull: false,
|
|
61
|
-
defaultValue: [],
|
|
62
|
-
},
|
|
63
|
-
Archived: {
|
|
64
|
-
type: DataTypes.BOOLEAN,
|
|
65
|
-
allowNull: true,
|
|
66
|
-
},
|
|
67
|
-
ads_limit: {
|
|
68
|
-
type: DataTypes.INTEGER,
|
|
69
|
-
allowNull: true,
|
|
70
|
-
defaultValue: 0,
|
|
71
|
-
comment:
|
|
72
|
-
"Number of currently active ads running on this page (Max limit: 250)",
|
|
73
|
-
},
|
|
74
|
-
},
|
|
75
|
-
{
|
|
76
|
-
tableName: "Pages",
|
|
77
|
-
}
|
|
78
|
-
);
|
|
79
|
-
|
|
80
|
-
return Pages;
|
|
81
|
-
};
|
|
1
|
+
module.exports = (sequelize, DataTypes) => {
|
|
2
|
+
const Pages = sequelize.define(
|
|
3
|
+
"Pages",
|
|
4
|
+
{
|
|
5
|
+
id: {
|
|
6
|
+
type: DataTypes.UUID,
|
|
7
|
+
defaultValue: DataTypes.UUIDV4,
|
|
8
|
+
primaryKey: true,
|
|
9
|
+
},
|
|
10
|
+
name: {
|
|
11
|
+
type: DataTypes.STRING,
|
|
12
|
+
allowNull: false,
|
|
13
|
+
},
|
|
14
|
+
code: {
|
|
15
|
+
type: DataTypes.STRING,
|
|
16
|
+
allowNull: false,
|
|
17
|
+
unique: true,
|
|
18
|
+
},
|
|
19
|
+
link: {
|
|
20
|
+
type: DataTypes.STRING,
|
|
21
|
+
allowNull: true,
|
|
22
|
+
},
|
|
23
|
+
feedProvider: {
|
|
24
|
+
type: DataTypes.ARRAY(DataTypes.STRING),
|
|
25
|
+
allowNull: false,
|
|
26
|
+
defaultValue: [], // Default value is an empty array
|
|
27
|
+
},
|
|
28
|
+
tasks: {
|
|
29
|
+
type: DataTypes.ARRAY(DataTypes.STRING),
|
|
30
|
+
allowNull: false,
|
|
31
|
+
defaultValue: [], // Default value is an empty array
|
|
32
|
+
},
|
|
33
|
+
is_published: {
|
|
34
|
+
type: DataTypes.BOOLEAN,
|
|
35
|
+
allowNull: false,
|
|
36
|
+
defaultValue: true,
|
|
37
|
+
},
|
|
38
|
+
Category: {
|
|
39
|
+
type: DataTypes.STRING,
|
|
40
|
+
allowNull: true,
|
|
41
|
+
},
|
|
42
|
+
Owner: {
|
|
43
|
+
type: DataTypes.STRING,
|
|
44
|
+
allowNull: true,
|
|
45
|
+
},
|
|
46
|
+
Status: {
|
|
47
|
+
type: DataTypes.STRING,
|
|
48
|
+
allowNull: true,
|
|
49
|
+
},
|
|
50
|
+
AdLibrary: {
|
|
51
|
+
type: DataTypes.STRING,
|
|
52
|
+
allowNull: true,
|
|
53
|
+
},
|
|
54
|
+
BusinessManager: {
|
|
55
|
+
type: DataTypes.STRING,
|
|
56
|
+
allowNull: true,
|
|
57
|
+
},
|
|
58
|
+
Users: {
|
|
59
|
+
type: DataTypes.ARRAY(DataTypes.STRING),
|
|
60
|
+
allowNull: false,
|
|
61
|
+
defaultValue: [],
|
|
62
|
+
},
|
|
63
|
+
Archived: {
|
|
64
|
+
type: DataTypes.BOOLEAN,
|
|
65
|
+
allowNull: true,
|
|
66
|
+
},
|
|
67
|
+
ads_limit: {
|
|
68
|
+
type: DataTypes.INTEGER,
|
|
69
|
+
allowNull: true,
|
|
70
|
+
defaultValue: 0,
|
|
71
|
+
comment:
|
|
72
|
+
"Number of currently active ads running on this page (Max limit: 250)",
|
|
73
|
+
},
|
|
74
|
+
},
|
|
75
|
+
{
|
|
76
|
+
tableName: "Pages",
|
|
77
|
+
}
|
|
78
|
+
);
|
|
79
|
+
|
|
80
|
+
return Pages;
|
|
81
|
+
};
|
|
@@ -1,59 +1,59 @@
|
|
|
1
|
-
module.exports = (sequelize, DataTypes) => {
|
|
2
|
-
const PipelineExecution = sequelize.define(
|
|
3
|
-
"PipelineExecution",
|
|
4
|
-
{
|
|
5
|
-
id: {
|
|
6
|
-
type: DataTypes.UUID,
|
|
7
|
-
defaultValue: DataTypes.UUIDV4,
|
|
8
|
-
primaryKey: true,
|
|
9
|
-
},
|
|
10
|
-
startTime: {
|
|
11
|
-
type: DataTypes.DATE,
|
|
12
|
-
allowNull: false,
|
|
13
|
-
},
|
|
14
|
-
endTime: {
|
|
15
|
-
type: DataTypes.DATE,
|
|
16
|
-
allowNull: false,
|
|
17
|
-
},
|
|
18
|
-
status: {
|
|
19
|
-
type: DataTypes.ENUM("success", "failed"),
|
|
20
|
-
allowNull: false,
|
|
21
|
-
},
|
|
22
|
-
fbDaysBack: {
|
|
23
|
-
type: DataTypes.INTEGER,
|
|
24
|
-
allowNull: true,
|
|
25
|
-
},
|
|
26
|
-
codeFuelDaysBack: {
|
|
27
|
-
type: DataTypes.INTEGER,
|
|
28
|
-
allowNull: true,
|
|
29
|
-
},
|
|
30
|
-
tonicDaysBack: {
|
|
31
|
-
type: DataTypes.INTEGER,
|
|
32
|
-
allowNull: true,
|
|
33
|
-
},
|
|
34
|
-
compadoDaysBack: { // Added missing column
|
|
35
|
-
type: DataTypes.INTEGER,
|
|
36
|
-
allowNull: true,
|
|
37
|
-
},
|
|
38
|
-
cfn2sDaysBack: { // Added missing column
|
|
39
|
-
type: DataTypes.INTEGER,
|
|
40
|
-
allowNull: true,
|
|
41
|
-
},
|
|
42
|
-
error: {
|
|
43
|
-
type: DataTypes.TEXT,
|
|
44
|
-
allowNull: true,
|
|
45
|
-
},
|
|
46
|
-
feedTimestamps: { // Added new column for feed timestamps
|
|
47
|
-
type: DataTypes.JSONB, // Use JSONB for PostgreSQL
|
|
48
|
-
allowNull: true,
|
|
49
|
-
field: 'feed_timestamps', // Map to snake_case column name
|
|
50
|
-
},
|
|
51
|
-
},
|
|
52
|
-
{
|
|
53
|
-
tableName: "pipeline_executions",
|
|
54
|
-
timestamps: true,
|
|
55
|
-
}
|
|
56
|
-
);
|
|
57
|
-
|
|
58
|
-
return PipelineExecution;
|
|
59
|
-
};
|
|
1
|
+
module.exports = (sequelize, DataTypes) => {
|
|
2
|
+
const PipelineExecution = sequelize.define(
|
|
3
|
+
"PipelineExecution",
|
|
4
|
+
{
|
|
5
|
+
id: {
|
|
6
|
+
type: DataTypes.UUID,
|
|
7
|
+
defaultValue: DataTypes.UUIDV4,
|
|
8
|
+
primaryKey: true,
|
|
9
|
+
},
|
|
10
|
+
startTime: {
|
|
11
|
+
type: DataTypes.DATE,
|
|
12
|
+
allowNull: false,
|
|
13
|
+
},
|
|
14
|
+
endTime: {
|
|
15
|
+
type: DataTypes.DATE,
|
|
16
|
+
allowNull: false,
|
|
17
|
+
},
|
|
18
|
+
status: {
|
|
19
|
+
type: DataTypes.ENUM("success", "failed"),
|
|
20
|
+
allowNull: false,
|
|
21
|
+
},
|
|
22
|
+
fbDaysBack: {
|
|
23
|
+
type: DataTypes.INTEGER,
|
|
24
|
+
allowNull: true,
|
|
25
|
+
},
|
|
26
|
+
codeFuelDaysBack: {
|
|
27
|
+
type: DataTypes.INTEGER,
|
|
28
|
+
allowNull: true,
|
|
29
|
+
},
|
|
30
|
+
tonicDaysBack: {
|
|
31
|
+
type: DataTypes.INTEGER,
|
|
32
|
+
allowNull: true,
|
|
33
|
+
},
|
|
34
|
+
compadoDaysBack: { // Added missing column
|
|
35
|
+
type: DataTypes.INTEGER,
|
|
36
|
+
allowNull: true,
|
|
37
|
+
},
|
|
38
|
+
cfn2sDaysBack: { // Added missing column
|
|
39
|
+
type: DataTypes.INTEGER,
|
|
40
|
+
allowNull: true,
|
|
41
|
+
},
|
|
42
|
+
error: {
|
|
43
|
+
type: DataTypes.TEXT,
|
|
44
|
+
allowNull: true,
|
|
45
|
+
},
|
|
46
|
+
feedTimestamps: { // Added new column for feed timestamps
|
|
47
|
+
type: DataTypes.JSONB, // Use JSONB for PostgreSQL
|
|
48
|
+
allowNull: true,
|
|
49
|
+
field: 'feed_timestamps', // Map to snake_case column name
|
|
50
|
+
},
|
|
51
|
+
},
|
|
52
|
+
{
|
|
53
|
+
tableName: "pipeline_executions",
|
|
54
|
+
timestamps: true,
|
|
55
|
+
}
|
|
56
|
+
);
|
|
57
|
+
|
|
58
|
+
return PipelineExecution;
|
|
59
|
+
};
|