slate/README.md

125 lines
4.3 KiB
Markdown
Raw Normal View History

2020-09-07 06:42:51 +03:00
![Slate](https://user-images.githubusercontent.com/310223/92346209-e368d580-f080-11ea-8693-0fb64f8d3b97.jpg)
2020-07-21 22:18:58 +03:00
# Slate
2020-07-01 03:31:48 +03:00
2020-09-07 06:42:51 +03:00
### An open source storage system for your data that makes it easy to collect, organize, and share them anywhere on the web.
2020-02-19 09:30:47 +03:00
2020-09-07 06:42:51 +03:00
- [Create an account and try it out!](https://slate.host)
- [Filecoin](https://filecoin.io)
- [Textile](https://textile.io)
- [Twitter](https://twitter.com/_slate)
2020-07-23 08:00:38 +03:00
2020-08-24 00:53:44 +03:00
### Introduction
2020-09-07 06:42:51 +03:00
![Slate Preview](https://user-images.githubusercontent.com/310223/92346093-94bb3b80-f080-11ea-8ac6-c4cce3cd1aec.gif)
2020-09-04 21:37:18 +03:00
Slate is the first open source file storage application designed to encourage collaboration and research across a distributed network. It is a first step towards enabling a thriving network for data storage and transactions powered by IPFS, Filecoin and Textile that is open and usable for everyone. Our goal is to provide a meaningful story for every feature the protocol provides today and in the future. The Slate Project is the byproduct of a growing community of contributors from around the world.
2020-09-04 21:37:18 +03:00
Slate is tightly scoped for the present and more broadly thought out for the future. Our primary objective is to create a best-in-class experience for uploading, collecting, and sharing media. Additional filetypes will be supported, but our focus is to start with the pieces that apply to everyone and then dial into more specific formats.
2020-09-07 06:42:51 +03:00
- Example slate: https://slate.host/tara/loom
- Example user profile: https://slate.host/gndclouds
- New brand: https://slate.host/narative/slate-brand-identity
2020-09-04 21:37:18 +03:00
- Monet on Filecoin: https://slate.host/slate/monet
2020-09-07 06:42:51 +03:00
[Create an account and try it out!](https://slate.host/_)
2020-09-04 21:37:18 +03:00
2020-09-07 06:42:51 +03:00
# Get involved
2020-10-24 23:05:46 +03:00
Slate is built by a growing community of collaborators and contributors. Wed love for you to join us!
2020-09-07 06:42:51 +03:00
How?
2020-09-07 06:42:51 +03:00
- Find something you want to work on and [file an issue](https://github.com/filecoin-project/slate/issues).
- If you see something you want to fix or change, **submit a PR**.
- Reach out at any time. We're always available on Twitter to answer your questions: [@\_slate](https://www.twitter.com/_slate).
2020-09-07 06:42:51 +03:00
## Slate Development Guide
2020-07-01 03:31:48 +03:00
2020-07-29 09:03:23 +03:00
- To work on Slate you must have an internet connection.
- We don't have windows support at the moment.
2020-07-17 09:29:25 +03:00
2020-11-01 00:19:46 +03:00
### Clone this repo
Working on Slate starts by cloning the repo :)
```sh
git clone https://github.com/filecoin-project/slate.git
cd slate
```
2020-07-17 09:29:25 +03:00
### .env
2020-11-01 00:19:46 +03:00
You must create a `.env` file if you want to work on the service.
- You must setup your own postgres or hosted postgres.
- You must have your own Textile hub account setup
- You will have to run 3 other servers manually until we automate.
2020-07-17 09:29:25 +03:00
```
POSTGRES_ADMIN_PASSWORD=XXX
POSTGRES_ADMIN_USERNAME=XXX
POSTGRES_HOSTNAME=XXX
POSTGRES_DATABASE=XXX
2020-07-17 13:32:10 +03:00
LOCAL_PASSWORD_SECRET=XXX
2020-08-12 11:23:37 +03:00
LOCAL_PASSWORD_ROUNDS_MANUAL=5
LOCAL_PASSWORD_ROUNDS=14
2020-07-20 05:27:31 +03:00
TEXTILE_HUB_KEY=XXX
TEXTILE_HUB_SECRET=XXX
JWT_SECRET=XXX
2020-10-29 21:39:40 +03:00
ALLOWED_HOST=localhost:1337
PUBSUB_SECRET=pKLO4lbzdMrhAFKwPo9bnmq03bxQrtu3
RESOURCE_URI_UPLOAD=http://localhost:4242
RESOURCE_URI_STORAGE_UPLOAD=http://localhost:4242
RESOURCE_URI_PUBSUB=ws://localhost:6464
2020-10-31 02:12:20 +03:00
RESOURCE_URI_SEARCH=http://localhost:1313
2020-07-17 09:29:25 +03:00
```
2020-06-17 10:44:20 +03:00
### Setup pubsub server
- In another terminal window, clone https://github.com/slate-engineering/fiji
2020-11-01 00:19:46 +03:00
- Use the same `.env` secret values as the root server.
### Setup file upload server
- In another terminal window, clone https://github.com/slate-engineering/shovel
2020-11-01 00:19:46 +03:00
- Use the same `.env` secret values as the root server.
### Setup search server
- In another terminal window, clone https://github.com/slate-engineering/lens
- Use the same `.env` secret values as the root server.
2020-07-02 14:04:03 +03:00
### Install and run
```sh
npm install
npm run dev
```
2020-07-23 08:00:38 +03:00
- Visit `localhost:1337` in a browser.
- You should have 3 terminal screens open unless you don't want real time updates and file upload support.
2020-10-23 23:25:10 +03:00
## Design System
2020-10-23 23:25:10 +03:00
Our design system is out of date and could use an update.
2020-10-23 23:25:10 +03:00
- [Use our components](https://slate.host/_/system)
2020-10-24 23:05:46 +03:00
- [Design System Release Repository](https://github.com/filecoin-project/slate-react-system)
2020-11-01 00:20:29 +03:00
## Developer API
Slate has a Developer API that allows you upload files using code and HTTP.
Every user who creates an account on Slate can use the API. Here is an example:
```js
const response = await fetch("https://slate.host/api/v1/get", {
method: "POST",
headers: {
"Content-Type": "application/json",
Authorization: "Basic XXX-YOUR-SLATE-KEY-XXX",
},
});
```