Update to version 12.1.6

Former-commit-id: 4d39e8a764a7c0d91b19a3710d8afe6c8c208c62
This commit is contained in:
Gerasimos (Makis) Maropoulos 2020-02-05 12:36:21 +02:00
parent d4e38da3ad
commit 9c97a8a668
14 changed files with 145 additions and 120 deletions

View File

@ -21,6 +21,13 @@ Developers are not forced to upgrade if they don't really need it. Upgrade whene
**How to upgrade**: Open your command-line and execute this command: `go get github.com/kataras/iris/v12@latest`. **How to upgrade**: Open your command-line and execute this command: `go get github.com/kataras/iris/v12@latest`.
# We, 05 February 2020 | v12.1.6
Fixes:
- [jet.View - urlpath error](https://github.com/kataras/iris/issues/1438)
- [Context.ServeFile send 'application/wasm' with a wrong extra field](https://github.com/kataras/iris/issues/1440)
# Su, 02 February 2020 | v12.1.5 # Su, 02 February 2020 | v12.1.5
Various improvements and linting. Various improvements and linting.

View File

@ -21,9 +21,9 @@ Los desarrolladores no están obligados a actualizar si realmente no lo necesita
**Cómo actualizar**: Abra su línea de comandos y ejecute este comando: `go get github.com/kataras/iris/v12@latest`. **Cómo actualizar**: Abra su línea de comandos y ejecute este comando: `go get github.com/kataras/iris/v12@latest`.
# Su, 02 February 2020 | v12.1.5 # We, 05 February 2020 | v12.1.6
Not translated yet, please navigate to the [english version](HISTORY.md#su-02-february-2020--v1215) instead. Not translated yet, please navigate to the [english version](HISTORY.md#we-05-february-2020--v1216) instead.
# Sábado, 26 de octubre 2019 | v12.0.0 # Sábado, 26 de octubre 2019 | v12.0.0

3
NOTICE
View File

@ -51,6 +51,9 @@ Revision ID: 607b5b7cef034da2692f99a4c9bafb31a999ccda
jade 9ffefa50b5f3141 https://github.com/Joker/jade jade 9ffefa50b5f3141 https://github.com/Joker/jade
6ac643e9d9ad611 6ac643e9d9ad611
6f4688705f 6f4688705f
jet 33cfc27b3e00072 github.com/CloudyKit/jet
655fdb3af24c325
3ea5bffb8f
json-iterator 08047c174c6c03e https://github.com/json-iterator/go json-iterator 08047c174c6c03e https://github.com/json-iterator/go
8ec963a411bde1b 8ec963a411bde1b
6d1ee67b26 6d1ee67b26

View File

@ -1,6 +1,6 @@
# News # News
![](https://iris-go.com/images/release.png) Iris version **12.1.5** has been [released](HISTORY.md#su-02-february-2020--v1215)! ![](https://iris-go.com/images/release.png) Iris version **12.1.6** has been [released](HISTORY.md#we-05-february-2020--v1216)!
![](https://iris-go.com/images/cli.png) The official [Iris Command Line Interface](https://github.com/kataras/iris-cli) will soon be near you in 2020! ![](https://iris-go.com/images/cli.png) The official [Iris Command Line Interface](https://github.com/kataras/iris-cli) will soon be near you in 2020!

View File

@ -1 +1 @@
12.1.5:https://github.com/kataras/iris/releases/tag/v12.1.5 12.1.6:https://github.com/kataras/iris/releases/tag/v12.1.6

View File

@ -19,9 +19,7 @@ import (
"github.com/kataras/iris/v12" "github.com/kataras/iris/v12"
) )
// $ go get github.com/valyala/tcplisten // You can run the same app as many times as you want.
// $ go run main.go
func main() { func main() {
app := iris.New() app := iris.New()
@ -35,7 +33,7 @@ func main() {
FastOpen: true, FastOpen: true,
} }
l, err := listenerCfg.NewListener("tcp", ":8080") l, err := listenerCfg.NewListener("tcp4", ":8080")
if err != nil { if err != nil {
panic(err) panic(err)
} }

View File

@ -125,16 +125,13 @@ func main() {
ctx.ViewData("showingAllDone", true) ctx.ViewData("showingAllDone", true)
ctx.ViewData("title", "Todos - All Done") ctx.ViewData("title", "Todos - All Done")
// Key does not actual matter at all here. // Use ctx.ViewData("_jet", jetData)
// However, you can enable it for better performance. // if using as middleware and you want
// In order to enable key mapping for // to pre-set the value or even change it later on from another next middleware.
// jet specific renderer and ranger types // ctx.ViewData("_jet", (&doneTODOs{}).New(todos))
// you have to initialize the View Engine // and ctx.View("todos/index.jet")
// with `tmpl.DisableViewDataTypeCheck("_jet")`. // OR
// ctx.View("todos/index.jet", (&doneTODOs{}).New(todos))
// Defaults to type checks, empty key.
ctx.ViewData("_jet", (&doneTODOs{}).New(todos))
ctx.View("todos/index.jet")
}) })
port := os.Getenv("PORT") port := os.Getenv("PORT")

View File

@ -2,7 +2,7 @@
{{block documentBody()}} {{block documentBody()}}
<h1>Show TODO</h1> <h1>Show TODO</h1>
<p>This uses a custom renderer by implementing the jet.Renderer interface. <p>This uses a custom renderer by implementing the jet.Renderer (or view.JetRenderer) interface.
<p> <p>
{{.}} {{.}}
</p> </p>

View File

@ -0,0 +1,66 @@
// Package main an example on how to naming your routes & use the custom 'url path' Jet Template Engine.
package main
import (
"github.com/kataras/iris/v12"
)
func main() {
app := iris.New()
app.RegisterView(iris.Jet("./views", ".jet").Reload(true))
mypathRoute := app.Get("/mypath", writePathHandler)
mypathRoute.Name = "my-page1"
mypath2Route := app.Get("/mypath2/{paramfirst}/{paramsecond}", writePathHandler)
mypath2Route.Name = "my-page2"
mypath3Route := app.Get("/mypath3/{paramfirst}/statichere/{paramsecond}", writePathHandler)
mypath3Route.Name = "my-page3"
mypath4Route := app.Get("/mypath4/{paramfirst}/statichere/{paramsecond}/{otherparam}/{something:path}", writePathHandler)
// same as: app.Get("/mypath4/:paramfirst/statichere/:paramsecond/:otherparam/*something", writePathHandler)
mypath4Route.Name = "my-page4"
// same with Handle/Func
mypath5Route := app.Handle("GET", "/mypath5/{paramfirst}/statichere/{paramsecond}/{otherparam}/anything/{something:path}", writePathHandler)
mypath5Route.Name = "my-page5"
mypath6Route := app.Get("/mypath6/{paramfirst}/{paramsecond}/statichere/{paramThirdAfterStatic}", writePathHandler)
mypath6Route.Name = "my-page6"
app.Get("/", func(ctx iris.Context) {
// for /mypath6...
paramsAsArray := []string{"theParam1", "theParam2", "paramThirdAfterStatic"}
ctx.ViewData("ParamsAsArray", paramsAsArray)
if err := ctx.View("page.jet"); err != nil {
panic(err)
}
})
app.Get("/redirect/{namedRoute}", func(ctx iris.Context) {
routeName := ctx.Params().Get("namedRoute")
r := app.GetRoute(routeName)
if r == nil {
ctx.StatusCode(iris.StatusNotFound)
ctx.Writef("Route with name %s not found", routeName)
return
}
println("The path of " + routeName + "is: " + r.Path)
// if routeName == "my-page1"
// prints: The path of of my-page1 is: /mypath
// if it's a path which takes named parameters
// then use "r.ResolvePath(paramValuesHere)"
ctx.Redirect(r.Path)
// http://localhost:8080/redirect/my-page1 will redirect to -> http://localhost:8080/mypath
})
// http://localhost:8080
// http://localhost:8080/redirect/my-page1
app.Run(iris.Addr(":8080"))
}
func writePathHandler(ctx iris.Context) {
ctx.Writef("Hello from %s.", ctx.Path())
}

View File

@ -0,0 +1,24 @@
<a href="{{urlpath("my-page1")}}">/mypath</a>
<br />
<br/>
<a href="{{urlpath("my-page2","theParam1","theParam2")}}">/mypath2/{paramfirst}/{paramsecond}</a>
<br />
<br />
<a href="{{urlpath("my-page3", "theParam1", "theParam2AfterStatic")}}">/mypath3/{paramfirst}/statichere/{paramsecond}</a>
<br />
<br />
<a href="{{urlpath("my-page4", "theParam1", "theparam2AfterStatic", "otherParam", "matchAnything")}}">
/mypath4/{paramfirst}/statichere/{paramsecond}/{otherparam}/{something:path}</a>
<br />
<br />
<a href="{{urlpath("my-page5", "theParam1", "theParam2Afterstatichere", "otherParam", "matchAnythingAfterStatic")}}">
/mypath5/{paramfirst}/statichere/{paramsecond}/{otherparam}/anything/{anything:path}</a>
<br />
<br />
<a href={{urlpath("my-page6", .ParamsAsArray)}}>
/mypath6/{paramfirst}/{paramsecond}/statichere/{paramThirdAfterStatic}
</a>

2
doc.go
View File

@ -38,7 +38,7 @@ Source code and other details for the project are available at GitHub:
Current Version Current Version
12.1.5 12.1.6
Installation Installation

2
go.mod
View File

@ -4,7 +4,7 @@ go 1.13
require ( require (
github.com/BurntSushi/toml v0.3.1 github.com/BurntSushi/toml v0.3.1
github.com/CloudyKit/jet v2.1.3-0.20180809161101-62edd43e4f88+incompatible github.com/CloudyKit/jet/v3 v3.0.0
github.com/Joker/jade v1.0.1-0.20190614124447-d475f43051e7 github.com/Joker/jade v1.0.1-0.20190614124447-d475f43051e7
github.com/Shopify/goreferrer v0.0.0-20181106222321-ec9c9a553398 github.com/Shopify/goreferrer v0.0.0-20181106222321-ec9c9a553398
github.com/aymerick/raymond v2.0.3-0.20180322193309-b565731e1464+incompatible github.com/aymerick/raymond v2.0.3-0.20180322193309-b565731e1464+incompatible

14
iris.go
View File

@ -41,7 +41,7 @@ import (
) )
// Version is the current version number of the Iris Web Framework. // Version is the current version number of the Iris Web Framework.
const Version = "12.1.5" const Version = "12.1.6"
// HTTP status codes as registered with IANA. // HTTP status codes as registered with IANA.
// See: http://www.iana.org/assignments/http-status-codes/http-status-codes.xhtml. // See: http://www.iana.org/assignments/http-status-codes/http-status-codes.xhtml.
@ -583,9 +583,17 @@ func (app *Application) NewHost(srv *http.Server) *host.Supervisor {
srv.ErrorLog = log.New(app.logger.Printer.Output, "[HTTP Server] ", 0) srv.ErrorLog = log.New(app.logger.Printer.Output, "[HTTP Server] ", 0)
} }
if srv.Addr == "" { if addr := srv.Addr; addr == "" {
srv.Addr = ":8080" addr = ":8080"
if len(app.Hosts) > 0 {
if v := app.Hosts[0].Server.Addr; v != "" {
addr = v
}
}
srv.Addr = addr
} }
app.logger.Debugf("Host: addr is %s", srv.Addr) app.logger.Debugf("Host: addr is %s", srv.Addr)
// create the new host supervisor // create the new host supervisor

View File

@ -10,7 +10,7 @@ import (
"github.com/kataras/iris/v12/context" "github.com/kataras/iris/v12/context"
"github.com/CloudyKit/jet" "github.com/CloudyKit/jet/v3"
) )
const jetEngineName = "jet" const jetEngineName = "jet"
@ -64,29 +64,15 @@ func Jet(directory, extension string) *JetEngine {
} }
s := &JetEngine{ s := &JetEngine{
directory: directory, directory: directory,
extension: extension, extension: extension,
loader: jet.NewOSFileSystemLoader(directory), loader: jet.NewOSFileSystemLoader(directory),
jetRangerRendererContextKey: "_jet",
} }
return s return s
} }
// DisableViewDataTypeCheck accepts a context key name to use
// to map the jet specific renderer and ranger over context's view data.
//
// If "jetDataContextKey" is not empty then `ExecuteWriter` will not check for
// types to check if an element passed through `Context.ViewData`
// contains a jet.Renderer or jet.Ranger or both.
// Instead will map those with simple key data naming (faster).
// Also it wont check if a value is already a reflect.Value (jet expects this type as values).
//
// Defaults to empty.
func (s *JetEngine) DisableViewDataTypeCheck(jetRangerRendererContextKey string) *JetEngine {
s.jetRangerRendererContextKey = jetRangerRendererContextKey
return s
}
// String returns the name of this view engine, the "jet". // String returns the name of this view engine, the "jet".
func (s *JetEngine) String() string { func (s *JetEngine) String() string {
return jetEngineName return jetEngineName
@ -118,7 +104,7 @@ func (s *JetEngine) AddFunc(funcName string, funcBody interface{}) {
// instead it wants: // instead it wants:
// func(JetArguments) reflect.Value. // func(JetArguments) reflect.Value.
s.AddVar(funcName, func(args JetArguments) reflect.Value { s.AddVar(funcName, jet.Func(func(args JetArguments) reflect.Value {
n := args.NumOfArguments() n := args.NumOfArguments()
if n == 0 { // no input, don't execute the function, panic instead. if n == 0 { // no input, don't execute the function, panic instead.
panic(funcName + " expects one or more input arguments") panic(funcName + " expects one or more input arguments")
@ -140,7 +126,7 @@ func (s *JetEngine) AddFunc(funcName string, funcBody interface{}) {
} }
return reflect.ValueOf(generalFunc(firstInput, variadicInputs...)) return reflect.ValueOf(generalFunc(firstInput, variadicInputs...))
}) }))
return return
} }
@ -366,53 +352,7 @@ func (s *JetEngine) AddRuntimeVars(ctx context.Context, vars JetRuntimeVars) {
AddJetRuntimeVars(ctx, vars) AddJetRuntimeVars(ctx, vars)
} }
type rangerAndRenderer struct {
ranger jet.Ranger
renderer jet.Renderer
}
func (rr rangerAndRenderer) Range() (reflect.Value, reflect.Value, bool) {
return rr.ranger.Range()
}
func (rr rangerAndRenderer) Render(jetRuntime *jet.Runtime) {
rr.renderer.Render(jetRuntime)
}
func rangerRenderer(bindingData interface{}) (interface{}, bool) {
if ranger, ok := bindingData.(jet.Ranger); ok {
// Externally fixes a BUG on the jet template parser:
// eval.go#executeList(list *ListNode):NodeRange.isSet.getRanger(expression = st.evalPrimaryExpressionGroup)
// which does not act the "ranger" as element, instead is converted to a value of struct, which makes a jet.Ranger func(*myStruct) Range...
// not a compatible jet.Ranger.
// getRanger(st.context) should work but author of the jet library is not currently available,
// to allow a recommentation or a PR and I don't really want to vendor it because
// some end-users may use the jet import path to pass things like Global Funcs and etc.
// So to fix it (at least temporarily and only for ref Ranger) we ptr the ptr the "ranger", not the bindingData, and this may
// have its downside because the same bindingData may be compatible with other node actions like range or custom Render
// but we have no other way at the moment. The same problem exists on the `Renderer` too!
// The solution below fixes the above issue but any fields of the struct are not available,
// this is ok because most of the times if not always, the users of jet don't use fields on Ranger and custom Renderer inside the templates.
if renderer, ok := bindingData.(jet.Renderer); ok {
// this can make a Ranger and Renderer both work together, unlike the jet parser itself.
return rangerAndRenderer{ranger, renderer}, true
}
return &ranger, true
}
if renderer, ok := bindingData.(jet.Renderer); ok {
// Here the fields are not available but usually if completes the jet.Renderer no
// fields are used in the template.
return &renderer, true // see above ^.
}
return nil, false
}
// ExecuteWriter should execute a template by its filename with an optional layout and bindingData. // ExecuteWriter should execute a template by its filename with an optional layout and bindingData.
// See `DisableViewDataTypeCheck` too.
func (s *JetEngine) ExecuteWriter(w io.Writer, filename string, layout string, bindingData interface{}) error { func (s *JetEngine) ExecuteWriter(w io.Writer, filename string, layout string, bindingData interface{}) error {
tmpl, err := s.Set.GetTemplate(filename) tmpl, err := s.Set.GetTemplate(filename)
if err != nil { if err != nil {
@ -434,46 +374,28 @@ func (s *JetEngine) ExecuteWriter(w io.Writer, filename string, layout string, b
return tmpl.Execute(w, vars, nil) return tmpl.Execute(w, vars, nil)
} }
jetRangerRenderer, ok := rangerRenderer(bindingData) if vars == nil {
if ok { vars = make(JetRuntimeVars)
return tmpl.Execute(w, vars, jetRangerRenderer)
} }
if m, ok := bindingData.(context.Map); ok { if m, ok := bindingData.(context.Map); ok {
var jetData interface{}
for k, v := range m { for k, v := range m {
if s.jetRangerRendererContextKey == "" {
switch value := v.(type) {
case jet.Ranger, jet.Renderer:
jetRangerRenderer, _ = rangerRenderer(value)
case reflect.Value:
if vars == nil {
vars = make(JetRuntimeVars)
}
// if it's already a reflect value.
vars[k] = value
default:
if vars == nil {
vars = make(JetRuntimeVars)
}
vars.Set(k, v)
}
continue
}
if k == s.jetRangerRendererContextKey { if k == s.jetRangerRendererContextKey {
jetRangerRenderer = v jetData = v
continue continue
} }
if vars == nil { if value, ok := v.(reflect.Value); ok {
vars = make(JetRuntimeVars) vars[k] = value
} else {
vars[k] = reflect.ValueOf(v)
} }
vars.Set(k, v)
} }
return tmpl.Execute(w, vars, jetRangerRenderer) if jetData != nil {
bindingData = jetData
}
} }
return tmpl.Execute(w, vars, bindingData) return tmpl.Execute(w, vars, bindingData)