Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/novi/Kunugi

Minimal web framework and middleware for Swift
https://github.com/novi/Kunugi

Last synced: 2 months ago
JSON representation

Minimal web framework and middleware for Swift

Awesome Lists containing this project

README

        

# Kunugi

Kunugi(椚) is minimal web framework and middleware systems for Swift. This is inpired by Node.js' [Koa](http://koajs.com).

Kunugi doesn't provide http server its self. It provides [Nest Interface](https://github.com/nestproject/Nest).

See some example projects until documents is done.

* [Kunugi-Examples](https://github.com/novi/Kunugi-Examples)
* [todoapi](https://github.com/novi/todoapi-example/tree/experimental/todoapi/todoapi)

_Note:_ This is in early development project.

# Usage

Define your context and app.

```swift
import Kunugi
import Nest

class Context: ContextBox {
var context: [ContextType] = []
var request: Request

var method: Method
var path: String
var parameters: [String: String] = [:]

init(request: Request) {
self.request = request
self.path = request.path
self.method = Method(request.method)
}
}

class App: AppType {

var wrap: [WrapMiddleware] = []
var middleware: [MiddlewareType] = []

func use(m: WrapMiddleware) {
wrap.append(m)
}

func use(m: MiddlewareType) {
middleware.append(m)
}

var application: Application {
... // root handler for your server
}
}

```

Create your request handler.

```swift
// Closure style handler with routes
let router = Router()
router.get("/hello") { ctx in
return .Respond(Response(.Ok, body: "world"))
}

// Controller style handler
struct HelloController: ControllerMiddleware, AnyRequestHandleable {
func post(ctx: ContextBox) throws -> MiddlewareResult {
return .Respond(Response(.Ok, body: "hello world"))
}
}

```

Stack your middleware to the app and start your server.

```swift
let app = App()

app.use(Logger())
app.use(BodyParser())

app.use(router)
app.use( Route("/helloworld", HelloController()) )

Server(port: 3000, app.application).start()
```

# Requirements

* Swift 2.1 or Later (includes Linux support)
* OS X 10.10 or Later

# License

MIT