Swiftpack.co - Package - m-housh/simplecontroller


https://travis-ci.org/m-hous/simplecontroller codecov

Allows for simple / quick CRUD controller's for Vapor-3 database models. This can be used to quickly proto-type or if you have some models that just need basic CRUD operations.



Add the SimpleController package to your Vapor3 project.

    import PackageDescription

    let package = Package(
        name: "MyVaporApp"
        dependencies: [
             // 💧 A server-side Swift web framework.
            .package(url: "https://github.com/vapor/vapor.git", from: "3.0.0"),

            // 🔵 Swift ORM (queries, models, relations, etc) built on SQLite 3.
            .package(url: "https://github.com/vapor/fluent-sqlite.git", from: "3.0.0"),
            // Simple controller
            .package(url: "https://github.com/m-housh/simplecontroller.git", from: "0.1.8") 
        targets: [
            .target(name: "App", dependencies: ["Vapor", "FluentSQLite",


Create a model that we can use for our controller.

    import Vapor
    import FluentSQLite

    /// An example model.
    public final class Foo: SQLiteModel, Migration, Content, Parameter {
        /// The unique identifier for `Foo`.
        public var id: Int?
        /// The bar string for `Foo`.
        public var bar: String
        init(id: Int? = nil, bar: String) {
            self.id = id
            self.bar = bar


Register your routes.

The ModelRouteCollection class will register GET, POST, GET:id, PUT, and DELETE routes at the provided path.

    import Vapor

    public func routes(_ router: Router) throws {
        // Basic "Hello, world!" example
        router.get("hello") { req in 
            return "Hello, world!"

        // Create a `FooController` to register with our router.
        let fooController = ModelRouteCollection(
            path: "path", "to", "foo",
        router.register(collection: fooController)

We can optionally set all the routes to be grouped using middleware, useful for authenticated routes.

    public func routes(_ router: Router) throws {

        let fooController = ModelRouteCollection(
            path: "foo",
            using: [MyMiddleware()]
        router.register(collection: fooController)

The application will now have simple CRUD routes for the Foo model. The GET path also has functionality to limit the results. This can be done in different ways depending on the query parameters.


These examples require you to have some models saved in the database.

  • Get the first 10 Foo's http://localhost:8080/foo?limit=10
  • Get Foo's 2 and 3: http://localhost:8080/foo?startIndex=1&limit=2
  • Same as above but with endIndex: http://localhost:8080/foo?startIndex=1&endIndex=3
Index's are 0 based.


Stars: 0
Help us keep the lights on

Used By