Class: SalesforceBulkApi::Api
- Inherits:
-
Object
- Object
- SalesforceBulkApi::Api
- Defined in:
- lib/salesforce_bulk_api.rb
Constant Summary collapse
- @@SALESFORCE_API_VERSION =
'32.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.
19 20 21 22 |
# File 'lib/salesforce_bulk_api.rb', line 19 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.
15 16 17 |
# File 'lib/salesforce_bulk_api.rb', line 15 def connection @connection end |
Instance Method Details
#counters ⇒ Object
44 45 46 47 48 49 50 51 52 53 54 |
# File 'lib/salesforce_bulk_api.rb', line 44 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
32 33 34 |
# File 'lib/salesforce_bulk_api.rb', line 32 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
36 37 38 |
# File 'lib/salesforce_bulk_api.rb', line 36 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
70 71 72 73 74 75 76 77 78 79 80 81 |
# File 'lib/salesforce_bulk_api.rb', line 70 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
66 67 68 |
# File 'lib/salesforce_bulk_api.rb', line 66 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.
62 63 64 |
# File 'lib/salesforce_bulk_api.rb', line 62 def on_job_created(&block) @listeners[:job_created] << block end |
#query(sobject, query, batch_size = 10000, timeout = 1500) ⇒ Object
40 41 42 |
# File 'lib/salesforce_bulk_api.rb', line 40 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
28 29 30 |
# File 'lib/salesforce_bulk_api.rb', line 28 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
24 25 26 |
# File 'lib/salesforce_bulk_api.rb', line 24 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 |