Files
Archive/mieru/apis/server/interface.go
2025-09-25 20:42:17 +02:00

74 lines
2.4 KiB
Go

// Copyright (C) 2025 mieru authors
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program. If not, see <https://www.gnu.org/licenses/>.
package server
import (
"errors"
"github.com/enfein/mieru/v3/pkg/appctl/appctlpb"
)
var (
ErrNoServerConfig = errors.New("no server config")
ErrInvalidServerConfig = errors.New("invalid server config")
ErrServerIsNotRunning = errors.New("server is not running")
ErrStoreServerConfigAfterStart = errors.New("can't store server config after start")
)
// Server contains methods supported by a proxy server.
type Server interface {
ServerConfigurationService
ServerLifecycleService
ServerNetworkService
}
// ServerConfigurationService contains methods to manage proxy server configuration.
type ServerConfigurationService interface {
// Load returns the server config.
// It returns ErrNoServerConfig if server config is never stored.
Load() (*ServerConfig, error)
// Store saves the server config.
// It returns wrapped ErrInvalidServerConfig error
// if the provided server config is invalid.
// It returns ErrStoreServerConfigAfterStart error
// if it is called after start.
Store(*ServerConfig) error
}
// ServerLifecycleService contains methods to manage proxy server lifecycle.
type ServerLifecycleService interface {
// Start activates the server with the stored configuration.
// Calling Start function more than once has undefined behavior.
Start() error
// Stop deactivates the server.
// Established network connections are NOT terminated.
// After stop, the server can't be reused.
Stop() error
// IsRunning returns true if the server has been started
// and has not been stopped.
IsRunning() bool
}
type ServerNetworkService interface{}
// ServerConfig stores proxy server configuration.
type ServerConfig struct {
Config *appctlpb.ServerConfig
}