Class: Api::Vendor::V1::ReservationsController

Inherits:
BaseController
  • Object
show all
Includes:
Concerns::Authentication, Concerns::CreateReservation, Concerns::IntegrationTestHelpers, Concerns::PaginationParam
Defined in:
app/controllers/api/vendor/v1/reservations_controller.rb

Constant Summary

Constants inherited from BaseController

BaseController::CACHE_NAMESPACE

Instance Attribute Summary

Attributes inherited from BaseController

#vendor

Instance Method Summary collapse

Methods included from LogrageCustomLogger

#append_info_to_payload

Methods included from ResponseCacheConcern

#my_response_cache

Instance Method Details

#count_transactionObject



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
# File 'app/controllers/api/vendor/v1/reservations_controller.rb', line 64

def count_transaction
  VendorLogger.log_event(:request, params[:route], payload: params)
  filter = Api::Vendor::V1::ReservationsFilter.new
  vendor_id = vendor.id
  current_user = params[:email]
  page_size = 10000
  page_number = 1
  filter.init_default(vendor_id, current_user).
    order_by(params.fetch(:order_by, nil)).
    page_number(page_number).
    per_page(page_size)

  filter.start_date(params[:from_updated_date]) if params[:from_updated_date].present?
  if params[:to_updated_date].present? && (params[:from_updated_date] > params[:to_updated_date])
    message = 'end date must bigger than start date'
    return render json: { success: false, message: message }
  elsif params[:to_updated_date].present?
    filter.end_date(params[:to_updated_date])
  end

  filter.build_collections

  reservations = filter.collections
  reservations.cache_key if reservations.present?

  time_x = Time.thai_time
  time_x_date = Time.thai_time.strftime('%F')
  start_time = time_x.strftime('%H:%M')
  reservations_pending = reservations.where('(date = ? AND start_time >= ?) OR date > ?', time_x_date, start_time,
                                            time_x_date).where(active: true, ack: true, is_temporary: true)
  reservations_upcoming = reservations.where('(date = ? AND start_time > ?) OR date > ?', time_x_date, start_time,
                                             time_x_date).where(active: true, ack: true, is_temporary: false)
  reservations_past = reservations.where('(date = ? AND start_time < ?) OR date < ?', time_x_date, start_time,
                                         time_x_date)

  serialized_data = {
    total: (reservations_pending.count + reservations_upcoming.count + reservations_past.count),
    pending: reservations_pending.count,
    upcoming: reservations_upcoming.count,
    past: reservations_past.count,
  }

  response = { data: serialized_data, success: true, message: nil }
  VendorLogger.log_event(:response, params[:route], payload: response)
  render json: response
end

#indexObject



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
# File 'app/controllers/api/vendor/v1/reservations_controller.rb', line 8

def index
  VendorLogger.log_event(:request, params[:route], payload: params)
  filter = Api::Vendor::V1::ReservationsFilter.new

  vendor_id = vendor.id
  current_user = params[:email]
  filter.init_default(vendor_id, current_user).
    order_by(params.fetch(:order_by, nil)).
    page_number(page_number_param).
    per_page(page_size_param)

  filter.start_date(params[:from_updated_date]) if params[:from_updated_date].present?
  if params[:to_updated_date].present? && (params[:from_updated_date] > params[:to_updated_date])
    message = 'end date must bigger than start date'
    return render json: { success: false, message: message }
  elsif params[:to_updated_date].present?
    filter.end_date(params[:to_updated_date])
  end

  section_type = params.fetch(:section_type, '')
  if section_type.present?
    case section_type
    when 'upcoming'
      filter.dining_time(Time.thai_time, 'gte').
        active_only(true).
        not_pending(true)
    when 'pending'
      filter.dining_time(Time.thai_time, 'gte').
        active_only(true).
        pending(true)
    when 'past'
      filter.dining_time(Time.thai_time, 'lt')
    else
      return render json: { success: false, data: nil, message: 'Invalid section_type value' }
    end
  end
  filter.build_collections

  cache_key = "#{self.class}:index:#{filter.collections.cache_key}:#{MyLocaleManager.normalize_locale}"

  my_response_cache(cache_key, :json) do
    reservations = filter.collections
    meta_options = { reservations: reservations.count }
    pagy, reservations = pagy_array(reservations, page: page_number_param.to_i, items: page_size_param.to_i,
                                                  overflow: :last_page)
    serialized_data = Api::Vendor::V1::ReservationSerializer.new(reservations,
                                                                 include: DEFAULT_INCLUDE,
                                                                 params: { vendor_name: vendor.name,
                                                                           integration_test_mode: integration_test_mode? }).serializable_hash
    serialized_data[:success] = true
    serialized_data[:message] = nil
    serialized_data
  end
  VendorLogger.log_event(:response, params[:route])
end

#showObject



111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
# File 'app/controllers/api/vendor/v1/reservations_controller.rb', line 111

def show
  reservation_id = params.require(:id)

  reservation = fetch_reservation(reservation_id)
  raise ActiveRecord::RecordNotFound if reservation.nil?

  call_reservation(reservation)
rescue ActionController::ParameterMissing => e
  render_error_response(error_message: e.message)
rescue ActiveRecord::RecordNotFound
  render_error_response(error_message: 'reservation not found')
rescue StandardError => e
  APMErrorHandler.report e
  render_error_response(error_message: e.message)
end