Expand description
§Command Line Interface Module
This module provides a secure and robust command-line interface (CLI) for the Static Site Generator (SSG). It handles argument parsing, configuration management, and validation of user inputs to ensure that the static site generator operates reliably and securely.
§Key Features
- Safe path handling (including symbolic link checks and canonicalization)
- Input validation (URL, language, environment variables)
- Secure configuration with size-limited config files
- Builder pattern for convenient configuration construction
- Error handling via
CliError
§Example Usage
use ssg::cmd::{Cli, SsgConfig};
fn main() -> anyhow::Result<()> {
let matches = Cli::build().get_matches();
// Attempt to load configuration from command-line arguments
let mut config = SsgConfig::from_matches(&matches)?;
println!("Configuration loaded: {:?}", config);
// Continue with application logic...
Ok(())
}Structs§
- Cli
- A simple CLI struct for building the SSG command.
- Language
Code - Type-safe representation of a language code.
- SsgConfig
- Core configuration for the static site generator.
- SsgConfig
Builder - Builder for
SsgConfig.
Enums§
- CliError
- Possible errors that can occur during CLI operations.
Constants§
- DEFAULT_
HOST - Default host for the local development server.
- DEFAULT_
PORT - Default port for the local development server.
- DEFAULT_
SITE_ NAME - Default site name for the configuration.
- DEFAULT_
SITE_ TITLE - Default site title for the configuration.
- MAX_
CONFIG_ SIZE - Maximum allowed size in bytes for config files.
- RESERVED_
NAMES - Reserved names that cannot be used as paths on Windows systems.
Statics§
- DEFAULT_
CONFIG - A static default configuration for the SSG site.
Functions§
- default_
config - Returns a reference to the lazily-initialised default configuration.
- is_
valid_ url - Returns
trueifslooks like a valid HTTP(S) URL. - resolve_
host - Resolve the dev-server host, preferring
$SSG_HOSToverDEFAULT_HOST. - resolve_
port - Resolve the dev-server port, preferring
$SSG_PORToverDEFAULT_PORT. - validate_
url - Validates a URL for security and format.