mirror of
https://github.com/kataras/iris.git
synced 2025-01-23 18:51:03 +01:00
3945fa68d1
We have to do the same on iris-contrib/examples, iris-contrib/middleware and e.t.c. Former-commit-id: 0860688158f374bc137bc934b81b26dcd0e10964
61 lines
2.0 KiB
Go
61 lines
2.0 KiB
Go
// file: main.go
|
|
|
|
package main
|
|
|
|
import (
|
|
"github.com/kataras/iris/v12/_examples/mvc/overview/datasource"
|
|
"github.com/kataras/iris/v12/_examples/mvc/overview/repositories"
|
|
"github.com/kataras/iris/v12/_examples/mvc/overview/services"
|
|
"github.com/kataras/iris/v12/_examples/mvc/overview/web/controllers"
|
|
"github.com/kataras/iris/v12/_examples/mvc/overview/web/middleware"
|
|
|
|
"github.com/kataras/iris/v12"
|
|
"github.com/kataras/iris/v12/mvc"
|
|
)
|
|
|
|
func main() {
|
|
app := iris.New()
|
|
app.Logger().SetLevel("debug")
|
|
|
|
// Load the template files.
|
|
app.RegisterView(iris.HTML("./web/views", ".html"))
|
|
|
|
// Serve our controllers.
|
|
mvc.New(app.Party("/hello")).Handle(new(controllers.HelloController))
|
|
// You can also split the code you write to configure an mvc.Application
|
|
// using the `mvc.Configure` method, as shown below.
|
|
mvc.Configure(app.Party("/movies"), movies)
|
|
|
|
// http://localhost:8080/hello
|
|
// http://localhost:8080/hello/iris
|
|
// http://localhost:8080/movies
|
|
// http://localhost:8080/movies/1
|
|
app.Run(
|
|
// Start the web server at localhost:8080
|
|
iris.Addr("localhost:8080"),
|
|
// skip err server closed when CTRL/CMD+C pressed:
|
|
iris.WithoutServerError(iris.ErrServerClosed),
|
|
// enables faster json serialization and more:
|
|
iris.WithOptimizations,
|
|
)
|
|
}
|
|
|
|
// note the mvc.Application, it's not iris.Application.
|
|
func movies(app *mvc.Application) {
|
|
// Add the basic authentication(admin:password) middleware
|
|
// for the /movies based requests.
|
|
app.Router.Use(middleware.BasicAuth)
|
|
|
|
// Create our movie repository with some (memory) data from the datasource.
|
|
repo := repositories.NewMovieRepository(datasource.Movies)
|
|
// Create our movie service, we will bind it to the movie app's dependencies.
|
|
movieService := services.NewMovieService(repo)
|
|
app.Register(movieService)
|
|
|
|
// serve our movies controller.
|
|
// Note that you can serve more than one controller
|
|
// you can also create child mvc apps using the `movies.Party(relativePath)` or `movies.Clone(app.Party(...))`
|
|
// if you want.
|
|
app.Handle(new(controllers.MovieController))
|
|
}
|