agrs-sequelize-sdk 1.1.95 → 1.1.97
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/models/Ad.js +9 -73
- package/models/AdSet.js +0 -144
- package/models/RSOCFeedCampaign.js +10 -1
- package/package.json +1 -1
- package/agrs-sequelize/LICENSE +0 -21
- package/agrs-sequelize/README.md +0 -179
- package/agrs-sequelize/index.js +0 -169
- package/agrs-sequelize/jq.exe +0 -0
- package/agrs-sequelize/models/ActivityHistory.js +0 -73
- package/agrs-sequelize/models/Ad.js +0 -209
- package/agrs-sequelize/models/AdAccount.js +0 -91
- package/agrs-sequelize/models/AdAccountValues.js +0 -26
- package/agrs-sequelize/models/AdHistory.js +0 -30
- package/agrs-sequelize/models/AdPerformance.js +0 -84
- package/agrs-sequelize/models/AdPerformanceHourly.js +0 -66
- package/agrs-sequelize/models/AdSet.js +0 -140
- package/agrs-sequelize/models/AdSetHistory.js +0 -30
- package/agrs-sequelize/models/AdsetPerformance.js +0 -116
- package/agrs-sequelize/models/Article.js +0 -156
- package/agrs-sequelize/models/Buyers.js +0 -26
- package/agrs-sequelize/models/Campaign.js +0 -136
- package/agrs-sequelize/models/CampaignCreationLog.js +0 -86
- package/agrs-sequelize/models/CampaignHistory.js +0 -33
- package/agrs-sequelize/models/Channel.js +0 -55
- package/agrs-sequelize/models/CodefuelCampaign.js +0 -159
- package/agrs-sequelize/models/CodefuelCampaignKWHistory.js +0 -41
- package/agrs-sequelize/models/CodefuelKeywords.js +0 -35
- package/agrs-sequelize/models/CurrencyRate.js +0 -27
- package/agrs-sequelize/models/Domain.js +0 -26
- package/agrs-sequelize/models/ExplorAdsChannel.js +0 -62
- package/agrs-sequelize/models/Feed.js +0 -34
- package/agrs-sequelize/models/Files.js +0 -73
- package/agrs-sequelize/models/Folders.js +0 -133
- package/agrs-sequelize/models/KeywordPerformance.js +0 -99
- package/agrs-sequelize/models/KeywordRotationState.js +0 -51
- package/agrs-sequelize/models/Pages.js +0 -74
- package/agrs-sequelize/models/PipelineExecution.js +0 -46
- package/agrs-sequelize/models/RSOCFeedCampaign.js +0 -302
- package/agrs-sequelize/models/RsocKeywordPerformance.js +0 -111
- package/agrs-sequelize/models/Rule.js +0 -39
- package/agrs-sequelize/models/RulesValues.js +0 -56
- package/agrs-sequelize/models/SupportedLocale.js +0 -24
- package/agrs-sequelize/models/TonicCampaign.js +0 -97
- package/agrs-sequelize/models/Users.js +0 -111
- package/agrs-sequelize/models/Vertical.js +0 -26
- package/agrs-sequelize/models/newFiles.js +0 -68
- package/agrs-sequelize/models/pixel.js +0 -33
- package/agrs-sequelize/models/pixels.js +0 -33
- package/agrs-sequelize/package-lock.json +0 -405
- package/agrs-sequelize/package.json +0 -19
- package/agrs-sequelize/run.ps1 +0 -98
- package/agrs-sequelize/run.sh +0 -214
|
@@ -1,66 +0,0 @@
|
|
|
1
|
-
// models/AdPerformanceHourly.js
|
|
2
|
-
module.exports = (sequelize, DataTypes) => {
|
|
3
|
-
const AdPerformanceHourly = sequelize.define(
|
|
4
|
-
"AdPerformanceHourly",
|
|
5
|
-
{
|
|
6
|
-
Date: {
|
|
7
|
-
type: DataTypes.DATEONLY,
|
|
8
|
-
primaryKey: true,
|
|
9
|
-
},
|
|
10
|
-
Hour: {
|
|
11
|
-
type: DataTypes.INTEGER,
|
|
12
|
-
primaryKey: true,
|
|
13
|
-
},
|
|
14
|
-
AdID: {
|
|
15
|
-
type: DataTypes.STRING,
|
|
16
|
-
primaryKey: true,
|
|
17
|
-
},
|
|
18
|
-
AmountSpent: {
|
|
19
|
-
type: DataTypes.FLOAT,
|
|
20
|
-
allowNull: true,
|
|
21
|
-
},
|
|
22
|
-
Impressions: {
|
|
23
|
-
type: DataTypes.INTEGER,
|
|
24
|
-
allowNull: true,
|
|
25
|
-
},
|
|
26
|
-
LinkClicks: {
|
|
27
|
-
type: DataTypes.INTEGER,
|
|
28
|
-
allowNull: true,
|
|
29
|
-
},
|
|
30
|
-
ViewContent: {
|
|
31
|
-
// New field
|
|
32
|
-
type: DataTypes.INTEGER,
|
|
33
|
-
allowNull: true,
|
|
34
|
-
},
|
|
35
|
-
Search: {
|
|
36
|
-
// New field
|
|
37
|
-
type: DataTypes.INTEGER,
|
|
38
|
-
allowNull: true,
|
|
39
|
-
},
|
|
40
|
-
Purchase: {
|
|
41
|
-
// New field
|
|
42
|
-
type: DataTypes.INTEGER,
|
|
43
|
-
allowNull: true,
|
|
44
|
-
},
|
|
45
|
-
originalSpend: {
|
|
46
|
-
type: DataTypes.FLOAT,
|
|
47
|
-
allowNull: true,
|
|
48
|
-
},
|
|
49
|
-
},
|
|
50
|
-
{
|
|
51
|
-
tableName: "AdPerformanceHourly",
|
|
52
|
-
indexes: [
|
|
53
|
-
{
|
|
54
|
-
unique: true,
|
|
55
|
-
fields: ["AdID", "Date", "Hour"],
|
|
56
|
-
},
|
|
57
|
-
],
|
|
58
|
-
}
|
|
59
|
-
);
|
|
60
|
-
|
|
61
|
-
AdPerformanceHourly.associate = (models) => {
|
|
62
|
-
AdPerformanceHourly.belongsTo(models.Ad, { foreignKey: "AdID" });
|
|
63
|
-
};
|
|
64
|
-
|
|
65
|
-
return AdPerformanceHourly;
|
|
66
|
-
};
|
|
@@ -1,140 +0,0 @@
|
|
|
1
|
-
module.exports = (sequelize, DataTypes) => {
|
|
2
|
-
const AdSet = sequelize.define(
|
|
3
|
-
"AdSet",
|
|
4
|
-
{
|
|
5
|
-
AdSetID: {
|
|
6
|
-
type: DataTypes.STRING,
|
|
7
|
-
primaryKey: true,
|
|
8
|
-
},
|
|
9
|
-
AdSetName: {
|
|
10
|
-
type: DataTypes.STRING,
|
|
11
|
-
allowNull: true,
|
|
12
|
-
},
|
|
13
|
-
Status: {
|
|
14
|
-
type: DataTypes.STRING,
|
|
15
|
-
allowNull: true,
|
|
16
|
-
},
|
|
17
|
-
daily_budget: {
|
|
18
|
-
type: DataTypes.INTEGER,
|
|
19
|
-
allowNull: true,
|
|
20
|
-
},
|
|
21
|
-
start_time: {
|
|
22
|
-
type: DataTypes.DATE,
|
|
23
|
-
allowNull: true,
|
|
24
|
-
},
|
|
25
|
-
end_time: {
|
|
26
|
-
type: DataTypes.DATE,
|
|
27
|
-
allowNull: true,
|
|
28
|
-
},
|
|
29
|
-
targeting: {
|
|
30
|
-
type: DataTypes.JSONB,
|
|
31
|
-
allowNull: true,
|
|
32
|
-
},
|
|
33
|
-
promotedObject: {
|
|
34
|
-
type: DataTypes.JSONB,
|
|
35
|
-
allowNull: true,
|
|
36
|
-
},
|
|
37
|
-
BillingEvent: {
|
|
38
|
-
type: DataTypes.STRING,
|
|
39
|
-
allowNull: false,
|
|
40
|
-
defaultValue: "impressions",
|
|
41
|
-
},
|
|
42
|
-
OptimizationGoal: {
|
|
43
|
-
type: DataTypes.STRING,
|
|
44
|
-
allowNull: false,
|
|
45
|
-
defaultValue: "offsite_conversions",
|
|
46
|
-
},
|
|
47
|
-
Draft: {
|
|
48
|
-
type: DataTypes.BOOLEAN,
|
|
49
|
-
allowNull: true,
|
|
50
|
-
defaultValue: false,
|
|
51
|
-
},
|
|
52
|
-
UserCreated: {
|
|
53
|
-
type: DataTypes.STRING,
|
|
54
|
-
allowNull: true,
|
|
55
|
-
},
|
|
56
|
-
publish: {
|
|
57
|
-
type: DataTypes.BOOLEAN,
|
|
58
|
-
allowNull: true,
|
|
59
|
-
defaultValue: true,
|
|
60
|
-
},
|
|
61
|
-
CampaignID: {
|
|
62
|
-
type: DataTypes.STRING,
|
|
63
|
-
allowNull: false,
|
|
64
|
-
references: {
|
|
65
|
-
model: "Campaign",
|
|
66
|
-
key: "CampaignID",
|
|
67
|
-
},
|
|
68
|
-
},
|
|
69
|
-
effectiveStatus: {
|
|
70
|
-
type: DataTypes.STRING,
|
|
71
|
-
allowNull: true,
|
|
72
|
-
},
|
|
73
|
-
issuesInfo: {
|
|
74
|
-
type: DataTypes.JSONB,
|
|
75
|
-
allowNull: true,
|
|
76
|
-
},
|
|
77
|
-
bid_strategy: {
|
|
78
|
-
type: DataTypes.STRING,
|
|
79
|
-
allowNull: true,
|
|
80
|
-
},
|
|
81
|
-
bid_amount: {
|
|
82
|
-
type: DataTypes.INTEGER,
|
|
83
|
-
allowNull: true,
|
|
84
|
-
},
|
|
85
|
-
waiting: {
|
|
86
|
-
type: DataTypes.BOOLEAN,
|
|
87
|
-
defaultValue: false,
|
|
88
|
-
},
|
|
89
|
-
},
|
|
90
|
-
{
|
|
91
|
-
tableName: "AdSet",
|
|
92
|
-
indexes: [
|
|
93
|
-
{
|
|
94
|
-
fields: ["CampaignID"],
|
|
95
|
-
},
|
|
96
|
-
],
|
|
97
|
-
}
|
|
98
|
-
);
|
|
99
|
-
|
|
100
|
-
AdSet.associate = (models) => {
|
|
101
|
-
AdSet.belongsTo(models.Campaign, { foreignKey: "CampaignID" });
|
|
102
|
-
AdSet.hasMany(models.Ad, { foreignKey: "AdSetID" });
|
|
103
|
-
// Add this line to define the relationship with AdSetPerformance
|
|
104
|
-
AdSet.hasMany(models.AdSetPerformance, { foreignKey: "AdSetID" });
|
|
105
|
-
};
|
|
106
|
-
|
|
107
|
-
AdSet.addHook("beforeUpdate", async (adSet, options) => {
|
|
108
|
-
if (adSet.changed("publish")) {
|
|
109
|
-
if (adSet.previous("publish") === true && adSet.publish === false) {
|
|
110
|
-
await sequelize.models.AdSetHistory.create({
|
|
111
|
-
AdSetID: adSet.AdSetID,
|
|
112
|
-
DataSnapshot: adSet._previousDataValues,
|
|
113
|
-
});
|
|
114
|
-
} else if (
|
|
115
|
-
adSet.previous("publish") === false &&
|
|
116
|
-
adSet.publish === true
|
|
117
|
-
) {
|
|
118
|
-
const latestHistory = await sequelize.models.AdSetHistory.findOne({
|
|
119
|
-
where: { AdSetID: adSet.AdSetID },
|
|
120
|
-
order: [["timestamp", "DESC"]],
|
|
121
|
-
});
|
|
122
|
-
|
|
123
|
-
if (latestHistory) {
|
|
124
|
-
await latestHistory.destroy();
|
|
125
|
-
}
|
|
126
|
-
}
|
|
127
|
-
}
|
|
128
|
-
});
|
|
129
|
-
|
|
130
|
-
AdSet.addHook("afterCreate", async (adSet, options) => {
|
|
131
|
-
if (adSet.publish === false) {
|
|
132
|
-
await sequelize.models.AdSetHistory.create({
|
|
133
|
-
AdSetID: adSet.AdSetID,
|
|
134
|
-
DataSnapshot: adSet.toJSON(),
|
|
135
|
-
});
|
|
136
|
-
}
|
|
137
|
-
});
|
|
138
|
-
|
|
139
|
-
return AdSet;
|
|
140
|
-
};
|
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
module.exports = (sequelize, DataTypes) => {
|
|
2
|
-
const AdSetHistory = sequelize.define(
|
|
3
|
-
"AdSetHistory",
|
|
4
|
-
{
|
|
5
|
-
HistoryID: {
|
|
6
|
-
type: DataTypes.UUID,
|
|
7
|
-
defaultValue: DataTypes.UUIDV4,
|
|
8
|
-
primaryKey: true,
|
|
9
|
-
},
|
|
10
|
-
AdSetID: {
|
|
11
|
-
type: DataTypes.STRING,
|
|
12
|
-
allowNull: false,
|
|
13
|
-
},
|
|
14
|
-
DataSnapshot: {
|
|
15
|
-
type: DataTypes.JSONB, // Store the full AdSet row as a JSON object
|
|
16
|
-
allowNull: false,
|
|
17
|
-
},
|
|
18
|
-
timestamp: {
|
|
19
|
-
type: DataTypes.DATE,
|
|
20
|
-
defaultValue: DataTypes.NOW,
|
|
21
|
-
},
|
|
22
|
-
},
|
|
23
|
-
{
|
|
24
|
-
tableName: "AdSetHistory",
|
|
25
|
-
timestamps: false,
|
|
26
|
-
}
|
|
27
|
-
);
|
|
28
|
-
|
|
29
|
-
return AdSetHistory;
|
|
30
|
-
};
|
|
@@ -1,116 +0,0 @@
|
|
|
1
|
-
module.exports = (sequelize, DataTypes) => {
|
|
2
|
-
const AdSetPerformance = sequelize.define(
|
|
3
|
-
"AdSetPerformance",
|
|
4
|
-
{
|
|
5
|
-
AdSetID: {
|
|
6
|
-
type: DataTypes.STRING,
|
|
7
|
-
allowNull: false,
|
|
8
|
-
primaryKey: true,
|
|
9
|
-
// Part of the composite primary key identifying the AdSet
|
|
10
|
-
},
|
|
11
|
-
Date: {
|
|
12
|
-
type: DataTypes.DATEONLY,
|
|
13
|
-
allowNull: false,
|
|
14
|
-
primaryKey: true,
|
|
15
|
-
// Part of the composite primary key representing the performance date
|
|
16
|
-
},
|
|
17
|
-
ChannelID: {
|
|
18
|
-
type: DataTypes.STRING,
|
|
19
|
-
allowNull: true,
|
|
20
|
-
// Optional identifier for the channel, extracted from AdSet name if available
|
|
21
|
-
},
|
|
22
|
-
StyleID: {
|
|
23
|
-
type: DataTypes.STRING,
|
|
24
|
-
allowNull: true,
|
|
25
|
-
// Optional identifier for the style, extracted from AdSet name if available
|
|
26
|
-
},
|
|
27
|
-
Spend: {
|
|
28
|
-
type: DataTypes.FLOAT,
|
|
29
|
-
defaultValue: 0,
|
|
30
|
-
// Total spend on the AdSet from the source platform (e.g., Facebook)
|
|
31
|
-
},
|
|
32
|
-
Impressions: {
|
|
33
|
-
type: DataTypes.INTEGER,
|
|
34
|
-
defaultValue: 0,
|
|
35
|
-
// Number of impressions recorded by the source platform
|
|
36
|
-
},
|
|
37
|
-
LinkClicks: {
|
|
38
|
-
type: DataTypes.INTEGER,
|
|
39
|
-
defaultValue: 0,
|
|
40
|
-
// Number of link clicks recorded by the source platform
|
|
41
|
-
},
|
|
42
|
-
ViewContent: {
|
|
43
|
-
type: DataTypes.INTEGER,
|
|
44
|
-
defaultValue: 0,
|
|
45
|
-
// Number of view content events recorded by the source platform
|
|
46
|
-
},
|
|
47
|
-
Search: {
|
|
48
|
-
type: DataTypes.INTEGER,
|
|
49
|
-
defaultValue: 0,
|
|
50
|
-
// Number of search events recorded by the source platform
|
|
51
|
-
},
|
|
52
|
-
Purchase: {
|
|
53
|
-
type: DataTypes.INTEGER,
|
|
54
|
-
defaultValue: 0,
|
|
55
|
-
// Number of purchase events recorded by the source platform
|
|
56
|
-
},
|
|
57
|
-
ExternalRevenue: {
|
|
58
|
-
type: DataTypes.FLOAT,
|
|
59
|
-
defaultValue: 0,
|
|
60
|
-
// Revenue data from an external source (e.g., analytics or monetization platforms)
|
|
61
|
-
},
|
|
62
|
-
ExternalImpressions: {
|
|
63
|
-
type: DataTypes.INTEGER,
|
|
64
|
-
defaultValue: 0,
|
|
65
|
-
// Number of impressions recorded by an external source
|
|
66
|
-
},
|
|
67
|
-
ExternalClicks: {
|
|
68
|
-
type: DataTypes.INTEGER,
|
|
69
|
-
defaultValue: 0,
|
|
70
|
-
// Number of clicks recorded by an external source
|
|
71
|
-
},
|
|
72
|
-
ExternalRequests: {
|
|
73
|
-
type: DataTypes.INTEGER,
|
|
74
|
-
defaultValue: 0,
|
|
75
|
-
// Number of requests recorded by an external source
|
|
76
|
-
},
|
|
77
|
-
ROI: {
|
|
78
|
-
type: DataTypes.FLOAT,
|
|
79
|
-
defaultValue: 0,
|
|
80
|
-
// Calculated Return on Investment (ExternalRevenue / Spend)
|
|
81
|
-
},
|
|
82
|
-
agrscid: {
|
|
83
|
-
type: DataTypes.STRING,
|
|
84
|
-
allowNull: true,
|
|
85
|
-
// Optional identifier for the AdSet, extracted from AdSet url if available
|
|
86
|
-
},
|
|
87
|
-
originalRevenue: {
|
|
88
|
-
type: DataTypes.FLOAT,
|
|
89
|
-
defaultValue: 0,
|
|
90
|
-
// Original revenue value before any modifications or calculations
|
|
91
|
-
}
|
|
92
|
-
},
|
|
93
|
-
{
|
|
94
|
-
tableName: "AdSetPerformance",
|
|
95
|
-
timestamps: false, // No need for createdAt/updatedAt timestamps
|
|
96
|
-
indexes: [
|
|
97
|
-
{
|
|
98
|
-
unique: true,
|
|
99
|
-
fields: ["AdSetID", "Date"],
|
|
100
|
-
// Composite unique index to ensure one record per AdSet per date
|
|
101
|
-
},
|
|
102
|
-
],
|
|
103
|
-
}
|
|
104
|
-
);
|
|
105
|
-
|
|
106
|
-
// Define associations with other models
|
|
107
|
-
AdSetPerformance.associate = (models) => {
|
|
108
|
-
AdSetPerformance.belongsTo(models.AdSet, {
|
|
109
|
-
foreignKey: "AdSetID",
|
|
110
|
-
targetKey: "AdSetID",
|
|
111
|
-
// Links to the AdSet model for additional AdSet details
|
|
112
|
-
});
|
|
113
|
-
};
|
|
114
|
-
|
|
115
|
-
return AdSetPerformance;
|
|
116
|
-
};
|
|
@@ -1,156 +0,0 @@
|
|
|
1
|
-
module.exports = (sequelize, DataTypes) => {
|
|
2
|
-
const Article = sequelize.define(
|
|
3
|
-
"Article",
|
|
4
|
-
{
|
|
5
|
-
providerId: {
|
|
6
|
-
type: DataTypes.STRING,
|
|
7
|
-
allowNull: true,
|
|
8
|
-
unique: true,
|
|
9
|
-
},
|
|
10
|
-
category: {
|
|
11
|
-
type: DataTypes.STRING,
|
|
12
|
-
allowNull: true,
|
|
13
|
-
},
|
|
14
|
-
AGRSAID: {
|
|
15
|
-
type: DataTypes.STRING,
|
|
16
|
-
allowNull: false,
|
|
17
|
-
unique: true,
|
|
18
|
-
},
|
|
19
|
-
articleUrl: {
|
|
20
|
-
type: DataTypes.STRING(1024),
|
|
21
|
-
allowNull: true,
|
|
22
|
-
},
|
|
23
|
-
feed: {
|
|
24
|
-
type: DataTypes.STRING,
|
|
25
|
-
allowNull: false,
|
|
26
|
-
},
|
|
27
|
-
feedName: {
|
|
28
|
-
type: DataTypes.STRING,
|
|
29
|
-
allowNull: false,
|
|
30
|
-
},
|
|
31
|
-
vertical: {
|
|
32
|
-
type: DataTypes.STRING,
|
|
33
|
-
allowNull: false,
|
|
34
|
-
},
|
|
35
|
-
language: {
|
|
36
|
-
type: DataTypes.STRING,
|
|
37
|
-
allowNull: false,
|
|
38
|
-
defaultValue: "en",
|
|
39
|
-
},
|
|
40
|
-
headline: {
|
|
41
|
-
type: DataTypes.STRING,
|
|
42
|
-
allowNull: true,
|
|
43
|
-
},
|
|
44
|
-
topics: {
|
|
45
|
-
type: DataTypes.ARRAY(DataTypes.STRING),
|
|
46
|
-
allowNull: true,
|
|
47
|
-
},
|
|
48
|
-
mainKeyword: {
|
|
49
|
-
type: DataTypes.STRING,
|
|
50
|
-
allowNull: true,
|
|
51
|
-
},
|
|
52
|
-
keywords: {
|
|
53
|
-
type: DataTypes.ARRAY(DataTypes.STRING),
|
|
54
|
-
allowNull: true,
|
|
55
|
-
},
|
|
56
|
-
date: {
|
|
57
|
-
type: DataTypes.DATE,
|
|
58
|
-
allowNull: true,
|
|
59
|
-
defaultValue: DataTypes.NOW,
|
|
60
|
-
},
|
|
61
|
-
nativeKeyword: {
|
|
62
|
-
type: DataTypes.STRING,
|
|
63
|
-
allowNull: false,
|
|
64
|
-
},
|
|
65
|
-
suggestedKeywords: {
|
|
66
|
-
type: DataTypes.STRING,
|
|
67
|
-
allowNull: true,
|
|
68
|
-
},
|
|
69
|
-
articleExcerpt: {
|
|
70
|
-
type: DataTypes.TEXT,
|
|
71
|
-
allowNull: true,
|
|
72
|
-
},
|
|
73
|
-
articleContent: {
|
|
74
|
-
type: DataTypes.TEXT,
|
|
75
|
-
allowNull: true,
|
|
76
|
-
},
|
|
77
|
-
fbPixelId: {
|
|
78
|
-
type: DataTypes.STRING,
|
|
79
|
-
allowNull: true,
|
|
80
|
-
},
|
|
81
|
-
status: {
|
|
82
|
-
type: DataTypes.STRING,
|
|
83
|
-
allowNull: false,
|
|
84
|
-
defaultValue: "pending",
|
|
85
|
-
validate: {
|
|
86
|
-
isIn: [
|
|
87
|
-
[
|
|
88
|
-
"pending",
|
|
89
|
-
"approved",
|
|
90
|
-
"rejected",
|
|
91
|
-
"disapproved",
|
|
92
|
-
"duplicated",
|
|
93
|
-
"keyword_already_exists",
|
|
94
|
-
"invalid_vertical",
|
|
95
|
-
"invalid_language",
|
|
96
|
-
"in_review",
|
|
97
|
-
"error",
|
|
98
|
-
],
|
|
99
|
-
],
|
|
100
|
-
},
|
|
101
|
-
},
|
|
102
|
-
originalStatus: {
|
|
103
|
-
type: DataTypes.STRING,
|
|
104
|
-
allowNull: true,
|
|
105
|
-
comment: "Original status from Predicto before any mapping",
|
|
106
|
-
},
|
|
107
|
-
creationType: {
|
|
108
|
-
type: DataTypes.STRING,
|
|
109
|
-
allowNull: false,
|
|
110
|
-
defaultValue: "slug",
|
|
111
|
-
validate: {
|
|
112
|
-
isIn: [["search", "slug"]],
|
|
113
|
-
},
|
|
114
|
-
},
|
|
115
|
-
createdAt: {
|
|
116
|
-
type: DataTypes.DATE,
|
|
117
|
-
defaultValue: DataTypes.NOW,
|
|
118
|
-
},
|
|
119
|
-
updatedAt: {
|
|
120
|
-
type: DataTypes.DATE,
|
|
121
|
-
defaultValue: DataTypes.NOW,
|
|
122
|
-
},
|
|
123
|
-
buyer: {
|
|
124
|
-
type: DataTypes.STRING,
|
|
125
|
-
allowNull: true,
|
|
126
|
-
},
|
|
127
|
-
country: {
|
|
128
|
-
type: DataTypes.STRING,
|
|
129
|
-
allowNull: true,
|
|
130
|
-
},
|
|
131
|
-
name: {
|
|
132
|
-
type: DataTypes.STRING,
|
|
133
|
-
allowNull: true,
|
|
134
|
-
},
|
|
135
|
-
},
|
|
136
|
-
{
|
|
137
|
-
tableName: "articles",
|
|
138
|
-
timestamps: true,
|
|
139
|
-
}
|
|
140
|
-
);
|
|
141
|
-
|
|
142
|
-
Article.associate = (models) => {
|
|
143
|
-
Article.hasMany(models.RSOCFeedCampaign, {
|
|
144
|
-
foreignKey: "AGRSAID",
|
|
145
|
-
sourceKey: "AGRSAID",
|
|
146
|
-
as: "RSOCFeedCampaigns",
|
|
147
|
-
constraints: false,
|
|
148
|
-
});
|
|
149
|
-
};
|
|
150
|
-
|
|
151
|
-
Article.prototype.isAvailableForCampaign = function () {
|
|
152
|
-
return ["approved", "keyword_already_exists"].includes(this.status);
|
|
153
|
-
};
|
|
154
|
-
|
|
155
|
-
return Article;
|
|
156
|
-
};
|
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
module.exports = (sequelize, DataTypes) => {
|
|
2
|
-
const Buyers = sequelize.define(
|
|
3
|
-
"Buyers",
|
|
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
|
-
},
|
|
20
|
-
{
|
|
21
|
-
tableName: "Buyers",
|
|
22
|
-
}
|
|
23
|
-
);
|
|
24
|
-
|
|
25
|
-
return Buyers;
|
|
26
|
-
};
|
|
@@ -1,136 +0,0 @@
|
|
|
1
|
-
module.exports = (sequelize, DataTypes) => {
|
|
2
|
-
const Campaign = sequelize.define(
|
|
3
|
-
"Campaign",
|
|
4
|
-
{
|
|
5
|
-
CampaignID: {
|
|
6
|
-
type: DataTypes.STRING,
|
|
7
|
-
primaryKey: true,
|
|
8
|
-
},
|
|
9
|
-
CampaignName: {
|
|
10
|
-
type: DataTypes.STRING,
|
|
11
|
-
allowNull: true,
|
|
12
|
-
},
|
|
13
|
-
pixelId: {
|
|
14
|
-
type: DataTypes.STRING,
|
|
15
|
-
allowNull: true,
|
|
16
|
-
},
|
|
17
|
-
customEventType: {
|
|
18
|
-
type: DataTypes.STRING,
|
|
19
|
-
allowNull: false,
|
|
20
|
-
defaultValue: "PURCHASE",
|
|
21
|
-
},
|
|
22
|
-
objective: {
|
|
23
|
-
type: DataTypes.STRING,
|
|
24
|
-
allowNull: false,
|
|
25
|
-
defaultValue: "OUTCOME_SALES",
|
|
26
|
-
},
|
|
27
|
-
status: {
|
|
28
|
-
type: DataTypes.STRING,
|
|
29
|
-
allowNull: true,
|
|
30
|
-
},
|
|
31
|
-
AdAccountID: {
|
|
32
|
-
type: DataTypes.STRING,
|
|
33
|
-
allowNull: false,
|
|
34
|
-
references: {
|
|
35
|
-
model: "AdAccount",
|
|
36
|
-
key: "AdAccountID",
|
|
37
|
-
},
|
|
38
|
-
},
|
|
39
|
-
CreatedTime: {
|
|
40
|
-
type: DataTypes.DATE,
|
|
41
|
-
allowNull: false,
|
|
42
|
-
},
|
|
43
|
-
CampaignDelivery: {
|
|
44
|
-
type: DataTypes.STRING,
|
|
45
|
-
allowNull: true,
|
|
46
|
-
},
|
|
47
|
-
DailyBudget: {
|
|
48
|
-
type: DataTypes.INTEGER,
|
|
49
|
-
allowNull: true,
|
|
50
|
-
},
|
|
51
|
-
Draft: {
|
|
52
|
-
type: DataTypes.BOOLEAN,
|
|
53
|
-
allowNull: true,
|
|
54
|
-
defaultValue: false,
|
|
55
|
-
},
|
|
56
|
-
publish: {
|
|
57
|
-
type: DataTypes.BOOLEAN,
|
|
58
|
-
allowNull: true,
|
|
59
|
-
defaultValue: true,
|
|
60
|
-
},
|
|
61
|
-
UserCreated: {
|
|
62
|
-
type: DataTypes.STRING,
|
|
63
|
-
allowNull: true,
|
|
64
|
-
},
|
|
65
|
-
special_ad_categories: {
|
|
66
|
-
type: DataTypes.ARRAY(DataTypes.STRING),
|
|
67
|
-
allowNull: true,
|
|
68
|
-
},
|
|
69
|
-
effectiveStatus: {
|
|
70
|
-
type: DataTypes.STRING,
|
|
71
|
-
allowNull: true,
|
|
72
|
-
},
|
|
73
|
-
issuesInfo: {
|
|
74
|
-
type: DataTypes.JSONB,
|
|
75
|
-
allowNull: true,
|
|
76
|
-
},
|
|
77
|
-
waiting: {
|
|
78
|
-
type: DataTypes.BOOLEAN,
|
|
79
|
-
defaultValue: false,
|
|
80
|
-
},
|
|
81
|
-
},
|
|
82
|
-
{
|
|
83
|
-
tableName: "Campaign",
|
|
84
|
-
indexes: [
|
|
85
|
-
{
|
|
86
|
-
fields: ["AdAccountID"], // Index on AdAccountID for faster joins
|
|
87
|
-
},
|
|
88
|
-
],
|
|
89
|
-
}
|
|
90
|
-
);
|
|
91
|
-
|
|
92
|
-
// Define associations
|
|
93
|
-
Campaign.associate = (models) => {
|
|
94
|
-
Campaign.belongsTo(models.AdAccount, { foreignKey: "AdAccountID" });
|
|
95
|
-
Campaign.hasMany(models.AdSet, { foreignKey: "CampaignID" });
|
|
96
|
-
};
|
|
97
|
-
|
|
98
|
-
// Combined beforeUpdate hook
|
|
99
|
-
Campaign.addHook("beforeUpdate", async (campaign, options) => {
|
|
100
|
-
if (campaign.changed("publish")) {
|
|
101
|
-
if (campaign.previous("publish") === true && campaign.publish === false) {
|
|
102
|
-
// Save current state to CampaignHistory
|
|
103
|
-
await sequelize.models.CampaignHistory.create({
|
|
104
|
-
CampaignID: campaign.CampaignID,
|
|
105
|
-
DataSnapshot: campaign._previousDataValues, // Store current state as JSON
|
|
106
|
-
});
|
|
107
|
-
} else if (
|
|
108
|
-
campaign.previous("publish") === false &&
|
|
109
|
-
campaign.publish === true
|
|
110
|
-
) {
|
|
111
|
-
// Delete the latest history entry
|
|
112
|
-
const latestHistory = await sequelize.models.CampaignHistory.findOne({
|
|
113
|
-
where: { CampaignID: campaign.CampaignID },
|
|
114
|
-
order: [["timestamp", "DESC"]], // Get the latest history entry
|
|
115
|
-
});
|
|
116
|
-
|
|
117
|
-
if (latestHistory) {
|
|
118
|
-
await latestHistory.destroy(); // Delete the latest history entry
|
|
119
|
-
}
|
|
120
|
-
}
|
|
121
|
-
}
|
|
122
|
-
});
|
|
123
|
-
|
|
124
|
-
Campaign.addHook("afterCreate", async (campaign, options) => {
|
|
125
|
-
if (campaign.publish === false) {
|
|
126
|
-
// If publish is false on creation, save a snapshot to CampaignHistory
|
|
127
|
-
await sequelize.models.CampaignHistory.create({
|
|
128
|
-
CampaignID: campaign.CampaignID,
|
|
129
|
-
DataSnapshot: campaign.toJSON(), // Save current state
|
|
130
|
-
});
|
|
131
|
-
}
|
|
132
|
-
});
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
return Campaign;
|
|
136
|
-
};
|