2020-12-09 18:43:51 +02:00
![.github/workflows/test-workflow.yml ](https://github.com/OpenFactorioServerManager/factorio-server-manager/workflows/.github/workflows/test-workflow.yml/badge.svg )
2016-05-08 15:30:18 +02:00
2017-03-22 22:12:28 +02:00
# Factorio Server Manager
2016-04-19 19:55:21 +02:00
2017-03-22 22:12:28 +02:00
### A tool for managing Factorio servers.
2016-04-27 17:30:25 +02:00
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.
2017-10-21 15:08:42 +02:00
* Manage installed mods, upload new ones and more
* Manage modpacks, so it is easier to play with different configurations
2016-04-27 17:30:25 +02:00
* Allow viewing of the server logs and current configuration.
2016-05-01 03:14:59 +02:00
* Authentication for protecting against unauthorized users
* Available as a Docker container
2016-04-27 17:30:25 +02:00
2016-11-03 00:18:47 +02:00
## Installation Docker
1. Pull the Docker container from Docker Hub using the pull command
```
2020-12-09 18:43:51 +02:00
docker pull ofsm/ofsm:latest
2016-11-03 00:18:47 +02:00
```
2. Now you can start the container by running:
```
2020-12-09 19:11:36 +02:00
docker run --name ofsm -d -p 80:80 -p 34197:34197/udp ofsm/ofsm:latest
2016-11-03 00:18:47 +02:00
```
2016-10-07 19:21:39 +02:00
## Installation Linux
2016-04-25 06:32:06 +02:00
1. Download the latest release
2020-11-21 05:28:43 +02:00
* [https://github.com/OpenFactorioServerManager/factorio-server-manager/releases ](https://github.com/OpenFactorioServerManager/factorio-server-manager/releases )
2017-12-22 02:17:32 +02:00
2. Download the Factorio Standalone server and install to a known directory.
2019-05-10 04:55:34 +02:00
3. Run the server binary file, use the --dir flag to point the management server to your Factorio installation. If you are using the steam installation, point FSM to the steam directory.
2016-04-27 19:38:19 +02:00
* ```./factorio-server-manager --dir /home/user/.factorio ```
2019-05-10 04:55:34 +02:00
* ```./factorio-server-manager --dir /home/user/.steam/steam/steamapps/common/Factorio ```
2016-04-27 17:30:25 +02:00
4. Visit [localhost:8080 ](localhost:8080 ) in your web browser.
2016-04-20 04:00:40 +02:00
2016-10-07 19:21:39 +02:00
## Installation Windows
2016-10-11 15:55:00 +02:00
1. Download the latest release
2020-11-21 05:28:43 +02:00
* [https://github.com/OpenFactorioServerManager/factorio-server-manager/releases ](https://github.com/OpenFactorioServerManager/factorio-server-manager/releases )
2017-12-22 02:17:32 +02:00
2. Download the Factorio Standalone server and install to a known directory.
2016-10-11 15:55:00 +02:00
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 18:30:27 +02:00
* ```.\factorio-server-manager --dir C:/Users/username/Factorio```
2016-10-11 15:55:00 +02:00
4. Visit [localhost:8080 ](localhost:8080 ) in your web browser.
2016-10-07 19:21:39 +02:00
2016-04-20 04:53:42 +02:00
## Usage
2019-10-30 01:26:59 +02: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-20 04:53:42 +02:00
```
Usage of ./factorio-server-manager:
2016-04-25 01:07:00 +02:00
-bin string
2016-09-27 17:04:00 +02: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-25 01:07:00 +02:00
-config string
2016-09-27 17:04:00 +02:00
Specify location of Factorio config.ini file (default "config/config.ini")
2016-04-20 04:53:42 +02:00
-dir string
2016-09-27 17:04:00 +02:00
Specify location of Factorio directory. (default "./")
2016-04-20 04:53:42 +02:00
-host string
2016-09-27 17:04:00 +02:00
Specify IP for webserver to listen on. (default "0.0.0.0")
2016-04-25 01:07:00 +02:00
-max-upload int
2016-09-27 17:04:00 +02:00
Maximum filesize for uploaded files (default 20MB). (default 20971520)
2016-04-20 04:53:42 +02:00
-port string
2016-09-27 17:04:00 +02:00
Specify a port for the server. (default "8080")
2019-07-24 13:06:40 +02:00
-glibc-custom string
Specify if custom glibc is used (default false) [true/false]
-glibc-loc string
Path to the glibc ld.so file (default "/opt/glibc-2.18/lib/ld-2.18.so")
-glibc-lib-loc
Path to the glibc lib folder (default "/opt/glibc-2.18/lib")
2020-08-18 07:13:57 +02:00
-autostart
Autostarts Factorio Server when FSM is starting. Default false [true/false]
(If no IP and/or port provided at startup, it will bind the factorio server to all interfaces
and set the server port to the default 34197, always loads latest save)
2016-04-20 05:16:36 +02:00
Example:
2016-04-19 19:55:21 +02:00
2016-04-20 05:16:36 +02:00
./factorio-server-manager --dir /home/user/.factorio --host 10.0.0.1
2016-04-20 04:53:42 +02:00
2019-07-24 13:06:40 +02:00
Custom glibc example:
./factorio-server-manager --dir /home/user/.factorio --host 10.0.0.1 --glibc-custom true --glibc-loc /opt/glibc-2.18/lib/ld-2.18.so --glibc-lib-loc /opt/glibc-2.18/lib
2016-04-20 05:16:36 +02:00
```
2016-04-20 04:53:42 +02:00
2016-04-28 02:19:07 +02:00
## Manage Factorio Server
2020-11-14 00:07:38 +02:00
![Factorio Server Manager Screenshot ](screenshots/Screenshot_Controls.png )
2016-04-28 02:19:07 +02:00
## Manage save files
2020-11-14 00:07:38 +02:00
![Factorio Server Manager Screenshot ](screenshots/Screenshot_Saves.png )
2016-04-28 02:19:07 +02:00
## Manage mods
2020-11-14 00:07:38 +02:00
![Factorio Server Manager Screenshot ](screenshots/Screenshot_Mods.png )
2016-04-28 02:19:07 +02:00
2016-04-20 14:22:51 +02:00
## Development
2017-12-22 02:17:32 +02:00
The backend is built as a REST API via the Go web application.
2016-04-20 04:53:42 +02:00
It also acts as the webserver to serve the front end react application
2016-04-20 14:22:51 +02:00
All api actions are accessible with the /api route. The frontend is accessible from /.
2016-04-20 05:16:36 +02:00
2020-12-19 05:16:51 +02:00
### API Auth
To authenticate with the API and get access to its functionality, you need to login first.
Here is a small example showing how to do it with a local install using default credentials, via the tool curl:
```
curl --cookie-jar cookie.txt --insecure --data '{"username":"admin","password":"factorio"}' -H "Content-Type: application/json" -X POST https://localhost/api/login
curl --cookie cookie.txt --insecure https://localhost/api/server/status
```
2016-04-27 17:30:25 +02:00
#### Requirements
2019-10-30 01:26:59 +02:00
+ Go 1.11
2020-01-29 17:39:31 +02:00
+ NodeJS >10.13.0
2016-04-20 05:16:36 +02:00
2017-12-22 00:50:29 +02:00
#### Building Releases
Creates a release zip for windows and linux: (this will install the dependencies listed in gopkgdeps)
```
2020-11-21 05:28:43 +02:00
git clone git@github.com:OpenFactorioServerManager/factorio-server-manager.git
2017-12-22 00:50:29 +02:00
cd factorio-server-manager
make gen_release
```
2016-04-20 14:22:51 +02:00
2017-12-22 00:50:29 +02:00
#### Building a Testing Binary:
2016-04-20 14:22:51 +02:00
```
2020-11-21 05:28:43 +02:00
git clone git@github.com:OpenFactorioServerManager/factorio-server-manager.git
2016-04-20 05:16:36 +02:00
cd factorio-server-manager
2017-12-22 00:50:29 +02:00
make
./factorio-server-manager/factorio-server-manager
2016-04-20 14:22:51 +02:00
```
2017-12-22 00:50:29 +02:00
#### Building the React Frontend alone
2018-08-12 02:24:31 +02:00
Frontend is built using React and the AdminLTE CSS framework.
2016-04-20 14:22:51 +02:00
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 19:55:21 +02:00
2016-04-20 14:22:51 +02:00
All necessary CSS and Javascript files are included for running the UI.
2017-01-23 04:26:55 +02:00
Transpiled bundle.js application is output to app/bundle.js, 'npm run build' script starts webpack to build the React application for development.
2016-04-20 14:22:51 +02:00
```
2018-08-12 02:24:31 +02:00
make app/bundle
2016-04-20 14:22:51 +02:00
```
2018-08-12 02:24:31 +02:00
##### For development
2019-10-30 01:26:59 +02:00
The frontend is completely build by npm with laravel-mix. All plugins are build into the compiled files. No plugins need to be load fro external sources.
2018-08-12 02:24:31 +02:00
It has different variants to build the frontend, provided by laravel-mix:
- `npm run dev` Build the code for development. This will also generate map-files, so the browser, can show, what line and file causes the output.
- `npm run watch` Build the code for development like the dev-command. This will not stop and automatically rebuild, when files are changed and saved.
- `npm run hot` Build the code for development. It has the same behaviour like the watch-command and also causes a hotReload of the files inside the browser (in theory)
- `npm run build` Build the code for deployment. It will generate no map-files and also minifies the bundle-files.
In every of those cases, also images and fonts will be copied to the app-folder.
2016-10-11 15:55:00 +02:00
### Building for Windows
1. Download the latest release source zip file
2020-11-21 05:28:43 +02:00
* [https://github.com/OpenFactorioServerManager/factorio-server-manager/releases ](https://github.com/OpenFactorioServerManager/factorio-server-manager/releases )
2017-12-22 02:17:32 +02:00
2. Unzip the Factorio Standalone server and move it to a known directory.
2019-10-30 01:26:59 +02:00
3. Download and install Go 1.11 or newer. https://golang.org/dl/
4. Download and install NodeJS 64-bit or 32-bit depending on your operating system, most users need 64-bit nowadays.
* https://nodejs.org/dist/v12.13.0/node-v12.13.0-x64.msi 64-bit
* https://nodejs.org/dist/v12.13.0/node-v12.13.0-x86.msi 32-bit
2016-10-11 15:55:00 +02:00
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.
2019-10-30 01:26:59 +02:00
3. Now you will want to go into the src folder for example "C:\FS\factorio-server-manager\src" once there hold down shift and right click an empty area of the folder. Then click "Open command windows here"
2016-10-11 15:55:00 +02:00
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.
2019-10-30 01:26:59 +02:00
6. From here you need to build the web front-end. Again hold shift and right click in an empty area then select open command prompt here. You then need to type this:
2016-10-11 15:55:00 +02:00
```
npm install
npm run build
```
2019-10-30 01:26:59 +02:00
7. Now execute the src file created in step #4 above. You have to specify the directory, where the factorio-server is located, as parameter. More about the parameter under [Usage ](#Usage )
2016-10-11 15:55:00 +02:00
8. You can now Visit [localhost:8080 ](localhost:8080 ) in your web browser to start using the Factorio server Manager
2016-04-20 14:22:51 +02: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'`
2019-10-31 18:35:41 +02:00
4. Add your changes a in human readable way into CHANGELOG.md
2016-04-20 14:22:51 +02:00
4. Push to the branch: `git push origin my-new-feature`
5. Submit a pull request :D
2016-04-20 05:16:36 +02:00
## Authors
2016-12-19 16:41:21 +02:00
* **Mitch Roote** - [roote.ca ](https://roote.ca )
2020-12-09 18:43:51 +02:00
* **[knoxfighter](https://github.com/knoxfighter)**
* **[Jannaahs](https://github.com/jannaahs)**
2016-04-20 05:16:36 +02:00
2018-07-18 04:27:14 +02:00
## Special Thanks
2020-11-21 05:28:43 +02:00
- **[All Contributions](https://github.com/OpenFactorioServerManager/factorio-server-manager/graphs/contributors)**
2018-07-18 04:27:14 +02:00
- **mickael9** for reverseengineering the factorio-save-file: https://forums.factorio.com/viewtopic.php?f=5& t=8568#
2016-04-20 05:16:36 +02:00
## License
This project is licensed under the MIT License - see the [LICENSE.md ](LICENSE.md ) file for details