/
path_signature.go
99 lines (81 loc) · 3.39 KB
/
path_signature.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
package api
import (
"context"
"fmt"
"net/http"
"github.com/hashicorp/vault/sdk/framework"
"github.com/hashicorp/vault/sdk/logical"
"github.com/ryadavDeqode/dq-vault/api/helpers"
"github.com/ryadavDeqode/dq-vault/config"
"github.com/ryadavDeqode/dq-vault/lib"
"github.com/ryadavDeqode/dq-vault/lib/adapter"
"github.com/ryadavDeqode/dq-vault/lib/bip44coins"
"github.com/ryadavDeqode/dq-vault/logger"
)
func (b *backend) pathSignature(ctx context.Context, req *logical.Request, d *framework.FieldData) (*logical.Response, error) {
backendLogger := b.logger
if err := helpers.ValidateFields(req, d); err != nil {
logger.Log(backendLogger, config.Error, "signature:", err.Error())
return nil, logical.CodedError(http.StatusUnprocessableEntity, err.Error())
}
// UUID of user which want to sign transaction
uuid, _ := d.Get("uuid").(string)
// derivation path
derivationPath, _ := d.Get("path").(string)
// coin type of transaction
// see supported coinTypes lib/bipp44coins
coinType, _ := d.Get("coinType").(int)
// data in JSON required for that transaction
// depends on type of transaction
payload, _ := d.Get("payload").(string)
if uint16(coinType) == bip44coins.Bitshares {
derivationPath = config.BitsharesDerivationPath
}
logger.Log(backendLogger, config.Info, "signature:", fmt.Sprintf("request path=[%v] cointype=%v payload=[%v]", derivationPath, coinType, payload))
// validate data provided
if err := helpers.ValidateData(ctx, req, uuid, derivationPath); err != nil {
logger.Log(backendLogger, config.Error, "signature:", err.Error())
return nil, logical.CodedError(http.StatusUnprocessableEntity, err.Error())
}
// path where user data is stored in vault
path := config.StorageBasePath + uuid
entry, err := req.Storage.Get(ctx, path)
if err != nil {
logger.Log(backendLogger, config.Error, "signature:", err.Error())
return nil, logical.CodedError(http.StatusUnprocessableEntity, err.Error())
}
// obtain mnemonic, passphrase of user
var userInfo helpers.User
err = entry.DecodeJSON(&userInfo)
if err != nil {
logger.Log(backendLogger, config.Error, "signature:", err.Error())
return nil, logical.CodedError(http.StatusUnprocessableEntity, err.Error())
}
// obtain seed from mnemonic and passphrase
seed, err := lib.SeedFromMnemonic(userInfo.Mnemonic, userInfo.Passphrase)
// obtains blockchain adapater based on coinType
adapter, err := adapter.GetAdapter(uint16(coinType), seed, derivationPath)
if err != nil {
logger.Log(backendLogger, config.Error, "signature:", err.Error())
return nil, logical.CodedError(http.StatusUnprocessableEntity, err.Error())
}
// Generates and stores ECDSA private key in adapter
_, err = adapter.DerivePrivateKey(backendLogger)
if err != nil {
logger.Log(backendLogger, config.Error, "signature:", err.Error())
return nil, logical.CodedError(http.StatusUnprocessableEntity, err.Error())
}
// creates signature from raw transaction payload
txHex, err := adapter.CreateSignedTransaction(payload, backendLogger)
if err != nil {
logger.Log(backendLogger, config.Error, "signature:", err.Error())
return nil, logical.CodedError(http.StatusUnprocessableEntity, err.Error())
}
logger.Log(backendLogger, config.Info, "signature:", fmt.Sprintf("\n[INFO ] signature: created signature signature=[%v]", txHex))
// Returns signature as output
return &logical.Response{
Data: map[string]interface{}{
"signature": txHex,
},
}, nil
}