2017-10-09 14:26:46 +02:00
|
|
|
package mvc
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/kataras/iris/context"
|
|
|
|
"github.com/kataras/iris/mvc/activator/methodfunc"
|
|
|
|
)
|
|
|
|
|
|
|
|
// Response completes the `methodfunc.Result` interface.
|
|
|
|
// It's being used as an alternative return value which
|
|
|
|
// wraps the status code, the content type, a content as bytes or as string
|
|
|
|
// and an error, it's smart enough to complete the request and send the correct response to the client.
|
|
|
|
type Response struct {
|
|
|
|
Code int
|
|
|
|
ContentType string
|
|
|
|
Content []byte
|
|
|
|
|
|
|
|
// if not empty then content type is the text/plain
|
|
|
|
// and content is the text as []byte.
|
|
|
|
Text string
|
|
|
|
// If not nil then it will fire that as "application/json" or the
|
|
|
|
// "ContentType" if not empty.
|
|
|
|
Object interface{}
|
|
|
|
|
2017-10-12 15:28:41 +02:00
|
|
|
// If Path is not empty then it will redirect
|
|
|
|
// the client to this Path, if Code is >= 300 and < 400
|
|
|
|
// then it will use that Code to do the redirection, otherwise
|
|
|
|
// StatusFound(302) or StatusSeeOther(303) for post methods will be used.
|
|
|
|
// Except when err != nil.
|
|
|
|
Path string
|
|
|
|
|
2017-10-09 14:26:46 +02:00
|
|
|
// if not empty then fire a 400 bad request error
|
|
|
|
// unless the Status is > 200, then fire that error code
|
|
|
|
// with the Err.Error() string as its content.
|
|
|
|
//
|
|
|
|
// if Err.Error() is empty then it fires the custom error handler
|
|
|
|
// if any otherwise the framework sends the default http error text based on the status.
|
|
|
|
Err error
|
|
|
|
Try func() int
|
2017-10-12 15:28:41 +02:00
|
|
|
|
|
|
|
// if true then it skips everything else and it throws a 404 not found error.
|
|
|
|
// Can be named as Failure but NotFound is more precise name in order
|
|
|
|
// to be visible that it's different than the `Err`
|
|
|
|
// because it throws a 404 not found instead of a 400 bad request.
|
|
|
|
// NotFound bool
|
|
|
|
// let's don't add this yet, it has its dangerous of missuse.
|
2017-10-09 14:26:46 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
var _ methodfunc.Result = Response{}
|
|
|
|
|
|
|
|
// Dispatch writes the response result to the context's response writer.
|
|
|
|
func (r Response) Dispatch(ctx context.Context) {
|
2017-10-12 15:28:41 +02:00
|
|
|
if r.Path != "" && r.Err == nil {
|
|
|
|
// it's not a redirect valid status
|
|
|
|
if r.Code < 300 || r.Code >= 400 {
|
|
|
|
if ctx.Method() == "POST" {
|
|
|
|
r.Code = 303 // StatusSeeOther
|
|
|
|
}
|
|
|
|
r.Code = 302 // StatusFound
|
|
|
|
}
|
|
|
|
ctx.Redirect(r.Path, r.Code)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2017-10-09 14:26:46 +02:00
|
|
|
if s := r.Text; s != "" {
|
|
|
|
r.Content = []byte(s)
|
|
|
|
}
|
|
|
|
|
2017-10-12 02:51:06 +02:00
|
|
|
methodfunc.DispatchCommon(ctx, r.Code, r.ContentType, r.Content, r.Object, r.Err, true)
|
2017-10-09 14:26:46 +02:00
|
|
|
}
|