Class: SalesforceBulkClient::Job
- Inherits:
- 
      Object
      
        - Object
- SalesforceBulkClient::Job
 
- Defined in:
- lib/salesforce_bulk_client/job.rb
Instance Attribute Summary collapse
- 
  
    
      #job_id  ⇒ Object 
    
    
  
  
  
  
    
      readonly
    
    
  
  
  
  
  
  
    Returns the value of attribute job_id. 
Instance Method Summary collapse
- #add_batch(batch) ⇒ Object
- #add_batches ⇒ Object
- #add_query ⇒ Object
- #check_batch_status(batch_id) ⇒ Object
- #check_job_status ⇒ Object
- #close_job ⇒ Object
- #create_job(batch_size) ⇒ Object
- #each_batch(timeout = 3600, poll_delay = 5) ⇒ Object
- #get_batch_result(batch_id) ⇒ Object
- #get_job_result(return_result, timeout, poll_delay) ⇒ Object
- 
  
    
      #initialize(args)  ⇒ Job 
    
    
  
  
  
    constructor
  
  
  
  
  
  
  
    A new instance of Job. 
- #list_batches ⇒ Object
Constructor Details
#initialize(args) ⇒ Job
Returns a new instance of Job.
| 9 10 11 12 13 14 15 16 17 | # File 'lib/salesforce_bulk_client/job.rb', line 9 def initialize(args) @job_id = args[:job_id] @operation = args[:operation] @sobject = args[:sobject] @external_field = args[:external_field] @records = args[:records] @connection = args[:connection] @batch_ids = [] end | 
Instance Attribute Details
#job_id ⇒ Object (readonly)
Returns the value of attribute job_id.
| 7 8 9 | # File 'lib/salesforce_bulk_client/job.rb', line 7 def job_id @job_id end | 
Instance Method Details
#add_batch(batch) ⇒ Object
| 46 47 48 49 | # File 'lib/salesforce_bulk_client/job.rb', line 46 def add_batch(batch) add_batch_result = @connection.post_request("job/#{@job_id}/batch", batch) add_batch_result.id end | 
#add_batches ⇒ Object
| 39 40 41 42 43 44 | # File 'lib/salesforce_bulk_client/job.rb', line 39 def add_batches raise 'Records must be an array of hashes.' unless @records.is_a? Array @records.each_slice(@batch_size) do |batch| @batch_ids << add_batch(batch) end end | 
#add_query ⇒ Object
| 34 35 36 37 | # File 'lib/salesforce_bulk_client/job.rb', line 34 def add_query add_query_result = @connection.post_request("job/#{@job_id}/batch", @records, false) @batch_ids << add_query_result.id end | 
#check_batch_status(batch_id) ⇒ Object
| 55 56 57 | # File 'lib/salesforce_bulk_client/job.rb', line 55 def check_batch_status(batch_id) @connection.get_request("job/#{@job_id}/batch/#{batch_id}") end | 
#check_job_status ⇒ Object
| 51 52 53 | # File 'lib/salesforce_bulk_client/job.rb', line 51 def check_job_status @connection.get_request("job/#{@job_id}") end | 
#close_job ⇒ Object
| 29 30 31 32 | # File 'lib/salesforce_bulk_client/job.rb', line 29 def close_job close_job_request = { state: 'Closed' } @connection.post_request("job/#{@job_id}", close_job_request) end | 
#create_job(batch_size) ⇒ Object
| 19 20 21 22 23 24 25 26 27 | # File 'lib/salesforce_bulk_client/job.rb', line 19 def create_job(batch_size) @batch_size = batch_size create_job_request = { operation: @operation.to_s.downcase, object: @sobject, contentType: 'JSON' } if !@external_field.nil? create_job_request[:externalIdFieldName] = @external_field end create_job_result = @connection.post_request('job', create_job_request) @job_id = create_job_result.id end | 
#each_batch(timeout = 3600, poll_delay = 5) ⇒ Object
| 116 117 118 119 120 121 122 123 124 125 | # File 'lib/salesforce_bulk_client/job.rb', line 116 def each_batch(timeout = 3600, poll_delay = 5) job_result = self.get_job_result(false, timeout, poll_delay) job_result.batches.each do |batch_info| batch_result = nil if batch_info.state == 'Completed' batch_result = self.get_batch_result(batch_info.id) end yield(batch_info, batch_result) end end | 
#get_batch_result(batch_id) ⇒ Object
| 103 104 105 106 107 108 109 110 111 112 113 114 | # File 'lib/salesforce_bulk_client/job.rb', line 103 def get_batch_result(batch_id) batch_results = @connection.get_request("job/#{@job_id}/batch/#{batch_id}/result") results = [] if @operation.to_s != 'query' results = batch_results else batch_results.each do |batch_result_id| results.concat(@connection.get_request("job/#{@job_id}/batch/#{batch_id}/result/#{batch_result_id}")) end end results end | 
#get_job_result(return_result, timeout, poll_delay) ⇒ Object
| 63 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 | # File 'lib/salesforce_bulk_client/job.rb', line 63 def get_job_result(return_result, timeout, poll_delay) batch_infos = [] polling_started = false polling_completed = false FirePoll.poll("Timeout waiting for Salesforce to process job batches #{@batch_ids} of job #{@job_id}.", timeout) do sleep poll_delay if polling_started polling_started = true job_status = self.check_job_status if job_status.state == 'Closed' batch_info_map = {} batches_ready = @batch_ids.all? do |batch_id| batch_info = batch_info_map[batch_id] = self.check_batch_status(batch_id) batch_info.state != 'Queued' && batch_info != 'InProgress' end if batches_ready @batch_ids.each do |batch_id| batch_infos.insert(0, batch_info_map[batch_id]) @batch_ids.delete(batch_id) end end polling_completed = true if @batch_ids.empty? else polling_completed = true end polling_completed end job_status = self.check_job_status batch_infos.each_with_index do |batch_state, i| if batch_state.state == 'Completed' && return_result == true batch_infos[i].merge!({ 'response' => self.get_batch_result(batch_state.id)}) end end job_status.merge!({ 'batches' => batch_infos }) job_status end | 
#list_batches ⇒ Object
| 59 60 61 | # File 'lib/salesforce_bulk_client/job.rb', line 59 def list_batches @connection.get_request("job/#{@job_id}/batch")&.batchInfo end |