Node.js Backend avec Express et TypeScript

VérifiéSûr

Runtime Node.js 20 LTS pour développer des services backend avec Express et TypeScript. Gère les opérations asynchrones, les connexions PostgreSQL, le traitement d'images avec Sharp et la configuration d'environnement. À utiliser pour le développement côté serveur avec modules ES et TypeScript.

Spar Skills Guide Bot
DeveloppementIntermédiaire
14002/06/2026
Claude Code
#nodejs#typescript#express#postgresql#backend

Recommandé pour

Notre avis

Fournit des modèles Node.js 20 LTS pour construire des services backend Express + TypeScript avec ESM, PostgreSQL et traitement d'images.

Points forts

  • Couvre le système de modules ESM avec les exigences d'extension
  • Inclut la validation de configuration d'environnement avec valeurs par défaut
  • Fournit une configuration de pool de connexions PostgreSQL avec gestion d'erreurs
  • Montre les modèles async/await et de transactions

Limites

  • Suppose une structure de projet spécifique (backend/src/)
  • Ne couvre pas le déploiement ni les optimisations de production
  • Limité à Node.js 20 LTS, pas les versions plus récentes
Quand l'utiliser

Lors du développement d'un backend Node.js avec Express, TypeScript et PostgreSQL dans un contexte monorepo.

Quand l'éviter

Lors de l'utilisation de modules CommonJS, de bases de données alternatives ou de JavaScript côté client uniquement.

Analyse de sécurité

Sûr
Score qualité90/100

The skill provides Node.js backend patterns and code snippets. It does not instruct the agent to execute destructive commands, exfiltrate data, or bypass safety. Allowed tools like Bash are standard for development but not exploited here.

Aucun point d'attention détecté

Exemples

Create a new database pool
Set up a PostgreSQL connection pool with max 20 connections and 30s idle timeout, using the pg library and ESM.
Implement a transaction with rollback
Show me how to implement a database transaction with rollback in Node.js using the pg pool in ESM.
Validate environment variables
Write a validated environment configuration module with required and optional variables, using dotenv.

name: node description: | Node.js LTS runtime and server-side JavaScript patterns for INVOOPAY backend. Use when: working with backend services, async operations, crypto, Buffer handling, or Node.js APIs. allowed-tools: Read, Edit, Write, Glob, Grep, Bash

Node Skill

Node.js 20 LTS runtime powering Express + TypeScript backend. Uses ES modules ("type": "module") with tsx for development. PostgreSQL via pg with connection pooling. Sharp for image processing.

Quick Start

Module System (ESM)

// backend/src/server.ts - Entry point
import app from './app.js';           // .js extension required for ESM
import { env } from './config/env.js';

app.listen(env.port, () => {
  console.log(`Backend listening on port ${env.port}`);
});

Environment Configuration

// backend/src/config/env.ts - Validated env with defaults
import dotenv from 'dotenv';
dotenv.config();

const required = (value: string | undefined, fallback?: string) => {
  if (value) return value;
  if (fallback !== undefined) return fallback;
  throw new Error('Missing required environment variable');
};

export const env = {
  port: Number(process.env.PORT ?? 4000),
  dbHost: process.env.DB_HOST ?? 'localhost',
  jwtSecret: required(process.env.JWT_SECRET, 'dev-only-secret'),
  nodeEnv: process.env.NODE_ENV ?? 'development',
};

Database Connection Pool

// backend/src/db/client.ts
import pg from 'pg';
const { Pool } = pg;

export const pool = new Pool({
  host: env.dbHost,
  max: 20,                    // Max connections
  idleTimeoutMillis: 30000,   // Close idle after 30s
  connectionTimeoutMillis: 2000,
});

pool.on('error', (err) => {
  console.error('Unexpected error on idle client', err);
  process.exit(-1);           // Crash on pool errors
});

Key Concepts

| Concept | Usage | Example | |---------|-------|---------| | ESM imports | Always use .js extension | import { x } from './mod.js' | | __dirname | Use import.meta.url | path.dirname(fileURLToPath(import.meta.url)) | | Async/await | All I/O operations | await pool.query(...) | | Buffer | Binary data handling | Buffer.from(data, 'hex') | | crypto | Encryption/hashing | crypto.randomBytes(32) |

Common Patterns

Async Service Method

export const productService = {
  async get(id: number, language: string = 'en') {
    const result = await pool.query(
      'SELECT * FROM products WHERE id = $1', [id]
    );
    if (!result.rows[0]) return null;
    return mapProduct(result.rows[0]);
  }
};

Transaction with Rollback

const client = await pool.connect();
try {
  await client.query('BEGIN');
  await client.query('INSERT ...', [...]);
  await client.query('UPDATE ...', [...]);
  await client.query('COMMIT');
} catch (error) {
  await client.query('ROLLBACK');
  throw error;
} finally {
  client.release();  // Always release!
}

See Also

  • patterns - Async patterns, error handling
  • types - TypeScript integration
  • modules - Project structure, imports
  • errors - Error handling patterns

Related Skills

For Express routes and middleware, see the express skill. For database queries, see the postgresql skill. For TypeScript patterns, see the typescript skill.

Skills similaires