2.2.4 • Published 2 years ago

@swvl/express-versioned-route v2.2.4

Weekly downloads
234
License
Apache-2.0
Repository
github
Last release
2 years ago

Express-Versioned-Route

Simple express.js 4.x extension, to add support for versioned routes.

Commitizen friendly semantic-release codecov Maintainability Rating Security Rating Quality Gate Status

Technical Debt Vulnerabilities Bugs Code Smells Duplicated Lines (%) Lines of Code

Highlights

  • Versioning the same route
  • Loading time validation
  • Custom middlewares for each version
  • Built-in soft deprecation policy
  • Case insensitive name matching
  • Minimal overhead ( less than 0.15ms/request )
  • Dynamic routing based on client headers
  • Client can choose specific version using accept-version header

Install

npm install @swvl/express-versioned-route

Usage

const searchVersionDef = versionsDef()({
  versions: {
    simpleSearch: ['2020-Q1', searchMW1, searchMW2, searchHandlerV1],
    dynamicSearch: [dynamicSearchMW1, dynamicSearchMW2, searchHandlerV2, 'default'],
    superSearch: [searchHandlerV3],
    deepSearch: [searchHandlerV4],
  },
  Android: [
    [400, 'simpleSearch'],
    [450, 'dynamicSearch'],
    [500, 'superSearch'],
  ],
  iOS: [
    [400, 'simpleSearch'],
    [460, 'dynamicSearch'],
  ],
});

app.get('/search', mw1, mw2, searchVersionDef);

Expected user headers

  • device-os & build-number
  • accept-version

Try it live on RunKit

Options

Global options can be passed as 1st parameter for versionsDef function, or configured as part of versionsDef specs

Example

const searchVersionDef = versionsDef(globalOptions)({
  versions: {
    ...
  }
  ...,
  options: {
    ...
  }
});

Supported options

License

Apache-2.0

2.2.4

2 years ago

2.2.3

4 years ago

2.2.2

4 years ago

2.2.1

4 years ago

2.2.0

4 years ago

2.1.1

4 years ago

2.1.0

4 years ago

2.0.0

4 years ago

1.1.3

4 years ago

1.1.2

4 years ago

1.1.1

4 years ago

1.1.0

4 years ago

1.1.0-next.2

4 years ago

1.1.0-next.1

4 years ago

1.0.0

4 years ago

1.0.0-next.2

4 years ago