2016-11-02 21:04:01 -04:00
[![Build Status ](https://travis-ci.org/MajorMJR/factorio-server-manager.svg?branch=master )](https://travis-ci.org/MajorMJR/factorio-server-manager) [![Docker Pulls ](https://img.shields.io/docker/pulls/mashape/kong.svg )](https://hub.docker.com/r/majormjr/factorio-server-manager/)
2016-05-08 09:30:18 -04:00
2016-04-19 22:00:40 -04:00
#Factorio Server Manager
2016-04-19 13:55:21 -04:00
2016-04-27 11:30:25 -04:00
###A tool for managing Factorio servers.
This tool runs on a Factorio server and allows management of the Factorio server, saves, mods and many other features.
## Features
* Allows control of the Factorio Server, starting and stopping the Factorio binary.
* Allows the management of save files, upload, download and delete saves.
* Manage installed mods, upload new ones, delete uneeded mods. Enable or disable individual mods.
* Allow viewing of the server logs and current configuration.
2016-04-30 21:14:59 -04:00
* Authentication for protecting against unauthorized users
* Available as a Docker container
2016-04-27 11:30:25 -04:00
2016-11-02 18:18:47 -04:00
## Installation Docker
1. Pull the Docker container from Docker Hub using the pull command
```
docker pull majormjr/factorio-server-manager
```
2. Now you can start the container by running:
```
docker run --name factorio-manager -d -p 80:80 -p 443:443 -p 34197:34197/udp majormjr/factorio-server-manager
```
2016-10-07 13:21:39 -04:00
## Installation Linux
2016-04-25 00:32:06 -04:00
1. Download the latest release
* [https://github.com/MajorMJR/factorio-server-manager/releases ](https://github.com/MajorMJR/factorio-server-manager/releases )
2016-04-27 11:30:25 -04:00
2. Download the Factorio Standalone server and install to a known directory.
3. Run the server binary file, use the --dir flag to point the management server to your Factorio installation.
2016-04-27 13:38:19 -04:00
* ```./factorio-server-manager --dir /home/user/.factorio ` ``
2016-04-27 11:30:25 -04:00
4. Visit [localhost:8080 ](localhost:8080 ) in your web browser.
2016-04-19 22:00:40 -04:00
2016-10-07 13:21:39 -04:00
## Installation Windows
2016-10-11 09:55:00 -04:00
1. Download the latest release
2016-10-07 13:21:39 -04:00
* [https://github.com/MajorMJR/factorio-server-manager/releases ](https://github.com/MajorMJR/factorio-server-manager/releases )
2016-10-11 09:55:00 -04:00
2. Download the Factorio Standalone server and install to a known directory.
3. Run the server binary file via cmd or Powershell, use the --dir flag to point the management server to your Factorio installation.
2016-10-11 12:30:27 -04:00
* ```.\factorio-server-manager --dir C:/Users/username/Factorio` ``
2016-10-11 09:55:00 -04:00
4. Visit [localhost:8080 ](localhost:8080 ) in your web browser.
2016-10-07 13:21:39 -04:00
2016-04-19 22:53:42 -04:00
## Usage
2016-04-30 21:15:24 -04:00
Run the UI server and specify the directory of your Factorio server installation and the interface to run the HTTP server on. Edit the conf.json file with your desired credentials for authentication.
2016-04-19 22:53:42 -04:00
```
Usage of ./factorio-server-manager:
2016-04-24 19:07:00 -04:00
-bin string
2016-09-27 12:04:00 -03:00
Location of Factorio Server binary file (default "bin/x64/factorio")
-conf string
Specify location of Factorio Server Manager config file. (default "./conf.json")
2016-04-24 19:07:00 -04:00
-config string
2016-09-27 12:04:00 -03:00
Specify location of Factorio config.ini file (default "config/config.ini")
2016-04-19 22:53:42 -04:00
-dir string
2016-09-27 12:04:00 -03:00
Specify location of Factorio directory. (default "./")
2016-04-19 22:53:42 -04:00
-host string
2016-09-27 12:04:00 -03:00
Specify IP for webserver to listen on. (default "0.0.0.0")
2016-04-24 19:07:00 -04:00
-max-upload int
2016-09-27 12:04:00 -03:00
Maximum filesize for uploaded files (default 20MB). (default 20971520)
2016-04-19 22:53:42 -04:00
-port string
2016-09-27 12:04:00 -03:00
Specify a port for the server. (default "8080")
2016-04-19 23:16:36 -04:00
Example:
2016-04-19 13:55:21 -04:00
2016-04-19 23:16:36 -04:00
./factorio-server-manager --dir /home/user/.factorio --host 10.0.0.1
2016-04-19 22:53:42 -04:00
2016-04-19 23:16:36 -04:00
```
2016-04-19 22:53:42 -04:00
2016-04-27 20:19:07 -04:00
## Manage Factorio Server
2016-05-15 10:17:46 -04:00
![Factorio Server Manager Screenshot ](http://i.imgur.com/q7tbzdH.png "Factorio Server Manager" )
2016-04-27 20:19:07 -04:00
## Manage save files
2016-05-15 10:17:46 -04:00
![Factorio Server Manager Screenshot ](http://i.imgur.com/M7kBAhI.png "Factorio Server Manager" )
2016-04-27 20:19:07 -04:00
## Manage mods
2016-05-15 10:17:46 -04:00
![Factorio Server Manager Screenshot ](http://i.imgur.com/L62Yb2W.png "Factorio Server Manager" )
2016-04-27 20:19:07 -04:00
2016-04-20 08:22:51 -04:00
## Development
2016-04-19 22:53:42 -04:00
The backend is built as a REST API via the Go web application.
It also acts as the webserver to serve the front end react application
2016-04-20 08:22:51 -04:00
All api actions are accessible with the /api route. The frontend is accessible from /.
2016-04-19 23:16:36 -04:00
2016-04-27 11:30:25 -04:00
#### Requirements
2016-04-19 23:16:36 -04:00
+ Go 1.6
+ NodeJS 4.2.6
2016-04-20 08:22:51 -04:00
#### Building the Go backend
Go Application which manages the Factorio server.
API requests for managing the Factorio server are sent to /api.
The frontend code is served by a HTTP file server running on /.
```
2016-04-19 23:16:36 -04:00
git clone https://github.com/MajorMJR/factorio-server-manager.git
cd factorio-server-manager
2016-04-19 13:55:21 -04:00
go build
2016-04-20 08:22:51 -04:00
```
#### Building the React frontend
Frontend is built using React and the AdminLTE CSS framework. See app/dist/ for AdminLTE included files and license.
The root of the UI application is served at app/index.html. Run the npm build script and the Go application during development to get live rebuilding of the UI code.
2016-04-19 13:55:21 -04:00
2016-04-20 08:22:51 -04:00
All necessary CSS and Javascript files are included for running the UI.
Transpiled bundle.js application is output to app/bundle.js, 'npm run build' script starts webpack to build the React application for development
```
install nodejs (use nvm)
cd ui/
npm install
npm run build
Start factorio-server-manager binary in another terminal
```
2016-10-11 09:55:00 -04:00
### Building for Windows
1. Download the latest release source zip file
* [https://github.com/MajorMJR/factorio-server-manager/releases ](https://github.com/MajorMJR/factorio-server-manager/releases )
2. Unzip the Factorio Standalone server and move it to a known directory.
3. Download and install Go 1.6 64-bit or 32-bit depending on your operating system, if unsure download 32-bit
* https://storage.googleapis.com/golang/go1.6.windows-amd64.msi 64-bit
* https://storage.googleapis.com/golang/go1.6.windows-386.msi 32-bit
4. Download and install NodeJS 4.2.6 64-bit or 32-bit depending on your operating system, if unsure download 32-bit
* https://nodejs.org/download/release/v4.2.6/node-v4.2.6-x64.msi 64-bit
* https://nodejs.org/download/release/v4.2.6/node-v4.2.6-x86.msi 32-bit
5. Download and install NVM, when asked if you want it to use NodeJS 4.2.6 accept
* https://github.com/coreybutler/nvm-windows/releases/download/1.1.1/nvm-setup.zip
6. You will need to setup GOPATH in environmental settings in windows. You will want to go into Control Panel\System and Security\System From there on the left hand side click "Advanced system settings". A window will open and you need to click Environment Variables.
7. Under System Variables click New. For Variable name use GOPATH and Variable value C:\Go\
Once everything is installed and ready to go you will need to compile the source for windows
1. Open the folder where ever you unzipped from step #2 above.
2. My folder structure is like this "C:\FS\factorio-server-manager\" C:\FS is where my factorio files are located C:\FS\factorio-server-manager\ is where the server manager files are.
3. You will now need to install some dependencies for Go. You will need to open up a command prompt and one at a time type each of these and hit enter before typing the next one.
```
go get github.com/apexskier/httpauth
go get github.com/go-ini/ini
go get github.com/gorilla/mux
go get github.com/hpcloud/tail
```
3. Now you will want to go into the src folder for example "C:\FS\factorio-server-manager\src" once there hold down left shift and right click an empty area of the folder. Then click "Open command windows here"
4. Type this into the command prompt then hit enter:
```
go build
```
5. Once finished you will now see src.exe or src file inside the folder. You need to move that file to the C:\FS\factorio-server-manager\ or the folder that is before your src folder.
6. From here you need to build the web front-end by going into your ui folder for me its C:\FS\factorio-server-manager\ui\ and again hold shift and left click in an empty area then select open command prompt here. You then need to type this:
```
npm install
npm run build
```
7. Now execute the src file created in step #4 above
8. You can now Visit [localhost:8080 ](localhost:8080 ) in your web browser to start using the Factorio server Manager
2016-04-20 08:22:51 -04:00
## Contributing
1. Fork it!
2. Create your feature branch: `git checkout -b my-new-feature`
3. Commit your changes: `git commit -am 'Add some feature'`
4. Push to the branch: `git push origin my-new-feature`
5. Submit a pull request :D
2016-04-19 23:16:36 -04:00
## Authors
* **Mitch Roote** - [roote.me ](https://roote.me )
## License
This project is licensed under the MIT License - see the [LICENSE.md ](LICENSE.md ) file for details