From 96b90e3a4d7ed615549af8abc52aa6be0cd1ea1f Mon Sep 17 00:00:00 2001 From: Eric Martindale Date: Mon, 4 Nov 2024 17:21:00 -0800 Subject: [PATCH] Strip various deprecated APIs --- API.md | 3403 ++++++++++++------------------------------ services/exchange.js | 12 - services/redis.js | 6 +- types/aggregator.js | 9 - types/app.js | 13 - types/circuit.js | 2 +- types/compiler.js | 12 - types/consensus.js | 9 - types/entity.js | 9 - types/keystore.js | 9 - types/mempool.js | 8 - types/node.js | 8 - types/oracle.js | 9 - types/path.js | 10 +- types/router.js | 8 - types/scribe.js | 10 - types/swap.js | 10 - types/transition.js | 8 - 18 files changed, 971 insertions(+), 2584 deletions(-) diff --git a/API.md b/API.md index 5a9a8039d..7b654655d 100644 --- a/API.md +++ b/API.md @@ -4,13 +4,6 @@
Actor

Generic Fabric Actor.

-
Aggregator
-

Aggregates a set of balances (inputs).

-
-
AppService
-

Web-friendly application framework for building single-page applications with -Fabric-based networking and storage.

-
Chain

Chain.

@@ -26,7 +19,7 @@ service to the network.

The Circuit is the mechanism through which Fabric operates, a computable directed graph describing a network of Peer components and their interactions (side effects). -See also Swarm for deeper *inspection of Machine +See also Swarm for deeper inspection of Machine mechanics.

CLI
@@ -36,15 +29,6 @@ the Fabric network using a terminal emulator.

Collection

The Collection type maintains an ordered list of State items.

-
Compiler : Actor
-

Compilers build interfaces for users of Fabric applications.

-
-
Consensus
-

Provides various network-specific rules.

-
-
Entity : Object
-

Live instance of an ARC in Fabric.

-
Environment

Interact with the user's Environment.

@@ -73,9 +57,6 @@ RFC 5869. Defaults to 32 byte output, matching Bitcoin's implementaton.

Key

Represents a cryptographic key.

-
Keystore
-

Provides an encrypted datastore for generic object storage.

-
LedgerScribe

An ordered stack of pages.

@@ -85,25 +66,11 @@ RFC 5869. Defaults to 32 byte output, matching Bitcoin's implementaton.

Machine

General-purpose state machine with Vector-based instructions.

-
Mempool
-

Stores a list of Transaction elements.

-
Message : Object

The Message type defines the Application Messaging Protocol, or AMP. Each Actor in the network receives and broadcasts messages, selectively disclosing new routes to peers which may have open circuits.

-
Node
-

Full definition of a Fabric node.

-
-
OracleStore
-

An Oracle manages one or more collections, using a mempool for -transitive state.

-
-
Path
-

A Path is a Fabric-native link to a Document -within the network.

-
Peer

An in-memory representation of a node in our network.

@@ -118,12 +85,6 @@ be moved to @fabric/http before final release!

Resource

Generic interface for collections of digital objects.

-
RouterScribe
-

Process incoming messages.

-
-
ScribeState
-

Simple tag-based recordkeeper.

-
Script
Service
@@ -156,21 +117,12 @@ committing to the outcome. This workflow keeps app design quite simple!

Store

Long-term storage.

-
Swap : Object
-

The Swap contract executes a set of transactions on two distinct -Chain components, utilizing a secret-reveal mechanism to atomically -execute either the full set or none.

-
Swarm : String

Orchestrates a network of peers.

Token

Implements a capability-based security token.

-
Transition
-

The Transition type reflects a change from one finite -State to another.

-
Tree

Class implementing a Merkle Tree.

@@ -192,14 +144,11 @@ contract's lifetime as "fulfillment conditions" for its closure.BitcoinService

Manages interaction with the Bitcoin network.

-
Exchange
-

Implements a basic Exchange.

-
Lightning

Manage a Lightning node.

Redis
-

Connect and subscribe to ZeroMQ servers.

+

Connect and subscribe to Redis servers.

ZMQ

Connect and subscribe to ZeroMQ publishers.

@@ -425,2743 +374,1505 @@ Get a number of random bytes from the runtime environment. | --- | --- | --- | --- | | [count] | Number | 32 | Number of random bytes to retrieve. | - + -## Aggregator -Aggregates a set of balances (inputs). +## Chain +Chain. **Kind**: global class +**Properties** -* [Aggregator](#Aggregator) - * [new Aggregator([settings])](#new_Aggregator_new) - * [._importBalances(list)](#Aggregator+_importBalances) ⇒ AnchorBalance - * [._computeBalances()](#Aggregator+_computeBalances) ⇒ AnchorBalance - * [.commit()](#Aggregator+commit) ⇒ AggregatorCommit - * ["commit"](#Aggregator+event_commit) +| Name | Type | Description | +| --- | --- | --- | +| name | String | Current name. | +| indices | Map | | +| storage | Storage | | - + -### new Aggregator([settings]) -Create a new Aggregator. +### new Chain(genesis) +Holds an immutable chain of events. -**Returns**: [Aggregator](#Aggregator) - Instance of the [Aggregator](#Aggregator). | Param | Type | Description | | --- | --- | --- | -| [settings] | Object | Map of configuration values. | -| [settings.inputs] | Array | Array of [AnchorBalance](AnchorBalance) instances. | +| genesis | [Vector](#Vector) | Initial state for the chain of events. | - + + +## Channel +The [Channel](#Channel) is a encrypted connection with a member of your +[Peer](#Peer) group, with some amount of $BTC bonded and paid for each +correctly-validated message. -### aggregator.\_importBalances(list) ⇒ AnchorBalance -Import a list of [AnchorBalance](AnchorBalance) instances. +Channels in Fabric are powerful tools for application development, as they +can empower users with income opportunities in exchange for delivering +service to the network. -**Kind**: instance method of [Aggregator](#Aggregator) -**Returns**: AnchorBalance - Summary of resulting balances. +**Kind**: global class -| Param | Type | Description | -| --- | --- | --- | -| list | Array | List of inputs to add. | +* [Channel](#Channel) + * [new Channel([settings])](#new_Channel_new) + * [.add(amount)](#Channel+add) + * [.fund(input)](#Channel+fund) + * [.open(channel)](#Channel+open) - + -### aggregator.\_computeBalances() ⇒ AnchorBalance -Updates the state to reflect balances from current inputs. +### new Channel([settings]) +Creates a channel between two peers. +of many transactions over time, to be settled on-chain later. -**Kind**: instance method of [Aggregator](#Aggregator) -**Returns**: AnchorBalance - Summary of balances. - -### aggregator.commit() ⇒ AggregatorCommit -Commits the balance of all input. +| Param | Type | Description | +| --- | --- | --- | +| [settings] | Object | Configuration for the channel. | -**Kind**: instance method of [Aggregator](#Aggregator) -**Returns**: AggregatorCommit - Commit instance. -**Emits**: [commit](#Aggregator+event_commit) - + -### "commit" -Commit event. +### channel.add(amount) +Add an amount to the channel's balance. -**Kind**: event emitted by [Aggregator](#Aggregator) -**Properties** +**Kind**: instance method of [Channel](#Channel) -| Name | Type | Description | +| Param | Type | Description | | --- | --- | --- | -| root | Uint8Array | Root of the [Tree](#Tree). | -| leaves | Array | Leaves of the [Tree](#Tree). | +| amount | Number | Amount value to add to current outgoing balance. | - + -## App ⇐ [Service](#Service) -Web-friendly application framework for building single-page applications with -Fabric-based networking and storage. +### channel.fund(input) +Fund the channel. -**Kind**: global class -**Extends**: [Service](#Service) -**Properties** +**Kind**: instance method of [Channel](#Channel) -| Name | Type | Description | +| Param | Type | Description | | --- | --- | --- | -| components | [Collection](#Collection) | Interface elements. | -| stash | [Store](#Store) | Routable [Datastore](Datastore). | - - -* [App](#App) ⇐ [Service](#Service) - * [new App(definition)](#new_App_new) - * [.start()](#App+start) ⇒ Promise - * [.stop()](#App+stop) ⇒ Promise - * [.define(name, structure)](#App+define) ⇒ Object - * [.defer(authority)](#App+defer) ⇒ [App](#App) - * [.attach(element)](#App+attach) ⇒ [App](#App) - * [.consume(resources)](#App+consume) ⇒ [App](#App) - * [.envelop(selector)](#App+envelop) ⇒ [App](#App) - * [.use(name, definition)](#App+use) ⇒ [App](#App) - * [.render()](#App+render) ⇒ String - * [._registerService(name, Service)](#App+_registerService) ⇒ [Service](#Service) - * [.init()](#Service+init) - * [.tick()](#Service+tick) ⇒ Number - * [.beat()](#Service+beat) ⇒ [Service](#Service) - * [.get(path)](#Service+get) ⇒ Mixed - * [.set(path)](#Service+set) ⇒ Mixed - * [.trust(source)](#Service+trust) ⇒ [Service](#Service) - * [.handler(message)](#Service+handler) ⇒ [Service](#Service) - * [.lock([duration])](#Service+lock) ⇒ Boolean - * [.when(event, method)](#Service+when) ⇒ EventEmitter - * [.route(msg)](#Service+route) ⇒ Promise - * [._GET(path)](#Service+_GET) ⇒ Promise - * [._PUT(path, value, [commit])](#Service+_PUT) ⇒ Promise - * [.connect(notify)](#Service+connect) ⇒ Promise - * [.send(channel, message)](#Service+send) ⇒ [Service](#Service) - * [._registerActor(actor)](#Service+_registerActor) ⇒ Promise - * [._send(message)](#Service+_send) +| input | Mixed | Instance of a [Transaction](Transaction). | - + -### new App(definition) -Generic bundle for building Fabric applications. +### channel.open(channel) +Opens a [Channel](#Channel) with a [Peer](#Peer). -**Returns**: [App](#App) - Returns an instance of `App`. +**Kind**: instance method of [Channel](#Channel) | Param | Type | Description | | --- | --- | --- | -| definition | Object | Application definition. See `config` for examples. | - - - -### app.start() ⇒ Promise -Start the program. +| channel | Object | Channel settings. | -**Kind**: instance method of [App](#App) -**Overrides**: [start](#Service+start) - + -### app.stop() ⇒ Promise -Stop the program. +## Circuit +The [Circuit](#Circuit) is the mechanism through which [Fabric](#Fabric) +operates, a computable directed graph describing a network of +[Peer](#Peer) components and their interactions (side effects). +See also [Swarm](#Swarm) for deeper inspection of [Machine](#Machine) +mechanics. -**Kind**: instance method of [App](#App) - +**Kind**: global class + -### app.define(name, structure) ⇒ Object -Define a Resource, or "Type", used by the application. +## CLI +Provides a Command Line Interface (CLI) for interacting with +the Fabric network using a terminal emulator. -**Kind**: instance method of [App](#App) -**Returns**: Object - [description] +**Kind**: global class -| Param | Type | Description | -| --- | --- | --- | -| name | String | Human-friendly name for the Resource. | -| structure | Object | Map of attribute names -> definitions. | +* [CLI](#CLI) + * [new CLI([settings])](#new_CLI_new) + * [.start()](#CLI+start) + * [.stop()](#CLI+stop) + * [._handleGrantCommand(params)](#CLI+_handleGrantCommand) - + -### app.defer(authority) ⇒ [App](#App) -Defer control of this application to an outside authority. +### new CLI([settings]) +Create a terminal-based interface for a [User](User). -**Kind**: instance method of [App](#App) -**Returns**: [App](#App) - The configured application as deferred to `authority`. | Param | Type | Description | | --- | --- | --- | -| authority | String | Hostname to trust. | +| [settings] | Object | Configuration values. | +| [settings.currencies] | Array | List of currencies to support. | - + -### app.attach(element) ⇒ [App](#App) -Configure the Application to use a specific element. +### clI.start() +Starts (and renders) the CLI. -**Kind**: instance method of [App](#App) -**Returns**: [App](#App) - Configured instance of the Application. +**Kind**: instance method of [CLI](#CLI) + -| Param | Type | Description | -| --- | --- | --- | -| element | DOMElement | DOM element to bind to. | +### clI.stop() +Disconnect all interfaces and exit the process. - +**Kind**: instance method of [CLI](#CLI) + -### app.consume(resources) ⇒ [App](#App) -Define the Application's resources from an existing resource map. +### clI.\_handleGrantCommand(params) +Creates a token for the target signer with a provided role and some optional data. -**Kind**: instance method of [App](#App) -**Returns**: [App](#App) - Configured instance of the Application. +**Kind**: instance method of [CLI](#CLI) | Param | Type | Description | | --- | --- | --- | -| resources | Object | Map of resource definitions by name. | +| params | Array | Parameters array. | - + -### app.envelop(selector) ⇒ [App](#App) -Use a CSS selector to find an element in the current document's tree and -bind to it as the render target. +## Collection +The [Collection](#Collection) type maintains an ordered list of [State](#State) items. -**Kind**: instance method of [App](#App) -**Returns**: [App](#App) - Instance of app with bound element. +**Kind**: global class +**Properties** -| Param | Type | Description | +| Name | Type | Description | | --- | --- | --- | -| selector | String | CSS selector. | +| @entity | Object | Fabric-bound entity object. | + + +* [Collection](#Collection) + * [new Collection([configuration])](#new_Collection_new) + * [.asMerkleTree()](#Collection+asMerkleTree) ⇒ MerkleTree + * [._setKey(name)](#Collection+_setKey) + * [.getByID(id)](#Collection+getByID) + * [.getLatest()](#Collection+getLatest) + * [.findByField(name, value)](#Collection+findByField) + * [.findByName(name)](#Collection+findByName) + * [.findBySymbol(symbol)](#Collection+findBySymbol) + * [._patchTarget(path, patches)](#Collection+_patchTarget) + * [.push(data)](#Collection+push) ⇒ Number + * [.get(path)](#Collection+get) ⇒ Mixed + * [.set(path)](#Collection+set) ⇒ Mixed + * ~~[.list()](#Collection+list) ⇒ Array~~ + * [.toTypedArray()](#Collection+toTypedArray) + * [.map()](#Collection+map) ⇒ Array + * [.create(entity)](#Collection+create) ⇒ Promise + * [.import(state, commit)](#Collection+import) - + -### app.use(name, definition) ⇒ [App](#App) -Define a named [Resource](#Resource). +### new Collection([configuration]) +Create a list of [Entity](Entity)-like objects for later retrieval. -**Kind**: instance method of [App](#App) -**Returns**: [App](#App) - Configurated instance of the [App](#App). +**Returns**: [Collection](#Collection) - Configured instance of the the [Collection](#Collection). -| Param | Type | Description | -| --- | --- | --- | -| name | String | Human-friendly name for this resource. | -| definition | Object | Map of configuration values. | +| Param | Type | Default | Description | +| --- | --- | --- | --- | +| [configuration] | Object | {} | Configuration object. | - + -### app.render() ⇒ String -Get the output of our program. +### collection.asMerkleTree() ⇒ MerkleTree +Current elements of the collection as a [MerkleTree](MerkleTree). -**Kind**: instance method of [App](#App) -**Returns**: String - Output of the program. - +**Kind**: instance method of [Collection](#Collection) + -### app.\_registerService(name, Service) ⇒ [Service](#Service) -Registers a named [Service](#Service) with the application. Services are -standardized interfaces for Fabric contracts, emitting [Message](#Message) -events with a predictable lifecycle. +### collection.\_setKey(name) +Sets the `key` property of collection settings. -**Kind**: instance method of [App](#App) -**Returns**: [Service](#Service) - The registered service instance. -**Internal**: +**Kind**: instance method of [Collection](#Collection) | Param | Type | Description | | --- | --- | --- | -| name | String | Internal name of the service. | -| Service | Class | The ES6 class definition implementing [Service](#Service). | +| name | String | Value to set the `key` setting to. | - + -### app.init() -Called by Web Components. -TODO: move to @fabric/http/types/spa +### collection.getByID(id) +Retrieve an element from the collection by ID. -**Kind**: instance method of [App](#App) -**Overrides**: [init](#Service+init) - +**Kind**: instance method of [Collection](#Collection) -### app.tick() ⇒ Number -Move forward one clock cycle. +| Param | Type | Description | +| --- | --- | --- | +| id | String | Document identifier. | -**Kind**: instance method of [App](#App) -**Overrides**: [tick](#Service+tick) - + -### app.beat() ⇒ [Service](#Service) -Compute latest state. +### collection.getLatest() +Retrieve the most recent element in the collection. -**Kind**: instance method of [App](#App) -**Overrides**: [beat](#Service+beat) -**Emits**: Message#event:beat - +**Kind**: instance method of [Collection](#Collection) + -### app.get(path) ⇒ Mixed -Retrieve a key from the [State](#State). +### collection.findByField(name, value) +Find a document by specific field. -**Kind**: instance method of [App](#App) -**Overrides**: [get](#Service+get) -**Returns**: Mixed - Returns the target value if found, otherwise null. +**Kind**: instance method of [Collection](#Collection) | Param | Type | Description | | --- | --- | --- | -| path | [Path](#Path) | Key to retrieve. | +| name | String | Name of field to search. | +| value | String | Value to match. | - + -### app.set(path) ⇒ Mixed -Set a key in the [State](#State) to a particular value. +### collection.findByName(name) +Find a document by the "name" field. -**Kind**: instance method of [App](#App) -**Overrides**: [set](#Service+set) +**Kind**: instance method of [Collection](#Collection) | Param | Type | Description | | --- | --- | --- | -| path | [Path](#Path) | Key to retrieve. | +| name | String | Name to search for. | - + -### app.trust(source) ⇒ [Service](#Service) -Explicitly trust all events from a known source. +### collection.findBySymbol(symbol) +Find a document by the "symbol" field. -**Kind**: instance method of [App](#App) -**Overrides**: [trust](#Service+trust) -**Returns**: [Service](#Service) - Instance of Service after binding events. +**Kind**: instance method of [Collection](#Collection) | Param | Type | Description | | --- | --- | --- | -| source | EventEmitter | Emitter of events. | +| symbol | String | Value to search for. | - + -### app.handler(message) ⇒ [Service](#Service) -Default route handler for an incoming message. Follows the Activity -Streams 2.0 spec: https://www.w3.org/TR/activitystreams-core/ +### collection.\_patchTarget(path, patches) +Modify a target document using an array of atomic updates. -**Kind**: instance method of [App](#App) -**Overrides**: [handler](#Service+handler) -**Returns**: [Service](#Service) - Chainable method. +**Kind**: instance method of [Collection](#Collection) | Param | Type | Description | | --- | --- | --- | -| message | Activity | Message object. | +| path | String | Path to the document to modify. | +| patches | Array | List of operations to apply. | - + -### app.lock([duration]) ⇒ Boolean -Attempt to acquire a lock for `duration` seconds. +### collection.push(data) ⇒ Number +Adds an [Entity](Entity) to the [Collection](#Collection). -**Kind**: instance method of [App](#App) -**Overrides**: [lock](#Service+lock) -**Returns**: Boolean - true if locked, false if unable to lock. +**Kind**: instance method of [Collection](#Collection) +**Returns**: Number - Length of the collection. -| Param | Type | Default | Description | -| --- | --- | --- | --- | -| [duration] | Number | 1000 | Number of milliseconds to hold lock. | +| Param | Type | Description | +| --- | --- | --- | +| data | Mixed | [Entity](Entity) to add. | - + -### app.when(event, method) ⇒ EventEmitter -Bind a method to an event, with current state as the immutable context. +### collection.get(path) ⇒ Mixed +Retrieve a key from the [State](#State). -**Kind**: instance method of [App](#App) -**Overrides**: [when](#Service+when) -**Returns**: EventEmitter - Instance of EventEmitter. +**Kind**: instance method of [Collection](#Collection) | Param | Type | Description | | --- | --- | --- | -| event | String | Name of the event upon which to execute `method` as a function. | -| method | function | Function to execute when named [Event](Event) `event` is encountered. | +| path | Path | Key to retrieve. | - + -### app.route(msg) ⇒ Promise -Resolve a [State](#State) from a particular [Message](#Message) object. +### collection.set(path) ⇒ Mixed +Set a key in the [State](#State) to a particular value. -**Kind**: instance method of [App](#App) -**Overrides**: [route](#Service+route) -**Returns**: Promise - Resolves with resulting [State](#State). +**Kind**: instance method of [Collection](#Collection) | Param | Type | Description | | --- | --- | --- | -| msg | [Message](#Message) | Explicit Fabric [Message](#Message). | - - +| path | Path | Key to retrieve. | -### app.\_GET(path) ⇒ Promise -Retrieve a value from the Service's state. + -**Kind**: instance method of [App](#App) -**Overrides**: [\_GET](#Service+_GET) -**Returns**: Promise - Resolves with the result. +### ~~collection.list() ⇒ Array~~ +***Deprecated*** -| Param | Type | Description | -| --- | --- | --- | -| path | String | Path of the value to retrieve. | +Generate a list of elements in the collection. - +**Kind**: instance method of [Collection](#Collection) + -### app.\_PUT(path, value, [commit]) ⇒ Promise -Store a value in the Service's state. +### collection.toTypedArray() +Provides the [Collection](#Collection) as an [Array](Array) of typed +elements. The type of these elments are defined by the collection's +type, supplied in the constructor. -**Kind**: instance method of [App](#App) -**Overrides**: [\_PUT](#Service+_PUT) -**Returns**: Promise - Resolves with with stored document. +**Kind**: instance method of [Collection](#Collection) + -| Param | Type | Default | Description | -| --- | --- | --- | --- | -| path | String | | Path to store the value at. | -| value | Object | | Document to store. | -| [commit] | Boolean | false | Sign the resulting state. | +### collection.map() ⇒ Array +Generate a hashtable of elements in the collection. - +**Kind**: instance method of [Collection](#Collection) + -### app.connect(notify) ⇒ Promise -Attach to network. +### collection.create(entity) ⇒ Promise +Create an instance of an [Entity](Entity). -**Kind**: instance method of [App](#App) -**Overrides**: [connect](#Service+connect) -**Returns**: Promise - Resolves to [Fabric](#Fabric). +**Kind**: instance method of [Collection](#Collection) +**Returns**: Promise - Resolves with instantiated [Entity](Entity). -| Param | Type | Default | Description | -| --- | --- | --- | --- | -| notify | Boolean | true | Commit to changes. | +| Param | Type | Description | +| --- | --- | --- | +| entity | Object | Object with properties. | - + -### app.send(channel, message) ⇒ [Service](#Service) -Send a message to a channel. +### collection.import(state, commit) +Loads [State](#State) into memory. -**Kind**: instance method of [App](#App) -**Overrides**: [send](#Service+send) -**Returns**: [Service](#Service) - Chainable method. +**Kind**: instance method of [Collection](#Collection) +**Emits**: event:message Will emit one {@link Snapshot} message. | Param | Type | Description | | --- | --- | --- | -| channel | String | Channel name to which the message will be sent. | -| message | String | Content of the message to send. | +| state | [State](#State) | State to import. | +| commit | Boolean | Whether or not to commit the result. | - + -### app.\_registerActor(actor) ⇒ Promise -Register an [Actor](#Actor) with the [Service](#Service). +## Environment +Interact with the user's Environment. -**Kind**: instance method of [App](#App) -**Overrides**: [\_registerActor](#Service+_registerActor) -**Returns**: Promise - Resolves upon successful registration. +**Kind**: global class -| Param | Type | Description | -| --- | --- | --- | -| actor | Object | Instance of the [Actor](#Actor). | +* [Environment](#Environment) + * [new Environment([settings])](#new_Environment_new) + * [.readVariable(name)](#Environment+readVariable) ⇒ String + * [.setWallet(wallet, force)](#Environment+setWallet) ⇒ [Environment](#Environment) + * [.start()](#Environment+start) ⇒ [Environment](#Environment) - + -### app.\_send(message) -Sends a message. +### new Environment([settings]) +Create an instance of [Environment](#Environment). -**Kind**: instance method of [App](#App) -**Overrides**: [\_send](#Service+_send) +**Returns**: [Environment](#Environment) - Instance of the Environment. | Param | Type | Description | | --- | --- | --- | -| message | Mixed | Message to send. | +| [settings] | Object | Settings for the Fabric environment. | - + -## Chain -Chain. +### environment.readVariable(name) ⇒ String +Read a variable from the environment. -**Kind**: global class -**Properties** +**Kind**: instance method of [Environment](#Environment) +**Returns**: String - Value of the variable (or an empty string). -| Name | Type | Description | +| Param | Type | Description | | --- | --- | --- | -| name | String | Current name. | -| indices | Map | | -| storage | Storage | | +| name | String | Variable name to read. | - + -### new Chain(genesis) -Holds an immutable chain of events. +### environment.setWallet(wallet, force) ⇒ [Environment](#Environment) +Configure the Environment to use a Fabric [Wallet](#Wallet). +**Kind**: instance method of [Environment](#Environment) +**Returns**: [Environment](#Environment) - The Fabric Environment. -| Param | Type | Description | -| --- | --- | --- | -| genesis | [Vector](#Vector) | Initial state for the chain of events. | +| Param | Type | Default | Description | +| --- | --- | --- | --- | +| wallet | [Wallet](#Wallet) | | Wallet to attach. | +| force | Boolean | false | Force existing wallets to be destroyed. | - + -## Channel -The [Channel](#Channel) is a encrypted connection with a member of your -[Peer](#Peer) group, with some amount of $BTC bonded and paid for each -correctly-validated message. +### environment.start() ⇒ [Environment](#Environment) +Start the Environment. -Channels in Fabric are powerful tools for application development, as they -can empower users with income opportunities in exchange for delivering -service to the network. +**Kind**: instance method of [Environment](#Environment) +**Returns**: [Environment](#Environment) - The Fabric Environment. + + +## Fabric +Reliable decentralized infrastructure. **Kind**: global class +**Emits**: Fabric#event:thread, Fabric#event:step Emitted on a `compute` step. -* [Channel](#Channel) - * [new Channel([settings])](#new_Channel_new) - * [.add(amount)](#Channel+add) - * [.fund(input)](#Channel+fund) - * [.open(channel)](#Channel+open) +* [Fabric](#Fabric) + * [new Fabric(config)](#new_Fabric_new) + * [.register(service)](#Fabric+register) + * [.push(value)](#Fabric+push) ⇒ [Stack](#Stack) + * [.trust(source)](#Fabric+trust) ⇒ [Fabric](#Fabric) + * [.compute()](#Fabric+compute) ⇒ [Fabric](#Fabric) - + -### new Channel([settings]) -Creates a channel between two peers. -of many transactions over time, to be settled on-chain later. +### new Fabric(config) +The [Fabric](#Fabric) type implements a peer-to-peer protocol for +establishing and settling of mutually-agreed upon proofs of +work. Contract execution takes place in the local node first, +then is optionally shared with the network. + +Utilizing | Param | Type | Description | | --- | --- | --- | -| [settings] | Object | Configuration for the channel. | +| config | [Vector](#Vector) | Initial configuration for the Fabric engine. This can be considered the "genesis" state for any contract using the system. If a chain of events is maintained over long periods of time, `state` can be considered "in contention", and it is demonstrated that the outstanding value of the contract remains to be settled. | - + -### channel.add(amount) -Add an amount to the channel's balance. +### fabric.register(service) +Register an available [Service](#Service) using an ES6 [Class](Class). -**Kind**: instance method of [Channel](#Channel) +**Kind**: instance method of [Fabric](#Fabric) | Param | Type | Description | | --- | --- | --- | -| amount | Number | Amount value to add to current outgoing balance. | +| service | Class | The ES6 [Class](Class). | - + -### channel.fund(input) -Fund the channel. +### fabric.push(value) ⇒ [Stack](#Stack) +Push an instruction onto the stack. -**Kind**: instance method of [Channel](#Channel) +**Kind**: instance method of [Fabric](#Fabric) -| Param | Type | Description | -| --- | --- | --- | -| input | Mixed | Instance of a [Transaction](Transaction). | +| Param | Type | +| --- | --- | +| value | Instruction | - + -### channel.open(channel) -Opens a [Channel](#Channel) with a [Peer](#Peer). +### fabric.trust(source) ⇒ [Fabric](#Fabric) +Blindly consume messages from a [Source](Source), relying on `this.chain` to +verify results. -**Kind**: instance method of [Channel](#Channel) +**Kind**: instance method of [Fabric](#Fabric) +**Returns**: [Fabric](#Fabric) - Returns itself. | Param | Type | Description | | --- | --- | --- | -| channel | Object | Channel settings. | +| source | EventEmitter | Any object which implements the `EventEmitter` pattern. | - + -## Circuit -The [Circuit](#Circuit) is the mechanism through which [Fabric](#Fabric) -operates, a computable directed graph describing a network of -[Peer](#Peer) components and their interactions (side effects). -See also [Swarm](#Swarm) for deeper *inspection of [Machine](#Machine) -mechanics. +### fabric.compute() ⇒ [Fabric](#Fabric) +Process the current stack. -**Kind**: global class - +**Kind**: instance method of [Fabric](#Fabric) +**Returns**: [Fabric](#Fabric) - Resulting instance of the stack. + -## CLI -Provides a Command Line Interface (CLI) for interacting with -the Fabric network using a terminal emulator. +## Federation +Create and manage sets of signers with the Federation class. **Kind**: global class -* [CLI](#CLI) - * [new CLI([settings])](#new_CLI_new) - * [.start()](#CLI+start) - * [.stop()](#CLI+stop) - * [._handleGrantCommand(params)](#CLI+_handleGrantCommand) +* [Federation](#Federation) + * [new Federation([settings])](#new_Federation_new) + * [.start()](#Federation+start) ⇒ [Federation](#Federation) - + -### new CLI([settings]) -Create a terminal-based interface for a [User](User). +### new Federation([settings]) +Create an instance of a federation. +**Returns**: [Federation](#Federation) - Instance of the federation. | Param | Type | Description | | --- | --- | --- | -| [settings] | Object | Configuration values. | -| [settings.currencies] | Array | List of currencies to support. | - - +| [settings] | Object | Settings. | -### clI.start() -Starts (and renders) the CLI. + -**Kind**: instance method of [CLI](#CLI) - +### federation.start() ⇒ [Federation](#Federation) +Start tracking state (i.e., ready to receive events). -### clI.stop() -Disconnect all interfaces and exit the process. - -**Kind**: instance method of [CLI](#CLI) - +**Kind**: instance method of [Federation](#Federation) +**Returns**: [Federation](#Federation) - Instance of the Federation. + -### clI.\_handleGrantCommand(params) -Creates a token for the target signer with a provided role and some optional data. +## Filesystem +Interact with a local filesystem. -**Kind**: instance method of [CLI](#CLI) +**Kind**: global class -| Param | Type | Description | -| --- | --- | --- | -| params | Array | Parameters array. | +* [Filesystem](#Filesystem) + * [new Filesystem([settings])](#new_Filesystem_new) + * [.ls()](#Filesystem+ls) ⇒ Array + * [.readFile(name)](#Filesystem+readFile) ⇒ Buffer + * [.writeFile(name, content)](#Filesystem+writeFile) ⇒ Boolean + * [._loadFromDisk()](#Filesystem+_loadFromDisk) ⇒ Promise + * [.sync()](#Filesystem+sync) ⇒ [Filesystem](#Filesystem) - + -## Collection -The [Collection](#Collection) type maintains an ordered list of [State](#State) items. +### new Filesystem([settings]) +Synchronize an [Actor](#Actor) with a local filesystem. -**Kind**: global class -**Properties** +**Returns**: [Filesystem](#Filesystem) - Instance of the Fabric filesystem. -| Name | Type | Description | +| Param | Type | Description | | --- | --- | --- | -| @entity | Object | Fabric-bound entity object. | - - -* [Collection](#Collection) - * [new Collection([configuration])](#new_Collection_new) - * [.asMerkleTree()](#Collection+asMerkleTree) ⇒ MerkleTree - * [._setKey(name)](#Collection+_setKey) - * [.getByID(id)](#Collection+getByID) - * [.getLatest()](#Collection+getLatest) - * [.findByField(name, value)](#Collection+findByField) - * [.findByName(name)](#Collection+findByName) - * [.findBySymbol(symbol)](#Collection+findBySymbol) - * [._patchTarget(path, patches)](#Collection+_patchTarget) - * [.push(data)](#Collection+push) ⇒ Number - * [.get(path)](#Collection+get) ⇒ Mixed - * [.set(path)](#Collection+set) ⇒ Mixed - * ~~[.list()](#Collection+list) ⇒ Array~~ - * [.toTypedArray()](#Collection+toTypedArray) - * [.map()](#Collection+map) ⇒ Array - * [.create(entity)](#Collection+create) ⇒ Promise - * [.import(state, commit)](#Collection+import) +| [settings] | Object | Configuration for the Fabric filesystem. | +| [settings.path] | Object | Path of the local filesystem. | - + -### new Collection([configuration]) -Create a list of [Entity](#Entity)-like objects for later retrieval. +### filesystem.ls() ⇒ Array +Get the list of files. -**Returns**: [Collection](#Collection) - Configured instance of the the [Collection](#Collection). +**Kind**: instance method of [Filesystem](#Filesystem) +**Returns**: Array - List of files. + -| Param | Type | Default | Description | -| --- | --- | --- | --- | -| [configuration] | Object | {} | Configuration object. | +### filesystem.readFile(name) ⇒ Buffer +Read a file by name. - +**Kind**: instance method of [Filesystem](#Filesystem) +**Returns**: Buffer - Contents of the file. -### collection.asMerkleTree() ⇒ MerkleTree -Current elements of the collection as a [MerkleTree](MerkleTree). +| Param | Type | Description | +| --- | --- | --- | +| name | String | Name of the file to read. | -**Kind**: instance method of [Collection](#Collection) - + -### collection.\_setKey(name) -Sets the `key` property of collection settings. +### filesystem.writeFile(name, content) ⇒ Boolean +Write a file by name. -**Kind**: instance method of [Collection](#Collection) +**Kind**: instance method of [Filesystem](#Filesystem) +**Returns**: Boolean - `true` if the write succeeded, `false` if it did not. | Param | Type | Description | | --- | --- | --- | -| name | String | Value to set the `key` setting to. | - - +| name | String | Name of the file to write. | +| content | Buffer | Content of the file. | -### collection.getByID(id) -Retrieve an element from the collection by ID. + -**Kind**: instance method of [Collection](#Collection) +### filesystem.\_loadFromDisk() ⇒ Promise +Load Filesystem state from disk. -| Param | Type | Description | -| --- | --- | --- | -| id | String | Document identifier. | +**Kind**: instance method of [Filesystem](#Filesystem) +**Returns**: Promise - Resolves with Filesystem instance. + - +### filesystem.sync() ⇒ [Filesystem](#Filesystem) +Syncronize state from the local filesystem. -### collection.getLatest() -Retrieve the most recent element in the collection. +**Kind**: instance method of [Filesystem](#Filesystem) +**Returns**: [Filesystem](#Filesystem) - Instance of the Fabric filesystem. + -**Kind**: instance method of [Collection](#Collection) - +## Hash256 +Simple interaction with 256-bit spaces. -### collection.findByField(name, value) -Find a document by specific field. +**Kind**: global class -**Kind**: instance method of [Collection](#Collection) +* [Hash256](#Hash256) + * [new Hash256(settings)](#new_Hash256_new) + * [.digest(input)](#Hash256.digest) ⇒ String + * [.reverse()](#Hash256.reverse) -| Param | Type | Description | -| --- | --- | --- | -| name | String | Name of field to search. | -| value | String | Value to match. | + - +### new Hash256(settings) +Create an instance of a `Hash256` object by calling `new Hash256()`, +where `settings` can be provided to supply a particular input object. -### collection.findByName(name) -Find a document by the "name" field. +If the `settings` is not a string, `input` must be provided. -**Kind**: instance method of [Collection](#Collection) | Param | Type | Description | | --- | --- | --- | -| name | String | Name to search for. | +| settings | Object | | +| settings.input | String | Input string to map as 256-bit hash. | - + -### collection.findBySymbol(symbol) -Find a document by the "symbol" field. +### Hash256.digest(input) ⇒ String +Produce a SHA256 digest of some input data. -**Kind**: instance method of [Collection](#Collection) +**Kind**: static method of [Hash256](#Hash256) +**Returns**: String - `SHA256(input)` as a hexadecimal string. | Param | Type | Description | | --- | --- | --- | -| symbol | String | Value to search for. | - - +| input | String \| Buffer | Content to digest. | -### collection.\_patchTarget(path, patches) -Modify a target document using an array of atomic updates. + -**Kind**: instance method of [Collection](#Collection) +### Hash256.reverse() +Reverses the bytes of the digest. -| Param | Type | Description | -| --- | --- | --- | -| path | String | Path to the document to modify. | -| patches | Array | List of operations to apply. | +**Kind**: static method of [Hash256](#Hash256) + - +## HKDF +Provides an HMAC-based Extract-and-Expand Key Derivation Function (HKDF), compatible with +RFC 5869. Defaults to 32 byte output, matching Bitcoin's implementaton. -### collection.push(data) ⇒ Number -Adds an [Entity](#Entity) to the [Collection](#Collection). +**Kind**: global class -**Kind**: instance method of [Collection](#Collection) -**Returns**: Number - Length of the collection. +* [HKDF](#HKDF) + * [new HKDF(settings)](#new_HKDF_new) + * [.derive([info], [size])](#HKDF+derive) -| Param | Type | Description | -| --- | --- | --- | -| data | Mixed | [Entity](#Entity) to add. | + - +### new HKDF(settings) +Create an HKDF instance. -### collection.get(path) ⇒ Mixed -Retrieve a key from the [State](#State). -**Kind**: instance method of [Collection](#Collection) +| Param | Type | Default | Description | +| --- | --- | --- | --- | +| settings | Object | | List of settings. | +| settings.initial | String | | Input keying material. | +| [settings.algorithm] | String | sha256 | Name of the hashing algorithm to use. | +| [settings.salt] | String | | Salt value (a non-secret random value). | -| Param | Type | Description | -| --- | --- | --- | -| path | [Path](#Path) | Key to retrieve. | + - +### hkdF.derive([info], [size]) +Derive a new output. -### collection.set(path) ⇒ Mixed -Set a key in the [State](#State) to a particular value. +**Kind**: instance method of [HKDF](#HKDF) -**Kind**: instance method of [Collection](#Collection) +| Param | Type | Default | Description | +| --- | --- | --- | --- | +| [info] | Buffer | | Context and application specific information. | +| [size] | Number | 32 | Length of output. | -| Param | Type | Description | -| --- | --- | --- | -| path | [Path](#Path) | Key to retrieve. | + - +## Identity +Manage a network identity. -### ~~collection.list() ⇒ Array~~ -***Deprecated*** +**Kind**: global class -Generate a list of elements in the collection. +* [Identity](#Identity) + * [new Identity([settings])](#new_Identity_new) + * [.sign(data)](#Identity+sign) ⇒ Signature + * [.toString()](#Identity+toString) ⇒ String -**Kind**: instance method of [Collection](#Collection) - + -### collection.toTypedArray() -Provides the [Collection](#Collection) as an [Array](Array) of typed -elements. The type of these elments are defined by the collection's -type, supplied in the constructor. +### new Identity([settings]) +Create an instance of an Identity. -**Kind**: instance method of [Collection](#Collection) - +**Returns**: [Identity](#Identity) - Instance of the identity. -### collection.map() ⇒ Array -Generate a hashtable of elements in the collection. +| Param | Type | Default | Description | +| --- | --- | --- | --- | +| [settings] | Object | | Settings for the Identity. | +| [settings.seed] | String | | BIP 39 seed phrase. | +| [settings.xprv] | String | | Serialized BIP 32 master private key. | +| [settings.xpub] | String | | Serialized BIP 32 master public key. | +| [settings.account] | Number | 0 | BIP 44 account index. | +| [settings.index] | Number | 0 | BIP 44 key index. | -**Kind**: instance method of [Collection](#Collection) - + -### collection.create(entity) ⇒ Promise -Create an instance of an [Entity](#Entity). +### identity.sign(data) ⇒ Signature +Sign a buffer of data using BIP 340: https://github.com/bitcoin/bips/blob/master/bip-0340.mediawiki -**Kind**: instance method of [Collection](#Collection) -**Returns**: Promise - Resolves with instantiated [Entity](#Entity). +**Kind**: instance method of [Identity](#Identity) +**Returns**: Signature - Resulting signature (64 bytes). | Param | Type | Description | | --- | --- | --- | -| entity | Object | Object with properties. | +| data | Buffer | Buffer of data to sign. | - - -### collection.import(state, commit) -Loads [State](#State) into memory. - -**Kind**: instance method of [Collection](#Collection) -**Emits**: event:message Will emit one {@link Snapshot} message. + -| Param | Type | Description | -| --- | --- | --- | -| state | [State](#State) | State to import. | -| commit | Boolean | Whether or not to commit the result. | +### identity.toString() ⇒ String +Retrieve the bech32m-encoded identity. - +**Kind**: instance method of [Identity](#Identity) +**Returns**: String - Public identity. + -## Compiler : [Actor](#Actor) -Compilers build interfaces for users of Fabric applications. +## Interface ⇐ EventEmitter +Interfaces compile abstract contract code into [Chain](#Chain)-executable transactions, or "chaincode". For example, the "Bitcoin" interface might compile a Swap contract into Script, preparing a valid Bitcoin transaction for broadcast which executes the swap contract. **Kind**: global class +**Extends**: EventEmitter **Properties** | Name | Type | Description | | --- | --- | --- | -| ast | AST | Compiler's current AST. | -| entity | [Entity](#Entity) | Compiler's current [Entity](#Entity). | +| status | String | Human-friendly value representing the Interface's current [State](#State). | -* [Compiler](#Compiler) : [Actor](#Actor) - * [new Compiler(settings)](#new_Compiler_new) - * _instance_ - * [._getJavaScriptAST(input)](#Compiler+_getJavaScriptAST) ⇒ AST - * _static_ - * [._fromJavaScript(body)](#Compiler._fromJavaScript) ⇒ +* [Interface](#Interface) ⇐ EventEmitter + * [new Interface(settings)](#new_Interface_new) + * [.log(...inputs)](#Interface+log) + * [.now()](#Interface+now) ⇒ Number + * [.start()](#Interface+start) + * [.stop()](#Interface+stop) + * [.cycle(val)](#Interface+cycle) - + -### new Compiler(settings) -Create a new Compiler. +### new Interface(settings) +Define an [Interface](#Interface) by creating an instance of this class. -**Returns**: [Compiler](#Compiler) - Instance of the compiler. +**Returns**: [Interface](#Interface) - Instance of the [Interface](#Interface). -| Param | Type | Default | Description | -| --- | --- | --- | --- | -| settings | Object | {} | Configuration. | -| settings.body | Buffer | | Body of the input program to compile. | +| Param | Type | Description | +| --- | --- | --- | +| settings | Object | Configuration values. | - + -### compiler.\_getJavaScriptAST(input) ⇒ AST -Parse a [Buffer](Buffer) of JavaScript into an Abstract Syntax Tree ([AST](AST)). +### interface.log(...inputs) +Log some output to the console. -**Kind**: instance method of [Compiler](#Compiler) +**Kind**: instance method of [Interface](#Interface) | Param | Type | Description | | --- | --- | --- | -| input | Buffer | Input JavaScript to parse. | +| ...inputs | any | Components of the message to long. Can be a single {@link} String, many [String](String) objects, or anything else. | - + -### Compiler.\_fromJavaScript(body) ⇒ -Creates a new Compiler instance from a JavaScript contract. +### interface.now() ⇒ Number +Returns current timestamp. -**Kind**: static method of [Compiler](#Compiler) -**Returns**: Compiler +**Kind**: instance method of [Interface](#Interface) + -| Param | Type | Description | -| --- | --- | --- | -| body | Buffer | Content of the JavaScript to evaluate. | +### interface.start() +Start the [Interface](#Interface). - +**Kind**: instance method of [Interface](#Interface) + -## Consensus -Provides various network-specific rules. +### interface.stop() +Stop the Interface. -**Kind**: global class - +**Kind**: instance method of [Interface](#Interface) + -### new Consensus([settings]) -Create an instance of a [Consensus](#Consensus) verifier. +### interface.cycle(val) +Ticks the clock with a named [Cycle](Cycle). +**Kind**: instance method of [Interface](#Interface) | Param | Type | Description | | --- | --- | --- | -| [settings] | Object | Configuration for the network. | -| [settings.network] | String | Name of the network. | -| [settings.provider] | String | Name of the source provider. | +| val | String | Name of cycle to scribe. | - + -## Entity : Object -Live instance of an ARC in Fabric. +## Key +Represents a cryptographic key. **Kind**: global class + -* [Entity](#Entity) : Object - * [new Entity([data])](#new_Entity_new) - * [.toJSON()](#Entity+toJSON) ⇒ String - * [.toRaw()](#Entity+toRaw) ⇒ Buffer - * [._downsample([input])](#Entity+_downsample) - - - -### new Entity([data]) -Generic template for virtual objects. +### new Key([settings]) +Create an instance of a Fabric Key, either restoring from some known +values or from prior knowledge. For instance, you can call `new Key()` +to create a fresh keypair, or `new Key({ public: 'deadbeef...' })` to +create it from a known public key. -**Returns**: [Entity](#Entity) - Instance of the [Entity](#Entity). | Param | Type | Default | Description | | --- | --- | --- | --- | -| [data] | Object | {} | Pass an object to use. | +| [settings] | Object | | Initialization for the key. | +| [settings.network] | String | | Network string. | +| [settings.seed] | String | | Mnemonic seed for initializing the key. | +| [settings.public] | String | | Public key in hex. | +| [settings.private] | String | | Private key in hex. | +| [settings.purpose] | String | 44 | Constrains derivations to this space. | - + + +## Ledger ⇐ [Scribe](#Scribe) +An ordered stack of pages. + +**Kind**: global class +**Extends**: [Scribe](#Scribe) +**Properties** -### entity.toJSON() ⇒ String -Produces a string of JSON, representing the entity. +| Name | Type | Description | +| --- | --- | --- | +| memory | Buffer | The ledger's memory (4096 bytes). | +| stack | [Stack](#Stack) | The ledger's stack. | +| tip | Mixed | The most recent page in the ledger. | -**Kind**: instance method of [Entity](#Entity) -**Returns**: String - JSON-encoded object. - -### entity.toRaw() ⇒ Buffer -As a [Buffer](Buffer). +* [Ledger](#Ledger) ⇐ [Scribe](#Scribe) + * [.append(item)](#Ledger+append) ⇒ Promise + * [.now()](#Scribe+now) ⇒ Number + * [.trust(source)](#Scribe+trust) ⇒ [Scribe](#Scribe) + * [.inherits(scribe)](#Scribe+inherits) ⇒ [Scribe](#Scribe) -**Kind**: instance method of [Entity](#Entity) -**Returns**: Buffer - Slice of memory. - + -### entity.\_downsample([input]) -Return a [Fabric](#Fabric)-labeled [Object](Object) for this [Entity](#Entity). +### ledger.append(item) ⇒ Promise +Attempts to append a [Page](Page) to the ledger. -**Kind**: instance method of [Entity](#Entity) +**Kind**: instance method of [Ledger](#Ledger) +**Returns**: Promise - Resolves after the change has been committed. | Param | Type | Description | | --- | --- | --- | -| [input] | Mixed | Input to downsample. If not provided, current Entity will be used. | - - - -## Environment -Interact with the user's Environment. +| item | Mixed | Item to store. | -**Kind**: global class + -* [Environment](#Environment) - * [new Environment([settings])](#new_Environment_new) - * [.readVariable(name)](#Environment+readVariable) ⇒ String - * [.setWallet(wallet, force)](#Environment+setWallet) ⇒ [Environment](#Environment) - * [.start()](#Environment+start) ⇒ [Environment](#Environment) +### ledger.now() ⇒ Number +Retrives the current timestamp, in milliseconds. - +**Kind**: instance method of [Ledger](#Ledger) +**Overrides**: [now](#Scribe+now) +**Returns**: Number - [Number](Number) representation of the millisecond [Integer](Integer) value. + -### new Environment([settings]) -Create an instance of [Environment](#Environment). +### ledger.trust(source) ⇒ [Scribe](#Scribe) +Blindly bind event handlers to the [Source](Source). -**Returns**: [Environment](#Environment) - Instance of the Environment. +**Kind**: instance method of [Ledger](#Ledger) +**Overrides**: [trust](#Scribe+trust) +**Returns**: [Scribe](#Scribe) - Instance of the [Scribe](#Scribe). | Param | Type | Description | | --- | --- | --- | -| [settings] | Object | Settings for the Fabric environment. | +| source | Source | Event stream. | - + -### environment.readVariable(name) ⇒ String -Read a variable from the environment. +### ledger.inherits(scribe) ⇒ [Scribe](#Scribe) +Use an existing Scribe instance as a parent. -**Kind**: instance method of [Environment](#Environment) -**Returns**: String - Value of the variable (or an empty string). +**Kind**: instance method of [Ledger](#Ledger) +**Overrides**: [inherits](#Scribe+inherits) +**Returns**: [Scribe](#Scribe) - The configured instance of the Scribe. | Param | Type | Description | | --- | --- | --- | -| name | String | Variable name to read. | +| scribe | [Scribe](#Scribe) | Instance of Scribe to use as parent. | - + -### environment.setWallet(wallet, force) ⇒ [Environment](#Environment) -Configure the Environment to use a Fabric [Wallet](#Wallet). +## Logger ⇐ [Actor](#Actor) +A basic logger that writes logs to the local file system -**Kind**: instance method of [Environment](#Environment) -**Returns**: [Environment](#Environment) - The Fabric Environment. +**Kind**: global class +**Extends**: [Actor](#Actor) -| Param | Type | Default | Description | -| --- | --- | --- | --- | -| wallet | [Wallet](#Wallet) | | Wallet to attach. | -| force | Boolean | false | Force existing wallets to be destroyed. | +* [Logger](#Logger) ⇐ [Actor](#Actor) + * [.path](#Logger+path) ⇒ String + * [.log(msg)](#Logger+log) ⇒ Boolean + * [.start()](#Logger+start) ⇒ Promise + * [.stop()](#Logger+stop) ⇒ Promise + * [.adopt(changes)](#Actor+adopt) ⇒ [Actor](#Actor) + * [.commit()](#Actor+commit) ⇒ String + * [.export()](#Actor+export) ⇒ Object + * [.get(path)](#Actor+get) ⇒ Object + * [.set(path, value)](#Actor+set) ⇒ Object + * [.toBuffer()](#Actor+toBuffer) ⇒ Buffer + * [.toGenericMessage()](#Actor+toGenericMessage) ⇒ Object + * [.toObject()](#Actor+toObject) ⇒ Object + * [.pause()](#Actor+pause) ⇒ [Actor](#Actor) + * [.serialize()](#Actor+serialize) ⇒ String + * [.sign()](#Actor+sign) ⇒ [Actor](#Actor) + * [.unpause()](#Actor+unpause) ⇒ [Actor](#Actor) + * [.value([format])](#Actor+value) ⇒ Object + * [._readObject(input)](#Actor+_readObject) ⇒ Object - + -### environment.start() ⇒ [Environment](#Environment) -Start the Environment. +### logger.path ⇒ String +Returns the path to the log file -**Kind**: instance method of [Environment](#Environment) -**Returns**: [Environment](#Environment) - The Fabric Environment. - +**Kind**: instance property of [Logger](#Logger) + -## Fabric -Reliable decentralized infrastructure. +### logger.log(msg) ⇒ Boolean +Writes the specified log to the log file -**Kind**: global class -**Emits**: Fabric#event:thread, Fabric#event:step Emitted on a `compute` step. +**Kind**: instance method of [Logger](#Logger) +**Returns**: Boolean - true, if msg was successfully written; false otherwise -* [Fabric](#Fabric) - * [new Fabric(config)](#new_Fabric_new) - * [.register(service)](#Fabric+register) - * [.push(value)](#Fabric+push) ⇒ [Stack](#Stack) - * [.trust(source)](#Fabric+trust) ⇒ [Fabric](#Fabric) - * [.compute()](#Fabric+compute) ⇒ [Fabric](#Fabric) +| Param | Type | Description | +| --- | --- | --- | +| msg | String \| Object | The message to log | - + -### new Fabric(config) -The [Fabric](#Fabric) type implements a peer-to-peer protocol for -establishing and settling of mutually-agreed upon proofs of -work. Contract execution takes place in the local node first, -then is optionally shared with the network. +### logger.start() ⇒ Promise +Starts the logger -Utilizing +This method creates the required directories for writing the log file. +**Kind**: instance method of [Logger](#Logger) + -| Param | Type | Description | -| --- | --- | --- | -| config | [Vector](#Vector) | Initial configuration for the Fabric engine. This can be considered the "genesis" state for any contract using the system. If a chain of events is maintained over long periods of time, `state` can be considered "in contention", and it is demonstrated that the outstanding value of the contract remains to be settled. | +### logger.stop() ⇒ Promise +Stops the logger - +This method closes the log file and returns after it has been closed. Any +errors on close would cause the return promise to be rejected. -### fabric.register(service) -Register an available [Service](#Service) using an ES6 [Class](Class). +**Kind**: instance method of [Logger](#Logger) + -**Kind**: instance method of [Fabric](#Fabric) +### logger.adopt(changes) ⇒ [Actor](#Actor) +Explicitly adopt a set of [JSONPatch](JSONPatch)-encoded changes. + +**Kind**: instance method of [Logger](#Logger) +**Overrides**: [adopt](#Actor+adopt) +**Returns**: [Actor](#Actor) - Instance of the Actor. | Param | Type | Description | | --- | --- | --- | -| service | Class | The ES6 [Class](Class). | - - +| changes | Array | List of [JSONPatch](JSONPatch) operations to apply. | -### fabric.push(value) ⇒ [Stack](#Stack) -Push an instruction onto the stack. + -**Kind**: instance method of [Fabric](#Fabric) +### logger.commit() ⇒ String +Resolve the current state to a commitment. -| Param | Type | -| --- | --- | -| value | Instruction | +**Kind**: instance method of [Logger](#Logger) +**Overrides**: [commit](#Actor+commit) +**Returns**: String - 32-byte ID + - - -### fabric.trust(source) ⇒ [Fabric](#Fabric) -Blindly consume messages from a [Source](Source), relying on `this.chain` to -verify results. - -**Kind**: instance method of [Fabric](#Fabric) -**Returns**: [Fabric](#Fabric) - Returns itself. - -| Param | Type | Description | -| --- | --- | --- | -| source | EventEmitter | Any object which implements the `EventEmitter` pattern. | - - - -### fabric.compute() ⇒ [Fabric](#Fabric) -Process the current stack. - -**Kind**: instance method of [Fabric](#Fabric) -**Returns**: [Fabric](#Fabric) - Resulting instance of the stack. - - -## Federation -Create and manage sets of signers with the Federation class. - -**Kind**: global class - -* [Federation](#Federation) - * [new Federation([settings])](#new_Federation_new) - * [.start()](#Federation+start) ⇒ [Federation](#Federation) +### logger.export() ⇒ Object +Export the Actor's state to a standard [Object](Object). - +**Kind**: instance method of [Logger](#Logger) +**Overrides**: [export](#Actor+export) +**Returns**: Object - Standard object. + -### new Federation([settings]) -Create an instance of a federation. +### logger.get(path) ⇒ Object +Retrieve a value from the Actor's state by [JSONPointer](JSONPointer) path. -**Returns**: [Federation](#Federation) - Instance of the federation. +**Kind**: instance method of [Logger](#Logger) +**Overrides**: [get](#Actor+get) +**Returns**: Object - Value of the path in the Actor's state. | Param | Type | Description | | --- | --- | --- | -| [settings] | Object | Settings. | - - - -### federation.start() ⇒ [Federation](#Federation) -Start tracking state (i.e., ready to receive events). - -**Kind**: instance method of [Federation](#Federation) -**Returns**: [Federation](#Federation) - Instance of the Federation. - - -## Filesystem -Interact with a local filesystem. - -**Kind**: global class - -* [Filesystem](#Filesystem) - * [new Filesystem([settings])](#new_Filesystem_new) - * [.ls()](#Filesystem+ls) ⇒ Array - * [.readFile(name)](#Filesystem+readFile) ⇒ Buffer - * [.writeFile(name, content)](#Filesystem+writeFile) ⇒ Boolean - * [._loadFromDisk()](#Filesystem+_loadFromDisk) ⇒ Promise - * [.sync()](#Filesystem+sync) ⇒ [Filesystem](#Filesystem) +| path | String | Path to retrieve using [JSONPointer](JSONPointer). | - + -### new Filesystem([settings]) -Synchronize an [Actor](#Actor) with a local filesystem. +### logger.set(path, value) ⇒ Object +Set a value in the Actor's state by [JSONPointer](JSONPointer) path. -**Returns**: [Filesystem](#Filesystem) - Instance of the Fabric filesystem. +**Kind**: instance method of [Logger](#Logger) +**Overrides**: [set](#Actor+set) +**Returns**: Object - Value of the path in the Actor's state. | Param | Type | Description | | --- | --- | --- | -| [settings] | Object | Configuration for the Fabric filesystem. | -| [settings.path] | Object | Path of the local filesystem. | - - - -### filesystem.ls() ⇒ Array -Get the list of files. - -**Kind**: instance method of [Filesystem](#Filesystem) -**Returns**: Array - List of files. - +| path | String | Path to set using [JSONPointer](JSONPointer). | +| value | Object | Value to set. | -### filesystem.readFile(name) ⇒ Buffer -Read a file by name. + -**Kind**: instance method of [Filesystem](#Filesystem) -**Returns**: Buffer - Contents of the file. +### logger.toBuffer() ⇒ Buffer +Casts the Actor to a normalized Buffer. -| Param | Type | Description | -| --- | --- | --- | -| name | String | Name of the file to read. | +**Kind**: instance method of [Logger](#Logger) +**Overrides**: [toBuffer](#Actor+toBuffer) + - +### logger.toGenericMessage() ⇒ Object +Casts the Actor to a generic message, used to uniquely identify the Actor's state. +Fields: +- `preimage`: JSON.stringify(state) +- `hash`: SHA256(preimage) +- `type`: 'FabricActorState' +- `version`: 1 (for now) +- `object`: state +- `parent`: null (for now) -### filesystem.writeFile(name, content) ⇒ Boolean -Write a file by name. +**Kind**: instance method of [Logger](#Logger) +**Overrides**: [toGenericMessage](#Actor+toGenericMessage) +**Returns**: Object - Generic message object. +**See** -**Kind**: instance method of [Filesystem](#Filesystem) -**Returns**: Boolean - `true` if the write succeeded, `false` if it did not. +- [https://en.wikipedia.org/wiki/Merkle_tree](https://en.wikipedia.org/wiki/Merkle_tree) +- [https://dev.fabric.pub/messages](https://dev.fabric.pub/messages) -| Param | Type | Description | -| --- | --- | --- | -| name | String | Name of the file to write. | -| content | Buffer | Content of the file. | + - +### logger.toObject() ⇒ Object +Returns the Actor's current state as an [Object](Object). -### filesystem.\_loadFromDisk() ⇒ Promise -Load Filesystem state from disk. +**Kind**: instance method of [Logger](#Logger) +**Overrides**: [toObject](#Actor+toObject) + -**Kind**: instance method of [Filesystem](#Filesystem) -**Returns**: Promise - Resolves with Filesystem instance. - +### logger.pause() ⇒ [Actor](#Actor) +Toggles `status` property to paused. -### filesystem.sync() ⇒ [Filesystem](#Filesystem) -Syncronize state from the local filesystem. +**Kind**: instance method of [Logger](#Logger) +**Overrides**: [pause](#Actor+pause) +**Returns**: [Actor](#Actor) - Instance of the Actor. + -**Kind**: instance method of [Filesystem](#Filesystem) -**Returns**: [Filesystem](#Filesystem) - Instance of the Fabric filesystem. - +### logger.serialize() ⇒ String +Serialize the Actor's current state into a JSON-formatted string. -## Hash256 -Simple interaction with 256-bit spaces. +**Kind**: instance method of [Logger](#Logger) +**Overrides**: [serialize](#Actor+serialize) + -**Kind**: global class +### logger.sign() ⇒ [Actor](#Actor) +Signs the Actor. -* [Hash256](#Hash256) - * [new Hash256(settings)](#new_Hash256_new) - * [.digest(input)](#Hash256.digest) ⇒ String - * [.reverse()](#Hash256.reverse) +**Kind**: instance method of [Logger](#Logger) +**Overrides**: [sign](#Actor+sign) + - +### logger.unpause() ⇒ [Actor](#Actor) +Toggles `status` property to unpaused. -### new Hash256(settings) -Create an instance of a `Hash256` object by calling `new Hash256()`, -where `settings` can be provided to supply a particular input object. +**Kind**: instance method of [Logger](#Logger) +**Overrides**: [unpause](#Actor+unpause) +**Returns**: [Actor](#Actor) - Instance of the Actor. + -If the `settings` is not a string, `input` must be provided. +### logger.value([format]) ⇒ Object +Get the inner value of the Actor with an optional cast type. +**Kind**: instance method of [Logger](#Logger) +**Overrides**: [value](#Actor+value) +**Returns**: Object - Inner value of the Actor as an [Object](Object), or cast to the requested `format`. -| Param | Type | Description | -| --- | --- | --- | -| settings | Object | | -| settings.input | String | Input string to map as 256-bit hash. | +| Param | Type | Default | Description | +| --- | --- | --- | --- | +| [format] | String | object | Cast the value to one of: `buffer, hex, json, string` | - + -### Hash256.digest(input) ⇒ String -Produce a SHA256 digest of some input data. +### logger.\_readObject(input) ⇒ Object +Parse an Object into a corresponding Fabric state. -**Kind**: static method of [Hash256](#Hash256) -**Returns**: String - `SHA256(input)` as a hexadecimal string. +**Kind**: instance method of [Logger](#Logger) +**Overrides**: [\_readObject](#Actor+_readObject) +**Returns**: Object - Fabric state. | Param | Type | Description | | --- | --- | --- | -| input | String \| Buffer | Content to digest. | - - - -### Hash256.reverse() -Reverses the bytes of the digest. +| input | Object | Object to read as input. | -**Kind**: static method of [Hash256](#Hash256) - + -## HKDF -Provides an HMAC-based Extract-and-Expand Key Derivation Function (HKDF), compatible with -RFC 5869. Defaults to 32 byte output, matching Bitcoin's implementaton. +## Machine +General-purpose state machine with [Vector](#Vector)-based instructions. **Kind**: global class -* [HKDF](#HKDF) - * [new HKDF(settings)](#new_HKDF_new) - * [.derive([info], [size])](#HKDF+derive) - - - -### new HKDF(settings) -Create an HKDF instance. - - -| Param | Type | Default | Description | -| --- | --- | --- | --- | -| settings | Object | | List of settings. | -| settings.initial | String | | Input keying material. | -| [settings.algorithm] | String | sha256 | Name of the hashing algorithm to use. | -| [settings.salt] | String | | Salt value (a non-secret random value). | - - - -### hkdF.derive([info], [size]) -Derive a new output. - -**Kind**: instance method of [HKDF](#HKDF) - -| Param | Type | Default | Description | -| --- | --- | --- | --- | -| [info] | Buffer | | Context and application specific information. | -| [size] | Number | 32 | Length of output. | - - +* [Machine](#Machine) + * [new Machine(settings)](#new_Machine_new) + * [.sip([n])](#Machine+sip) ⇒ Number + * [.slurp([n])](#Machine+slurp) ⇒ Number + * [.compute(input)](#Machine+compute) ⇒ [Machine](#Machine) -## Identity -Manage a network identity. + -**Kind**: global class - -* [Identity](#Identity) - * [new Identity([settings])](#new_Identity_new) - * [.sign(data)](#Identity+sign) ⇒ Signature - * [.toString()](#Identity+toString) ⇒ String - - - -### new Identity([settings]) -Create an instance of an Identity. - -**Returns**: [Identity](#Identity) - Instance of the identity. - -| Param | Type | Default | Description | -| --- | --- | --- | --- | -| [settings] | Object | | Settings for the Identity. | -| [settings.seed] | String | | BIP 39 seed phrase. | -| [settings.xprv] | String | | Serialized BIP 32 master private key. | -| [settings.xpub] | String | | Serialized BIP 32 master public key. | -| [settings.account] | Number | 0 | BIP 44 account index. | -| [settings.index] | Number | 0 | BIP 44 key index. | - - - -### identity.sign(data) ⇒ Signature -Sign a buffer of data using BIP 340: https://github.com/bitcoin/bips/blob/master/bip-0340.mediawiki - -**Kind**: instance method of [Identity](#Identity) -**Returns**: Signature - Resulting signature (64 bytes). - -| Param | Type | Description | -| --- | --- | --- | -| data | Buffer | Buffer of data to sign. | - - - -### identity.toString() ⇒ String -Retrieve the bech32m-encoded identity. - -**Kind**: instance method of [Identity](#Identity) -**Returns**: String - Public identity. - - -## Interface ⇐ EventEmitter -Interfaces compile abstract contract code into [Chain](#Chain)-executable transactions, or "chaincode". For example, the "Bitcoin" interface might compile a Swap contract into Script, preparing a valid Bitcoin transaction for broadcast which executes the swap contract. - -**Kind**: global class -**Extends**: EventEmitter -**Properties** - -| Name | Type | Description | -| --- | --- | --- | -| status | String | Human-friendly value representing the Interface's current [State](#State). | - - -* [Interface](#Interface) ⇐ EventEmitter - * [new Interface(settings)](#new_Interface_new) - * [.log(...inputs)](#Interface+log) - * [.now()](#Interface+now) ⇒ Number - * [.start()](#Interface+start) - * [.stop()](#Interface+stop) - * [.cycle(val)](#Interface+cycle) - - - -### new Interface(settings) -Define an [Interface](#Interface) by creating an instance of this class. - -**Returns**: [Interface](#Interface) - Instance of the [Interface](#Interface). - -| Param | Type | Description | -| --- | --- | --- | -| settings | Object | Configuration values. | - - - -### interface.log(...inputs) -Log some output to the console. - -**Kind**: instance method of [Interface](#Interface) - -| Param | Type | Description | -| --- | --- | --- | -| ...inputs | any | Components of the message to long. Can be a single {@link} String, many [String](String) objects, or anything else. | - - - -### interface.now() ⇒ Number -Returns current timestamp. - -**Kind**: instance method of [Interface](#Interface) - - -### interface.start() -Start the [Interface](#Interface). - -**Kind**: instance method of [Interface](#Interface) - - -### interface.stop() -Stop the Interface. - -**Kind**: instance method of [Interface](#Interface) - - -### interface.cycle(val) -Ticks the clock with a named [Cycle](Cycle). - -**Kind**: instance method of [Interface](#Interface) - -| Param | Type | Description | -| --- | --- | --- | -| val | String | Name of cycle to scribe. | - - - -## Key -Represents a cryptographic key. - -**Kind**: global class - - -### new Key([settings]) -Create an instance of a Fabric Key, either restoring from some known -values or from prior knowledge. For instance, you can call `new Key()` -to create a fresh keypair, or `new Key({ public: 'deadbeef...' })` to -create it from a known public key. - - -| Param | Type | Default | Description | -| --- | --- | --- | --- | -| [settings] | Object | | Initialization for the key. | -| [settings.network] | String | | Network string. | -| [settings.seed] | String | | Mnemonic seed for initializing the key. | -| [settings.public] | String | | Public key in hex. | -| [settings.private] | String | | Private key in hex. | -| [settings.purpose] | String | 44 | Constrains derivations to this space. | - - - -## Keystore -Provides an encrypted datastore for generic object storage. - -**Kind**: global class - -* [Keystore](#Keystore) - * [new Keystore([configuration])](#new_Keystore_new) - * [._setState(state)](#Keystore+_setState) ⇒ [Actor](#Actor) - - - -### new Keystore([configuration]) -Create an instance of the Store. - -**Returns**: [Keystore](#Keystore) - Instance of the store. - -| Param | Type | Default | Description | -| --- | --- | --- | --- | -| [configuration] | FabricStoreConfiguration | | Settings to use. | -| [configuration.name] | String | "DefaultStore" | Name of the Store. | - - - -### keystore.\_setState(state) ⇒ [Actor](#Actor) -Saves an Object to the store. - -**Kind**: instance method of [Keystore](#Keystore) -**Returns**: [Actor](#Actor) - The local instance of the provided State's [Actor](#Actor). - -| Param | Type | Description | -| --- | --- | --- | -| state | Object | State to store. | - - - -## Ledger ⇐ [Scribe](#Scribe) -An ordered stack of pages. - -**Kind**: global class -**Extends**: [Scribe](#Scribe) -**Properties** - -| Name | Type | Description | -| --- | --- | --- | -| memory | Buffer | The ledger's memory (4096 bytes). | -| stack | [Stack](#Stack) | The ledger's stack. | -| tip | Mixed | The most recent page in the ledger. | - - -* [Ledger](#Ledger) ⇐ [Scribe](#Scribe) - * [.append(item)](#Ledger+append) ⇒ Promise - * [.now()](#Scribe+now) ⇒ Number - * [.trust(source)](#Scribe+trust) ⇒ [Scribe](#Scribe) - * [.inherits(scribe)](#Scribe+inherits) ⇒ [Scribe](#Scribe) - * [.toHTML()](#State+toHTML) - * [.toString()](#State+toString) ⇒ String - * [.serialize([input])](#State+serialize) ⇒ Buffer - * [.deserialize(input)](#State+deserialize) ⇒ [State](#State) - * [.fork()](#State+fork) ⇒ [State](#State) - * [.get(path)](#State+get) ⇒ Mixed - * [.set(path)](#State+set) ⇒ Mixed - * [.commit()](#State+commit) - * [.render()](#State+render) ⇒ String - - - -### ledger.append(item) ⇒ Promise -Attempts to append a [Page](Page) to the ledger. - -**Kind**: instance method of [Ledger](#Ledger) -**Returns**: Promise - Resolves after the change has been committed. - -| Param | Type | Description | -| --- | --- | --- | -| item | Mixed | Item to store. | - - - -### ledger.now() ⇒ Number -Retrives the current timestamp, in milliseconds. - -**Kind**: instance method of [Ledger](#Ledger) -**Overrides**: [now](#Scribe+now) -**Returns**: Number - [Number](Number) representation of the millisecond [Integer](Integer) value. - - -### ledger.trust(source) ⇒ [Scribe](#Scribe) -Blindly bind event handlers to the [Source](Source). - -**Kind**: instance method of [Ledger](#Ledger) -**Overrides**: [trust](#Scribe+trust) -**Returns**: [Scribe](#Scribe) - Instance of the [Scribe](#Scribe). - -| Param | Type | Description | -| --- | --- | --- | -| source | Source | Event stream. | - - - -### ledger.inherits(scribe) ⇒ [Scribe](#Scribe) -Use an existing Scribe instance as a parent. - -**Kind**: instance method of [Ledger](#Ledger) -**Overrides**: [inherits](#Scribe+inherits) -**Returns**: [Scribe](#Scribe) - The configured instance of the Scribe. - -| Param | Type | Description | -| --- | --- | --- | -| scribe | [Scribe](#Scribe) | Instance of Scribe to use as parent. | - - - -### ledger.toHTML() -Converts the State to an HTML document. - -**Kind**: instance method of [Ledger](#Ledger) -**Overrides**: [toHTML](#State+toHTML) - - -### ledger.toString() ⇒ String -Unmarshall an existing state to an instance of a [Blob](Blob). - -**Kind**: instance method of [Ledger](#Ledger) -**Overrides**: [toString](#State+toString) -**Returns**: String - Serialized [Blob](Blob). - - -### ledger.serialize([input]) ⇒ Buffer -Convert to [Buffer](Buffer). - -**Kind**: instance method of [Ledger](#Ledger) -**Overrides**: [serialize](#State+serialize) -**Returns**: Buffer - [Store](#Store)-able blob. - -| Param | Type | Description | -| --- | --- | --- | -| [input] | Mixed | Input to serialize. | - - - -### ledger.deserialize(input) ⇒ [State](#State) -Take a hex-encoded input and convert to a [State](#State) object. - -**Kind**: instance method of [Ledger](#Ledger) -**Overrides**: [deserialize](#State+deserialize) -**Returns**: [State](#State) - [description] - -| Param | Type | Description | -| --- | --- | --- | -| input | String | [description] | - - - -### ledger.fork() ⇒ [State](#State) -Creates a new child [State](#State), with `@parent` set to -the current [State](#State) by immutable identifier. - -**Kind**: instance method of [Ledger](#Ledger) -**Overrides**: [fork](#State+fork) - - -### ledger.get(path) ⇒ Mixed -Retrieve a key from the [State](#State). - -**Kind**: instance method of [Ledger](#Ledger) -**Overrides**: [get](#State+get) - -| Param | Type | Description | -| --- | --- | --- | -| path | [Path](#Path) | Key to retrieve. | - - - -### ledger.set(path) ⇒ Mixed -Set a key in the [State](#State) to a particular value. - -**Kind**: instance method of [Ledger](#Ledger) -**Overrides**: [set](#State+set) - -| Param | Type | Description | -| --- | --- | --- | -| path | [Path](#Path) | Key to retrieve. | - - - -### ledger.commit() -Increment the vector clock, broadcast all changes as a transaction. - -**Kind**: instance method of [Ledger](#Ledger) -**Overrides**: [commit](#State+commit) - - -### ledger.render() ⇒ String -Compose a JSON string for network consumption. - -**Kind**: instance method of [Ledger](#Ledger) -**Overrides**: [render](#State+render) -**Returns**: String - JSON-encoded [String](String). - - -## Logger ⇐ [Actor](#Actor) -A basic logger that writes logs to the local file system - -**Kind**: global class -**Extends**: [Actor](#Actor) - -* [Logger](#Logger) ⇐ [Actor](#Actor) - * [.path](#Logger+path) ⇒ String - * [.log(msg)](#Logger+log) ⇒ Boolean - * [.start()](#Logger+start) ⇒ Promise - * [.stop()](#Logger+stop) ⇒ Promise - * [.adopt(changes)](#Actor+adopt) ⇒ [Actor](#Actor) - * [.commit()](#Actor+commit) ⇒ String - * [.export()](#Actor+export) ⇒ Object - * [.get(path)](#Actor+get) ⇒ Object - * [.set(path, value)](#Actor+set) ⇒ Object - * [.toBuffer()](#Actor+toBuffer) ⇒ Buffer - * [.toGenericMessage()](#Actor+toGenericMessage) ⇒ Object - * [.toObject()](#Actor+toObject) ⇒ Object - * [.pause()](#Actor+pause) ⇒ [Actor](#Actor) - * [.serialize()](#Actor+serialize) ⇒ String - * [.sign()](#Actor+sign) ⇒ [Actor](#Actor) - * [.unpause()](#Actor+unpause) ⇒ [Actor](#Actor) - * [.value([format])](#Actor+value) ⇒ Object - * [._readObject(input)](#Actor+_readObject) ⇒ Object - - - -### logger.path ⇒ String -Returns the path to the log file - -**Kind**: instance property of [Logger](#Logger) - - -### logger.log(msg) ⇒ Boolean -Writes the specified log to the log file - -**Kind**: instance method of [Logger](#Logger) -**Returns**: Boolean - true, if msg was successfully written; false otherwise - -| Param | Type | Description | -| --- | --- | --- | -| msg | String \| Object | The message to log | - - - -### logger.start() ⇒ Promise -Starts the logger - -This method creates the required directories for writing the log file. - -**Kind**: instance method of [Logger](#Logger) - - -### logger.stop() ⇒ Promise -Stops the logger - -This method closes the log file and returns after it has been closed. Any -errors on close would cause the return promise to be rejected. - -**Kind**: instance method of [Logger](#Logger) - - -### logger.adopt(changes) ⇒ [Actor](#Actor) -Explicitly adopt a set of [JSONPatch](JSONPatch)-encoded changes. - -**Kind**: instance method of [Logger](#Logger) -**Overrides**: [adopt](#Actor+adopt) -**Returns**: [Actor](#Actor) - Instance of the Actor. - -| Param | Type | Description | -| --- | --- | --- | -| changes | Array | List of [JSONPatch](JSONPatch) operations to apply. | - - - -### logger.commit() ⇒ String -Resolve the current state to a commitment. - -**Kind**: instance method of [Logger](#Logger) -**Overrides**: [commit](#Actor+commit) -**Returns**: String - 32-byte ID - - -### logger.export() ⇒ Object -Export the Actor's state to a standard [Object](Object). - -**Kind**: instance method of [Logger](#Logger) -**Overrides**: [export](#Actor+export) -**Returns**: Object - Standard object. - - -### logger.get(path) ⇒ Object -Retrieve a value from the Actor's state by [JSONPointer](JSONPointer) path. - -**Kind**: instance method of [Logger](#Logger) -**Overrides**: [get](#Actor+get) -**Returns**: Object - Value of the path in the Actor's state. - -| Param | Type | Description | -| --- | --- | --- | -| path | String | Path to retrieve using [JSONPointer](JSONPointer). | - - - -### logger.set(path, value) ⇒ Object -Set a value in the Actor's state by [JSONPointer](JSONPointer) path. - -**Kind**: instance method of [Logger](#Logger) -**Overrides**: [set](#Actor+set) -**Returns**: Object - Value of the path in the Actor's state. - -| Param | Type | Description | -| --- | --- | --- | -| path | String | Path to set using [JSONPointer](JSONPointer). | -| value | Object | Value to set. | - - - -### logger.toBuffer() ⇒ Buffer -Casts the Actor to a normalized Buffer. - -**Kind**: instance method of [Logger](#Logger) -**Overrides**: [toBuffer](#Actor+toBuffer) - - -### logger.toGenericMessage() ⇒ Object -Casts the Actor to a generic message, used to uniquely identify the Actor's state. -Fields: -- `preimage`: JSON.stringify(state) -- `hash`: SHA256(preimage) -- `type`: 'FabricActorState' -- `version`: 1 (for now) -- `object`: state -- `parent`: null (for now) - -**Kind**: instance method of [Logger](#Logger) -**Overrides**: [toGenericMessage](#Actor+toGenericMessage) -**Returns**: Object - Generic message object. -**See** - -- [https://en.wikipedia.org/wiki/Merkle_tree](https://en.wikipedia.org/wiki/Merkle_tree) -- [https://dev.fabric.pub/messages](https://dev.fabric.pub/messages) - - - -### logger.toObject() ⇒ Object -Returns the Actor's current state as an [Object](Object). - -**Kind**: instance method of [Logger](#Logger) -**Overrides**: [toObject](#Actor+toObject) - - -### logger.pause() ⇒ [Actor](#Actor) -Toggles `status` property to paused. - -**Kind**: instance method of [Logger](#Logger) -**Overrides**: [pause](#Actor+pause) -**Returns**: [Actor](#Actor) - Instance of the Actor. - - -### logger.serialize() ⇒ String -Serialize the Actor's current state into a JSON-formatted string. - -**Kind**: instance method of [Logger](#Logger) -**Overrides**: [serialize](#Actor+serialize) - - -### logger.sign() ⇒ [Actor](#Actor) -Signs the Actor. - -**Kind**: instance method of [Logger](#Logger) -**Overrides**: [sign](#Actor+sign) - - -### logger.unpause() ⇒ [Actor](#Actor) -Toggles `status` property to unpaused. - -**Kind**: instance method of [Logger](#Logger) -**Overrides**: [unpause](#Actor+unpause) -**Returns**: [Actor](#Actor) - Instance of the Actor. - - -### logger.value([format]) ⇒ Object -Get the inner value of the Actor with an optional cast type. - -**Kind**: instance method of [Logger](#Logger) -**Overrides**: [value](#Actor+value) -**Returns**: Object - Inner value of the Actor as an [Object](Object), or cast to the requested `format`. - -| Param | Type | Default | Description | -| --- | --- | --- | --- | -| [format] | String | object | Cast the value to one of: `buffer, hex, json, string` | - - - -### logger.\_readObject(input) ⇒ Object -Parse an Object into a corresponding Fabric state. - -**Kind**: instance method of [Logger](#Logger) -**Overrides**: [\_readObject](#Actor+_readObject) -**Returns**: Object - Fabric state. - -| Param | Type | Description | -| --- | --- | --- | -| input | Object | Object to read as input. | - - - -## Machine -General-purpose state machine with [Vector](#Vector)-based instructions. - -**Kind**: global class - -* [Machine](#Machine) - * [new Machine(settings)](#new_Machine_new) - * [.sip([n])](#Machine+sip) ⇒ Number - * [.slurp([n])](#Machine+slurp) ⇒ Number - * [.compute(input)](#Machine+compute) ⇒ [Machine](#Machine) - - - -### new Machine(settings) -Create a Machine. - - -| Param | Type | Description | -| --- | --- | --- | -| settings | Object | Run-time configuration. | - - - -### machine.sip([n]) ⇒ Number -Get `n` bits of deterministic random data. - -**Kind**: instance method of [Machine](#Machine) -**Returns**: Number - Random bits from [Generator](Generator). - -| Param | Type | Default | Description | -| --- | --- | --- | --- | -| [n] | Number | 128 | Number of bits to retrieve. | - - - -### machine.slurp([n]) ⇒ Number -Get `n` bytes of deterministic random data. - -**Kind**: instance method of [Machine](#Machine) -**Returns**: Number - Random bytes from [Generator](Generator). - -| Param | Type | Default | Description | -| --- | --- | --- | --- | -| [n] | Number | 32 | Number of bytes to retrieve. | - - - -### machine.compute(input) ⇒ [Machine](#Machine) -Computes the next "step" for our current Vector. Analagous to `sum`. -The top item on the stack is always the memory held at current position, -so counts should always begin with 0. - -**Kind**: instance method of [Machine](#Machine) -**Returns**: [Machine](#Machine) - Instance of the resulting machine. - -| Param | Type | Description | -| --- | --- | --- | -| input | Object | Value to pass as input. | - - - -## Mempool -Stores a list of [Transaction](Transaction) elements. - -**Kind**: global class -**Emits**: event:{Message} confirmed Emitted when the Mempool has dropped a transaction. - - -### new Mempool(settings) -Creates an instance of a [Mempool](#Mempool) [Service](#Service). - - -| Param | Type | Description | -| --- | --- | --- | -| settings | Object | Map of settings to utilize. | - - - -## Message : Object -The [Message](#Message) type defines the Application Messaging Protocol, or AMP. -Each [Actor](#Actor) in the network receives and broadcasts messages, -selectively disclosing new routes to peers which may have open circuits. - -**Kind**: global class - -* [Message](#Message) : Object - * [new Message(message)](#new_Message_new) - * [.asRaw()](#Message+asRaw) ⇒ Buffer - * [.sign()](#Message+sign) ⇒ [Message](#Message) - * [.verify()](#Message+verify) ⇒ Boolean - * [._setSigner(signer)](#Message+_setSigner) ⇒ [Message](#Message) - - - -### new Message(message) -The `Message` type is standardized in [Fabric](#Fabric) as a [Array](Array), which can be added to any other vector to compute a resulting state. - -**Returns**: [Message](#Message) - Instance of the message. - -| Param | Type | Description | -| --- | --- | --- | -| message | Object | Message vector. Will be serialized by [Array#_serialize](Array#_serialize). | - - - -### message.asRaw() ⇒ Buffer -Returns a [Buffer](Buffer) of the complete message. - -**Kind**: instance method of [Message](#Message) -**Returns**: Buffer - Buffer of the encoded [Message](#Message). - - -### message.sign() ⇒ [Message](#Message) -Signs the message using the associated signer. - -**Kind**: instance method of [Message](#Message) -**Returns**: [Message](#Message) - Signed message. - - -### message.verify() ⇒ Boolean -Verify a message's signature. - -**Kind**: instance method of [Message](#Message) -**Returns**: Boolean - `true` if the signature is valid, `false` if not. - - -### message.\_setSigner(signer) ⇒ [Message](#Message) -Sets the signer for the message. - -**Kind**: instance method of [Message](#Message) -**Returns**: [Message](#Message) - Instance of the Message with associated signer. - -| Param | Type | Description | -| --- | --- | --- | -| signer | [Signer](#Signer) | Signer instance. | - - - -## Node -Full definition of a Fabric node. - -**Kind**: global class - -* [Node](#Node) - * [new Node(settings)](#new_Node_new) - * [.trust(source, settings)](#Node+trust) - - - -### new Node(settings) -Manage a Fabric service. - -**Returns**: [Node](#Node) - Instance of the managed service. - -| Param | Type | Description | -| --- | --- | --- | -| settings | Object | Configuration for the node. | - - - -### node.trust(source, settings) -Explicitly trusts an [EventEmitter](EventEmitter). - -**Kind**: instance method of [Node](#Node) - -| Param | Type | Description | -| --- | --- | --- | -| source | EventEmitter | Actor to listen to. | -| settings | Object \| String | Label for the trusted messages, or a configuration object. | - - - -## Oracle ⇐ [Store](#Store) -An Oracle manages one or more collections, using a mempool for -transitive state. - -**Kind**: global class -**Extends**: [Store](#Store) - -* [Oracle](#Oracle) ⇐ [Store](#Store) - * [new Oracle(initial)](#new_Oracle_new) - * [.broadcast(msg)](#Oracle+broadcast) ⇒ Boolean - * [._REGISTER(obj)](#Store+_REGISTER) ⇒ [Vector](#Vector) - * [._POST(key, value)](#Store+_POST) ⇒ Promise - * [.get(key)](#Store+get) ⇒ Promise - * [.set(key, value)](#Store+set) - * [.trust(source)](#Store+trust) ⇒ [Store](#Store) - * [.del(key)](#Store+del) - * [.flush()](#Store+flush) - * [.start()](#Store+start) ⇒ Promise - - - -### new Oracle(initial) -Trusted point-of-reference for external services. - - -| Param | Type | Description | -| --- | --- | --- | -| initial | Object | Initialization vector. | - - - -### oracle.broadcast(msg) ⇒ Boolean -Core messaging function for interacting with this object in system-time. - -**Kind**: instance method of [Oracle](#Oracle) -**Returns**: Boolean - Returns `true` on success, `false` on failure. - -| Param | Type | Description | -| --- | --- | --- | -| msg | [Message](#Message) | Instance of a [module:Message](module:Message) object, validated then transmitted verbatim. | - - - -### oracle.\_REGISTER(obj) ⇒ [Vector](#Vector) -Registers an [Actor](#Actor). Necessary to store in a collection. - -**Kind**: instance method of [Oracle](#Oracle) -**Overrides**: [\_REGISTER](#Store+_REGISTER) -**Returns**: [Vector](#Vector) - Returned from `storage.set` - -| Param | Type | Description | -| --- | --- | --- | -| obj | Object | Instance of the object to store. | - - - -### oracle.\_POST(key, value) ⇒ Promise -Insert something into a collection. - -**Kind**: instance method of [Oracle](#Oracle) -**Overrides**: [\_POST](#Store+_POST) -**Returns**: Promise - Resolves on success with a String pointer. - -| Param | Type | Description | -| --- | --- | --- | -| key | String | Path to add data to. | -| value | Mixed | Object to store. | - - - -### oracle.get(key) ⇒ Promise -Barebones getter. - -**Kind**: instance method of [Oracle](#Oracle) -**Overrides**: [get](#Store+get) -**Returns**: Promise - Resolves on complete. `null` if not found. - -| Param | Type | Description | -| --- | --- | --- | -| key | String | Name of data to retrieve. | - - - -### oracle.set(key, value) -Set a `key` to a specific `value`. - -**Kind**: instance method of [Oracle](#Oracle) -**Overrides**: [set](#Store+set) - -| Param | Type | Description | -| --- | --- | --- | -| key | String | Address of the information. | -| value | Mixed | Content to store at `key`. | - - - -### oracle.trust(source) ⇒ [Store](#Store) -Implicitly trust an [Event](Event) source. - -**Kind**: instance method of [Oracle](#Oracle) -**Overrides**: [trust](#Store+trust) -**Returns**: [Store](#Store) - Resulting instance of [Store](#Store) with new trust. - -| Param | Type | Description | -| --- | --- | --- | -| source | EventEmitter | Event-emitting source. | - - - -### oracle.del(key) -Remove a [Value](#Value) by [Path](#Path). - -**Kind**: instance method of [Oracle](#Oracle) -**Overrides**: [del](#Store+del) - -| Param | Type | Description | -| --- | --- | --- | -| key | [Path](#Path) | Key to remove. | - - - -### oracle.flush() -Wipes the storage. - -**Kind**: instance method of [Oracle](#Oracle) -**Overrides**: [flush](#Store+flush) - - -### oracle.start() ⇒ Promise -Start running the process. - -**Kind**: instance method of [Oracle](#Oracle) -**Overrides**: [start](#Store+start) -**Returns**: Promise - Resolves on complete. - - -## Path -A [Path](#Path) is a [Fabric](#Fabric)-native link to a [Document](Document) -within the network. - -**Kind**: global class - -* [Path](#Path) - * [new Path(input)](#new_Path_new) - * [.isValid()](#Path+isValid) ⇒ Boolean - - - -### new Path(input) -Create a new [Path](#Path). - - -| Param | Type | Description | -| --- | --- | --- | -| input | String \| Object | Named path. | - - - -### path.isValid() ⇒ Boolean -**Kind**: instance method of [Path](#Path) -**Returns**: Boolean - Whether or not the Path is valid. - - -## Peer -An in-memory representation of a node in our network. - -**Kind**: global class - -* [Peer](#Peer) - * [new Peer([config])](#new_Peer_new) - * ~~[.address](#Peer+address)~~ - * [.broadcast(message)](#Peer+broadcast) - * [._connect(target)](#Peer+_connect) - * [._fillPeerSlots()](#Peer+_fillPeerSlots) ⇒ [Peer](#Peer) - * [._handleFabricMessage(buffer)](#Peer+_handleFabricMessage) ⇒ [Peer](#Peer) - * [.start()](#Peer+start) - * [.stop()](#Peer+stop) - * [.listen()](#Peer+listen) ⇒ [Peer](#Peer) - - - -### new Peer([config]) -Create an instance of [Peer](#Peer). - - -| Param | Type | Default | Description | -| --- | --- | --- | --- | -| [config] | Object | | Initialization Vector for this peer. | -| [config.listen] | Boolean | | Whether or not to listen for connections. | -| [config.upnp] | Boolean | | Whether or not to use UPNP for automatic configuration. | -| [config.port] | Number | 7777 | Port to use for P2P connections. | -| [config.peers] | Array | [] | List of initial peers. | - - - -### ~~peer.address~~ -***Deprecated*** - -**Kind**: instance property of [Peer](#Peer) - - -### peer.broadcast(message) -Write a [Buffer](Buffer) to all connected peers. - -**Kind**: instance method of [Peer](#Peer) - -| Param | Type | Description | -| --- | --- | --- | -| message | Buffer | Message buffer to send. | - - - -### peer.\_connect(target) -Open a Fabric connection to the target address and initiate the Fabric Protocol. - -**Kind**: instance method of [Peer](#Peer) - -| Param | Type | Description | -| --- | --- | --- | -| target | String | Target address. | - - - -### peer.\_fillPeerSlots() ⇒ [Peer](#Peer) -Attempt to fill available connection slots with new peers. - -**Kind**: instance method of [Peer](#Peer) -**Returns**: [Peer](#Peer) - Instance of the peer. - - -### peer.\_handleFabricMessage(buffer) ⇒ [Peer](#Peer) -Handle a Fabric [Message](#Message) buffer. - -**Kind**: instance method of [Peer](#Peer) -**Returns**: [Peer](#Peer) - Instance of the Peer. - -| Param | Type | -| --- | --- | -| buffer | Buffer | - - - -### peer.start() -Start the Peer. - -**Kind**: instance method of [Peer](#Peer) - - -### peer.stop() -Stop the peer. - -**Kind**: instance method of [Peer](#Peer) - - -### peer.listen() ⇒ [Peer](#Peer) -Start listening for connections. - -**Kind**: instance method of [Peer](#Peer) -**Returns**: [Peer](#Peer) - Chainable method. - - -## Reader -Read from a byte stream, seeking valid Fabric messages. - -**Kind**: global class - - -### new Reader(settings) -Create an instance of a [Reader](#Reader), which can listen to a byte stream -for valid Fabric messages. - - -| Param | Type | Description | -| --- | --- | --- | -| settings | Object | Settings for the stream. | - - - -## Remote : [Remote](#Remote) -Interact with a remote [Resource](#Resource). This is currently the only -HTTP-related code that should remain in @fabric/core — all else must -be moved to @fabric/http before final release! - -**Kind**: global class -**Properties** - -| Name | Type | -| --- | --- | -| config | Object | -| secure | Boolean | - - -* [Remote](#Remote) : [Remote](#Remote) - * [new Remote(target)](#new_Remote_new) - * [.enumerate()](#Remote+enumerate) ⇒ Configuration - * [.request(type, path, [params])](#Remote+request) ⇒ FabricHTTPResult - * [._PUT(path, body)](#Remote+_PUT) ⇒ FabricHTTPResult \| String - * [._GET(path, params)](#Remote+_GET) ⇒ FabricHTTPResult \| String - * [._POST(path, params)](#Remote+_POST) ⇒ FabricHTTPResult \| String - * [._OPTIONS(path, params)](#Remote+_OPTIONS) ⇒ Object - * [._PATCH(path, body)](#Remote+_PATCH) ⇒ Object - * [._DELETE(path, params)](#Remote+_DELETE) ⇒ Object - - - -### new Remote(target) -An in-memory representation of a node in our network. - - -| Param | Type | Description | -| --- | --- | --- | -| target | Object | Target object. | -| target.host | String | Named host, e.g. "localhost". | -| target.secure | String | Require TLS session. | - - - -### remote.enumerate() ⇒ Configuration -Enumerate the available Resources on the remote host. - -**Kind**: instance method of [Remote](#Remote) -**Returns**: Configuration - An object with enumerable key/value pairs for the Application Resource Contract. - - -### remote.request(type, path, [params]) ⇒ FabricHTTPResult -Make an HTTP request to the configured authority. - -**Kind**: instance method of [Remote](#Remote) - -| Param | Type | Description | -| --- | --- | --- | -| type | String | One of `GET`, `PUT`, `POST`, `DELETE`, or `OPTIONS`. | -| path | String | The path to request from the authority. | -| [params] | Object | Options. | - - - -### remote.\_PUT(path, body) ⇒ FabricHTTPResult \| String -HTTP PUT against the configured Authority. - -**Kind**: instance method of [Remote](#Remote) -**Returns**: FabricHTTPResult \| String - Result of request. - -| Param | Type | Description | -| --- | --- | --- | -| path | String | HTTP Path to request. | -| body | Object | Map of parameters to supply. | - - - -### remote.\_GET(path, params) ⇒ FabricHTTPResult \| String -HTTP GET against the configured Authority. - -**Kind**: instance method of [Remote](#Remote) -**Returns**: FabricHTTPResult \| String - Result of request. - -| Param | Type | Description | -| --- | --- | --- | -| path | String | HTTP Path to request. | -| params | Object | Map of parameters to supply. | - - - -### remote.\_POST(path, params) ⇒ FabricHTTPResult \| String -HTTP POST against the configured Authority. - -**Kind**: instance method of [Remote](#Remote) -**Returns**: FabricHTTPResult \| String - Result of request. - -| Param | Type | Description | -| --- | --- | --- | -| path | String | HTTP Path to request. | -| params | Object | Map of parameters to supply. | - - - -### remote.\_OPTIONS(path, params) ⇒ Object -HTTP OPTIONS on the configured Authority. - -**Kind**: instance method of [Remote](#Remote) -**Returns**: Object - - Full description of remote resource. - -| Param | Type | Description | -| --- | --- | --- | -| path | String | HTTP Path to request. | -| params | Object | Map of parameters to supply. | - - - -### remote.\_PATCH(path, body) ⇒ Object -HTTP PATCH on the configured Authority. - -**Kind**: instance method of [Remote](#Remote) -**Returns**: Object - - Full description of remote resource. - -| Param | Type | Description | -| --- | --- | --- | -| path | String | HTTP Path to request. | -| body | Object | Map of parameters to supply. | - - - -### remote.\_DELETE(path, params) ⇒ Object -HTTP DELETE on the configured Authority. +### new Machine(settings) +Create a Machine. -**Kind**: instance method of [Remote](#Remote) -**Returns**: Object - - Full description of remote resource. | Param | Type | Description | | --- | --- | --- | -| path | String | HTTP Path to request. | -| params | Object | Map of parameters to supply. | +| settings | Object | Run-time configuration. | - + -## Resource -Generic interface for collections of digital objects. +### machine.sip([n]) ⇒ Number +Get `n` bits of deterministic random data. -**Kind**: global class +**Kind**: instance method of [Machine](#Machine) +**Returns**: Number - Random bits from [Generator](Generator). -* [Resource](#Resource) - * [new Resource(definition)](#new_Resource_new) - * [.create(obj)](#Resource+create) ⇒ [Vector](#Vector) - * [.update(id, update)](#Resource+update) ⇒ [Vector](#Vector) +| Param | Type | Default | Description | +| --- | --- | --- | --- | +| [n] | Number | 128 | Number of bits to retrieve. | - + -### new Resource(definition) +### machine.slurp([n]) ⇒ Number +Get `n` bytes of deterministic random data. -| Param | Type | Description | -| --- | --- | --- | -| definition | Object | Initial parameters | +**Kind**: instance method of [Machine](#Machine) +**Returns**: Number - Random bytes from [Generator](Generator). - +| Param | Type | Default | Description | +| --- | --- | --- | --- | +| [n] | Number | 32 | Number of bytes to retrieve. | -### resource.create(obj) ⇒ [Vector](#Vector) -Create an instance of the Resource's type. + -**Kind**: instance method of [Resource](#Resource) -**Returns**: [Vector](#Vector) - Resulting Vector with deterministic identifier. +### machine.compute(input) ⇒ [Machine](#Machine) +Computes the next "step" for our current Vector. Analagous to `sum`. +The top item on the stack is always the memory held at current position, +so counts should always begin with 0. + +**Kind**: instance method of [Machine](#Machine) +**Returns**: [Machine](#Machine) - Instance of the resulting machine. | Param | Type | Description | | --- | --- | --- | -| obj | Object | Map of the instance's properties and values. | +| input | Object | Value to pass as input. | - + -### resource.update(id, update) ⇒ [Vector](#Vector) -Modify an existing instance of a Resource by its unique identifier. Produces a new instance. +## Message : Object +The [Message](#Message) type defines the Application Messaging Protocol, or AMP. +Each [Actor](#Actor) in the network receives and broadcasts messages, +selectively disclosing new routes to peers which may have open circuits. -**Kind**: instance method of [Resource](#Resource) -**Returns**: [Vector](#Vector) - Resulting Vector instance with updated identifier. +**Kind**: global class + +* [Message](#Message) : Object + * [new Message(message)](#new_Message_new) + * [.asRaw()](#Message+asRaw) ⇒ Buffer + * [.sign()](#Message+sign) ⇒ [Message](#Message) + * [.verify()](#Message+verify) ⇒ Boolean + * [._setSigner(signer)](#Message+_setSigner) ⇒ [Message](#Message) + + + +### new Message(message) +The `Message` type is standardized in [Fabric](#Fabric) as a [Array](Array), which can be added to any other vector to compute a resulting state. + +**Returns**: [Message](#Message) - Instance of the message. | Param | Type | Description | | --- | --- | --- | -| id | String | Unique ID to update. | -| update | Object | Map of change to make (keys -> values). | +| message | Object | Message vector. Will be serialized by [Array#_serialize](Array#_serialize). | + + + +### message.asRaw() ⇒ Buffer +Returns a [Buffer](Buffer) of the complete message. - +**Kind**: instance method of [Message](#Message) +**Returns**: Buffer - Buffer of the encoded [Message](#Message). + -## Router ⇐ [Scribe](#Scribe) -Process incoming messages. +### message.sign() ⇒ [Message](#Message) +Signs the message using the associated signer. -**Kind**: global class -**Extends**: [Scribe](#Scribe) +**Kind**: instance method of [Message](#Message) +**Returns**: [Message](#Message) - Signed message. + -* [Router](#Router) ⇐ [Scribe](#Scribe) - * [new Router(map)](#new_Router_new) - * [.route(msg)](#Router+route) ⇒ Array - * [.use(plugin, name)](#Router+use) ⇒ [Router](#Router) - * [.now()](#Scribe+now) ⇒ Number - * [.trust(source)](#Scribe+trust) ⇒ [Scribe](#Scribe) - * [.inherits(scribe)](#Scribe+inherits) ⇒ [Scribe](#Scribe) - * [.toHTML()](#State+toHTML) - * [.toString()](#State+toString) ⇒ String - * [.serialize([input])](#State+serialize) ⇒ Buffer - * [.deserialize(input)](#State+deserialize) ⇒ [State](#State) - * [.fork()](#State+fork) ⇒ [State](#State) - * [.get(path)](#State+get) ⇒ Mixed - * [.set(path)](#State+set) ⇒ Mixed - * [.commit()](#State+commit) - * [.render()](#State+render) ⇒ String +### message.verify() ⇒ Boolean +Verify a message's signature. - +**Kind**: instance method of [Message](#Message) +**Returns**: Boolean - `true` if the signature is valid, `false` if not. + -### new Router(map) -Maintains a list of triggers ("commands") and their behaviors. +### message.\_setSigner(signer) ⇒ [Message](#Message) +Sets the signer for the message. +**Kind**: instance method of [Message](#Message) +**Returns**: [Message](#Message) - Instance of the Message with associated signer. | Param | Type | Description | | --- | --- | --- | -| map | Object | Map of command names => behaviors. | +| signer | [Signer](#Signer) | Signer instance. | - + -### router.route(msg) ⇒ Array -Assembles a list of possible responses to the incoming request. +## Peer +An in-memory representation of a node in our network. -**Kind**: instance method of [Router](#Router) -**Returns**: Array - List of outputs generated from the input string. +**Kind**: global class -| Param | Type | Description | -| --- | --- | --- | -| msg | String | Input message to route. | +* [Peer](#Peer) + * [new Peer([config])](#new_Peer_new) + * ~~[.address](#Peer+address)~~ + * [.broadcast(message)](#Peer+broadcast) + * [._connect(target)](#Peer+_connect) + * [._fillPeerSlots()](#Peer+_fillPeerSlots) ⇒ [Peer](#Peer) + * [._handleFabricMessage(buffer)](#Peer+_handleFabricMessage) ⇒ [Peer](#Peer) + * [.start()](#Peer+start) + * [.stop()](#Peer+stop) + * [.listen()](#Peer+listen) ⇒ [Peer](#Peer) - + -### router.use(plugin, name) ⇒ [Router](#Router) -Attaches a new handler to the router. +### new Peer([config]) +Create an instance of [Peer](#Peer). -**Kind**: instance method of [Router](#Router) -**Returns**: [Router](#Router) - Configured instance of the router. -| Param | Type | Description | -| --- | --- | --- | -| plugin | Plugin | Instance of the plugin. | -| name | Plugin.name | Name of the plugin. | +| Param | Type | Default | Description | +| --- | --- | --- | --- | +| [config] | Object | | Initialization Vector for this peer. | +| [config.listen] | Boolean | | Whether or not to listen for connections. | +| [config.upnp] | Boolean | | Whether or not to use UPNP for automatic configuration. | +| [config.port] | Number | 7777 | Port to use for P2P connections. | +| [config.peers] | Array | [] | List of initial peers. | - + -### router.now() ⇒ Number -Retrives the current timestamp, in milliseconds. +### ~~peer.address~~ +***Deprecated*** -**Kind**: instance method of [Router](#Router) -**Overrides**: [now](#Scribe+now) -**Returns**: Number - [Number](Number) representation of the millisecond [Integer](Integer) value. - +**Kind**: instance property of [Peer](#Peer) + -### router.trust(source) ⇒ [Scribe](#Scribe) -Blindly bind event handlers to the [Source](Source). +### peer.broadcast(message) +Write a [Buffer](Buffer) to all connected peers. -**Kind**: instance method of [Router](#Router) -**Overrides**: [trust](#Scribe+trust) -**Returns**: [Scribe](#Scribe) - Instance of the [Scribe](#Scribe). +**Kind**: instance method of [Peer](#Peer) | Param | Type | Description | | --- | --- | --- | -| source | Source | Event stream. | +| message | Buffer | Message buffer to send. | - + -### router.inherits(scribe) ⇒ [Scribe](#Scribe) -Use an existing Scribe instance as a parent. +### peer.\_connect(target) +Open a Fabric connection to the target address and initiate the Fabric Protocol. -**Kind**: instance method of [Router](#Router) -**Overrides**: [inherits](#Scribe+inherits) -**Returns**: [Scribe](#Scribe) - The configured instance of the Scribe. +**Kind**: instance method of [Peer](#Peer) | Param | Type | Description | | --- | --- | --- | -| scribe | [Scribe](#Scribe) | Instance of Scribe to use as parent. | +| target | String | Target address. | - + -### router.toHTML() -Converts the State to an HTML document. +### peer.\_fillPeerSlots() ⇒ [Peer](#Peer) +Attempt to fill available connection slots with new peers. -**Kind**: instance method of [Router](#Router) -**Overrides**: [toHTML](#State+toHTML) - +**Kind**: instance method of [Peer](#Peer) +**Returns**: [Peer](#Peer) - Instance of the peer. + -### router.toString() ⇒ String -Unmarshall an existing state to an instance of a [Blob](Blob). +### peer.\_handleFabricMessage(buffer) ⇒ [Peer](#Peer) +Handle a Fabric [Message](#Message) buffer. -**Kind**: instance method of [Router](#Router) -**Overrides**: [toString](#State+toString) -**Returns**: String - Serialized [Blob](Blob). - +**Kind**: instance method of [Peer](#Peer) +**Returns**: [Peer](#Peer) - Instance of the Peer. -### router.serialize([input]) ⇒ Buffer -Convert to [Buffer](Buffer). +| Param | Type | +| --- | --- | +| buffer | Buffer | -**Kind**: instance method of [Router](#Router) -**Overrides**: [serialize](#State+serialize) -**Returns**: Buffer - [Store](#Store)-able blob. + -| Param | Type | Description | -| --- | --- | --- | -| [input] | Mixed | Input to serialize. | +### peer.start() +Start the Peer. - +**Kind**: instance method of [Peer](#Peer) + -### router.deserialize(input) ⇒ [State](#State) -Take a hex-encoded input and convert to a [State](#State) object. +### peer.stop() +Stop the peer. -**Kind**: instance method of [Router](#Router) -**Overrides**: [deserialize](#State+deserialize) -**Returns**: [State](#State) - [description] +**Kind**: instance method of [Peer](#Peer) + -| Param | Type | Description | -| --- | --- | --- | -| input | String | [description] | +### peer.listen() ⇒ [Peer](#Peer) +Start listening for connections. - +**Kind**: instance method of [Peer](#Peer) +**Returns**: [Peer](#Peer) - Chainable method. + -### router.fork() ⇒ [State](#State) -Creates a new child [State](#State), with `@parent` set to -the current [State](#State) by immutable identifier. +## Reader +Read from a byte stream, seeking valid Fabric messages. -**Kind**: instance method of [Router](#Router) -**Overrides**: [fork](#State+fork) - +**Kind**: global class + -### router.get(path) ⇒ Mixed -Retrieve a key from the [State](#State). +### new Reader(settings) +Create an instance of a [Reader](#Reader), which can listen to a byte stream +for valid Fabric messages. -**Kind**: instance method of [Router](#Router) -**Overrides**: [get](#State+get) | Param | Type | Description | | --- | --- | --- | -| path | [Path](#Path) | Key to retrieve. | - - - -### router.set(path) ⇒ Mixed -Set a key in the [State](#State) to a particular value. +| settings | Object | Settings for the stream. | -**Kind**: instance method of [Router](#Router) -**Overrides**: [set](#State+set) + -| Param | Type | Description | -| --- | --- | --- | -| path | [Path](#Path) | Key to retrieve. | +## Remote : [Remote](#Remote) +Interact with a remote [Resource](#Resource). This is currently the only +HTTP-related code that should remain in @fabric/core — all else must +be moved to @fabric/http before final release! - +**Kind**: global class +**Properties** -### router.commit() -Increment the vector clock, broadcast all changes as a transaction. +| Name | Type | +| --- | --- | +| config | Object | +| secure | Boolean | -**Kind**: instance method of [Router](#Router) -**Overrides**: [commit](#State+commit) - -### router.render() ⇒ String -Compose a JSON string for network consumption. +* [Remote](#Remote) : [Remote](#Remote) + * [new Remote(target)](#new_Remote_new) + * [.enumerate()](#Remote+enumerate) ⇒ Configuration + * [.request(type, path, [params])](#Remote+request) ⇒ FabricHTTPResult + * [._PUT(path, body)](#Remote+_PUT) ⇒ FabricHTTPResult \| String + * [._GET(path, params)](#Remote+_GET) ⇒ FabricHTTPResult \| String + * [._POST(path, params)](#Remote+_POST) ⇒ FabricHTTPResult \| String + * [._OPTIONS(path, params)](#Remote+_OPTIONS) ⇒ Object + * [._PATCH(path, body)](#Remote+_PATCH) ⇒ Object + * [._DELETE(path, params)](#Remote+_DELETE) ⇒ Object -**Kind**: instance method of [Router](#Router) -**Overrides**: [render](#State+render) -**Returns**: String - JSON-encoded [String](String). - + -## Scribe ⇐ [State](#State) -Simple tag-based recordkeeper. +### new Remote(target) +An in-memory representation of a node in our network. -**Kind**: global class -**Extends**: [State](#State) -**Properties** -| Name | Type | Description | +| Param | Type | Description | | --- | --- | --- | -| config | Object | Current configuration. | +| target | Object | Target object. | +| target.host | String | Named host, e.g. "localhost". | +| target.secure | String | Require TLS session. | + -* [Scribe](#Scribe) ⇐ [State](#State) - * [new Scribe(config)](#new_Scribe_new) - * [.now()](#Scribe+now) ⇒ Number - * [.trust(source)](#Scribe+trust) ⇒ [Scribe](#Scribe) - * [.inherits(scribe)](#Scribe+inherits) ⇒ [Scribe](#Scribe) - * [.toHTML()](#State+toHTML) - * [.toString()](#State+toString) ⇒ String - * [.serialize([input])](#State+serialize) ⇒ Buffer - * [.deserialize(input)](#State+deserialize) ⇒ [State](#State) - * [.fork()](#State+fork) ⇒ [State](#State) - * [.get(path)](#State+get) ⇒ Mixed - * [.set(path)](#State+set) ⇒ Mixed - * [.commit()](#State+commit) - * [.render()](#State+render) ⇒ String +### remote.enumerate() ⇒ Configuration +Enumerate the available Resources on the remote host. - +**Kind**: instance method of [Remote](#Remote) +**Returns**: Configuration - An object with enumerable key/value pairs for the Application Resource Contract. + -### new Scribe(config) -The "Scribe" is a simple tag-based recordkeeper. +### remote.request(type, path, [params]) ⇒ FabricHTTPResult +Make an HTTP request to the configured authority. +**Kind**: instance method of [Remote](#Remote) | Param | Type | Description | | --- | --- | --- | -| config | Object | General configuration object. | -| config.verbose | Boolean | Should the Scribe be noisy? | +| type | String | One of `GET`, `PUT`, `POST`, `DELETE`, or `OPTIONS`. | +| path | String | The path to request from the authority. | +| [params] | Object | Options. | - + -### scribe.now() ⇒ Number -Retrives the current timestamp, in milliseconds. +### remote.\_PUT(path, body) ⇒ FabricHTTPResult \| String +HTTP PUT against the configured Authority. -**Kind**: instance method of [Scribe](#Scribe) -**Returns**: Number - [Number](Number) representation of the millisecond [Integer](Integer) value. - +**Kind**: instance method of [Remote](#Remote) +**Returns**: FabricHTTPResult \| String - Result of request. -### scribe.trust(source) ⇒ [Scribe](#Scribe) -Blindly bind event handlers to the [Source](Source). +| Param | Type | Description | +| --- | --- | --- | +| path | String | HTTP Path to request. | +| body | Object | Map of parameters to supply. | -**Kind**: instance method of [Scribe](#Scribe) -**Returns**: [Scribe](#Scribe) - Instance of the [Scribe](#Scribe). + + +### remote.\_GET(path, params) ⇒ FabricHTTPResult \| String +HTTP GET against the configured Authority. + +**Kind**: instance method of [Remote](#Remote) +**Returns**: FabricHTTPResult \| String - Result of request. | Param | Type | Description | | --- | --- | --- | -| source | Source | Event stream. | +| path | String | HTTP Path to request. | +| params | Object | Map of parameters to supply. | - + -### scribe.inherits(scribe) ⇒ [Scribe](#Scribe) -Use an existing Scribe instance as a parent. +### remote.\_POST(path, params) ⇒ FabricHTTPResult \| String +HTTP POST against the configured Authority. -**Kind**: instance method of [Scribe](#Scribe) -**Returns**: [Scribe](#Scribe) - The configured instance of the Scribe. +**Kind**: instance method of [Remote](#Remote) +**Returns**: FabricHTTPResult \| String - Result of request. | Param | Type | Description | | --- | --- | --- | -| scribe | [Scribe](#Scribe) | Instance of Scribe to use as parent. | +| path | String | HTTP Path to request. | +| params | Object | Map of parameters to supply. | - + -### scribe.toHTML() -Converts the State to an HTML document. +### remote.\_OPTIONS(path, params) ⇒ Object +HTTP OPTIONS on the configured Authority. -**Kind**: instance method of [Scribe](#Scribe) -**Overrides**: [toHTML](#State+toHTML) - +**Kind**: instance method of [Remote](#Remote) +**Returns**: Object - - Full description of remote resource. -### scribe.toString() ⇒ String -Unmarshall an existing state to an instance of a [Blob](Blob). +| Param | Type | Description | +| --- | --- | --- | +| path | String | HTTP Path to request. | +| params | Object | Map of parameters to supply. | -**Kind**: instance method of [Scribe](#Scribe) -**Overrides**: [toString](#State+toString) -**Returns**: String - Serialized [Blob](Blob). - + -### scribe.serialize([input]) ⇒ Buffer -Convert to [Buffer](Buffer). +### remote.\_PATCH(path, body) ⇒ Object +HTTP PATCH on the configured Authority. -**Kind**: instance method of [Scribe](#Scribe) -**Overrides**: [serialize](#State+serialize) -**Returns**: Buffer - [Store](#Store)-able blob. +**Kind**: instance method of [Remote](#Remote) +**Returns**: Object - - Full description of remote resource. | Param | Type | Description | | --- | --- | --- | -| [input] | Mixed | Input to serialize. | +| path | String | HTTP Path to request. | +| body | Object | Map of parameters to supply. | - + -### scribe.deserialize(input) ⇒ [State](#State) -Take a hex-encoded input and convert to a [State](#State) object. +### remote.\_DELETE(path, params) ⇒ Object +HTTP DELETE on the configured Authority. -**Kind**: instance method of [Scribe](#Scribe) -**Overrides**: [deserialize](#State+deserialize) -**Returns**: [State](#State) - [description] +**Kind**: instance method of [Remote](#Remote) +**Returns**: Object - - Full description of remote resource. | Param | Type | Description | | --- | --- | --- | -| input | String | [description] | +| path | String | HTTP Path to request. | +| params | Object | Map of parameters to supply. | - + -### scribe.fork() ⇒ [State](#State) -Creates a new child [State](#State), with `@parent` set to -the current [State](#State) by immutable identifier. +## Resource +Generic interface for collections of digital objects. -**Kind**: instance method of [Scribe](#Scribe) -**Overrides**: [fork](#State+fork) - +**Kind**: global class -### scribe.get(path) ⇒ Mixed -Retrieve a key from the [State](#State). +* [Resource](#Resource) + * [new Resource(definition)](#new_Resource_new) + * [.create(obj)](#Resource+create) ⇒ [Vector](#Vector) + * [.update(id, update)](#Resource+update) ⇒ [Vector](#Vector) -**Kind**: instance method of [Scribe](#Scribe) -**Overrides**: [get](#State+get) + + +### new Resource(definition) | Param | Type | Description | | --- | --- | --- | -| path | [Path](#Path) | Key to retrieve. | +| definition | Object | Initial parameters | - + -### scribe.set(path) ⇒ Mixed -Set a key in the [State](#State) to a particular value. +### resource.create(obj) ⇒ [Vector](#Vector) +Create an instance of the Resource's type. -**Kind**: instance method of [Scribe](#Scribe) -**Overrides**: [set](#State+set) +**Kind**: instance method of [Resource](#Resource) +**Returns**: [Vector](#Vector) - Resulting Vector with deterministic identifier. | Param | Type | Description | | --- | --- | --- | -| path | [Path](#Path) | Key to retrieve. | +| obj | Object | Map of the instance's properties and values. | - + -### scribe.commit() -Increment the vector clock, broadcast all changes as a transaction. +### resource.update(id, update) ⇒ [Vector](#Vector) +Modify an existing instance of a Resource by its unique identifier. Produces a new instance. -**Kind**: instance method of [Scribe](#Scribe) -**Overrides**: [commit](#State+commit) - +**Kind**: instance method of [Resource](#Resource) +**Returns**: [Vector](#Vector) - Resulting Vector instance with updated identifier. -### scribe.render() ⇒ String -Compose a JSON string for network consumption. +| Param | Type | Description | +| --- | --- | --- | +| id | String | Unique ID to update. | +| update | Object | Map of change to make (keys -> values). | -**Kind**: instance method of [Scribe](#Scribe) -**Overrides**: [render](#State+render) -**Returns**: String - JSON-encoded [String](String). ## Script @@ -3261,7 +1972,7 @@ Retrieve a key from the [State](#State). | Param | Type | Description | | --- | --- | --- | -| path | [Path](#Path) | Key to retrieve. | +| path | Path | Key to retrieve. | @@ -3272,7 +1983,7 @@ Set a key in the [State](#State) to a particular value. | Param | Type | Description | | --- | --- | --- | -| path | [Path](#Path) | Key to retrieve. | +| path | Path | Key to retrieve. | @@ -3811,7 +2522,7 @@ Retrieve a key from the [State](#State). | Param | Type | Description | | --- | --- | --- | -| path | [Path](#Path) | Key to retrieve. | +| path | Path | Key to retrieve. | @@ -3822,7 +2533,7 @@ Set a key in the [State](#State) to a particular value. | Param | Type | Description | | --- | --- | --- | -| path | [Path](#Path) | Key to retrieve. | +| path | Path | Key to retrieve. | @@ -3950,13 +2661,13 @@ Implicitly trust an [Event](Event) source. ### store.del(key) -Remove a [Value](#Value) by [Path](#Path). +Remove a [Value](#Value) by [Path](Path). **Kind**: instance method of [Store](#Store) | Param | Type | Description | | --- | --- | --- | -| key | [Path](#Path) | Key to remove. | +| key | Path | Key to remove. | @@ -3971,43 +2682,6 @@ Start running the process. **Kind**: instance method of [Store](#Store) **Returns**: Promise - Resolves on complete. - - -## Swap : Object -The [Swap](#Swap) contract executes a set of transactions on two distinct -[Chain](#Chain) components, utilizing a secret-reveal mechanism to atomically -execute either the full set or none. - -**Kind**: global class - -* [Swap](#Swap) : Object - * [new Swap([settings])](#new_Swap_new) - * [.extractSecret(tx, address)](#Swap+extractSecret) ⇒ Mixed - - - -### new Swap([settings]) -Atomically execute a set of transactions across two [Chain](#Chain) components. - - -| Param | Type | Default | Description | -| --- | --- | --- | --- | -| [settings] | Object | {} | Configuration for the swap. | - - - -### swap.extractSecret(tx, address) ⇒ Mixed -Find an input from the provided transaction which spends from the target -P2SH address. - -**Kind**: instance method of [Swap](#Swap) -**Returns**: Mixed - False on failure, secret value on success. - -| Param | Type | Description | -| --- | --- | --- | -| tx | Transaction | [Transaction](Transaction) to iterate over. | -| address | String | P2SH address to search for. | - ## Swarm : String @@ -4068,21 +2742,6 @@ Create a new Fabric Token. | --- | --- | --- | | [settings] | Object | Configuration. | - - -## Transition -The [Transition](#Transition) type reflects a change from one finite -[State](#State) to another. - -**Kind**: global class - - -### new Transition(settings) - -| Param | Type | Description | -| --- | --- | --- | -| settings | Object | Configuration for the transition object. | - ## Tree @@ -4382,7 +3041,7 @@ Create a crowdfunding transaction. ### wallet.\_getSwapInputScript(redeemScript, secret) -Generate [Script](#Script) for claiming a [Swap](#Swap). +Generate [Script](#Script) for claiming a [Swap](Swap). **Kind**: instance method of [Wallet](#Wallet) @@ -4394,7 +3053,7 @@ Generate [Script](#Script) for claiming a [Swap](#Swap). ### wallet.\_getRefundInputScript(redeemScript) -Generate [Script](#Script) for reclaiming funds commited to a [Swap](#Swap). +Generate [Script](#Script) for reclaiming funds commited to a [Swap](Swap). **Kind**: instance method of [Wallet](#Wallet) @@ -4740,7 +3399,7 @@ Retrieve a key from the [State](#State). | Param | Type | Description | | --- | --- | --- | -| path | [Path](#Path) | Key to retrieve. | +| path | Path | Key to retrieve. | @@ -4752,7 +3411,7 @@ Set a key in the [State](#State) to a particular value. | Param | Type | Description | | --- | --- | --- | -| path | [Path](#Path) | Key to retrieve. | +| path | Path | Key to retrieve. | @@ -4888,27 +3547,6 @@ Sends a message. | --- | --- | --- | | message | Mixed | Message to send. | - - -## Exchange -Implements a basic Exchange. - -**Kind**: global class - - -### new Exchange(settings) -Create an instance of the Exchange. You may run two instances at -once to simulate two-party contracts, or use the Fabric Market to -find and trade with real peers. - -**Returns**: Exchnge - -| Param | Type | Description | -| --- | --- | --- | -| settings | Object | Map of settings to values. | -| settings.fees | Object | Map of fee settings (all values in BTC). | -| settings.fees.minimum | Object | Minimum fee (satoshis). | - ## Lightning @@ -4946,7 +3584,7 @@ Make an RPC request through the Lightning UNIX socket. ## Redis -Connect and subscribe to ZeroMQ servers. +Connect and subscribe to Redis servers. **Kind**: global class @@ -4958,7 +3596,7 @@ Connect and subscribe to ZeroMQ servers. ### new Redis([settings]) -Creates an instance of a ZeroMQ subscriber. +Creates an instance of a Redis subscriber. **Returns**: [Redis](#Redis) - Instance of the Redis service, ready to run `start()` @@ -4966,7 +3604,7 @@ Creates an instance of a ZeroMQ subscriber. | --- | --- | --- | | [settings] | Object | Settings for the Redis connection. | | [settings.host] | String | Host for the Redis server. | -| [settings.port] | Number | Remote ZeroMQ service port. | +| [settings.port] | Number | Remote Redis service port. | @@ -5039,30 +3677,9 @@ Deprecated 2021-11-06. **Kind**: global class * ~~[Scribe](#Scribe)~~ - * [new Scribe(config)](#new_Scribe_new) * [.now()](#Scribe+now) ⇒ Number * [.trust(source)](#Scribe+trust) ⇒ [Scribe](#Scribe) * [.inherits(scribe)](#Scribe+inherits) ⇒ [Scribe](#Scribe) - * [.toHTML()](#State+toHTML) - * [.toString()](#State+toString) ⇒ String - * [.serialize([input])](#State+serialize) ⇒ Buffer - * [.deserialize(input)](#State+deserialize) ⇒ [State](#State) - * [.fork()](#State+fork) ⇒ [State](#State) - * [.get(path)](#State+get) ⇒ Mixed - * [.set(path)](#State+set) ⇒ Mixed - * [.commit()](#State+commit) - * [.render()](#State+render) ⇒ String - - - -### new Scribe(config) -The "Scribe" is a simple tag-based recordkeeper. - - -| Param | Type | Description | -| --- | --- | --- | -| config | Object | General configuration object. | -| config.verbose | Boolean | Should the Scribe be noisy? | @@ -5095,94 +3712,6 @@ Use an existing Scribe instance as a parent. | --- | --- | --- | | scribe | [Scribe](#Scribe) | Instance of Scribe to use as parent. | - - -### scribe.toHTML() -Converts the State to an HTML document. - -**Kind**: instance method of [Scribe](#Scribe) -**Overrides**: [toHTML](#State+toHTML) - - -### scribe.toString() ⇒ String -Unmarshall an existing state to an instance of a [Blob](Blob). - -**Kind**: instance method of [Scribe](#Scribe) -**Overrides**: [toString](#State+toString) -**Returns**: String - Serialized [Blob](Blob). - - -### scribe.serialize([input]) ⇒ Buffer -Convert to [Buffer](Buffer). - -**Kind**: instance method of [Scribe](#Scribe) -**Overrides**: [serialize](#State+serialize) -**Returns**: Buffer - [Store](#Store)-able blob. - -| Param | Type | Description | -| --- | --- | --- | -| [input] | Mixed | Input to serialize. | - - - -### scribe.deserialize(input) ⇒ [State](#State) -Take a hex-encoded input and convert to a [State](#State) object. - -**Kind**: instance method of [Scribe](#Scribe) -**Overrides**: [deserialize](#State+deserialize) -**Returns**: [State](#State) - [description] - -| Param | Type | Description | -| --- | --- | --- | -| input | String | [description] | - - - -### scribe.fork() ⇒ [State](#State) -Creates a new child [State](#State), with `@parent` set to -the current [State](#State) by immutable identifier. - -**Kind**: instance method of [Scribe](#Scribe) -**Overrides**: [fork](#State+fork) - - -### scribe.get(path) ⇒ Mixed -Retrieve a key from the [State](#State). - -**Kind**: instance method of [Scribe](#Scribe) -**Overrides**: [get](#State+get) - -| Param | Type | Description | -| --- | --- | --- | -| path | [Path](#Path) | Key to retrieve. | - - - -### scribe.set(path) ⇒ Mixed -Set a key in the [State](#State) to a particular value. - -**Kind**: instance method of [Scribe](#Scribe) -**Overrides**: [set](#State+set) - -| Param | Type | Description | -| --- | --- | --- | -| path | [Path](#Path) | Key to retrieve. | - - - -### scribe.commit() -Increment the vector clock, broadcast all changes as a transaction. - -**Kind**: instance method of [Scribe](#Scribe) -**Overrides**: [commit](#State+commit) - - -### scribe.render() ⇒ String -Compose a JSON string for network consumption. - -**Kind**: instance method of [Scribe](#Scribe) -**Overrides**: [render](#State+render) -**Returns**: String - JSON-encoded [String](String). ## ~~Stash~~ diff --git a/services/exchange.js b/services/exchange.js index 5da48961a..fa2df48e9 100644 --- a/services/exchange.js +++ b/services/exchange.js @@ -15,19 +15,7 @@ const Collection = require('../types/collection'); const Message = require('../types/message'); const Service = require('../types/service'); -/** - * Implements a basic Exchange. - */ class Exchange extends Service { - /** - * Create an instance of the Exchange. You may run two instances at - * once to simulate two-party contracts, or use the Fabric Market to - * find and trade with real peers. - * @param {Object} settings Map of settings to values. - * @param {Object} settings.fees Map of fee settings (all values in BTC). - * @param {Object} settings.fees.minimum Minimum fee (satoshis). - * @returns Exchnge - */ constructor (settings = {}) { super(settings); diff --git a/services/redis.js b/services/redis.js index 153b04e7c..e62d14d9d 100644 --- a/services/redis.js +++ b/services/redis.js @@ -5,14 +5,14 @@ const Service = require('../types/service'); const Message = require('../types/message'); /** - * Connect and subscribe to ZeroMQ servers. + * Connect and subscribe to Redis servers. */ class Redis extends Service { /** - * Creates an instance of a ZeroMQ subscriber. + * Creates an instance of a Redis subscriber. * @param {Object} [settings] Settings for the Redis connection. * @param {String} [settings.host] Host for the Redis server. - * @param {Number} [settings.port] Remote ZeroMQ service port. + * @param {Number} [settings.port] Remote Redis service port. * @returns {Redis} Instance of the Redis service, ready to run `start()` */ constructor (settings = {}) { diff --git a/types/aggregator.js b/types/aggregator.js index 7eb7efec7..3a0c22d5e 100644 --- a/types/aggregator.js +++ b/types/aggregator.js @@ -8,16 +8,7 @@ const Service = require('./service'); const Actor = require('./actor'); const Tree = require('./tree'); -/** - * Aggregates a set of balances (inputs). - */ class Aggregator extends Service { - /** - * Create a new Aggregator. - * @param {Object} [settings] Map of configuration values. - * @param {Array} [settings.inputs] Array of {@link AnchorBalance} instances. - * @returns {Aggregator} Instance of the {@link Aggregator}. - */ constructor (settings = {}) { super(settings); diff --git a/types/app.js b/types/app.js index 800f2ef7f..bcd1176d8 100644 --- a/types/app.js +++ b/types/app.js @@ -15,20 +15,7 @@ const Service = require('./service'); const Storage = require('./store'); // const Swarm = require('./swarm'); -/** - * Web-friendly application framework for building single-page applications with - * Fabric-based networking and storage. - * @extends Service - * @property {Collection} components Interface elements. - * @property {Store} stash Routable {@link Datastore}. - */ -// class App extends Scribe { class App extends Service { - /** - * Generic bundle for building Fabric applications. - * @param {Object} definition Application definition. See `config` for examples. - * @return {App} Returns an instance of `App`. - */ constructor (definition = {}) { super(definition); diff --git a/types/circuit.js b/types/circuit.js index e7eb64953..946fd25ee 100644 --- a/types/circuit.js +++ b/types/circuit.js @@ -14,7 +14,7 @@ const Actor = require('./actor'); * The {@link Circuit} is the mechanism through which {@link Fabric} * operates, a computable directed graph describing a network of * {@link Peer} components and their interactions (side effects). - * See also {@link Swarm} for deeper *inspection of {@link Machine} + * See also {@link Swarm} for deeper inspection of {@link Machine} * mechanics. */ class Circuit extends Actor { diff --git a/types/compiler.js b/types/compiler.js index d20abe0a6..949682a14 100644 --- a/types/compiler.js +++ b/types/compiler.js @@ -45,19 +45,7 @@ const Machine = require('./machine'); // ``` // This will auto-configure validation base from chain of greatest work. -/** - * Compilers build interfaces for users of Fabric applications. - * @type {Actor} - * @property {AST} ast Compiler's current AST. - * @property {Entity} entity Compiler's current {@link Entity}. - */ class Compiler { - /** - * Create a new Compiler. - * @param {Object} settings={} Configuration. - * @param {Buffer} settings.body Body of the input program to compile. - * @return {Compiler} Instance of the compiler. - */ constructor (settings = {}) { this.settings = Object.assign({ ast: null, diff --git a/types/consensus.js b/types/consensus.js index 7bd0edd84..706cae448 100644 --- a/types/consensus.js +++ b/types/consensus.js @@ -7,16 +7,7 @@ // For node... const bcoin = require('bcoin'); -/** - * Provides various network-specific rules. - */ class Consensus { - /** - * Create an instance of a {@link Consensus} verifier. - * @param {Object} [settings] Configuration for the network. - * @param {String} [settings.network] Name of the network. - * @param {String} [settings.provider] Name of the source provider. - */ constructor (settings = {}) { this.settings = Object.assign({ network: 'mainnet', diff --git a/types/entity.js b/types/entity.js index 9901612a6..ebc4b2ab9 100644 --- a/types/entity.js +++ b/types/entity.js @@ -3,16 +3,7 @@ const crypto = require('crypto'); const { EventEmitter } = require('events'); -/** - * Live instance of an ARC in Fabric. - * @type {Object} - */ class Entity extends EventEmitter { - /** - * Generic template for virtual objects. - * @param {Object} [data={}] Pass an object to use. - * @return {Entity} Instance of the {@link Entity}. - */ constructor (data = {}) { super(data); diff --git a/types/keystore.js b/types/keystore.js index 9c387a47a..08a49a121 100644 --- a/types/keystore.js +++ b/types/keystore.js @@ -13,16 +13,7 @@ const Message = require('./message'); const Tree = require('./tree'); const Key = require('./key'); -/** - * Provides an encrypted datastore for generic object storage. - */ class Keystore extends Actor { - /** - * Create an instance of the Store. - * @param {FabricStoreConfiguration} [configuration] Settings to use. - * @param {String} [configuration.name="DefaultStore"] Name of the Store. - * @returns {Keystore} Instance of the store. - */ constructor (settings = {}) { super(settings); if (!settings.seed) settings.seed = (process) ? process.env.FABRIC_SEED || null : null; diff --git a/types/mempool.js b/types/mempool.js index 7d592e2c5..60a6d57b4 100644 --- a/types/mempool.js +++ b/types/mempool.js @@ -5,15 +5,7 @@ const Service = require('./service'); const Collection = require('./collection'); const Transaction = require('./transaction'); -/** - * Stores a list of {@link Transaction} elements. - * @emits {Message} confirmed Emitted when the Mempool has dropped a transaction. - */ class Mempool extends Service { - /** - * Creates an instance of a {@link Mempool} {@link Service}. - * @param {Object} settings Map of settings to utilize. - */ constructor (settings = {}) { super(settings); diff --git a/types/node.js b/types/node.js index 3a96f92a9..edaf2b568 100644 --- a/types/node.js +++ b/types/node.js @@ -13,15 +13,7 @@ const Service = require('../types/service'); const Environment = require('../types/environment'); const environment = new Environment(); -/** - * Full definition of a Fabric node. - */ class Node extends Service { - /** - * Manage a Fabric service. - * @param {Object} settings Configuration for the node. - * @returns {Node} Instance of the managed service. - */ constructor (settings = {}) { super(settings); diff --git a/types/oracle.js b/types/oracle.js index 11afdfd21..3ae03182f 100644 --- a/types/oracle.js +++ b/types/oracle.js @@ -4,16 +4,7 @@ const Machine = require('./machine'); const Resource = require('./resource'); const Store = require('./store'); -/** - * An Oracle manages one or more collections, using a mempool for - * transitive state. - * @extends Store - */ class Oracle extends Store { - /** - * Trusted point-of-reference for external services. - * @param {Object} initial - Initialization vector. - */ constructor (init) { super(init); diff --git a/types/path.js b/types/path.js index 724637d51..e276cbdda 100644 --- a/types/path.js +++ b/types/path.js @@ -1,14 +1,6 @@ 'use strict'; -/** - * A {@link Path} is a {@link Fabric}-native link to a {@link Document} - * within the network. - */ class Path extends String { - /** - * Create a new {@link Path}. - * @param {String|Object} input Named path. - */ constructor (input = {}) { super(input); @@ -31,4 +23,4 @@ class Path extends String { } } -module.exports = Path; \ No newline at end of file +module.exports = Path; diff --git a/types/router.js b/types/router.js index 31eb2b43e..efd0ecadb 100644 --- a/types/router.js +++ b/types/router.js @@ -6,15 +6,7 @@ const Scribe = require('./scribe'); // Current code is specific to @fabric/doorman — should be a general- // purpose Router, not for strings and triggers in chat messages. -/** - * Process incoming messages. - * @extends Scribe - */ class Router extends Scribe { - /** - * Maintains a list of triggers ("commands") and their behaviors. - * @param {Object} map Map of command names => behaviors. - */ constructor (config) { super(config); diff --git a/types/scribe.js b/types/scribe.js index b66f53f3e..d91580be3 100644 --- a/types/scribe.js +++ b/types/scribe.js @@ -5,17 +5,7 @@ const crypto = require('crypto'); // Fabric Components const State = require('./state'); -/** - * Simple tag-based recordkeeper. - * @extends State - * @property {Object} config Current configuration. - */ class Scribe extends State { - /** - * The "Scribe" is a simple tag-based recordkeeper. - * @param {Object} config General configuration object. - * @param {Boolean} config.verbose Should the Scribe be noisy? - */ constructor (config = {}) { super(config); diff --git a/types/swap.js b/types/swap.js index 519f1110d..126272d20 100644 --- a/types/swap.js +++ b/types/swap.js @@ -8,17 +8,7 @@ const bcoin = require('bcoin'); // Native Dependencies const crypto = require('crypto'); -/** - * The {@link Swap} contract executes a set of transactions on two distinct - * {@link Chain} components, utilizing a secret-reveal mechanism to atomically - * execute either the full set or none. - * @type {Object} - */ class Swap { - /** - * Atomically execute a set of transactions across two {@link Chain} components. - * @param {Object} [settings={}] Configuration for the swap. - */ constructor (settings = {}) { this.settings = Object.assign({ chain: 'bitcoin:regtest' diff --git a/types/transition.js b/types/transition.js index 0c833c5bd..21eb26f75 100644 --- a/types/transition.js +++ b/types/transition.js @@ -9,15 +9,7 @@ const EncryptedPromise = require('./promise'); const Entity = require('./entity'); const Witness = require('./witness'); -/** - * The {@link Transition} type reflects a change from one finite - * {@link State} to another. - */ class Transition extends Entity { - /** - * - * @param {Object} settings Configuration for the transition object. - */ constructor (settings = {}) { super(settings);