mirror of
https://github.com/SunRed/haste-server.git
synced 2024-11-23 09:50:17 +01:00
Added proper documentation
This commit is contained in:
parent
1efc62a8c5
commit
b4f42219e5
9 changed files with 326 additions and 311 deletions
21
LICENSE
Normal file
21
LICENSE
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
The MIT License
|
||||||
|
|
||||||
|
Copyright © 2011-2012 John Crepezzi
|
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||||
|
this software and associated documentation files (the ‘Software’), to deal in
|
||||||
|
the Software without restriction, including without limitation the rights to
|
||||||
|
use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
|
||||||
|
of the Software, and to permit persons to whom the Software is furnished to do
|
||||||
|
so, subject to the following conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be included in all
|
||||||
|
copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED ‘AS IS’, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||||
|
SOFTWARE
|
303
README.md
303
README.md
|
@ -1,9 +1,15 @@
|
||||||
|
# DISCLAIMER
|
||||||
|
|
||||||
|
This is a continued version of hastebin server with extended development, developed alone by zneix.
|
||||||
|
Original developer abandoned this amazing project and due to pile of unmerged Pull Requests and several security issues with outdated dependencies I decided to rewrite whole project in JavaScript ES6.
|
||||||
|
|
||||||
|
**This version is heavily changed, meaning there will be breaking changes in your config if you were running outdated upstream version.**
|
||||||
|
|
||||||
# Haste
|
# Haste
|
||||||
|
|
||||||
Haste is an open-source pastebin software written in node.js, which is easily
|
Haste is an open-source pastebin software written in Node.JS, which is easily installable in any network.
|
||||||
installable in any network. It can be backed by either redis or filesystem,
|
It can be backed by either redis or filesystem and has a very easy adapter interface for other storage systems.
|
||||||
and has a very easy adapter interface for other stores. A publicly available
|
A publicly available version can be found at [haste.zneix.eu](https://haste.zneix.eu)
|
||||||
version can be found at [hastebin.com](http://hastebin.com)
|
|
||||||
|
|
||||||
Major design objectives:
|
Major design objectives:
|
||||||
|
|
||||||
|
@ -11,297 +17,28 @@ Major design objectives:
|
||||||
* Be really simple
|
* Be really simple
|
||||||
* Be easy to set up and use
|
* Be easy to set up and use
|
||||||
|
|
||||||
Haste works really well with a little utility called
|
~~Haste works really well with a little utility called [haste-client](https://github.com/seejohnrun/haste-client), allowing you to do things like:~~
|
||||||
[haste-client](https://github.com/seejohnrun/haste-client), allowing you
|
|
||||||
to do things like:
|
|
||||||
|
|
||||||
`cat something | haste`
|
~~`cat file | haste`~~
|
||||||
|
|
||||||
which will output a URL to share containing the contents of `cat something`'s
|
~~which will output a URL to paste containing the contents of `file`. Check the README there for more details and usages.~~
|
||||||
STDOUT. Check the README there for more details and usages.
|
|
||||||
|
|
||||||
## Tested Browsers
|
There will be a rewritten version of this CLI Haste Client in Golang soon.
|
||||||
|
|
||||||
* Firefox 81
|
|
||||||
* Chrome 17
|
|
||||||
* Safari 5.3
|
|
||||||
|
|
||||||
## Installation
|
# Installation
|
||||||
|
|
||||||
1. Download the package, and expand it
|
Full installation and config instructions can be found in [`docs` directory](https://github.com/zneix/haste-server/tree/master/docs).
|
||||||
2. Explore the settings inside of config.js, but the defaults should be good
|
|
||||||
3. `npm install`
|
|
||||||
4. `npm start`
|
|
||||||
|
|
||||||
## Settings
|
|
||||||
|
|
||||||
* `host` - the host the server runs on (default localhost)
|
## Authors
|
||||||
* `port` - the port the server runs on (default 7777)
|
|
||||||
* `keyLength` - the length of the keys to user (default 10)
|
|
||||||
* `maxLength` - maximum length of a paste (default 400000)
|
|
||||||
* `staticMaxAge` - max age for static assets (86400)
|
|
||||||
* `compressStaticAssets` - whether or not to compile static js assets (true)
|
|
||||||
* `documents` - static documents to serve (ex: http://hastebin.com/about.md)
|
|
||||||
in addition to static assets. These will never expire.
|
|
||||||
* `storage` - storage options (see below)
|
|
||||||
* `logging` - logging preferences
|
|
||||||
* `keyGenerator` - key generator options (see below)
|
|
||||||
* `rateLimits` - settings for rate limiting (see below)
|
|
||||||
|
|
||||||
## Rate Limiting
|
Project continued by zneix <zzneix@gmail.com>
|
||||||
|
|
||||||
When present, the `rateLimits` option enables built-in rate limiting courtesy
|
Original Code by John Crepezzi <john.crepezzi@gmail.com>
|
||||||
of `express-rate-limit`. Any of the options supported by that library can be
|
|
||||||
used and set in `config.js`.
|
|
||||||
|
|
||||||
See the README for [express-rate-limit](https://www.npmjs.com/package/express-rate-limit)
|
|
||||||
for more information!
|
|
||||||
|
|
||||||
## Key Generation
|
## Other components:
|
||||||
|
|
||||||
### Phonetic
|
|
||||||
|
|
||||||
Attempts to generate phonetic keys, similar to `pwgen`
|
|
||||||
|
|
||||||
``` json
|
|
||||||
{
|
|
||||||
"type": "phonetic"
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
### Random
|
|
||||||
|
|
||||||
Generates a random key
|
|
||||||
|
|
||||||
``` json
|
|
||||||
{
|
|
||||||
"type": "random",
|
|
||||||
"keyspace": "abcdef"
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
The _optional_ keySpace argument is a string of acceptable characters
|
|
||||||
for the key.
|
|
||||||
|
|
||||||
## Storage
|
|
||||||
|
|
||||||
### File
|
|
||||||
|
|
||||||
To use file storage (the default) change the storage section in `config.js` to
|
|
||||||
something like:
|
|
||||||
|
|
||||||
``` json
|
|
||||||
{
|
|
||||||
"type": "file",
|
|
||||||
"path": "./data"
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
where `path` represents where you want the files stored.
|
|
||||||
|
|
||||||
File storage currently does not support paste expiration, you can follow [#191](https://github.com/seejohnrun/haste-server/issues/191) for status updates.
|
|
||||||
|
|
||||||
### Redis
|
|
||||||
|
|
||||||
To use redis storage you must install the `redis` package in npm, and have
|
|
||||||
`redis-server` running on the machine.
|
|
||||||
|
|
||||||
`npm install redis`
|
|
||||||
|
|
||||||
Once you've done that, your config section should look like:
|
|
||||||
|
|
||||||
``` json
|
|
||||||
{
|
|
||||||
"type": "redis",
|
|
||||||
"host": "localhost",
|
|
||||||
"port": 6379,
|
|
||||||
"db": 2
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
You can also set an `expire` option to the number of seconds to expire keys in.
|
|
||||||
This is off by default, but will constantly kick back expirations on each view
|
|
||||||
or post.
|
|
||||||
|
|
||||||
All of which are optional except `type` with very logical default values.
|
|
||||||
|
|
||||||
If your Redis server is configured for password authentification, use the `password` field.
|
|
||||||
|
|
||||||
### Postgres
|
|
||||||
|
|
||||||
To use postgres storage you must install the `pg` package in npm
|
|
||||||
|
|
||||||
`npm install pg`
|
|
||||||
|
|
||||||
Once you've done that, your config section should look like:
|
|
||||||
|
|
||||||
``` json
|
|
||||||
{
|
|
||||||
"type": "postgres",
|
|
||||||
"connectionUrl": "postgres://user:password@host:5432/database"
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
You can also just set the environment variable for `DATABASE_URL` to your database connection url.
|
|
||||||
|
|
||||||
You will have to manually add a table to your postgres database:
|
|
||||||
|
|
||||||
`create table entries (id serial primary key, key varchar(255) not null, value text not null, expiration int, unique(key));`
|
|
||||||
|
|
||||||
You can also set an `expire` option to the number of seconds to expire keys in.
|
|
||||||
This is off by default, but will constantly kick back expirations on each view
|
|
||||||
or post.
|
|
||||||
|
|
||||||
All of which are optional except `type` with very logical default values.
|
|
||||||
|
|
||||||
### MongoDB
|
|
||||||
|
|
||||||
To use mongodb storage you must install the 'mongodb' pachage in npm
|
|
||||||
|
|
||||||
`npm install mongodb`
|
|
||||||
|
|
||||||
Once you've done that, your config section should look like:
|
|
||||||
|
|
||||||
``` json
|
|
||||||
{
|
|
||||||
"type": "mongodb",
|
|
||||||
"expire": false,
|
|
||||||
"connectionUrl": "mongodb://localhost:27017/haste",
|
|
||||||
"clientOptions": {
|
|
||||||
"useUnifiedTopology": true,
|
|
||||||
"useNewUrlParser": true,
|
|
||||||
"keepAlive": true,
|
|
||||||
"keepAliveInitialDelay": 60000,
|
|
||||||
"poolSize": 30,
|
|
||||||
"socketTimeoutMS": 360000,
|
|
||||||
"connectTimeoutMS": 360000,
|
|
||||||
"auth": {
|
|
||||||
"user": "username",
|
|
||||||
"password": "password"
|
|
||||||
},
|
|
||||||
"authSource": "admin"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
You can adjust properties in `clientOptions`, but the ones in config are considered as the most optimal defaults.
|
|
||||||
You can omit `auth` object if database has no authentication.
|
|
||||||
No further database configuration is required.
|
|
||||||
|
|
||||||
You can set `expire` option to the number of seconds in which documents will expire.
|
|
||||||
This is set to `false` by default, but will constantly kick back expirations on each view or post.
|
|
||||||
|
|
||||||
### Memcached
|
|
||||||
|
|
||||||
To use memcache storage you must install the `memcached` package via npm
|
|
||||||
|
|
||||||
`npm install memcached`
|
|
||||||
|
|
||||||
Once you've done that, your config section should look like:
|
|
||||||
|
|
||||||
``` json
|
|
||||||
{
|
|
||||||
"type": "memcached",
|
|
||||||
"host": "127.0.0.1",
|
|
||||||
"port": 11211
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
You can also set an `expire` option to the number of seconds to expire keys in.
|
|
||||||
This behaves just like the redis expirations, but does not push expirations
|
|
||||||
forward on GETs.
|
|
||||||
|
|
||||||
All of which are optional except `type` with very logical default values.
|
|
||||||
|
|
||||||
### RethinkDB
|
|
||||||
|
|
||||||
To use the RethinkDB storage system, you must install the `rethinkdbdash` package via npm
|
|
||||||
|
|
||||||
`npm install rethinkdbdash`
|
|
||||||
|
|
||||||
Once you've done that, your config section should look like this:
|
|
||||||
|
|
||||||
``` json
|
|
||||||
{
|
|
||||||
"type": "rethinkdb",
|
|
||||||
"host": "127.0.0.1",
|
|
||||||
"port": 28015,
|
|
||||||
"db": "haste"
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
In order for this to work, the database must be pre-created before the script is ran.
|
|
||||||
Also, you must create an `uploads` table, which will store all the data for uploads.
|
|
||||||
|
|
||||||
You can optionally add the `user` and `password` properties to use a user system.
|
|
||||||
|
|
||||||
### Amazon S3
|
|
||||||
|
|
||||||
To use [Amazon S3](https://aws.amazon.com/s3/) as a storage system, you must
|
|
||||||
install the `aws-sdk` package via npm:
|
|
||||||
|
|
||||||
`npm install aws-sdk`
|
|
||||||
|
|
||||||
Once you've done that, your config section should look like this:
|
|
||||||
|
|
||||||
```json
|
|
||||||
{
|
|
||||||
"type": "amazon-s3",
|
|
||||||
"bucket": "your-bucket-name",
|
|
||||||
"region": "us-east-1"
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
Authentication is handled automatically by the client. Check
|
|
||||||
[Amazon's documentation](https://docs.aws.amazon.com/sdk-for-javascript/v2/developer-guide/setting-credentials-node.html)
|
|
||||||
for more information. You will need to grant your role these permissions to
|
|
||||||
your bucket:
|
|
||||||
|
|
||||||
```json
|
|
||||||
{
|
|
||||||
"Version": "2012-10-17",
|
|
||||||
"Statement": [
|
|
||||||
{
|
|
||||||
"Action": [
|
|
||||||
"s3:GetObject",
|
|
||||||
"s3:PutObject"
|
|
||||||
],
|
|
||||||
"Effect": "Allow",
|
|
||||||
"Resource": "arn:aws:s3:::your-bucket-name-goes-here/*"
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
## Author
|
|
||||||
|
|
||||||
John Crepezzi <john.crepezzi@gmail.com>
|
|
||||||
|
|
||||||
## License
|
|
||||||
|
|
||||||
(The MIT License)
|
|
||||||
|
|
||||||
Copyright © 2011-2012 John Crepezzi
|
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy of
|
|
||||||
this software and associated documentation files (the ‘Software’), to deal in
|
|
||||||
the Software without restriction, including without limitation the rights to
|
|
||||||
use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
|
|
||||||
of the Software, and to permit persons to whom the Software is furnished to do
|
|
||||||
so, subject to the following conditions:
|
|
||||||
|
|
||||||
The above copyright notice and this permission notice shall be included in all
|
|
||||||
copies or substantial portions of the Software.
|
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED ‘AS IS’, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
||||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
||||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
||||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
||||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
||||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
||||||
SOFTWARE
|
|
||||||
|
|
||||||
### Other components:
|
|
||||||
|
|
||||||
* jQuery: MIT/GPL license
|
* jQuery: MIT/GPL license
|
||||||
* highlight.js: Copyright © 2006, Ivan Sagalaev
|
* highlight.js: Copyright © 2006, Ivan Sagalaev
|
||||||
|
|
37
about.md
37
about.md
|
@ -1,6 +1,6 @@
|
||||||
# Haste
|
# Haste
|
||||||
|
|
||||||
Sharing code is a good thing, and it should be _really_ easy to do it.
|
Sharing code is a good thing, and it should be _really_ easy to do.
|
||||||
A lot of times, I want to show you something I'm seeing - and that's where we
|
A lot of times, I want to show you something I'm seeing - and that's where we
|
||||||
use pastebins.
|
use pastebins.
|
||||||
|
|
||||||
|
@ -8,28 +8,25 @@ Haste is the prettiest, easiest to use pastebin ever made.
|
||||||
|
|
||||||
## Basic Usage
|
## Basic Usage
|
||||||
|
|
||||||
Type what you want me to see, click "Save", and then copy the URL. Send that
|
Paste your code, click "Save" and copy the URL.
|
||||||
URL to someone and they'll see what you see.
|
Send that URL to someone and they'll see your code.
|
||||||
|
|
||||||
To make a new entry, click "New" (or type 'control + n')
|
To make a new entry, click "New" (or hit `Ctrl + N`)
|
||||||
|
|
||||||
## From the Console
|
## From the Console
|
||||||
|
|
||||||
Most of the time I want to show you some text, it's coming from my current
|
Sometimes I want to show you some text from my current console session.
|
||||||
console session. We should make it really easy to take code from the console
|
We made it really easy to take code from the console and send it to people.
|
||||||
and send it to people.
|
|
||||||
|
|
||||||
`cat something | haste` # https://hastebin.com/1238193
|
`cat something | haste` # https://hastebin.com/2107420
|
||||||
|
|
||||||
You can even take this a step further, and cut out the last step of copying the
|
You can take this a step further and directly copy the URL with:
|
||||||
URL with:
|
|
||||||
|
|
||||||
* osx: `cat something | haste | pbcopy`
|
* osx: `cat something | haste | pbcopy`
|
||||||
* linux: `cat something | haste | xsel`
|
* linux: `cat something | haste | xsel`
|
||||||
* windows: check out [WinHaste](https://github.com/ajryan/WinHaste)
|
* windows: check out [WinHaste](https://github.com/ajryan/WinHaste)
|
||||||
|
|
||||||
After running that, the STDOUT output of `cat something` will show up at a URL
|
After running that, URL to your paste will be copied to clipboard.
|
||||||
which has been conveniently copied to your clipboard.
|
|
||||||
|
|
||||||
That's all there is to that, and you can install it with `gem install haste`
|
That's all there is to that, and you can install it with `gem install haste`
|
||||||
right now.
|
right now.
|
||||||
|
@ -38,15 +35,14 @@ right now.
|
||||||
|
|
||||||
## Duration
|
## Duration
|
||||||
|
|
||||||
Pastes will stay for 30 days from their last view. They may be removed earlier
|
Pastes will not be removed, however I preseve all rights to make any exceptions.
|
||||||
and without notice.
|
Contact me directly with any issues about documents uploaded at `zzneix@gmail.com`
|
||||||
|
|
||||||
## Privacy
|
## Privacy
|
||||||
|
|
||||||
While the contents of hastebin.com are not directly crawled by any search robot
|
While the contents of haste.zneix.eu are not crawled by any search robot that
|
||||||
that obeys "robots.txt", there should be no great expectation of privacy. Post
|
obeys "robots.txt", there should be no great expectation of privacy.
|
||||||
things at your own risk. Not responsible for any loss of data or removed
|
Post things at your own risk. Not responsible for any removed pastes.
|
||||||
pastes.
|
|
||||||
|
|
||||||
## Open Source
|
## Open Source
|
||||||
|
|
||||||
|
@ -55,8 +51,9 @@ Haste can easily be installed behind your network, and it's all open source!
|
||||||
* [haste-client](https://github.com/seejohnrun/haste-client)
|
* [haste-client](https://github.com/seejohnrun/haste-client)
|
||||||
* [haste-server](https://github.com/zneix/haste-server)
|
* [haste-server](https://github.com/zneix/haste-server)
|
||||||
|
|
||||||
## Author
|
## Authors
|
||||||
|
|
||||||
|
Project continued by zneix <zzneix@gmail.com>
|
||||||
|
|
||||||
Original Code by John Crepezzi <john.crepezzi@gmail.com>
|
Original Code by John Crepezzi <john.crepezzi@gmail.com>
|
||||||
Continued by zneix <zzneix@gmail.com>
|
|
||||||
Key Design by Brian Dawson <bridawson@gmail.com>
|
Key Design by Brian Dawson <bridawson@gmail.com>
|
||||||
|
|
46
docs/generators.md
Normal file
46
docs/generators.md
Normal file
|
@ -0,0 +1,46 @@
|
||||||
|
# Generators
|
||||||
|
|
||||||
|
Here's a list of all supported random string generators.
|
||||||
|
One of these is meant to be set in `config.json` as `keyGenerator` object.
|
||||||
|
Default type is [random](#random) with all alphanumeric characters as keyspace.
|
||||||
|
|
||||||
|
|
||||||
|
**Table of Contents**
|
||||||
|
|
||||||
|
- [Phonetic](#phonetic)
|
||||||
|
- [Random](#random)
|
||||||
|
- [Dictionary](#dictionary)
|
||||||
|
|
||||||
|
## Random
|
||||||
|
|
||||||
|
Generates a random key from set of characters in `keysapce`.
|
||||||
|
Keyspace can be left empty to use all alphanumeric characters instead.
|
||||||
|
|
||||||
|
``` json
|
||||||
|
{
|
||||||
|
"type": "random",
|
||||||
|
"keyspace": "abcdef"
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
## Phonetic
|
||||||
|
|
||||||
|
Generates phonetic key with a combination of vovels similar to `pwgen` command on linux.
|
||||||
|
|
||||||
|
``` json
|
||||||
|
{
|
||||||
|
"type": "phonetic"
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
## Dictionary
|
||||||
|
|
||||||
|
Generates a key consisting of words from file named `words.txt`, one word per line.
|
||||||
|
To avoid any issues with URL length, it is recommended to use `keyLength` 5 or shorter.
|
||||||
|
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"type": "dictionary",
|
||||||
|
"path": "./words.txt"
|
||||||
|
}
|
||||||
|
```
|
118
docs/install.md
Normal file
118
docs/install.md
Normal file
|
@ -0,0 +1,118 @@
|
||||||
|
# Short instructions
|
||||||
|
|
||||||
|
1. Install [node](https://nodejs.org/en/) and npm packages.
|
||||||
|
2. Rename `example.config.js` to `config.js`. (Defaults are enough)
|
||||||
|
3. (Optional) Change document storage system ([guide](./storage.md))
|
||||||
|
4. Run with `npm start` or `node .`
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# Full installation instructions
|
||||||
|
|
||||||
|
> **NOTE:** This guide assumes you're on a Linux server, like Debian 10 or Ubuntu 20.04.
|
||||||
|
If you're using windows, you will have to improvise a bit with Autorestarts.
|
||||||
|
|
||||||
|
**Table of Contents**
|
||||||
|
|
||||||
|
- [Set up node](#set-up-node)
|
||||||
|
- [Install dependencies](#install-dependencies)
|
||||||
|
- [Edit configuration](#edit-configuration)
|
||||||
|
- [Run the server](#run-the-server)
|
||||||
|
- [Further steps](#further-steps)
|
||||||
|
|
||||||
|
|
||||||
|
## Set up node
|
||||||
|
|
||||||
|
Hastebin server runs on the JavaScript runtime called node, so you need to download it first:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
curl -sL https://deb.nodesource.com/setup_14.x | bash -
|
||||||
|
apt-get install -y nodejs
|
||||||
|
```
|
||||||
|
|
||||||
|
If method above didn't work [use this guide](https://github.com/nodesource/distributions/blob/master/README.md#installation-instructions).
|
||||||
|
|
||||||
|
For Windows enviroments, you can [download and install node from its website](https://nodejs.org/en/download/current/).
|
||||||
|
|
||||||
|
Node should also automatically install [npm](https://docs.npmjs.com/about-npm/) which will help us install dependencies. You can verify your installations, with following commands
|
||||||
|
|
||||||
|
```bash
|
||||||
|
node -v
|
||||||
|
npm -v
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
## Install dependencies
|
||||||
|
|
||||||
|
Hastebin makes use of several node packages, which can be installed with npm by executing this command:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
npm install
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
## Edit configuration
|
||||||
|
|
||||||
|
There is an [example configuration file](../example.config.json) available for you to copy:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
cp example.config.json config.json
|
||||||
|
```
|
||||||
|
|
||||||
|
By default storage system stores haste documents as hashed files in `./data` directory.
|
||||||
|
|
||||||
|
Rest of provided defaults are enough to run the server, however, example config contains comments about what each value does and you can adjust the options to your likings.
|
||||||
|
|
||||||
|
[Guide for all supported storage systems.](./storage.md).
|
||||||
|
[Guide for all supported key generators.](./generators.md).
|
||||||
|
|
||||||
|
|
||||||
|
## Run the server
|
||||||
|
|
||||||
|
You should now be able to start the server with the following command:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
npm run-script start
|
||||||
|
```
|
||||||
|
|
||||||
|
To stop server the server, hit `Ctrl + C`
|
||||||
|
|
||||||
|
## Further steps
|
||||||
|
|
||||||
|
Once you're good to go and server is running you probably want to keep it alive 24/7 - to achieve that you can choose from variety of things like: pm2, systemd, screen, etc.
|
||||||
|
Here, I will cover a basic guide to the PM2 - a program which will make sure your server is running 24/7 with autorestarts.
|
||||||
|
|
||||||
|
Download it with npm:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
sudo npm install pm2 -g
|
||||||
|
```
|
||||||
|
|
||||||
|
Now assign Hastebin server to pm2's daemon:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
pm2 start "npm start" --name=haste
|
||||||
|
```
|
||||||
|
|
||||||
|
To ensure haste server will automatically start after server reboot you need to retrieve startup script and execute it.
|
||||||
|
Example:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
$ pm2 startup
|
||||||
|
[PM2] Init System found: systemd
|
||||||
|
[PM2] To setup the Startup Script, copy/paste the following command:
|
||||||
|
sudo env PATH=$PATH:/usr/bin /usr/lib/node_modules/pm2/bin/pm2 startup systemd -u zneix --hp /home/zneix
|
||||||
|
```
|
||||||
|
|
||||||
|
Now, just copy-paste the last line into your terminal and you should be done.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
PM2 Commands:
|
||||||
|
|
||||||
|
- `pm2 list`: displays list of all pm2 processes
|
||||||
|
- `pm2 logs haste`: displays server logs
|
||||||
|
|
||||||
|
- `pm2 restart haste`: restarts Hastebin server (you will need to do that after config changes, etc.)
|
||||||
|
- `pm2 stop haste`: stops Hastebin server
|
||||||
|
- `pm2 start haste`: starts Hastebin server if it was stopped manually before
|
100
docs/storage.md
Normal file
100
docs/storage.md
Normal file
|
@ -0,0 +1,100 @@
|
||||||
|
# Storage
|
||||||
|
|
||||||
|
Here's a list of all supported document store systems.
|
||||||
|
One of these is meant to be set in `config.json` as `storage` object.
|
||||||
|
Default type is [file](#file) with save directory at `./data`.
|
||||||
|
With some storage options you can set up document expiration - after which documents will no longer be available
|
||||||
|
|
||||||
|
**Table of Contents**
|
||||||
|
|
||||||
|
In alphabetical order:
|
||||||
|
|
||||||
|
- [Amazon S3](#amazon-s3)
|
||||||
|
- [File](#file)
|
||||||
|
- [Memcached](#memcached)
|
||||||
|
- [MongoDB](#mongodb)
|
||||||
|
- [Postgres](#postgres)
|
||||||
|
- [Redis](#redis)
|
||||||
|
- [RethinkDB](#rethinkdb)
|
||||||
|
|
||||||
|
|
||||||
|
## Amazon S3
|
||||||
|
|
||||||
|
Not rewritten yet, to be filled in
|
||||||
|
|
||||||
|
|
||||||
|
## File
|
||||||
|
|
||||||
|
Default storage option, with no further installation required.
|
||||||
|
Stores documents in a specified directory in files named with a md5 hash of the key to avoid any security issues.
|
||||||
|
Default path is `./data`
|
||||||
|
> **NOTE:** File storage option does not support document expiration!
|
||||||
|
|
||||||
|
Config:
|
||||||
|
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"type": "file",
|
||||||
|
"path": "./data"
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
## Memcached
|
||||||
|
|
||||||
|
Not rewritten yet, to be filled in
|
||||||
|
|
||||||
|
|
||||||
|
## MongoDB
|
||||||
|
|
||||||
|
Requires npm package (Tested on v3.6.0):
|
||||||
|
|
||||||
|
```bash
|
||||||
|
npm i mongodb@3.6.0
|
||||||
|
```
|
||||||
|
|
||||||
|
Stores documents in a specified database in a collection named `entries`.
|
||||||
|
Expiration property in config can be changed to a value in seconds after which entries will not be served to users.
|
||||||
|
|
||||||
|
Optimal default config:
|
||||||
|
> **NOTE:** Depending on how your MongoDB server is configured, options as connectionUri may vary.
|
||||||
|
If server has no authentication, you can omit the `auth` object.
|
||||||
|
|
||||||
|
Check [documentation](http://mongodb.github.io/node-mongodb-native/3.5/api/MongoClient.html) for more detailed explanation about available `clientOptions` properties.
|
||||||
|
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"type": "mongodb",
|
||||||
|
"expire": 0,
|
||||||
|
"connectionUri": "mongodb://localhost:27017/haste",
|
||||||
|
"clientOptions": {
|
||||||
|
"useUnifiedTopology": true,
|
||||||
|
"useNewUrlParser": true,
|
||||||
|
"keepAlive": true,
|
||||||
|
"keepAliveInitialDelay": 60000,
|
||||||
|
"poolSize": 30,
|
||||||
|
"socketTimeoutMS": 360000,
|
||||||
|
"connectTimeoutMS": 360000,
|
||||||
|
"auth": {
|
||||||
|
"user": "username",
|
||||||
|
"password": "password"
|
||||||
|
},
|
||||||
|
"authSource": "admin"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
## Postgres
|
||||||
|
|
||||||
|
Not rewritten yet, to be filled in
|
||||||
|
|
||||||
|
|
||||||
|
## Redis
|
||||||
|
|
||||||
|
Not rewritten yet, to be filled in
|
||||||
|
|
||||||
|
|
||||||
|
## RethinkDB
|
||||||
|
|
||||||
|
Not rewritten yet, to be filled in
|
|
@ -27,8 +27,8 @@ module.exports = {
|
||||||
"level": "info"
|
"level": "info"
|
||||||
},
|
},
|
||||||
|
|
||||||
//rate limits for requests, handled by express-rate-limit
|
//rate limits for requests, can be omitted
|
||||||
//options can be found here: https://github.com/nfriedly/express-rate-limit/blob/master/lib/express-rate-limit.js#L7-L14
|
//handled by express-rate-limit, options can be found here: https://github.com/nfriedly/express-rate-limit/blob/master/lib/express-rate-limit.js#L7-L14
|
||||||
"rateLimits": {
|
"rateLimits": {
|
||||||
"windowMs": 30 * 60 * 1000,
|
"windowMs": 30 * 60 * 1000,
|
||||||
"max": 250
|
"max": 250
|
||||||
|
|
|
@ -1,11 +1,7 @@
|
||||||
|
const winston = require('winston');
|
||||||
const fs = require('fs');
|
const fs = require('fs');
|
||||||
const crypto = require('crypto');
|
const crypto = require('crypto');
|
||||||
|
|
||||||
const winston = require('winston');
|
|
||||||
|
|
||||||
// For storing in files
|
|
||||||
// options[type] = file
|
|
||||||
// options[path] - Where to store
|
|
||||||
|
|
||||||
class FileDocumentStore {
|
class FileDocumentStore {
|
||||||
|
|
||||||
|
|
|
@ -3,7 +3,7 @@ const mongodb = require('mongodb');
|
||||||
|
|
||||||
const MongoDocumentStore = function (config){
|
const MongoDocumentStore = function (config){
|
||||||
this.expire = config.expire;
|
this.expire = config.expire;
|
||||||
this.MongoClient = new mongodb.MongoClient(config.connectionUrl, config.clientOptions);
|
this.MongoClient = new mongodb.MongoClient(config.connectionUri, config.clientOptions);
|
||||||
};
|
};
|
||||||
|
|
||||||
MongoDocumentStore.prototype.set = async function (key, data, callback, skipExpire){
|
MongoDocumentStore.prototype.set = async function (key, data, callback, skipExpire){
|
||||||
|
|
Loading…
Reference in a new issue