1.18.117 • Published 17 hours ago

@arcblock/jwt v1.18.117

Weekly downloads
-
License
Apache-2.0
Repository
github
Last release
17 hours ago

did-auth

styled with prettier docs Gitter

This library aims to ease the process of handling Did-Auth process between different parts, its implemented according to ABT-DID-Protocol, and can eliminate the threat of middle-man attach if properly used, there are typically 2 use case for the library:

  • dApp <--> dApp: for inter application communication, we provide AppAuthenticator and AppHandlers
  • dApp <--> DID Wallet: for application and wallet communication, we provide WalletAuthenticator and WalletHandlers

Table of Contents

Install

npm install @arcblock/jwt
// or
yarn add @arcblock/jwt

Usage

Between dApp and DID Wallet

WalletAuthenticator and WalletHandlers should be used together with @ocap/react-forge.

const { fromRandom } = require('@ocap/wallet');
const { WalletAuthenticator, WalletHandlers } = require('@arcblock/jwt');

// First setup authenticator and handler factory
const wallet = fromRandom().toJSON();
const authenticator = new WalletAuthenticator({
  wallet,
  baseUrl: 'http://wangshijun.natapp1.cc',
  appInfo: {
    description: 'Starter projects to develop web application on forge',
    icon: '/images/logo@2x.png',
    name: 'Forge Web Starter',
  },
  chainInfo: {
    host: 'http://did-workshop.arcblock.co:8210/api',
    id: 'forge',
  },
});

const handlers = new WalletHandlers({
  authenticator,
  tokenStorage: new MongoStorage({ url: process.env.MONGO_URI }),
});

// Then attach handler to express server
const express = require('express');
const app = express();

// This is required if you want to use dynamic baseUrl inference
app.set('trust proxy', true);

handlers.attach({
  prefix: '/api/did',
  action: 'login',
  claims: {
    profile: () => ({
      fields: ['fullName', 'email'],
      description: 'Please provide your name and email to continue',
    }),
  },
  onAuth: async ({ claims, userDid }) => {
    try {
      const profile = claims.find((x) => x.type === 'profile');
      console.info('login.success', { userDid, profile });
    } catch (err) {
      console.error('login.error', err);
    }
  },
});

// Then your app will have 5 api endpoints that can be consumed by AuthComponent
// - `GET /api/did/login/token` create new token
// - `GET /api/did/login/status` check for token status
// - `GET /api/did/login/timeout` expire a token
// - `GET /api/did/login/auth` create auth response
// - `POST /api/did/login/auth` process login request

Between dApp and dApp

Please note that AppAuthenticator and AppHandlers should be used to sign and verify the message sent between dApps, so there must are both a client and a server.

Initialize authenticator and handlers

const { fromRandom } = require('@ocap/wallet');
const { AppAuthenticator, AppHandlers } = require('@arcblock/jwt');

// First setup authenticator and handler factory
const wallet = fromRandom().toJSON();
const authenticator = new AppAuthenticator(wallet);
const handlers = new AppHandlers(authenticator);

For the server

const express = require('express');
const app = express();

app.post('/api/endpoint', handlers.attach(), (req, res) => {
  console.log('client.appPk', req.appPk);
  console.log('verified payload', req.payload);

  // Sent signed response: sensitive info should not be here
  res.jsonSecure({
    key: 'value',
  });
});

For the client

const axios = require('axios');

const signedPayload = authenticator.sign({
  amount,
  depositorDid,
  depositorPk,
  withdrawer: appAuth.wallet.address,
  merchantId: process.env.MERCHANT_ID,
});

const res = await axios.post('http://example.com/api/endpoint', signedPayload);
const payload = await authenticator.verify(res.data);
if (payload.error) {
  throw new Error(payload.error);
}
// Do something with the payload
1.18.117

17 hours ago

1.18.116

10 days ago

1.18.115

1 month ago

1.18.114

1 month ago

1.18.113

2 months ago

1.18.112

2 months ago

1.18.111

2 months ago

1.18.110

3 months ago

1.18.109

3 months ago

1.18.108

4 months ago

1.18.107

5 months ago

1.18.106

5 months ago

1.18.105

5 months ago

1.18.104

5 months ago

1.18.96

5 months ago

1.18.99

5 months ago

1.18.98

5 months ago

1.18.97

5 months ago

1.18.103

5 months ago

1.18.102

5 months ago

1.18.101

5 months ago

1.18.100

5 months ago

1.18.95

6 months ago

1.18.94

6 months ago

1.18.93

7 months ago

1.18.85

10 months ago

1.18.89

10 months ago

1.18.88

10 months ago

1.18.87

10 months ago

1.18.86

10 months ago

1.18.92

7 months ago

1.18.91

8 months ago

1.18.90

8 months ago

1.18.81

11 months ago

1.18.84

11 months ago

1.18.83

11 months ago

1.18.82

11 months ago

1.18.80

12 months ago

1.18.70

1 year ago

1.18.74

1 year ago

1.18.73

1 year ago

1.18.72

1 year ago

1.18.71

1 year ago

1.18.78

1 year ago

1.18.77

1 year ago

1.18.76

1 year ago

1.18.75

1 year ago

1.18.79

12 months ago

1.18.69

1 year ago

1.18.67

1 year ago

1.18.66

1 year ago

1.18.68

1 year ago

1.18.41

1 year ago

1.18.40

1 year ago

1.18.45

1 year ago

1.18.44

1 year ago

1.18.43

1 year ago

1.18.42

1 year ago

1.18.49

1 year ago

1.18.48

1 year ago

1.18.47

1 year ago

1.18.46

1 year ago

1.18.38

1 year ago

1.18.39

1 year ago

1.18.63

1 year ago

1.18.62

1 year ago

1.18.61

1 year ago

1.18.60

1 year ago

1.18.65

1 year ago

1.18.64

1 year ago

1.18.52

1 year ago

1.18.51

1 year ago

1.18.50

1 year ago

1.18.56

1 year ago

1.18.55

1 year ago

1.18.54

1 year ago

1.18.53

1 year ago

1.18.59

1 year ago

1.18.58

1 year ago

1.18.57

1 year ago

1.18.34

1 year ago

1.18.33

1 year ago

1.18.37

1 year ago

1.18.36

1 year ago

1.18.35

1 year ago

1.18.1

2 years ago

1.18.0

2 years ago

1.18.5

2 years ago

1.18.4

2 years ago

1.18.3

2 years ago

1.18.2

2 years ago

1.18.9

2 years ago

1.18.8

2 years ago

1.18.7

2 years ago

1.18.6

2 years ago

1.18.30

1 year ago

1.18.32

1 year ago

1.18.31

1 year ago

1.17.23

2 years ago

1.18.23

1 year ago

1.18.22

1 year ago

1.18.21

1 year ago

1.18.20

1 year ago

1.18.27

1 year ago

1.18.26

1 year ago

1.18.25

1 year ago

1.18.24

1 year ago

1.18.28

1 year ago

1.18.12

2 years ago

1.18.11

2 years ago

1.18.10

2 years ago

1.18.16

1 year ago

1.18.15

1 year ago

1.18.14

2 years ago

1.18.13

2 years ago

1.18.19

1 year ago

1.18.18

1 year ago

1.18.17

1 year ago

1.17.22

2 years ago

1.17.21

2 years ago

1.17.20

2 years ago

1.17.15

2 years ago

1.17.14

2 years ago

1.17.13

2 years ago

1.17.12

2 years ago

1.17.19

2 years ago

1.17.18

2 years ago

1.17.17

2 years ago

1.17.16

2 years ago

1.16.10

2 years ago

1.16.14

2 years ago

1.16.13

2 years ago

1.16.12

2 years ago

1.16.17

2 years ago

1.16.16

2 years ago

1.16.15

2 years ago

1.17.11

2 years ago

1.17.10

2 years ago

1.6.10

2 years ago

1.17.2

2 years ago

1.17.1

2 years ago

1.17.0

2 years ago

1.17.6

2 years ago

1.17.5

2 years ago

1.17.4

2 years ago

1.17.3

2 years ago

1.17.9

2 years ago

1.17.8

2 years ago

1.17.7

2 years ago

1.16.7

2 years ago

1.16.6

2 years ago

1.16.5

2 years ago

1.16.9

2 years ago

1.16.8

2 years ago

1.16.3

2 years ago

1.16.2

2 years ago

1.16.1

2 years ago

1.16.0

2 years ago

1.16.4

2 years ago

1.15.0

2 years ago

1.15.4

2 years ago

1.15.3

2 years ago

1.15.2

2 years ago

1.15.1

2 years ago

1.14.20

2 years ago

1.15.7

2 years ago

1.14.21

2 years ago

1.15.6

2 years ago

1.14.22

2 years ago

1.15.5

2 years ago

1.14.23

2 years ago

1.14.24

2 years ago

1.14.25

2 years ago

1.14.19

2 years ago

1.14.1

2 years ago

1.14.0

2 years ago

1.14.5

2 years ago

1.14.4

2 years ago

1.14.3

2 years ago

1.14.2

2 years ago

1.14.9

2 years ago

1.13.75

2 years ago

1.14.8

2 years ago

1.13.74

2 years ago

1.14.7

2 years ago

1.13.77

2 years ago

1.14.6

2 years ago

1.13.76

2 years ago

1.13.71

2 years ago

1.13.70

2 years ago

1.13.73

2 years ago

1.13.72

2 years ago

1.13.79

2 years ago

1.13.78

2 years ago

1.13.66

2 years ago

1.13.65

2 years ago

1.13.68

2 years ago

1.13.67

2 years ago

1.13.69

2 years ago

1.13.80

2 years ago

1.13.86

2 years ago

1.14.10

2 years ago

1.13.85

2 years ago

1.14.11

2 years ago

1.14.12

2 years ago

1.13.82

2 years ago

1.13.81

2 years ago

1.13.84

2 years ago

1.13.83

2 years ago

1.14.17

2 years ago

1.14.18

2 years ago

1.14.13

2 years ago

1.14.14

2 years ago

1.14.15

2 years ago

1.14.16

2 years ago

1.13.64

2 years ago

1.13.63

2 years ago

1.13.60

2 years ago

1.13.62

2 years ago

1.13.61

2 years ago

1.13.57

2 years ago

1.13.56

3 years ago

1.13.59

2 years ago

1.13.58

2 years ago

1.13.55

3 years ago

1.13.54

3 years ago

1.13.53

3 years ago

1.13.52

3 years ago

1.13.51

3 years ago

1.13.50

3 years ago

1.13.49

3 years ago