Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix Document constructor Typescript bindings #423

Merged
merged 7 commits into from
Oct 1, 2021
Merged

Conversation

cycraig
Copy link
Contributor

@cycraig cycraig commented Sep 28, 2021

Description of change

This replaces the constructor for WasmDocument to fix a type mismatch in the generated bindings. Several Document constructors are also replaced with a single new() function in both Rust and Wasm. This is for consistency and to clarify the canonical method of constructing a new Document.

The downside is that this removes the ability for a developer to pass in the desired fragment name for the authentication verification method on a newly generated Document in Wasm (e.g. instead of "#authentication" one could specify "#customkey123"). This was not possible in Rust, if that behaviour is still desired we should add it in this PR to both languages.
Edit: added the ability to set the default verification method fragment in both Rust and Wasm.

Breaking changes:

  • replace IotaDocument from_keypair(), from_keypair_with_network() with new(), new_with_options().
  • the default authentication verification method fragment for a new WasmDocument is changed from "#key" to "#authentication"
    • this discrepancy seemed unintentional and now matches the Rust behaviour
  • new Document() in the Wasm bindings now take a KeyPair instead of a KeyType and returns just a Document instead of a NewDocument { Document, KeyPair } struct.
    • BEFORE: pub fn new(type_: KeyType, network: Option<String>, tag: Option<String>) -> Result<NewDocument>
    • AFTER: pub fn new(key: KeyPair, network: Option<String>, fragment: Option<String>) -> Result<Document>

Creating a new DID document in Wasm is also now a two-step process, which should be acceptable since this only affects the low-level API and matches the Rust experience.

BEFORE:

const { doc, key } = new Document(KeyType.Ed25519);

AFTER:

const key = new KeyPair(KeyType.Ed25519);
const doc = new Document(key);

NOTE: this will require updating the repl.it examples in the documentation.

Motivation

This is currently a mismatch in the expected type returned by the WasmDocument constructor compared to the generated Typescript definition:

  /// Creates a new DID Document from the given KeyPair.
  #[wasm_bindgen(constructor)]
  #[allow(clippy::new_ret_no_self)]
  pub fn new(type_: KeyType, network: Option<String>, tag: Option<String>) -> Result<NewDocument> {

where NewDocument is a struct holding the new WasmDocument and KeyPair:

#[wasm_bindgen(inspectable)]
pub struct NewDocument {
  key: KeyPair,
  doc: WasmDocument,
}

However, the generated Typescript constructor implicitly expects it to return WasmDocument, not NewDocument:

export class Document {
  free(): void;
/**
* Creates a new DID Document from the given KeyPair.
* @param {number} type_
* @param {string | undefined} network
* @param {string | undefined} tag
*/
  constructor(type_: number, network?: string, tag?: string);

Unfortunately there is no easy way to catch these types of bugs without creating dedicated Typescript tests or converting our examples to Typescript. I tried using tsc --allowJs --checkJs --noEmit on the examples but it doesn't link up to the Typescript definitions to catch the type-mismatch.

Minimal Reproducible Example

The following code snippet fails to compile when using Typescript:

example.ts:

import { Document, KeyType } from "@iota/identity-wasm/node";
const { doc, key } = new Document(KeyType.Ed25519);

Run tsc example.ts

Error:

example.ts:2:13 - error TS2339: Property 'doc' does not exist on type 'Document'.

7     const { doc, key } = new Document(KeyType.Ed25519);
              ~~~

example.ts:2:18 - error TS2339: Property 'key' does not exist on type 'Document'.

7     const { doc, key } = new Document(KeyType.Ed25519);
                   ~~~


Found 2 errors.

Note that this example runs fine in Javascript because it doesn't validate the expected type.

Type of change

  • Bug fix (a non-breaking change which fixes an issue)
  • Enhancement (a non-breaking change which adds functionality)
  • Breaking change (fix or feature that would cause existing functionality to not work as expected)
  • Documentation Fix

How the change has been tested

Tests and examples were updated and pass locally. New constructor compiles to Typescript.

Change checklist

Add an x to the boxes that are relevant to your changes.

  • I have followed the contribution guidelines for this project
  • I have performed a self-review of my own code
  • I have commented my code, particularly in hard-to-understand areas
  • I have made corresponding changes to the documentation
  • I have added tests that prove my fix is effective or that my feature works
  • New and existing unit tests pass locally with my changes

Replace IotaDocument `from_keypair()`, `from_keypair_with_network()` with `new()`.
Update Wasm binding examples to be more consistent with Rust.
@cycraig cycraig added Binding Bug Something isn't working. Wasm Related to Wasm bindings. Becomes part of the Wasm changelog labels Sep 28, 2021
@cycraig cycraig changed the title Fix WasmDocument constructor Typescript bindings Fix Document constructor Typescript bindings Sep 28, 2021
@cycraig cycraig marked this pull request as ready for review September 29, 2021 07:55
Copy link
Contributor

@PhilippGackstatter PhilippGackstatter left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I really like the decoupling of key generation and document creation. My only concern is the optional argument in IotaDocument::new that we should discuss.

// internally which verifies correctness on construction.
Ok(unsafe { Self::from_authentication_unchecked(method) })
}
const DEFAULT_METHOD_FRAGMENT: &'static str = "authentication";
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm wondering a bit about the discrepancy between what the default account-generated document and the default IotaDocument look like. The low-level API uses this "authentication" fragment, while the account uses "_sign-0" as the default fragment.

pub(crate) const AUTH: &'static str = "_sign-";

I don't see why they should not be consistent, and if we want to make them so, I would rather change the account to use something a little easier to type. But with the changes in #421 calling the default verification method "authentication" isn't quite right either, because it's a general verification method at that point. Since its main purpose is signing, I would suggest to use "sign" as the default in the low-level API, and "sign-0" in the account. Any thoughts on this? (This might be out of scope for this PR.)

Copy link
Contributor Author

@cycraig cycraig Sep 29, 2021

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

There's also the default verification method fragment "key":

pub const DEFAULT_TAG: &'static str = "key";

I agree that the Account should default to the same name as the low-level API. I particularly dislike how the fragment is used to determine whether or not a verification method is used for authentication in KeyLocation:

  /// Returns true if the key location points to an authentication method.
  pub fn is_authentication(&self) -> bool {
    Self::is_authentication_fragment(&self.fragment)
  }

  /// Returns true if the fragment points to an authentication method.
  pub fn is_authentication_fragment(fragment: &Fragment) -> bool {
    fragment.name().starts_with(Self::AUTH)         // <============= "_sign-"
  }

This could lead to confusion if someone happens to name their verification method "_sign-xyx"? Probably out-of-scope for this PR.

While the default key is used for signing, it's a bit more special than a regular verification method since it can sign document updates too. The two choices are either: choose a special name like "auth"/"default"/"bikeshedding", or treat it as a regular verification method, like "key-0" or "sign-0". Probably worth getting some more opinions on this.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The IOTA DID specification recommends the "_sign-x" name for verification method used to update the document. Just a reminder to apply whatever the final decision is to the documentation too.

It is RECOMMENDED to name this public key #_sign-x, where x is the index of the signing key, which is incremented every time the signing key is updated, starting at index 1.

DID Documents published to the Tangle must be cryptographically signed. As such the DID Document MUST include one verification method with a public key. It is recommended, for security reasons, to not use this keypair for other purposes as the control over this private key is vital for controlling the identity. It is RECOMMENDED to name this public key #_sign-x, where x is the index of the signing key, which is incremented every time the signing key is updated, starting at index 1.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks like we're going with "sign-x".

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Unfortunately verification method names are tightly coupled with the logic in the Account, so it's not as simple as choosing a different name and using any authentication verification method. It needs its own issue/PR.

identity-iota/src/did/doc/iota_document.rs Outdated Show resolved Hide resolved
identity-iota/src/did/doc/iota_document.rs Outdated Show resolved Hide resolved
identity-iota/src/did/doc/iota_document.rs Outdated Show resolved Hide resolved
cycraig and others added 3 commits September 29, 2021 18:09
Co-authored-by: Philipp <philipp.gackstatter@iota.org>
Allow default verification method fragment to be specified.
Add doc, unit tests.
Copy link
Contributor

@PhilippGackstatter PhilippGackstatter left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks great now - thanks for addressing the comments. One thought while reading over new_with_options was that we could ask for an Option<NetworkName> as the network name. But I suppose the reasoning is that this is the low-level API which shouldn't impose this restriction, and I would agree with that. We can think about changing IdentityCreate in the account though, which takes an arbitrary String as the network name.

@cycraig
Copy link
Contributor Author

cycraig commented Oct 1, 2021

One thought while reading over new_with_options was that we could ask for an Option<NetworkName> as the network name. But I suppose the reasoning is that this is the low-level API which shouldn't impose this restriction, and I would agree with that. We can think about changing IdentityCreate in the account though, which takes an arbitrary String as the network name.

The reason for using Opton<&str> was more to do with ergonomics. What I really wanted to use was Option<impl TryInto<NetworkName>> as the parameter. The problem I encountered was that using any generic as an optional parameter caused issues with None required a type annotation.

Example:

pub fn new_with_options(keypair: &KeyPair, network: Option<impl TryInto<NetworkName>>, fragment: Option<&str>)

Trying to use new_with_options with None for the network causes annoying issues since it requires a concrete type for monomorphisation:

let document = IotaDocument::new_with_options(&keypair, None, Some("fragment"))?;
error[E0283]: type annotations needed
   --> identity-iota\src\did\doc\iota_document.rs:977:47
    |
119 |   pub fn new_with_options(keypair: &KeyPair, network: Option<impl TryInto<NetworkName>>, fragment: Option<&str>) -> Result<Self> {
    |                                                                   -------------------- required by this bound in `IotaDocument::new_with_options`
...
977 |     let result: Result<IotaDocument, Error> = IotaDocument::new_with_options(&keypair, None, Some("fragment"));
    |                                               ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ cannot infer type for type parameter `impl TryInto<NetworkName>` declared on the associated function `new_with_options`
    |
    = note: cannot satisfy `_: TryInto<network::NetworkName>`
help: consider specifying the type argument in the function call
    |
977 |     let result: Result<IotaDocument, Error> = IotaDocument::new_with_options::<impl TryInto<NetworkName>>(&keypair, None, Some(""));
    |                                                                             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

Using NetworkName as the parameter is fine, and it is better than just a &str in that it communicates the restriction to the caller at compile time. It is, however, slightly more cumbersome:

E.g. with Option<NetworkName>:

pub fn new_with_options(keypair: &KeyPair, network: Option<NetworkName>, fragment: Option<&str>) -> Result<Self>;

// BEFORE:
// let document = IotaDocument::new_with_options(&keypair, Some("dev"), Some("auth-key"))?;

// AFTER:
let document = IotaDocument::new_with_options(&keypair, Some(Network::Devnet.name()), Some("auth-key"))?;
// OR
let network_name = NetworkName::try_from("dev");
let document = IotaDocument::new_with_options(&keypair, Some(network_name), Some("auth-key"))?;

One can also make the argument to use NetworkName for IotaDID::new_with_network, which currently uses &str too:

pub fn new_with_network(public: &[u8], network: &str) -> Result<Self>

On a final note, we don't seem to expose NetworkName in the Wasm bindings yet, we probably should if only for developers to validate that arbitrary strings are valid IOTA DID network names using our API.

@PhilippGackstatter
Copy link
Contributor

I mainly thought of it because you used

let document = IotaDocument::new_with_options(&keypair, Some(Network::Devnet.as_name_str()), Some("auth-key"))?;

before, which isn't less cumbersome than

let document = IotaDocument::new_with_options(&keypair, Some(Network::Devnet.name()), Some("auth-key"))?;

But the main question is if the low-level API should restrict that, or in other words, should the low-level API enforce the IOTA DID method spec? In this particular case, (after thinking more about this) I think it's actually okay to do so (contrary to what I said above).

@cycraig
Copy link
Contributor Author

cycraig commented Oct 1, 2021

True, then it really only affects private Tangle network names:

let document = IotaDocument::new_with_options(&keypair, Some("private"), Some("auth-key"))?;

// vs

let network_name = NetworkName::try_from("private")?;
let document = IotaDocument::new_with_options(&keypair, Some(network_name), Some("auth-key"))?;

If we do change it to use NetworkName, would we make the same change for IotaDID::new_with_network() too?

Edit: the low-level API already enforces the IOTA DID method spec by validating the network name string, it's a question of whether that enforcement is done at the parameter-level of the API (moving the explicit check to the caller's code when they construct the parameter type) or as internal runtime checks. This also affects things like fragment names and method references: we use strings in a lot of places where we could and probably should enforce type validation. I'm probably just hesitant to make many breaking changes, but this would be the time to do it.

Remove IotaDID::from_components.
Remove specific InvalidNetworkName strings for consistency with other errors and to use with TryInto.
Allow Network::try_from_name to take an actual NetworkName as well as a
string.
@cycraig
Copy link
Contributor Author

cycraig commented Oct 1, 2021

@PhilippGackstatter I changed the parameters for IotaDocument::new_with_options(), IotaDID::new_with_network() and IdentityCreate::network() to use NetworkName instead of &str. However, I used impl TryInto<NetworkName> so developers can still pass (static/owned) strings if they so choose.

During the refactor I started to feel like NetworkName should be an internal construct, since it's so similar to Network and is a bit confusing to deal with both in some places. I'm not entirely happy with this last change since it's a bit less clean and doesn't translate well to Wasm, but the one benefit is that IdentityCreate::network is now fallible, so invalid NetworkNames are caught earlier.

Copy link
Contributor

@PhilippGackstatter PhilippGackstatter left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Excellent improvements!

@cycraig cycraig merged commit 6094899 into dev Oct 1, 2021
@cycraig cycraig deleted the fix/document-constructor branch October 1, 2021 15:05
olivereanderson pushed a commit that referenced this pull request Oct 25, 2021
* Fix WasmDocument constructor Typescript bindings

Replace IotaDocument `from_keypair()`, `from_keypair_with_network()` with `new()`.
Update Wasm binding examples to be more consistent with Rust.

* Fix test and benchmark compilation

* Fix benchmark compilation

* Apply suggestions from code review

* Add Document::new_with_options constructor

Allow default verification method fragment to be specified.
Add doc, unit tests.

* Use NetworkName instead of &str

Remove IotaDID::from_components.
Remove specific InvalidNetworkName strings for consistency with other errors and to use with TryInto.
Allow Network::try_from_name to take an actual NetworkName as well as a
string.

Co-authored-by: Philipp <philipp.gackstatter@iota.org>
JelleMillenaar pushed a commit that referenced this pull request Nov 1, 2021
* Docs/readme improvs (#257)

* Update main readme

* WASM readme update

* Updated example with account

* Rust examples readme

* Bump wasm version

* Revert "Bump wasm version"

This reverts commit 73d9d66.

* consistent node version

* Bump wasm version

* Expand unit test coverage in bitset.rs, iota_did.rs, and iota_document.rs (#265)

* Add some tests

* Add IotaDocument::try_from_core() unit tests

* Fix clippy error

* read indexation payload from transaction payloads

* Remove IotaDID->DID Deref anti-pattern. (#269)

* Remove IotaDID->DID Deref anti-pattern.

* Address l1h3r review comments.

* Rework WASM examples to explicitly use client configs. (#275)

* Rework WASM examples to explicitly use client configs.

* Add explorer_util.js adn fix typo.

* Fix explorer URL construction.

Inlined the prefix since it is no longer exported.

* Bump dns-packet from 1.3.1 to 1.3.4 in /bindings/wasm (#277)

Bumps [dns-packet](https://github.com/mafintosh/dns-packet) from 1.3.1 to 1.3.4.
- [Release notes](https://github.com/mafintosh/dns-packet/releases)
- [Changelog](https://github.com/mafintosh/dns-packet/blob/master/CHANGELOG.md)
- [Commits](mafintosh/dns-packet@v1.3.1...v1.3.4)

Signed-off-by: dependabot[bot] <support@github.com>

Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>

* Bump browserslist from 4.16.3 to 4.16.6 in /bindings/wasm (#278)

Bumps [browserslist](https://github.com/browserslist/browserslist) from 4.16.3 to 4.16.6.
- [Release notes](https://github.com/browserslist/browserslist/releases)
- [Changelog](https://github.com/browserslist/browserslist/blob/main/CHANGELOG.md)
- [Commits](browserslist/browserslist@4.16.3...4.16.6)

Signed-off-by: dependabot[bot] <support@github.com>

Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>

* Add IotaDocument::from_keypair_with_network() and WASM binding. (#276)

* Add IotaDocument::from_keypair_with_network() and WASM binding.

* Undo unintentional formatting in README.

* Add optional network arg to from_keypair WASM binding.

* Update API reference for fromKeyPair.

* Update README.

* Update bindings/wasm/src/wasm_document.rs

* Use u32 for message delays (#281)

* Use u32 for message delays

* Update docs

* Update version

* Bump ws from 6.2.1 to 6.2.2 in /bindings/wasm (#282)

Bumps [ws](https://github.com/websockets/ws) from 6.2.1 to 6.2.2.
- [Release notes](https://github.com/websockets/ws/releases)
- [Commits](https://github.com/websockets/ws/commits)

---
updated-dependencies:
- dependency-name: ws
  dependency-type: indirect
...

Signed-off-by: dependabot[bot] <support@github.com>

Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>

* docs: Fix some typos in the method spec

* docs: Describe build process for wasm bindings

* Update iota-client (#270)

* Update iota-client

* Fix features

* New client builder

* New wasm client

* Update examples

* More common types (#283)

* Fragment/UnixTimestamp -> core::common

* clippy

* Timestamp::now -> Timestamp::now_utc

* Remove shard from DIDs (#280)

* Remove shard from DIDs

* wasm fixes

* update yarn.lock

* doctest

* Version Bump

* Restore checkCredential/checkPresentation WASM functions (#287)

* Restore client.checkCredential/checkPresentation

* doc: Serialize `message_id` for `IotaDocument`s

* wasm: Fix incorrect path in example imports

* client: Rename `read_document` to `resolve`

* Revert "doc: Serialize `message_id` for `IotaDocument`s"

This reverts commit 26e2dcd.

* wasm: Serialize `message_id` for resolve method

Co-authored-by: PhilippGackstatter <philipp.gackstatter@iota.org>

* Add blake2b to wasm bindings (#288)

* Add blake2b to wasm bindings

* docs

* core: Reimpl `Key` with generics

* replace deleted method readDocument(id) with resolve(id) (#294)

* account: Disable custom riker logging

* Docs/setup docusaurus (#298)

* setup docusarus template

* add iota style and identity content

* add gh deploy action

* fix sidebar and titles

* change build dir

* fix folder name

* add specs, fix links

* fix images

* fix base path and github link

* add cname for security

* Add `publicKeyMultibase` (#307)

* Add publicKeyMultibase support

Add and expand base-encoding tests.

* Remove publicKeyHex

* Add verification method publicKeyMultibase test

* Ignore wasm lint warning

* setup documentation file structure in docusaurus

* Example Cleanup (#292)

* Default Network should be Mainnet

* Use remote PoW by default

* Always set a primary node

* Client updates

- Add TangleResolve for generic client implementations
- Add Receipt return value with additional txn info
- Rename `Client::transaction_url` -> `Client::message_url`

* Appease clippy

* Update examples

* Add ability to configure account clients (#293)

* Add ability to configure account clients

* rename

* stricter bound

* Use dashmap

* Explicit account test mode

* Fix missed method

* Ignore lint

* faster tests

* Minutes/2021 14 07 (#316)

* 2021-07-14

* 2021-07-14

* final

* Rename

Co-authored-by: HackMD <no-reply@hackmd.io>

* add codeSnippet component

* Update actions to pin Rust nightly version (#318)

Fix attempt for inconsistent Github Actions failures.

* Wasm examples browser (#317)

* create did through browser

* add examples to create and resolve DID

* add manipulate_did and create_vc

* and merkle key and revocation

* add missing index.html

* move node examples to separate folder

* update readme file

* remove web.js and format browser examples

* include node examples in git

* update readme links of node examples

* account: Add stronghold and re-export wasm feature (#291)

Signed-off-by: PhilippGackstatter <philipp.gackstatter@iota.org>

account: Complete stronghold feature integration

account: Enable new resolver to fix wasm target

account: Use tokio 1.5 & split async feature

account: Add note on `Stronghold` availability

builder: Apply cargo fmt
Signed-off-by: PhilippGackstatter <philipp.gackstatter@iota.org>

* Fix cyclic dependency (#319)

Remove unused preserve_order serde_json feature flag.

* update file paths

* add remark-import-partial plugin

* add missing doc files

* update landing page

* Fix inconsistent stronghold storage tests (#320)

Raise test timeouts and improve handling on slow systems.

* update footer/add empty team page

* remember selected programming language

* fix rust Replit

* change height of code snippet

* add teams page

* adjust team page

* minor edits to landing page

* Added DID Intro text

* Moved meeting minutes

* Remove mdbook docs

* Renamed DocOps -> documentation

* Updated deploy workflow documentation

* Updated blogs

* signature: Impl thread-safe `Cell` (#329)

Signed-off-by: PhilippGackstatter <philipp.gackstatter@iota.org>

* update docusaurus.config.js

* Docs/docusaurus (#324)

* Docs/setup docusaurus (#298)

* setup docusarus template

* add iota style and identity content

* add gh deploy action

* fix sidebar and titles

* change build dir

* fix folder name

* add specs, fix links

* fix images

* fix base path and github link

* add cname for security

* setup documentation file structure in docusaurus

* add codeSnippet component

* update file paths

* add remark-import-partial plugin

* add missing doc files

* update landing page

* update footer/add empty team page

* remember selected programming language

* fix rust Replit

* change height of code snippet

* add teams page

* adjust team page

* minor edits to landing page

* Added DID Intro text

* Moved meeting minutes

* Remove mdbook docs

* Renamed DocOps -> documentation

* Updated deploy workflow documentation

* Updated blogs

* update docusaurus.config.js

Co-authored-by: huhn511 <sehe89@gmail.com>
Co-authored-by: JelleMillenaar <Jelle.millenaar@iota.org>

* Fix workflow

* Trigger workflow if itself changes

* Moved latest meeting notes

* Docs/docusaurus (#331)

* Docs/setup docusaurus (#298)

* setup docusarus template

* add iota style and identity content

* add gh deploy action

* fix sidebar and titles

* change build dir

* fix folder name

* add specs, fix links

* fix images

* fix base path and github link

* add cname for security

* setup documentation file structure in docusaurus

* add codeSnippet component

* update file paths

* add remark-import-partial plugin

* add missing doc files

* update landing page

* update footer/add empty team page

* remember selected programming language

* fix rust Replit

* change height of code snippet

* add teams page

* adjust team page

* minor edits to landing page

* Added DID Intro text

* Moved meeting minutes

* Remove mdbook docs

* Renamed DocOps -> documentation

* Updated deploy workflow documentation

* Updated blogs

* update docusaurus.config.js

* Fix workflow

* Trigger workflow if itself changes

* Moved latest meeting notes

Co-authored-by: huhn511 <sehe89@gmail.com>
Co-authored-by: Abdulrahim Al Methiab <abdulrahim.almethiab@iota.org>

* replace package-lock

* prevent broken links from failing the build

* fix docusaurus base URL

* Bump prismjs from 1.23.0 to 1.24.1 in /documentation (#330)

Bumps [prismjs](https://github.com/PrismJS/prism) from 1.23.0 to 1.24.1.
- [Release notes](https://github.com/PrismJS/prism/releases)
- [Changelog](https://github.com/PrismJS/prism/blob/master/CHANGELOG.md)
- [Commits](PrismJS/prism@v1.23.0...v1.24.1)

---
updated-dependencies:
- dependency-name: prismjs
  dependency-type: indirect
...

Signed-off-by: dependabot[bot] <support@github.com>

Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>

* Add sccache to pipeline (#335)

* Add sccache to pipeline

* Fix Github Actions build-and-test include path

CI checks should correctly run if the build-and-test.yml definition changes
now.

* Fix sccache installation on Linux, Windows

* Debug Windows sccache path

* Add cache steps to all build CI jobs

Fix cache restore keys.

* Fix sccache restore keys

* * Upgraded docusaurus to improve mobile nav
* Fixed docs edit url

* * Fixed broken link

* Fix import.meta error (#340)

* Fix import.meta error

Update our workaround for webpack not supporting import.meta properly,
which causes an error when trying to use the Wasm web bindings with some
frameworks, e.g. React.

* Improve workaround regex

* Fix wasm examples (#337)

* Use camel case for JSON

* Fix messageId extraction

* Use explicit receipt var in examples

* Fix web explorer url

* Update yarn.lock

* Bump tar from 5.0.5 to 5.0.7 in /bindings/wasm (#346)

Bumps [tar](https://github.com/npm/node-tar) from 5.0.5 to 5.0.7.
- [Release notes](https://github.com/npm/node-tar/releases)
- [Changelog](https://github.com/npm/node-tar/blob/main/CHANGELOG.md)
- [Commits](isaacs/node-tar@v5.0.5...v5.0.7)

---
updated-dependencies:
- dependency-name: tar
  dependency-type: indirect
...

Signed-off-by: dependabot[bot] <support@github.com>

Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>

* Fix libjose clippy lint (#348)

Remove needless borrow in libjose

* Add Wasm examples to CI (#345)

* Fix Wasm README.md example

Add Wasm examples CI job.
Update build-and-test CI to run wasm_bindgen annotated tests.

* Add txm annotations to test Wasm README.md example

Add txm to examples CI job.

* Fix Wasm node and README.md examples tests

The examples will now throw error codes on unsuccessful termination.

* Enable wasm examples CI job on PR temporarily

* Add configurable branch/ref for example CI

* Disable examples CI job on pull requests

* Rename Wasm Examples CI job

* Switch to jest for testing node bindings examples

* Add wasm browser example tests with cypress

Fix broken browser examples, doc strings.
Update example CI job with browser tests.
Temporarily enable examples CI job on PR for testing.

* Disable examples CI on PR

Update yarn.lock to include cypress

* improve node tests reliability

* improve browser test reliability

Co-authored-by: Abdulrahim Al Methiab <abdulrahim.almethiab@iota.org>

* Bump version to 0.3.5 for @iota/identity-wasm@dev (#351)

Update package-lock.json

* Improve Wasm error handling (#344)

* Add WasmError

Enables idiomatic Javascript error handling with js_sys::Error which
includes error enum variant names.

* Add WasmError test

* remove book.toml (#341)

* Fix low-level links (#353)

Some of them were pointing to the wrong file.

* Update documentation links (#354)

* Update doc links

* Updated remaining incorrect links

Co-authored-by: JelleMillenaar <Jelle.millenaar@iota.org>

* Add integration chain history/diff chain API (#347)

* Retrieve basic message history

* add Client::resolve_diffs

* Add WASM support/example

* Remove needless borrow

* cargo clean

* cargo fmt

* add did-history node example

* fix did-history node example

* add did-history browser example

* start implementing create_diff example for browser

* add create_diff examples

* fix revocation

* Address comments

Add clarifying comments to resolve history example.
Add wasm bindings equivalents for the resolve history example.
Add diff_chain example to base examples.
Add authorisation method to WasmDocument in order to use resolveDiffs.
Improve rustdoc comments.
Fix base example README.md references.

* Fix merge.

Fix clippy lint warnings.
Fix formatting.

* Remove leftover file from merge conflict.

* Fix format

* Fix wasm examples README.md

* Add Wasm binding history types

Add bridging Wasm structs for MessageHistory, DiffSet, DocumentDiff,
DiffChain, IntegrationChain.
Update client methods to return the briding structs where possible
instead of a serialized JsValue.
Improve error ergonomics in Wasm bindings by replacing
`.map_err(wasm_error)` with `.wasm_result()` and define a custom Result
type for JsValue errors.
Rename integration, diff chain `is_valid`/`check_validity` methods to
`is_valid_addition`/`check_valid_addition` to reduce ambiguity.
Add an extra check for the `message_id` in `check_valid_addition`.

* Export more functions to wasm bindings

Add publish_json, diff_address, integration_address to wasm bindings.
Update resolve_history example to include diff chain spam.
Remove message_id check from check_valid_addition added in previous
commit which was causing a test to fail.

* Export more structs to Wasm and update examples.

Export Timestamp and associated timestamp fields from IotaDocument to
Wasm bindings.
Update examples for parity between Rust, Nodejs, and browser versions.
Add revoke_vc Rust example.
Fix examples where from_keypair is used incorrectly to add new
verification methods.
Fix examples not setting the updated timestamp.
Fix printing nested JSON in examples/node/resolve_history.

* Fix README.md spelling.

* Fix broken Wasm examples

Fix merkle_key revocation example.
Fix invalid README.md references.

* Fix clippy, fmt warnings

* Refactor MessageHistory to DocumentHistory

Remove duplicate logic.
Remove Wasm bindings for DiffChain, IntegrationChain as per discussions
that those structures should be reserved for internal use and to keep
the external Wasm API cleaner.
Change `resolve_diff` to require a document previously published on the
integration change to avoid issues with validation.

* Export DocumentHistory to Wasm bindings

Fix spam messages returning the wrong message ids.
Change DocumentHistory structure due to Wasm binding limitations on
generics.
Update Wasm resolve_history examples.

* Update bindings/wasm/src/did/wasm_document.rs

Co-authored-by: Philipp <philipp.gackstatter@iota.org>

* Update bindings/wasm/examples/browser/mainpulate_did.js

Co-authored-by: Philipp <philipp.gackstatter@iota.org>

* Update identity-iota/src/chain/document_chain.rs

Co-authored-by: Philipp <philipp.gackstatter@iota.org>

* Update document_chain.rs

Add doc comment for DocumentChain.

* Update document_chain.rs

Fix formatting.

* Fix whitespace formatting to satisfy CI

* Rename address to index

Corrects integrationAddress -> integrationIndex, diffAddress ->
diffIndex.

Co-authored-by: Abdulrahim Al Methiab <abdulrahim.almethiab@iota.org>
Co-authored-by: Craig Bester <craig.bester@iota.org>
Co-authored-by: Philipp <philipp.gackstatter@iota.org>

* Bump version to 0.3.6 for @iota/identity-wasm@dev (#363)

* added cargo example build and dummy run

* added parallel execution for js and rust examples

* added actual cargo example run

* fixed cargo example run

* added output cache, changed cache key, reordering

* use jq instead of python

* use matrix build, caching for web examples

* use current branch

* Improve `Network` type to better support private tangles (#360)

* Make `Network` not `Copy`

This is in preparation for adding another
non-`Copy` variant later.

* Add `Other` variant in `Network`

* Add node.js DID creation on private tangle example

* Add `from_name` in Wasm and fix absence of `Copy`

* Remove superfluous imports

* Add browser Wasm example

* Remove old variable

* Add low-level Rust API example

* Format Wasm network source code

* Add account Rust API example

* Use same ideas for account & low-level examples

* Rename `Network::as_str` to `name`

* Impl spec compliance check for `Network` names

* Change `IotaDID::network` return type to `Result`

* Change bindings according to new return type

* Improve Wasm examples with resolution step

* Add private tangle test

* Add cypress browser test

* Use `?` instead of `unwrap` where possible

* Add explorer url to `Network::Other` variant

* Add explorer_url tests

* Merge branch 'dev' into feat/private-tangle-network

* Fix `explorer_url` conversion

* Fix `message_url` in new examples

* Fix network names in Rust private tangle examples

* Update bindings/wasm/examples/node/test.js

Co-authored-by: Craig Bester <craig.bester@iota.org>

* Update bindings/wasm/cypress/integration/browser_test.js

Co-authored-by: Craig Bester <craig.bester@iota.org>

* Update bindings/wasm/examples/node/private_tangle.js

Co-authored-by: Craig Bester <craig.bester@iota.org>

* Update bindings/wasm/examples/browser/private_tangle.js

Co-authored-by: Craig Bester <craig.bester@iota.org>

* Update examples/account/private_tangle.rs

Co-authored-by: Craig Bester <craig.bester@iota.org>

* Update examples/low-level-api/private_tangle.rs

Co-authored-by: Craig Bester <craig.bester@iota.org>

Co-authored-by: Craig Bester <craig.bester@iota.org>

* remove target cache

* added exit condition

* improved naming

* changed sccache key

* use release mode to build examples

* renamed workflow

* Add HTML remove comments remark plugin (#366)

* Remove `toUnix` and `fromUnix` methods in `WasmTimestamp` (#365)

* Remove unix methods in Timestamp due to #362

* Add lint to avoid future reintroduction of i64/u64

* Update Wasm docs

* Link the relevant issue in the lint

* Bump version to 0.3.7 for @iota/identity-wasm@dev (#368)

* Bump url-parse from 1.5.1 to 1.5.3 in /documentation (#356)

Bumps [url-parse](https://github.com/unshiftio/url-parse) from 1.5.1 to 1.5.3.
- [Release notes](https://github.com/unshiftio/url-parse/releases)
- [Commits](unshiftio/url-parse@1.5.1...1.5.3)

---
updated-dependencies:
- dependency-name: url-parse
  dependency-type: indirect
...

Signed-off-by: dependabot[bot] <support@github.com>

Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>

* Bump url-parse from 1.5.1 to 1.5.3 in /bindings/wasm (#357)

Bumps [url-parse](https://github.com/unshiftio/url-parse) from 1.5.1 to 1.5.3.
- [Release notes](https://github.com/unshiftio/url-parse/releases)
- [Commits](unshiftio/url-parse@1.5.1...1.5.3)

---
updated-dependencies:
- dependency-name: url-parse
  dependency-type: indirect
...

Signed-off-by: dependabot[bot] <support@github.com>

Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>

* Fix iota-client dependency (#371)

* Update dependency versions

Fix iota-client dependency resolution error in GitHub Actions.
Update minor dependencies.

* Fix Rust examples CI failures

Prevent private_tangle examples returning an error on publish when no
private Tangle is running locally.

* Update wasm bindings resolver to version 2

Removes mio dependency which cannot be compiled to the wasm target. It
was brought in by tokio features in dev-dependencies, hence why the new
resolver works.

* Update iota-client dependency pinned commit

Fix Wasm compilation.

* Migrate riker stronghold to actix version (#370)

Move password expiration to the stronghold thread

Asyncify the tests

Fix "unnecessary let binding"-lint

Update to latest stronghold & crypto.rs

Fix clippy "let binding returned" lint

Improve unwrap safety documentation

Improve error handling in stronghold init

Simplify stronghold init statement

Upgrade all crates to iota-crypto 0.7

Improve error handling and use `expect` everywhere

Alphabetize `Cargo.toml`

Fix "block in if condition" clippy lint

* Bump to 0.3.8 for @iota/identity-wasm@dev, add set_message_id (#373)

* Add set_message_id to WasmDocument

Allow setting the message_id on DID documents in the wasm bindings.

* Bump version to 0.3.8 for @iota/identity-wasm@dev

* Fix messageId in create_did Wasm examples

* Make sccache installation a bit faster on macOS (#374)

* Bump to 0.3.9 for @iota/identity-wasm@dev, fix messageId  (#376)

* Fix WasmDocumentDiff message_id

Fix message_id incorrectly returning the previous_message_id.

* Bump version to 0.3.9 for @iota/identity-wasm@dev

* Enable the creation of an identity from a `KeyPair` in the `Account` (#352)

* Add `key_insert` function in `Storage` trait

* account: Impl keygen from bytes for `MemStore`

* account: Remove unused imports

* account: Document key size for Ed25519

* account: Fix clippy dereference lint

* account: Remove unnecessary comment

* account: Document `secret_key` better

* account: Fix ed25519 key size doc comment

* Add optional `secret_key` to `CreateMethod`

* Use renamed crypto methods in `MemStore`

* Add creating id from secret key tests

* Update stronghold to bug-fixed version

* Add stronghold insertion test

* Return proper error on invalid key length

* Implement method_secret for `CreateMethod`

* Add key size check in `CreateIdentity`

* Don't test error message itself

* Use `MethodSecret` in `IdentityCreate`

* Test type/secret mismatch

* Move insertion logic to new method

* Refactor `NetworkName` (#375)

* Add NetworkName

Use a newtype wrapper for network names to enforce spec compliance.
Fix potential bug with ClientMap theoretically having duplicate network
clients when custom explorer URLs are set.

* Update IotaDID to validate network name

Rename `with_network` to `new_with_network`.

* Fix Wasm bindings

Add `Network::name_str` to avoid cloning the `NetworkName`.

* Remove did! macro

The did! macro was unused and just converted the errors from try_did!
into panics.
Add network validation tests for Account::create_identity.

* Address comments

Rename Network::from_name to Network::try_from_name
Rename NetworkName::try_from_name to NetworkName::try_from
Rename try_did! to try_construct_did!

* Fix compilation

* Bump tar from 5.0.7 to 5.0.11 in /bindings/wasm (#378)

Bumps [tar](https://github.com/npm/node-tar) from 5.0.7 to 5.0.11.
- [Release notes](https://github.com/npm/node-tar/releases)
- [Changelog](https://github.com/npm/node-tar/blob/main/CHANGELOG.md)
- [Commits](isaacs/node-tar@v5.0.7...v5.0.11)

---
updated-dependencies:
- dependency-name: tar
  dependency-type: indirect
...

Signed-off-by: dependabot[bot] <support@github.com>

Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>

* Extend Network doc comment for other networks (#382)

* extend doc comment

* Fix spelling

* Add build step for Wasm examples (#369)

* added build step for examples

* enable more examples

* enabled more examples, cleaned up utils

* removed platform specific examples

* fixed node tests

* copy index.html to dist

* enable all examples

* changed example server root

* fixed browser test

* fixed wasm path

* enabled all node tests

* added example build to workflow

* renamed build step

* fixed tests

* added example build to README

* fixed example path

* added sourcemap option to build step

* removed redundant try catch

* added WASM example build to build and test

* fixed Readme links

* changed test command

* added signature for linkify method

* minor rework of resolution workflow

* Use a network name that matches part of the private tangle network id (#383)

* Fix private tangle examples

* Fix Wasm private tangle examples

* * Removed comment about txm which causes a compilation error upon importing from the wiki (#384)

* Change build workflow step to avoid recompilation (#386)

* Fix Wasm private-tangle example (#389)

Fixes failing example tests when nothing (undefined) is passed to the function.

* Revert "* Removed comment about txm which causes a compilation error upon importing from the wiki (#384)" (#385)

This reverts commit 0f5be7e.

* Docs - Improve SEO (#380)

* * Browser friendly descriptive urls
* Removed duplicate onBrokenLinks declaration in config

* * Removed Docusarus assets.
* Added description, image and keywords for all docs.
* Added alt attribute to images
* Upgraded to docusarus beta 4
* Added png identity icon

* Apply suggestions from code review

Co-authored-by: charlesthompson3 <74603461+charlesthompson3@users.noreply.github.com>

Co-authored-by: charlesthompson3 <74603461+charlesthompson3@users.noreply.github.com>

* Content for create did, replit improvements (#372)

* Content for create did, replit improvements

* md

* Improved phrasing based on suggestions

* use Cargo.lock for caches, remove libjose caches (#390)

* use Cargo.lock for caches, remove libjose caches

* fix sccache env

* Update .github/workflows/build-and-test.yml

Co-authored-by: Craig Bester <craig.bester@iota.org>

* Update .github/workflows/build-and-test.yml

Co-authored-by: Craig Bester <craig.bester@iota.org>

Co-authored-by: Craig Bester <craig.bester@iota.org>

* Enable lazy tangle updates in the `Account` (#377)

* Implement pushing unpublished commits to tangle

* Improve methods added to the storage interface

* Bail early if no commits to publish

* Implement new storage methods for `Stronghold`

* Implement clippy suggestions

* Add lazy publish example

* Add lazy publish test

* Apply format

* Replace `unwrap` with `?`

* Implement a "network-resilient" test runner

* Make identity updates thread-safe

* Expand docs, fix nitpicks

* Add lock to `publish_changes`

* Return locks lazily in `get_lock`

* Remove lock when deleting from index

* Clone locks when cloning the index

* Rename document to did in all examples

* Fix spelling, docs, naming

* Improve docs, simplify code

* Add `IdentityLock` type

* Rename `publish_changes` -> `publish_updates`

* Internalize `Account` commands (#391)

* Impl basic `account.new_command` idea

* Fix apply impl

* Enable multiple updates on an updater

* Flesh out `IdentityUpdater` impl

* Fix command tests

* Rename document to did in all examples

* Update examples to use new update syntax

* Add documentation

* Remove Default impl, use proper macro path for key

* Document `IdentityUpdater`, derive basic traits

* Update recently added tests

* Roll back name change

* Reference `key` to get rid of `Clone` requirement

* Remove `CreateIdentityBuilder`

* Call `update_identity` on each update

* Move tests inside the account crate

* Document `IdentityUpdater` methods

* Rename `CommandError` -> `UpdateError`

Avoids having `Command` in the public interface.

* Update stray occurrence of `CommandError`

* Use better name for captured attribute in macro

* Move lazy test inside the crate & update syntax

* Remove `Clone` bound

* Rename `CommandError` -> `UpdateError` in account

* Make `resolve_id` method signatures consistent

* Move builder doc to the fn instead of the impl

* Replace yarn with npm (#394)

* Replace yarn with npm

* Fix npm publish included files

Exclude examples from published wasm bindings package.

* Update wasm bindings README.md

Add link to examples.
Add note on import statements.
Improve formatting.

* Add toml formatting (#393)

* Add dprint for Cargo.toml formatting

Add dprint check to format CI action.

* Format toml files

* Fix format workflow

* Use pre-packaged dprint from npm

* Disable incremental compilation in CI

Attempt to reduce cache size.

* Fix rustdoc lint warnings

Re-enable incremental cargo compilation in CI except for build-and-test-wasm.

* Remove redundant format check

* Add composite action to CI (#392)

* Add IOTA wiki CLI (#381)

* Add document merge to wasm bindings (#401)

* Update document merge functions in wasm bindings

Add WasmDocumentDiff::merge()
Update parameter of WasmDocument::merge()

* Fix formatting

* Fix IntegrationChainHistory, DiffChainHistory bindings

* Remove redundant js_class, js_name attributes

* Bump version to 0.3.10 for @iota/identity-wasm@dev (#402)

* Rename document1 to did1 in README example. (#400)

* Rename document1 to did1 in README example.

Previously, the example used `document1` to refer to the DID, whereas the "document" isn't resolved until `account.resolve_identity()` is called.

* Apply suggestions

* Fix wasm compilation (#404)

Explicitly enable tokio "rt" feature to fix compilation of bee-runtime
dependency.

* Replace `testnet` with `devnet` (#405)

* Replace testnet with devnet

* Update documentation

* Small wiki content tweaks. (#399)

- Fix "_Rust_ API Reference" title
- Some acronym expansions
- Consistently hyphenate Self-Sovereign Identity
- Link to Rust and WASM API reference (they're still stubs though)
- Some small wording tweaks

* Bump version to 0.3.11 for @iota/identity-wasm@dev (#416)

Add `proof` field getter for WasmDocumentDiff.

* Initial content for VC Wiki Overview page (#407)

* Initial content for VC Wiki Overview page

* Address Jelle's review comments (round 1).

* Update README.md (#413)

changed links for documentation to wiki.iota.org links

* Bump tmpl from 1.0.4 to 1.0.5 in /bindings/wasm (#410)

Bumps [tmpl](https://github.com/daaku/nodejs-tmpl) from 1.0.4 to 1.0.5.
- [Release notes](https://github.com/daaku/nodejs-tmpl/releases)
- [Commits](https://github.com/daaku/nodejs-tmpl/commits/v1.0.5)

---
updated-dependencies:
- dependency-name: tmpl
  dependency-type: indirect
...

Signed-off-by: dependabot[bot] <support@github.com>

Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>

* Rename SecretKey to PrivateKey throughout identity.rs code base. (#409)

* Rename SecretKey to PrivateKey throughout identity.rs codebase.

* Fix formatting issues.

* Resolve cycraig review (more secret->private renamings)

* Add stub content to IOTA DID Resolution wiki page. (#406)

* Add stub content to IOTA DID Resolution wiki page.

* Address Jelle's review comments (explorer, wording, etc.)

* Add default signing key as a generic verification method (#421)

* Rename auth to int chain everywhere

* Create verification method with attached auth

* Fix generations in tests

* Update remaining generations in tests

* Remove outdated TODO

* Impl generic verif method in low level API

* Use 'integration' instead of 'int'

* Add test that verifies number of verif. methods

* Assert the authentication relationship

* Fix Document constructor Typescript bindings (#423)

* Fix WasmDocument constructor Typescript bindings

Replace IotaDocument `from_keypair()`, `from_keypair_with_network()` with `new()`.
Update Wasm binding examples to be more consistent with Rust.

* Fix test and benchmark compilation

* Fix benchmark compilation

* Apply suggestions from code review

* Add Document::new_with_options constructor

Allow default verification method fragment to be specified.
Add doc, unit tests.

* Use NetworkName instead of &str

Remove IotaDID::from_components.
Remove specific InvalidNetworkName strings for consistency with other errors and to use with TryInto.
Allow Network::try_from_name to take an actual NetworkName as well as a
string.

Co-authored-by: Philipp <philipp.gackstatter@iota.org>

* Fix example dependencies in Readme (#430)

Account feature has to be added to the identity dependencies to use identity::account::*.

* Update Account API to return IdentityState from find_identity and create_identity (#414)

* Update Account::create_identity() to return IdentityState.

* Update Account::find_identity() to return IdentityState.

* Fix Wasm network calls, pin reqwest to 0.11.4 (#439)

* Rename JSON serialization field name to match spec. (#412)

* Rename JSON serialization field name to match spec.

* Rename notSupported -> representationNotSupported

* Reduce WASM build size (#427)

* reduce wasm build size

* Enable lto for Wasm release

Add `build-dev` task for Wasm for debugging.

Co-authored-by: Craig Bester <craig.bester@iota.org>

* Chore/combine examples (#420)

* Merged Stronghold with basic examples in account

* Updated explorer to identity resolver

* Added explorer URL after basic example

* Renamed examples

* Completed manipulate did example

* Fixed suggestions, removed replaced examples.

* Improved example readme

* Consistently use Stronghold and Resolver URL

* Fix examples

* Merged config example with private tangle

* low-level-api private-network example runs

* cargo fmt

* cargo fmt with nightly

* Impl suggestions

* Docs - Reogranize Docs, Add Examples & Cheat Sheet (#425)

* Reorganized files

* Renamed .md files to .mdx (see https://docusaurus.io/docs/next/markdown-features/react)
Added examples
Deleted unused files
Updated sidebar
Added 20px margin bottom for replit embedded object
Removed redundant units and props in styles.css

* added NLOF

* Apply suggestions from code review

Co-authored-by: charlesthompson3 <74603461+charlesthompson3@users.noreply.github.com>

* Added Wasm Cheat and Rust Cheat sheet skeleton

* Apply suggestions from code review

Co-authored-by: charlesthompson3 <74603461+charlesthompson3@users.noreply.github.com>

* fix typo

* Fixed links
ADded first draft of rust cheat sheet
Changed extension in verifiable_presentations.md to mdx

* Added example output for all functions in the WASM cheat_sheet.md

* Added example JSON output for all functions in the Rust cheat_sheet.md

* Added tutorial

* Formatted tutorial

* Addressing comments:
* Added instructions and descriptions on installing both main and dev branches.
* Removed low level API items from rust cheat sheet and added Account modules examples where possible.
* Added stronghold, private tangle and vp account module examples

* * added branch specific installation instructions
* fixed html in cheat_sheet.md

Co-authored-by: charlesthompson3 <74603461+charlesthompson3@users.noreply.github.com>

* Update CI cache action versions (#435)

* updated cache action versions

* added actions to watched paths

* updated cache version for examples workflow

* Docs - Fix build (#445)

* * Replaced imported account module stronghold example with basic example.
* Removed reference to deleted account module examples
* Added test action to catch future include issues

* testing action

* removed action as I wasn't being successful at all

* Added combined examples as suggested by @cycraig

* Added missing include statements (#446)

* Update TimeCop to avoid Into<SystemTime> (#444)

Out of an abundance of caution. Not an actual vulnerability since
`set_current` is unused and we don't use any SystemTime conversions
affected by a known vulnerability.

* Update methods to default to `PublicKeyMultibase` (#443)

* Update methods to default to PublicKeyMultibase

* Update documentation to use PublicKeyMultibase

* Separate `DID`, `DIDUrl` constructs (#428)

* Add separate DID, DIDUrl constructs

Add DID trait.
Add CoreDID, IotaDID structs.
Add DIDUrl generic struct.
Update various structs and functions to use a DID instead of a DIDUrl
where appropriate.

* Implement RelativeDIDUrl

Add extra CoreDID validation.
Add RelativeDIDUrl doctests.
Update tests, examples.

* Add DID Url unit tests.

Handle relative DID Url edge-cases.
Remove uriparse dependency.

* Fix formatting

* Fix clippy lint warnings

* Fix dereference_document

Add dereference unit tests.

* Fix formatting, clippy lint warnings

Add missing licence headers.

* Fix tests, benchmarks

* Remove unsafe cast in IotaVerificationMethod

* Add WasmDIDUrl

Update Wasm examples.

* Fix wasm formatting

* Improve RelativeDIDUrl comparisons

* Improve DIDUrl parsing

Re-export BaseDIDUrl to satisfy TryFrom<BaseDIDUrl> without adding the
`did_url` crate dependency to other projects.

* Remove resolution metadata check

Fix formatting.

* Change remove_service, remove_method parameters

Add doc comments.

* improved documentation

* fixed formatting

* Set `explorer_url` in private Tangle example (#454)

* Use explorer_url from custom network

* Use devnet explorer url

Co-authored-by: Craig Bester <craig.bester@iota.org>

* Fix explorer url formatting

Co-authored-by: Craig Bester <craig.bester@iota.org>

* Fix low-level private tangle example (#461)

* Fix low-level private tangle example

* Keep discussion on network name requirements

* Fix links in documentation (#450)

* Fix links in create.mdx

* Fix links in validate_university_degree.mdx

* Add dark image (#469)

* Clean up Documentation (#463)

* Removed meeting minutes

* Removed copy

* Fixing some links

* Removed Blog

* Add IOTA DIDComm protocols specification (#379)

* [WIP] Add DIDComm protocol specifications

* [WIP] Describe presentation messages

* [WIP] enhanced presentation protocol

* [WIP] enhanced presentation protocol

* [WIP] enhanced presentation protocol

* [WIP] enhanced presentation protocol

* [WIP] Add alternative presentation diagrams

* [WIP] further work on presentation

* [WIP] added signing protocol

* [WIP] further signing protocol

* [WIP] further signing protocol

* [WIP] fixed presentation

* [WIP] added issuance

* [WIP] further issuance

* [WIP] added credential-types, renamed problem-reports

* [WIP] minor cleanup

* [WIP] furthr work on issuance

* [WIP] further work on issuance

* [WIP] further work on issuance

* [WIP] further work on issuance

* [WIP] further work on issuance

* [WIP] further work on issuance

* [WIP] added revocation

* [WIP] added revocation diagram

* [WIP] added revocation-options, further revocation

* [WIP] further revocation-options, further revocation

* [WIP]further revocation

* [WIP]further revocation and revocation-options

* [WIP]further revocation and revocation-options

* [WIP] added termination

* [WIP] reference external flows

* [WIP] add presentation-exchange to presentation

* [WIP] further revocation

* [WIP] further revocation

* [WIP] further revocation

* added connection

* [WIP] further connection

* [WIP] further connection

* [WIP] further connection

* [WIP] further connection, added authetication

* [WIP] further authetication

* [WIP] fixed typos

* [WIP] further auth]

* [WIP] further auth

* [WIP] further auth

* [WIP] further auth

* fixed typo

* [WIP] problem reports

* problem reports

* further problem reports

* further problem reports

* problem reports, added 'post' protocol

* added post

* type negotiation, reworked revocation

* type negotiation

* cleanup

* added introduction

* editing

* editing

* editing

* Update issuance.md

fixed grammar.

* added potential future CrendentialInfo methods

* Fix Credential Kinds links

Minor formatting.

* First 3 files review, typos and extra info

* Update DIDComm spec introduction slightly

* Change DIDComm spec sidebar ordering

* Edit trust paragraph in authentication

Remove redundant authentication example.

* Update connection->feature discovery relationship

* Minor changes to presentation

* Spelling fixes

* Reorder resources section to after protocols in overview

* Reorder revocation to before revocation options

* Improve credential links in presentation

* Fix footnote numbering in signing

* Update signing authorisation consideration

* added description to sections

* fix sidebar links

* added diagram section

* Deduplicate authentication protocol links

* Deduplicate connection protocol links

* Deduplicate issuance protocol links

* Deduplicate presentation protocol links

* Deduplicate signing protocol links

* changed intro text

* further presentation

* cleaned up presentation

* further overview

* further authentication

* renamed Credential Kinds, added description for trust considerations

* further authentication

* reworked presentation

* updated changelog

* removed TODO

* fixed links

* added disclaimer and changed headline structure

* updated 'last updated'

Co-authored-by: Eike Haß <eike-hass@web.de>
Co-authored-by: Oliver Anderson <oliver.anderson@iota.org>
Co-authored-by: JelleMillenaar <Jelle.millenaar@iota.org>

* Restrict KeyCollection sizes (#411)

* add an upper limit to the amount o keys that can be generated

* comment count new behavior

* fix pre-existing test to adjust to next power of two policy

* set upper limit to 2^32

* define an upper limit of 2^12 for key collection

* add check before allocating vec

* throw error when trying to create a KeyCollection with 0 keys, improve comments

* fix comment

* run cargo fmt

* add const MAX_PROOF_NODES for limiting the amount of nodes in a Proof

* fix fmt

* Clean up previous didcomm impl (#470)

* Removed messages from the wasm bindings

* Revert "Removed messages from the wasm bindings"

This reverts commit e66cf82.

* cleaned up identity-comm/src/messages and identity-comm/src/tests (#467)

* deleted bindings/wasm/src/message (#468)

* build api-reference

Co-authored-by: Oliver Anderson <oliver.anderson@iota.org>
Co-authored-by: Eike Haß <eike-hass@web.de>

* bump wasm to v0.4.0 (#472)

* Bump crate versions to `0.4.0` (#471)

* Bump crate versions to `0.4.0`

* Bump `identity-wasm`, too!

* Bump `identity-wasm` itself, too.

Co-authored-by: l1h3r <devin.turner@iota.org>
Co-authored-by: Devin Turner <5410284+l1h3r@users.noreply.github.com>
Co-authored-by: Matt Renaud <matt@m-renaud.com>
Co-authored-by: Thoralf-M <thoralf.mue@gmail.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Co-authored-by: PhilippGackstatter <philipp.gackstatter@iota.org>
Co-authored-by: Abdulrahim Al Methiab <31316147+abdulmth@users.noreply.github.com>
Co-authored-by: huhn511 <sehe89@gmail.com>
Co-authored-by: Craig Bester <cycraig33@gmail.com>
Co-authored-by: Abdulrahim Al Methiab <abdulrahim.almethiab@iota.org>
Co-authored-by: HackMD <no-reply@hackmd.io>
Co-authored-by: Craig Bester <craig.bester@iota.org>
Co-authored-by: lucastortora <lucas.tortora@iota.org>
Co-authored-by: eGarciaR <e.garcia.ribera@gmail.com>
Co-authored-by: Thoralf-M <46689931+Thoralf-M@users.noreply.github.com>
Co-authored-by: Eike Haß <eike-hass@web.de>
Co-authored-by: Rajiv Shah <rajivshah1@icloud.com>
Co-authored-by: lucas-tortora <85233773+lucas-tortora@users.noreply.github.com>
Co-authored-by: charlesthompson3 <74603461+charlesthompson3@users.noreply.github.com>
Co-authored-by: Phyloiota <77154511+Phyloiota@users.noreply.github.com>
Co-authored-by: Christian M <7541795+chriamue@users.noreply.github.com>
Co-authored-by: Oliver Anderson <oliver.anderson@iota.org>
Co-authored-by: Dr-Electron <dr-electr0n@protonmail.com>
Co-authored-by: Henrique Nogara <nogara.henrique@gmail.com>
@JelleMillenaar JelleMillenaar added the No changelog Excludes PR from becoming part of any changelog label Dec 15, 2021
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Bug Something isn't working. No changelog Excludes PR from becoming part of any changelog Wasm Related to Wasm bindings. Becomes part of the Wasm changelog
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants