forked from vmware-archive/atc
-
Notifications
You must be signed in to change notification settings - Fork 0
/
123_add_config_to_jobs_resources.go
139 lines (118 loc) · 2.78 KB
/
123_add_config_to_jobs_resources.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
package migrations
import (
"encoding/json"
"github.com/concourse/atc"
"github.com/concourse/atc/db/migration"
)
func AddConfigToJobsResources(tx migration.LimitedTx) error {
_, err := tx.Exec(`
ALTER TABLE resources
ADD COLUMN config json NOT NULL DEFAULT '{}',
ADD COLUMN active bool NOT NULL DEFAULT false;
`)
if err != nil {
return err
}
_, err = tx.Exec(`
ALTER TABLE resource_types
ADD COLUMN config json NOT NULL DEFAULT '{}',
ADD COLUMN active bool NOT NULL DEFAULT false;
`)
if err != nil {
return err
}
_, err = tx.Exec(`
ALTER TABLE jobs
ADD COLUMN config json NOT NULL DEFAULT '{}',
ADD COLUMN active bool NOT NULL DEFAULT false;
`)
if err != nil {
return err
}
rows, err := tx.Query(`
SELECT id, config
FROM pipelines
`)
if err != nil {
return err
}
defer rows.Close()
pipelineConfigs := map[int]atc.Config{}
for rows.Next() {
var pipelineID int
var pipelineConfigPayload []byte
err := rows.Scan(&pipelineID, &pipelineConfigPayload)
if err != nil {
return err
}
var pipelineConfig atc.Config
err = json.Unmarshal(pipelineConfigPayload, &pipelineConfig)
if err != nil {
return err
}
pipelineConfigs[pipelineID] = pipelineConfig
}
for pipelineID, pipelineConfig := range pipelineConfigs {
for _, jobConfig := range pipelineConfig.Jobs {
jobConfigPayload, err := json.Marshal(jobConfig)
if err != nil {
return err
}
_, err = tx.Exec(`
UPDATE jobs
SET config = $1, active = true
WHERE name = $2 AND pipeline_id = $3
`, jobConfigPayload, jobConfig.Name, pipelineID)
if err != nil {
return err
}
for _, resourceConfig := range pipelineConfig.Resources {
resourceConfigPayload, err := json.Marshal(resourceConfig)
if err != nil {
return err
}
_, err = tx.Exec(`
UPDATE resources
SET config = $1, active = true
WHERE name = $2 AND pipeline_id = $3
`, resourceConfigPayload, resourceConfig.Name, pipelineID)
if err != nil {
return err
}
}
for _, resourceTypeConfig := range pipelineConfig.ResourceTypes {
resourceTypeConfigPayload, err := json.Marshal(resourceTypeConfig)
if err != nil {
return err
}
_, err = tx.Exec(`
UPDATE resource_types
SET config = $1, active = true
WHERE name = $2 AND pipeline_id = $3
`, resourceTypeConfigPayload, resourceTypeConfig.Name, pipelineID)
if err != nil {
return err
}
}
}
}
_, err = tx.Exec(`
ALTER TABLE resources ALTER COLUMN config DROP DEFAULT;
`)
if err != nil {
return err
}
_, err = tx.Exec(`
ALTER TABLE resource_types ALTER COLUMN config DROP DEFAULT;
`)
if err != nil {
return err
}
_, err = tx.Exec(`
ALTER TABLE jobs ALTER COLUMN config DROP DEFAULT;
`)
if err != nil {
return err
}
return nil
}