Module: Ballast::Concerns::Common
- Defined in:
- lib/ballast/concerns/common.rb
Overview
A concern to handle common tasks in an application.
Instance Method Summary (collapse)
-
- (Object) authenticate_user(area: nil, title: nil, message: nil, &authenticator)
Authenticates a user via HTTP, handling the error if the authentication failed.
-
- (Object) format_long_date(date, separator: "•", format: "%I:%M%p %- %b %o, %Y (%:Z)")
Formats a long date.
-
- (String) format_short_amount(amount, suffix = "")
Formats a short amount of time (less than one hour).
-
- (String) format_short_duration(date, reference: nil, suffix: "")
Formats a relative date using abbreviation or short formats.
-
- (Boolean) json?
Checks if the current request wants JSON or JSONP as response.
-
- (Service::Response) perform_service(klass, operation = :perform, **kwargs)
Executes a service.
-
- (Boolean) request_data?
Checks if the user is sending any data.
Instance Method Details
- (Object) authenticate_user(area: nil, title: nil, message: nil, &authenticator)
Authenticates a user via HTTP, handling the error if the authentication failed.
87 88 89 90 91 92 93 94 95 96 |
# File 'lib/ballast/concerns/common.rb', line 87 def authenticate_user(area: nil, title: nil, message: nil, &authenticator) return if authenticate_with_http_basic { |username, password| authenticator.call(username, password) } area ||= "Private Area" title ||= "Authentication required." ||= "To view this resource you have to authenticate." headers["WWW-Authenticate"] = "Basic realm=\"#{area}\"" handle_error({status: 401, title: title, message: }) end |
- (Object) format_long_date(date, separator: "•", format: "%I:%M%p %- %b %o, %Y (%:Z)")
Formats a long date.
75 76 77 78 79 |
# File 'lib/ballast/concerns/common.rb', line 75 def format_long_date(date, separator: "•", format: "%I:%M%p %- %b %o, %Y (%:Z)") tz = Time.zone replacements = {"%-" => separator, "%o" => date.day.ordinalize, "%:Z" => tz.current_name(tz.uses_dst? && date.dst?)} date.strftime(format).gsub(/%(-|o|(:Z))/) { |r| replacements.fetch(r, r) } end |
- (String) format_short_amount(amount, suffix = "")
Formats a short amount of time (less than one hour).
59 60 61 62 63 64 65 66 67 |
# File 'lib/ballast/concerns/common.rb', line 59 def format_short_amount(amount, suffix = "") if amount < 1.minute "#{amount.floor}s#{suffix}" elsif amount < 1.hour "#{(amount / 60).floor}m#{suffix}" else "#{(amount / 3600).floor}h#{suffix}" end end |
- (String) format_short_duration(date, reference: nil, suffix: "")
Formats a relative date using abbreviation or short formats.
40 41 42 43 44 45 46 47 48 49 50 51 52 |
# File 'lib/ballast/concerns/common.rb', line 40 def format_short_duration(date, reference: nil, suffix: "") amount = (reference || Time.now).to_i - date.to_i if amount <= 0 "now" elsif amount < 1.day format_short_amount(amount, suffix) elsif amount < 1.year date.strftime("%b %d") else date.strftime("%b %d %Y") end end |
- (Boolean) json?
Checks if the current request wants JSON or JSONP as response.
23 24 25 |
# File 'lib/ballast/concerns/common.rb', line 23 def json? [:json, :jsonp].include?(request.format.to_sym) || params[:json].to_boolean end |
- (Service::Response) perform_service(klass, operation = :perform, **kwargs)
Executes a service.
16 17 18 |
# File 'lib/ballast/concerns/common.rb', line 16 def perform_service(klass, operation = :perform, **kwargs) @result = klass.new(self).call(operation, params: params, **kwargs) end |
- (Boolean) request_data?
Checks if the user is sending any data.
30 31 32 |
# File 'lib/ballast/concerns/common.rb', line 30 def request_data? request.post? || request.put? || request.patch? end |