Class: ModernTreasury::LedgerController
- Inherits:
-
BaseController
- Object
- BaseController
- ModernTreasury::LedgerController
- Defined in:
- lib/modern_treasury/controllers/ledger_controller.rb
Overview
LedgerController
Constant Summary
Constants inherited from BaseController
Instance Attribute Summary
Attributes inherited from BaseController
Instance Method Summary collapse
-
#create_ledger(idempotency_key: nil, body: nil) ⇒ ApiResponse
Create a ledger.
-
#delete_ledger(id) ⇒ ApiResponse
Delete a ledger.
-
#get_ledger(id) ⇒ ApiResponse
Get details on a single ledger.
-
#list_ledgers(after_cursor: nil, per_page: nil, metadata: nil, updated_at: nil) ⇒ ApiResponse
Get a list of ledgers.
-
#update_ledger(id, body: nil) ⇒ ApiResponse
Update the details of a ledger.
Methods inherited from BaseController
#initialize, #new_parameter, #new_request_builder, #new_response_handler, user_agent, user_agent_parameters
Constructor Details
This class inherits a constructor from ModernTreasury::BaseController
Instance Method Details
#create_ledger(idempotency_key: nil, body: nil) ⇒ ApiResponse
Create a ledger. something unique, preferably something like an UUID. description here
51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 |
# File 'lib/modern_treasury/controllers/ledger_controller.rb', line 51 def create_ledger(idempotency_key: nil, body: nil) @api_call .request(new_request_builder(HttpMethodEnum::POST, '/api/ledgers', Server::DEFAULT) .header_param(new_parameter('application/json', key: 'Content-Type')) .header_param(new_parameter(idempotency_key, key: 'Idempotency-Key')) .body_param(new_parameter(body)) .header_param(new_parameter('application/json', key: 'accept')) .body_serializer(proc do |param| param.to_json unless param.nil? end) .auth(Single.new('basic_auth'))) .response(new_response_handler .deserializer(APIHelper.method(:custom_type_deserializer)) .deserialize_into(Ledger.method(:from_hash)) .is_api_response(true) .local_error('403', 'forbidden', ErrorMessageException) .local_error('422', 'unsuccessful', ErrorMessageException)) .execute end |
#delete_ledger(id) ⇒ ApiResponse
Delete a ledger.
137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 |
# File 'lib/modern_treasury/controllers/ledger_controller.rb', line 137 def delete_ledger(id) @api_call .request(new_request_builder(HttpMethodEnum::DELETE, '/api/ledgers/{id}', Server::DEFAULT) .template_param(new_parameter(id, key: 'id') .is_required(true) .should_encode(true)) .header_param(new_parameter('application/json', key: 'accept')) .auth(Single.new('basic_auth'))) .response(new_response_handler .deserializer(APIHelper.method(:custom_type_deserializer)) .deserialize_into(Ledger.method(:from_hash)) .is_api_response(true) .local_error('403', 'forbidden', ErrorMessageException) .local_error('404', 'not found', ErrorMessageException)) .execute end |
#get_ledger(id) ⇒ ApiResponse
Get details on a single ledger.
79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 |
# File 'lib/modern_treasury/controllers/ledger_controller.rb', line 79 def get_ledger(id) @api_call .request(new_request_builder(HttpMethodEnum::GET, '/api/ledgers/{id}', Server::DEFAULT) .template_param(new_parameter(id, key: 'id') .is_required(true) .should_encode(true)) .header_param(new_parameter('application/json', key: 'accept')) .auth(Single.new('basic_auth'))) .response(new_response_handler .deserializer(APIHelper.method(:custom_type_deserializer)) .deserialize_into(Ledger.method(:from_hash)) .is_api_response(true) .local_error('404', 'not found', ErrorMessageException)) .execute end |
#list_ledgers(after_cursor: nil, per_page: nil, metadata: nil, updated_at: nil) ⇒ ApiResponse
Get a list of ledgers. here here you want to query for records with metadata key ‘Type` and value `Loan`, the query would be `metadata%5BType%5D=Loan`. This encodes the query parameters. (>), `gte` (>=), `lt` (<), `lte` (<=), or `eq` (=) to filter by the posted at timestamp. For example, for all times after Jan 1 2000 12:00 UTC, use updated_at%5Bgt%5D=2000-01-01T12:00:00Z.
23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 |
# File 'lib/modern_treasury/controllers/ledger_controller.rb', line 23 def list_ledgers(after_cursor: nil, per_page: nil, metadata: nil, updated_at: nil) @api_call .request(new_request_builder(HttpMethodEnum::GET, '/api/ledgers', Server::DEFAULT) .query_param(new_parameter(after_cursor, key: 'after_cursor')) .query_param(new_parameter(per_page, key: 'per_page')) .query_param(new_parameter(, key: 'metadata')) .query_param(new_parameter(updated_at, key: 'updated_at')) .header_param(new_parameter('application/json', key: 'accept')) .auth(Single.new('basic_auth'))) .response(new_response_handler .deserializer(APIHelper.method(:custom_type_deserializer)) .deserialize_into(Ledger.method(:from_hash)) .is_api_response(true) .is_response_array(true)) .execute end |
#update_ledger(id, body: nil) ⇒ ApiResponse
Update the details of a ledger. description here
104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 |
# File 'lib/modern_treasury/controllers/ledger_controller.rb', line 104 def update_ledger(id, body: nil) @api_call .request(new_request_builder(HttpMethodEnum::PATCH, '/api/ledgers/{id}', Server::DEFAULT) .template_param(new_parameter(id, key: 'id') .is_required(true) .should_encode(true)) .header_param(new_parameter('application/json', key: 'Content-Type')) .body_param(new_parameter(body)) .header_param(new_parameter('application/json', key: 'accept')) .body_serializer(proc do |param| param.to_json unless param.nil? end) .auth(Single.new('basic_auth'))) .response(new_response_handler .deserializer(APIHelper.method(:custom_type_deserializer)) .deserialize_into(Ledger.method(:from_hash)) .is_api_response(true) .local_error('403', 'forbidden', ErrorMessageException) .local_error('404', 'not found', ErrorMessageException) .local_error('422', 'unsuccessful', ErrorMessageException)) .execute end |