Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/textileio/js-examples
Examples and demos using Textile's Javascript/Typescript libraries and clients.
https://github.com/textileio/js-examples
Last synced: 12 days ago
JSON representation
Examples and demos using Textile's Javascript/Typescript libraries and clients.
- Host: GitHub
- URL: https://github.com/textileio/js-examples
- Owner: textileio
- License: mit
- Created: 2020-04-20T21:10:37.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2021-05-07T13:12:09.000Z (over 3 years ago)
- Last Synced: 2024-09-04T00:06:40.744Z (3 months ago)
- Language: TypeScript
- Size: 2.32 MB
- Stars: 60
- Watchers: 5
- Forks: 29
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# js-examples
All code here is used as reference in the main documentation page, [docs.textile.io](https://docs.textile.io).
## Issues & Support
Please open all issues on [textileio/js-textile](https://github.com/textileio/js-textile/issues) and the name or link to the specific example you are debugging.
## Use
You can find each stand-alone example in each of the subdirectories.
**Note**
The chat demo, hub-threaddb-chat, has been temporarily deprecated until we complete the [threads refactor](https://github.com/textileio/js-threads/issues/414) project.
> Examples and demos using Textile's Javascript/Typescript libraries and clients.
### bucket-photo-gallery - setup user buckets to hold files
This example users non-signing keys for development mode. Here, you'll create a new user and then give them an interface to upload files to their own bucket.
You can read about key generation here: https://docs.textile.io/hub/apis/.
Next, you will need to update the example to use your Hub API key, https://github.com/textileio/js-examples/blob/master/bucket-photo-gallery/src/App.tsx#L19.
Note: you will want to use a signing key if you use this example for a production application. Read more about that process here, https://docs.textile.io/tutorials/hub/production-auth/.
#### Build & serve
Change directories into the `bucket-photo-galleries` repo.
```bash
npm run start
```Your browser should automatically launch to the app running on [localhost:3001](http://localhost:3001).
### hub-browser-auth-app - shows the full client/server setup to using signed api keys
This example includes two Typescript projects. A server in `src/server` and a client in `src/client`. The example demonstrates how to use the [Textile Hub](https://docs.textile.io/) APIs from the Browser using user identities and **user group keys**.
Read the full tutorial accompanying this example on [docs.textile.io](https://docs.textile.io).
To run, you need to first copy the `example.env` folder to `.env`. Next, you need to update the key and secret fields with values you create using the Hub CLI.
#### WARNING
_Do not share any API Key Secrets. This includes User Group Key secret and Account key Secrets. Be sure you never commit them into public repos or share them in published apps._
#### Configure
Create a `.env` file in the root of your project. Ensure you never check this file into your repo or share it, it contains your User Group Key Secret.
```bash
cp example.env .env
```Then replace the `USER_API_KEY` and `USER_API_SECRET` values with those you create using the Textile Hub and your own account or org (see [docs.textile.io](https://docs.textile.io) for details).
#### Setup
```bash
npm install
```#### Clean
```bash
npm run clean
```#### Run basic auth client
In this example, you can see how to create a basic user auth flow:
* the user is defined by a simple keypair created in the browser on demand.
* the user is then granted access to the developer's hub resources through the use of API keys.
* the user can then access their own thread APIs to begin creating threads and buckets.The client code is available in `src/basic`.
#### Build & serve
You can run the server and client in development mode by opening two terminal windows.
**Terminal 1: watch the client code**
```bash
npm run dev:client
```**Terminal 2: start the dev server**
```bash
npm run start:server
```You can now view the example at [localhost:3001](http://localhost:3001).
### user-mailbox-setup - demonstrates how to setup the user mailbox api
This example uses a hard-coded PrivateKey as your first user's identity. It then uses the User API to enable the user's mailbox. Instead of setting up a second user, it will just send messages from the user to themselves.
To use this example, you must create a Hub API key and update the code to use it.
### react-native-hub-app - demonstrates both bucket and thread functionality in react native
Like many of the examples, start by copying `example.env` to `.env` and filling our key and secret values from your own Hub account.
The example, when run, will go through a series of examples that set up user identity, threads, and then buckets with the Textile Hub.
### metamask-identities-ed25519 - a password based privatekey generation workflow for textile identities
This example will use a user's Ethereum address and signing API from Metamask to create a new ed25519 private key identity. It does this in combination with a user supplied password. Your app never needs to store the password or private key, as the user can regenerate them at any time.
You can use the identity created with any example above, your own apps, and with any Textile API for your user identities.
### 3box-identities-ed25519
Similar to the above example, this example uses 3Box to derive the private key based on the user's ethereum account. It uses the box api to store the private key value on 3Box's server so it can be fetched at a future time.
You can use the identity created with any example above, your own apps, and with any Textile API for your user identities.