diff --git a/README.md b/README.md index 4a750d3..9969968 100644 --- a/README.md +++ b/README.md @@ -29,7 +29,6 @@ Docs can be accessed at [Docs Link](https://eclipse-zenoh.github.io/zenoh-ts/) > :warning: **WARNING** :warning: : Zenoh and its ecosystem are under active development. When you build from git, make sure you also build from git any other Zenoh repository you plan to use (e.g. binding, plugin, backend, etc.). It may happen that some changes in git are not compatible with the most recent packaged Zenoh release (e.g. deb, docker, pip). We put particular effort in maintaining compatibility between the various git repositories in the Zenoh project. - ## Executing the `zenohd` with `zenoh-plugin-remote-api` plugin The `zenohd` router and its pluigns should be built with the same zenoh sources and the same version of rust compiler with the same set of features. @@ -65,7 +64,7 @@ Therefore one of these methods is recommended: Expected output for is like: - ``` + ```txt zenohd: zenohd v1.0.3 built with rustc 1.75.0 (82e1608df 2023-12-21) zenoh::net::runtime: Using ZID: f7bc54e0941036422ec08ebac6fbdb40 zenoh::api::loader: Loading plugin "remote_api" @@ -75,7 +74,7 @@ Therefore one of these methods is recommended: zenoh::net::runtime::orchestrator: Zenoh can be reached at: tcp/.... ``` -2. Build the plugin and the router from the sources: +1. Build the plugin and the router from the sources: Build the `zenoh-plugin-remote-api` @@ -84,22 +83,16 @@ Therefore one of these methods is recommended: ``` Build and run the zenohd from the same sources which were used for the plugin. - The zenohd dependency is specified in `[workspace.metadata.bin]` section in Cargo.toml and processed by the 3-rd party tool https://crates.io/crates/cargo-run-bin. + The zenohd dependency is specified in `[workspace.metadata.bin]` section in Cargo.toml and processed by the 3-rd party tool [cargo-run-bin](https://crates.io/crates/cargo-run-bin). ```sh cargo install cargo-run-bin - cargo bin -i zenohd - ``` - - Use this command to run local zenoh router version - - ```sh cargo bin zenohd --config EXAMPLE_CONFIG.json5 ``` Expected output is like: - ``` + ```txt zenohd: zenohd vc764bf9b built with rustc 1.75.0 (82e1608df 2023-12-21) zenoh::net::runtime: Using ZID: bb3fb16628f57e92f92accf2f5c81511 zenoh::api::loader: Loading plugin "remote_api" @@ -109,68 +102,56 @@ Therefore one of these methods is recommended: zenoh::net::runtime::orchestrator: Zenoh can be reached at: ... ``` - ## Building the Typescript project 1. Make sure that the following utilities are available on your platform. - - [NPM](https://www.npmjs.com/package/npm) - - [yarn](https://classic.yarnpkg.com/lang/en/docs/install/#debian-stable) - - [Typescript](https://www.typescriptlang.org/download/) -2. Navigate to the directory `zenoh-ts` +- [NPM](https://www.npmjs.com/package/npm) +- [yarn](https://classic.yarnpkg.com/lang/en/docs/install/#debian-stable) +- [Typescript](https://www.typescriptlang.org/download/) + +1. Navigate to the directory `zenoh-ts` -3. Run the commands: +1. Run the commands: -```bash - yarn install - # - yarn run build +```sh +yarn install +yarn run build ``` -## Building the Rust Plugin +## Build and run the command line examples -1. Make sure that the following utilities are available on your platform. - - [Cargo + Rust Compiler](https://rustup.rs/) - -2. Navigate to `zenoh-plugin-remote-api` - -3. Run `cargo build` - -## **Examples of usage** - -### Running the Rust Plugin - -Prerequisites: - - You have a zenoh router (`zenohd`) installed, and the `zenoh_plugin_remote_api` library file is available in `~/.zenoh/lib`. - -### **Setup via a JSON5 configuration file** - - - Create a `zenoh.json5` configuration file containing for example: - ```json5 - { - plugins: { - // configuration of "storage_manager" plugin: - remote_api: { - "websocket_port": "10000", - // secure_websocket configuration is optional - "secure_websocket": { - "certificate_path" : "/path/to/certificate", - "private_key_path" : "/path/to/private_key" - } - } - // Optionally, add the REST plugin - rest: { http_port: 8000 } - } - } - ``` - - Run the zenoh router with: - `zenohd -c zenoh.json5` +This library is currently compatible with browsers, but not with NodeJS due to websocket library limitations. +To run the command line examples use javascript runtime [deno](https://deno.com/) which is expected be consistent with the browser. + +1. Install [deno](https://deno.com/) +1. Navigate to the `zenoh-ts/examples/deno` directory +1. Install `zenoh-ts` library by running `yarn install` +1. Run zenohd with remote_api plugin, configured to websocket port 10000, as described above +1. Run the examples by running `yarn example `, i.e. `yarn example src/z_sub.ts` + +E.g. in different sessions run publisher and subcriber examples: + +```sh +yarn example src/pub.rs +``` + +```sh +yarn example src/sub.rs +``` + +The subscriber should start to receive messages from publisher + +This will start an instance of Deno running the example. +The application will attempt to connect to a `websocket_port` : `10000` where the Remote API plugin is expected to be running. ## Adding Typescript to your application The TypeScript library can be install from the command line: -`npm install @eclipse-zenoh/zenoh-ts@0.0.8` +```sh +npm install @eclipse-zenoh/zenoh-ts@0.0.8 +```` Or added via package.json diff --git a/zenoh-ts/examples/README.md b/zenoh-ts/examples/deno/README.md similarity index 100% rename from zenoh-ts/examples/README.md rename to zenoh-ts/examples/deno/README.md diff --git a/zenoh-ts/examples/package.json b/zenoh-ts/examples/deno/package.json similarity index 83% rename from zenoh-ts/examples/package.json rename to zenoh-ts/examples/deno/package.json index 35b6e81..3aab911 100644 --- a/zenoh-ts/examples/package.json +++ b/zenoh-ts/examples/deno/package.json @@ -3,6 +3,7 @@ "private": false, "version": "0.0.0", "type": "module", + "license": "EPL-2.0", "scripts": { "build": "tsc", "clean": "rm -rf ./node_modules ./dist ./esm", @@ -13,6 +14,6 @@ "typescript": "^5.2.2" }, "dependencies": { - "@eclipse-zenoh/zenoh-ts": "file:.." + "@eclipse-zenoh/zenoh-ts": "file:../.." } } diff --git a/zenoh-ts/examples/src/z_delete.ts b/zenoh-ts/examples/deno/src/z_delete.ts similarity index 100% rename from zenoh-ts/examples/src/z_delete.ts rename to zenoh-ts/examples/deno/src/z_delete.ts diff --git a/zenoh-ts/examples/src/z_get.ts b/zenoh-ts/examples/deno/src/z_get.ts similarity index 100% rename from zenoh-ts/examples/src/z_get.ts rename to zenoh-ts/examples/deno/src/z_get.ts diff --git a/zenoh-ts/examples/src/z_get_liveliness.ts b/zenoh-ts/examples/deno/src/z_get_liveliness.ts similarity index 100% rename from zenoh-ts/examples/src/z_get_liveliness.ts rename to zenoh-ts/examples/deno/src/z_get_liveliness.ts diff --git a/zenoh-ts/examples/src/z_liveliness.ts b/zenoh-ts/examples/deno/src/z_liveliness.ts similarity index 100% rename from zenoh-ts/examples/src/z_liveliness.ts rename to zenoh-ts/examples/deno/src/z_liveliness.ts diff --git a/zenoh-ts/examples/src/z_ping.ts b/zenoh-ts/examples/deno/src/z_ping.ts similarity index 100% rename from zenoh-ts/examples/src/z_ping.ts rename to zenoh-ts/examples/deno/src/z_ping.ts diff --git a/zenoh-ts/examples/src/z_pong.ts b/zenoh-ts/examples/deno/src/z_pong.ts similarity index 100% rename from zenoh-ts/examples/src/z_pong.ts rename to zenoh-ts/examples/deno/src/z_pong.ts diff --git a/zenoh-ts/examples/src/z_pub.ts b/zenoh-ts/examples/deno/src/z_pub.ts similarity index 100% rename from zenoh-ts/examples/src/z_pub.ts rename to zenoh-ts/examples/deno/src/z_pub.ts diff --git a/zenoh-ts/examples/src/z_put.ts b/zenoh-ts/examples/deno/src/z_put.ts similarity index 100% rename from zenoh-ts/examples/src/z_put.ts rename to zenoh-ts/examples/deno/src/z_put.ts diff --git a/zenoh-ts/examples/src/z_queryable.ts b/zenoh-ts/examples/deno/src/z_queryable.ts similarity index 100% rename from zenoh-ts/examples/src/z_queryable.ts rename to zenoh-ts/examples/deno/src/z_queryable.ts diff --git a/zenoh-ts/examples/src/z_sub.ts b/zenoh-ts/examples/deno/src/z_sub.ts similarity index 100% rename from zenoh-ts/examples/src/z_sub.ts rename to zenoh-ts/examples/deno/src/z_sub.ts diff --git a/zenoh-ts/examples/src/z_sub_liveliness.ts b/zenoh-ts/examples/deno/src/z_sub_liveliness.ts similarity index 100% rename from zenoh-ts/examples/src/z_sub_liveliness.ts rename to zenoh-ts/examples/deno/src/z_sub_liveliness.ts diff --git a/zenoh-ts/examples/src/z_sub_thr.ts b/zenoh-ts/examples/deno/src/z_sub_thr.ts similarity index 100% rename from zenoh-ts/examples/src/z_sub_thr.ts rename to zenoh-ts/examples/deno/src/z_sub_thr.ts diff --git a/zenoh-ts/examples/tsconfig.json b/zenoh-ts/examples/deno/tsconfig.json similarity index 100% rename from zenoh-ts/examples/tsconfig.json rename to zenoh-ts/examples/deno/tsconfig.json diff --git a/zenoh-ts/examples/yarn.lock b/zenoh-ts/examples/deno/yarn.lock similarity index 99% rename from zenoh-ts/examples/yarn.lock rename to zenoh-ts/examples/deno/yarn.lock index 8580915..661e86b 100644 --- a/zenoh-ts/examples/yarn.lock +++ b/zenoh-ts/examples/deno/yarn.lock @@ -2,8 +2,8 @@ # yarn lockfile v1 -"@eclipse-zenoh/zenoh-ts@file:..": - version "1.0.0-dev" +"@eclipse-zenoh/zenoh-ts@file:../..": + version "1.0.3" dependencies: base64-arraybuffer "^1.0.2" channel-ts "^0.1.2" diff --git a/zenoh-ts/package.json b/zenoh-ts/package.json index 5a788b1..3edbab6 100644 --- a/zenoh-ts/package.json +++ b/zenoh-ts/package.json @@ -50,5 +50,6 @@ "keywords": [ "networking" ], - "author": "Charles Schleich" + "author": "Charles Schleich", + "packageManager": "yarn@1.22.22+sha512.a6b2f7906b721bba3d67d4aff083df04dad64c399707841b7acf00f6b133b7ac24255f2652fa22ae3534329dc6180534e98d17432037ff6fd140556e2bb3137e" }