Class: SalesforceBulkApi::Api
- Inherits:
-
Object
- Object
- SalesforceBulkApi::Api
- Defined in:
- lib/salesforce_bulk_api.rb
Constant Summary collapse
- SALESFORCE_API_VERSION =
'46.0'
Instance Attribute Summary collapse
-
#connection ⇒ Object
readonly
Returns the value of attribute connection.
Instance Method Summary collapse
- #counters ⇒ Object
- #create(sobject, records, get_response = false, send_nulls = false, batch_size = 10000, timeout = 1500) ⇒ Object
- #delete(sobject, records, get_response = false, batch_size = 10000, timeout = 1500) ⇒ Object
- #do_operation(operation, sobject, records, external_field, get_response, timeout, batch_size, send_nulls = false, no_null_list = []) ⇒ Object
-
#initialize(client) ⇒ Api
constructor
A new instance of Api.
- #job_from_id(job_id) ⇒ Object
-
#on_job_created(&block) ⇒ Object
Allows you to attach a listener that accepts the created job (which has a useful #job_id field).
- #query(sobject, query, batch_size = 10000, timeout = 1500) ⇒ Object
- #update(sobject, records, get_response = false, send_nulls = false, no_null_list = [], batch_size = 10000, timeout = 1500) ⇒ Object
- #upsert(sobject, records, external_field, get_response = false, send_nulls = false, no_null_list = [], batch_size = 10000, timeout = 1500) ⇒ Object
Constructor Details
#initialize(client) ⇒ Api
Returns a new instance of Api.
18 19 20 21 |
# File 'lib/salesforce_bulk_api.rb', line 18 def initialize(client) @connection = SalesforceBulkApi::Connection.new(SALESFORCE_API_VERSION, client) @listeners = { job_created: [] } end |
Instance Attribute Details
#connection ⇒ Object (readonly)
Returns the value of attribute connection.
14 15 16 |
# File 'lib/salesforce_bulk_api.rb', line 14 def connection @connection end |
Instance Method Details
#counters ⇒ Object
43 44 45 46 47 48 49 50 51 52 53 |
# File 'lib/salesforce_bulk_api.rb', line 43 def counters { http_get: @connection.counters[:get], http_post: @connection.counters[:post], upsert: get_counters[:upsert], update: get_counters[:update], create: get_counters[:create], delete: get_counters[:delete], query: get_counters[:query] } end |
#create(sobject, records, get_response = false, send_nulls = false, batch_size = 10000, timeout = 1500) ⇒ Object
31 32 33 |
# File 'lib/salesforce_bulk_api.rb', line 31 def create(sobject, records, get_response = false, send_nulls = false, batch_size = 10000, timeout = 1500) do_operation('insert', sobject, records, nil, get_response, timeout, batch_size, send_nulls) end |
#delete(sobject, records, get_response = false, batch_size = 10000, timeout = 1500) ⇒ Object
35 36 37 |
# File 'lib/salesforce_bulk_api.rb', line 35 def delete(sobject, records, get_response = false, batch_size = 10000, timeout = 1500) do_operation('delete', sobject, records, nil, get_response, timeout, batch_size) end |
#do_operation(operation, sobject, records, external_field, get_response, timeout, batch_size, send_nulls = false, no_null_list = []) ⇒ Object
68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 |
# File 'lib/salesforce_bulk_api.rb', line 68 def do_operation(operation, sobject, records, external_field, get_response, timeout, batch_size, send_nulls = false, no_null_list = []) count operation.to_sym job = SalesforceBulkApi::Job.new( operation: operation, sobject: sobject, records: records, external_field: external_field, connection: @connection ) job.create_job(batch_size, send_nulls, no_null_list) @listeners[:job_created].each {|callback| callback.call(job)} operation == "query" ? job.add_query() : job.add_batches() response = job.close_job response.merge!({'batches' => job.get_job_result(get_response, timeout)}) if get_response == true response end |
#job_from_id(job_id) ⇒ Object
64 65 66 |
# File 'lib/salesforce_bulk_api.rb', line 64 def job_from_id(job_id) SalesforceBulkApi::Job.new(job_id: job_id, connection: @connection) end |
#on_job_created(&block) ⇒ Object
Allows you to attach a listener that accepts the created job (which has a useful #job_id field). This is useful for recording a job ID persistently before you begin batch work (i.e. start modifying the salesforce database), so if the load process you are writing needs to recover, it can be aware of previous jobs it started and wait for them to finish.
60 61 62 |
# File 'lib/salesforce_bulk_api.rb', line 60 def on_job_created(&block) @listeners[:job_created] << block end |
#query(sobject, query, batch_size = 10000, timeout = 1500) ⇒ Object
39 40 41 |
# File 'lib/salesforce_bulk_api.rb', line 39 def query(sobject, query, batch_size = 10000, timeout = 1500) do_operation('query', sobject, query, nil, true, timeout, batch_size) end |
#update(sobject, records, get_response = false, send_nulls = false, no_null_list = [], batch_size = 10000, timeout = 1500) ⇒ Object
27 28 29 |
# File 'lib/salesforce_bulk_api.rb', line 27 def update(sobject, records, get_response = false, send_nulls = false, no_null_list = [], batch_size = 10000, timeout = 1500) do_operation('update', sobject, records, nil, get_response, timeout, batch_size, send_nulls, no_null_list) end |
#upsert(sobject, records, external_field, get_response = false, send_nulls = false, no_null_list = [], batch_size = 10000, timeout = 1500) ⇒ Object
23 24 25 |
# File 'lib/salesforce_bulk_api.rb', line 23 def upsert(sobject, records, external_field, get_response = false, send_nulls = false, no_null_list = [], batch_size = 10000, timeout = 1500) do_operation('upsert', sobject, records, external_field, get_response, timeout, batch_size, send_nulls, no_null_list) end |