CypherID
CypherId is a self-sovereign decentralized ID system.
Identities (and signed identities, i.e. identity certificates)
Identity profiles
Identity attestation
Contact books
Identities
Identities consist of:
Public key on a specific curve, serialized in one of the pre-defined formats
Optional revocation single-use-seal defined using specific proof-of-publication medium
Optional signature over the public key, its curve and revocation single-use-seal (or its absence). If the signature is present the identity is called a "certificate"
Optional mnemonic must be absent in some formats (like QR code or strict binary & text).
Identities may be represented in multiple ways:
As a simply-copyable ASCII string using base58 encoding starting with
ssiprefix, enhanced with error detection checksum and optional mnemonic suffix (not covering signature even if present, but always covering seal).As a URI in form using
ssi:schema:ssi:<baid58>/bc/<txid>/<vout>?[sig=<base36cert>]#<mnemonic>As a QR code, using URI representation from the above, in alphanumeric mode
In one of Strict Encoding representations, as strict binary, strict text or JSON or YAML. Text formats may contain optional mnemonic fields, but they must always be absent in the binary serialization (since it can be re-generated from the SSI data)
data SSI ::
key secp256k1(compact [U8^33] | xonly [U8^32]) | curve25519(compact [u8^32]),
seal (bc(txid [U8^32], vout U16))?,
sig (schnorr([U8 ^ 64..65]) | ecdsa([U8 ^ 65]) | eddsa([U8 ^ 64]))?
profile Profile?
type SSIExt over SSI
{-
fn read_mnemonic :: (ssi SSI) -> (mnemo Mnemonic)
let checksum := crc32 (ssi.key, ssi.seal)
mnemo := mnemonic (checksum)
-}
read mnemonic :: [([AlphaSmall ^ 3..8])^3]
crc32 key, seal |> mnemonic
check !! SSIError -- fn check :: (SSI) -> (() | SSIError)
{- this is a lambda function
fn _match :: (ssi) -> (() | SSIError)
_match1 ssi
fn _match1 :: (ssi) -> (() | SSIError)
(and (eq ssi.key.@ty, 0), (eq ssi.sig.@ty, 1))
-}
key, sig =>
-- this a function table where each row is a lambda:
-- fn _ :: (_ _, _) -> (() | SSIError)
secp256k1(_), schnorr(_) -> (),
secp256k1(_), ecdsa(_) -> (),
curve25519(_), eddsa(_) -> (),
.. -> !! SSIError.invalidSigScheme
Last updated
