Skip to content

A mod that provide you with some ways to manage your saves.

License

Notifications You must be signed in to change notification settings

DSFdsfWxp/savemaster

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

16 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

saveMaster

A Mindustry mod to manage saves. Provides a variety of practical functions.

Functions

  • Save editor
  • Multiplayer
  • Cloud save (need to deploy it by yourself)

How to install

You need to download the released mod from github manually then import.

How to use

You'll find a new option in setting.
Then explore by yourself. It's not complex.

Cloud Save

deploy on cloudflare

Use cloudflare's workers and kv to build a free server. The code needed is in /cloud.

  1. Make sure you have a cloudflare account.
  2. Create a worker.
  3. Create a kv.
  4. Bind the kv to the worker with a variable name db.
  5. Create environment variable key for the worker, puting the key to access this server (key ≈ password here).
  6. Paste code in /cloud/worker.js into your worker (Remove all the code in worker first) then deploy.

config in game

  1. Settings -> saveMaster -> Saves Manager -> Cloud Save Option
  2. Paste the url of your worker to Server Address (e.g. example.workers.dev)
  3. Input the key you set in your worker. (environment variable key)
  4. Pick a name for you save. Note that different devices with the same save name will use the same cloud save slot (linked to the same cloud save).
  5. Enable the cloud save (it's enabled when it shows CloudSave: Enable)
  6. Save the config

protocol

You can also write a server by yourself. Follow this protocol so it will work for this mod.

read

Function: Read save
Interface: /read
Method: GET
Header:

  • key: the key to access the server
  • name: save name
  • time: The time when the save was last synchronized, in the form of 20240101123000, used to determine whether the local save needs to be updated

Returns: The request returns only 304 if the time passed in is newer than the one on the server. If an save named name is not found on the server, the request simply returns 404. Otherwise return the save file.

write

Function: Write save
Interface: /write
Method: POST
Header:

  • key: the key to access the server
  • name: save name
  • time: save creation time

Payload: save file
Return: 200 is returned if the writing is successful.

remove

Function: Delete save
Interface: /remove
Method: GET
Header:

  • key: the key to access the server
  • name: save name Return: 200 is returned if the deletion is successful.

limit

Function: Get server limits
Interface: /limit
Method: GET
Header:

  • key: the key to access the server

Return the limitations of the server (only include maxPayloadSize and maxNameSize), for example:

{
   "maxPayloadSize": 26214400,
   "maxNameSize": 512
}

maxPayloadSize: max size of the save (byte).
maxNameSize: max size of the save name (byte).

About

A mod that provide you with some ways to manage your saves.

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published