Skip to content

Commit

Permalink
Merge pull request #128 from iotaledger/dev
Browse files Browse the repository at this point in the history
Deploy documentation page
  • Loading branch information
l1h3r authored Feb 19, 2021
2 parents d8708b6 + 5fe585b commit 7f51d38
Show file tree
Hide file tree
Showing 28 changed files with 5,518 additions and 48 deletions.
6 changes: 5 additions & 1 deletion .github/workflows/deploy_docs_to_github_pages.yml
Original file line number Diff line number Diff line change
Expand Up @@ -18,9 +18,13 @@ jobs:

- run: mdbook build

- run: cargo doc --document-private-items --no-deps --release
- run: cp -r target/doc book/docs

- name: Deploy
uses: peaceiris/actions-gh-pages@v3
uses: iotaledger/actions-gh-pages@v3
with:
github_token: ${{ secrets.GITHUB_TOKEN }}
publish_branch: gh-pages
publish_dir: ./book
cname: identity.docs.iota.org
46 changes: 46 additions & 0 deletions .github/workflows/publish.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,46 @@
name: Publish

on:
workflow_dispatch:

jobs:
wasm:
runs-on: ubuntu-latest
strategy:
fail-fast: false

steps:
- uses: actions/checkout@v2

- name: Install stable toolchain
uses: actions-rs/toolchain@v1
with:
toolchain: stable
profile: minimal
override: true

- name: Install WASM toolchain
uses: actions-rs/toolchain@v1
with:
toolchain: stable
target: wasm32-unknown-unknown

- name: Set up Node.js
uses: actions/setup-node@v1
with:
node-version: 12.x
registry-url: 'https://registry.npmjs.org'

- name: Install JS dependencies
run: yarn
working-directory: bindings/wasm

- name: Build WASM bindings
run: yarn build
working-directory: bindings/wasm

- name: Publish WASM bindings to NPM
run: yarn publish --access public --loglevel silly
env:
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
working-directory: bindings/wasm
3 changes: 0 additions & 3 deletions bindings/wasm/.gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,4 @@ web
node
pkg

package-lock.json
yarn.lock

.DS_STORE
10 changes: 10 additions & 0 deletions bindings/wasm/.npmignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
/target
Cargo.lock

node_modules
wasm-web
wasm-node
pkg

package-lock.json
yarn.lock
75 changes: 38 additions & 37 deletions bindings/wasm/README.md
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
# IOTA Identity WASM

> This is the alpha version of the official WASM binding to IOTA's Identity API.
> This is the alpha version of the official WASM bindings for [IOTA Identity](https://github.com/iotaledger/identity.rs).
## [API Reference](docs/api-reference.md)

Expand All @@ -17,21 +17,23 @@ $ yarn add @iota/identity-wasm
```js
const identity = require('@iota/identity-wasm/node')

// Generate Keypair
const alice_keypair = identity.Key.generateEd25519()
console.log("alice_keypair: ", alice_keypair)
// Generate a new KeyPair
const key = new identity.KeyPair(identity.KeyType.Ed25519)

// Create the DIDs
let alice_did = new identity.DID(alice_keypair)
console.log("alice_did and IOTA address: ", alice_did.toString(), alice_did.address)
// Create a new DID Document with the KeyPair as the default authentication method
const doc = identity.Document.fromKeyPair(key)

// Create the public key
let alice_pubkey = identity.PubKey.generateEd25519(alice_did, alice_keypair.public)
console.log("alice_pubkey: ", alice_pubkey);
// Sign the DID Document with the sceret key
doc.sign(key)

// Create the DID Documents
let alice_document = new identity.Doc(alice_pubkey)
console.log("alice_document: ", alice_document)
// Publish the DID Document to the IOTA Tangle
identity.publish(doc.toJSON(), { node: "https://nodes.thetangle.org:443" })
.then((message) => {
console.log("Tangle Message Id: ", message)
console.log("Tangle Message Url", `https://explorer.iota.org/mainnet/transaction/${message}`)
}).catch((error) => {
console.error("Error: ", error)
})
```

## Web Setup
Expand All @@ -56,11 +58,11 @@ import copy from 'rollup-plugin-copy'

// Add the copy plugin to the `plugins` array of your rollup config:
copy({
targets: [{
src: 'node_modules/@iota/identity-wasm/web/identity_wasm_bg.wasm',
dest: 'public',
rename: 'identity_wasm_bg.wasm'
}]
targets: [{
src: 'node_modules/@iota/identity-wasm/web/identity_wasm_bg.wasm',
dest: 'public',
rename: 'identity_wasm_bg.wasm'
}]
})
```

Expand All @@ -81,12 +83,12 @@ const CopyWebPlugin= require('copy-webpack-plugin');
// Add the copy plugin to the `plugins` array of your webpack config:

new CopyWebPlugin({
patterns: [
{
from: 'node_modules/@iota/identity-wasm/web/identity_wasm_bg.wasm',
to: 'identity_wasm_bg.wasm'
}
]
patterns: [
{
from: 'node_modules/@iota/identity-wasm/web/identity_wasm_bg.wasm',
to: 'identity_wasm_bg.wasm'
}
]
}),
```

Expand All @@ -95,26 +97,25 @@ new CopyWebPlugin({
```js
import * as identity from "@iota/identity-wasm/web";


identity.init().then(() => {
let keyPair = identity.Key.ed25519();
console.log("keyPair", keyPair);
let did = new identity.DID(keyPair);
console.log("did", did);
const key = new identity.KeyPair(identity.KeyType.Ed25519)
const doc = identity.Document.fromKeyPair(key)
console.log("Key Pair", key)
console.log("DID Document: ", doc)
});

// or

(async () => {
await identity.init()
let keyPair = identity.Key.ed25519();
console.log("keyPair", keyPair);
let did = new identity.DID(keyPair);
console.log("did", did);
})();
await identity.init()
const key = new identity.KeyPair(identity.KeyType.Ed25519)
const doc = identity.Document.fromKeyPair(key)
console.log("Key Pair", key)
console.log("DID Document: ", doc)
})()

// Default path is "identity_wasm_bg.wasm", but you can override it like this
await identity.init("./static/identity_wasm_bg.wasm");
await identity.init("./static/identity_wasm_bg.wasm");
```

`identity.init().then(() => {` or `await identity.init()` is required to load the wasm file (from the server if not available, because of that it will only be slow for the first time)
`identity.init().then(<callback>)` or `await identity.init()` is required to load the wasm file (from the server if not available, because of that it will only be slow for the first time)
Loading

0 comments on commit 7f51d38

Please sign in to comment.