Skip to content

Commit

Permalink
feat: Add option for attestation request in wallet CLI
Browse files Browse the repository at this point in the history
Signed-off-by: Bob Stasyszyn <[email protected]>
  • Loading branch information
bstasyszyn committed Jan 24, 2024
1 parent 05660b2 commit 1aa6b69
Showing 1 changed file with 33 additions and 13 deletions.
46 changes: 33 additions & 13 deletions component/wallet-cli/pkg/attestation/attestation_client.go
Original file line number Diff line number Diff line change
Expand Up @@ -55,10 +55,28 @@ func NewClient(config *Config) *Client {
}
}

func (c *Client) GetAttestationVC(ctx context.Context) (*verifiable.Credential, error) {
type options struct {
attestationRequest *AttestWalletInitRequest
}

type Opt func(*options)

func WithAttestationRequest(value *AttestWalletInitRequest) Opt {
return func(o *options) {
o.attestationRequest = value
}
}

func (c *Client) GetAttestationVC(ctx context.Context, opts ...Opt) (*verifiable.Credential, error) {
logger.Debug("get attestation vc", zap.String("walletDID", c.walletDID))

initResp, err := c.attestationInit(ctx)
options := &options{}

for _, opt := range opts {
opt(options)
}

initResp, err := c.attestationInit(ctx, options.attestationRequest)
if err != nil {
return nil, fmt.Errorf("attestation init: %w", err)
}
Expand All @@ -80,19 +98,21 @@ func (c *Client) GetAttestationVC(ctx context.Context) (*verifiable.Credential,
return attestationVC, nil
}

func (c *Client) attestationInit(ctx context.Context) (*AttestWalletInitResponse, error) {
func (c *Client) attestationInit(ctx context.Context, req *AttestWalletInitRequest) (*AttestWalletInitResponse, error) {
logger.Debug("attestation init started", zap.String("walletDID", c.walletDID))

req := &AttestWalletInitRequest{
Assertions: []string{
"wallet_authentication",
},
WalletAuthentication: map[string]interface{}{
"wallet_id": c.walletDID,
},
WalletMetadata: map[string]interface{}{
"wallet_name": "wallet-cli",
},
if req == nil {
req = &AttestWalletInitRequest{
Assertions: []string{
"wallet_authentication",
},
WalletAuthentication: map[string]interface{}{
"wallet_id": c.walletDID,
},
WalletMetadata: map[string]interface{}{
"wallet_name": "wallet-cli",
},
}
}

body, err := json.Marshal(req)
Expand Down

0 comments on commit 1aa6b69

Please sign in to comment.