New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

express-simple-controllers

Package Overview
Dependencies
Maintainers
1
Versions
8
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

express-simple-controllers

Create super simple controllers for routing an express app.

  • 1.1.5
  • latest
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
7
decreased by-65%
Maintainers
1
Weekly downloads
 
Created
Source

express-simple-controllers

Create super simple controllers for routing an express app.

How to use

First off, initialize the controllers

import initialize from "express-simple-controllers";
import express from "express";

const router = express.Router();

initialize(router);

Then create a controllers directory and add anything with an _controller.js suffix. e.g. home_controller.js. Anything with that suffix will be added as a controller.

If you need to change the controller directory...

initialize(router, { directory: "server/controllers" });
Basic

You can create controller methods in a few different ways.

const show = {
  method: "GET",
  route: "/home",
  handler(req, res, next) {
    res.render("home");
  }
};

export { show };
Handler types
const show = {
  method: "GET",
  route: "/home",
  handler: {
    json(req, res, next) {
      res.json({ home: "home" });
    }
    html(req, res, next) {
      res.render("home");
    }
  }
};

export { show };
Middleware and before

If you export a before function, it will run before every method in the file unless you pass a skipBefore: true.

const before = (req, res, next) => {
  req.something = "a thing";
  next();
}

const show = {
  method: "GET",
  route: "/home",
  handler(req, res, next) {
    const { something } = req;

    res.render("home", { something });
  }
};

const showNoBefore = {
  method: "GET",
  route: "/home",
  skipBefore: true,
  handler(req, res, next) {
    // ...
  }
};

export {
  before,
  show,
  showNoBefore,
};

You can also pass an array of of middleware.

const show = {
  method: "GET",
  route: "/home",
  middleware: [first, second(someOptions)],
  handler(req, res, next) {
    res.render("home");
  }
};

export { show };

CRUD routes

You can also create a simple crud controller by creating named functions in the exports...

// user_controller.js
const before = (req, res, next) => next();

// GET /user
const show = (req, res, next) => {};

// GET /users
const list = (req, res, next) => {};

// PUT /user
const update = (req, res, next) => {};

// POST /user
const create = (req, res, next) => {};

// DELETE /user
const delete = (req, res, next) => {};

export {
  show,
  list,
  update,
  create,
  delete
};

The prefix of the file sets the route, in the above case /user because the controller is named user_controller.js.

Build

Will build to the /dist directory.

npm run build

Running tests

npm run test
npm run test:ci # Runs in watch mode

Keywords

FAQs

Package last updated on 31 Mar 2017

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc