-
Notifications
You must be signed in to change notification settings - Fork 2
/
certificate_provider_store.go
108 lines (86 loc) · 3.25 KB
/
certificate_provider_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
package app
import (
"context"
"errors"
"fmt"
"time"
"github.com/ministryofjustice/opg-modernising-lpa/internal/actor"
"github.com/ministryofjustice/opg-modernising-lpa/internal/dynamo"
"github.com/ministryofjustice/opg-modernising-lpa/internal/page"
)
type certificateProviderStore struct {
dynamoClient DynamoClient
now func() time.Time
}
func (s *certificateProviderStore) Create(ctx context.Context, shareCode actor.ShareCodeData, email string) (*actor.CertificateProviderProvidedDetails, error) {
data, err := page.SessionDataFromContext(ctx)
if err != nil {
return nil, err
}
if data.LpaID == "" || data.SessionID == "" {
return nil, errors.New("certificateProviderStore.Create requires LpaID and SessionID")
}
certificateProvider := &actor.CertificateProviderProvidedDetails{
PK: dynamo.LpaKey(data.LpaID),
SK: dynamo.CertificateProviderKey(data.SessionID),
UID: shareCode.ActorUID,
LpaID: data.LpaID,
UpdatedAt: s.now(),
Email: email,
}
transaction := dynamo.NewTransaction().
Create(certificateProvider).
Create(lpaLink{
PK: dynamo.LpaKey(data.LpaID),
SK: dynamo.SubKey(data.SessionID),
DonorKey: shareCode.LpaOwnerKey,
ActorType: actor.TypeCertificateProvider,
UpdatedAt: s.now(),
}).
Delete(dynamo.Keys{PK: shareCode.PK, SK: shareCode.SK})
if err := s.dynamoClient.WriteTransaction(ctx, transaction); err != nil {
return nil, err
}
return certificateProvider, err
}
func (s *certificateProviderStore) GetAny(ctx context.Context) (*actor.CertificateProviderProvidedDetails, error) {
data, err := page.SessionDataFromContext(ctx)
if err != nil {
return nil, err
}
if data.LpaID == "" {
return nil, errors.New("certificateProviderStore.GetAny requires LpaID")
}
var certificateProvider actor.CertificateProviderProvidedDetails
err = s.dynamoClient.OneByPartialSK(ctx, dynamo.LpaKey(data.LpaID), dynamo.CertificateProviderKey(""), &certificateProvider)
return &certificateProvider, err
}
func (s *certificateProviderStore) Get(ctx context.Context) (*actor.CertificateProviderProvidedDetails, error) {
data, err := page.SessionDataFromContext(ctx)
if err != nil {
return nil, err
}
if data.LpaID == "" || data.SessionID == "" {
return nil, errors.New("certificateProviderStore.Get requires LpaID and SessionID")
}
var certificateProvider actor.CertificateProviderProvidedDetails
err = s.dynamoClient.One(ctx, dynamo.LpaKey(data.LpaID), dynamo.CertificateProviderKey(data.SessionID), &certificateProvider)
return &certificateProvider, err
}
func (s *certificateProviderStore) Put(ctx context.Context, certificateProvider *actor.CertificateProviderProvidedDetails) error {
certificateProvider.UpdatedAt = s.now()
return s.dynamoClient.Put(ctx, certificateProvider)
}
func (s *certificateProviderStore) Delete(ctx context.Context) error {
data, err := page.SessionDataFromContext(ctx)
if err != nil {
return err
}
if data.LpaID == "" || data.SessionID == "" {
return errors.New("certificateProviderStore.Delete requires LpaID and SessionID")
}
if err := s.dynamoClient.DeleteOne(ctx, dynamo.LpaKey(data.LpaID), dynamo.CertificateProviderKey(data.SessionID)); err != nil {
return fmt.Errorf("error deleting certificate provider: %w", err)
}
return nil
}