Skip to content

smhg/express-locale

Repository files navigation

express-locale CI

Express middleware to determine the locale identifier of the incomming request.

It returns (only) full locale identifiers based on the middleware's configuration. Configuration defines possible sources, their order and, optionally, a whitelist. For performance reasons, on each request, remaining lookups are ignored as soon as a match is found.

Use version 1.x for Express 3 support and/or older Node versions.

Installation

npm install --save express-locale

Usage

import express from 'express';
import createLocaleMiddleware from 'express-locale';

express()
  .use(createLocaleMiddleware())
  .use((req, res) => {
    res.end(`Request locale: ${req.locale}`);
  })
  .listen(3000);

The locale property on the request object will contain an object with these properties:

{
	"source": "default",
	"language": "en",
	"region": "GB"
}

When using this object in a string context, its toString method returns the locale identifier (en-GB in the example above).

Note: only full locales (language-REGION) are returned, but a mapping of languages to a default locale can be provided as a lookup.

Configuration

You can pass a configuration object to createLocaleMiddleware() with the default being:

{
  "priority": ["accept-language", "default"],
  "default": "en-GB"
}

This tells the middleware to use 2 sources in order: accept-language, which has no configuration, and default which is set to en-GB.

The name of the lookup used in the priority list always matches the configuration key.

Options

  • priority Array, default: ['accept-language', 'default']

    Defines the order of lookups. The first lookup to return a full locale will be the final result.

    Built-in lookups:

    • cookie
    • query
    • hostname
    • accept-language
    • map
    • default

    Read below on how to add custom lookups.

  • allowed Array

    If provided, each lookup's results are validated against this whitelist.

    Note: since this validation happens after each lookup, values which will still pass through the next lookup (like when using map) need to also be whitelisted as in the example below. This will likely be addressed in a future version (see #20).

    // example
    createLocaleMiddleware({
      priority: ['accept-language', 'cookie', 'map'],
      map: {
        'en': 'en-US',
        'fr': 'fr-CA'
      },
      allowed: ['en', 'fr', 'en-US', 'fr-CA']
    });
  • requestProperty String, default 'locale'

    The property on the request object (req) in which the locale is set.

  • cookie Object, default '{name: 'locale'}'

    The name of the cookie that contains the locale for the cookie lookup.

    Use with cookie-parser middleware.

  • query Object, default '{name: 'locale'}'

    The name of the query string parameter that contains the locale for the query lookup.

  • hostname Object

    A mapping of hostnames to locales for the hostname lookup.

    // example
    createLocaleMiddleware({
      priority: ['hostname'],
      map: {
        'en.wikipedia.org': 'en-US',
        'nl.wikipedia.org': 'nl-NL'
      }
    });
  • map Object

    Maps lookup results that return only a language to a full locale.

    // example
    createLocaleMiddleware({
      priority: ['accept-language', 'cookie', 'map'],
      map: {
        'en': 'en-US',
        'fr': 'fr-CA'
      }
    });
  • default String, default 'en-GB'

    The default locale for the default lookup.

  • lookups Object

    Add custom lookups or overwrite the default ones by using the lookups property.

    // example
    createLocaleMiddleware({
      priority: ['custom'],
      lookups: {
        custom: (req) => req.ip === '127.0.0.1' ? 'en-US' : undefined
      }
    });