diff options
author | Paul Duncan <pabs@pablotron.org> | 2016-03-08 13:07:57 -0500 |
---|---|---|
committer | Paul Duncan <pabs@pablotron.org> | 2016-03-08 13:07:57 -0500 |
commit | 46418b2237f86dc7b41c8c2a3dd5725634dceffe (patch) | |
tree | 1874bc0416d3f1530d91f249a487779ff95d4914 /src/guff/api | |
parent | 1cbbb00e3c6bcf4255fee485de3f2828ff2d1d4c (diff) | |
download | old-guff-46418b2237f86dc7b41c8c2a3dd5725634dceffe.tar.bz2 old-guff-46418b2237f86dc7b41c8c2a3dd5725634dceffe.zip |
add date filters
Diffstat (limited to 'src/guff/api')
-rw-r--r-- | src/guff/api/methods.cr | 27 | ||||
-rw-r--r-- | src/guff/api/post.cr | 16 |
2 files changed, 34 insertions, 9 deletions
diff --git a/src/guff/api/methods.cr b/src/guff/api/methods.cr index 758cca9..f3a7f3c 100644 --- a/src/guff/api/methods.cr +++ b/src/guff/api/methods.cr @@ -16,6 +16,24 @@ module Guff default: "", }, + "year": { + text: "Year filter", + type: :int, + required: false, + }, + + "month": { + text: "Month filter", + type: :int, + required: false, + }, + + "day": { + text: "Day filter", + type: :int, + required: false, + }, + "page": { text: "Page number", type: :int, @@ -338,14 +356,7 @@ module Guff end # get value - val = if arg_data[:required] - params.fetch(arg_name) - # elsif arg_data.has_key?(:default) - elsif arg_data[:default]? - params.fetch(arg_name, arg_data[:default] as String) - else - nil - end + val = params.fetch(arg_name, arg_data[:default]?) as String? if val # check value diff --git a/src/guff/api/post.cr b/src/guff/api/post.cr index 7141530..55abd86 100644 --- a/src/guff/api/post.cr +++ b/src/guff/api/post.cr @@ -3,13 +3,27 @@ require "json" module Guff module API module PostAPI + GET_POSTS_FILTERS = { + q: "q", + year: "year", + month: "month", + day: "day", + } + private def do_post_get_posts( context : HTTP::Server::Context, args : Hash(String, String) ) + # build filters + filters = GET_POSTS_FILTERS.reduce({} of Symbol => String) do |r, k, s| + r[k] = args[s] if args.has_key?(s) + r + end + + # get and return posts @models.post.get_posts( site_id: get_site(context), - q: args["q"]? || "", + filters: filters, tags: get_posts_tags(args["tags"]), page: args.has_key?("page") ? args["page"].to_i : 1, ) |