forked from gramework/gramework
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathapp.go
More file actions
92 lines (78 loc) · 2.15 KB
/
app.go
File metadata and controls
92 lines (78 loc) · 2.15 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
// Copyright 2017-present Kirill Danshin and Gramework contributors
// Copyright 2019-present Highload LTD (UK CN: 11893420)
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
package gramework
import (
"time"
"github.com/microcosm-cc/bluemonday"
)
// SetName for the server
// Deprecated: Use New() with OptAppName option instead
func (app *App) SetName(name string) {
if len(name) > 0 {
app.name = name
} else {
app.name = DefaultAppName
}
app.serverBase.Name = app.name
}
// SetCookieExpire allows you set cookie expire time
func (app *App) SetCookieExpire(d time.Duration) {
if d != 0 {
app.cookieExpire = d
}
}
// SetCookiePath allows you set cookie path
func (app *App) SetCookiePath(path string) {
app.cookiePath = path
}
// SetCookieDomain allows you to implement SSO and other useful features
// without additional pain
func (app *App) SetCookieDomain(domain string) {
app.cookieDomain = domain
}
// SetSanitizerPolicy updates app's sanitizer policy to a new one, if newPolicy is not nil
func (app *App) SetSanitizerPolicy(newPolicy *bluemonday.Policy) {
if newPolicy != nil {
app.sanitizerPolicy = newPolicy
}
}
// ToTLSHandler returns handler that redirects user to HTTPS scheme
func (app *App) ToTLSHandler() func(*Context) {
return func(ctx *Context) {
ctx.ToTLS()
}
}
// HTTP returns HTTP-only router
func (app *App) HTTP() *Router {
return app.defaultRouter.HTTP()
}
// HTTPS returns HTTPS-only router
func (app *App) HTTPS() *Router {
return app.defaultRouter.HTTPS()
}
// MethodNotAllowed sets MethodNotAllowed handler
func (app *App) MethodNotAllowed(c func(ctx *Context)) *App {
app.defaultRouter.router.MethodNotAllowed = c
return app
}
// Redir sends 301 redirect to the given url
//
// it's equivalent to
//
// ctx.Redirect(url, 301)
func (app *App) Redir(url string) func(*Context) {
return func(ctx *Context) {
ctx.Redirect(url, redirectCode)
}
}
// Forbidden send 403 Forbidden error
func (app *App) Forbidden(ctx *Context) {
ctx.Forbidden()
}