Skip to content

CLI Commands ​

Asena CLI provides command-line utilities to help you manage your Asena applications efficiently.

Installation ​

Prerequisite: Bun runtime (v1.2.8 or higher)

bash
bun install -g @asenajs/asena-cli

Verify installation:

bash
asena --version

asena create ​

Bootstrap a new Asena project with a complete development environment setup.

Features ​

  • Interactive Setup - User-friendly setup experience with inquirer
  • Non-Interactive Mode - Support for SSH and CI/CD environments with CLI arguments
  • Multi-Adapter Support - Choose between Hono or Ergenecore adapters
  • Project Structure - Creates complete project structure with necessary files
  • Default Components - Generates default controller and server setup
  • Development Tools - Optional ESLint and Prettier integration
  • Dependency Management - Automatically installs required dependencies

Usage ​

Interactive Mode (prompts for all options):

bash
asena create
# or create in current directory
asena create .

SSH Connection Issue

Interactive prompts may not work properly over SSH connections or in non-TTY environments (CI/CD pipelines). Use non-interactive mode instead.

Non-Interactive Mode (specify options via CLI arguments):

bash
# Create with all features enabled
asena create my-project --adapter=hono --logger --eslint --prettier

# Create in current directory without optional features
asena create . --adapter=ergenecore --no-logger --no-eslint --no-prettier

# Mix of CLI arguments and interactive prompts
asena create my-app --adapter=hono  # Will prompt for remaining options

CLI Options ​

OptionDescriptionValuesDefault
[project-name]Project name (use . for current directory)Any stringPrompted
--adapter <adapter>Adapter to usehono, ergenecorePrompted
--logger / --no-loggerSetup Asena loggerbooleantrue
--eslint / --no-eslintSetup ESLintbooleantrue
--prettier / --no-prettierSetup Prettierbooleantrue

Interactive Prompts ​

When using interactive mode without CLI arguments:

bash
✔ Enter your project name: my-asena-app
✔ Select adapter: Ergenecore
✔ Do you want to setup logger? Yes
✔ Do you want to setup ESLint? Yes
✔ Do you want to setup Prettier? Yes
â ™ Creating asena project...

Generated Project Structure ​

my-asena-app/
├── src/
│   ├── controllers/    # Route controllers
│   ├── services/       # Business logic
│   ├── middlewares/    # Middleware files
│   ├── config/         # Server configuration classes
│   ├── namespaces/     # WebSocket namespaces
│   └── index.ts        # Application entry point
├── tests/              # Test files
├── public/             # Static assets
├── asena.config.ts     # Configuration
├── package.json
└── tsconfig.json

asena generate ​

Quickly and consistently create project components with proper structure and imports.

Shortcut: asena g

Features ​

  • Multi-Component Support - Generate controllers, services, middlewares, configs, and websockets
  • Automatic Code Generation - Creates template code with base structure and necessary imports
  • Adapter-Aware - Generates adapter-specific code based on project configuration
  • Suffix Configuration - Customize component naming conventions (see Suffix Configuration)
  • Project Structure Integration - Places files in the correct directories
  • Command Shortcuts - Faster usage with aliases

Commands ​

ComponentFull CommandShortcutDescription
Controllerasena generate controllerasena g cGenerates a controller
Serviceasena generate serviceasena g sGenerates a service
Middlewareasena generate middlewareasena g mGenerates a middleware
Configasena generate configasena g configGenerates a server config
WebSocketasena generate websocketasena g wsGenerates a WebSocket namespace

Examples ​

Generate Controller ​

bash
asena g c
# or
asena generate controller

Prompt:

bash
✔ Enter controller name: User

Generated: src/controllers/UserController.ts

typescript
import { Controller } from '@asenajs/asena/server';
import { Get } from '@asenajs/asena/web';
import type { Context } from '@asenajs/ergenecore/types';

@Controller('/user')
export class UserController {
  @Get({ path: '/' })
  async index(context: Context) {
    return context.send({ message: 'Hello from UserController!' });
  }
}

Generate Service ​

bash
asena g s
# or
asena generate service

Prompt:

bash
✔ Enter service name: User

Generated: src/services/UserService.ts

typescript
import { Service } from '@asenajs/asena/server';

@Service()
export class UserService {
  async getUsers() {
    // Add your business logic here
    return [];
  }
}

Generate Middleware ​

bash
asena g m
# or
asena generate middleware

Prompt:

bash
✔ Enter middleware name: Auth

Generated: src/middlewares/AuthMiddleware.ts

typescript
import { Middleware } from '@asenajs/asena/server';
import { MiddlewareService, type Context } from '@asenajs/ergenecore';

@Middleware()
export class AuthMiddleware extends MiddlewareService {
  async handle(context: Context, next: () => Promise<void>) {
    // Add your middleware logic here
    await next();
  }
}

Generate Config ​

bash
asena g config
# or
asena generate config

Prompt:

bash
✔ Enter config name: Server

Generated: src/config/ServerConfig.ts

typescript
import { Config } from '@asenajs/asena/server';
import { ConfigService, type Context } from '@asenajs/ergenecore';

@Config()
export class ServerConfig extends ConfigService {
  onError(error: Error, context: Context): Response {
    console.error('Error:', error);
    return context.send({ error: 'Internal server error' }, 500);
  }
}

Generate WebSocket ​

bash
asena g ws
# or
asena generate websocket

Prompt:

bash
✔ Enter websocket namespace name: Chat

Generated: src/namespaces/ChatNamespace.ts

typescript
import { Websocket } from '@asenajs/asena/server';
import { WebsocketService, type Context } from '@asenajs/ergenecore';

@Websocket({ namespace: '/chat' })
export class ChatNamespace extends WebsocketService {
  onConnect(context: Context): void {
    console.log('Client connected to /chat');
  }

  onMessage(context: Context, message: any): void {
    console.log('Message received:', message);
  }

  onDisconnect(context: Context): void {
    console.log('Client disconnected from /chat');
  }
}

Adapter-Specific Generation

The CLI automatically detects your adapter (Ergenecore or Hono) from asena.config.ts and generates appropriate imports and base classes.

asena dev start ​

Start the application in development mode with automatic building.

Features ​

  • Automatic Build - Builds the project before starting
  • Component Registration - Automatically registers all controllers, services, and middlewares
  • Hot Reload - Restarts server on file changes (when used with --watch)

Usage ​

bash
asena dev start

Output ​

Build completed successfully.
2025-10-15 14:30:19 [info]:
    ___    _____  ______ _   __ ___
   /   |  / ___/ / ____// | / //   |
  / /| |  \__ \ / __/  /  |/ // /| |
 / ___ | ___/ // /___ / /|  // ___ |
/_/  |_|/____//_____//_/ |_//_/  |_|

2025-10-15 14:30:20 [info]:   Adapter: ErgenecoreAdapter implemented
2025-10-15 14:30:20 [info]:   All components registered and ready to use
2025-10-15 14:30:20 [info]:   Controller: UserController found:
2025-10-15 14:30:20 [info]:   Successfully registered GET route for PATH: /users
2025-10-15 14:30:20 [info]:   Controller: UserController successfully registered.
2025-10-15 14:30:20 [info]:   Server started on port 3000

Controller Names in Output

Controller names are visible in logs when buildOptions.minify.identifiers is set to false in asena.config.ts.

asena build ​

Build the project for production deployment.

Features ​

  • Configuration Processing - Reads and processes asena.config.ts
  • Code Generation - Creates a temporary build file combining all components
  • Import Management - Automatically organizes imports based on project structure
  • Server Integration - Integrates all components with AsenaServer
  • No Manual Registration - Controllers are automatically discovered and registered

Usage ​

bash
asena build

Build Process ​

  1. Reads asena.config.ts
  2. Scans source folder for controllers, services, middlewares, configs, and websockets
  3. Generates a temporary build file with all imports
  4. Bundles the application using Bun's bundler
  5. Outputs compiled files to buildOptions.outdir (default: dist/)

Build Output ​

Build completed successfully.
Output: dist/index.js

Production Deployment

After building, you can run your application with:

bash
bun dist/index.asena.js

asena init ​

Initialize an existing project with Asena configuration.

Features ​

  • Configuration Generation - Creates asena.config.ts
  • Default Values - Provides sensible defaults for quick start
  • No Need if Using create - Not required if you used asena create

Usage ​

bash
asena init

Generated Configuration ​

Creates asena.config.ts:

typescript
import { defineConfig } from '@asenajs/asena-cli';

export default defineConfig({
  sourceFolder: 'src',
  rootFile: 'src/index.ts',
  buildOptions: {
    outdir: 'dist',
    sourcemap: 'linked',
    target: 'bun',
    minify: {
      whitespace: true,
      syntax: true,
      identifiers: false,
    },
  },
});

When to Use asena init

Use asena init when:

  • Adding Asena to an existing project
  • Manually setting up a project without asena create
  • Resetting configuration to defaults

Command Reference ​

Quick Reference ​

CommandShortcutDescription
asena create-Create a new Asena project
asena generateasena gGenerate project components
asena generate controllerasena g cGenerate a controller
asena generate serviceasena g sGenerate a service
asena generate middlewareasena g mGenerate a middleware
asena generate configasena g configGenerate a config
asena generate websocketasena g wsGenerate a WebSocket namespace
asena dev start-Start development server
asena build-Build for production
asena init-Initialize configuration
asena --versionasena -vShow CLI version
asena --helpasena -hShow help

Next Steps:

Released under the MIT License.