Node.js Backend avec Express et TypeScript

VérifiéSûr

Runtime Node.js 20 LTS pour services backend utilisant Express, TypeScript et PostgreSQL. Couvre les patterns asynchrones, la gestion de pools de connexion et les opérations cryptographiques.

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

Recommandé pour

Notre avis

Fournit des modèles et bonnes pratiques pour construire des backends Node.js avec Express, TypeScript et PostgreSQL.

Points forts

  • Couvre le système de modules ESM avec extensions .js
  • Inclut la configuration d'environnement validée
  • Présente le pooling de connexion PostgreSQL avec gestion d'erreurs
  • Montre les motifs asynchrones et les transactions avec rollback

Limites

  • Centré sur un projet spécifique (INVOOPAY), non générique
  • Ne couvre pas les tests ou le déploiement
  • Version Node.js 20 uniquement
Quand l'utiliser

Lorsque vous développez un backend Node.js avec Express et TypeScript nécessitant une gestion fiable des connexions et des transactions.

Quand l'éviter

Pour des projets backend simples sans base de données ou n'utilisant pas Express/TypeScript.

Analyse de sécurité

Sûr
Score qualité88/100

The skill provides safe Node.js backend patterns with no destructive commands, no exfiltration, and no obfuscated code. Allowed tools include Bash but no malicious instructions are given.

Aucun point d'attention détecté

Exemples

Create Express endpoint with async query
Use the Node skill to add a new GET endpoint /products/:id that fetches a product from PostgreSQL using async/await and returns JSON.
Database transaction with rollback
Write a Node.js service function that inserts data into two related tables within a PostgreSQL transaction, rolling back on error.

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