helpers.rb
4.97 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
module API
  module APIHelpers
    PRIVATE_TOKEN_PARAM = :private_token
    def logger
      API.logger
    end
    def current_user
      private_token = params[PRIVATE_TOKEN_PARAM].to_s
      @current_user ||= User.find_by_private_token(private_token)
      @current_user = nil if !@current_user.nil? && @current_user.private_token_expired?
      @current_user
    end
    def current_person
      current_user.person unless current_user.nil?
    end
    def logout
      @current_user = nil
    end
    def environment
      @environment
    end
    def limit
      limit = params[:limit].to_i
      limit = default_limit if limit <= 0
      limit
    end
    def period(from_date, until_date)
      return nil if from_date.nil? && until_date.nil?
      begin_period = from_date.nil? ? Time.at(0).to_datetime : from_date
      end_period = until_date.nil? ? DateTime.now : until_date
      begin_period..end_period
    end
    def parse_content_type(content_type)
      return nil if content_type.blank?
      content_type.split(',').map do |content_type|
        content_type.camelcase
      end
    end
    def make_conditions_with_parameter(params = {})
      conditions = {}
      from_date = DateTime.parse(params[:from]) if params[:from]
      until_date = DateTime.parse(params[:until]) if params[:until]
      conditions[:type] = parse_content_type(params[:content_type]) unless params[:content_type].nil?
      conditions[:created_at] = period(from_date, until_date) if from_date || until_date
      conditions
    end
    def select_filtered_collection_of(object, method, params)
      conditions = make_conditions_with_parameter(params)
               
      if params[:reference_id]
        objects = object.send(method).send("#{params.key?(:oldest) ? 'older_than' : 'newer_than'}", params[:reference_id]).find(:all, :conditions => conditions, :limit => limit, :order => "created_at DESC")
      else
        objects = object.send(method).find(:all, :conditions => conditions, :limit => limit, :order => "created_at DESC")
      end
      objects
    end
#FIXME see if its needed
#    def paginate(relation)
#      per_page  = params[:per_page].to_i
#      paginated = relation.page(params[:page]).per(per_page)
#      add_pagination_headers(paginated, per_page)
#
#      paginated
#    end
    def authenticate!
      unauthorized! unless current_user
    end
#FIXME see if its needed
#    def authenticated_as_admin!
#      forbidden! unless current_user.is_admin?
#    end
#
#FIXME see if its needed
#    def authorize! action, subject
#      unless abilities.allowed?(current_user, action, subject)
#        forbidden!
#      end
#    end
#
#FIXME see if its needed
#    def can?(object, action, subject)
#      abilities.allowed?(object, action, subject)
#    end
    # Checks the occurrences of required attributes, each attribute must be present in the params hash
    # or a Bad Request error is invoked.
    #
    # Parameters:
    #   keys (required) - A hash consisting of keys that must be present
    def required_attributes!(keys)
      keys.each do |key|
        bad_request!(key) unless params[key].present?
      end
    end
    # Checks the occurrences of uniqueness of attributes, each attribute must be present in the params hash
    # or a Bad Request error is invoked.
    #
    # Parameters:
    #   keys (unique) - A hash consisting of keys that must be unique
    def unique_attributes!(obj, keys)
      keys.each do |key|
        cant_be_saved_request!(key) if obj.send("find_by_#{key.to_s}", params[key])
      end
    end
    def attributes_for_keys(keys)
      attrs = {}
      keys.each do |key|
        attrs[key] = params[key] if params[key].present? or (params.has_key?(key) and params[key] == false)
      end
      attrs
    end
    # error helpers
    def forbidden!
      render_api_error!('403 Forbidden', 403)
    end
    def cant_be_saved_request!(attribute)
      message = _("(Invalid request) #{attribute} can't be saved")
      render_api_error!(message, 400)
    end
    def bad_request!(attribute)
      message = _("(Bad request) #{attribute} not given")
      render_api_error!(message, 400)
    end
    def something_wrong!
      message = _("Something wrong happened")
      render_api_error!(message, 400)
    end
    def unauthorized!
      render_api_error!(_('Unauthorized'), 401)
    end
    def not_allowed!
      render_api_error!(_('Method Not Allowed'), 405)
    end
    def render_api_error!(message, status)
      error!({'message' => message, :code => status}, status)
    end
    protected
    def detect_stuff_by_domain
      @domain = Domain.find_by_name(request.host)
      if @domain.nil?
        @environment = Environment.default
        if @environment.nil? && Rails.env.development?
          # This should only happen in development ...
          @environment = Environment.create!(:name => "Noosfero", :is_default => true)
        end
      else
        @environment = @domain.environment
      end
    end
    private
    def default_limit
      20
    end
  end
end