@metalabel/dfos-protocol 0.12.0 → 0.13.0
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/dist/chain/index.d.ts +2 -2
- package/dist/chain/index.js +2 -2
- package/dist/{chunk-J5C4OXL4.js → chunk-4EJCATUC.js} +3 -6
- package/dist/{chunk-J3XXF6F5.js → chunk-FMHROCFH.js} +4 -4
- package/dist/credentials/index.d.ts +2 -2
- package/dist/credentials/index.js +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/index.js +2 -2
- package/dist/{schemas-Bb_9P8_s.d.ts → schemas-BXye25k7.d.ts} +13 -6
- package/examples/content-delegated.json +4 -4
- package/examples/content-delete.json +3 -3
- package/examples/content-lifecycle.json +3 -3
- package/examples/credential-write.json +2 -2
- package/examples/identity-services.json +3 -3
- package/package.json +1 -1
package/dist/chain/index.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { I as IdentityOperation, i as Signer, V as VerifiedIdentity, S as ServiceEntry, b as ContentOperation, c as CountersignPayload, a as ArtifactPayload } from '../schemas-
|
|
2
|
-
export { A as ARTIFACT_CID_ANCHOR_RE, C as CONTENT_ID_ANCHOR_RE, M as MAX_ARTIFACT_PAYLOAD_SIZE, d as MAX_OPERATION_SIZE, e as MAX_SERVICES_ENTRIES, f as MAX_SERVICES_PAYLOAD_SIZE, g as MultikeyPublicKey, R as RevocationPayload, h as ServicesArray } from '../schemas-
|
|
1
|
+
import { I as IdentityOperation, i as Signer, V as VerifiedIdentity, S as ServiceEntry, b as ContentOperation, c as CountersignPayload, a as ArtifactPayload } from '../schemas-BXye25k7.js';
|
|
2
|
+
export { A as ARTIFACT_CID_ANCHOR_RE, C as CONTENT_ID_ANCHOR_RE, M as MAX_ARTIFACT_PAYLOAD_SIZE, d as MAX_OPERATION_SIZE, e as MAX_SERVICES_ENTRIES, f as MAX_SERVICES_PAYLOAD_SIZE, g as MultikeyPublicKey, R as RevocationPayload, h as ServicesArray } from '../schemas-BXye25k7.js';
|
|
3
3
|
import 'zod';
|
|
4
4
|
|
|
5
5
|
/** Ed25519 public key multicodec value */
|
package/dist/chain/index.js
CHANGED
|
@@ -34,13 +34,13 @@ import {
|
|
|
34
34
|
verifyIdentityChain,
|
|
35
35
|
verifyIdentityExtensionFromTrustedState,
|
|
36
36
|
verifyRevocation
|
|
37
|
-
} from "../chunk-
|
|
37
|
+
} from "../chunk-4EJCATUC.js";
|
|
38
38
|
import {
|
|
39
39
|
ED25519_PRIV_MULTICODEC,
|
|
40
40
|
ED25519_PUB_MULTICODEC,
|
|
41
41
|
decodeMultikey,
|
|
42
42
|
encodeEd25519Multikey
|
|
43
|
-
} from "../chunk-
|
|
43
|
+
} from "../chunk-FMHROCFH.js";
|
|
44
44
|
import "../chunk-4QQ5HK5M.js";
|
|
45
45
|
export {
|
|
46
46
|
ARTIFACT_CID_ANCHOR_RE,
|
|
@@ -5,7 +5,7 @@ import {
|
|
|
5
5
|
matchesResource,
|
|
6
6
|
verifyDFOSCredential,
|
|
7
7
|
verifyDelegationChain
|
|
8
|
-
} from "./chunk-
|
|
8
|
+
} from "./chunk-FMHROCFH.js";
|
|
9
9
|
import {
|
|
10
10
|
createJws,
|
|
11
11
|
dagCborCanonicalEncode,
|
|
@@ -27,7 +27,7 @@ var MultikeyPublicKey = z.looseObject({
|
|
|
27
27
|
publicKeyMultibase: z.string()
|
|
28
28
|
});
|
|
29
29
|
var CONTENT_ID_ANCHOR_RE = /^[2346789acdefhknrtvz]{31}$/;
|
|
30
|
-
var ARTIFACT_CID_ANCHOR_RE = /^
|
|
30
|
+
var ARTIFACT_CID_ANCHOR_RE = /^bafyrei[a-z2-7]{52}$/;
|
|
31
31
|
var ServiceEntry = z.object({
|
|
32
32
|
id: z.string().min(1),
|
|
33
33
|
type: z.string().min(1)
|
|
@@ -108,8 +108,7 @@ var ContentCreate = z.looseObject({
|
|
|
108
108
|
did: z.string(),
|
|
109
109
|
documentCID: CIDString,
|
|
110
110
|
baseDocumentCID: CIDString.nullable(),
|
|
111
|
-
createdAt: Iso8601
|
|
112
|
-
note: z.string().nullable()
|
|
111
|
+
createdAt: Iso8601
|
|
113
112
|
});
|
|
114
113
|
var ContentUpdate = z.looseObject({
|
|
115
114
|
version: z.literal(1),
|
|
@@ -119,7 +118,6 @@ var ContentUpdate = z.looseObject({
|
|
|
119
118
|
documentCID: CIDString.nullable(),
|
|
120
119
|
baseDocumentCID: CIDString.nullable(),
|
|
121
120
|
createdAt: Iso8601,
|
|
122
|
-
note: z.string().nullable(),
|
|
123
121
|
/** DFOS credential authorizing this operation when signer is not the chain creator */
|
|
124
122
|
authorization: z.string().optional()
|
|
125
123
|
});
|
|
@@ -129,7 +127,6 @@ var ContentDelete = z.looseObject({
|
|
|
129
127
|
did: z.string(),
|
|
130
128
|
previousOperationCID: CIDString,
|
|
131
129
|
createdAt: Iso8601,
|
|
132
|
-
note: z.string().nullable(),
|
|
133
130
|
/** DFOS credential authorizing this operation when signer is not the chain creator */
|
|
134
131
|
authorization: z.string().optional()
|
|
135
132
|
});
|
|
@@ -292,16 +292,16 @@ var verifyDelegationChain = async (credential, options) => {
|
|
|
292
292
|
chain.push(parent);
|
|
293
293
|
current = parent;
|
|
294
294
|
}
|
|
295
|
-
throw new CredentialVerificationError("delegation chain too deep (max 16
|
|
295
|
+
throw new CredentialVerificationError("delegation chain too deep (max 16 credentials)");
|
|
296
296
|
};
|
|
297
297
|
var parseResource = (resource) => {
|
|
298
298
|
const colonIdx = resource.indexOf(":");
|
|
299
299
|
if (colonIdx < 0) return null;
|
|
300
300
|
return { type: resource.substring(0, colonIdx), id: resource.substring(colonIdx + 1) };
|
|
301
301
|
};
|
|
302
|
-
var parseActions = (action) =>
|
|
303
|
-
|
|
304
|
-
|
|
302
|
+
var parseActions = (action) => new Set(
|
|
303
|
+
action.split(",").map((a) => a.trim()).filter((a) => a !== "")
|
|
304
|
+
);
|
|
305
305
|
var isAttenuated = (parentAtt, childAtt) => {
|
|
306
306
|
return childAtt.every((childEntry) => {
|
|
307
307
|
const childRes = parseResource(childEntry.resource);
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import { z } from 'zod';
|
|
2
|
-
import { V as VerifiedIdentity } from '../schemas-
|
|
2
|
+
import { V as VerifiedIdentity } from '../schemas-BXye25k7.js';
|
|
3
3
|
|
|
4
4
|
/**
|
|
5
5
|
* Max byte length of a credential JWS token — the credential's analog of
|
|
6
6
|
* MAX_OPERATION_SIZE. Credentials are EXEMPT from the 64 KiB operation cap (a
|
|
7
|
-
* maximum-depth 16-
|
|
7
|
+
* maximum-depth 16-credential delegation chain embeds each parent token in `prf` and
|
|
8
8
|
* legitimately exceeds it), so they carry their own larger ceiling. Measured
|
|
9
9
|
* over the serialized leaf token, which contains the entire nested chain, so one
|
|
10
10
|
* bound caps the whole delegation. A DoS guard on the nested `prf` structure;
|
package/dist/index.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
export { JwsHeader, JwsVerificationError, JwtClaims, JwtCreateOptions, JwtHeader, JwtVerificationError, JwtVerifyOptions, PrefixedID, assertJwsProfile, base64urlDecode, base64urlEncode, createJws, createJwt, createNewEd25519Keypair, dagCborCanonicalEncode, decodeJwsUnsafe, decodeJwtUnsafe, generateId, generateIdNoPrefix, importEd25519Keypair, isCanonicallyEqual, isValidEd25519Signature, isValidId, normalizedId, parseDagCborCID, signPayloadEd25519, verifyJws, verifyJwt } from './crypto/index.js';
|
|
2
|
-
export { A as ARTIFACT_CID_ANCHOR_RE, a as ArtifactPayload, C as CONTENT_ID_ANCHOR_RE, b as ContentOperation, c as CountersignPayload, I as IdentityOperation, M as MAX_ARTIFACT_PAYLOAD_SIZE, d as MAX_OPERATION_SIZE, e as MAX_SERVICES_ENTRIES, f as MAX_SERVICES_PAYLOAD_SIZE, g as MultikeyPublicKey, R as RevocationPayload, S as ServiceEntry, h as ServicesArray, i as Signer, V as VerifiedIdentity } from './schemas-
|
|
2
|
+
export { A as ARTIFACT_CID_ANCHOR_RE, a as ArtifactPayload, C as CONTENT_ID_ANCHOR_RE, b as ContentOperation, c as CountersignPayload, I as IdentityOperation, M as MAX_ARTIFACT_PAYLOAD_SIZE, d as MAX_OPERATION_SIZE, e as MAX_SERVICES_ENTRIES, f as MAX_SERVICES_PAYLOAD_SIZE, g as MultikeyPublicKey, R as RevocationPayload, S as ServiceEntry, h as ServicesArray, i as Signer, V as VerifiedIdentity } from './schemas-BXye25k7.js';
|
|
3
3
|
export { AnchorKind, ED25519_PRIV_MULTICODEC, ED25519_PUB_MULTICODEC, RECOGNIZED_SERVICE_TYPES, VerifiedArtifact, VerifiedContentChain, VerifiedCountersignature, VerifiedRevocation, anchorsByLabel, assertServicesWithinCap, classifyAnchor, decodeMultikey, deriveChainIdentifier, deriveContentId, encodeEd25519Multikey, isRecognizedServiceType, relayEndpoints, signArtifact, signContentOperation, signCountersignature, signIdentityOperation, signRevocation, verifyArtifact, verifyContentChain, verifyContentExtensionFromTrustedState, verifyCountersignature, verifyIdentityChain, verifyIdentityExtensionFromTrustedState, verifyRevocation } from './chain/index.js';
|
|
4
4
|
export { Attenuation, AuthTokenClaims, AuthTokenCreateOptions, AuthTokenVerificationError, AuthTokenVerifyOptions, CredentialVerificationError, DFOSCredentialPayload, MAX_CREDENTIAL_SIZE, VerifiedAuthToken, VerifiedDFOSCredential, VerifiedDelegationChain, createAuthToken, createDFOSCredential, decodeDFOSCredentialUnsafe, isAttenuated, matchesResource, verifyAuthToken, verifyDFOSCredential, verifyDelegationChain } from './credentials/index.js';
|
|
5
5
|
import 'multiformats';
|
package/dist/index.js
CHANGED
|
@@ -34,7 +34,7 @@ import {
|
|
|
34
34
|
verifyIdentityChain,
|
|
35
35
|
verifyIdentityExtensionFromTrustedState,
|
|
36
36
|
verifyRevocation
|
|
37
|
-
} from "./chunk-
|
|
37
|
+
} from "./chunk-4EJCATUC.js";
|
|
38
38
|
import {
|
|
39
39
|
Attenuation,
|
|
40
40
|
AuthTokenClaims,
|
|
@@ -54,7 +54,7 @@ import {
|
|
|
54
54
|
verifyAuthToken,
|
|
55
55
|
verifyDFOSCredential,
|
|
56
56
|
verifyDelegationChain
|
|
57
|
-
} from "./chunk-
|
|
57
|
+
} from "./chunk-FMHROCFH.js";
|
|
58
58
|
import {
|
|
59
59
|
JwsVerificationError,
|
|
60
60
|
JwtVerificationError,
|
|
@@ -37,9 +37,19 @@ type MultikeyPublicKey = z.infer<typeof MultikeyPublicKey>;
|
|
|
37
37
|
* Anchor target shapes — a ContentAnchor references a STABLE content
|
|
38
38
|
* identifier, dispatched by structural form:
|
|
39
39
|
* - 31-char contentId (content chain) → mutable, gateable
|
|
40
|
-
* - CIDv1
|
|
41
|
-
* Both are stable; a chain HEAD CID (also
|
|
42
|
-
* op) is rejected by the shape-dispatch + resolution type check,
|
|
40
|
+
* - CIDv1 dag-cbor+sha256 (artifact) → immutable, public
|
|
41
|
+
* Both are stable; a chain HEAD CID (also a `bafyrei…` CID but resolves to a
|
|
42
|
+
* non-artifact op) is rejected by the shape-dispatch + resolution type check,
|
|
43
|
+
* never anchored.
|
|
44
|
+
*
|
|
45
|
+
* The artifact form is the EXACT 59-char CIDv1(dag-cbor 0x71 + sha256 0x12 0x20)
|
|
46
|
+
* base32 string — 36 raw bytes → 58 base32 chars + the `b` multibase prefix,
|
|
47
|
+
* fixed `bafyrei` head + 52 base32 chars. Artifact payloads are ALWAYS dag-cbor +
|
|
48
|
+
* sha256 (ArtifactPayload below), so every real artifact CID is `bafyrei…`. The
|
|
49
|
+
* regex is pinned to that exact length (not a loose `baf…{20,}`) so an anchor of
|
|
50
|
+
* any other shape — wrong codec, wrong length — is rejected uniformly across
|
|
51
|
+
* implementations. New anchor KINDS arrive via a new service `type`, never a new
|
|
52
|
+
* anchor shape.
|
|
43
53
|
*/
|
|
44
54
|
declare const CONTENT_ID_ANCHOR_RE: RegExp;
|
|
45
55
|
declare const ARTIFACT_CID_ANCHOR_RE: RegExp;
|
|
@@ -148,7 +158,6 @@ declare const ContentOperation: z.ZodDiscriminatedUnion<[z.ZodObject<{
|
|
|
148
158
|
documentCID: z.ZodString;
|
|
149
159
|
baseDocumentCID: z.ZodNullable<z.ZodString>;
|
|
150
160
|
createdAt: z.ZodISODateTime;
|
|
151
|
-
note: z.ZodNullable<z.ZodString>;
|
|
152
161
|
}, z.core.$loose>, z.ZodObject<{
|
|
153
162
|
version: z.ZodLiteral<1>;
|
|
154
163
|
type: z.ZodLiteral<"update">;
|
|
@@ -157,7 +166,6 @@ declare const ContentOperation: z.ZodDiscriminatedUnion<[z.ZodObject<{
|
|
|
157
166
|
documentCID: z.ZodNullable<z.ZodString>;
|
|
158
167
|
baseDocumentCID: z.ZodNullable<z.ZodString>;
|
|
159
168
|
createdAt: z.ZodISODateTime;
|
|
160
|
-
note: z.ZodNullable<z.ZodString>;
|
|
161
169
|
authorization: z.ZodOptional<z.ZodString>;
|
|
162
170
|
}, z.core.$loose>, z.ZodObject<{
|
|
163
171
|
version: z.ZodLiteral<1>;
|
|
@@ -165,7 +173,6 @@ declare const ContentOperation: z.ZodDiscriminatedUnion<[z.ZodObject<{
|
|
|
165
173
|
did: z.ZodString;
|
|
166
174
|
previousOperationCID: z.ZodString;
|
|
167
175
|
createdAt: z.ZodISODateTime;
|
|
168
|
-
note: z.ZodNullable<z.ZodString>;
|
|
169
176
|
authorization: z.ZodOptional<z.ZodString>;
|
|
170
177
|
}, z.core.$loose>], "type">;
|
|
171
178
|
type ContentOperation = z.infer<typeof ContentOperation>;
|
|
@@ -2,8 +2,8 @@
|
|
|
2
2
|
"description": "Content chain: creator signs genesis, delegate signs update with write credential",
|
|
3
3
|
"type": "content-delegated",
|
|
4
4
|
"chain": [
|
|
5
|
-
"
|
|
6
|
-
"
|
|
5
|
+
"eyJhbGciOiJFZERTQSIsInR5cCI6ImRpZDpkZm9zOmNvbnRlbnQtb3AiLCJraWQiOiJkaWQ6ZGZvczpjbm5uZnQ5ZjhhMnJuOTM4ZDZua3ozOHI4NDd2MmtyI2tleV9yOWV2MzRmdmMyM3o5OTl2ZWFhZnQ4M25uMjl6dmhlIiwiY2lkIjoiYmFmeXJlaWFjZXVvcW1jc3ZjdXZmN3M3YnlscWtvaG01aDdtdXhxbWVxbXYzbjdpc3F0ZHl0dzZuZ3kifQ.eyJ2ZXJzaW9uIjoxLCJ0eXBlIjoiY3JlYXRlIiwiZGlkIjoiZGlkOmRmb3M6Y25ubmZ0OWY4YTJybjkzOGQ2bmt6MzhyODQ3djJrciIsImRvY3VtZW50Q0lEIjoiYmFmeXJlaWRyd2V4NWRjYjJ1c3NqNmJ0eGJjMzQyM3U1d2VzNnJyd29tbXhhemt1bHRzcG9oN2EzdGkiLCJiYXNlRG9jdW1lbnRDSUQiOm51bGwsImNyZWF0ZWRBdCI6IjIwMjYtMDMtMDdUMDA6MTA6MDAuMDAwWiJ9.5S4nTGLjqy6WD1ojt8h858AsTh_js8kV_YJsRY-LeERRIPnPBG2wMbYgVhWcTUX2iYln_l-PgRlGlcs3XT98DA",
|
|
6
|
+
"eyJhbGciOiJFZERTQSIsInR5cCI6ImRpZDpkZm9zOmNvbnRlbnQtb3AiLCJraWQiOiJkaWQ6ZGZvczo5NGFoNzk2M24yMjNrOGM5ODg0aGgyN2VraDQybmVhI2tleV9hOHIyNzQzNGFhcjc2YWU3MmM4NzdmYTQ3a2FyOHJuIiwiY2lkIjoiYmFmeXJlaWVrNXozNXRiN256aTdoY3praGJseG56d2xjcjNtY25pbXlmcWh4NzRqbWhmM2FyYzd3YmkifQ.eyJ2ZXJzaW9uIjoxLCJ0eXBlIjoidXBkYXRlIiwiZGlkIjoiZGlkOmRmb3M6OTRhaDc5NjNuMjIzazhjOTg4NGhoMjdla2g0Mm5lYSIsInByZXZpb3VzT3BlcmF0aW9uQ0lEIjoiYmFmeXJlaWFjZXVvcW1jc3ZjdXZmN3M3YnlscWtvaG01aDdtdXhxbWVxbXYzbjdpc3F0ZHl0dzZuZ3kiLCJkb2N1bWVudENJRCI6ImJhZnlyZWllanNzaWhrZGZsamphYmRhbWhrdXlpYm1jNzQzaG4zaTM2YTdmbnV6c2plb2FydHBlNXdhIiwiYmFzZURvY3VtZW50Q0lEIjoiYmFmeXJlaWRyd2V4NWRjYjJ1c3NqNmJ0eGJjMzQyM3U1d2VzNnJyd29tbXhhemt1bHRzcG9oN2EzdGkiLCJjcmVhdGVkQXQiOiIyMDI2LTAzLTA3VDAwOjExOjAwLjAwMFoiLCJhdXRob3JpemF0aW9uIjoiZXlKaGJHY2lPaUpGWkVSVFFTSXNJblI1Y0NJNkltUnBaRHBrWm05ek9tTnlaV1JsYm5ScFlXd2lMQ0pyYVdRaU9pSmthV1E2WkdadmN6cGpibTV1Wm5RNVpqaGhNbkp1T1RNNFpEWnVhM296T0hJNE5EZDJNbXR5STJ0bGVWOXlPV1YyTXpSbWRtTXlNM281T1RsMlpXRmhablE0TTI1dU1qbDZkbWhsSWl3aVkybGtJam9pWW1GbWVYSmxhV1Z5ZERKcWNHaHJlWEI0ZDIxMWFqZHRkbTExY0hoamQybzNlbkZxZUdJek1tMTFhbnBwTWpObVlua3lkekpzWW5Wa2EzVWlmUS5leUoyWlhKemFXOXVJam94TENKMGVYQmxJam9pUkVaUFUwTnlaV1JsYm5ScFlXd2lMQ0pwYzNNaU9pSmthV1E2WkdadmN6cGpibTV1Wm5RNVpqaGhNbkp1T1RNNFpEWnVhM296T0hJNE5EZDJNbXR5SWl3aVlYVmtJam9pWkdsa09tUm1iM002T1RSaGFEYzVOak51TWpJemF6aGpPVGc0Tkdob01qZGxhMmcwTW01bFlTSXNJbUYwZENJNlczc2ljbVZ6YjNWeVkyVWlPaUpqYUdGcGJqb3lNbU00Y25ab09ISjJaRGRoTjJSa2EyVnJNelEwTXpKb2VucG9OelJ5SWl3aVlXTjBhVzl1SWpvaWQzSnBkR1VpZlYwc0luQnlaaUk2VzEwc0ltVjRjQ0k2TVRjNU9EYzJNVFl3TUN3aWFXRjBJam94TnpjeU9EUXhOakF3ZlEuZXJYMkRSUnRSWnctdFFueGd0RWE2SGNyaHZGM0pONHNESHppbGxFOXY1ZkhMYldLMEtJVTQ5SWtNRTdBTmJ5bDBETWo0WDRQTlZFZk1QUDlHRTFiQ0EifQ.XtEeHcTkXUaPPrkfH3a_JIxzgqL5fKe4jR7r52VpgnBx_ptjeyBmy9kjJxM0e0rpKkFSwE2Egi06yEr7a9q_DA"
|
|
7
7
|
],
|
|
8
8
|
"creatorPublicKey": "z6MkrzLMNwoJSV4P3YccWcbtk8vd9LtgMKnLeaDLUqLuASjb",
|
|
9
9
|
"delegatePublicKey": "z6MkvsvmSh2dGnu2qw1Tnw7M5fz98ycfuYGxqnpfgmPkLv7o",
|
|
@@ -33,9 +33,9 @@
|
|
|
33
33
|
"createdAt": "2026-03-07T00:11:00.000Z"
|
|
34
34
|
}
|
|
35
35
|
],
|
|
36
|
-
"authorization": "
|
|
36
|
+
"authorization": "eyJhbGciOiJFZERTQSIsInR5cCI6ImRpZDpkZm9zOmNyZWRlbnRpYWwiLCJraWQiOiJkaWQ6ZGZvczpjbm5uZnQ5ZjhhMnJuOTM4ZDZua3ozOHI4NDd2MmtyI2tleV9yOWV2MzRmdmMyM3o5OTl2ZWFhZnQ4M25uMjl6dmhlIiwiY2lkIjoiYmFmeXJlaWVydDJqcGhreXB4d211ajdtdm11cHhjd2o3enFqeGIzMm11anppMjNmYnkydzJsYnVka3UifQ.eyJ2ZXJzaW9uIjoxLCJ0eXBlIjoiREZPU0NyZWRlbnRpYWwiLCJpc3MiOiJkaWQ6ZGZvczpjbm5uZnQ5ZjhhMnJuOTM4ZDZua3ozOHI4NDd2MmtyIiwiYXVkIjoiZGlkOmRmb3M6OTRhaDc5NjNuMjIzazhjOTg4NGhoMjdla2g0Mm5lYSIsImF0dCI6W3sicmVzb3VyY2UiOiJjaGFpbjoyMmM4cnZoOHJ2ZDdhN2Rka2VrMzQ0MzJoenpoNzRyIiwiYWN0aW9uIjoid3JpdGUifV0sInByZiI6W10sImV4cCI6MTc5ODc2MTYwMCwiaWF0IjoxNzcyODQxNjAwfQ.erX2DRRtRZw-tQnxgtEa6HcrhvF3JN4sDHzillE9v5fHLbWK0KIU49IkME7ANbyl0DMj4X4PNVEfMPP9GE1bCA",
|
|
37
37
|
"expected": {
|
|
38
|
-
"contentId": "
|
|
38
|
+
"contentId": "22c8rvh8rvd7a7ddkek34432hzzh74r",
|
|
39
39
|
"creatorDID": "did:dfos:cnnnft9f8a2rn938d6nkz38r847v2kr",
|
|
40
40
|
"isDeleted": false,
|
|
41
41
|
"currentDocumentCID": "bafyreiejssihkdfljjabdamhkuyibmc743hn3i36a7fnuzsjeoartpe5wa",
|
|
@@ -2,8 +2,8 @@
|
|
|
2
2
|
"description": "Content chain: create + delete",
|
|
3
3
|
"type": "content",
|
|
4
4
|
"chain": [
|
|
5
|
-
"
|
|
6
|
-
"
|
|
5
|
+
"eyJhbGciOiJFZERTQSIsInR5cCI6ImRpZDpkZm9zOmNvbnRlbnQtb3AiLCJraWQiOiJkaWQ6ZGZvczpjbm5uZnQ5ZjhhMnJuOTM4ZDZua3ozOHI4NDd2MmtyI2tleV9lejlhODc0dGNrcjNkdjkzM2QzY2tkbjd6NnpyY3Q4IiwiY2lkIjoiYmFmeXJlaWQyNmJhZ241Y2ZlZTN4cHRhZmptYmx4d3VkdzQzNXA2cms1ZzNwNGdqdGtudXlscnhzc3kifQ.eyJ2ZXJzaW9uIjoxLCJ0eXBlIjoiY3JlYXRlIiwiZGlkIjoiZGlkOmRmb3M6Y25ubmZ0OWY4YTJybjkzOGQ2bmt6MzhyODQ3djJrciIsImRvY3VtZW50Q0lEIjoiYmFmeXJlaWV2Y3FybXZ0ejJwaXM1dGRpenQ3c2pvdG9xcW9nbDZ2cnJxZ2E2NHcydG53a3Eycm51ZHkiLCJiYXNlRG9jdW1lbnRDSUQiOm51bGwsImNyZWF0ZWRBdCI6IjIwMjYtMDMtMDdUMDA6MDI6MDAuMDAwWiJ9.mTRCvPga89hVeu-gNowrL8TApoGJlxVQBw3CzrvEA-LxAQaSp03Uyn0JwdhPWh22UtwZTe2d27IIuJ7P-5PtAA",
|
|
6
|
+
"eyJhbGciOiJFZERTQSIsInR5cCI6ImRpZDpkZm9zOmNvbnRlbnQtb3AiLCJraWQiOiJkaWQ6ZGZvczpjbm5uZnQ5ZjhhMnJuOTM4ZDZua3ozOHI4NDd2MmtyI2tleV9lejlhODc0dGNrcjNkdjkzM2QzY2tkbjd6NnpyY3Q4IiwiY2lkIjoiYmFmeXJlaWhkcTZ0ZGw0c2R1N3V6b3l3c3p1NnNrMnJveGd1b3hqenp2ZjRkeTZtcDRmaGdkemczYm0ifQ.eyJ2ZXJzaW9uIjoxLCJ0eXBlIjoiZGVsZXRlIiwiZGlkIjoiZGlkOmRmb3M6Y25ubmZ0OWY4YTJybjkzOGQ2bmt6MzhyODQ3djJrciIsInByZXZpb3VzT3BlcmF0aW9uQ0lEIjoiYmFmeXJlaWQyNmJhZ241Y2ZlZTN4cHRhZmptYmx4d3VkdzQzNXA2cms1ZzNwNGdqdGtudXlscnhzc3kiLCJjcmVhdGVkQXQiOiIyMDI2LTAzLTA3VDAwOjAzOjAwLjAwMFoifQ.AgSmh-c1vXQYDan91HHkt8js1AH3upLxodv45RcfU-4TTNRaJq6fLdwe8tlto3N1_RSdaxhEEee9GgTLpYmXAQ"
|
|
7
7
|
],
|
|
8
8
|
"signerPublicKey": "z6MkfUd65JrAhfdgFuMCccU9ThQvjB2fJAMUHkuuajF992gK",
|
|
9
9
|
"documents": [
|
|
@@ -21,7 +21,7 @@
|
|
|
21
21
|
}
|
|
22
22
|
],
|
|
23
23
|
"expected": {
|
|
24
|
-
"contentId": "
|
|
24
|
+
"contentId": "a3n7r3nde8e4keeak92rr3aeztftvc2",
|
|
25
25
|
"isDeleted": true,
|
|
26
26
|
"currentDocumentCID": null,
|
|
27
27
|
"length": 2
|
|
@@ -2,8 +2,8 @@
|
|
|
2
2
|
"description": "Content chain: create + update (with both documents)",
|
|
3
3
|
"type": "content",
|
|
4
4
|
"chain": [
|
|
5
|
-
"
|
|
6
|
-
"
|
|
5
|
+
"eyJhbGciOiJFZERTQSIsInR5cCI6ImRpZDpkZm9zOmNvbnRlbnQtb3AiLCJraWQiOiJkaWQ6ZGZvczpjbm5uZnQ5ZjhhMnJuOTM4ZDZua3ozOHI4NDd2MmtyI2tleV9lejlhODc0dGNrcjNkdjkzM2QzY2tkbjd6NnpyY3Q4IiwiY2lkIjoiYmFmeXJlaWQyNmJhZ241Y2ZlZTN4cHRhZmptYmx4d3VkdzQzNXA2cms1ZzNwNGdqdGtudXlscnhzc3kifQ.eyJ2ZXJzaW9uIjoxLCJ0eXBlIjoiY3JlYXRlIiwiZGlkIjoiZGlkOmRmb3M6Y25ubmZ0OWY4YTJybjkzOGQ2bmt6MzhyODQ3djJrciIsImRvY3VtZW50Q0lEIjoiYmFmeXJlaWV2Y3FybXZ0ejJwaXM1dGRpenQ3c2pvdG9xcW9nbDZ2cnJxZ2E2NHcydG53a3Eycm51ZHkiLCJiYXNlRG9jdW1lbnRDSUQiOm51bGwsImNyZWF0ZWRBdCI6IjIwMjYtMDMtMDdUMDA6MDI6MDAuMDAwWiJ9.mTRCvPga89hVeu-gNowrL8TApoGJlxVQBw3CzrvEA-LxAQaSp03Uyn0JwdhPWh22UtwZTe2d27IIuJ7P-5PtAA",
|
|
6
|
+
"eyJhbGciOiJFZERTQSIsInR5cCI6ImRpZDpkZm9zOmNvbnRlbnQtb3AiLCJraWQiOiJkaWQ6ZGZvczpjbm5uZnQ5ZjhhMnJuOTM4ZDZua3ozOHI4NDd2MmtyI2tleV9lejlhODc0dGNrcjNkdjkzM2QzY2tkbjd6NnpyY3Q4IiwiY2lkIjoiYmFmeXJlaWEybGxwbHVvN2kyc2xoNzUyaXB3YnNxd2t2YXppdmpidnpkN202NmlzZm16aGJvaDNsNnkifQ.eyJ2ZXJzaW9uIjoxLCJ0eXBlIjoidXBkYXRlIiwiZGlkIjoiZGlkOmRmb3M6Y25ubmZ0OWY4YTJybjkzOGQ2bmt6MzhyODQ3djJrciIsInByZXZpb3VzT3BlcmF0aW9uQ0lEIjoiYmFmeXJlaWQyNmJhZ241Y2ZlZTN4cHRhZmptYmx4d3VkdzQzNXA2cms1ZzNwNGdqdGtudXlscnhzc3kiLCJkb2N1bWVudENJRCI6ImJhZnlyZWlmZXRwdXRreTRmbnp2N3NyZzdsN3luaWg2ajR5dHplcWlicmNwNXVpZXB2b2x4cWhjYmN5IiwiYmFzZURvY3VtZW50Q0lEIjoiYmFmeXJlaWV2Y3FybXZ0ejJwaXM1dGRpenQ3c2pvdG9xcW9nbDZ2cnJxZ2E2NHcydG53a3Eycm51ZHkiLCJjcmVhdGVkQXQiOiIyMDI2LTAzLTA3VDAwOjAzOjAwLjAwMFoifQ._1k6S9qAFJeS7Ti1CmF32PhPjIxNTAiA63rSo9oF88Nf7ksKc1ENLLYgjkJcb6YOZ-C7O_3i_noJfnFsrX1xBQ"
|
|
7
7
|
],
|
|
8
8
|
"signerPublicKey": "z6MkfUd65JrAhfdgFuMCccU9ThQvjB2fJAMUHkuuajF992gK",
|
|
9
9
|
"documents": [
|
|
@@ -33,7 +33,7 @@
|
|
|
33
33
|
}
|
|
34
34
|
],
|
|
35
35
|
"expected": {
|
|
36
|
-
"contentId": "
|
|
36
|
+
"contentId": "a3n7r3nde8e4keeak92rr3aeztftvc2",
|
|
37
37
|
"isDeleted": false,
|
|
38
38
|
"currentDocumentCID": "bafyreifetputky4fnzv7srg7l7ynih6j4ytzeqibrcp5uiepvolxqhcbcy",
|
|
39
39
|
"length": 2
|
|
@@ -2,12 +2,12 @@
|
|
|
2
2
|
"description": "DFOS credential: write access (broad + narrowed)",
|
|
3
3
|
"type": "credential",
|
|
4
4
|
"broadCredential": "eyJhbGciOiJFZERTQSIsInR5cCI6ImRpZDpkZm9zOmNyZWRlbnRpYWwiLCJraWQiOiJkaWQ6ZGZvczpjbm5uZnQ5ZjhhMnJuOTM4ZDZua3ozOHI4NDd2MmtyI2tleV9yOWV2MzRmdmMyM3o5OTl2ZWFhZnQ4M25uMjl6dmhlIiwiY2lkIjoiYmFmeXJlaWZ5aW5ieGhicml0NTZtM2FhdjY2bXc0eGQ2YWRxamFzdmNmaG11NjZnNnRudXFncnljbG0ifQ.eyJ2ZXJzaW9uIjoxLCJ0eXBlIjoiREZPU0NyZWRlbnRpYWwiLCJpc3MiOiJkaWQ6ZGZvczpjbm5uZnQ5ZjhhMnJuOTM4ZDZua3ozOHI4NDd2MmtyIiwiYXVkIjoiZGlkOmRmb3M6OTRhaDc5NjNuMjIzazhjOTg4NGhoMjdla2g0Mm5lYSIsImF0dCI6W3sicmVzb3VyY2UiOiJjaGFpbjoqIiwiYWN0aW9uIjoid3JpdGUifV0sInByZiI6W10sImV4cCI6MTc5ODc2MTYwMCwiaWF0IjoxNzcyODQxNjAwfQ.A-EygURAN2bALVwI2AZKFEuy30ZnWJFBaD4jCTf1d7A90rYELStjTWJ1iI7OulihTCfaVtlvj5HtX6Dwv1VxAg",
|
|
5
|
-
"narrowCredential": "
|
|
5
|
+
"narrowCredential": "eyJhbGciOiJFZERTQSIsInR5cCI6ImRpZDpkZm9zOmNyZWRlbnRpYWwiLCJraWQiOiJkaWQ6ZGZvczpjbm5uZnQ5ZjhhMnJuOTM4ZDZua3ozOHI4NDd2MmtyI2tleV9yOWV2MzRmdmMyM3o5OTl2ZWFhZnQ4M25uMjl6dmhlIiwiY2lkIjoiYmFmeXJlaWVzemt5YW9lc256eXlzcXVxc3JweGJwM2NwMmxpNGg0MjZxZGZxaXg1bnlvcnV1b3dibmEifQ.eyJ2ZXJzaW9uIjoxLCJ0eXBlIjoiREZPU0NyZWRlbnRpYWwiLCJpc3MiOiJkaWQ6ZGZvczpjbm5uZnQ5ZjhhMnJuOTM4ZDZua3ozOHI4NDd2MmtyIiwiYXVkIjoiZGlkOmRmb3M6OTRhaDc5NjNuMjIzazhjOTg4NGhoMjdla2g0Mm5lYSIsImF0dCI6W3sicmVzb3VyY2UiOiJjaGFpbjphM243cjNuZGU4ZTRrZWVhazkycnIzYWV6dGZ0dmMyIiwiYWN0aW9uIjoid3JpdGUifV0sInByZiI6W10sImV4cCI6MTc5ODc2MTYwMCwiaWF0IjoxNzcyODQxNjAwfQ.jzGLUBl0NhKaigoKH2OQBcC-bOlnhdL0ro4gWQpM2F-dZtdumxnixQ3cHabp8EaqfQ-jsRVkjqQ6Sf8sib8ZAg",
|
|
6
6
|
"issuerPublicKey": "z6MkrzLMNwoJSV4P3YccWcbtk8vd9LtgMKnLeaDLUqLuASjb",
|
|
7
7
|
"audiencePublicKey": "z6MkvsvmSh2dGnu2qw1Tnw7M5fz98ycfuYGxqnpfgmPkLv7o",
|
|
8
8
|
"expected": {
|
|
9
9
|
"iss": "did:dfos:cnnnft9f8a2rn938d6nkz38r847v2kr",
|
|
10
10
|
"aud": "did:dfos:94ah7963n223k8c9884hh27ekh42nea",
|
|
11
|
-
"narrowContentId": "
|
|
11
|
+
"narrowContentId": "a3n7r3nde8e4keeak92rr3aeztftvc2"
|
|
12
12
|
}
|
|
13
13
|
}
|
|
@@ -2,11 +2,11 @@
|
|
|
2
2
|
"description": "Identity chain: genesis publishing a services set (relay locator + content/artifact anchors)",
|
|
3
3
|
"type": "identity",
|
|
4
4
|
"chain": [
|
|
5
|
-
"
|
|
5
|
+
"eyJhbGciOiJFZERTQSIsInR5cCI6ImRpZDpkZm9zOmlkZW50aXR5LW9wIiwia2lkIjoia2V5X3I5ZXYzNGZ2YzIzejk5OXZlYWFmdDgzbm4yOXp2aGUiLCJjaWQiOiJiYWZ5cmVpZ2h1dnppdGZhN29meXlyd3l2eXVha21xZmVmem11cGhpN2ZhZmF3b3gzYWh4ZGgzdHNhNCJ9.eyJ2ZXJzaW9uIjoxLCJ0eXBlIjoiY3JlYXRlIiwiYXV0aEtleXMiOlt7ImlkIjoia2V5X3I5ZXYzNGZ2YzIzejk5OXZlYWFmdDgzbm4yOXp2aGUiLCJ0eXBlIjoiTXVsdGlrZXkiLCJwdWJsaWNLZXlNdWx0aWJhc2UiOiJ6Nk1rcnpMTU53b0pTVjRQM1ljY1djYnRrOHZkOUx0Z01LbkxlYURMVXFMdUFTamIifV0sImFzc2VydEtleXMiOlt7ImlkIjoia2V5X3I5ZXYzNGZ2YzIzejk5OXZlYWFmdDgzbm4yOXp2aGUiLCJ0eXBlIjoiTXVsdGlrZXkiLCJwdWJsaWNLZXlNdWx0aWJhc2UiOiJ6Nk1rcnpMTU53b0pTVjRQM1ljY1djYnRrOHZkOUx0Z01LbkxlYURMVXFMdUFTamIifV0sImNvbnRyb2xsZXJLZXlzIjpbeyJpZCI6ImtleV9yOWV2MzRmdmMyM3o5OTl2ZWFhZnQ4M25uMjl6dmhlIiwidHlwZSI6Ik11bHRpa2V5IiwicHVibGljS2V5TXVsdGliYXNlIjoiejZNa3J6TE1Od29KU1Y0UDNZY2NXY2J0azh2ZDlMdGdNS25MZWFETFVxTHVBU2piIn1dLCJzZXJ2aWNlcyI6W3siaWQiOiJyZWxheSIsInR5cGUiOiJEZm9zUmVsYXkiLCJlbmRwb2ludCI6Imh0dHBzOi8vcmVsYXkuZGZvcy5jb20ifSx7ImlkIjoicHJvZmlsZSIsInR5cGUiOiJDb250ZW50QW5jaG9yIiwibGFiZWwiOiJwcm9maWxlIiwiYW5jaG9yIjoiYTNuN3IzbmRlOGU0a2VlYWs5MnJyM2FlenRmdHZjMiJ9LHsiaWQiOiJhdmF0YXIiLCJ0eXBlIjoiQ29udGVudEFuY2hvciIsImxhYmVsIjoiYXZhdGFyIiwiYW5jaG9yIjoiYmFmeXJlaWV2Y3FybXZ0ejJwaXM1dGRpenQ3c2pvdG9xcW9nbDZ2cnJxZ2E2NHcydG53a3Eycm51ZHkifV0sImNyZWF0ZWRBdCI6IjIwMjYtMDMtMDdUMDA6MDU6MDAuMDAwWiJ9.uN27ljlSuUwY2EO9bfX-G2yXliJQjEsWBsHYt1-0Vds5IASc2BO8FmjhcNv5JSQjDWJ54anTR2yRPkVxkeLKBw"
|
|
6
6
|
],
|
|
7
7
|
"controllerPublicKey": "z6MkrzLMNwoJSV4P3YccWcbtk8vd9LtgMKnLeaDLUqLuASjb",
|
|
8
8
|
"expected": {
|
|
9
|
-
"did": "did:dfos:
|
|
9
|
+
"did": "did:dfos:hd34z9a4tf6h62864nh4f7at6hr36r4",
|
|
10
10
|
"isDeleted": false,
|
|
11
11
|
"controllerKeys": [
|
|
12
12
|
{
|
|
@@ -25,7 +25,7 @@
|
|
|
25
25
|
"id": "profile",
|
|
26
26
|
"type": "ContentAnchor",
|
|
27
27
|
"label": "profile",
|
|
28
|
-
"anchor": "
|
|
28
|
+
"anchor": "a3n7r3nde8e4keeak92rr3aeztftvc2"
|
|
29
29
|
},
|
|
30
30
|
{
|
|
31
31
|
"id": "avatar",
|