Skip to content

BernardoGomesNegri/tf2-web-server-manager

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

65 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

tf2-web-server-manager

A Team Fortress 2 server manager that runs inside your browser.

To run, start the program "tf2-server-manager" and visit "localhost:3000" on your browser. There, you can log in to your server and run any command as if you were on the server window. It is possible to override the port by passing it as the first parameter to the program i.e. "tf2-server-manager 80" to run it on port 80.

Compiling

Pre-Requisistes

This program depends on GHC, Cabal and Elm. Instructions on how to download each are on their websites. The Makefile needs the Info-Zip "zip" tool installed to make a zip file.

With the Makefile

Run "make" in the directory. This will compile everything and create a folder called "out" for the output. To compile with optimizations, use "make final". Use "make dist" to get a zip file in the "out" folder with the binaries.

With the script

To compile with the script, run "build.ps1" in the root folder inside the root folder. It should work on Linux and Windows. This will compile by default without opimizations. To compile with optimizations, run build.ps1 with the argument "final", it should say "With optimizations ON" if optimizations are on. The output should be at the root of the project, on a folder called "out".

Manually

To manually compile, install GHC, Cabal and Elm, then run cabal build --flags=debug, if you wish to compile with optimizations turned on, then run cabal build on the main directory. The build output will be printed on the terminal. Copy this executable (you don't need any of the other files) to a folder (let's call it "out"). Inside this "out" folder, create a folder called "frontend". Back to the root directory, switch to the "frontend" folder (not the one you just created), then run elm make src/Server.elm --output=outfolder/frontend/server.js, replacing "outfolder" with the folder the executable is located. To compile with optimizations on, use elm make src/Server.elm --output=outfolder/frontend/server.js --optimize. Now run elm make src/Login.elm --output=outfolder/frontend/login.js without changing directory, again replacing "outfolder" with the folder the executable is in. To compile with opimizations, use elm make src/Login.elm --output=outfolder/frontend/login.js --optimize. Now copy every file in frontend/static to outfolder/frontend, given outfolder is your output folder, without using the "static" prefix. Now run the server executable from the same directory it is in (your outfolder)