env-var-mapper
Generate environment variable to CLI argument mapping with prefix support, type conversion, and fallback chains for configuration.
Best use case
env-var-mapper is best used when you need a repeatable AI agent workflow instead of a one-off prompt.
Generate environment variable to CLI argument mapping with prefix support, type conversion, and fallback chains for configuration.
Teams using env-var-mapper should expect a more consistent output, faster repeated execution, less prompt rewriting.
When to use this skill
- You want a reusable workflow that can be run more than once with consistent structure.
When not to use this skill
- You only need a quick one-off answer and do not need a reusable workflow.
- You cannot install or maintain the underlying files, dependencies, or repository context.
Installation
Claude Code / Cursor / Codex
Manual Installation
- Download SKILL.md from GitHub
- Place it in
.claude/skills/env-var-mapper/SKILL.mdinside your project - Restart your AI agent — it will auto-discover the skill
How env-var-mapper Compares
| Feature / Agent | env-var-mapper | Standard Approach |
|---|---|---|
| Platform Support | Not specified | Limited / Varies |
| Context Awareness | High | Baseline |
| Installation Complexity | Unknown | N/A |
Frequently Asked Questions
What does this skill do?
Generate environment variable to CLI argument mapping with prefix support, type conversion, and fallback chains for configuration.
Where can I find the source code?
You can find the source code on GitHub using the link provided at the top of the page.
SKILL.md Source
# Environment Variable Mapper
Generate environment variable to CLI argument mapping for flexible configuration.
## Capabilities
- Generate env var to argument mapping logic
- Create prefix-based environment loading
- Set up type conversion for env vars
- Implement fallback chains (env -> config -> default)
- Configure .env file support
- Generate documentation for env vars
## Usage
Invoke this skill when you need to:
- Map environment variables to CLI arguments
- Create prefix-based config loading
- Implement configuration fallback chains
- Support .env files in CLI applications
## Inputs
| Parameter | Type | Required | Description |
|-----------|------|----------|-------------|
| language | string | Yes | Target language (typescript, python, go) |
| prefix | string | No | Env var prefix (e.g., MYAPP_) |
| mappings | array | Yes | Environment variable mappings |
| dotenvSupport | boolean | No | Enable .env file support (default: true) |
### Mapping Structure
```json
{
"mappings": [
{
"envVar": "PORT",
"argument": "port",
"type": "number",
"default": 3000,
"description": "Server port"
},
{
"envVar": "DATABASE_URL",
"argument": "database-url",
"type": "string",
"required": true,
"sensitive": true
},
{
"envVar": "DEBUG",
"argument": "debug",
"type": "boolean",
"default": false
}
]
}
```
## Generated Code Patterns
### TypeScript Mapper
```typescript
import { config } from 'dotenv';
import { z } from 'zod';
// Load .env file
config();
const ENV_PREFIX = 'MYAPP_';
// Environment schema
const envSchema = z.object({
PORT: z.coerce.number().default(3000),
DATABASE_URL: z.string().min(1),
DEBUG: z.coerce.boolean().default(false),
LOG_LEVEL: z.enum(['debug', 'info', 'warn', 'error']).default('info'),
});
// Get prefixed env var
function getEnv(name: string): string | undefined {
return process.env[`${ENV_PREFIX}${name}`] ?? process.env[name];
}
// Build env object with prefix support
function buildEnvObject(): Record<string, string | undefined> {
return {
PORT: getEnv('PORT'),
DATABASE_URL: getEnv('DATABASE_URL'),
DEBUG: getEnv('DEBUG'),
LOG_LEVEL: getEnv('LOG_LEVEL'),
};
}
// Parse and validate environment
export function loadEnvironment() {
const env = buildEnvObject();
return envSchema.parse(env);
}
// Map env vars to CLI arguments
export function envToArgs(): string[] {
const env = loadEnvironment();
const args: string[] = [];
if (env.PORT !== 3000) {
args.push('--port', String(env.PORT));
}
if (env.DATABASE_URL) {
args.push('--database-url', env.DATABASE_URL);
}
if (env.DEBUG) {
args.push('--debug');
}
if (env.LOG_LEVEL !== 'info') {
args.push('--log-level', env.LOG_LEVEL);
}
return args;
}
// Generate documentation
export const ENV_DOCS = `
Environment Variables:
${ENV_PREFIX}PORT Server port (default: 3000)
${ENV_PREFIX}DATABASE_URL Database connection URL (required)
${ENV_PREFIX}DEBUG Enable debug mode (default: false)
${ENV_PREFIX}LOG_LEVEL Log level: debug|info|warn|error (default: info)
`;
```
### Python Mapper
```python
import os
from dataclasses import dataclass
from typing import Optional
from dotenv import load_dotenv
# Load .env file
load_dotenv()
ENV_PREFIX = 'MYAPP_'
@dataclass
class Environment:
port: int = 3000
database_url: str = ''
debug: bool = False
log_level: str = 'info'
def get_env(name: str) -> Optional[str]:
"""Get env var with prefix fallback."""
return os.getenv(f'{ENV_PREFIX}{name}') or os.getenv(name)
def parse_bool(value: Optional[str]) -> bool:
"""Parse boolean from environment variable."""
if value is None:
return False
return value.lower() in ('true', '1', 'yes', 'on')
def load_environment() -> Environment:
"""Load and validate environment variables."""
env = Environment()
if port := get_env('PORT'):
env.port = int(port)
if database_url := get_env('DATABASE_URL'):
env.database_url = database_url
else:
raise ValueError('DATABASE_URL is required')
env.debug = parse_bool(get_env('DEBUG'))
if log_level := get_env('LOG_LEVEL'):
if log_level not in ('debug', 'info', 'warn', 'error'):
raise ValueError(f'Invalid LOG_LEVEL: {log_level}')
env.log_level = log_level
return env
def env_to_args() -> list[str]:
"""Convert environment to CLI arguments."""
env = load_environment()
args = []
if env.port != 3000:
args.extend(['--port', str(env.port)])
if env.database_url:
args.extend(['--database-url', env.database_url])
if env.debug:
args.append('--debug')
if env.log_level != 'info':
args.extend(['--log-level', env.log_level])
return args
ENV_DOCS = f'''
Environment Variables:
{ENV_PREFIX}PORT Server port (default: 3000)
{ENV_PREFIX}DATABASE_URL Database connection URL (required)
{ENV_PREFIX}DEBUG Enable debug mode (default: false)
{ENV_PREFIX}LOG_LEVEL Log level: debug|info|warn|error (default: info)
'''
```
### Go Mapper
```go
package config
import (
"fmt"
"os"
"strconv"
"strings"
"github.com/joho/godotenv"
)
const EnvPrefix = "MYAPP_"
type Environment struct {
Port int
DatabaseURL string
Debug bool
LogLevel string
}
func init() {
// Load .env file if present
godotenv.Load()
}
func getEnv(name string) string {
if val := os.Getenv(EnvPrefix + name); val != "" {
return val
}
return os.Getenv(name)
}
func parseBool(value string) bool {
lower := strings.ToLower(value)
return lower == "true" || lower == "1" || lower == "yes" || lower == "on"
}
func LoadEnvironment() (*Environment, error) {
env := &Environment{
Port: 3000,
Debug: false,
LogLevel: "info",
}
if port := getEnv("PORT"); port != "" {
p, err := strconv.Atoi(port)
if err != nil {
return nil, fmt.Errorf("invalid PORT: %s", port)
}
env.Port = p
}
env.DatabaseURL = getEnv("DATABASE_URL")
if env.DatabaseURL == "" {
return nil, fmt.Errorf("DATABASE_URL is required")
}
env.Debug = parseBool(getEnv("DEBUG"))
if logLevel := getEnv("LOG_LEVEL"); logLevel != "" {
valid := []string{"debug", "info", "warn", "error"}
found := false
for _, v := range valid {
if v == logLevel {
found = true
break
}
}
if !found {
return nil, fmt.Errorf("invalid LOG_LEVEL: %s", logLevel)
}
env.LogLevel = logLevel
}
return env, nil
}
```
## Workflow
1. **Define mappings** - Specify env vars and arguments
2. **Configure prefix** - Set application prefix
3. **Generate loader** - Create env loading code
4. **Add type conversion** - Handle type coercion
5. **Generate docs** - Create env var documentation
6. **Add validation** - Required and constraints
## Best Practices Applied
- Prefix support for namespacing
- Fallback from prefixed to non-prefixed
- Type-safe env var parsing
- Boolean string parsing
- .env file support
- Auto-generated documentation
## Target Processes
- argument-parser-setup
- configuration-management-system
- cli-application-bootstrapRelated Skills
connected-papers-mapper
Citation graph exploration for discovering related work through visual graph traversal
analogy-mapper
Skill for identifying and mapping analogies across domains
qubit-mapper
Qubit mapping and routing skill for hardware topology optimization
eu-mdr-gspr-mapper
EU MDR General Safety and Performance Requirements (GSPR) mapping and compliance documentation skill
investor-network-mapper
Maps co-investor relationships, syndication history, and network connections
dependency-mapper
Map and visualize cross-project dependencies in programs and portfolios
value-stream-mapper
Value stream mapping skill for current state analysis, waste identification, and future state design with implementation roadmaps
data-lineage-mapper
Extracts and maps data lineage from various sources including SQL, dbt, Airflow, and Spark, generating comprehensive lineage graphs for impact analysis.
mcp-error-code-mapper
Map application errors to MCP error codes with proper messages, error types, and recovery suggestions.
process-builder
Scaffold new babysitter process definitions following SDK patterns, proper structure, and best practices. Guides the 3-phase workflow from research to implementation.
babysitter
Orchestrate via @babysitter. Use this skill when asked to babysit a run, orchestrate a process or whenever it is called explicitly. (babysit, babysitter, orchestrate, orchestrate a run, workflow, etc.)
yolo
Run Babysitter autonomously with minimal manual interruption.