2023-07-03 02:39:23 -06:00
|
|
|
/*
|
|
|
|
Copyright 2023 Yarmo Mackenbach
|
|
|
|
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
you may not use this file except in compliance with the License.
|
|
|
|
You may obtain a copy of the License at
|
|
|
|
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
See the License for the specific language governing permissions and
|
|
|
|
limitations under the License.
|
|
|
|
*/
|
2023-07-09 03:42:21 -06:00
|
|
|
import { PublicKeyFetchMethod, PublicKeyEncoding, PublicKeyType } from './enums.js'
|
2023-07-03 02:39:23 -06:00
|
|
|
|
|
|
|
/**
|
|
|
|
* A profile of personas with identity claims
|
|
|
|
* @function
|
2023-07-09 03:42:21 -06:00
|
|
|
* @param {Array<import('./persona.js').Persona>} personas
|
2023-07-03 02:39:23 -06:00
|
|
|
* @public
|
|
|
|
* @example
|
|
|
|
* const claim = Claim('https://alice.tld', '123');
|
|
|
|
* const pers = Persona('Alice', 'About Alice', [claim]);
|
|
|
|
* const profile = Profile([pers]);
|
|
|
|
*/
|
2023-07-08 00:17:13 -06:00
|
|
|
export class Profile {
|
2023-07-03 02:39:23 -06:00
|
|
|
/**
|
2023-07-09 03:42:21 -06:00
|
|
|
* Create a new profile
|
|
|
|
* @function
|
|
|
|
* @param {import('./enums.js').ProfileType} profileType
|
|
|
|
* @param {string} identifier
|
|
|
|
* @param {Array<import('./persona.js').Persona>} personas
|
|
|
|
* @public
|
|
|
|
*/
|
|
|
|
constructor (profileType, identifier, personas) {
|
|
|
|
/**
|
|
|
|
* Profile version
|
|
|
|
* @type {number}
|
2023-07-03 02:39:23 -06:00
|
|
|
* @public
|
|
|
|
*/
|
2023-07-09 03:42:21 -06:00
|
|
|
this.profileVersion = 2
|
2023-07-03 02:39:23 -06:00
|
|
|
/**
|
2023-07-09 03:42:21 -06:00
|
|
|
* Profile version
|
|
|
|
* @type {import('./enums.js').ProfileType}
|
|
|
|
* @public
|
|
|
|
*/
|
|
|
|
this.profileType = profileType
|
|
|
|
/**
|
|
|
|
* Identifier of the profile (fingerprint, email address, uri...)
|
|
|
|
* @type {string}
|
|
|
|
* @public
|
|
|
|
*/
|
|
|
|
this.identifier = identifier
|
|
|
|
/**
|
|
|
|
* List of personas
|
|
|
|
* @type {Array<import('./persona.js').Persona>}
|
|
|
|
* @public
|
|
|
|
*/
|
2023-07-03 02:39:23 -06:00
|
|
|
this.personas = personas || []
|
|
|
|
/**
|
2023-07-09 03:42:21 -06:00
|
|
|
* Index of primary persona (to be displayed first or prominently)
|
|
|
|
* @type {number}
|
|
|
|
* @public
|
|
|
|
*/
|
|
|
|
this.primaryPersonaIndex = personas.length > 0 ? 0 : -1
|
|
|
|
/**
|
|
|
|
* The cryptographic key associated with the profile
|
|
|
|
* @property {object}
|
|
|
|
* @public
|
|
|
|
*/
|
|
|
|
this.publicKey = {
|
|
|
|
/**
|
|
|
|
* The type of cryptographic key
|
|
|
|
* @type {PublicKeyType}
|
|
|
|
* @public
|
|
|
|
*/
|
|
|
|
keyType: PublicKeyType.NONE,
|
|
|
|
/**
|
|
|
|
* The encoding of the cryptographic key
|
|
|
|
* @type {PublicKeyEncoding}
|
|
|
|
* @public
|
|
|
|
*/
|
|
|
|
encoding: PublicKeyEncoding.NONE,
|
|
|
|
/**
|
2023-07-10 02:25:17 -06:00
|
|
|
* The encoded cryptographic key
|
2023-07-09 03:42:21 -06:00
|
|
|
* @type {string | null}
|
|
|
|
* @public
|
|
|
|
*/
|
|
|
|
encodedKey: null,
|
|
|
|
/**
|
|
|
|
* The raw cryptographic key as object (to be removed during toJSON())
|
|
|
|
* @type {import('openpgp').PublicKey | import('jose').KeyLike | null}
|
|
|
|
* @public
|
|
|
|
*/
|
|
|
|
key: null,
|
|
|
|
/**
|
|
|
|
* Details on how to fetch the public key
|
|
|
|
* @property {object}
|
|
|
|
* @public
|
|
|
|
*/
|
|
|
|
fetch: {
|
|
|
|
/**
|
|
|
|
* The method to fetch the key
|
|
|
|
* @type {PublicKeyFetchMethod}
|
2023-07-03 02:39:23 -06:00
|
|
|
* @public
|
|
|
|
*/
|
2023-07-09 03:42:21 -06:00
|
|
|
method: PublicKeyFetchMethod.NONE,
|
|
|
|
/**
|
|
|
|
* The query to fetch the key
|
|
|
|
* @type {string | null}
|
|
|
|
* @public
|
|
|
|
*/
|
|
|
|
query: null,
|
|
|
|
/**
|
|
|
|
* The URL the method eventually resolved to
|
|
|
|
* @type {string | null}
|
|
|
|
* @public
|
|
|
|
*/
|
|
|
|
resolvedUrl: null
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/**
|
|
|
|
* List of verifier URLs
|
|
|
|
* @type {{name: string, url: string}[]}
|
|
|
|
* @public
|
|
|
|
*/
|
|
|
|
this.verifiers = []
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @function
|
|
|
|
* @param {string} name
|
|
|
|
* @param {string} url
|
|
|
|
*/
|
|
|
|
addVerifier (name, url) {
|
|
|
|
this.verifiers.push({ name, url })
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @function
|
|
|
|
* @param {import('openpgp').PublicKey} publicKey
|
|
|
|
*/
|
|
|
|
setOpenPgpPublicKey (publicKey) {}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @function
|
|
|
|
* @param {import('jose').KeyLike} publicKey
|
|
|
|
*/
|
|
|
|
setJwkPublicKey (publicKey) {}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get a JSON representation of the Profile object
|
|
|
|
* @function
|
|
|
|
* @returns {object}
|
|
|
|
*/
|
|
|
|
toJSON () {
|
|
|
|
return {
|
|
|
|
profileVersion: this.profileVersion,
|
|
|
|
profileType: this.profileType,
|
|
|
|
identifier: this.identifier,
|
|
|
|
personas: this.personas.map(x => x.toJSON()),
|
|
|
|
primaryPersonaIndex: this.primaryPersonaIndex,
|
|
|
|
publicKey: {
|
|
|
|
keyType: this.publicKey.keyType,
|
2023-07-10 02:25:17 -06:00
|
|
|
encoding: this.publicKey.encoding,
|
|
|
|
encodedKey: this.publicKey.encodedKey,
|
2023-07-09 03:42:21 -06:00
|
|
|
fetch: {
|
|
|
|
method: this.publicKey.fetch.method,
|
|
|
|
query: this.publicKey.fetch.query,
|
|
|
|
resolvedUrl: this.publicKey.fetch.resolvedUrl
|
|
|
|
}
|
|
|
|
},
|
|
|
|
verifiers: this.verifiers
|
|
|
|
}
|
2023-07-03 02:39:23 -06:00
|
|
|
}
|
|
|
|
}
|