2016-04-19 01:40:59 +00:00
|
|
|
|
|
|
|
-- +goose Up
|
|
|
|
-- SQL in section 'Up' is executed when this migration is applied
|
|
|
|
ALTER TABLE campaigns RENAME TO campaigns_old;
|
|
|
|
/*
|
2016-04-26 06:03:30 +00:00
|
|
|
The new campaigns table will rely on a "tasks" table that is basically a list of tasks to accomplish.
|
2016-04-19 01:40:59 +00:00
|
|
|
|
|
|
|
This will include sending emails, hosting landing pages, or possibly taking other action as needed,
|
|
|
|
including running scripts, sending HTTP requests, etc.
|
|
|
|
*/
|
2016-04-26 06:03:30 +00:00
|
|
|
CREATE TABLE campaigns ("id" integer primary key autoincrement, "user_id" bigint, "name" varchar(255) NOT NULL, "created_date" datetime, "completed_date" datetime, "task_id" bigint, "status" varchar(255));
|
2016-04-19 01:40:59 +00:00
|
|
|
|
|
|
|
INSERT INTO campaigns
|
|
|
|
(
|
|
|
|
id,
|
|
|
|
user_id,
|
|
|
|
name,
|
|
|
|
created_date,
|
|
|
|
completed_date,
|
|
|
|
status
|
|
|
|
)
|
|
|
|
SELECT
|
|
|
|
campaigns_old.id,
|
|
|
|
campaigns_old.user_id,
|
|
|
|
campaigns_old.name,
|
|
|
|
campaigns_old.created_date,
|
|
|
|
campaigns_old.completed_date,
|
|
|
|
campaigns_old.status
|
|
|
|
FROM campaigns_old;
|
|
|
|
|
2016-04-26 06:03:30 +00:00
|
|
|
/* Create our tasks table */
|
2016-04-19 01:40:59 +00:00
|
|
|
|
2016-04-26 06:03:30 +00:00
|
|
|
CREATE TABLE "tasks" ("id" integer primary key autoincrement,"user_id" bigint,"previous_id" bigint,"next_id" bigint,"campaign_id" bigint, "metadata" blob,"type" varchar(255));
|
2016-04-19 01:40:59 +00:00
|
|
|
|
2016-04-26 06:03:30 +00:00
|
|
|
/* Setup our email tasks */
|
2016-04-19 01:40:59 +00:00
|
|
|
|
2016-04-26 06:03:30 +00:00
|
|
|
INSERT INTO tasks (
|
2016-04-19 01:40:59 +00:00
|
|
|
user_id,
|
|
|
|
campaign_id,
|
2016-04-26 06:03:30 +00:00
|
|
|
type,
|
2016-04-19 01:40:59 +00:00
|
|
|
metadata
|
|
|
|
)
|
|
|
|
SELECT
|
|
|
|
campaigns_old.user_id,
|
|
|
|
campaigns_old.id,
|
|
|
|
"SEND_EMAIL",
|
|
|
|
'{' ||
|
|
|
|
'"smtp_id":' || campaigns_old.smtp_id || ',' ||
|
|
|
|
'"template_id":' || campaigns_old.template_id ||
|
|
|
|
'}'
|
|
|
|
FROM campaigns_old;
|
|
|
|
|
2016-04-26 06:03:30 +00:00
|
|
|
/* Point our campaigns to the SMTP tasks */
|
|
|
|
UPDATE campaigns
|
|
|
|
SET
|
|
|
|
task_id = (SELECT tasks.id FROM tasks
|
|
|
|
WHERE tasks.campaign_id = campaigns.id
|
|
|
|
AND tasks.type = "SEND_EMAIL"
|
|
|
|
);
|
|
|
|
|
|
|
|
/* Setup our landing page tasks */
|
2016-04-19 01:40:59 +00:00
|
|
|
|
2016-04-26 06:03:30 +00:00
|
|
|
INSERT INTO tasks (
|
2016-04-19 01:40:59 +00:00
|
|
|
user_id,
|
|
|
|
campaign_id,
|
2016-04-26 06:03:30 +00:00
|
|
|
type,
|
2016-04-19 01:40:59 +00:00
|
|
|
metadata,
|
|
|
|
previous_id
|
|
|
|
)
|
|
|
|
SELECT
|
|
|
|
campaigns_old.user_id,
|
|
|
|
campaigns_old.id as campaign_id,
|
|
|
|
"LANDING_PAGE",
|
|
|
|
'{' ||
|
|
|
|
'"page_id" : ' || campaigns_old.page_id || ',' ||
|
|
|
|
'"url" : "' || campaigns_old.url || '"' ||
|
|
|
|
'}',
|
2016-04-26 06:03:30 +00:00
|
|
|
tasks.id as task_id
|
|
|
|
FROM campaigns_old, tasks
|
|
|
|
WHERE tasks.id IN (
|
|
|
|
SELECT id FROM tasks
|
2016-04-19 01:40:59 +00:00
|
|
|
WHERE campaign_id=campaigns_old.id
|
2016-04-26 06:03:30 +00:00
|
|
|
AND type="SEND_EMAIL"
|
2016-04-19 01:40:59 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
/*
|
2016-04-26 06:03:30 +00:00
|
|
|
Next, we need to update our email tasks to point to the landing page
|
|
|
|
tasks.
|
2016-04-19 01:40:59 +00:00
|
|
|
*/
|
|
|
|
|
2016-04-26 06:03:30 +00:00
|
|
|
UPDATE tasks
|
2016-04-19 01:40:59 +00:00
|
|
|
SET
|
|
|
|
next_id = (
|
2016-04-26 06:03:30 +00:00
|
|
|
SELECT t2.id
|
|
|
|
FROM tasks AS t2
|
|
|
|
WHERE t2.previous_id=tasks.id
|
|
|
|
AND t2.campaign_id = tasks.campaign_id
|
|
|
|
AND t2.type = "LANDING_PAGE"
|
2016-04-19 01:40:59 +00:00
|
|
|
)
|
2016-04-26 06:03:30 +00:00
|
|
|
WHERE type = "SEND_EMAIL";
|
|
|
|
|
|
|
|
/* Finally, we drop our temp table */
|
|
|
|
DROP TABLE campaigns_old;
|
2016-04-19 01:40:59 +00:00
|
|
|
|
|
|
|
-- +goose Down
|
|
|
|
-- SQL section 'Down' is executed when this migration is rolled back
|
|
|
|
|