Updated contributing guidelines and development steps
parent
24a9b2e6e4
commit
0d66654b9f
|
@ -0,0 +1,9 @@
|
||||||
|
## Contributing license
|
||||||
|
By contributing to this repository, you agree your contributions to be bound by the [SHINOBI OPEN SOURCE SOFTWARE LICENSE AGREEMENT
|
||||||
|
](LICENSE.md)
|
||||||
|
|
||||||
|
## Suggestions
|
||||||
|
For suggestions to this project, please refer to the [README](README.md)
|
||||||
|
|
||||||
|
## Development
|
||||||
|
For contributing to the repository, please refer to [DEVELOPMENT.md](DEVELOPMENT.md)
|
|
@ -15,8 +15,6 @@ any sort of super user access.
|
||||||
Prerequisites
|
Prerequisites
|
||||||
=============
|
=============
|
||||||
|
|
||||||
> To get all of Shinobi at once you can use the Ninja Way. Learn more about that here
|
|
||||||
https://shinobi.video/docs/start#content-the-ninja-way
|
|
||||||
|
|
||||||
- *Node.js* :
|
- *Node.js* :
|
||||||
You'll need Node and NPM, and for this guide we recommend you set up a user-local install of
|
You'll need Node and NPM, and for this guide we recommend you set up a user-local install of
|
||||||
|
@ -34,6 +32,11 @@ instance you're working with by copying it. It is recommended to use at least ve
|
||||||
You'll also need FFmpeg. This is the video processing engine at the core of Shinobi. You will
|
You'll also need FFmpeg. This is the video processing engine at the core of Shinobi. You will
|
||||||
need at least version 3.3.3.
|
need at least version 3.3.3.
|
||||||
|
|
||||||
|
### Installing prerequisites automatically
|
||||||
|
To get all of Shinobi at once you can use the Ninja Way. Learn more about that here
|
||||||
|
https://shinobi.video/docs/start#content-the-ninja-way
|
||||||
|
However this will download the repository to /home/Shinobi and start Shinobi. Once you have finished the installation using the ninja way, ensure that you stop Shinobi othewise it will confilict with your dev instance. To stop Shinobi run `sudo pm2 stop camera.js` and `sudo pm2 stop cron.js`
|
||||||
|
|
||||||
Development
|
Development
|
||||||
===========
|
===========
|
||||||
First off you need to clone the Shinobi repository. Either the regular Shinobi repository or the
|
First off you need to clone the Shinobi repository. Either the regular Shinobi repository or the
|
||||||
|
@ -56,6 +59,8 @@ git clone https://gitlab.com/Shinobi-Systems/ShinobiCE.git
|
||||||
```
|
```
|
||||||
Then cd into either the "Shinobi" or "ShinobiCE" directory.
|
Then cd into either the "Shinobi" or "ShinobiCE" directory.
|
||||||
|
|
||||||
|
Make sure to add your fork as a remote so you can send Merge requests
|
||||||
|
|
||||||
Grabbing packages
|
Grabbing packages
|
||||||
-----------------
|
-----------------
|
||||||
To install the required Node packages you need to install them with NPM:
|
To install the required Node packages you need to install them with NPM:
|
||||||
|
@ -73,27 +78,7 @@ instances of Shinobi whenever someone updated.
|
||||||
```sh
|
```sh
|
||||||
cp conf.sample.json conf.json
|
cp conf.sample.json conf.json
|
||||||
```
|
```
|
||||||
Generally for development SQLite is going to be easier with SQLite, as we don't have to maintain
|
|
||||||
a MariaDB/MySQL installation and we may need to reset the database often. To set the DB to SQLite:
|
|
||||||
```sh
|
|
||||||
node tools/modifyConfiguration.js databaseType=sqlite
|
|
||||||
```
|
|
||||||
You can confirm this worked by checking conf.json for the following line
|
|
||||||
\[near the end of the file\]:
|
|
||||||
```json
|
|
||||||
"databaseType": "sqlite"
|
|
||||||
```
|
|
||||||
|
|
||||||
Currently Shinobi doesn't use a model framework or seeding system, so setting up the database
|
|
||||||
basically involves copying the pre-set instance bundled with the repository:
|
|
||||||
```sh
|
|
||||||
cp sql/shinobi.sample.sqlite shinobi.sqlite
|
|
||||||
```
|
|
||||||
|
|
||||||
### Resetting the DB
|
|
||||||
If you need to reset the database, you can now do so by deleting the shiobi.sqlite file and
|
|
||||||
copying the sql/shinobi.sample.sqlite file again. Just be sure to stop any running Shinobi
|
|
||||||
instances before you do so.
|
|
||||||
|
|
||||||
Enabling the Super User Interface
|
Enabling the Super User Interface
|
||||||
---------------------------------
|
---------------------------------
|
||||||
|
@ -113,4 +98,8 @@ and "cron" processes directy. To monitor output, we recommend you use a terminal
|
||||||
byobu, tmux, or screen. In one terminal window, run ```node cron.js``` and in another run
|
byobu, tmux, or screen. In one terminal window, run ```node cron.js``` and in another run
|
||||||
```node camera.js```. Shinobi should now be running on port 8080 on your local machine (you can
|
```node camera.js```. Shinobi should now be running on port 8080 on your local machine (you can
|
||||||
change the port in conf.json) and accessable at http://localhost:8080 in your browser. Any source
|
change the port in conf.json) and accessable at http://localhost:8080 in your browser. Any source
|
||||||
code changes you make will require restarting either the camera or cron process [or both].
|
code changes you make will require restarting either the camera or cron process [or both]. To avoid manually restarting, use the npm package `nodemon`. Run these commands in two separate terminals.
|
||||||
|
```sh
|
||||||
|
npx nodemon server.js
|
||||||
|
npx nodemon cron.js
|
||||||
|
```
|
||||||
|
|
Loading…
Reference in New Issue