spee.ch/README.md

187 lines
8.4 KiB
Markdown
Raw Normal View History

2018-02-24 03:07:28 +01:00
# Spee.ch
2018-10-29 22:23:51 +01:00
Spee.ch is a web app that reads and publishes images and videos to and from the [LBRY](https://lbry.io/) blockchain. You are encouraged to contribute to the shared code base, or fork it and make it your own.
2018-08-01 19:38:00 +02:00
2018-10-29 22:23:51 +01:00
You can create your own custom version of spee.ch by installing this code base and then creating your own custom components and styles to override the defaults. (More details/guide on how to do that coming soon.)
2017-03-29 19:28:35 +02:00
## Quickstart
### Ubuntu
[Ubuntu VPS Setup](./docs/ubuntu16vpspersonal.md)
2018-11-10 01:17:31 +01:00
_Note: This is our new setup. For our old setup see the [fullstart guide](./fullstart.md)._
2018-08-10 00:39:32 +02:00
#### System Dependencies:
2018-08-10 00:46:11 +02:00
* [node](https://nodejs.org)
* [MySQL](https://dev.mysql.com/doc/refman/8.0/en/installing.html)
2018-08-10 00:46:11 +02:00
* [`lbry`](https://github.com/lbryio/lbry) daemon
2018-10-29 22:23:51 +01:00
* note: retrieve an address from the daemon and send your wallet a few credits (or join us in the [#speech discord channel](https://discord.gg/YjYbwhS) and we will send you a few)
* [FFmpeg](https://www.ffmpeg.org/download.html)
2018-10-29 22:23:51 +01:00
#### Customize your app
2018-08-10 01:12:02 +02:00
2018-10-29 22:23:51 +01:00
Check out the [customization guide](https://github.com/lbryio/spee.ch/blob/readme-update/customize.md) to change your app's appearance and components
2018-08-01 19:25:35 +02:00
2018-08-10 00:50:51 +02:00
#### (optional) add custom components and update the styles
2018-08-01 19:25:35 +02:00
2018-10-29 22:23:51 +01:00
* Create custom components by creating React components in `src/views/` (further instructions coming soon)
* Update the CSS by changing the files in `public/assets/css/` (further instructions and refactor coming soon)
2018-08-01 19:25:35 +02:00
2018-08-10 00:50:51 +02:00
#### (optional) Syncing the full blockchain
2018-08-10 00:39:32 +02:00
* Start the `spee.ch-sync` tool available at [billbitt/spee.ch-sync](https://github.com/billbitt/spee.ch-sync)
* This is not necessary, but highly recommended. It will decode the blocks of the `LBRY` blockchain and add the claims information to your database's tables
2017-06-27 00:16:46 +02:00
## API
2018-08-11 00:22:02 +02:00
#### /api/claim/publish
method: `POST`
2018-08-11 00:13:35 +02:00
example:
```
curl -F 'name=MyPictureName' -F 'file=@/path/to/myPicture.jpeg' https://spee.ch/api/claim/publish
```
Parameters:
* `name` (required)
* `file` (required) (must be type .mp4, .jpeg, .jpg, .gif, or .png)
* `nsfw` (optional)
* `license` (optional)
* `title` (optional)
* `description` (optional)
2018-10-29 22:23:51 +01:00
* `thumbnail` URL to thumbnail image, for .mp4 uploads only (optional)
2018-08-11 00:13:35 +02:00
* `channelName` channel to publish too (optional)
* `channelPassword` password for channel to publish too (optional, but required if `channelName` is provided)
response:
```
{
"success": <bool>,
"message": <string>,
"data": {
"name": <string>,
"claimId": <string>,
"url": <string>,
"showUrl": <string>,
"serveUrl": <string>,
"lbryTx": {
"claim_address": <string>,
"claim_id": <string>,
"fee": <number>,
"nout": <number>,
"tx": <string>,
"value": <number>
}
}
}
```
2018-10-29 22:23:51 +01:00
#### /api/claim/availability/:name
2018-08-11 00:22:02 +02:00
method: `GET`
2018-10-29 22:23:51 +01:00
example:
2018-08-11 00:13:35 +02:00
```
curl https://spee.ch/api/claim/availability/doitlive
```
response:
```
{
"success": <bool>, // `true` if spee.ch successfully checked the claim availability
"data": <bool>, // `true` if claim is available, false if it is not available
"message": <string> // human readable message of whether claim was available or not
}
```
2018-08-11 00:13:35 +02:00
## Contribute
2018-04-17 21:57:53 +02:00
### Stack
The spee.ch stack is MySQL, Express.js, Node.js, and React.js. Spee.ch also runs `lbrynet` on its server, and it uses the `lbrynet` API to make requests -- such as `publish`, `create_channel`, and `get` -- on the `LBRY` network.
2018-10-29 22:23:51 +01:00
Spee.ch also runs a sync tool, which decodes blocks from the `LBRY` blockchain as they are mined, and stores the information in MySQL. It stores all claims in the `Claims` table, and all channel claims in the `Certificates` table.
2018-08-01 19:38:00 +02:00
2018-07-27 21:39:09 +02:00
* server
* [MySQL](https://www.mysql.com/)
2018-10-29 22:23:51 +01:00
* [express](https://www.npmjs.com/package/express)
2018-07-27 21:39:09 +02:00
* [node](https://nodejs.org/)
* [lbry](https://github.com/lbryio/lbry)
* [FFmpeg](https://www.ffmpeg.org/)
2018-07-27 21:39:09 +02:00
* client
* [react](https://reactjs.org/)
2018-08-10 00:50:51 +02:00
* redux
* sagas
* scss
* handlebars
2018-10-29 22:23:51 +01:00
2018-08-10 00:39:32 +02:00
### Architecture
* `cli/` contains the code for the CLI tool. Running the tool will create `.json` config files and place them in the `config/` folder
* `configure.js` is the entry point for the CLI tool
2018-10-29 22:23:51 +01:00
* `cli/defaults/` holds default config files
* `cli/questions/` holds the questions that the CLI tool asks to build the config files
2018-08-10 00:39:32 +02:00
* `client/` contains all of the client code
* The client side of spee.ch uses `React` and `Redux`
* `client/src/index.js` is the entry point for the client side js. It checks for preloaded state, creates the store, and places the `<App />` component in the document.
* `client/src/app.js` holds the `<App />` component, which contains the routes for `react-router-dom`
* `client/src/` contains all of the JSX code for the app. When the app is built, the content of this folder is transpiled into the `client/build/` folder.
* The Redux code is broken up into `actions/` `reducers/` and `selectors/`
* The React components are broken up into `containers/` (components that pull props directly from the Redux store), `components/` ('dumb' components), and `pages/`
* spee.ch also uses sagas which are in the `sagas/` folders and `channels/`
* `client/scss/` contains the CSS for the project
2018-10-29 22:23:51 +01:00
*
2018-11-09 17:22:23 +01:00
* `config/custom` is a folder which can be used to override the default components in `client/`
2018-08-10 00:39:32 +02:00
* The folder structure mimics that of the `client/` folder
2018-11-09 17:22:23 +01:00
* to customize spee.ch, place your own components and scss in the `config/custom/src/` and `config/custom/scss` folders.
2018-10-29 22:23:51 +01:00
2018-08-10 00:39:32 +02:00
* `server/` contains all of the server code
* `index.js` is the entry point for the server. It creates the [express app](https://expressjs.com/), requires the routes, syncs the database, and starts the server listening on the `PORT` designated in the config files.
* `server/routes/` contains all of the routes for the express app
* `server/controllers/` contains all of the controllers for all of the routes
* `server/models/` contains all of the models which the app uses to interact with the `MySQL` database.
* Spee.ch uses the [sequelize](http://docs.sequelizejs.com/) ORM for communicating with the database.
2018-10-29 22:23:51 +01:00
2018-08-10 00:39:32 +02:00
* `tests/` holds the end-to-end tests for this project
* Spee.ch uses `mocha` with the `chai` assertion library
* unit tests are located inside the project in-line with the files being tested and are designated with a `xxxx.test.js` file name
2018-10-29 22:23:51 +01:00
2018-08-10 00:39:32 +02:00
### Tests
* This package uses `mocha` with `chai` for testing.
* Before running tests, create a `testingConfig.js` file in `devConfig/` by copying `testingConfig.example.js`
* To run tests:
* To run all tests, including those that require LBC (like publishing), simply run `npm test`
* To run only tests that do not require LBC, run `npm run test:no-lbc`
### URL formats
Spee.ch has a few types of URL formats that return different assets from the LBRY network. Below is a list of all possible URLs for the content on spee.ch
2018-08-10 00:39:32 +02:00
* retrieve the controlling `LBRY` claim:
* https://spee.ch/`claim`
* https://spee.ch/`claim`.`ext` (serve)
* retrieve a specific `LBRY` claim:
* https://spee.ch/`claim_id`/`claim`
* https://spee.ch/`claim_id`/`claim`.`ext` (serve)
* retrieve all contents for the controlling `LBRY` channel
* https://spee.ch/`@channel`
* a specific `LBRY` channel
* https://spee.ch/`@channel`:`channel_id`
* retrieve a specific claim within the controlling `LBRY` channel
* https://spee.ch/`@channel`/`claim`
* https://spee.ch/`@channel`/`claim`.`ext` (serve)
* retrieve a specific claim within a specific `LBRY` channel
* https://spee.ch/`@channel`:`channel_id`/`claim`
* https://spee.ch/`@channel`:`channel_id`/`claim`.`ext` (serve)
2018-10-29 22:23:51 +01:00
2018-08-10 00:39:32 +02:00
### Bugs
If you find a bug or experience a problem, please report your issue here on GitHub and find us in the lbry discord!
2018-08-10 00:39:32 +02:00
2018-08-01 19:38:00 +02:00
### Issue tags in this repo
#### level 1
Issues that anyone with basic web development can handle; little-to-no experience with the spee.ch codebase is required.
2018-10-29 22:23:51 +01:00
#### level 2
2018-08-01 19:38:00 +02:00
Familiarity with web apps is required, but little-to-no familiarity with the lbry daemon is necessary
#### level 3
Familiarity with the spee.ch code base and how the lbry daemon functions is required
#### level 4
Issues with lbry (e.g. the spee.ch wallet, lbrynet configuration, etc.) that require strong familiarity with the lbry daemon and/or network to fix. Generally these issues are best suited for the `lbry` `protocol team` but are reported in this repo because they are part of the spee.ch implementation