Class: Accession::Request

Inherits:
Object
  • Object
show all
Includes:
ActiveModel::Validations
Defined in:
lib/accession/accession/request.rb

Overview

Does what is says on the tin. Accepts an Accession::Submission and creates a resource based on the service submission. The resource will be a RestClient::Resource which will relate to the specified accessioning service.

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(submission) ⇒ Request

Returns a new instance of Request.



25
26
27
28
29
30
31
32
# File 'lib/accession/accession/request.rb', line 25

def initialize(submission)
  @submission = submission

  if valid?
    @resource = rest_client.new(submission.service.url, submission.service.)
    set_proxy
  end
end

Instance Attribute Details

#resourceObject (readonly)

Returns the value of attribute resource.



14
15
16
# File 'lib/accession/accession/request.rb', line 14

def resource
  @resource
end

#submissionObject (readonly)

Returns the value of attribute submission.



14
15
16
# File 'lib/accession/accession/request.rb', line 14

def submission
  @submission
end

Class Method Details

.post(submission) ⇒ Object



21
22
23
# File 'lib/accession/accession/request.rb', line 21

def self.post(submission)
  new(submission).post
end

Instance Method Details

#postObject

Post the submission to the appropriate accessioning service It will open the payload of the submission. If the service errors it will return a NullResponse Makes sure that the payload is closed.



38
39
40
41
42
43
44
45
46
47
# File 'lib/accession/accession/request.rb', line 38

def post
  return unless valid?

  Accession::Response.new(resource.post(submission.payload.open))
rescue StandardError => e
  handle_exception(e, message: 'Posting of accession submission failed')
  Accession::NullResponse.new
ensure
  submission&.payload&.close!
end