本文整理汇总了Golang中github.com/mdigger/rest.Context.SetHeader方法的典型用法代码示例。如果您正苦于以下问题:Golang Context.SetHeader方法的具体用法?Golang Context.SetHeader怎么用?Golang Context.SetHeader使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类github.com/mdigger/rest.Context
的用法示例。
在下文中一共展示了Context.SetHeader方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Golang代码示例。
示例1: Save
// Save сохраняет переданный в запросе файл в хранилище.
func (fs *FileStore) Save(c *rest.Context) error {
fileInfo, err := fs.Store.Create(c.Request.Body) // сохраняем в хранилище
if err != nil {
return err
}
// файл успешно сохранен
var url = c.Request.URL
if !strings.HasSuffix(url.Path, "/") {
// добавляем к URL запроса "/" в конце, чтобы корректно обработать
// объединение относительного пути
url.Path += "/"
}
// объединяем текущий URL запроса с именем сохраненного файла
url, _ = url.Parse(fileInfo.Name)
urlStr := url.String() // полный URL для доступа к файлу
fileInfo.Name = urlStr
c.SetHeader("Location", urlStr)
log.WithFields(log.Fields{
"url": urlStr,
"mime": fileInfo.Mimetype,
"size": fileInfo.Size,
}).Debug("file saved")
// отдаем ответ с информацией о файле
c.SetStatus(http.StatusCreated)
return c.Write(fileInfo)
}
示例2: Save
// Save сохраняет аватарку пользователя в файле
func (a *Avatars) Save(c *rest.Context) error {
// получаем имя MX-сервера из пути
mxname := c.Param("mx-name")
// получаем идентификатор пользователя
uid, ok := c.Data(userID).(uint64)
if !ok {
return c.Error(http.StatusInternalServerError, "bad user ID (JID)")
}
// создаем катало для сохранения аватарки
fldr := filepath.Join(a.Path, mxname)
if err := os.MkdirAll(fldr, 0700); err != nil {
return c.Error(http.StatusInternalServerError, err.Error())
}
// добавляем идентификатор пользователя, как имя файла
id := strconv.FormatUint(uid, 10)
avatar := filepath.Join(fldr, id)
// создаем файл
file, err := os.Create(avatar)
if err != nil {
return c.Error(http.StatusInternalServerError, err.Error())
}
// копируем в файл содержимое запроса
_, err = io.Copy(file, c.Request.Body)
file.Close()
if err != nil {
return c.Error(http.StatusInternalServerError, err.Error())
}
// сохраняем дату файла в списке
fi, err := os.Stat(avatar)
if err != nil {
return c.Error(http.StatusInternalServerError, err.Error())
}
a.mu.Lock()
mxlist := a.list[mxname]
if mxlist == nil {
mxlist = make(map[uint64]time.Time)
}
mxlist[uid] = fi.ModTime()
a.list[mxname] = mxlist
a.mu.Unlock()
// отдаем в заголовке путь к созданному файлу
c.SetHeader("Location", path.Join(c.Request.URL.Path, id))
c.SetStatus(http.StatusCreated)
return c.Write(nil)
}
示例3: Authorize
// Authorize проверяет авторизацию пользователя и только в случае успешной
// авторизации запускает обработчик запроса.
func (a *Auth) Authorize(c *rest.Context) error {
// получаем имя MX-сервера из пути
mxname := c.Param("mx-name")
// проверяем псевдонимы и делаем редирект на основное имя
if name, ok := a.aliases[mxname]; ok {
var url = strings.Replace(c.Request.URL.Path, mxname, name, 1)
var status = http.StatusMovedPermanently
var method = c.Request.Method
if method != "GET" && method != "HEAD" {
status = http.StatusPermanentRedirect
}
return c.Redirect(status, url)
}
// редирект для данного псевдонима не определен
auth, ok := a.mxlist[mxname]
// проверяем, что сервер с таким именем определен
if !ok {
return c.Error(http.StatusNotFound, fmt.Sprintf("mx %s not found", mxname))
}
// проверяем авторизацию, переданную в запросе
login, password, ok := c.BasicAuth()
if !ok {
realm := fmt.Sprintf("Basic realm=%q", mxname)
c.SetHeader("WWW-Authenticate", realm)
return rest.ErrUnauthorized
}
// проверяем авторизацию пользователя на сервере MX или в кеше
ui, err := auth.Login(login, password)
switch err := err.(type) {
case nil:
break
case *mxlogin.Error: // неверная авторизация
// if err.Code == 6 {
// break // пользователь уже залогинен
// }
return c.Error(http.StatusForbidden, err.Error())
default: // проблемы с подключением к MX серверу
return c.Error(http.StatusServiceUnavailable, err.Error())
}
// сохраняем идентификатор пользователя
c.SetData(userID, ui.ID)
return nil
}