params.go 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. // Copyright 2018 Frédéric Guillot. All rights reserved.
  2. // Use of this source code is governed by the Apache 2.0
  3. // license that can be found in the LICENSE file.
  4. package request // import "miniflux.app/http/request"
  5. import (
  6. "net/http"
  7. "strconv"
  8. "github.com/gorilla/mux"
  9. )
  10. // FormInt64Value returns a form value as integer.
  11. func FormInt64Value(r *http.Request, param string) int64 {
  12. value := r.FormValue(param)
  13. integer, err := strconv.ParseInt(value, 10, 64)
  14. if err != nil {
  15. return 0
  16. }
  17. return integer
  18. }
  19. // RouteInt64Param returns an URL route parameter as int64.
  20. func RouteInt64Param(r *http.Request, param string) int64 {
  21. vars := mux.Vars(r)
  22. value, err := strconv.ParseInt(vars[param], 10, 64)
  23. if err != nil {
  24. return 0
  25. }
  26. if value < 0 {
  27. return 0
  28. }
  29. return value
  30. }
  31. // RouteStringParam returns a URL route parameter as string.
  32. func RouteStringParam(r *http.Request, param string) string {
  33. vars := mux.Vars(r)
  34. return vars[param]
  35. }
  36. // QueryStringParam returns a query string parameter as string.
  37. func QueryStringParam(r *http.Request, param, defaultValue string) string {
  38. value := r.URL.Query().Get(param)
  39. if value == "" {
  40. value = defaultValue
  41. }
  42. return value
  43. }
  44. // QueryIntParam returns a query string parameter as integer.
  45. func QueryIntParam(r *http.Request, param string, defaultValue int) int {
  46. return int(QueryInt64Param(r, param, int64(defaultValue)))
  47. }
  48. // QueryInt64Param returns a query string parameter as int64.
  49. func QueryInt64Param(r *http.Request, param string, defaultValue int64) int64 {
  50. value := r.URL.Query().Get(param)
  51. if value == "" {
  52. return defaultValue
  53. }
  54. val, err := strconv.ParseInt(value, 10, 64)
  55. if err != nil {
  56. return defaultValue
  57. }
  58. if val < 0 {
  59. return defaultValue
  60. }
  61. return val
  62. }
  63. // HasQueryParam checks if the query string contains the given parameter.
  64. func HasQueryParam(r *http.Request, param string) bool {
  65. values := r.URL.Query()
  66. _, ok := values[param]
  67. return ok
  68. }