/
persister_settings.go
79 lines (62 loc) · 2.22 KB
/
persister_settings.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
// Copyright © 2023 Ory Corp
// SPDX-License-Identifier: Apache-2.0
package sql
import (
"context"
"fmt"
"time"
"github.com/ory/kratos/identity"
"github.com/ory/kratos/persistence/sql/update"
"github.com/gofrs/uuid"
"github.com/ory/x/otelx"
"github.com/ory/x/sqlcon"
"github.com/ory/kratos/selfservice/flow/settings"
)
var _ settings.FlowPersister = new(Persister)
func (p *Persister) CreateSettingsFlow(ctx context.Context, r *settings.Flow) (err error) {
ctx, span := p.r.Tracer(ctx).Tracer().Start(ctx, "persistence.sql.CreateSettingsFlow")
defer otelx.End(span, &err)
r.NID = p.NetworkID(ctx)
r.EnsureInternalContext()
return sqlcon.HandleError(p.GetConnection(ctx).Create(r))
}
func (p *Persister) GetSettingsFlow(ctx context.Context, id uuid.UUID) (_ *settings.Flow, err error) {
ctx, span := p.r.Tracer(ctx).Tracer().Start(ctx, "persistence.sql.GetSettingsFlow")
defer otelx.End(span, &err)
var r settings.Flow
err = p.GetConnection(ctx).Where("id = ? AND nid = ?", id, p.NetworkID(ctx)).First(&r)
if err != nil {
return nil, sqlcon.HandleError(err)
}
r.Identity, err = p.PrivilegedPool.GetIdentity(ctx, r.IdentityID, identity.ExpandDefault)
if err != nil {
return nil, err
}
return &r, nil
}
func (p *Persister) UpdateSettingsFlow(ctx context.Context, r *settings.Flow) (err error) {
ctx, span := p.r.Tracer(ctx).Tracer().Start(ctx, "persistence.sql.UpdateSettingsFlow")
defer otelx.End(span, &err)
r.EnsureInternalContext()
cp := *r
cp.NID = p.NetworkID(ctx)
return update.Generic(ctx, p.GetConnection(ctx), p.r.Tracer(ctx).Tracer(), cp)
}
func (p *Persister) DeleteExpiredSettingsFlows(ctx context.Context, expiresAt time.Time, limit int) (err error) {
ctx, span := p.r.Tracer(ctx).Tracer().Start(ctx, "persistence.sql.DeleteExpiredSettingsFlows")
defer otelx.End(span, &err)
//#nosec G201 -- TableName is static
err = p.GetConnection(ctx).RawQuery(fmt.Sprintf(
"DELETE FROM %s WHERE id in (SELECT id FROM (SELECT id FROM %s c WHERE expires_at <= ? and nid = ? ORDER BY expires_at ASC LIMIT %d ) AS s )",
new(settings.Flow).TableName(ctx),
new(settings.Flow).TableName(ctx),
limit,
),
expiresAt,
p.NetworkID(ctx),
).Exec()
if err != nil {
return sqlcon.HandleError(err)
}
return nil
}