v 0.1.96

CLI Reference

The Ecopages CLI is your main tool for developing, building, and serving your application. You typically run it via a script file (e.g., app.ts) using Bun.

Commands

Ecopages supports four main commands that determine the server's behavior.

dev

Starts the development server.

build

Generates a static production build of your project.

preview

Builds your project and starts a local production server for testing.

start

Starts the production server using the existing build in the .eco directory.


Global Flags

These flags can be appended to any command to override default behavior.

FlagTypeDescription
--devbooleanForces development mode regardless of the command.
--buildbooleanForces build mode regardless of the command.
--previewbooleanForces preview mode regardless of the command.
--react-fast-refreshbooleanEnables React Fast Refresh during development.

Environment Variables

Ecopages listens to environment variables for configuration. When these are set, they often override defaults, but specific rules apply for precedence.

Canonical Base URL

Used for generating absolute URLs in production builds (meta tags, sitemaps, etc.).

  1. ConfigBuilder.setBaseUrl(): Highest priority. Set directly in eco.config.ts.
  2. ECOPAGES_BASE_URL: Environment variable override.
  3. Default: http://localhost:3000.

Server Hostname & Port

Used to determine where the server listens.

  1. serverOptions: Highest priority. Passed to the EcopagesApp constructor.
  2. Environment Variables: ECOPAGES_PORT and ECOPAGES_HOSTNAME.
  3. Defaults: localhost:3000.
VariableDescriptionDefault
ECOPAGES_BASE_URLThe canonical base URL of your site.http://localhost:3000
ECOPAGES_PORTThe port the server listens on.3000
ECOPAGES_HOSTNAMEThe hostname the server binds to.localhost
ECOPAGES_LOGGER_DEBUGEnables verbose debug logging.false

Example Usage

Run development server

bun run app.ts dev

Build for production with a specific base URL

ECOPAGES_BASE_URL=https://my-site.com bun run app.ts build

Start the production server

NODE_ENV=production bun run app.ts start