module WolfCore::HttpOperations

def async_http_get(**args)

def async_http_get(**args)
  log_object 'starting async_http_get'
  log_object args, title: 'async_http_get args are'
  run_async do
    response = http_get(**args)
    log_object parse_http_response(response), title: 'async_http_get response is'
  end
end

def async_http_post(**args)

def async_http_post(**args)
  log_object "starting async_http_post"
  log_object args, title: 'async_http_post args are'
  run_async do
    response = http_post(**args)
    log_object parse_http_response(response), title: 'async_http_post response is'
  end
end

def async_http_put(**args)

def async_http_put(**args)
  log_object 'starting async_http_put'
  log_object args, title: 'async_http_put args are'
  run_async do
    response = http_put(**args)
    log_object parse_http_response(response), title: 'async_http_put response is'
  end
end

def http_get(url:, headers: {}, query: nil)

def http_get(url:, headers: {}, query: nil)
  WolfCore::HttpDataSource.http_get(url: url, headers: headers, query: query)
end

def http_post(url:, headers: {}, body: nil, query: nil)

def http_post(url:, headers: {}, body: nil, query: nil)
  WolfCore::HttpDataSource.http_post(url: url, headers: headers, query: query, body: body)
end

def http_put(url:, headers: {}, body: nil, query: nil)

def http_put(url:, headers: {}, body: nil, query: nil)
  WolfCore::HttpDataSource.http_put(url: url, headers: headers, query: query, body: body)
end

def parse_http_response(response)

def parse_http_response(response)
  body = JSON.parse(response.body) rescue response.body
  OpenStruct.new({
    code: response.code,
    body: body,
    message: response.message,
  })
end

def safe_http_get(url:, headers: {}, query: nil, error_message: nil, title: nil)

def safe_http_get(url:, headers: {}, query: nil, error_message: nil, title: nil)
  response = http_get(url: url, headers: headers, query: query)
  response = parse_http_response(response)
  log_object response, title: title if title.present?
  error_message ||= 'Error on safe_http_get'
  validate_http_response(response: response, message: error_message)
  response
end

def safe_http_post(url:, headers: {}, body: nil, query: nil, error_message: nil, title: nil)

def safe_http_post(url:, headers: {}, body: nil, query: nil, error_message: nil, title: nil)
  response = http_post(url: url, headers: headers, body: body, query: query)
  response = parse_http_response(response)
  title ||= 'safe_http_post response is'
  log_object response, title: title
  error_message ||= 'Error on safe_http_post'
  validate_http_response(response: response, message: error_message)
  response
end

def safe_http_put(url:, headers: {}, body: nil, query: nil, error_message: nil, title: nil)

def safe_http_put(url:, headers: {}, body: nil, query: nil, error_message: nil, title: nil)
  response = http_put(url: url, headers: headers, body: body, query: query)
  response = parse_http_response(response)
  title ||= 'safe_http_put response is'
  log_object response, title: title
  error_message ||= 'Error on safe_http_put'
  validate_http_response(response: response, message: error_message)
  response
end

def validate_http_response(response:, message:, error_data: nil)

def validate_http_response(response:, message:, error_data: nil)
  unless response.code == 200
    error_data = {
      message: message,
      response: parse_http_response(response)
    }.merge(error_data || {})
    raise_service_error(error_data)
  end
end