misskey/README.md

142 lines
4.7 KiB
Markdown
Raw Normal View History

2016-12-28 14:49:51 -08:00
# Misskey
[![][travis-badge]][travis-link]
2016-12-30 04:38:00 -08:00
[![][appveyor-badge]][appveyor-link]
2016-12-28 14:49:51 -08:00
[![][dependencies-badge]][dependencies-link]
[![][mit-badge]][mit]
2017-01-23 22:41:43 -08:00
[![][saythanks-badge]][saythanks]
2016-12-28 14:49:51 -08:00
2017-01-24 01:41:07 -08:00
[![][himawari-badge]][himasaku]
[![][sakurako-badge]][himasaku]
2017-01-17 22:48:36 -08:00
[![Sauce Test Status][saucelabs-image]][saucelabs-url]
2016-12-30 20:37:21 -08:00
Welcome!
2016-12-30 20:48:10 -08:00
Misskey is a completely open source, ultimately sophisticated new type of mini-blog based SNS.
2016-12-28 14:49:51 -08:00
2016-12-29 03:43:33 -08:00
![ss](./resources/ss.jpg)
2016-12-30 21:15:37 -08:00
## Features
* Automatically updated timeline
2016-12-30 21:11:31 -08:00
* Private chatting (messaging)
2016-12-30 21:15:49 -08:00
* Free 1GB storage
2016-12-30 21:11:31 -08:00
* Mobile device support (smartphone, tablet, etc)
2016-12-30 21:16:13 -08:00
* Thirdparty application support
2017-01-20 23:08:06 -08:00
* Link to Twitter
2016-12-30 21:11:31 -08:00
2017-01-02 12:28:54 -08:00
and more! You can touch with your own eyes at https://misskey.xyz/.
2016-12-30 21:11:31 -08:00
2016-12-30 21:12:15 -08:00
## Building
2016-12-30 14:18:06 -08:00
1. Install *git*, *Node.js* and *npm*
2016-12-30 09:44:45 -08:00
2. `git clone git://github.com/syuilo/misskey.git`
3. `cd misskey`
4. `npm install`
5. `npm run config`
6. `npm run build`
2016-12-28 14:49:51 -08:00
2017-01-24 18:32:00 -08:00
GLHF!
2017-01-25 05:04:52 -08:00
## Testing
2017-01-19 03:43:22 -08:00
Run `npm test` after building
2016-12-30 09:44:45 -08:00
## Setup
2016-12-30 14:06:38 -08:00
### Dependencies :package:
2016-12-30 09:47:45 -08:00
Please install these softwares.
2016-12-30 12:25:26 -08:00
* **[MongoDB](https://www.mongodb.com/)**
* **[Redis](https://redis.io/)**
* **[GraphicsMagick](http://www.graphicsmagick.org/)**
2016-12-30 14:06:38 -08:00
#### Optional
2016-12-30 20:05:15 -08:00
* [Elasticsearch](https://www.elastic.co/) - used to provide searching feature instead of MongoDB
2016-12-28 14:49:51 -08:00
2016-12-29 07:23:25 -08:00
### Domains
2016-12-28 14:49:51 -08:00
Misskey requires two domains called the primary domain and the secondary domain.
* The primary domain is used to provide main service of Misskey.
* The secondary domain is used to avoid vulnerabilities such as XSS.
**Ensure that the secondary domain is not a subdomain of the primary domain.**
2017-02-20 14:34:14 -08:00
#### Subdomains
Misskey uses following subdomains:
* **api**.*{primary domain}*
* **auth**.*{primary domain}*
* **about**.*{primary domain}*
* **dev**.*{primary domain}*
* **file**.*{secondary domain}*
2017-02-14 07:44:07 -08:00
2016-12-29 07:23:25 -08:00
### reCAPTCHA
2016-12-30 09:39:46 -08:00
Please visit https://www.google.com/recaptcha/intro/ and generate keys.
2016-12-29 07:23:25 -08:00
2016-12-30 13:58:52 -08:00
## Setup with Docker :whale:
2016-12-30 13:38:14 -08:00
Ensure that the working directory is the repository root directory.
To create misskey image:
2016-12-31 00:33:53 -08:00
2016-12-30 20:00:11 -08:00
`sudo docker build -t misskey ./docker`
2016-12-30 13:38:14 -08:00
To run misskey:
2016-12-31 00:33:53 -08:00
2016-12-30 13:38:14 -08:00
`sudo docker run --rm -i -t -p $PORT:80 -v $(pwd):/root/misskey -v $DBPATH:/data/db misskey`
2016-12-31 00:36:11 -08:00
where `$PORT` is the port used to access Misskey Web from host browser
and `$DBPATH` is the path of MongoDB database on the host for data persistence.
2016-12-30 13:38:14 -08:00
ex: `sudo docker run --rm -i -t -p 80:80 -v $(pwd):/root/misskey -v /data/db:/data/db misskey`
2016-12-31 00:33:53 -08:00
If you want to run misskey in production mode, add `--env NODE_ENV=production` like this:
2016-12-31 00:35:07 -08:00
`sudo docker run --rm -i -t -p 80:80 -v $(pwd):/root/misskey -v /data/db:/data/db --env NODE_ENV=production misskey`
2016-12-31 00:33:53 -08:00
2016-12-31 00:36:11 -08:00
Note that `$(pwd)` is the working directory.
2016-12-30 13:38:14 -08:00
2016-12-28 14:49:51 -08:00
## Launch
2016-12-29 07:16:47 -08:00
`sudo npm start`
2016-12-28 14:49:51 -08:00
2017-01-25 05:04:52 -08:00
## Debugging :bug:
2017-01-23 04:07:11 -08:00
### Show a debug messages
Misskey uses [debug](https://github.com/visionmedia/debug) and namespace is `misskey:*`.
2017-01-23 01:25:52 -08:00
2016-12-30 10:50:21 -08:00
## Contribute
Do you have feature request or problem with Misskey?
2016-12-31 01:16:27 -08:00
Please create issue to report it if it is about the Misskey implementation itself.
2016-12-30 10:50:21 -08:00
Currently Misskey is missing documents so writing documents would be appreciated.
Pull requests are always welcome.
2017-01-23 21:52:59 -08:00
*We love contributions from anybody.*
2016-12-30 11:02:01 -08:00
2016-12-30 14:09:29 -08:00
[Contribution guide](./CONTRIBUTING.md)
2016-12-30 12:35:23 -08:00
### TODO
2016-12-30 14:15:48 -08:00
* More [tests](./test)!
* More [docs](./docs)!
2016-12-30 20:53:29 -08:00
* More cleaning up code!
2016-12-30 12:35:23 -08:00
2017-01-18 02:40:18 -08:00
## Collaborators
| ![syuilo](https://avatars2.githubusercontent.com/u/4439005?v=3&s=70) | ![Morisawa Aya](https://avatars0.githubusercontent.com/u/10798641?v=3&s=70)
|---|---|
| [syuilo](https://syuilo.com) | [Aya Morisawa](https://github.com/ayamorisawa)|
2017-01-01 09:17:53 -08:00
## Copyright
2017-01-19 03:44:19 -08:00
Misskey is an open-source software licensed under [The MIT License](LICENSE).
2016-12-28 14:49:51 -08:00
2017-01-23 21:50:31 -08:00
🍮
2016-12-28 14:49:51 -08:00
[mit]: http://opensource.org/licenses/MIT
[mit-badge]: https://img.shields.io/badge/license-MIT-444444.svg?style=flat-square
[travis-link]: https://travis-ci.org/syuilo/misskey
2016-12-30 04:40:19 -08:00
[travis-badge]: http://img.shields.io/travis/syuilo/misskey.svg?style=flat-square&label=Linux
2016-12-30 04:38:00 -08:00
[appveyor-link]: https://ci.appveyor.com/project/syuilo/misskey
2016-12-30 04:40:19 -08:00
[appveyor-badge]: https://img.shields.io/appveyor/ci/syuilo/misskey/master.svg?style=flat-square&label=Windows
2016-12-28 14:49:51 -08:00
[dependencies-link]: https://gemnasium.com/syuilo/misskey
[dependencies-badge]: https://img.shields.io/gemnasium/syuilo/misskey.svg?style=flat-square
2017-01-17 22:48:36 -08:00
[saucelabs-image]: https://saucelabs.com/browser-matrix/syuilo.svg
[saucelabs-url]: https://saucelabs.com/u/syuilo
2017-01-23 22:41:43 -08:00
[saythanks]: https://saythanks.io/to/syuilo
2017-01-23 22:42:40 -08:00
[saythanks-badge]: https://img.shields.io/badge/SayThanks.io-☼-1EAEDB.svg?style=flat-square
2017-01-24 01:41:07 -08:00
[himasaku]: https://himasaku.net
[himawari-badge]: https://img.shields.io/badge/%E5%8F%A4%E8%B0%B7-%E5%90%91%E6%97%A5%E8%91%B5-1684c5.svg?style=flat-square
[sakurako-badge]: https://img.shields.io/badge/%E5%A4%A7%E5%AE%A4-%E6%AB%BB%E5%AD%90-efb02a.svg?style=flat-square