2019-09-23 03:47:38 +00:00
|
|
|
package api
|
|
|
|
|
|
|
|
import (
|
|
|
|
"encoding/json"
|
|
|
|
"fmt"
|
2019-12-22 21:21:21 +00:00
|
|
|
"github.com/pkg/errors"
|
2019-12-01 02:07:05 +00:00
|
|
|
"github.com/pterodactyl/wings/parser"
|
2019-09-23 03:47:38 +00:00
|
|
|
)
|
|
|
|
|
2019-09-23 04:22:16 +00:00
|
|
|
const (
|
2019-12-01 02:07:05 +00:00
|
|
|
ProcessStopCommand = "command"
|
|
|
|
ProcessStopSignal = "signal"
|
2019-09-23 04:22:16 +00:00
|
|
|
ProcessStopNativeStop = "stop"
|
|
|
|
)
|
|
|
|
|
2019-12-22 21:21:21 +00:00
|
|
|
// Holds the server configuration data returned from the Panel. When a server process
|
|
|
|
// is started, Wings communicates with the Panel to fetch the latest build information
|
|
|
|
// as well as get all of the details needed to parse the given Egg.
|
|
|
|
//
|
|
|
|
// This means we do not need to hit Wings each time part of the server is updated, and
|
|
|
|
// the Panel serves as the source of truth at all times. This also means if a configuration
|
|
|
|
// is accidentally wiped on Wings we can self-recover without too much hassle, so long
|
|
|
|
// as Wings is aware of what servers should exist on it.
|
|
|
|
type ServerConfigurationResponse struct {
|
|
|
|
Settings json.RawMessage `json:"settings"`
|
|
|
|
ProcessConfiguration *ProcessConfiguration `json:"process_configuration"`
|
|
|
|
}
|
|
|
|
|
2019-09-23 03:47:38 +00:00
|
|
|
// Defines the process configuration for a given server instance. This sets what the
|
|
|
|
// daemon is looking for to mark a server as done starting, what to do when stopping,
|
|
|
|
// and what changes to make to the configuration file for a server.
|
2019-12-22 21:21:21 +00:00
|
|
|
type ProcessConfiguration struct {
|
2019-09-23 03:47:38 +00:00
|
|
|
Startup struct {
|
|
|
|
Done string `json:"done"`
|
|
|
|
UserInteraction []string `json:"userInteraction"`
|
|
|
|
} `json:"startup"`
|
|
|
|
Stop struct {
|
|
|
|
Type string `json:"type"`
|
|
|
|
Value string `json:"value"`
|
|
|
|
} `json:"stop"`
|
2019-12-01 02:07:05 +00:00
|
|
|
ConfigurationFiles []parser.ConfigurationFile `json:"configs"`
|
2019-09-23 03:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-12-28 22:57:19 +00:00
|
|
|
// Defines installation script information for a server process. This is used when
|
|
|
|
// a server is installed for the first time, and when a server is marked for re-installation.
|
|
|
|
type InstallationScript struct {
|
|
|
|
ContainerImage string `json:"container_image"`
|
|
|
|
Entrypoint string `json:"entrypoint"`
|
|
|
|
Script string `json:"script"`
|
|
|
|
}
|
|
|
|
|
2019-09-23 03:47:38 +00:00
|
|
|
// Fetches the server configuration and returns the struct for it.
|
2019-12-22 21:21:21 +00:00
|
|
|
func (r *PanelRequest) GetServerConfiguration(uuid string) (*ServerConfigurationResponse, *RequestError, error) {
|
|
|
|
resp, err := r.Get(fmt.Sprintf("/servers/%s", uuid))
|
2019-09-23 03:47:38 +00:00
|
|
|
if err != nil {
|
2019-12-22 21:21:21 +00:00
|
|
|
return nil, nil, errors.WithStack(err)
|
2019-09-23 03:47:38 +00:00
|
|
|
}
|
|
|
|
defer resp.Body.Close()
|
|
|
|
|
|
|
|
r.Response = resp
|
|
|
|
|
|
|
|
if r.HasError() {
|
2019-12-17 04:47:35 +00:00
|
|
|
return nil, r.Error(), nil
|
2019-09-23 03:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-12-22 21:21:21 +00:00
|
|
|
res := &ServerConfigurationResponse{}
|
2019-09-23 03:47:38 +00:00
|
|
|
b, _ := r.ReadBody()
|
|
|
|
|
|
|
|
if err := json.Unmarshal(b, res); err != nil {
|
2019-12-22 21:21:21 +00:00
|
|
|
return nil, nil, errors.WithStack(err)
|
2019-09-23 03:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-12-17 04:47:35 +00:00
|
|
|
return res, nil, nil
|
2019-09-23 03:47:38 +00:00
|
|
|
}
|
2019-12-28 22:57:19 +00:00
|
|
|
|
|
|
|
// Fetches installation information for the server process.
|
|
|
|
func (r *PanelRequest) GetInstallationScript(uuid string) (InstallationScript, *RequestError, error) {
|
|
|
|
res := InstallationScript{}
|
|
|
|
|
|
|
|
resp, err := r.Get(fmt.Sprintf("/servers/%s/install", uuid))
|
|
|
|
if err != nil {
|
|
|
|
return res, nil, errors.WithStack(err)
|
|
|
|
}
|
|
|
|
defer resp.Body.Close()
|
|
|
|
|
|
|
|
r.Response = resp
|
|
|
|
|
|
|
|
if r.HasError() {
|
|
|
|
return res, r.Error(), nil
|
|
|
|
}
|
|
|
|
|
|
|
|
b, _ := r.ReadBody()
|
|
|
|
|
|
|
|
if err := json.Unmarshal(b, &res); err != nil {
|
|
|
|
return res, nil, errors.WithStack(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
return res, nil, nil
|
|
|
|
}
|