with '#' will be ignored, and an empty message aborts the commit. Author: Ethan Alicea <64653625+Tech-Gamer@users.noreply.github.com> On branch develop Your branch is up to date with 'origin/develop'. Changes to be committed: modified: .github/workflows/push.yaml modified: .github/workflows/release.yaml modified: CHANGELOG.md modified: Dockerfile modified: Makefile modified: README.md modified: cmd/configure.go modified: cmd/diagnostics.go modified: cmd/root.go modified: config/config.go modified: environment/allocations.go modified: environment/docker.go modified: environment/docker/api.go modified: environment/docker/container.go modified: environment/docker/environment.go modified: environment/docker/power.go modified: environment/docker/stats.go modified: environment/environment.go modified: environment/settings.go modified: events/events.go modified: go.mod modified: internal/cron/activity_cron.go modified: internal/cron/cron.go modified: internal/cron/sftp_cron.go modified: internal/database/database.go modified: internal/progress/progress.go modified: internal/progress/progress_test.go modified: loggers/cli/cli.go new file: oryxBuildBinary modified: parser/parser.go modified: remote/http.go modified: remote/servers.go modified: remote/types.go modified: router/downloader/downloader.go modified: router/middleware.go modified: router/middleware/middleware.go modified: router/middleware/request_error.go modified: router/router.go modified: router/router_download.go modified: router/router_server.go modified: router/router_server_backup.go modified: router/router_server_files.go modified: router/router_server_transfer.go modified: router/router_server_ws.go modified: router/router_system.go modified: router/router_transfer.go modified: router/tokens/parser.go modified: router/websocket/listeners.go modified: router/websocket/websocket.go modified: server/activity.go modified: server/backup.go modified: server/backup/backup.go modified: server/backup/backup_local.go modified: server/backup/backup_s3.go modified: server/configuration.go modified: server/console.go modified: server/crash.go modified: server/events.go modified: server/filesystem/archive.go modified: server/filesystem/filesystem.go modified: server/filesystem/filesystem_test.go modified: server/install.go modified: server/installer/installer.go modified: server/listeners.go modified: server/manager.go modified: server/mounts.go modified: server/power.go modified: server/power_test.go modified: server/resources.go modified: server/server.go modified: server/transfer/archive.go modified: server/transfer/source.go modified: server/transfer/transfer.go modified: server/update.go modified: sftp/event.go modified: sftp/handler.go modified: sftp/server.go modified: wings.go
110 lines
3.5 KiB
Go
110 lines
3.5 KiB
Go
package environment
|
|
|
|
import (
|
|
"fmt"
|
|
"strconv"
|
|
|
|
"github.com/docker/go-connections/nat"
|
|
|
|
"github.com/Tech-Gamer/nwy-wings/config"
|
|
)
|
|
|
|
// Defines the allocations available for a given server. When using the Docker environment
|
|
// driver these correspond to mappings for the container that allow external connections.
|
|
type Allocations struct {
|
|
// ForceOutgoingIP causes a dedicated bridge network to be created for the
|
|
// server with a special option, causing Docker to SNAT outgoing traffic to
|
|
// the DefaultMapping's IP. This is important to servers which rely on external
|
|
// services that check the IP of the server (Source Engine servers, for example).
|
|
ForceOutgoingIP bool `json:"force_outgoing_ip"`
|
|
// Defines the default allocation that should be used for this server. This is
|
|
// what will be used for {SERVER_IP} and {SERVER_PORT} when modifying configuration
|
|
// files or the startup arguments for a server.
|
|
DefaultMapping struct {
|
|
Ip string `json:"ip"`
|
|
Port int `json:"port"`
|
|
} `json:"default"`
|
|
|
|
// Mappings contains all the ports that should be assigned to a given server
|
|
// attached to the IP they correspond to.
|
|
Mappings map[string][]int `json:"mappings"`
|
|
}
|
|
|
|
// Converts the server allocation mappings into a format that can be understood by Docker. While
|
|
// we do strive to support multiple environments, using Docker's standardized format for the
|
|
// bindings certainly makes life a little easier for managing things.
|
|
//
|
|
// You'll want to use DockerBindings() if you need to re-map 127.0.0.1 to the Docker interface.
|
|
func (a *Allocations) Bindings() nat.PortMap {
|
|
out := nat.PortMap{}
|
|
|
|
for ip, ports := range a.Mappings {
|
|
for _, port := range ports {
|
|
// Skip over invalid ports.
|
|
if port < 1 || port > 65535 {
|
|
continue
|
|
}
|
|
|
|
binding := nat.PortBinding{
|
|
HostIP: ip,
|
|
HostPort: strconv.Itoa(port),
|
|
}
|
|
|
|
tcp := nat.Port(fmt.Sprintf("%d/tcp", port))
|
|
udp := nat.Port(fmt.Sprintf("%d/udp", port))
|
|
|
|
out[tcp] = append(out[tcp], binding)
|
|
out[udp] = append(out[udp], binding)
|
|
}
|
|
}
|
|
|
|
return out
|
|
}
|
|
|
|
// Returns the bindings for the server in a way that is supported correctly by Docker. This replaces
|
|
// any reference to 127.0.0.1 with the IP of the pterodactyl0 network interface which will allow the
|
|
// server to operate on a local address while still being accessible by other containers.
|
|
func (a *Allocations) DockerBindings() nat.PortMap {
|
|
iface := config.Get().Docker.Network.Interface
|
|
|
|
out := a.Bindings()
|
|
// Loop over all the bindings for this container, and convert any that reference 127.0.0.1
|
|
// to use the pterodactyl0 network interface IP, as that is the true local for what people are
|
|
// trying to do when creating servers.
|
|
for p, binds := range out {
|
|
for i, alloc := range binds {
|
|
if alloc.HostIP != "127.0.0.1" {
|
|
continue
|
|
}
|
|
|
|
// If using ISPN just delete the local allocation from the server.
|
|
if config.Get().Docker.Network.ISPN {
|
|
out[p] = append(out[p][:i], out[p][i+1:]...)
|
|
} else {
|
|
out[p][i] = nat.PortBinding{
|
|
HostIP: iface,
|
|
HostPort: alloc.HostPort,
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
return out
|
|
}
|
|
|
|
// Converts the server allocation mappings into a PortSet that can be understood
|
|
// by Docker. This formatting is slightly different than "Bindings" as it should
|
|
// return an empty struct rather than a binding.
|
|
//
|
|
// To accomplish this, we'll just get the values from "DockerBindings" and then set them
|
|
// to empty structs. Because why not.
|
|
func (a *Allocations) Exposed() nat.PortSet {
|
|
out := nat.PortSet{}
|
|
|
|
for port := range a.DockerBindings() {
|
|
out[port] = struct{}{}
|
|
}
|
|
|
|
return out
|
|
}
|