You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

186 lines
6.3 KiB

6 months ago
require_relative '../carto/http/client'
module Cartodb
class Central
def self.sync_data_with_cartodb_central?
Cartodb.get_config(:cartodb_central_api, 'username').present? &&
Cartodb.get_config(:cartodb_central_api, 'password').present?
end
def initialize
config_host = Cartodb.get_config(:cartodb_central_api, 'host')
config_port = Cartodb.get_config(:cartodb_central_api, 'port')
@host = "http#{'s' if Rails.env.production? || Rails.env.staging?}://#{config_host}"
@host << ":#{config_port}" if config_port.present?
@auth = {
username: Cartodb.get_config(:cartodb_central_api, 'username'),
password: Cartodb.get_config(:cartodb_central_api, 'password')
}
end
def host
@host
end
def google_signup_url
"#{host}/google/signup"
end
def login_url
URI.join(host, 'login').to_s
end
def unverified_url
URI.join(host, 'unverified').to_s
end
def build_request(path, body, method, timeout = 200)
http_client = Carto::Http::Client.get('central', log_requests: true)
http_client.request(
"#{@host}/#{path}",
method: method,
body: body.nil? ? nil: body.to_json,
userpwd: "#{@auth[:username]}:#{@auth[:password]}",
headers: { "Content-Type" => "application/json" },
ssl_verifypeer: Rails.env.production?,
timeout: timeout,
followlocation: true
)
end
def send_request(path, body, method, expected_codes, timeout = nil)
request = build_request(path, body, method, timeout)
response = request.run
if expected_codes.include?(response.code)
return response.body && response.body.length >= 2 ? JSON.parse(response.body) : {}
else
raise CartoDB::CentralCommunicationFailure.new(response)
end
end
def get_user(username_or_email)
send_request("api/users/#{username_or_email}", nil, :get, [200, 404])
end
def get_organization_users(organization_name)
send_request("api/organizations/#{ organization_name }/users", nil, :get, [200], 600)
end
def get_organization_user(organization_name, username)
send_request("api/organizations/#{ organization_name }/users/#{ username }", nil, :get, [200])
end
def create_organization_user(organization_name, user_attributes)
body = {user: user_attributes}
send_request("api/organizations/#{ organization_name }/users", body, :post, [201])
end
def update_organization_user(organization_name, username, user_attributes)
body = {user: user_attributes}
send_request("api/organizations/#{ organization_name }/users/#{ username }", body, :put, [204])
end
def delete_organization_user(organization_name, username)
send_request("api/organizations/#{organization_name}/users/#{username}", nil, :delete, [204, 404])
end
def update_user(username, user_attributes)
body = {user: user_attributes}
send_request("api/users/#{username}", body, :put, [204])
end
def delete_user(username)
send_request("api/users/#{username}", nil, :delete, [204, 404])
end
def check_do_enabled(username)
send_request("api/users/#{username}/do_status", nil, :get, [200])
end
def get_do_token(username)
send_request("api/users/#{username}/do_token", nil, :get, [200])
end
def create_do_datasets(username:, datasets:)
body = { datasets: datasets }
send_request("api/users/#{username}/do/datasets", body, :post, [201])
end
def remove_do_dataset(username:, id:)
send_request("api/users/#{username}/do/datasets/#{id}", nil, :delete, [204])
end
############################################################################
# Organizations
def get_organizations
send_request("api/organizations", nil, :get, [200], 600)
end
def get_organization(organization_name)
send_request("api/organizations/#{ organization_name }", nil, :get, [200])
end
# Returns remote organization attributes if response code is 201
# otherwise returns nil
# luisico asks: Not sure why organization_name is passed to this method. It's not used
# rilla answers: That's right, but this methods is just a stub: org creation from the editor is still unsupported
def create_organization(organization_name, organization_attributes)
body = {organization: organization_attributes}
send_request("api/organizations", body, :post, [201])
end
def update_organization(organization_name, organization_attributes)
body = {organization: organization_attributes}
send_request("api/organizations/#{ organization_name }", body, :put, [204])
end
def delete_organization(organization_name)
send_request("api/organizations/#{organization_name}", nil, :delete, [204, 404])
end
############################################################################
# Mobile apps
def get_mobile_apps(username)
send_request("api/users/#{username}/mobile_apps", nil, :get, [200])
end
def get_mobile_app(username, app_id)
send_request("api/users/#{username}/mobile_apps/#{app_id}", nil, :get, [200])
end
def create_mobile_app(username, mobile_app_attributes)
body = { mobile_app: mobile_app_attributes }
send_request("api/users/#{username}/mobile_apps", body, :post, [201])
end
def update_mobile_app(username, app_id, mobile_app_attributes)
body = { mobile_app: mobile_app_attributes }
send_request("api/users/#{username}/mobile_apps/#{app_id}", body, :put, [204])
end
def delete_mobile_app(username, app_id)
send_request("api/users/#{username}/mobile_apps/#{app_id}", nil, :delete, [204])
end
############################################################################
# OAuth apps
def create_oauth_app(username, oauth_app_attributes)
body = { oauth_app: oauth_app_attributes }
send_request("api/users/#{username}/oauth_apps", body, :post, [201])
end
def update_oauth_app(username, app_id, oauth_app_attributes)
body = { oauth_app: oauth_app_attributes }
send_request("api/users/#{username}/oauth_apps/#{app_id}", body, :put, [204])
end
def delete_oauth_app(username, app_id)
send_request("api/users/#{username}/oauth_apps/#{app_id}", nil, :delete, [204])
end
end
end