123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110 |
- // Copyright 2014 beego Author. All Rights Reserved.
- //
- // 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
- //
- // Unless required by applicable law or agreed to in writing, software
- // distributed under the License is distributed on an "AS IS" BASIS,
- // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- // See the License for the specific language governing permissions and
- // limitations under the License.
- package beego
- import (
- "fmt"
- "net/url"
- "strings"
- )
- // FlashData is a tools to maintain data when using across request.
- type FlashData struct {
- Data map[string]string
- }
- // NewFlash return a new empty FlashData struct.
- func NewFlash() *FlashData {
- return &FlashData{
- Data: make(map[string]string),
- }
- }
- // Set message to flash
- func (fd *FlashData) Set(key string, msg string, args ...interface{}) {
- if len(args) == 0 {
- fd.Data[key] = msg
- } else {
- fd.Data[key] = fmt.Sprintf(msg, args...)
- }
- }
- // Success writes success message to flash.
- func (fd *FlashData) Success(msg string, args ...interface{}) {
- if len(args) == 0 {
- fd.Data["success"] = msg
- } else {
- fd.Data["success"] = fmt.Sprintf(msg, args...)
- }
- }
- // Notice writes notice message to flash.
- func (fd *FlashData) Notice(msg string, args ...interface{}) {
- if len(args) == 0 {
- fd.Data["notice"] = msg
- } else {
- fd.Data["notice"] = fmt.Sprintf(msg, args...)
- }
- }
- // Warning writes warning message to flash.
- func (fd *FlashData) Warning(msg string, args ...interface{}) {
- if len(args) == 0 {
- fd.Data["warning"] = msg
- } else {
- fd.Data["warning"] = fmt.Sprintf(msg, args...)
- }
- }
- // Error writes error message to flash.
- func (fd *FlashData) Error(msg string, args ...interface{}) {
- if len(args) == 0 {
- fd.Data["error"] = msg
- } else {
- fd.Data["error"] = fmt.Sprintf(msg, args...)
- }
- }
- // Store does the saving operation of flash data.
- // the data are encoded and saved in cookie.
- func (fd *FlashData) Store(c *Controller) {
- c.Data["flash"] = fd.Data
- var flashValue string
- for key, value := range fd.Data {
- flashValue += "\x00" + key + "\x23" + BConfig.WebConfig.FlashSeparator + "\x23" + value + "\x00"
- }
- c.Ctx.SetCookie(BConfig.WebConfig.FlashName, url.QueryEscape(flashValue), 0, "/")
- }
- // ReadFromRequest parsed flash data from encoded values in cookie.
- func ReadFromRequest(c *Controller) *FlashData {
- flash := NewFlash()
- if cookie, err := c.Ctx.Request.Cookie(BConfig.WebConfig.FlashName); err == nil {
- v, _ := url.QueryUnescape(cookie.Value)
- vals := strings.Split(v, "\x00")
- for _, v := range vals {
- if len(v) > 0 {
- kv := strings.Split(v, "\x23"+BConfig.WebConfig.FlashSeparator+"\x23")
- if len(kv) == 2 {
- flash.Data[kv[0]] = kv[1]
- }
- }
- }
- //read one time then delete it
- c.Ctx.SetCookie(BConfig.WebConfig.FlashName, "", -1, "/")
- }
- c.Data["flash"] = flash.Data
- return flash
- }
|