The fastest HTTP/2 Go Web Framework. New, modern and easy to learn. Fast development with Code you control. Unbeatable cost-performance ratio 🚀
Go to file
Gerasimos (Makis) Maropoulos 221334f8cb Readme Update
Former-commit-id: ed3f825945b51aa4cafd231c2ad7eb5fa1270852
2017-03-22 05:45:03 +02:00
_examples Add an example for sessions + securecookie. Relative: http://support.iris-go.com/d/29-mark-cookie-for-session-as-secure 2017-03-18 23:43:04 +02:00
_future _future 2017-03-22 05:07:30 +02:00
.github http://support.iris-go.com (beta) 2017-03-05 02:42:28 +02:00
adaptors Enhance the view engine's example for {{url ...}} and {{urlpath ...}} tmpl funcs for reverse routing. 2017-03-19 02:06:15 +02:00
httptest Make ExecRouteAgainst to work better and fix gorillamux and httprouter, remove of contextlinker policy it's useless now 2017-02-18 07:03:37 +02:00
iris Organising kataras/go-fs. No api changes for these changes don't worry. See previous commit's description for more info. 2017-03-01 19:17:32 +02:00
middleware Add a simple pprof middleware for newcomers 2017-03-05 03:36:00 +02:00
.gitignore Nothing special here. Come on post some good feature requests, I'm starting to get bored! 2017-02-28 15:41:39 +02:00
.travis.yml Remove entirely go 1.7 travis 2017-02-17 05:08:52 +02:00
addr_test.go Add tests for RedirectTo, Sessions, Flash messages and for Cookies. 2017-02-19 10:23:01 +02:00
addr.go Add the new Go 1.8 Shutdown | Remove DisableBanner, is controlled by LoggerPolicy now. 2017-02-17 04:46:33 +02:00
compression.go Organising kataras/go-fs. No api changes for these changes don't worry. See previous commit's description for more info. 2017-03-01 19:17:32 +02:00
configuration_test.go Add iris.TOML to load configuration from toml-syntax based documents. 2017-03-06 00:08:58 +02:00
configuration.go Add iris.TOML to load configuration from toml-syntax based documents. 2017-03-06 00:08:58 +02:00
context_test.go Add tests for context binders, render policy and readform 2017-02-21 13:26:30 +02:00
context.go Implement feature request: http://support.iris-go.com/d/29-mark-cookie-for-session-as-secure 2017-03-18 12:22:20 +02:00
doc.go Readme Update 2017-03-22 05:45:03 +02:00
DONATIONS.md Readme Update 2017-03-22 05:45:03 +02:00
fs.go Nothing special here, just split the static handler to a package-level func and per-route func (same as before) 2017-03-14 02:58:56 +02:00
handler_test.go Add a simple and pure .Regex middleware for routers that don't support regex route path validations out-of-the-box 2017-02-22 00:51:50 +02:00
handler.go 20 days of unstoppable work. Waiting fo go 1.8, I didn't finish yet, some touches remains. 2017-02-14 05:54:11 +02:00
HISTORY.md Build a better web, together! 2017-03-19 03:49:17 +02:00
iris.go Readme Update 2017-03-22 05:45:03 +02:00
LICENSE Happy new year! Update to 6.0.0 | HTTP/2 full support. https://github.com/kataras/iris/issues/565 2017-01-02 21:20:17 +02:00
logo.jpg Fix https://github.com/iris-contrib/middleware/issues/13 2016-09-30 18:48:48 +03:00
policy_gorillamux_test.go Helpers for third-party adaptors and middleware authors to generate route paths without even know the router that has being selected by user 2017-02-28 15:01:18 +02:00
policy_httprouter_test.go Helpers for third-party adaptors and middleware authors to generate route paths without even know the router that has being selected by user 2017-02-28 15:01:18 +02:00
policy_nativerouter_test.go Add tests for RedirectTo, Sessions, Flash messages and for Cookies. 2017-02-19 10:23:01 +02:00
policy_routerwrapper_test.go Add some _examples in the main repository too. 2017-03-13 15:16:12 +02:00
policy_sessions_test.go Enhance the view engine's example for {{url ...}} and {{urlpath ...}} tmpl funcs for reverse routing. 2017-03-19 02:06:15 +02:00
policy.go Fix http://support.iris-go.com/d/17-fallback-handler-for-non-matched-routes/9 2017-03-13 01:40:57 +02:00
README.md Readme Update 2017-03-22 05:45:03 +02:00
response_recorder.go Fix http://support.iris-go.com/d/17-fallback-handler-for-non-matched-routes/9 2017-03-13 01:40:57 +02:00
response_writer_test.go Add the new Go 1.8 Shutdown | Remove DisableBanner, is controlled by LoggerPolicy now. 2017-02-17 04:46:33 +02:00
response_writer.go Fix http://support.iris-go.com/d/17-fallback-handler-for-non-matched-routes/9 2017-03-13 01:40:57 +02:00
route_test.go Make ExecRouteAgainst to work better and fix gorillamux and httprouter, remove of contextlinker policy it's useless now 2017-02-18 07:03:37 +02:00
route.go Make ExecRouteAgainst to work better and fix gorillamux and httprouter, remove of contextlinker policy it's useless now 2017-02-18 07:03:37 +02:00
router.go Nothing special here, just split the static handler to a package-level func and per-route func (same as before) 2017-03-14 02:58:56 +02:00
serializer_test.go Move the kataras/go-serializer into one iris' file. 2017-03-01 15:04:42 +02:00
serializer.go Move the kataras/go-serializer into one iris' file. 2017-03-01 15:04:42 +02:00
status_test.go Fix http://support.iris-go.com/d/17-fallback-handler-for-non-matched-routes/9 2017-03-13 01:40:57 +02:00
status.go Fix http://support.iris-go.com/d/17-fallback-handler-for-non-matched-routes/9 2017-03-13 01:40:57 +02:00
transaction_test.go add white box tests for transaction, response writer and some of the context's method 2017-02-17 02:14:46 +02:00
transaction.go 20 days of unstoppable work. Waiting fo go 1.8, I didn't finish yet, some touches remains. 2017-02-14 05:54:11 +02:00
updater.go Organising kataras/go-fs. No api changes for these changes don't worry. See previous commit's description for more info. 2017-03-01 19:17:32 +02:00

Navigate to http://support.iris-go.com

Build Status http://goreportcard.com/report/kataras/iris Iris support forum CHANGELOG/HISTORY Examples for new Gophers Docs Chat Buy me a cup of coffee
Iris is an efficient and well-designed, cross-platform, web framework with robust set of features. Build your own high-performance web applications and APIs powered by unlimited potentials and portability. If you're coming from Node.js world, this is the expressjs successor for the Go Programming Language.

This benchmark measures results from 'real-world' instead of 'hello-world' application source code. | Last Update At: July 21, 2016. | Shows: Processing Time Horizontal Graph. | Who did Transparency:  Third-party source | Iris version: these benchmark results are totally valid for v5. | New (go 1.8 + iris.v6) benchmarks will be published on the next techempower's fortune!

What you say about Iris ✌



What people say What people say

Legends

Juan Sebastián Suárez Valencia donated 20 EUR at September 11 of 2016

Bob Lee donated 20 EUR at September 16 of 2016

Celso Luiz donated 50 EUR at September 29 of 2016

Ankur Srivastava donated 20 EUR at October 2 of 2016

Damon Zhao donated 20 EUR at October 21 of 2016

exponity - consulting & digital transformation donated 30 EUR at November 4 of 2016

Thomas Fritz donated 25 EUR at Jenuary 8 of 2017

Thanos V. donated 20 EUR at Jenuary 16 of 2017

George Opritescu donated 20 EUR at February 7 of 2017

Lex Tang donated 20 EUR at February 22 of 2017

Feature Overview

  • Focus on high performance
  • Automatically install and serve certificates from https://letsencrypt.org
  • Robust routing and middleware ecosystem
  • Build RESTful APIs
  • Choose your favorite routes' path syntax between httprouter and gorillamux
  • Request-Scoped Transactions
  • Group API's and subdomains with wildcard support
  • Body binding for JSON, XML, Forms, can be extended to use your own custom binders
  • More than 50 handy functions to send HTTP responses
  • View system: supporting more than 6+ template engines, with prerenders. You can still use your favorite
  • Define virtual hosts and (wildcard) subdomains with path level routing
  • Graceful shutdown
  • Limit request body
  • Localization i18N
  • Serve static files
  • Cache
  • Log requests
  • Customizable format and output for the logger
  • Customizable HTTP errors
  • Compression (Gzip)
  • Authentication
  • OAuth, OAuth2 supporting 27+ popular websites
  • JWT
  • Basic Authentication
  • HTTP Sessions
  • Add / Remove trailing slash from the URL with option to redirect
  • Redirect requests
  • HTTP to HTTPS
  • HTTP to HTTPS WWW
  • HTTP to HTTPS non WWW
  • Non WWW to WWW
  • WWW to non WWW
  • Highly scalable rich content render (Markdown, JSON, JSONP, XML...)
  • Websocket-only API similar to socket.io
  • Hot Reload on source code changes
  • Typescript integration + Web IDE
  • Checks for updates at startup
  • Highly customizable
  • Feels like you used iris forever, thanks to its Fluent API
  • And many others...

Installation

The only requirement is the Go Programming Language, at least 1.8

$ go get gopkg.in/kataras/iris.v6

For further installation support, navigate here.

Overview

package main

import (
	"gopkg.in/kataras/iris.v6"
	"gopkg.in/kataras/iris.v6/adaptors/cors"
	"gopkg.in/kataras/iris.v6/adaptors/httprouter"
	"gopkg.in/kataras/iris.v6/adaptors/view"
)

func main() {
	// Receives optional iris.Configuration{}, see ./configuration.go
	// for more.
	app := iris.New()

	// Order doesn't matter,
	// You can split it to different .Adapt calls.
	// See ./adaptors folder for more.
	app.Adapt(
		// adapt a logger which prints all errors to the os.Stdout
		iris.DevLogger(),
		// adapt the adaptors/httprouter or adaptors/gorillamux
		httprouter.New(),
		// 5 template engines are supported out-of-the-box:
		//
		// - standard html/template
		// - amber
		// - django
		// - handlebars
		// - pug(jade)
		//
		// Use the html standard engine for all files inside "./views" folder with extension ".html"
		view.HTML("./views", ".html"),
		// Cors wrapper to the entire application, allow all origins.
		cors.New(cors.Options{AllowedOrigins: []string{"*"}}))

	// http://localhost:6300
	// Method: "GET"
	// Render ./views/index.html
	app.Get("/", func(ctx *iris.Context) {
		ctx.Render("index.html", iris.Map{"Title": "Page Title"}, iris.RenderOptions{"gzip": true})
	})

	// Group routes, optionally: share middleware, template layout and custom http errors.
	userAPI := app.Party("/users", userAPIMiddleware).
		Layout("layouts/userLayout.html")
	{
		// Fire userNotFoundHandler when Not Found
		// inside http://localhost:6300/users/*anything
		userAPI.OnError(404, userNotFoundHandler)

		// http://localhost:6300/users
		// Method: "GET"
		userAPI.Get("/", getAllHandler)

		// http://localhost:6300/users/42
		// Method: "GET"
		userAPI.Get("/:id", getByIDHandler)

		// http://localhost:6300/users
		// Method: "POST"
		userAPI.Post("/", saveUserHandler)
	}

	// Start the server at 127.0.0.1:6300
	app.Listen(":6300")
}

func userAPIMiddleware(ctx *iris.Context) {
	// your code here...
	println("Request: " + ctx.Path())
	ctx.Next() // go to the next handler(s)
}

func userNotFoundHandler(ctx *iris.Context) {
	// your code here...
	ctx.HTML(iris.StatusNotFound, "<h1> User page not found </h1>")
}

func getAllHandler(ctx *iris.Context) {
	// your code here...
}

func getByIDHandler(ctx *iris.Context) {
	// take the :id from the path, parse to integer
	// and set it to the new userID local variable.
	userID, _ := ctx.ParamInt("id")

	// userRepo, imaginary database service <- your only job.
	user := userRepo.GetByID(userID)

	// send back a response to the client,
	// .JSON: content type as application/json; charset="utf-8"
	// iris.StatusOK: with 200 http status code.
	//
	// send user as it is or make use of any json valid golang type,
	// like the iris.Map{"username" : user.Username}.
	ctx.JSON(iris.StatusOK, user)
}

func saveUserHandler(ctx *iris.Context) {
	// your code here...
}

Reload on source code changes

$ go get -u github.com/kataras/rizla
$ cd $GOPATH/src/mywebapp
$ rizla main.go

Reload templates on each incoming request

app.Adapt(view.HTML("./views", ".html").Reload(true))

FAQ & Documentation

  1. Getting Started with Go+Iris

  2. Official small but practical examples

  3. Navigate through community examples too

  4. Creating A URL Shortener Service Using Go, Iris, and Bolt

  5. ./adaptors and ./middleware contains examples of their usage

  6. Godocs for deep documentation

  7. HISTORY.md is your best friend, version migrations are released there

I'll be glad to talk with you about your awesome feature requests, open a new discussion, you will be heard!

Support

  • the project, will help you to follow the upcoming features
  • Donate, will help me to continue
  • Post a feature request or report a bug, will help all of us to build a better web, together
  • 🌎 post an article or tweet and share it with your neighbor

Buy me a cup of coffee?

Iris is free and open source but developing it has taken thousands of hours of my time and a large part of my sanity. If you feel this web framework useful to you, it would go a great way to ensuring that I can afford to take the time to continue to develop it.

I spend all my time in the construction of Iris, therefore I have no income value.

Feel free to send any amount through paypal

Please check your e-mail after your donation.

Thanks for your gratitude and finance help ♡

Third Party Middleware

Iris has its own middleware form of func(ctx *iris.Context) but it's also compatible with all net/http middleware forms using iris.ToHandler, i.e Negroni's middleware form of func(w http.ResponseWriter, r *http.Request, next http.HandlerFunc).

Here is a small list of Iris compatible middleware, I'm sure you can find more:

Middleware Author Description
binding Matt Holt Data binding from HTTP requests into structs
cloudwatch Colin Steele AWS cloudwatch metrics middleware
csp Awake Networks Content Security Policy (CSP) support
delay Jeff Martinez Add delays/latency to endpoints. Useful when testing effects of high latency
New Relic Go Agent Yadvendar Champawat Official New Relic Go Agent (currently in beta)
gorelic Jingwen Owen Ou New Relic agent for Go runtime
JWT Middleware Auth0 Middleware checks for a JWT on the Authorization header on incoming requests and decodes it
logrus Dan Buch Logrus-based logger
onthefly Alexander Rødseth Generate TinySVG, HTML and CSS on the fly
permissions2 Alexander Rødseth Cookies, users and permissions
prometheus Rene Zbinden Easily create metrics endpoint for the prometheus instrumentation tool
render Cory Jacobsen Render JSON, XML and HTML templates
RestGate Prasanga Siripala Secure authentication for REST API endpoints
secure Cory Jacobsen Middleware that implements a few quick security wins
stats Florent Messa Store information about your web application (response time, etc.)
VanGoH Taylor Wrobel Configurable AWS-Style HMAC authentication middleware
xrequestid Andrea Franz Middleware that assigns a random X-Request-Id header to each request
digits Bilal Amarni Middleware that handles Twitter Digits authentication

Feel free to put up a PR your middleware!

Testing

The httptest package is a simple Iris helper for the httpexpect, a new library for End-to-end HTTP and REST API testing for Go.

You can find tests by navigating to the source code, i.e:

A simple test is located to ./httptest/_example/main_test.go

Philosophy

The Iris philosophy is to provide robust tooling for HTTP, making it a great solution for single page applications, web sites, hybrids, or public HTTP APIs. Keep note that, today, iris is faster than nginx itself.

Iris does not force you to use any specific ORM or template engine. Iris is routerless which means you can adapt any router you like, httprouter is the fastest, gorillamux has more features. With support for the most used template engines (5), you can quickly craft the perfect application.

People

The author of Iris is @kataras.

However the real Success of Iris belongs to you with your bug reports and feature requests that made this Framework so Unique.

Contact

Besides the fact that we have a community chat for questions or reports and ideas, stackoverflow section for generic go+iris questions and the iris support for bug reports and feature requests, you can also contact with me, as a person who is always open to help you:

Codename: "√Νεxτ"

License

Unless otherwise noted, the source files are distributed under the MIT License found in the LICENSE file.

Note that some optional components that you may use with Iris requires different license agreements.