/
store_options.go
105 lines (85 loc) · 2.58 KB
/
store_options.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
package bertyprotocol
import (
"encoding/hex"
"berty.tech/berty/v2/go/pkg/bertytypes"
"berty.tech/berty/v2/go/pkg/errcode"
"berty.tech/go-ipfs-log/identityprovider"
orbitdb "berty.tech/go-orbit-db"
"berty.tech/go-orbit-db/accesscontroller"
)
func DefaultOrbitDBOptions(g *bertytypes.Group, options *orbitdb.CreateDBOptions, keystore *BertySignedKeyStore, storeType string) (*orbitdb.CreateDBOptions, error) {
var err error
if options == nil {
options = &orbitdb.CreateDBOptions{}
}
options = &orbitdb.CreateDBOptions{
Directory: options.Directory,
Overwrite: options.Overwrite,
LocalOnly: options.LocalOnly,
StoreType: options.StoreType,
AccessControllerAddress: options.AccessControllerAddress,
AccessController: options.AccessController,
Replicate: options.Replicate,
Cache: options.Cache,
}
t := true
options.Create = &t
if options.AccessController == nil {
options.AccessController, err = defaultACForGroup(g, storeType)
if err != nil {
return nil, errcode.TODO.Wrap(err)
}
}
options.Keystore = keystore
options.Identity, err = defaultIdentityForGroup(g, keystore)
if err != nil {
return nil, errcode.TODO.Wrap(err)
}
return options, nil
}
func defaultACForGroup(g *bertytypes.Group, storeType string) (accesscontroller.ManifestParams, error) {
groupID := g.GroupIDAsString()
sigPK, err := g.GetSigningPubKey()
if err != nil {
return nil, errcode.TODO.Wrap(err)
}
signingKeyBytes, err := sigPK.Raw()
if err != nil {
return nil, errcode.TODO.Wrap(err)
}
access := map[string][]string{
"write": {hex.EncodeToString(signingKeyBytes)},
identityGroupIDKey: {groupID},
storeTypeKey: {storeType},
}
address, err := simpleAccessControllerCID(access)
if err != nil {
return nil, err
}
param := &accesscontroller.CreateAccessControllerOptions{
Access: access,
SkipManifest: true,
Type: "bertysimple",
Address: address,
}
return param, nil
}
func defaultIdentityForGroup(g *bertytypes.Group, ks *BertySignedKeyStore) (*identityprovider.Identity, error) {
sigPK, err := g.GetSigningPubKey()
if err != nil {
return nil, errcode.TODO.Wrap(err)
}
signingKeyBytes, err := sigPK.Raw()
if err != nil {
return nil, errcode.TODO.Wrap(err)
}
identity, err := ks.getIdentityProvider().createIdentity(&identityprovider.CreateIdentityOptions{
Type: identityType,
Keystore: ks,
ID: hex.EncodeToString(signingKeyBytes),
})
if err != nil {
return nil, errcode.TODO.Wrap(err)
}
return identity, nil
}