Monibuca Configuration Mechanism 
Monibuca employs a flexible configuration system that supports multiple configuration methods. Configuration files use the YAML format and can be initialized either through files or by directly passing configuration objects.
Configuration Loading Process 
Configuration initialization occurs during Server startup and can be provided through one of three methods:
- YAML configuration file path
 - Byte array containing YAML configuration content
 - Raw configuration object (RawConfig)
 
Configuration parsing process:
go// Supports three configuration input methods case string: // Configuration file path case []byte: // YAML configuration content case RawConfig: // Raw configuration object
Configuration Structure 
Simplified Configuration Syntax 
When a configuration item's value is a struct or map type, the system supports a simplified configuration approach: if a simple type value is configured directly, that value will be automatically assigned to the first field of the struct.
For example, given the following struct:
type Config struct {
    Port int
    Host string
}You can use simplified syntax:
plugin: 1935  # equivalent to plugin: { port: 1935 }Configuration Deserialization Mechanism 
Each plugin contains a config.Config type field for storing and managing configuration information. The configuration loading priority from highest to lowest is:
- User configuration (via 
ParseUserFile) - Default configuration (via 
ParseDefaultYaml) - Global configuration (via 
ParseGlobal) - Plugin-specific configuration (via 
Parse) - Common configuration (via 
Parse) 
Configurations are automatically deserialized into the plugin's public properties. For example:
type MyPlugin struct {
    Plugin
    Port    int    `yaml:"port"`
    Host    string `yaml:"host"`
}Corresponding YAML configuration:
myplugin:
    port: 8080
    host: "localhost"The configuration will automatically deserialize to the Port and Host fields. You can query configurations using methods provided by Config:
Has(name string)- Check if a configuration existsGet(name string)- Get the value of a configurationGetMap()- Get a map of all configurations
Additionally, plugin configurations support saving modifications:
func (p *Plugin) SaveConfig() (err error)This saves the modified configuration to {settingDir}/{pluginName}.yaml.
Global Configuration 
Global configuration is located under the global node in the YAML file and includes these main configuration items:
global:
  disableall: false         # Whether to disable all plugins
  streamalias:              # Stream alias configuration
    pattern: "target"       # Regex -> target path
  location:                 # HTTP routing rules
    pattern: "target"       # Regex -> target address
  admin:                    # Admin interface configuration
    enablelogin: false      # Whether to enable login mechanism
    filepath: "admin.zip"   # Admin interface file path
    homepage: "home"        # Admin interface homepage
    users:                  # User list (effective only when login is enabled)
      - username: "admin"   # Username
        password: "admin"   # Password
        role: "admin"       # Role (admin/user)Database Configuration 
If database connection is configured, the system will automatically:
- Connect to the database
 - Auto-migrate data models
 - Initialize user data (if login is enabled)
 - Initialize proxy configurations
 
global:
  db:
    dsn: ""                # Database connection string
    dbtype: ""              # Database typeProxy Configuration 
The system supports pull and push proxy configurations:
global:
  pullproxy:              # Pull proxy configuration
    - id: 1              # Proxy ID
      name: "proxy1"     # Proxy name
      url: "rtmp://..."  # Proxy address
      type: "rtmp"       # Proxy type
      pullonstart: true  # Whether to pull on startup
  pushproxy:              # Push proxy configuration
    - id: 1              # Proxy ID
      name: "proxy1"     # Proxy name
      url: "rtmp://..."  # Proxy address
      type: "rtmp"       # Proxy type
      pushonstart: true  # Whether to push on startup
      audio: true        # Whether to push audioPlugin Configuration 
Each plugin can have its own configuration node, named as the lowercase version of the plugin name:
rtmp:                    # RTMP plugin configuration
  tcp: :1935            # Listen port
rtsp:                   # RTSP plugin configuration
  tcp: :554             # Listen portConfiguration Priority 
The configuration system uses a multi-level priority mechanism, from highest to lowest:
URL Query Parameter Configuration - Configurations specified via URL query parameters during publishing or subscribing have the highest priority
Example: rtmp://localhost/live/stream?audio=falsePlugin-Specific Configuration - Configuration items under the plugin's configuration node
yamlrtmp: publish: pubaudio: true subscribe: subaudio: trueGlobal Configuration - Configuration items under the global node
yamlglobal: publish: pubaudio: true subscribe: subaudio: true
Common Configuration 
There are some common configuration items that can appear in both global and plugin configurations. When plugins use these items, they prioritize values from plugin configuration, falling back to global configuration if not set in plugin configuration.
Main common configurations include:
Publish Configuration
yamlpublish: pubaudio: true # Whether to include audio pubvideo: true # Whether to include video bufferlength: 1000 # Buffer lengthSubscribe Configuration
yamlsubscribe: subaudio: true # Whether to subscribe to audio subvideo: true # Whether to subscribe to video bufferlength: 1000 # Buffer lengthHTTP Configuration
yamlhttp: listenaddr: :8080 # Listen addressOther Common Configurations
- PublicIP - Public IP
 - PublicIPv6 - Public IPv6
 - LogLevel - Log level
 - EnableAuth - Whether to enable authentication
 
Usage example:
# Global configuration
global:
  publish:
    pubaudio: true
    pubvideo: true
  subscribe:
    subaudio: true
    subvideo: true
# Plugin configuration (higher priority than global)
rtmp:
  publish:
    pubaudio: false  # Overrides global configuration
  subscribe:
    subvideo: false  # Overrides global configuration
# URL query parameters (highest priority)
# rtmp://localhost/live/stream?subaudio=true&subvideo=falseHot Configuration Update 
Currently, the system supports hot updates for the admin interface file (admin.zip), periodically checking for changes and automatically reloading.
Configuration Validation 
The system performs basic validation of configurations at startup:
- Checks necessary directory permissions
 - Validates database connections
 - Validates user configurations (if login is enabled)