本文整理匯總了Golang中github.com/labstack/echo.Context.QueryParam方法的典型用法代碼示例。如果您正苦於以下問題:Golang Context.QueryParam方法的具體用法?Golang Context.QueryParam怎麽用?Golang Context.QueryParam使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類github.com/labstack/echo.Context
的用法示例。
在下文中一共展示了Context.QueryParam方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: sf
// sf is the recursive function used to build the structure neeeded by SelectFields
func sf(in interface{}, c echo.Context) (interface{}, error) {
in = reflect.Indirect(reflect.ValueOf(in)).Interface()
Type := reflect.TypeOf(in)
switch Type.Kind() {
case reflect.Struct:
ret := make(map[string]interface{})
value := reflect.ValueOf(in)
if fieldString := c.QueryParam("fields"); fieldString != "" {
fields := strings.Split(fieldString, ",")
for _, field := range fields {
fieldName := utils.UpperFirst(field)
if structField, ok := Type.FieldByName(fieldName); ok {
jsonTag := structField.Tag.Get("json")
if jsonTag != "-" && jsonTag != "" {
ret[strings.Split(jsonTag, ",")[0]] = value.FieldByName(fieldName).Interface()
}
} else {
// Else check if json field name is different from struct field name (with first letter in uppercase)
// this is the user expected behaviour, but we prefer the above approach to speed up the process
var found bool
for i := 0; i < Type.NumField(); i++ {
jsonTag := Type.Field(i).Tag.Get("json")
if strings.Split(jsonTag, ",")[0] == field {
ret[field] = value.Field(i).Interface()
found = true
break
}
}
if !found {
return nil, fmt.Errorf("Field %s does not exists", field)
}
}
}
} else {
for i := 0; i < Type.NumField(); i++ {
jsonTag := Type.Field(i).Tag.Get("json")
if jsonTag != "-" && jsonTag != "" {
ret[strings.Split(jsonTag, ",")[0]] = value.Field(i).Interface()
}
}
}
return &ret, nil
case reflect.Slice:
value := reflect.ValueOf(in)
ret := make([]interface{}, value.Len())
for i := 0; i < value.Len(); i++ {
if m, e := sf(value.Index(i).Elem().Interface(), c); e == nil {
ret[i] = m
} else {
return nil, fmt.Errorf(`Error "%s" on field number %d`, e.Error(), i)
}
}
return &ret, nil
}
return nil, errors.New("input parameter is not a struct or a slice of struct")
}
示例2: handleDownloadTarFunc
func (h *handler) handleDownloadTarFunc(c echo.Context) error {
pathToSend := c.QueryParam("path")
fileFilter := c.QueryParam("file-filter")
if strings.TrimSpace(pathToSend) == "" {
return fmt.Errorf("Request does not contain query 'path' value")
}
var tarProvider tar_io.TarProvider
if isDir, err := path_utils.DirectoryExists(pathToSend); err != nil {
return fmt.Errorf("Unable to determine if path '%s' is a directory, error: %s", pathToSend, err.Error())
} else if isDir {
tarProvider = tar_io.Factories.TarProvider.Dir(pathToSend, fileFilter)
h.logger.Infof("Now starting to send dir '%s'", pathToSend)
} else if isFile, err := path_utils.FileExists(pathToSend); err != nil {
return fmt.Errorf("Unable to determine if path '%s' is a file, error: %s", pathToSend, err.Error())
} else if isFile {
tarProvider = tar_io.Factories.TarProvider.File(pathToSend)
h.logger.Infof("Now starting to send file '%s'", pathToSend)
} else {
return fmt.Errorf("Path '%s' is not an existing file or directory", pathToSend)
}
handler := &sendTarHandler{writer: c.Response()}
err := tar_io.UploadProvider(tarProvider, handler)
if err != nil {
return fmt.Errorf("Unable to send file, error: %s", err.Error())
}
return nil
}
示例3: SetupConfig
func (self InstallController) SetupConfig(ctx echo.Context) error {
// config/env.ini 存在
if db.MasterDB != nil {
if logic.DefaultInstall.IsTableExist(ctx) {
return ctx.Redirect(http.StatusSeeOther, "/")
}
return ctx.Redirect(http.StatusSeeOther, "/install/do")
}
step := goutils.MustInt(ctx.QueryParam("step"))
if step == 2 {
err := self.genConfig(ctx)
if err != nil {
data := map[string]interface{}{
"dbhost": ctx.FormValue("dbhost"),
"dbport": ctx.FormValue("dbport"),
"dbname": ctx.FormValue("dbname"),
"uname": ctx.FormValue("uname"),
"err_type": 1,
}
if err == db.ConnectDBErr {
data["err_type"] = 1
} else if err == db.UseDBErr {
data["err_type"] = 2
}
return renderInstall(ctx, "install/setup-err.html", data)
}
}
return renderInstall(ctx, "install/setup-config.html", map[string]interface{}{"step": step})
}
示例4: ReadList
// 消息列表
func (MessageController) ReadList(ctx echo.Context) error {
user := ctx.Get("user").(*model.Me)
msgtype := ctx.Param("msgtype")
if msgtype == "" {
msgtype = "system"
}
curPage := goutils.MustInt(ctx.QueryParam("p"), 1)
paginator := logic.NewPaginator(curPage)
var (
messages []map[string]interface{}
total int64
)
switch msgtype {
case "system":
messages = logic.DefaultMessage.FindSysMsgsByUid(ctx, user.Uid, paginator)
total = logic.DefaultMessage.SysMsgCount(ctx, user.Uid)
case "inbox":
messages = logic.DefaultMessage.FindToMsgsByUid(ctx, user.Uid, paginator)
total = logic.DefaultMessage.ToMsgCount(ctx, user.Uid)
case "outbox":
messages = logic.DefaultMessage.FindFromMsgsByUid(ctx, user.Uid, paginator)
total = logic.DefaultMessage.FromMsgCount(ctx, user.Uid)
default:
return ctx.Redirect(http.StatusSeeOther, "/")
}
pageHtml := paginator.SetTotal(total).GetPageHtml(fmt.Sprintf("/message/%s", msgtype))
return render(ctx, "messages/list.html", map[string]interface{}{"messages": messages, "msgtype": msgtype, "page": template.HTML(pageHtml)})
}
示例5: handleStatsFunc
func (h *handler) handleStatsFunc(c echo.Context) error {
path := c.QueryParam("path")
if strings.TrimSpace(path) == "" {
return fmt.Errorf("Request does not contain query 'path' value")
}
info, err := os.Stat(path)
if err != nil {
if os.IsNotExist(err) {
return c.JSON(200, &dtos.StatsDto{
Path: path,
Exists: false,
})
}
return fmt.Errorf("Unable to get stats of path '%s', error: %s", path, err.Error())
}
returnDto := &dtos.StatsDto{
Path: path,
Exists: true,
IsDir: info.IsDir(),
ModTime: info.ModTime(),
Mode: info.Mode(),
Size: info.Size(),
}
return c.JSON(200, returnDto)
}
示例6: ReadList
// ReadList 獲得wiki列表
func (WikiController) ReadList(ctx echo.Context) error {
limit := 20
lastId := goutils.MustInt(ctx.QueryParam("lastid"))
wikis := logic.DefaultWiki.FindBy(ctx, limit+5, lastId)
if wikis == nil {
logger.Errorln("wiki controller: find wikis error")
return ctx.Redirect(http.StatusSeeOther, "/wiki")
}
num := len(wikis)
if num == 0 {
if lastId == 0 {
return ctx.Redirect(http.StatusSeeOther, "/")
}
return ctx.Redirect(http.StatusSeeOther, "/wiki")
}
var (
hasPrev, hasNext bool
prevId, nextId int
)
if lastId != 0 {
prevId = lastId
// 避免因為wiki下線,導致判斷錯誤(所以 > 5)
if prevId-wikis[0].Id > 5 {
hasPrev = false
} else {
prevId += limit
hasPrev = true
}
}
if num > limit {
hasNext = true
wikis = wikis[:limit]
nextId = wikis[limit-1].Id
} else {
nextId = wikis[num-1].Id
}
pageInfo := map[string]interface{}{
"has_prev": hasPrev,
"prev_id": prevId,
"has_next": hasNext,
"next_id": nextId,
}
// 獲取當前用戶喜歡對象信息
// me, ok := ctx.Get("user").(*model.Me)
// var likeFlags map[int]int
// if ok {
// likeFlags, _ = logic.DefaultLike.FindUserLikeObjects(ctx, me.Uid, model.TypeWiki, wikis[0].Id, nextId)
// }
return render(ctx, "wiki/list.html", map[string]interface{}{"wikis": wikis, "activeWiki": "active", "page": pageInfo})
}
示例7: handlePathSummaryFunc
func (h *handler) handlePathSummaryFunc(c echo.Context) error {
path := c.QueryParam("path")
if strings.TrimSpace(path) == "" {
return fmt.Errorf("Request does not contain query 'path' value")
}
info, err := os.Stat(path)
if err != nil {
if os.IsNotExist(err) {
//TODO: Return empty dir instead of NotFound so that on the other side it will result in a "out of sync" status?
//return c.JSON(http.StatusNotFound, &dtos.FilesystemSummaryDto{
return c.JSON(200, &dtos.FilesystemSummaryDto{
FlattenedFiles: []*dtos.FileSummary{
&dtos.FileSummary{},
},
})
}
return fmt.Errorf("Unable to get stats of path '%s', error: %s", path, err.Error())
}
baseDir := ""
flattenedFiles := []*dtos.FileSummary{}
if info.IsDir() {
dirSummary, err := h.svcs.FilePathSummaries.GetDirSummary(path)
if err != nil {
return fmt.Errorf("Cannot get dir '%s' summary, error: %s", path, err.Error())
}
baseDir = path
for _, f := range dirSummary.FlattenedFileSummaries {
flattenedFiles = append(flattenedFiles, &dtos.FileSummary{
RelativePath: f.RelativePath,
ModTime: f.ModTime,
ChecksumHex: f.Checksum.HexString(),
})
}
} else {
//TODO: 2016-05-09 20:57 - it is hacky to use an empty basedir and full path for single files. See other spot where we reference this timestamp in the TODO
baseDir = ""
fileSummary, err := h.svcs.FilePathSummaries.GetFileSummary(baseDir, path)
if err != nil {
return fmt.Errorf("Cannot get file '%s' summary, error: %s", path, err.Error())
}
flattenedFiles = append(flattenedFiles, &dtos.FileSummary{
RelativePath: fileSummary.RelativePath,
ModTime: fileSummary.ModTime,
ChecksumHex: fileSummary.Checksum.HexString(),
})
}
returnDto := &dtos.FilesystemSummaryDto{
BaseDir: baseDir,
FlattenedFiles: flattenedFiles,
}
return c.JSON(200, returnDto)
}
示例8: ReadCatResources
// ReadCatResources 某個分類的資源列表
func (ResourceController) ReadCatResources(ctx echo.Context) error {
curPage := goutils.MustInt(ctx.QueryParam("p"), 1)
paginator := logic.NewPaginator(curPage)
catid := goutils.MustInt(ctx.Param("catid"))
resources, total := logic.DefaultResource.FindByCatid(ctx, paginator, catid)
pageHtml := paginator.SetTotal(total).GetPageHtml(ctx.Request().URL().Path())
return render(ctx, "resources/index.html", map[string]interface{}{"activeResources": "active", "resources": resources, "categories": logic.AllCategory, "page": template.HTML(pageHtml), "curCatid": catid})
}
示例9: ReadList
// ReadList 開源項目列表頁
func (ProjectController) ReadList(ctx echo.Context) error {
limit := 20
lastId := goutils.MustInt(ctx.QueryParam("lastid"))
projects := logic.DefaultProject.FindBy(ctx, limit+5, lastId)
num := len(projects)
if num == 0 {
if lastId == 0 {
return ctx.Redirect(http.StatusSeeOther, "/")
} else {
return ctx.Redirect(http.StatusSeeOther, "/projects")
}
}
var (
hasPrev, hasNext bool
prevId, nextId int
)
if lastId > 0 {
prevId = lastId
// 避免因為項目下線,導致判斷錯誤(所以 > 5)
if prevId-projects[0].Id > 5 {
hasPrev = false
} else {
prevId += limit
hasPrev = true
}
}
if num > limit {
hasNext = true
projects = projects[:limit]
nextId = projects[limit-1].Id
} else {
nextId = projects[num-1].Id
}
pageInfo := map[string]interface{}{
"has_prev": hasPrev,
"prev_id": prevId,
"has_next": hasNext,
"next_id": nextId,
}
// 獲取當前用戶喜歡對象信息
me, ok := ctx.Get("user").(*model.Me)
var likeFlags map[int]int
if ok {
likeFlags, _ = logic.DefaultLike.FindUserLikeObjects(ctx, me.Uid, model.TypeProject, projects[0].Id, nextId)
}
return render(ctx, "projects/list.html", map[string]interface{}{"projects": projects, "activeProjects": "active", "page": pageInfo, "likeflags": likeFlags})
}
示例10: Get
// Get all tags
func (*TagsController) Get(c echo.Context) error {
var model models.Tag
var name = c.QueryParam("name")
ret, err := model.Get(name)
if err != nil {
return c.JSON(400, utils.ErrMarshal(err.Error()))
}
return c.JSON(200, ret)
}
示例11: Get
// Get posts
func (*PostsController) Get(c echo.Context) error {
var model models.Post
var title = c.QueryParam("title")
ret, err := model.Get(title)
if err != nil {
return c.JSON(400, utils.ErrMarshal(err.Error()))
}
return c.JSON(200, ret)
}
示例12: CheckExist
// CheckExist 檢測 uri 對應的項目是否存在(驗證,true表示不存在;false表示存在)
func (ProjectController) CheckExist(ctx echo.Context) error {
uri := ctx.QueryParam("uri")
if uri == "" {
return ctx.JSON(http.StatusOK, `true`)
}
if logic.DefaultProject.UriExists(ctx, uri) {
return ctx.JSON(http.StatusOK, `false`)
}
return ctx.JSON(http.StatusOK, `true`)
}
示例13: CallbackHandler
func (handlerGroup *HandlerGroup) CallbackHandler(context echo.Context) error {
domain := "jessemillar.auth0.com"
// Instantiating the OAuth2 package to exchange the Code for a Token
conf := &oauth2.Config{
ClientID: os.Getenv("AUTH0_CLIENT_ID"),
ClientSecret: os.Getenv("AUTH0_CLIENT_SECRET"),
RedirectURL: os.Getenv("AUTH0_CALLBACK"),
Scopes: []string{"openid", "name", "email", "nickname"},
Endpoint: oauth2.Endpoint{
AuthURL: "https://" + domain + "/authorize",
TokenURL: "https://" + domain + "/oauth/token",
},
}
// Getting the Code that we got from Auth0
code := context.QueryParam("code")
// Exchanging the code for a token
token, err := conf.Exchange(oauth2.NoContext, code)
if err != nil {
return context.String(http.StatusInternalServerError, err.Error())
}
// Getting the user information
client := conf.Client(oauth2.NoContext, token)
resp, err := client.Get("https://" + domain + "/userinfo")
if err != nil {
return context.String(http.StatusInternalServerError, err.Error())
}
// Reading the body
raw, err := ioutil.ReadAll(resp.Body)
defer resp.Body.Close()
if err != nil {
return context.String(http.StatusInternalServerError, err.Error())
}
// Unmarshal the JSON of the Auth0 profile
var profile map[string]interface{}
if err := json.Unmarshal(raw, &profile); err != nil {
return context.String(http.StatusInternalServerError, err.Error())
}
helpers.MakeCookie(context, "id_token", token.Extra("id_token").(string))
// Redirect to logged in page
context.Redirect(http.StatusMovedPermanently, "/frontend")
return context.String(http.StatusOK, "Callback finished") // We'll never actually hit this...?
}
示例14: NodeTopics
// NodeTopics 某節點下的主題列表
func (TopicController) NodeTopics(ctx echo.Context) error {
curPage := goutils.MustInt(ctx.QueryParam("p"), 1)
paginator := logic.NewPaginator(curPage)
querystring, nid := "nid=?", goutils.MustInt(ctx.Param("nid"))
topics := logic.DefaultTopic.FindAll(ctx, paginator, "topics.mtime DESC", querystring, nid)
total := logic.DefaultTopic.Count(ctx, querystring, nid)
pageHtml := paginator.SetTotal(total).GetPageHtml(ctx.Request().URL().Path())
// 當前節點信息
node := logic.GetNode(nid)
return render(ctx, "topics/node.html", map[string]interface{}{"activeTopics": "active", "topics": topics, "page": template.HTML(pageHtml), "total": total, "node": node})
}
示例15: ReadingList
// ReadingList 晨讀列表頁
func (ReadingController) ReadingList(ctx echo.Context) error {
limit := 20
lastId := goutils.MustInt(ctx.QueryParam("lastid"))
rtype := goutils.MustInt(ctx.QueryParam("rtype"), model.RtypeGo)
readings := logic.DefaultReading.FindBy(ctx, limit+5, rtype, lastId)
num := len(readings)
if num == 0 {
if lastId == 0 {
return ctx.Redirect(http.StatusSeeOther, "/")
} else {
return ctx.Redirect(http.StatusSeeOther, "/readings")
}
}
var (
hasPrev, hasNext bool
prevId, nextId int
)
if lastId > 0 {
prevId = lastId
// 避免因為項目下線,導致判斷錯誤(所以 > 5)
if prevId-readings[0].Id > 5 {
hasPrev = false
} else {
prevId += limit
hasPrev = true
}
}
if num > limit {
hasNext = true
readings = readings[:limit]
nextId = readings[limit-1].Id
} else {
nextId = readings[num-1].Id
}
pageInfo := map[string]interface{}{
"has_prev": hasPrev,
"prev_id": prevId,
"has_next": hasNext,
"next_id": nextId,
}
return render(ctx, "readings/list.html", map[string]interface{}{"activeReadings": "active", "readings": readings, "page": pageInfo, "rtype": rtype})
}