Class: RazorRisk::Cassini::Applications::RouteVerbAdaptors::Snapshots::Progress::CollectionGet
- Inherits:
-
RESTFramework::VerbHandler
- Object
- RESTFramework::VerbHandler
- RazorRisk::Cassini::Applications::RouteVerbAdaptors::Snapshots::Progress::CollectionGet
- Includes:
- Cassini::Mixin::RazorResponseValidator, Cassini::Util::ConversionUtil, Razor::Connectivity::Razor3::EntityConnectors, RazorRisk::Core::Diagnostics::Logger
- Defined in:
- lib/razor_risk/cassini/applications/route_verb_adaptors/snapshots/progress/collection_get.rb
Overview
########################################################################## classes
Constant Summary collapse
- HTTP_VERB =
:get
- HTTP_ACCEPTS =
[ 'application/xml', 'application/json', 'text/xml', ]
- QUERY_PARAMETERS =
[]
- ROUTE_VARIABLES =
[]
Instance Method Summary collapse
- #handle(env, params, request, response) ⇒ Object
-
#initialize(*args, **options) ⇒ CollectionGet
constructor
########################################################## methods.
Constructor Details
#initialize(*args, **options) ⇒ CollectionGet
########################################################## methods
64 65 66 67 68 |
# File 'lib/razor_risk/cassini/applications/route_verb_adaptors/snapshots/progress/collection_get.rb', line 64 def initialize *args, ** @connector_class = [:connector_class] || SnapshotsConnector super end |
Instance Method Details
#handle(env, params, request, response) ⇒ Object
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 102 103 104 105 106 107 108 109 |
# File 'lib/razor_risk/cassini/applications/route_verb_adaptors/snapshots/progress/collection_get.rb', line 70 def handle env, params, request, response trace ParamNames[ :env, :params, :request, :response ], env, params, request, response ec = @connector_class.new settings.razor_requester, credentials: get_required_credentials qr = ec.get_progress indicate_result_by: :qualified_result log :debug1, "qr(#{qr.class})='#{qr}'" # Check the request succeeded validate_qualified_razor_response qr if qr.result.nil? error HTTP_STATUS_NAMES::NOT_FOUND, 'No snapshots in progress' elsif qr.failed? log :warning, 'Failed to retrieve snapshot progress information for an unkown reason' error HTTP_STATUS_NAMES::INTERNAL_SERVER_ERROR, 'Oops! Something went wrong' end unless qr.result.xpath('snapshotProgress').any? error HTTP_STATUS_NAMES::NOT_FOUND, 'No snapshots in progress' end status HTTP_STATUS_NAMES::OK if request.accept?('application/xml') log :debug1, 'application/xml' content_type 'application/xml' qr.result.to_s elsif request.accept?('text/xml') log :debug1, 'text/xml' content_type 'text/xml' qr.result.to_s elsif request.accept?('application/json') log :debug1, 'application/json' content_type 'application/json' convert_XML_to_JSON qr.result, { scheme: :gdata } else log :violation, "unexpected failure to match given 'Accept' header '#{request.accept}'" error HTTP_STATUS_NAMES::INTERNAL_SERVER_ERROR, 'Oops! Something went wrong' end end |