-
Notifications
You must be signed in to change notification settings - Fork 88
/
preflight_store.go
127 lines (103 loc) · 3.76 KB
/
preflight_store.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
package kotsstore
import (
"database/sql"
"time"
"github.com/pkg/errors"
"github.com/replicatedhq/kots/pkg/persistence"
preflighttypes "github.com/replicatedhq/kots/pkg/preflight/types"
)
func (s *KOTSStore) SetPreflightProgress(appID string, sequence int64, progress string) error {
db := persistence.MustGetDBSession()
query := `update app_downstream_version set preflight_progress = $1 where app_id = $2 and parent_sequence = $3`
_, err := db.Exec(query, progress, appID, sequence)
if err != nil {
return errors.Wrap(err, "failed to write preflight results")
}
return nil
}
func (s *KOTSStore) GetPreflightProgress(appID string, sequence int64) (string, error) {
db := persistence.MustGetDBSession()
query := `
SELECT preflight_progress
FROM app_downstream_version
WHERE app_id = $1 AND sequence = $2`
row := db.QueryRow(query, appID, sequence)
var progress sql.NullString
if err := row.Scan(&progress); err != nil {
return "", errors.Wrap(err, "failed to scan")
}
return progress.String, nil
}
func (s *KOTSStore) SetPreflightResults(appID string, sequence int64, results []byte) error {
db := persistence.MustGetDBSession()
query := `update app_downstream_version set preflight_result = $1, preflight_result_created_at = $2,
status = (case when status = 'deployed' then 'deployed' else 'pending' end),
preflight_progress = NULL, preflight_skipped = false
where app_id = $3 and parent_sequence = $4`
_, err := db.Exec(query, results, time.Now(), appID, sequence)
if err != nil {
return errors.Wrap(err, "failed to write preflight results")
}
return nil
}
func (s *KOTSStore) GetPreflightResults(appID string, sequence int64) (*preflighttypes.PreflightResult, error) {
db := persistence.MustGetDBSession()
query := `
SELECT
app_downstream_version.preflight_result,
app_downstream_version.preflight_result_created_at,
app_downstream_version.preflight_skipped,
app.slug as app_slug,
cluster.slug as cluster_slug
FROM app_downstream_version
INNER JOIN app ON app_downstream_version.app_id = app.id
INNER JOIN cluster ON app_downstream_version.cluster_id = cluster.id
WHERE
app_downstream_version.app_id = $1 AND
app_downstream_version.sequence = $2`
row := db.QueryRow(query, appID, sequence)
r, err := preflightResultFromRow(row)
if err != nil {
return nil, errors.Wrap(err, "failed to get preflight result from row")
}
return r, nil
}
func (s *KOTSStore) ResetPreflightResults(appID string, sequence int64) error {
db := persistence.MustGetDBSession()
query := `update app_downstream_version set preflight_result=null, preflight_result_created_at=null, preflight_skipped=false where app_id = $1 and parent_sequence = $2`
_, err := db.Exec(query, appID, sequence)
if err != nil {
return errors.Wrap(err, "failed to exec")
}
return nil
}
func (s *KOTSStore) SetIgnorePreflightPermissionErrors(appID string, sequence int64) error {
db := persistence.MustGetDBSession()
query := `UPDATE app_downstream_version
SET status = 'pending_preflight', preflight_ignore_permissions = true, preflight_result = null, preflight_skipped = false
WHERE app_id = $1 AND sequence = $2`
_, err := db.Exec(query, appID, sequence)
if err != nil {
return errors.Wrap(err, "failed to set downstream version ignore rbac errors")
}
return nil
}
func preflightResultFromRow(row scannable) (*preflighttypes.PreflightResult, error) {
r := &preflighttypes.PreflightResult{}
var preflightResult sql.NullString
var preflightResultCreatedAt sql.NullTime
if err := row.Scan(
&preflightResult,
&preflightResultCreatedAt,
&r.Skipped,
&r.AppSlug,
&r.ClusterSlug,
); err != nil {
return nil, errors.Wrap(err, "failed to scan")
}
r.Result = preflightResult.String
if preflightResultCreatedAt.Valid {
r.CreatedAt = &preflightResultCreatedAt.Time
}
return r, nil
}