@docknetwork/wallet-sdk-relay-service 0.4.19 → 0.4.23
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/_rollupPluginBabelHelpers-4923c894.js +464 -0
- package/lib/_rollupPluginBabelHelpers-78739aa5.js +458 -0
- package/lib/did/did-resolver.js +38 -0
- package/lib/did/did-resolver.mjs +26 -0
- package/lib/did/dids.js +45 -0
- package/lib/did/dids.mjs +41 -0
- package/lib/didcomm.js +603 -0
- package/lib/didcomm.mjs +575 -0
- package/lib/index.js +491 -0
- package/lib/index.mjs +479 -0
- package/lib/payloads.js +146 -0
- package/lib/payloads.mjs +132 -0
- package/package.json +4 -4
- package/src/index.js +11 -1
package/lib/payloads.mjs
ADDED
|
@@ -0,0 +1,132 @@
|
|
|
1
|
+
import { _ as _asyncToGenerator, a as _regeneratorRuntime, d as _createForOfIteratorHelper } from './_rollupPluginBabelHelpers-78739aa5.js';
|
|
2
|
+
import VerifiableCredential from '@docknetwork/sdk/verifiable-credential';
|
|
3
|
+
import { cryptoWaitReady } from '@polkadot/util-crypto';
|
|
4
|
+
import { getSuiteFromKeyDoc } from '@docknetwork/sdk/utils/vc/helpers';
|
|
5
|
+
import { getKeypairFromDoc } from '@docknetwork/universal-wallet/methods/keypairs';
|
|
6
|
+
import assert from 'assert';
|
|
7
|
+
import base64url from 'base64url';
|
|
8
|
+
|
|
9
|
+
// 1 year
|
|
10
|
+
var DEFAULT_EXPIRATION = 86400 * 1000 * 365;
|
|
11
|
+
var isDIDDockRegex = /did:dock/gi;
|
|
12
|
+
function ensureDIDDockFragment(keyDoc) {
|
|
13
|
+
if (!isDIDDockRegex.test(keyDoc.id)) {
|
|
14
|
+
return keyDoc;
|
|
15
|
+
}
|
|
16
|
+
keyDoc.id = keyDoc.id.replace(/#.+/, '');
|
|
17
|
+
keyDoc.id = "".concat(keyDoc.id, "#keys-1");
|
|
18
|
+
return keyDoc;
|
|
19
|
+
}
|
|
20
|
+
function generateSignedPayload(_x, _x2) {
|
|
21
|
+
return _generateSignedPayload.apply(this, arguments);
|
|
22
|
+
}
|
|
23
|
+
function _generateSignedPayload() {
|
|
24
|
+
_generateSignedPayload = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee(keyPairDoc, subject) {
|
|
25
|
+
var cred, keyPair, suite;
|
|
26
|
+
return _regeneratorRuntime().wrap(function _callee$(_context) {
|
|
27
|
+
while (1) switch (_context.prev = _context.next) {
|
|
28
|
+
case 0:
|
|
29
|
+
assert(!!keyPairDoc, 'keyPairDoc is required');
|
|
30
|
+
assert(!!subject, 'subject is required');
|
|
31
|
+
_context.next = 4;
|
|
32
|
+
return cryptoWaitReady();
|
|
33
|
+
case 4:
|
|
34
|
+
keyPairDoc = ensureDIDDockFragment(keyPairDoc);
|
|
35
|
+
cred = new VerifiableCredential('dock:relay');
|
|
36
|
+
cred.setContext(['https://www.w3.org/2018/credentials/v1', {
|
|
37
|
+
dk: 'https://ld.dock.io/credentials#',
|
|
38
|
+
RelayAuthCredential: 'dk:RelayAuthCredential',
|
|
39
|
+
token: 'dk:token',
|
|
40
|
+
limit: 'dk:limit',
|
|
41
|
+
to: 'dk:to',
|
|
42
|
+
msg: 'dk:msg'
|
|
43
|
+
}]);
|
|
44
|
+
cred.setIssuanceDate(new Date().toISOString());
|
|
45
|
+
cred.setExpirationDate(new Date(Date.now() + DEFAULT_EXPIRATION).toISOString());
|
|
46
|
+
cred.setSubject(subject);
|
|
47
|
+
cred.setIssuer(keyPairDoc.controller);
|
|
48
|
+
cred.addType('RelayAuthCredential');
|
|
49
|
+
keyPair = getKeypairFromDoc(keyPairDoc);
|
|
50
|
+
keyPair.signer = keyPair.signer();
|
|
51
|
+
_context.next = 16;
|
|
52
|
+
return getSuiteFromKeyDoc(keyPair);
|
|
53
|
+
case 16:
|
|
54
|
+
suite = _context.sent;
|
|
55
|
+
_context.next = 19;
|
|
56
|
+
return cred.sign(suite);
|
|
57
|
+
case 19:
|
|
58
|
+
return _context.abrupt("return", {
|
|
59
|
+
payload: [subject, cred.issuanceDate, cred.expirationDate, cred.toJSON().proof],
|
|
60
|
+
did: keyPairDoc.controller
|
|
61
|
+
});
|
|
62
|
+
case 20:
|
|
63
|
+
case "end":
|
|
64
|
+
return _context.stop();
|
|
65
|
+
}
|
|
66
|
+
}, _callee);
|
|
67
|
+
}));
|
|
68
|
+
return _generateSignedPayload.apply(this, arguments);
|
|
69
|
+
}
|
|
70
|
+
function generateSignedPayloadFromList(_x3, _x4) {
|
|
71
|
+
return _generateSignedPayloadFromList.apply(this, arguments);
|
|
72
|
+
}
|
|
73
|
+
function _generateSignedPayloadFromList() {
|
|
74
|
+
_generateSignedPayloadFromList = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee2(keyPairDocs, subject) {
|
|
75
|
+
var payload, dids, _iterator, _step, keyPairDoc, _yield$generateSigned, signedPayload, did;
|
|
76
|
+
return _regeneratorRuntime().wrap(function _callee2$(_context2) {
|
|
77
|
+
while (1) switch (_context2.prev = _context2.next) {
|
|
78
|
+
case 0:
|
|
79
|
+
payload = [];
|
|
80
|
+
dids = [];
|
|
81
|
+
_iterator = _createForOfIteratorHelper(keyPairDocs);
|
|
82
|
+
_context2.prev = 3;
|
|
83
|
+
_iterator.s();
|
|
84
|
+
case 5:
|
|
85
|
+
if ((_step = _iterator.n()).done) {
|
|
86
|
+
_context2.next = 16;
|
|
87
|
+
break;
|
|
88
|
+
}
|
|
89
|
+
keyPairDoc = _step.value;
|
|
90
|
+
_context2.next = 9;
|
|
91
|
+
return generateSignedPayload(keyPairDoc, subject);
|
|
92
|
+
case 9:
|
|
93
|
+
_yield$generateSigned = _context2.sent;
|
|
94
|
+
signedPayload = _yield$generateSigned.payload;
|
|
95
|
+
did = _yield$generateSigned.did;
|
|
96
|
+
payload.push(signedPayload);
|
|
97
|
+
dids.push(did);
|
|
98
|
+
case 14:
|
|
99
|
+
_context2.next = 5;
|
|
100
|
+
break;
|
|
101
|
+
case 16:
|
|
102
|
+
_context2.next = 21;
|
|
103
|
+
break;
|
|
104
|
+
case 18:
|
|
105
|
+
_context2.prev = 18;
|
|
106
|
+
_context2.t0 = _context2["catch"](3);
|
|
107
|
+
_iterator.e(_context2.t0);
|
|
108
|
+
case 21:
|
|
109
|
+
_context2.prev = 21;
|
|
110
|
+
_iterator.f();
|
|
111
|
+
return _context2.finish(21);
|
|
112
|
+
case 24:
|
|
113
|
+
return _context2.abrupt("return", {
|
|
114
|
+
payload: payload,
|
|
115
|
+
dids: dids
|
|
116
|
+
});
|
|
117
|
+
case 25:
|
|
118
|
+
case "end":
|
|
119
|
+
return _context2.stop();
|
|
120
|
+
}
|
|
121
|
+
}, _callee2, null, [[3, 18, 21, 24]]);
|
|
122
|
+
}));
|
|
123
|
+
return _generateSignedPayloadFromList.apply(this, arguments);
|
|
124
|
+
}
|
|
125
|
+
function toBase64(payload) {
|
|
126
|
+
return base64url.encode(JSON.stringify(payload));
|
|
127
|
+
}
|
|
128
|
+
function fromBase64(payload) {
|
|
129
|
+
return JSON.parse(base64url.decode(payload));
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
export { ensureDIDDockFragment, fromBase64, generateSignedPayload, generateSignedPayloadFromList, toBase64 };
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@docknetwork/wallet-sdk-relay-service",
|
|
3
|
-
"version": "0.4.
|
|
3
|
+
"version": "0.4.23",
|
|
4
4
|
"license": "https://github.com/docknetwork/react-native-sdk/LICENSE",
|
|
5
5
|
"repository": {
|
|
6
6
|
"type": "git",
|
|
@@ -8,13 +8,13 @@
|
|
|
8
8
|
"directory": "packages/relay-service"
|
|
9
9
|
},
|
|
10
10
|
"scripts": {
|
|
11
|
-
"build": "rm -rf lib && rollup -c"
|
|
11
|
+
"build": "rm -rf lib && rollup -c && node ../../scripts/fix-build-imports.js ./lib"
|
|
12
12
|
},
|
|
13
13
|
"dependencies": {
|
|
14
14
|
"uuid": "^9.0.0",
|
|
15
15
|
"@docknetwork/minimal-cipher": "^5.2.1",
|
|
16
|
-
"@docknetwork/sdk": "8.
|
|
17
|
-
"@docknetwork/wallet-sdk-wasm": "
|
|
16
|
+
"@docknetwork/sdk": "8.6.0",
|
|
17
|
+
"@docknetwork/wallet-sdk-wasm": "1.4.0"
|
|
18
18
|
},
|
|
19
19
|
"devDependencies": {
|
|
20
20
|
"jest": "29.1.0",
|
package/src/index.js
CHANGED
|
@@ -78,7 +78,7 @@ const getMessages = async ({
|
|
|
78
78
|
const result = await axios.get(
|
|
79
79
|
`${serviceURL}/messages/batch-dids?dids=${encodeURIComponent(
|
|
80
80
|
JSON.stringify(dids),
|
|
81
|
-
)}&payload=${toBase64(payload)}`,
|
|
81
|
+
)}&payload=${toBase64(payload)}&keepMessages=true`,
|
|
82
82
|
);
|
|
83
83
|
|
|
84
84
|
const data = result.data;
|
|
@@ -109,6 +109,15 @@ const getMessages = async ({
|
|
|
109
109
|
}
|
|
110
110
|
};
|
|
111
111
|
|
|
112
|
+
const ackMessages = ({did, messageIds}) => {
|
|
113
|
+
assert(!!did, 'did is required');
|
|
114
|
+
assert(!!messageIds, 'messageIds is required');
|
|
115
|
+
return axios.post(`${serviceURL}/messages/ack`, {
|
|
116
|
+
ack: messageIds,
|
|
117
|
+
did,
|
|
118
|
+
});
|
|
119
|
+
};
|
|
120
|
+
|
|
112
121
|
const registerDIDPushNotification = async ({keyPairDocs, token}) => {
|
|
113
122
|
assert(!!keyPairDocs, 'keyPairDoc is required');
|
|
114
123
|
assert(Array.isArray(keyPairDocs), 'keyPairDocs must be an array');
|
|
@@ -265,6 +274,7 @@ export const RelayService = {
|
|
|
265
274
|
resolveDidcommMessage,
|
|
266
275
|
registerDIDPushNotification,
|
|
267
276
|
setServiceURL,
|
|
277
|
+
ackMessages,
|
|
268
278
|
serviceURL,
|
|
269
279
|
signJwt,
|
|
270
280
|
};
|