lusid-sdk 1.1.257__py3-none-any.whl → 2.0.430__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of lusid-sdk might be problematic. Click here for more details.

Files changed (1256) hide show
  1. lusid/__init__.py +262 -253
  2. lusid/api/__init__.py +15 -3
  3. lusid/api/abor_api.py +2297 -0
  4. lusid/api/abor_configuration_api.py +944 -0
  5. lusid/api/address_key_definition_api.py +296 -269
  6. lusid/api/aggregation_api.py +470 -261
  7. lusid/api/allocations_api.py +409 -402
  8. lusid/api/application_metadata_api.py +266 -244
  9. lusid/api/blocks_api.py +407 -400
  10. lusid/api/calendars_api.py +1179 -1634
  11. lusid/api/chart_of_accounts_api.py +5391 -0
  12. lusid/api/complex_market_data_api.py +471 -310
  13. lusid/api/compliance_api.py +1042 -1866
  14. lusid/api/configuration_recipe_api.py +1507 -359
  15. lusid/api/conventions_api.py +1982 -0
  16. lusid/api/corporate_action_sources_api.py +957 -881
  17. lusid/api/counterparties_api.py +729 -711
  18. lusid/api/custom_entities_api.py +1190 -1469
  19. lusid/api/custom_entity_definitions_api.py +387 -364
  20. lusid/api/custom_entity_types_api.py +393 -369
  21. lusid/api/cut_label_definitions_api.py +482 -451
  22. lusid/api/data_types_api.py +708 -1090
  23. lusid/api/derived_transaction_portfolios_api.py +204 -213
  24. lusid/api/entities_api.py +114 -114
  25. lusid/api/executions_api.py +409 -402
  26. lusid/api/funds_api.py +944 -0
  27. lusid/api/instrument_event_types_api.py +1287 -0
  28. lusid/api/instrument_events_api.py +631 -82
  29. lusid/api/instruments_api.py +2388 -1911
  30. lusid/api/legacy_compliance_api.py +1449 -0
  31. lusid/api/legal_entities_api.py +1898 -2242
  32. lusid/api/order_graph_api.py +355 -362
  33. lusid/api/order_instructions_api.py +745 -0
  34. lusid/api/order_management_api.py +508 -873
  35. lusid/api/orders_api.py +409 -402
  36. lusid/api/packages_api.py +745 -0
  37. lusid/api/participations_api.py +407 -400
  38. lusid/api/persons_api.py +1775 -2102
  39. lusid/api/placements_api.py +407 -400
  40. lusid/api/portfolio_groups_api.py +2811 -2983
  41. lusid/api/portfolios_api.py +2861 -4068
  42. lusid/api/property_definitions_api.py +1102 -1183
  43. lusid/api/quotes_api.py +1293 -512
  44. lusid/api/reconciliations_api.py +1858 -733
  45. lusid/api/reference_lists_api.py +389 -389
  46. lusid/api/reference_portfolio_api.py +409 -619
  47. lusid/api/relation_definitions_api.py +538 -0
  48. lusid/api/relations_api.py +414 -0
  49. lusid/api/relationship_definitions_api.py +484 -494
  50. lusid/api/relationships_api.py +206 -224
  51. lusid/api/schemas_api.py +366 -322
  52. lusid/api/scopes_api.py +184 -207
  53. lusid/api/scripted_translation_api.py +766 -775
  54. lusid/api/search_api.py +408 -423
  55. lusid/api/sequences_api.py +376 -404
  56. lusid/api/structured_result_data_api.py +1205 -575
  57. lusid/api/system_configuration_api.py +979 -143
  58. lusid/api/tax_rule_sets_api.py +900 -0
  59. lusid/api/transaction_configuration_api.py +1055 -1093
  60. lusid/api/transaction_fees_api.py +935 -0
  61. lusid/api/transaction_portfolios_api.py +4373 -3879
  62. lusid/api/translation_api.py +364 -0
  63. lusid/api_client.py +197 -124
  64. lusid/api_response.py +25 -0
  65. lusid/configuration.py +58 -81
  66. lusid/exceptions.py +17 -15
  67. lusid/extensions/__init__.py +7 -0
  68. lusid/extensions/api_client.py +766 -0
  69. lusid/extensions/api_client_factory.py +248 -0
  70. lusid/extensions/api_configuration.py +234 -0
  71. lusid/extensions/configuration_loaders.py +201 -0
  72. lusid/{utilities → extensions}/proxy_config.py +24 -6
  73. lusid/{utilities → extensions}/refreshing_token.py +82 -35
  74. lusid/extensions/rest.py +300 -0
  75. lusid/extensions/retry.py +357 -0
  76. lusid/extensions/socket_keep_alive.py +52 -0
  77. lusid/extensions/tcp_keep_alive_connector.py +113 -0
  78. lusid/models/__init__.py +246 -244
  79. lusid/models/a2_b_breakdown.py +65 -187
  80. lusid/models/a2_b_category.py +60 -154
  81. lusid/models/a2_b_data_record.py +178 -540
  82. lusid/models/a2_b_movement_record.py +192 -635
  83. lusid/models/abor.py +157 -0
  84. lusid/models/abor_configuration.py +159 -0
  85. lusid/models/abor_configuration_properties.py +115 -0
  86. lusid/models/abor_configuration_request.py +145 -0
  87. lusid/models/abor_properties.py +115 -0
  88. lusid/models/abor_request.py +131 -0
  89. lusid/models/access_controlled_action.py +87 -215
  90. lusid/models/access_controlled_resource.py +105 -271
  91. lusid/models/access_metadata_operation.py +84 -234
  92. lusid/models/access_metadata_value.py +58 -166
  93. lusid/models/account.py +131 -0
  94. lusid/models/account_properties.py +115 -0
  95. lusid/models/accounting_method.py +42 -0
  96. lusid/models/accounts_upsert_response.py +110 -0
  97. lusid/models/accumulation_event.py +87 -293
  98. lusid/models/action_id.py +55 -204
  99. lusid/models/action_result_of_portfolio.py +57 -154
  100. lusid/models/add_business_days_to_date_request.py +63 -214
  101. lusid/models/add_business_days_to_date_response.py +52 -127
  102. lusid/models/additional_payment.py +58 -228
  103. lusid/models/address_definition.py +97 -284
  104. lusid/models/address_key_compliance_parameter.py +73 -166
  105. lusid/models/address_key_definition.py +74 -220
  106. lusid/models/address_key_filter.py +69 -191
  107. lusid/models/address_key_list.py +73 -170
  108. lusid/models/address_key_list_compliance_parameter.py +77 -164
  109. lusid/models/address_key_option_definition.py +71 -293
  110. lusid/models/adjust_holding.py +101 -214
  111. lusid/models/adjust_holding_for_date_request.py +109 -285
  112. lusid/models/adjust_holding_request.py +107 -250
  113. lusid/models/aggregate_spec.py +67 -196
  114. lusid/models/aggregated_return.py +106 -373
  115. lusid/models/aggregated_returns_dispersion_request.py +102 -291
  116. lusid/models/aggregated_returns_request.py +128 -403
  117. lusid/models/aggregated_returns_response.py +95 -184
  118. lusid/models/aggregated_transactions_request.py +131 -0
  119. lusid/models/aggregation_context.py +55 -125
  120. lusid/models/aggregation_measure_failure_detail.py +80 -238
  121. lusid/models/aggregation_op.py +49 -0
  122. lusid/models/aggregation_options.py +55 -189
  123. lusid/models/aggregation_query.py +106 -439
  124. lusid/models/aggregation_type.py +44 -0
  125. lusid/models/allocation.py +207 -735
  126. lusid/models/allocation_request.py +175 -611
  127. lusid/models/allocation_service_run_response.py +102 -0
  128. lusid/models/allocation_set_request.py +64 -126
  129. lusid/models/amortisation_event.py +80 -266
  130. lusid/models/annul_quotes_response.py +99 -215
  131. lusid/models/annul_single_structured_data_response.py +74 -186
  132. lusid/models/annul_structured_data_response.py +99 -215
  133. lusid/models/asset_class.py +44 -0
  134. lusid/models/asset_leg.py +57 -161
  135. lusid/models/barrier.py +62 -228
  136. lusid/models/basket.py +85 -229
  137. lusid/models/basket_identifier.py +57 -224
  138. lusid/models/batch_adjust_holdings_response.py +128 -214
  139. lusid/models/batch_upsert_instrument_properties_response.py +101 -221
  140. lusid/models/batch_upsert_portfolio_transactions_response.py +128 -214
  141. lusid/models/batch_upsert_property_definition_properties_response.py +97 -221
  142. lusid/models/block.py +133 -542
  143. lusid/models/block_and_order_id_request.py +60 -156
  144. lusid/models/block_and_orders.py +65 -156
  145. lusid/models/block_and_orders_create_request.py +59 -134
  146. lusid/models/block_and_orders_request.py +117 -405
  147. lusid/models/block_request.py +108 -448
  148. lusid/models/block_set_request.py +64 -126
  149. lusid/models/blocked_order_request.py +113 -395
  150. lusid/models/bond.py +151 -570
  151. lusid/models/bond_coupon_event.py +80 -261
  152. lusid/models/bond_default_event.py +74 -167
  153. lusid/models/bond_principal_event.py +80 -261
  154. lusid/models/book_transactions_request.py +97 -0
  155. lusid/models/book_transactions_response.py +107 -0
  156. lusid/models/bool_compliance_parameter.py +73 -164
  157. lusid/models/bool_list_compliance_parameter.py +77 -164
  158. lusid/models/branch_step.py +83 -201
  159. lusid/models/bucketed_cash_flow_request.py +172 -0
  160. lusid/models/bucketed_cash_flow_response.py +111 -271
  161. lusid/models/bucketing_schedule.py +56 -126
  162. lusid/models/calculation_info.py +73 -0
  163. lusid/models/calendar.py +88 -337
  164. lusid/models/calendar_date.py +84 -407
  165. lusid/models/calendar_dependency.py +73 -166
  166. lusid/models/cap_floor.py +85 -295
  167. lusid/models/cash_dependency.py +76 -199
  168. lusid/models/cash_dividend_event.py +100 -291
  169. lusid/models/cash_election.py +73 -316
  170. lusid/models/cash_flow_event.py +80 -199
  171. lusid/models/cash_flow_lineage.py +91 -276
  172. lusid/models/cash_flow_value.py +90 -289
  173. lusid/models/cash_flow_value_set.py +86 -164
  174. lusid/models/cash_ladder_record.py +58 -216
  175. lusid/models/cash_perpetual.py +78 -231
  176. lusid/models/cds_flow_conventions.py +113 -514
  177. lusid/models/cds_index.py +100 -382
  178. lusid/models/cds_protection_detail_specification.py +57 -230
  179. lusid/models/change.py +110 -355
  180. lusid/models/change_history.py +90 -297
  181. lusid/models/change_history_action.py +39 -0
  182. lusid/models/change_item.py +80 -252
  183. lusid/models/chart_of_accounts.py +135 -0
  184. lusid/models/chart_of_accounts_properties.py +115 -0
  185. lusid/models/chart_of_accounts_request.py +120 -0
  186. lusid/models/check_step.py +92 -233
  187. lusid/models/cleardown_module_details.py +95 -0
  188. lusid/models/cleardown_module_request.py +117 -0
  189. lusid/models/cleardown_module_response.py +139 -0
  190. lusid/models/cleardown_module_rule.py +94 -0
  191. lusid/models/cleardown_module_rules_updated_response.py +110 -0
  192. lusid/models/client.py +75 -0
  193. lusid/models/close_event.py +76 -197
  194. lusid/models/close_period_diary_entry_request.py +149 -0
  195. lusid/models/complete_portfolio.py +149 -493
  196. lusid/models/complete_relation.py +96 -0
  197. lusid/models/complete_relationship.py +88 -378
  198. lusid/models/complex_bond.py +129 -326
  199. lusid/models/complex_market_data.py +82 -151
  200. lusid/models/complex_market_data_id.py +74 -274
  201. lusid/models/compliance_breached_order_info.py +83 -0
  202. lusid/models/compliance_parameter.py +85 -156
  203. lusid/models/compliance_parameter_type.py +56 -0
  204. lusid/models/compliance_rule.py +137 -0
  205. lusid/models/compliance_rule_breakdown.py +84 -257
  206. lusid/models/compliance_rule_breakdown_request.py +84 -252
  207. lusid/models/compliance_rule_response.py +149 -409
  208. lusid/models/compliance_rule_result.py +91 -0
  209. lusid/models/compliance_rule_result_detail.py +91 -414
  210. lusid/models/compliance_rule_result_portfolio_detail.py +57 -159
  211. lusid/models/compliance_rule_result_v2.py +68 -250
  212. lusid/models/compliance_rule_upsert_request.py +178 -0
  213. lusid/models/compliance_rule_upsert_response.py +82 -0
  214. lusid/models/compliance_run_info.py +81 -0
  215. lusid/models/compliance_run_info_v2.py +64 -253
  216. lusid/models/compliance_step.py +77 -146
  217. lusid/models/compliance_step_type.py +42 -0
  218. lusid/models/compliance_summary_rule_result.py +94 -342
  219. lusid/models/compliance_summary_rule_result_request.py +94 -348
  220. lusid/models/compliance_template.py +89 -251
  221. lusid/models/compliance_template_parameter.py +55 -201
  222. lusid/models/compliance_template_variation.py +94 -292
  223. lusid/models/component_transaction.py +92 -0
  224. lusid/models/composite_breakdown.py +72 -188
  225. lusid/models/composite_breakdown_request.py +97 -281
  226. lusid/models/composite_breakdown_response.py +90 -186
  227. lusid/models/composite_dispersion.py +116 -339
  228. lusid/models/composite_dispersion_response.py +95 -184
  229. lusid/models/compounding.py +76 -299
  230. lusid/models/configuration_recipe.py +114 -362
  231. lusid/models/constant_volatility_surface.py +85 -268
  232. lusid/models/constituents_adjustment_header.py +73 -185
  233. lusid/models/contract_for_difference.py +90 -461
  234. lusid/models/corporate_action.py +82 -313
  235. lusid/models/corporate_action_source.py +104 -302
  236. lusid/models/corporate_action_transition.py +69 -155
  237. lusid/models/corporate_action_transition_component.py +59 -262
  238. lusid/models/corporate_action_transition_component_request.py +55 -192
  239. lusid/models/corporate_action_transition_request.py +69 -153
  240. lusid/models/counterparty_agreement.py +73 -292
  241. lusid/models/counterparty_risk_information.py +78 -197
  242. lusid/models/counterparty_signatory.py +57 -161
  243. lusid/models/create_address_key_definition_request.py +53 -163
  244. lusid/models/create_calendar_request.py +94 -262
  245. lusid/models/create_corporate_action_source_request.py +100 -291
  246. lusid/models/create_custom_entity_type_request.py +79 -242
  247. lusid/models/create_cut_label_definition_request.py +85 -256
  248. lusid/models/create_data_map_request.py +61 -155
  249. lusid/models/create_data_type_request.py +143 -462
  250. lusid/models/create_date_request.py +111 -368
  251. lusid/models/create_derived_property_definition_request.py +79 -331
  252. lusid/models/create_derived_transaction_portfolio_request.py +160 -535
  253. lusid/models/create_portfolio_details.py +55 -125
  254. lusid/models/create_portfolio_group_request.py +117 -314
  255. lusid/models/create_property_definition_request.py +105 -424
  256. lusid/models/create_recipe_request.py +90 -0
  257. lusid/models/create_reconciliation_request.py +140 -0
  258. lusid/models/create_reference_portfolio_request.py +102 -317
  259. lusid/models/create_relation_definition_request.py +95 -0
  260. lusid/models/create_relation_request.py +71 -0
  261. lusid/models/create_relationship_definition_request.py +112 -437
  262. lusid/models/create_relationship_request.py +87 -238
  263. lusid/models/create_sequence_request.py +105 -327
  264. lusid/models/create_tax_rule_set_request.py +103 -0
  265. lusid/models/create_trade_tickets_response.py +69 -156
  266. lusid/models/create_transaction_portfolio_request.py +158 -574
  267. lusid/models/create_unit_definition.py +83 -241
  268. lusid/models/credit_default_swap.py +105 -384
  269. lusid/models/credit_rating.py +67 -178
  270. lusid/models/credit_spread_curve_data.py +109 -420
  271. lusid/models/credit_support_annex.py +73 -432
  272. lusid/models/criterion_type.py +39 -0
  273. lusid/models/currency_and_amount.py +58 -155
  274. lusid/models/curve_options.py +110 -0
  275. lusid/models/custodian_account.py +93 -396
  276. lusid/models/custodian_account_properties.py +115 -0
  277. lusid/models/custodian_account_request.py +148 -0
  278. lusid/models/custodian_accounts_upsert_response.py +110 -0
  279. lusid/models/custom_entity_definition.py +85 -351
  280. lusid/models/custom_entity_definition_request.py +79 -242
  281. lusid/models/custom_entity_field.py +73 -222
  282. lusid/models/custom_entity_field_definition.py +71 -296
  283. lusid/models/custom_entity_id.py +91 -280
  284. lusid/models/custom_entity_request.py +78 -228
  285. lusid/models/custom_entity_response.py +118 -409
  286. lusid/models/custom_entity_type.py +85 -351
  287. lusid/models/cut_label_definition.py +111 -322
  288. lusid/models/cut_local_time.py +53 -154
  289. lusid/models/data_definition.py +86 -301
  290. lusid/models/data_map_key.py +83 -174
  291. lusid/models/data_mapping.py +64 -126
  292. lusid/models/data_scope.py +80 -0
  293. lusid/models/data_type.py +145 -506
  294. lusid/models/data_type_summary.py +117 -398
  295. lusid/models/data_type_value_range.py +38 -0
  296. lusid/models/date_attributes.py +140 -371
  297. lusid/models/date_or_diary_entry.py +91 -0
  298. lusid/models/date_range.py +59 -155
  299. lusid/models/date_time_comparison_type.py +38 -0
  300. lusid/models/date_time_compliance_parameter.py +74 -165
  301. lusid/models/date_time_list_compliance_parameter.py +77 -164
  302. lusid/models/day_month.py +71 -0
  303. lusid/models/day_of_week.py +20 -102
  304. lusid/models/decimal_compliance_parameter.py +73 -164
  305. lusid/models/decimal_list.py +73 -170
  306. lusid/models/decimal_list_compliance_parameter.py +77 -164
  307. lusid/models/decorated_compliance_run_summary.py +65 -156
  308. lusid/models/delete_accounts_response.py +95 -0
  309. lusid/models/delete_custodian_accounts_response.py +103 -0
  310. lusid/models/delete_instrument_properties_response.py +67 -186
  311. lusid/models/delete_instrument_response.py +74 -216
  312. lusid/models/delete_instruments_response.py +74 -217
  313. lusid/models/delete_modes.py +38 -0
  314. lusid/models/delete_relation_request.py +71 -0
  315. lusid/models/delete_relationship_request.py +87 -238
  316. lusid/models/deleted_entity_response.py +81 -306
  317. lusid/models/dependency_source_filter.py +70 -228
  318. lusid/models/described_address_key.py +81 -0
  319. lusid/models/dialect.py +67 -185
  320. lusid/models/dialect_id.py +89 -330
  321. lusid/models/dialect_schema.py +58 -167
  322. lusid/models/diary_entry.py +155 -0
  323. lusid/models/diary_entry_request.py +120 -0
  324. lusid/models/discount_factor_curve_data.py +91 -296
  325. lusid/models/discounting_dependency.py +76 -199
  326. lusid/models/discounting_method.py +39 -0
  327. lusid/models/dividend_option_event.py +112 -354
  328. lusid/models/dividend_reinvestment_event.py +105 -354
  329. lusid/models/economic_dependency.py +82 -150
  330. lusid/models/economic_dependency_type.py +50 -0
  331. lusid/models/economic_dependency_with_complex_market_data.py +61 -156
  332. lusid/models/economic_dependency_with_quote.py +68 -186
  333. lusid/models/election_specification.py +73 -0
  334. lusid/models/eligibility_calculation.py +71 -0
  335. lusid/models/empty_model_options.py +71 -134
  336. lusid/models/entity_identifier.py +60 -190
  337. lusid/models/equity.py +86 -225
  338. lusid/models/equity_all_of_identifiers.py +83 -415
  339. lusid/models/equity_curve_by_prices_data.py +91 -296
  340. lusid/models/equity_curve_dependency.py +80 -281
  341. lusid/models/equity_model_options.py +73 -169
  342. lusid/models/equity_option.py +117 -573
  343. lusid/models/equity_swap.py +107 -487
  344. lusid/models/equity_vol_dependency.py +80 -275
  345. lusid/models/equity_vol_surface_data.py +101 -267
  346. lusid/models/error_detail.py +77 -216
  347. lusid/models/event_date_range.py +54 -155
  348. lusid/models/ex_dividend_configuration.py +57 -221
  349. lusid/models/exchange_traded_option.py +84 -261
  350. lusid/models/exchange_traded_option_contract_details.py +80 -535
  351. lusid/models/execution.py +144 -671
  352. lusid/models/execution_request.py +119 -577
  353. lusid/models/execution_set_request.py +64 -126
  354. lusid/models/exercise_event.py +83 -228
  355. lusid/models/exotic_instrument.py +79 -199
  356. lusid/models/expanded_group.py +121 -338
  357. lusid/models/fee_rule.py +138 -0
  358. lusid/models/fee_rule_upsert_request.py +142 -0
  359. lusid/models/fee_rule_upsert_response.py +97 -0
  360. lusid/models/field_definition.py +62 -195
  361. lusid/models/field_schema.py +83 -247
  362. lusid/models/field_value.py +60 -165
  363. lusid/models/file_response.py +69 -181
  364. lusid/models/filter_predicate_compliance_parameter.py +73 -167
  365. lusid/models/filter_step.py +83 -201
  366. lusid/models/fixed_leg.py +95 -287
  367. lusid/models/fixed_leg_all_of_overrides.py +65 -154
  368. lusid/models/fixed_schedule.py +131 -0
  369. lusid/models/flexible_loan.py +88 -263
  370. lusid/models/float_schedule.py +155 -0
  371. lusid/models/floating_leg.py +109 -349
  372. lusid/models/flow_convention_name.py +60 -193
  373. lusid/models/flow_conventions.py +120 -607
  374. lusid/models/forward_rate_agreement.py +90 -356
  375. lusid/models/from_recipe.py +81 -0
  376. lusid/models/fund.py +182 -0
  377. lusid/models/fund_properties.py +115 -0
  378. lusid/models/fund_request.py +165 -0
  379. lusid/models/fund_share_class.py +81 -336
  380. lusid/models/funding_leg.py +89 -259
  381. lusid/models/funding_leg_options.py +91 -0
  382. lusid/models/future.py +100 -388
  383. lusid/models/futures_contract_details.py +112 -562
  384. lusid/models/fx_conventions.py +55 -198
  385. lusid/models/fx_dependency.py +78 -231
  386. lusid/models/fx_forward.py +99 -481
  387. lusid/models/fx_forward_curve_by_quote_reference.py +114 -387
  388. lusid/models/fx_forward_curve_data.py +95 -360
  389. lusid/models/fx_forward_model_options.py +91 -242
  390. lusid/models/fx_forward_pips_curve_data.py +95 -360
  391. lusid/models/fx_forward_settlement_event.py +119 -507
  392. lusid/models/fx_forward_tenor_curve_data.py +117 -420
  393. lusid/models/fx_forward_tenor_pips_curve_data.py +117 -420
  394. lusid/models/fx_forwards_dependency.py +80 -269
  395. lusid/models/fx_linked_notional_schedule.py +90 -255
  396. lusid/models/fx_option.py +159 -629
  397. lusid/models/fx_rate_schedule.py +111 -0
  398. lusid/models/fx_swap.py +89 -224
  399. lusid/models/fx_tenor_convention.py +53 -166
  400. lusid/models/fx_vol_dependency.py +80 -269
  401. lusid/models/fx_vol_surface_data.py +101 -267
  402. lusid/models/general_ledger_profile_mapping.py +78 -0
  403. lusid/models/general_ledger_profile_request.py +112 -0
  404. lusid/models/general_ledger_profile_response.py +146 -0
  405. lusid/models/get_cds_flow_conventions_response.py +115 -0
  406. lusid/models/get_complex_market_data_response.py +111 -214
  407. lusid/models/get_counterparty_agreement_response.py +97 -213
  408. lusid/models/get_credit_support_annex_response.py +97 -213
  409. lusid/models/get_data_map_response.py +129 -0
  410. lusid/models/get_flow_conventions_response.py +115 -0
  411. lusid/models/get_index_convention_response.py +115 -0
  412. lusid/models/get_instruments_response.py +111 -214
  413. lusid/models/get_quotes_response.py +130 -244
  414. lusid/models/get_recipe_composer_response.py +95 -0
  415. lusid/models/get_recipe_response.py +77 -183
  416. lusid/models/get_reference_portfolio_constituents_response.py +117 -319
  417. lusid/models/get_structured_result_data_response.py +111 -214
  418. lusid/models/get_virtual_document_response.py +129 -0
  419. lusid/models/group_by_selector_compliance_parameter.py +73 -167
  420. lusid/models/group_by_step.py +83 -201
  421. lusid/models/group_filter_predicate_compliance_parameter.py +73 -167
  422. lusid/models/group_filter_step.py +92 -201
  423. lusid/models/group_of_market_data_key_rules.py +61 -163
  424. lusid/models/grouped_result_of_address_key.py +89 -0
  425. lusid/models/holding_adjustment.py +121 -313
  426. lusid/models/holding_adjustment_with_date.py +124 -345
  427. lusid/models/holding_context.py +51 -127
  428. lusid/models/holding_contributor.py +55 -156
  429. lusid/models/holdings_adjustment.py +92 -257
  430. lusid/models/holdings_adjustment_header.py +82 -225
  431. lusid/models/i_unit_definition_dto.py +85 -217
  432. lusid/models/id_selector_definition.py +75 -227
  433. lusid/models/identifier_part_schema.py +74 -283
  434. lusid/models/index_convention.py +100 -388
  435. lusid/models/index_model_options.py +80 -172
  436. lusid/models/index_projection_dependency.py +80 -275
  437. lusid/models/industry_classifier.py +60 -172
  438. lusid/models/inflation_fixing_dependency.py +78 -237
  439. lusid/models/inflation_index_conventions.py +71 -307
  440. lusid/models/inflation_leg.py +120 -455
  441. lusid/models/inflation_linked_bond.py +153 -601
  442. lusid/models/inflation_swap.py +88 -259
  443. lusid/models/informational_error_event.py +78 -237
  444. lusid/models/informational_event.py +86 -262
  445. lusid/models/inline_valuation_request.py +150 -497
  446. lusid/models/inline_valuations_reconciliation_request.py +82 -216
  447. lusid/models/input_transition.py +53 -160
  448. lusid/models/instrument.py +160 -597
  449. lusid/models/instrument_capabilities.py +133 -0
  450. lusid/models/instrument_cash_flow.py +90 -386
  451. lusid/models/instrument_definition.py +93 -280
  452. lusid/models/instrument_definition_format.py +55 -201
  453. lusid/models/instrument_delete_modes.py +38 -0
  454. lusid/models/instrument_event.py +86 -182
  455. lusid/models/instrument_event_configuration.py +56 -156
  456. lusid/models/instrument_event_holder.py +115 -490
  457. lusid/models/instrument_event_type.py +57 -0
  458. lusid/models/instrument_id_type_descriptor.py +55 -195
  459. lusid/models/instrument_id_value.py +54 -163
  460. lusid/models/instrument_leg.py +82 -143
  461. lusid/models/instrument_list.py +73 -170
  462. lusid/models/instrument_list_compliance_parameter.py +77 -164
  463. lusid/models/instrument_match.py +78 -156
  464. lusid/models/instrument_models.py +78 -184
  465. lusid/models/instrument_payment_diary.py +131 -0
  466. lusid/models/instrument_payment_diary_leg.py +91 -0
  467. lusid/models/instrument_payment_diary_row.py +132 -0
  468. lusid/models/instrument_properties.py +97 -213
  469. lusid/models/instrument_resolution_detail.py +105 -0
  470. lusid/models/instrument_search_property.py +53 -163
  471. lusid/models/instrument_type.py +74 -0
  472. lusid/models/interest_rate_swap.py +110 -322
  473. lusid/models/interest_rate_swaption.py +90 -296
  474. lusid/models/intermediate_compliance_step.py +110 -0
  475. lusid/models/ir_vol_cube_data.py +101 -267
  476. lusid/models/ir_vol_dependency.py +78 -237
  477. lusid/models/is_business_day_response.py +54 -157
  478. lusid/models/journal_entry_line.py +224 -0
  479. lusid/models/journal_entry_lines_query_parameters.py +109 -0
  480. lusid/models/label_value_set.py +51 -129
  481. lusid/models/leg_definition.py +143 -619
  482. lusid/models/legal_entity.py +158 -392
  483. lusid/models/level_step.py +54 -161
  484. lusid/models/life_cycle_event_lineage.py +84 -246
  485. lusid/models/life_cycle_event_value.py +86 -224
  486. lusid/models/lineage_member.py +69 -276
  487. lusid/models/link.py +62 -214
  488. lusid/models/list_aggregation_reconciliation.py +73 -211
  489. lusid/models/list_aggregation_response.py +111 -324
  490. lusid/models/list_complex_market_data_with_meta_data_response.py +86 -0
  491. lusid/models/loan_period.py +56 -187
  492. lusid/models/lock_period_diary_entry_request.py +91 -0
  493. lusid/models/lusid_instrument.py +99 -168
  494. lusid/models/lusid_problem_details.py +95 -327
  495. lusid/models/lusid_trade_ticket.py +155 -639
  496. lusid/models/lusid_unique_id.py +53 -166
  497. lusid/models/lusid_validation_problem_details.py +106 -356
  498. lusid/models/mapped_string.py +72 -209
  499. lusid/models/mapping.py +93 -281
  500. lusid/models/mapping_rule.py +96 -308
  501. lusid/models/market_context.py +111 -243
  502. lusid/models/market_context_suppliers.py +59 -241
  503. lusid/models/market_data_key_rule.py +114 -493
  504. lusid/models/market_data_options.py +73 -141
  505. lusid/models/market_data_options_type.py +37 -0
  506. lusid/models/market_data_overrides.py +79 -156
  507. lusid/models/market_data_specific_rule.py +115 -525
  508. lusid/models/market_data_type.py +50 -0
  509. lusid/models/market_observable_type.py +41 -0
  510. lusid/models/market_options.py +108 -318
  511. lusid/models/market_quote.py +60 -166
  512. lusid/models/match_criterion.py +95 -0
  513. lusid/models/maturity_event.py +74 -167
  514. lusid/models/metric_value.py +58 -155
  515. lusid/models/model_options.py +76 -144
  516. lusid/models/model_options_type.py +43 -0
  517. lusid/models/model_property.py +72 -218
  518. lusid/models/model_schema.py +116 -0
  519. lusid/models/model_selection.py +67 -172
  520. lusid/models/move_orders_to_different_blocks_request.py +59 -134
  521. lusid/models/moved_order_to_different_block_response.py +67 -183
  522. lusid/models/movement_type.py +56 -0
  523. lusid/models/multi_currency_amounts.py +71 -0
  524. lusid/models/next_value_in_sequence_response.py +66 -156
  525. lusid/models/numeric_comparison_type.py +39 -0
  526. lusid/models/opaque_dependency.py +71 -134
  527. lusid/models/opaque_market_data.py +84 -275
  528. lusid/models/opaque_model_options.py +73 -164
  529. lusid/models/open_event.py +74 -166
  530. lusid/models/operand_type.py +38 -0
  531. lusid/models/operation.py +67 -221
  532. lusid/models/operation_type.py +37 -0
  533. lusid/models/operator.py +43 -0
  534. lusid/models/option_entry.py +71 -0
  535. lusid/models/optionality_schedule.py +118 -0
  536. lusid/models/order.py +173 -704
  537. lusid/models/order_by_spec.py +60 -166
  538. lusid/models/order_flow_configuration.py +51 -131
  539. lusid/models/order_graph_block.py +85 -381
  540. lusid/models/order_graph_block_allocation_detail.py +55 -126
  541. lusid/models/order_graph_block_allocation_synopsis.py +61 -160
  542. lusid/models/order_graph_block_execution_detail.py +55 -126
  543. lusid/models/order_graph_block_execution_synopsis.py +61 -160
  544. lusid/models/order_graph_block_order_detail.py +83 -314
  545. lusid/models/order_graph_block_order_synopsis.py +61 -190
  546. lusid/models/order_graph_block_placement_detail.py +55 -126
  547. lusid/models/order_graph_block_placement_synopsis.py +61 -190
  548. lusid/models/order_graph_placement.py +94 -341
  549. lusid/models/order_graph_placement_allocation_detail.py +55 -126
  550. lusid/models/order_graph_placement_allocation_synopsis.py +61 -160
  551. lusid/models/order_graph_placement_child_placement_detail.py +55 -126
  552. lusid/models/order_graph_placement_execution_detail.py +55 -126
  553. lusid/models/order_graph_placement_execution_synopsis.py +61 -160
  554. lusid/models/order_graph_placement_order_detail.py +55 -126
  555. lusid/models/order_graph_placement_order_synopsis.py +59 -128
  556. lusid/models/order_graph_placement_placement_synopsis.py +61 -160
  557. lusid/models/order_instruction.py +157 -0
  558. lusid/models/order_instruction_request.py +127 -0
  559. lusid/models/order_instruction_set_request.py +82 -0
  560. lusid/models/order_request.py +141 -580
  561. lusid/models/order_set_request.py +64 -126
  562. lusid/models/otc_confirmation.py +55 -125
  563. lusid/models/output_transaction.py +189 -905
  564. lusid/models/output_transition.py +77 -281
  565. lusid/models/package.py +132 -0
  566. lusid/models/package_request.py +111 -0
  567. lusid/models/package_set_request.py +82 -0
  568. lusid/models/paged_resource_list_of_abor.py +113 -0
  569. lusid/models/paged_resource_list_of_abor_configuration.py +113 -0
  570. lusid/models/paged_resource_list_of_account.py +113 -0
  571. lusid/models/paged_resource_list_of_address_key_definition.py +95 -238
  572. lusid/models/paged_resource_list_of_allocation.py +95 -238
  573. lusid/models/paged_resource_list_of_block.py +95 -238
  574. lusid/models/paged_resource_list_of_calendar.py +95 -238
  575. lusid/models/paged_resource_list_of_chart_of_accounts.py +113 -0
  576. lusid/models/paged_resource_list_of_cleardown_module_response.py +113 -0
  577. lusid/models/paged_resource_list_of_cleardown_module_rule.py +113 -0
  578. lusid/models/paged_resource_list_of_compliance_rule_response.py +95 -238
  579. lusid/models/paged_resource_list_of_compliance_run_info_v2.py +95 -238
  580. lusid/models/paged_resource_list_of_compliance_template.py +95 -238
  581. lusid/models/paged_resource_list_of_corporate_action_source.py +95 -238
  582. lusid/models/paged_resource_list_of_custodian_account.py +113 -0
  583. lusid/models/paged_resource_list_of_custom_entity_definition.py +95 -238
  584. lusid/models/paged_resource_list_of_custom_entity_response.py +95 -238
  585. lusid/models/paged_resource_list_of_custom_entity_type.py +95 -238
  586. lusid/models/paged_resource_list_of_cut_label_definition.py +95 -238
  587. lusid/models/paged_resource_list_of_data_type_summary.py +95 -238
  588. lusid/models/paged_resource_list_of_dialect_id.py +95 -238
  589. lusid/models/paged_resource_list_of_diary_entry.py +113 -0
  590. lusid/models/paged_resource_list_of_execution.py +95 -238
  591. lusid/models/paged_resource_list_of_fund.py +113 -0
  592. lusid/models/paged_resource_list_of_general_ledger_profile_response.py +113 -0
  593. lusid/models/paged_resource_list_of_instrument.py +95 -238
  594. lusid/models/paged_resource_list_of_instrument_event_holder.py +95 -238
  595. lusid/models/paged_resource_list_of_legal_entity.py +95 -238
  596. lusid/models/paged_resource_list_of_order.py +95 -238
  597. lusid/models/paged_resource_list_of_order_graph_block.py +95 -238
  598. lusid/models/paged_resource_list_of_order_graph_placement.py +95 -238
  599. lusid/models/paged_resource_list_of_order_instruction.py +113 -0
  600. lusid/models/paged_resource_list_of_package.py +113 -0
  601. lusid/models/paged_resource_list_of_participation.py +95 -238
  602. lusid/models/paged_resource_list_of_person.py +95 -238
  603. lusid/models/paged_resource_list_of_placement.py +95 -238
  604. lusid/models/paged_resource_list_of_portfolio_group.py +95 -238
  605. lusid/models/paged_resource_list_of_portfolio_group_search_result.py +95 -238
  606. lusid/models/paged_resource_list_of_portfolio_search_result.py +95 -238
  607. lusid/models/paged_resource_list_of_posting_module_response.py +113 -0
  608. lusid/models/paged_resource_list_of_posting_module_rule.py +113 -0
  609. lusid/models/paged_resource_list_of_property_definition.py +95 -238
  610. lusid/models/paged_resource_list_of_property_definition_search_result.py +95 -238
  611. lusid/models/paged_resource_list_of_reconciliation.py +113 -0
  612. lusid/models/paged_resource_list_of_reference_list_response.py +95 -238
  613. lusid/models/paged_resource_list_of_relationship_definition.py +95 -238
  614. lusid/models/paged_resource_list_of_sequence_definition.py +95 -238
  615. lusid/models/paged_resource_list_of_transaction_template.py +113 -0
  616. lusid/models/paged_resource_list_of_transaction_template_specification.py +113 -0
  617. lusid/models/paged_resource_list_of_translation_script_id.py +95 -238
  618. lusid/models/paged_resource_list_of_virtual_row.py +95 -238
  619. lusid/models/participation.py +86 -243
  620. lusid/models/participation_request.py +65 -186
  621. lusid/models/participation_set_request.py +64 -126
  622. lusid/models/performance_return.py +75 -251
  623. lusid/models/performance_returns_metric.py +83 -309
  624. lusid/models/period_diary_entries_reopened_response.py +104 -0
  625. lusid/models/period_type.py +41 -0
  626. lusid/models/perpetual_entity_state.py +39 -0
  627. lusid/models/perpetual_property.py +57 -157
  628. lusid/models/person.py +137 -363
  629. lusid/models/place_blocks_request.py +59 -134
  630. lusid/models/placement.py +161 -696
  631. lusid/models/placement_request.py +136 -614
  632. lusid/models/placement_set_request.py +64 -126
  633. lusid/models/portfolio.py +200 -744
  634. lusid/models/portfolio_cash_flow.py +139 -591
  635. lusid/models/portfolio_cash_ladder.py +116 -248
  636. lusid/models/portfolio_details.py +143 -547
  637. lusid/models/portfolio_entity_id.py +90 -214
  638. lusid/models/portfolio_group.py +138 -400
  639. lusid/models/portfolio_group_id_compliance_parameter.py +77 -164
  640. lusid/models/portfolio_group_id_list.py +81 -167
  641. lusid/models/portfolio_group_id_list_compliance_parameter.py +77 -164
  642. lusid/models/portfolio_group_properties.py +97 -213
  643. lusid/models/portfolio_group_search_result.py +123 -370
  644. lusid/models/portfolio_holding.py +167 -674
  645. lusid/models/portfolio_id_compliance_parameter.py +77 -164
  646. lusid/models/portfolio_id_list.py +81 -167
  647. lusid/models/portfolio_id_list_compliance_parameter.py +77 -164
  648. lusid/models/portfolio_properties.py +97 -242
  649. lusid/models/portfolio_reconciliation_request.py +65 -192
  650. lusid/models/portfolio_result_data_key_rule.py +133 -392
  651. lusid/models/portfolio_return_breakdown.py +109 -492
  652. lusid/models/portfolio_search_result.py +128 -440
  653. lusid/models/portfolio_trade_ticket.py +79 -0
  654. lusid/models/portfolio_type.py +39 -0
  655. lusid/models/portfolios_reconciliation_request.py +62 -188
  656. lusid/models/posting_module_details.py +95 -0
  657. lusid/models/posting_module_request.py +117 -0
  658. lusid/models/posting_module_response.py +139 -0
  659. lusid/models/posting_module_rule.py +119 -0
  660. lusid/models/posting_module_rules_updated_response.py +110 -0
  661. lusid/models/premium.py +56 -193
  662. lusid/models/pricing_context.py +105 -244
  663. lusid/models/pricing_model.py +55 -0
  664. lusid/models/pricing_options.py +80 -463
  665. lusid/models/processed_command.py +67 -224
  666. lusid/models/property_definition.py +234 -763
  667. lusid/models/property_definition_search_result.py +202 -646
  668. lusid/models/property_definition_type.py +38 -0
  669. lusid/models/property_domain.py +75 -0
  670. lusid/models/property_filter.py +87 -228
  671. lusid/models/property_interval.py +68 -221
  672. lusid/models/property_key_compliance_parameter.py +73 -166
  673. lusid/models/property_key_list_compliance_parameter.py +77 -164
  674. lusid/models/property_life_time.py +38 -0
  675. lusid/models/property_schema.py +91 -180
  676. lusid/models/property_type.py +39 -0
  677. lusid/models/property_value.py +68 -184
  678. lusid/models/property_value_equals.py +93 -0
  679. lusid/models/property_value_in.py +93 -0
  680. lusid/models/query_bucketed_cash_flows_request.py +145 -636
  681. lusid/models/query_cash_flows_request.py +96 -0
  682. lusid/models/query_instrument_events_request.py +113 -0
  683. lusid/models/query_trade_tickets_request.py +96 -0
  684. lusid/models/quote.py +87 -313
  685. lusid/models/quote_access_metadata_rule.py +92 -0
  686. lusid/models/quote_access_metadata_rule_id.py +129 -0
  687. lusid/models/quote_dependency.py +78 -240
  688. lusid/models/quote_id.py +57 -161
  689. lusid/models/quote_instrument_id_type.py +45 -0
  690. lusid/models/quote_series_id.py +96 -307
  691. lusid/models/quote_type.py +50 -0
  692. lusid/models/raw_vendor_event.py +82 -232
  693. lusid/models/re_open_period_diary_entry_request.py +84 -0
  694. lusid/models/realised_gain_loss.py +115 -462
  695. lusid/models/recipe_block.py +87 -0
  696. lusid/models/recipe_composer.py +100 -0
  697. lusid/models/recipe_value.py +87 -0
  698. lusid/models/recombine_step.py +83 -201
  699. lusid/models/reconcile_date_time_rule.py +88 -233
  700. lusid/models/reconcile_numeric_rule.py +88 -233
  701. lusid/models/reconcile_string_rule.py +102 -232
  702. lusid/models/reconciled_transaction.py +69 -215
  703. lusid/models/reconciliation.py +165 -0
  704. lusid/models/reconciliation_break.py +105 -411
  705. lusid/models/reconciliation_configuration.py +84 -0
  706. lusid/models/reconciliation_id.py +80 -0
  707. lusid/models/reconciliation_left_right_address_key_pair.py +53 -160
  708. lusid/models/reconciliation_line.py +77 -216
  709. lusid/models/reconciliation_request.py +97 -246
  710. lusid/models/reconciliation_response.py +70 -155
  711. lusid/models/reconciliation_rule.py +74 -143
  712. lusid/models/reconciliation_rule_type.py +40 -0
  713. lusid/models/reconciliation_side_configuration.py +94 -0
  714. lusid/models/reconciliation_transactions.py +79 -0
  715. lusid/models/reference_data.py +69 -156
  716. lusid/models/reference_instrument.py +77 -239
  717. lusid/models/reference_list.py +77 -148
  718. lusid/models/reference_list_request.py +77 -251
  719. lusid/models/reference_list_response.py +98 -309
  720. lusid/models/reference_list_type.py +42 -0
  721. lusid/models/reference_portfolio_constituent.py +96 -307
  722. lusid/models/reference_portfolio_constituent_request.py +80 -214
  723. lusid/models/reference_portfolio_weight_type.py +39 -0
  724. lusid/models/related_entity.py +105 -349
  725. lusid/models/relation.py +70 -281
  726. lusid/models/relation_definition.py +143 -0
  727. lusid/models/relationship.py +76 -318
  728. lusid/models/relationship_definition.py +111 -446
  729. lusid/models/relative_date_offset.py +53 -193
  730. lusid/models/repo.py +136 -476
  731. lusid/models/reset_event.py +90 -262
  732. lusid/models/resource_id.py +53 -172
  733. lusid/models/resource_list_of_access_controlled_resource.py +95 -238
  734. lusid/models/resource_list_of_access_metadata_value_of.py +100 -238
  735. lusid/models/resource_list_of_address_key_definition.py +95 -238
  736. lusid/models/resource_list_of_aggregated_return.py +95 -238
  737. lusid/models/resource_list_of_aggregation_query.py +95 -238
  738. lusid/models/resource_list_of_allocation.py +95 -238
  739. lusid/models/resource_list_of_block.py +95 -238
  740. lusid/models/resource_list_of_block_and_orders.py +95 -238
  741. lusid/models/resource_list_of_calendar_date.py +95 -238
  742. lusid/models/resource_list_of_change.py +95 -238
  743. lusid/models/resource_list_of_change_history.py +95 -238
  744. lusid/models/resource_list_of_compliance_breached_order_info.py +113 -0
  745. lusid/models/resource_list_of_compliance_rule.py +113 -0
  746. lusid/models/resource_list_of_compliance_rule_result.py +113 -0
  747. lusid/models/resource_list_of_compliance_run_info.py +113 -0
  748. lusid/models/resource_list_of_constituents_adjustment_header.py +95 -238
  749. lusid/models/resource_list_of_corporate_action.py +95 -238
  750. lusid/models/resource_list_of_data_type.py +95 -238
  751. lusid/models/resource_list_of_execution.py +95 -238
  752. lusid/models/resource_list_of_fee_rule.py +113 -0
  753. lusid/models/resource_list_of_get_cds_flow_conventions_response.py +113 -0
  754. lusid/models/resource_list_of_get_counterparty_agreement_response.py +95 -238
  755. lusid/models/resource_list_of_get_credit_support_annex_response.py +95 -238
  756. lusid/models/resource_list_of_get_flow_conventions_response.py +113 -0
  757. lusid/models/resource_list_of_get_index_convention_response.py +113 -0
  758. lusid/models/resource_list_of_get_recipe_composer_response.py +113 -0
  759. lusid/models/resource_list_of_get_recipe_response.py +95 -238
  760. lusid/models/resource_list_of_holdings_adjustment_header.py +95 -238
  761. lusid/models/resource_list_of_i_unit_definition_dto.py +95 -238
  762. lusid/models/resource_list_of_instrument_cash_flow.py +95 -238
  763. lusid/models/resource_list_of_instrument_event_holder.py +113 -0
  764. lusid/models/resource_list_of_instrument_id_type_descriptor.py +95 -238
  765. lusid/models/resource_list_of_legal_entity.py +95 -238
  766. lusid/models/resource_list_of_list_complex_market_data_with_meta_data_response.py +113 -0
  767. lusid/models/resource_list_of_mapping.py +95 -238
  768. lusid/models/resource_list_of_moved_order_to_different_block_response.py +95 -238
  769. lusid/models/resource_list_of_order.py +95 -238
  770. lusid/models/resource_list_of_order_instruction.py +113 -0
  771. lusid/models/resource_list_of_package.py +113 -0
  772. lusid/models/resource_list_of_participation.py +95 -238
  773. lusid/models/resource_list_of_performance_return.py +95 -238
  774. lusid/models/resource_list_of_person.py +95 -238
  775. lusid/models/resource_list_of_placement.py +95 -238
  776. lusid/models/resource_list_of_portfolio.py +95 -238
  777. lusid/models/resource_list_of_portfolio_cash_flow.py +95 -238
  778. lusid/models/resource_list_of_portfolio_cash_ladder.py +95 -238
  779. lusid/models/resource_list_of_portfolio_trade_ticket.py +113 -0
  780. lusid/models/resource_list_of_processed_command.py +95 -238
  781. lusid/models/resource_list_of_property.py +95 -238
  782. lusid/models/resource_list_of_property_definition.py +95 -238
  783. lusid/models/resource_list_of_property_interval.py +95 -238
  784. lusid/models/resource_list_of_quote.py +95 -238
  785. lusid/models/resource_list_of_quote_access_metadata_rule.py +113 -0
  786. lusid/models/resource_list_of_reconciliation_break.py +95 -238
  787. lusid/models/resource_list_of_relation.py +95 -238
  788. lusid/models/resource_list_of_relationship.py +95 -238
  789. lusid/models/resource_list_of_scope_definition.py +95 -238
  790. lusid/models/resource_list_of_side_definition.py +95 -238
  791. lusid/models/resource_list_of_string.py +87 -238
  792. lusid/models/resource_list_of_tax_rule_set.py +113 -0
  793. lusid/models/resource_list_of_transaction.py +95 -238
  794. lusid/models/resource_list_of_transaction_type.py +95 -238
  795. lusid/models/resource_list_of_value_type.py +88 -238
  796. lusid/models/response_meta_data.py +77 -216
  797. lusid/models/result_data_key_rule.py +103 -389
  798. lusid/models/result_data_schema.py +108 -184
  799. lusid/models/result_key_rule.py +74 -143
  800. lusid/models/result_key_rule_type.py +39 -0
  801. lusid/models/result_value.py +80 -149
  802. lusid/models/result_value0_d.py +87 -225
  803. lusid/models/result_value_bool.py +73 -165
  804. lusid/models/result_value_currency.py +78 -164
  805. lusid/models/result_value_date_time_offset.py +81 -196
  806. lusid/models/result_value_decimal.py +80 -195
  807. lusid/models/result_value_dictionary.py +89 -163
  808. lusid/models/result_value_int.py +80 -195
  809. lusid/models/result_value_string.py +78 -164
  810. lusid/models/result_value_type.py +48 -0
  811. lusid/models/rounding_configuration.py +55 -125
  812. lusid/models/rounding_configuration_component.py +51 -131
  813. lusid/models/rounding_convention.py +67 -218
  814. lusid/models/scaling_methodology.py +39 -0
  815. lusid/models/schedule.py +78 -143
  816. lusid/models/schedule_type.py +44 -0
  817. lusid/models/scope_definition.py +51 -131
  818. lusid/models/script_map_reference.py +76 -219
  819. lusid/models/security_election.py +68 -252
  820. lusid/models/sequence_definition.py +94 -374
  821. lusid/models/set_legal_entity_identifiers_request.py +69 -126
  822. lusid/models/set_legal_entity_properties_request.py +69 -126
  823. lusid/models/set_person_identifiers_request.py +69 -126
  824. lusid/models/set_person_properties_request.py +64 -128
  825. lusid/models/set_transaction_configuration_alias.py +84 -0
  826. lusid/models/set_transaction_configuration_source_request.py +107 -0
  827. lusid/models/side_configuration_data.py +76 -334
  828. lusid/models/side_configuration_data_request.py +79 -0
  829. lusid/models/side_definition.py +83 -388
  830. lusid/models/side_definition_request.py +66 -322
  831. lusid/models/sides_definition_request.py +57 -164
  832. lusid/models/simple_cash_flow_loan.py +88 -263
  833. lusid/models/simple_instrument.py +94 -301
  834. lusid/models/sort_order.py +38 -0
  835. lusid/models/step_schedule.py +85 -236
  836. lusid/models/stock_split_event.py +78 -349
  837. lusid/models/stream.py +70 -328
  838. lusid/models/string_comparison_type.py +41 -0
  839. lusid/models/string_compliance_parameter.py +73 -167
  840. lusid/models/string_list.py +73 -170
  841. lusid/models/string_list_compliance_parameter.py +77 -164
  842. lusid/models/structured_result_data.py +73 -267
  843. lusid/models/structured_result_data_id.py +89 -236
  844. lusid/models/sub_holding_key_value_equals.py +93 -0
  845. lusid/models/target_tax_lot.py +86 -368
  846. lusid/models/target_tax_lot_request.py +86 -368
  847. lusid/models/tax_rule.py +97 -0
  848. lusid/models/tax_rule_set.py +124 -0
  849. lusid/models/template_field.py +77 -0
  850. lusid/models/term_deposit.py +93 -323
  851. lusid/models/total_return_swap.py +88 -259
  852. lusid/models/touch.py +62 -228
  853. lusid/models/trade_ticket.py +76 -0
  854. lusid/models/trade_ticket_type.py +38 -0
  855. lusid/models/transaction.py +181 -812
  856. lusid/models/transaction_configuration_data.py +89 -190
  857. lusid/models/transaction_configuration_data_request.py +89 -190
  858. lusid/models/transaction_configuration_movement_data.py +110 -320
  859. lusid/models/transaction_configuration_movement_data_request.py +110 -320
  860. lusid/models/transaction_configuration_type_alias.py +90 -339
  861. lusid/models/transaction_currency_and_amount.py +81 -0
  862. lusid/models/transaction_field_map.py +97 -0
  863. lusid/models/transaction_price.py +63 -162
  864. lusid/models/transaction_price_and_type.py +81 -0
  865. lusid/models/transaction_price_type.py +40 -0
  866. lusid/models/transaction_property_map.py +80 -0
  867. lusid/models/transaction_property_mapping.py +65 -188
  868. lusid/models/transaction_property_mapping_request.py +65 -188
  869. lusid/models/transaction_query_mode.py +38 -0
  870. lusid/models/transaction_query_parameters.py +67 -234
  871. lusid/models/transaction_reconciliation_request.py +84 -302
  872. lusid/models/transaction_reconciliation_request_v2.py +115 -0
  873. lusid/models/transaction_request.py +143 -661
  874. lusid/models/transaction_roles.py +44 -0
  875. lusid/models/transaction_set_configuration_data.py +89 -186
  876. lusid/models/transaction_set_configuration_data_request.py +92 -0
  877. lusid/models/transaction_status.py +39 -0
  878. lusid/models/transaction_template.py +100 -0
  879. lusid/models/transaction_template_request.py +79 -0
  880. lusid/models/transaction_template_specification.py +99 -0
  881. lusid/models/transaction_type.py +119 -248
  882. lusid/models/transaction_type_alias.py +73 -282
  883. lusid/models/transaction_type_calculation.py +60 -206
  884. lusid/models/transaction_type_movement.py +128 -405
  885. lusid/models/transaction_type_property_mapping.py +75 -197
  886. lusid/models/transaction_type_request.py +104 -220
  887. lusid/models/transactions_reconciliations_response.py +70 -155
  888. lusid/models/transition_event.py +101 -318
  889. lusid/models/translate_entities_inlined_request.py +72 -195
  890. lusid/models/translate_entities_request.py +76 -187
  891. lusid/models/translate_entities_response.py +104 -184
  892. lusid/models/translate_instrument_definitions_request.py +91 -0
  893. lusid/models/translate_instrument_definitions_response.py +129 -0
  894. lusid/models/translate_trade_ticket_request.py +91 -0
  895. lusid/models/translate_trade_tickets_response.py +129 -0
  896. lusid/models/translation_context.py +57 -154
  897. lusid/models/translation_input.py +51 -134
  898. lusid/models/translation_result.py +66 -163
  899. lusid/models/translation_script.py +63 -193
  900. lusid/models/translation_script_id.py +76 -219
  901. lusid/models/trial_balance.py +138 -0
  902. lusid/models/trial_balance_query_parameters.py +111 -0
  903. lusid/models/trigger_event.py +82 -301
  904. lusid/models/typed_resource_id.py +76 -219
  905. lusid/models/unit_schema.py +39 -0
  906. lusid/models/units_ratio.py +53 -160
  907. lusid/models/unmatched_holding_method.py +38 -0
  908. lusid/models/update_calendar_request.py +74 -195
  909. lusid/models/update_custom_entity_definition_request.py +77 -204
  910. lusid/models/update_custom_entity_type_request.py +77 -204
  911. lusid/models/update_cut_label_definition_request.py +83 -226
  912. lusid/models/update_data_type_request.py +105 -234
  913. lusid/models/update_derived_property_definition_request.py +66 -229
  914. lusid/models/update_instrument_identifier_request.py +65 -191
  915. lusid/models/update_portfolio_group_request.py +58 -161
  916. lusid/models/update_portfolio_request.py +58 -161
  917. lusid/models/update_property_definition_request.py +58 -164
  918. lusid/models/update_reconciliation_request.py +131 -0
  919. lusid/models/update_relationship_definition_request.py +76 -219
  920. lusid/models/update_tax_rule_set_request.py +95 -0
  921. lusid/models/update_unit_request.py +100 -207
  922. lusid/models/upsert_cds_flow_conventions_request.py +73 -0
  923. lusid/models/upsert_complex_market_data_request.py +61 -156
  924. lusid/models/upsert_compliance_rule_request.py +113 -380
  925. lusid/models/upsert_compliance_run_summary_request.py +72 -250
  926. lusid/models/upsert_compliance_run_summary_result.py +72 -250
  927. lusid/models/upsert_corporate_action_request.py +94 -337
  928. lusid/models/upsert_corporate_actions_response.py +111 -214
  929. lusid/models/upsert_counterparty_agreement_request.py +55 -126
  930. lusid/models/upsert_credit_support_annex_request.py +55 -125
  931. lusid/models/upsert_custom_entities_response.py +111 -244
  932. lusid/models/upsert_custom_entity_access_metadata_request.py +64 -126
  933. lusid/models/upsert_dialect_request.py +61 -156
  934. lusid/models/upsert_flow_conventions_request.py +73 -0
  935. lusid/models/upsert_index_convention_request.py +73 -0
  936. lusid/models/upsert_instrument_event_request.py +107 -329
  937. lusid/models/upsert_instrument_events_response.py +111 -214
  938. lusid/models/upsert_instrument_properties_response.py +67 -157
  939. lusid/models/upsert_instrument_property_request.py +68 -196
  940. lusid/models/upsert_instruments_response.py +135 -274
  941. lusid/models/upsert_legal_entities_response.py +111 -214
  942. lusid/models/upsert_legal_entity_access_metadata_request.py +64 -126
  943. lusid/models/upsert_legal_entity_request.py +115 -267
  944. lusid/models/upsert_person_access_metadata_request.py +64 -126
  945. lusid/models/upsert_person_request.py +92 -232
  946. lusid/models/upsert_portfolio_access_metadata_request.py +59 -128
  947. lusid/models/upsert_portfolio_group_access_metadata_request.py +59 -128
  948. lusid/models/upsert_portfolio_transactions_response.py +101 -214
  949. lusid/models/upsert_quote_access_metadata_rule_request.py +92 -0
  950. lusid/models/upsert_quote_request.py +75 -215
  951. lusid/models/upsert_quotes_response.py +111 -214
  952. lusid/models/upsert_recipe_composer_request.py +73 -0
  953. lusid/models/upsert_recipe_request.py +55 -125
  954. lusid/models/upsert_reference_portfolio_constituents_request.py +94 -265
  955. lusid/models/upsert_reference_portfolio_constituents_response.py +77 -181
  956. lusid/models/upsert_result_values_data_request.py +93 -0
  957. lusid/models/upsert_returns_response.py +100 -245
  958. lusid/models/upsert_single_structured_data_response.py +74 -186
  959. lusid/models/upsert_structured_data_response.py +99 -215
  960. lusid/models/upsert_structured_result_data_request.py +61 -155
  961. lusid/models/upsert_transaction_properties_response.py +97 -211
  962. lusid/models/upsert_translation_script_request.py +57 -164
  963. lusid/models/user.py +56 -126
  964. lusid/models/valuation_request.py +156 -528
  965. lusid/models/valuation_schedule.py +93 -329
  966. lusid/models/valuations_reconciliation_request.py +82 -216
  967. lusid/models/value_type.py +34 -116
  968. lusid/models/vendor_dependency.py +95 -0
  969. lusid/models/vendor_library.py +43 -0
  970. lusid/models/vendor_model_rule.py +97 -335
  971. lusid/models/version.py +110 -431
  972. lusid/models/version_summary_dto.py +85 -208
  973. lusid/models/versioned_resource_list_of_a2_b_data_record.py +101 -268
  974. lusid/models/versioned_resource_list_of_a2_b_movement_record.py +101 -268
  975. lusid/models/versioned_resource_list_of_holding_contributor.py +101 -268
  976. lusid/models/versioned_resource_list_of_journal_entry_line.py +119 -0
  977. lusid/models/versioned_resource_list_of_output_transaction.py +101 -268
  978. lusid/models/versioned_resource_list_of_portfolio_holding.py +101 -268
  979. lusid/models/versioned_resource_list_of_transaction.py +101 -268
  980. lusid/models/versioned_resource_list_of_trial_balance.py +119 -0
  981. lusid/models/versioned_resource_list_with_warnings_of_portfolio_holding.py +134 -0
  982. lusid/models/virtual_document.py +88 -0
  983. lusid/models/virtual_document_row.py +80 -0
  984. lusid/models/virtual_row.py +76 -156
  985. lusid/models/warning.py +71 -0
  986. lusid/models/weekend_mask.py +61 -165
  987. lusid/models/weighted_instrument.py +75 -256
  988. lusid/models/weighted_instrument_in_line_lookup_identifiers.py +71 -415
  989. lusid/models/weighted_instruments.py +59 -128
  990. lusid/models/yield_curve_data.py +107 -296
  991. lusid/py.typed +0 -0
  992. lusid/rest.py +171 -237
  993. lusid_sdk-2.0.430.dist-info/METADATA +1639 -0
  994. lusid_sdk-2.0.430.dist-info/RECORD +995 -0
  995. {lusid_sdk-1.1.257.dist-info → lusid_sdk-2.0.430.dist-info}/WHEEL +1 -2
  996. lusid/__version__.py +0 -1
  997. lusid/api/queryable_keys_api.py +0 -196
  998. lusid/models/accumulation_event_all_of.py +0 -310
  999. lusid/models/address_key_compliance_parameter_all_of.py +0 -184
  1000. lusid/models/address_key_list_all_of.py +0 -188
  1001. lusid/models/address_key_list_compliance_parameter_all_of.py +0 -182
  1002. lusid/models/amortisation_event_all_of.py +0 -283
  1003. lusid/models/basket_all_of.py +0 -247
  1004. lusid/models/batch_upsert_dates_for_calendar_response.py +0 -232
  1005. lusid/models/batch_upsert_portfolio_access_metadata_request.py +0 -174
  1006. lusid/models/batch_upsert_portfolio_access_metadata_response.py +0 -202
  1007. lusid/models/batch_upsert_portfolio_access_metadata_response_item.py +0 -174
  1008. lusid/models/bond_all_of.py +0 -587
  1009. lusid/models/bond_coupon_event_all_of.py +0 -278
  1010. lusid/models/bond_default_event_all_of.py +0 -184
  1011. lusid/models/bond_principal_event_all_of.py +0 -278
  1012. lusid/models/bonus_issue_event.py +0 -426
  1013. lusid/models/bonus_issue_event_all_of.py +0 -426
  1014. lusid/models/bool_compliance_parameter_all_of.py +0 -182
  1015. lusid/models/branch_step_all_of.py +0 -219
  1016. lusid/models/branch_step_request.py +0 -193
  1017. lusid/models/branch_step_request_all_of.py +0 -193
  1018. lusid/models/calendar_dependency_all_of.py +0 -184
  1019. lusid/models/call_on_intermediate_securities_event.py +0 -400
  1020. lusid/models/call_on_intermediate_securities_event_all_of.py +0 -400
  1021. lusid/models/cancel_order_and_move_remaining_result.py +0 -201
  1022. lusid/models/cancel_orders_and_move_remaining_request.py +0 -204
  1023. lusid/models/cancel_orders_and_move_remaining_response.py +0 -262
  1024. lusid/models/cancel_orders_response.py +0 -262
  1025. lusid/models/cancel_placements_response.py +0 -262
  1026. lusid/models/cancelled_order_result.py +0 -143
  1027. lusid/models/cancelled_placement_result.py +0 -175
  1028. lusid/models/cap_floor_all_of.py +0 -313
  1029. lusid/models/capital_distribution_event.py +0 -308
  1030. lusid/models/capital_distribution_event_all_of.py +0 -308
  1031. lusid/models/cash.py +0 -216
  1032. lusid/models/cash_all_of.py +0 -216
  1033. lusid/models/cash_and_security_offer_election.py +0 -335
  1034. lusid/models/cash_dependency_all_of.py +0 -216
  1035. lusid/models/cash_dividend_event_all_of.py +0 -308
  1036. lusid/models/cash_flow_event_all_of.py +0 -217
  1037. lusid/models/cash_flow_value_all_of.py +0 -306
  1038. lusid/models/cash_flow_value_set_all_of.py +0 -182
  1039. lusid/models/cash_offer_election.py +0 -275
  1040. lusid/models/cash_perpetual_all_of.py +0 -248
  1041. lusid/models/cds_credit_event.py +0 -244
  1042. lusid/models/cds_credit_event_all_of.py +0 -244
  1043. lusid/models/cds_index_all_of.py +0 -399
  1044. lusid/models/cdx_credit_event.py +0 -306
  1045. lusid/models/cdx_credit_event_all_of.py +0 -306
  1046. lusid/models/check_step_all_of.py +0 -251
  1047. lusid/models/check_step_request.py +0 -193
  1048. lusid/models/close_event_all_of.py +0 -214
  1049. lusid/models/complex_bond_all_of.py +0 -344
  1050. lusid/models/compliance_rule_template.py +0 -329
  1051. lusid/models/compliance_run_configuration.py +0 -144
  1052. lusid/models/compliance_run_summary.py +0 -267
  1053. lusid/models/compliance_step_request.py +0 -167
  1054. lusid/models/compliance_template_variation_dto.py +0 -290
  1055. lusid/models/compliance_template_variation_request.py +0 -290
  1056. lusid/models/configuration_recipe_snippet.py +0 -372
  1057. lusid/models/constant_volatility_surface_all_of.py +0 -285
  1058. lusid/models/contract_for_difference_all_of.py +0 -478
  1059. lusid/models/create_compliance_template_request.py +0 -228
  1060. lusid/models/credit_default_swap_all_of.py +0 -401
  1061. lusid/models/credit_premium_cash_flow_event.py +0 -278
  1062. lusid/models/credit_premium_cash_flow_event_all_of.py +0 -278
  1063. lusid/models/credit_spread_curve_data_all_of.py +0 -437
  1064. lusid/models/date_time_compliance_parameter_all_of.py +0 -182
  1065. lusid/models/decimal_compliance_parameter_all_of.py +0 -182
  1066. lusid/models/decimal_list_all_of.py +0 -188
  1067. lusid/models/discount_factor_curve_data_all_of.py +0 -313
  1068. lusid/models/discounting_dependency_all_of.py +0 -216
  1069. lusid/models/dividend_option_event_all_of.py +0 -371
  1070. lusid/models/empty_model_options_all_of.py +0 -152
  1071. lusid/models/equity_all_of.py +0 -243
  1072. lusid/models/equity_curve_by_prices_data_all_of.py +0 -313
  1073. lusid/models/equity_curve_dependency_all_of.py +0 -298
  1074. lusid/models/equity_model_options_all_of.py +0 -187
  1075. lusid/models/equity_option_all_of.py +0 -590
  1076. lusid/models/equity_swap_all_of.py +0 -504
  1077. lusid/models/equity_vol_dependency_all_of.py +0 -292
  1078. lusid/models/equity_vol_surface_data_all_of.py +0 -284
  1079. lusid/models/exchange_traded_option_all_of.py +0 -278
  1080. lusid/models/exercise_event_all_of.py +0 -245
  1081. lusid/models/exotic_instrument_all_of.py +0 -217
  1082. lusid/models/expiry_event.py +0 -184
  1083. lusid/models/expiry_event_all_of.py +0 -184
  1084. lusid/models/filter_predicate_compliance_parameter_all_of.py +0 -185
  1085. lusid/models/filter_step_request.py +0 -193
  1086. lusid/models/fixed_leg_all_of.py +0 -304
  1087. lusid/models/flexible_loan_all_of.py +0 -280
  1088. lusid/models/floating_leg_all_of.py +0 -366
  1089. lusid/models/forward_rate_agreement_all_of.py +0 -373
  1090. lusid/models/fund_id_list.py +0 -185
  1091. lusid/models/fund_id_list_all_of.py +0 -185
  1092. lusid/models/fund_share_class_all_of.py +0 -354
  1093. lusid/models/funding_leg_all_of.py +0 -276
  1094. lusid/models/future_all_of.py +0 -405
  1095. lusid/models/future_expiry_event.py +0 -246
  1096. lusid/models/future_expiry_event_all_of.py +0 -246
  1097. lusid/models/fx_dependency_all_of.py +0 -248
  1098. lusid/models/fx_forward_all_of.py +0 -498
  1099. lusid/models/fx_forward_curve_by_quote_reference_all_of.py +0 -405
  1100. lusid/models/fx_forward_curve_data_all_of.py +0 -377
  1101. lusid/models/fx_forward_model_options_all_of.py +0 -260
  1102. lusid/models/fx_forward_pips_curve_data_all_of.py +0 -377
  1103. lusid/models/fx_forward_settlement_event_all_of.py +0 -524
  1104. lusid/models/fx_forward_tenor_curve_data_all_of.py +0 -437
  1105. lusid/models/fx_forward_tenor_pips_curve_data_all_of.py +0 -437
  1106. lusid/models/fx_forwards_dependency_all_of.py +0 -286
  1107. lusid/models/fx_linked_notional_schedule_all_of.py +0 -273
  1108. lusid/models/fx_option_all_of.py +0 -646
  1109. lusid/models/fx_swap_all_of.py +0 -242
  1110. lusid/models/fx_vol_dependency_all_of.py +0 -286
  1111. lusid/models/group_by_step_request.py +0 -193
  1112. lusid/models/group_calculation_compliance_parameter.py +0 -185
  1113. lusid/models/group_filter_step_all_of.py +0 -219
  1114. lusid/models/group_filter_step_request.py +0 -193
  1115. lusid/models/holding_ids_request.py +0 -149
  1116. lusid/models/holding_pricing_info.py +0 -234
  1117. lusid/models/index_model_options_all_of.py +0 -190
  1118. lusid/models/index_projection_dependency_all_of.py +0 -292
  1119. lusid/models/inflation_fixing_dependency_all_of.py +0 -254
  1120. lusid/models/inflation_leg_all_of.py +0 -472
  1121. lusid/models/inflation_linked_bond_all_of.py +0 -618
  1122. lusid/models/inflation_swap_all_of.py +0 -276
  1123. lusid/models/informational_error_event_all_of.py +0 -254
  1124. lusid/models/informational_event_all_of.py +0 -279
  1125. lusid/models/instrument_event_instruction.py +0 -380
  1126. lusid/models/instrument_event_instruction_request.py +0 -279
  1127. lusid/models/instrument_event_instructions_response.py +0 -174
  1128. lusid/models/instrument_leg_all_of.py +0 -152
  1129. lusid/models/instrument_list_all_of.py +0 -188
  1130. lusid/models/interest_rate_swap_all_of.py +0 -339
  1131. lusid/models/interest_rate_swaption_all_of.py +0 -313
  1132. lusid/models/intermediate_securities_distribution_event.py +0 -426
  1133. lusid/models/intermediate_securities_distribution_event_all_of.py +0 -426
  1134. lusid/models/ir_vol_cube_data_all_of.py +0 -284
  1135. lusid/models/ir_vol_dependency_all_of.py +0 -254
  1136. lusid/models/lapse_election.py +0 -211
  1137. lusid/models/life_cycle_event_value_all_of.py +0 -241
  1138. lusid/models/loan_facility.py +0 -292
  1139. lusid/models/loan_facility_all_of.py +0 -292
  1140. lusid/models/look_up_pricing_model_options.py +0 -216
  1141. lusid/models/look_up_pricing_model_options_all_of.py +0 -216
  1142. lusid/models/mastered_instrument.py +0 -364
  1143. lusid/models/mastered_instrument_all_of.py +0 -364
  1144. lusid/models/maturity_event_all_of.py +0 -184
  1145. lusid/models/mbs_coupon_event.py +0 -278
  1146. lusid/models/mbs_coupon_event_all_of.py +0 -278
  1147. lusid/models/mbs_interest_deferral_event.py +0 -278
  1148. lusid/models/mbs_interest_deferral_event_all_of.py +0 -278
  1149. lusid/models/mbs_interest_shortfall_event.py +0 -278
  1150. lusid/models/mbs_interest_shortfall_event_all_of.py +0 -278
  1151. lusid/models/mbs_principal_event.py +0 -278
  1152. lusid/models/mbs_principal_event_all_of.py +0 -278
  1153. lusid/models/mbs_principal_write_off_event.py +0 -278
  1154. lusid/models/mbs_principal_write_off_event_all_of.py +0 -278
  1155. lusid/models/merger_event.py +0 -456
  1156. lusid/models/merger_event_all_of.py +0 -456
  1157. lusid/models/new_instrument.py +0 -236
  1158. lusid/models/opaque_dependency_all_of.py +0 -152
  1159. lusid/models/opaque_market_data_all_of.py +0 -293
  1160. lusid/models/opaque_model_options_all_of.py +0 -182
  1161. lusid/models/open_event_all_of.py +0 -183
  1162. lusid/models/option_exercise_cash_event.py +0 -500
  1163. lusid/models/option_exercise_cash_event_all_of.py +0 -500
  1164. lusid/models/option_exercise_election.py +0 -211
  1165. lusid/models/option_exercise_physical_event.py +0 -530
  1166. lusid/models/option_exercise_physical_event_all_of.py +0 -530
  1167. lusid/models/order_graph_block_transaction_detail.py +0 -149
  1168. lusid/models/order_graph_block_transaction_synopsis.py +0 -178
  1169. lusid/models/order_update_request.py +0 -320
  1170. lusid/models/paged_resource_list_of_instrument_event_instruction.py +0 -256
  1171. lusid/models/percent_check_step.py +0 -251
  1172. lusid/models/percent_check_step_request.py +0 -193
  1173. lusid/models/placement_update_request.py +0 -306
  1174. lusid/models/portfolio_group_id_list_all_of.py +0 -185
  1175. lusid/models/portfolio_result_data_key_rule_all_of.py +0 -409
  1176. lusid/models/pre_trade_configuration.py +0 -149
  1177. lusid/models/property_key_compliance_parameter_all_of.py +0 -184
  1178. lusid/models/property_list.py +0 -188
  1179. lusid/models/property_list_all_of.py +0 -188
  1180. lusid/models/property_list_compliance_parameter.py +0 -182
  1181. lusid/models/protection_payout_cash_flow_event.py +0 -278
  1182. lusid/models/queryable_key.py +0 -508
  1183. lusid/models/quote_dependency_all_of.py +0 -257
  1184. lusid/models/raw_vendor_event_all_of.py +0 -249
  1185. lusid/models/reconcile_date_time_rule_all_of.py +0 -251
  1186. lusid/models/reconcile_numeric_rule_all_of.py +0 -251
  1187. lusid/models/reconcile_string_rule_all_of.py +0 -250
  1188. lusid/models/reference_instrument_all_of.py +0 -257
  1189. lusid/models/repo_all_of.py +0 -493
  1190. lusid/models/reset_event_all_of.py +0 -279
  1191. lusid/models/resource_list_of_output_transaction.py +0 -256
  1192. lusid/models/resource_list_of_queryable_key.py +0 -256
  1193. lusid/models/result_data_key_rule_all_of.py +0 -406
  1194. lusid/models/result_value0_d_all_of.py +0 -243
  1195. lusid/models/result_value_bool_all_of.py +0 -183
  1196. lusid/models/result_value_currency_all_of.py +0 -182
  1197. lusid/models/result_value_date_time_offset_all_of.py +0 -213
  1198. lusid/models/result_value_decimal_all_of.py +0 -213
  1199. lusid/models/result_value_dictionary_all_of.py +0 -182
  1200. lusid/models/result_value_int_all_of.py +0 -213
  1201. lusid/models/result_value_string_all_of.py +0 -182
  1202. lusid/models/return_zero_pv_options.py +0 -145
  1203. lusid/models/reverse_stock_split_event.py +0 -366
  1204. lusid/models/reverse_stock_split_event_all_of.py +0 -366
  1205. lusid/models/schema.py +0 -226
  1206. lusid/models/scrip_dividend_event.py +0 -366
  1207. lusid/models/scrip_dividend_event_all_of.py +0 -366
  1208. lusid/models/security_offer_election.py +0 -241
  1209. lusid/models/settlement_cycle.py +0 -180
  1210. lusid/models/settlement_schedule.py +0 -200
  1211. lusid/models/simple_cash_flow_loan_all_of.py +0 -280
  1212. lusid/models/simple_instrument_all_of.py +0 -318
  1213. lusid/models/simple_rounding_convention.py +0 -175
  1214. lusid/models/specific_holding_pricing_info.py +0 -179
  1215. lusid/models/spin_off_event.py +0 -426
  1216. lusid/models/staged_modifications_info.py +0 -208
  1217. lusid/models/step_schedule_all_of.py +0 -254
  1218. lusid/models/stock_dividend_event.py +0 -366
  1219. lusid/models/stock_dividend_event_all_of.py +0 -366
  1220. lusid/models/stock_split_event_all_of.py +0 -366
  1221. lusid/models/string_compliance_parameter_all_of.py +0 -185
  1222. lusid/models/swap_cash_flow_event.py +0 -279
  1223. lusid/models/swap_cash_flow_event_all_of.py +0 -279
  1224. lusid/models/swap_principal_event.py +0 -279
  1225. lusid/models/swap_principal_event_all_of.py +0 -279
  1226. lusid/models/tender_event.py +0 -456
  1227. lusid/models/tender_event_all_of.py +0 -456
  1228. lusid/models/term_deposit_all_of.py +0 -340
  1229. lusid/models/term_deposit_interest_event.py +0 -246
  1230. lusid/models/term_deposit_interest_event_all_of.py +0 -246
  1231. lusid/models/term_deposit_principal_event.py +0 -246
  1232. lusid/models/term_deposit_principal_event_all_of.py +0 -246
  1233. lusid/models/total_return_swap_all_of.py +0 -276
  1234. lusid/models/transition_event_all_of.py +0 -335
  1235. lusid/models/trigger_event_all_of.py +0 -318
  1236. lusid/models/update_compliance_template_request.py +0 -228
  1237. lusid/models/update_orders_response.py +0 -262
  1238. lusid/models/update_placements_response.py +0 -262
  1239. lusid/models/update_reference_data_request.py +0 -178
  1240. lusid/models/upsert_persons_response.py +0 -238
  1241. lusid/models/upsert_reference_portfolio_constituent_properties_request.py +0 -178
  1242. lusid/models/upsert_reference_portfolio_constituent_properties_response.py +0 -231
  1243. lusid/models/yield_curve_data_all_of.py +0 -313
  1244. lusid/tcp/__init__.py +0 -1
  1245. lusid/tcp/tcp_keep_alive_probes.py +0 -110
  1246. lusid/utilities/__init__.py +0 -8
  1247. lusid/utilities/api_client_builder.py +0 -145
  1248. lusid/utilities/api_client_factory.py +0 -132
  1249. lusid/utilities/api_configuration.py +0 -126
  1250. lusid/utilities/api_configuration_loader.py +0 -87
  1251. lusid/utilities/config_keys.json +0 -50
  1252. lusid/utilities/config_keys.py +0 -13
  1253. lusid/utilities/lusid_retry.py +0 -47
  1254. lusid_sdk-1.1.257.dist-info/METADATA +0 -21
  1255. lusid_sdk-1.1.257.dist-info/RECORD +0 -987
  1256. lusid_sdk-1.1.257.dist-info/top_level.txt +0 -1
@@ -5,49 +5,71 @@
5
5
 
6
6
  FINBOURNE Technology # noqa: E501
7
7
 
8
- The version of the OpenAPI document: 1.1.257
9
8
  Contact: info@finbourne.com
10
- Generated by: https://openapi-generator.tech
11
- """
9
+ Generated by OpenAPI Generator (https://openapi-generator.tech)
12
10
 
11
+ Do not edit the class manually.
12
+ """
13
13
 
14
- from __future__ import absolute_import
15
14
 
16
15
  import re # noqa: F401
16
+ import io
17
+ import warnings
17
18
 
18
- # python 2 and python 3 compatibility library
19
- import six
19
+ from pydantic import validate_arguments, ValidationError
20
+ from typing import overload, Optional, Union, Awaitable
20
21
 
21
- from lusid.api_client import ApiClient
22
- from lusid.exceptions import ( # noqa: F401
23
- ApiTypeError,
24
- ApiValueError
25
- )
22
+ from typing_extensions import Annotated
23
+ from datetime import datetime
24
+
25
+ from pydantic import Field, StrictStr, conint, constr, validator
26
+
27
+ from typing import Dict, Optional
28
+
29
+ from lusid.models.annul_structured_data_response import AnnulStructuredDataResponse
26
30
  from lusid.models.create_data_map_request import CreateDataMapRequest
31
+ from lusid.models.data_map_key import DataMapKey
32
+ from lusid.models.get_data_map_response import GetDataMapResponse
27
33
  from lusid.models.get_structured_result_data_response import GetStructuredResultDataResponse
28
- from lusid.models.lusid_problem_details import LusidProblemDetails
29
- from lusid.models.lusid_validation_problem_details import LusidValidationProblemDetails
34
+ from lusid.models.get_virtual_document_response import GetVirtualDocumentResponse
30
35
  from lusid.models.paged_resource_list_of_virtual_row import PagedResourceListOfVirtualRow
31
36
  from lusid.models.resource_list_of_address_key_definition import ResourceListOfAddressKeyDefinition
32
37
  from lusid.models.structured_result_data_id import StructuredResultDataId
38
+ from lusid.models.upsert_result_values_data_request import UpsertResultValuesDataRequest
33
39
  from lusid.models.upsert_structured_data_response import UpsertStructuredDataResponse
34
40
  from lusid.models.upsert_structured_result_data_request import UpsertStructuredResultDataRequest
35
41
 
42
+ from lusid.api_client import ApiClient
43
+ from lusid.api_response import ApiResponse
44
+ from lusid.exceptions import ( # noqa: F401
45
+ ApiTypeError,
46
+ ApiValueError
47
+ )
36
48
 
37
- class StructuredResultDataApi(object):
49
+
50
+ class StructuredResultDataApi:
38
51
  """NOTE: This class is auto generated by OpenAPI Generator
39
52
  Ref: https://openapi-generator.tech
40
53
 
41
54
  Do not edit the class manually.
42
55
  """
43
56
 
44
- def __init__(self, api_client=None):
57
+ def __init__(self, api_client=None) -> None:
45
58
  if api_client is None:
46
- api_client = ApiClient()
59
+ api_client = ApiClient.get_default()
47
60
  self.api_client = api_client
48
61
 
49
- def create_data_map(self, scope, request_body, **kwargs): # noqa: E501
50
- """CreateDataMap: Create data map # noqa: E501
62
+ @overload
63
+ async def create_data_map(self, scope : Annotated[constr(strict=True, max_length=64, min_length=1), Field(..., description="The scope in which to create or update data maps.")], request_body : Annotated[Dict[str, CreateDataMapRequest], Field(..., description="Individual data map creation requests.")], **kwargs) -> UpsertStructuredDataResponse: # noqa: E501
64
+ ...
65
+
66
+ @overload
67
+ def create_data_map(self, scope : Annotated[constr(strict=True, max_length=64, min_length=1), Field(..., description="The scope in which to create or update data maps.")], request_body : Annotated[Dict[str, CreateDataMapRequest], Field(..., description="Individual data map creation requests.")], async_req: Optional[bool]=True, **kwargs) -> UpsertStructuredDataResponse: # noqa: E501
68
+ ...
69
+
70
+ @validate_arguments
71
+ def create_data_map(self, scope : Annotated[constr(strict=True, max_length=64, min_length=1), Field(..., description="The scope in which to create or update data maps.")], request_body : Annotated[Dict[str, CreateDataMapRequest], Field(..., description="Individual data map creation requests.")], async_req: Optional[bool]=None, **kwargs) -> Union[UpsertStructuredDataResponse, Awaitable[UpsertStructuredDataResponse]]: # noqa: E501
72
+ """[EXPERIMENTAL] CreateDataMap: Create data map # noqa: E501
51
73
 
52
74
  Create or update one or more structured result store address definition data maps in a particular scope. Note these are immutable and cannot be changed once created. In the request, each data map must be keyed by a unique correlation ID. This ID is ephemeral and not stored by LUSID. It serves only to easily identify each data map object in the response. The response returns both the collection of successfully created or updated data maps, as well as those that failed. For each failure, a reason is provided. It is important to check the failed set for any unsuccessful results. # noqa: E501
53
75
  This method makes a synchronous HTTP request by default. To make an
@@ -59,27 +81,29 @@ class StructuredResultDataApi(object):
59
81
  :param scope: The scope in which to create or update data maps. (required)
60
82
  :type scope: str
61
83
  :param request_body: Individual data map creation requests. (required)
62
- :type request_body: dict(str, CreateDataMapRequest)
84
+ :type request_body: Dict[str, CreateDataMapRequest]
63
85
  :param async_req: Whether to execute the request asynchronously.
64
86
  :type async_req: bool, optional
65
- :param _preload_content: if False, the urllib3.HTTPResponse object will
66
- be returned without reading/decoding response
67
- data. Default is True.
68
- :type _preload_content: bool, optional
69
- :param _request_timeout: timeout setting for this request. If one
70
- number provided, it will be total request
71
- timeout. It can also be a pair (tuple) of
72
- (connection, read) timeouts.
87
+ :param _request_timeout: timeout setting for this request.
88
+ If one number provided, it will be total request
89
+ timeout. It can also be a pair (tuple) of
90
+ (connection, read) timeouts.
73
91
  :return: Returns the result object.
74
92
  If the method is called asynchronously,
75
93
  returns the request thread.
76
94
  :rtype: UpsertStructuredDataResponse
77
95
  """
78
96
  kwargs['_return_http_data_only'] = True
97
+ if '_preload_content' in kwargs:
98
+ message = "Error! Please call the create_data_map_with_http_info method with `_preload_content` instead and obtain raw data from ApiResponse.raw_data" # noqa: E501
99
+ raise ValueError(message)
100
+ if async_req is not None:
101
+ kwargs['async_req'] = async_req
79
102
  return self.create_data_map_with_http_info(scope, request_body, **kwargs) # noqa: E501
80
103
 
81
- def create_data_map_with_http_info(self, scope, request_body, **kwargs): # noqa: E501
82
- """CreateDataMap: Create data map # noqa: E501
104
+ @validate_arguments
105
+ def create_data_map_with_http_info(self, scope : Annotated[constr(strict=True, max_length=64, min_length=1), Field(..., description="The scope in which to create or update data maps.")], request_body : Annotated[Dict[str, CreateDataMapRequest], Field(..., description="Individual data map creation requests.")], **kwargs) -> ApiResponse: # noqa: E501
106
+ """[EXPERIMENTAL] CreateDataMap: Create data map # noqa: E501
83
107
 
84
108
  Create or update one or more structured result store address definition data maps in a particular scope. Note these are immutable and cannot be changed once created. In the request, each data map must be keyed by a unique correlation ID. This ID is ephemeral and not stored by LUSID. It serves only to easily identify each data map object in the response. The response returns both the collection of successfully created or updated data maps, as well as those that failed. For each failure, a reason is provided. It is important to check the failed set for any unsuccessful results. # noqa: E501
85
109
  This method makes a synchronous HTTP request by default. To make an
@@ -91,16 +115,17 @@ class StructuredResultDataApi(object):
91
115
  :param scope: The scope in which to create or update data maps. (required)
92
116
  :type scope: str
93
117
  :param request_body: Individual data map creation requests. (required)
94
- :type request_body: dict(str, CreateDataMapRequest)
118
+ :type request_body: Dict[str, CreateDataMapRequest]
95
119
  :param async_req: Whether to execute the request asynchronously.
96
120
  :type async_req: bool, optional
97
- :param _return_http_data_only: response data without head status code
98
- and headers
99
- :type _return_http_data_only: bool, optional
100
- :param _preload_content: if False, the urllib3.HTTPResponse object will
101
- be returned without reading/decoding response
102
- data. Default is True.
121
+ :param _preload_content: if False, the ApiResponse.data will
122
+ be set to none and raw_data will store the
123
+ HTTP response body without reading/decoding.
124
+ Default is True.
103
125
  :type _preload_content: bool, optional
126
+ :param _return_http_data_only: response data instead of ApiResponse
127
+ object with status code, headers, etc
128
+ :type _return_http_data_only: bool, optional
104
129
  :param _request_timeout: timeout setting for this request. If one
105
130
  number provided, it will be total request
106
131
  timeout. It can also be a pair (tuple) of
@@ -109,117 +134,280 @@ class StructuredResultDataApi(object):
109
134
  request; this effectively ignores the authentication
110
135
  in the spec for a single request.
111
136
  :type _request_auth: dict, optional
112
- :return: Returns the result object, the HTTP status code, and the headers.
137
+ :type _content_type: string, optional: force content-type for the request
138
+ :return: Returns the result object.
113
139
  If the method is called asynchronously,
114
140
  returns the request thread.
115
- :rtype: (UpsertStructuredDataResponse, int, HTTPHeaderDict)
141
+ :rtype: tuple(UpsertStructuredDataResponse, status_code(int), headers(HTTPHeaderDict))
116
142
  """
117
143
 
118
- local_var_params = locals()
144
+ _params = locals()
119
145
 
120
- all_params = [
146
+ _all_params = [
121
147
  'scope',
122
148
  'request_body'
123
149
  ]
124
- all_params.extend(
150
+ _all_params.extend(
125
151
  [
126
152
  'async_req',
127
153
  '_return_http_data_only',
128
154
  '_preload_content',
129
155
  '_request_timeout',
130
156
  '_request_auth',
157
+ '_content_type',
131
158
  '_headers'
132
159
  ]
133
160
  )
134
161
 
135
- for key, val in six.iteritems(local_var_params['kwargs']):
136
- if key not in all_params:
162
+ # validate the arguments
163
+ for _key, _val in _params['kwargs'].items():
164
+ if _key not in _all_params:
137
165
  raise ApiTypeError(
138
166
  "Got an unexpected keyword argument '%s'"
139
- " to method create_data_map" % key
167
+ " to method create_data_map" % _key
140
168
  )
141
- local_var_params[key] = val
142
- del local_var_params['kwargs']
143
- # verify the required parameter 'scope' is set
144
- if self.api_client.client_side_validation and ('scope' not in local_var_params or # noqa: E501
145
- local_var_params['scope'] is None): # noqa: E501
146
- raise ApiValueError("Missing the required parameter `scope` when calling `create_data_map`") # noqa: E501
147
- # verify the required parameter 'request_body' is set
148
- if self.api_client.client_side_validation and ('request_body' not in local_var_params or # noqa: E501
149
- local_var_params['request_body'] is None): # noqa: E501
150
- raise ApiValueError("Missing the required parameter `request_body` when calling `create_data_map`") # noqa: E501
151
-
152
- if self.api_client.client_side_validation and ('scope' in local_var_params and # noqa: E501
153
- len(local_var_params['scope']) > 64): # noqa: E501
154
- raise ApiValueError("Invalid value for parameter `scope` when calling `create_data_map`, length must be less than or equal to `64`") # noqa: E501
155
- if self.api_client.client_side_validation and ('scope' in local_var_params and # noqa: E501
156
- len(local_var_params['scope']) < 1): # noqa: E501
157
- raise ApiValueError("Invalid value for parameter `scope` when calling `create_data_map`, length must be greater than or equal to `1`") # noqa: E501
158
- if self.api_client.client_side_validation and 'scope' in local_var_params and not re.search(r'^[a-zA-Z0-9\-_]+$', local_var_params['scope']): # noqa: E501
159
- raise ApiValueError("Invalid value for parameter `scope` when calling `create_data_map`, must conform to the pattern `/^[a-zA-Z0-9\-_]+$/`") # noqa: E501
160
- collection_formats = {}
161
-
162
- path_params = {}
163
- if 'scope' in local_var_params:
164
- path_params['scope'] = local_var_params['scope'] # noqa: E501
165
-
166
- query_params = []
167
-
168
- header_params = dict(local_var_params.get('_headers', {}))
169
-
170
- form_params = []
171
- local_var_files = {}
172
-
173
- body_params = None
174
- if 'request_body' in local_var_params:
175
- body_params = local_var_params['request_body']
176
- # HTTP header `Accept`
177
- header_params['Accept'] = self.api_client.select_header_accept(
169
+ _params[_key] = _val
170
+ del _params['kwargs']
171
+
172
+ _collection_formats = {}
173
+
174
+ # process the path parameters
175
+ _path_params = {}
176
+ if _params['scope']:
177
+ _path_params['scope'] = _params['scope']
178
+
179
+
180
+ # process the query parameters
181
+ _query_params = []
182
+ # process the header parameters
183
+ _header_params = dict(_params.get('_headers', {}))
184
+ # process the form parameters
185
+ _form_params = []
186
+ _files = {}
187
+ # process the body parameter
188
+ _body_params = None
189
+ if _params['request_body'] is not None:
190
+ _body_params = _params['request_body']
191
+
192
+ # set the HTTP header `Accept`
193
+ _header_params['Accept'] = self.api_client.select_header_accept(
178
194
  ['text/plain', 'application/json', 'text/json']) # noqa: E501
179
195
 
180
- header_params['Accept-Encoding'] = "gzip, deflate, br"
196
+ # set the HTTP header `Content-Type`
197
+ _content_types_list = _params.get('_content_type',
198
+ self.api_client.select_header_content_type(
199
+ ['application/json-patch+json', 'application/json', 'text/json', 'application/*+json']))
200
+ if _content_types_list:
201
+ _header_params['Content-Type'] = _content_types_list
202
+
203
+ # authentication setting
204
+ _auth_settings = ['oauth2'] # noqa: E501
181
205
 
182
- # HTTP header `Content-Type`
183
- header_params['Content-Type'] = self.api_client.select_header_content_type( # noqa: E501
184
- ['application/json-patch+json', 'application/json', 'text/json', 'application/*+json']) # noqa: E501
206
+ _response_types_map = {
207
+ '200': "UpsertStructuredDataResponse",
208
+ '400': "LusidValidationProblemDetails",
209
+ }
185
210
 
186
- # set the LUSID header
187
- header_params['X-LUSID-SDK-Language'] = 'Python'
188
- header_params['X-LUSID-SDK-Version'] = '1.1.257'
211
+ return self.api_client.call_api(
212
+ '/api/unitresults/datamap/{scope}', 'POST',
213
+ _path_params,
214
+ _query_params,
215
+ _header_params,
216
+ body=_body_params,
217
+ post_params=_form_params,
218
+ files=_files,
219
+ response_types_map=_response_types_map,
220
+ auth_settings=_auth_settings,
221
+ async_req=_params.get('async_req'),
222
+ _return_http_data_only=_params.get('_return_http_data_only'), # noqa: E501
223
+ _preload_content=_params.get('_preload_content', True),
224
+ _request_timeout=_params.get('_request_timeout'),
225
+ collection_formats=_collection_formats,
226
+ _request_auth=_params.get('_request_auth'))
227
+
228
+ @overload
229
+ async def delete_structured_result_data(self, scope : Annotated[constr(strict=True, max_length=64, min_length=1), Field(..., description="The scope from which to delete data items.")], request_body : Annotated[Dict[str, StructuredResultDataId], Field(..., description="The data IDs to delete, each keyed by a unique, ephemeral correlation ID.")], **kwargs) -> AnnulStructuredDataResponse: # noqa: E501
230
+ ...
231
+
232
+ @overload
233
+ def delete_structured_result_data(self, scope : Annotated[constr(strict=True, max_length=64, min_length=1), Field(..., description="The scope from which to delete data items.")], request_body : Annotated[Dict[str, StructuredResultDataId], Field(..., description="The data IDs to delete, each keyed by a unique, ephemeral correlation ID.")], async_req: Optional[bool]=True, **kwargs) -> AnnulStructuredDataResponse: # noqa: E501
234
+ ...
235
+
236
+ @validate_arguments
237
+ def delete_structured_result_data(self, scope : Annotated[constr(strict=True, max_length=64, min_length=1), Field(..., description="The scope from which to delete data items.")], request_body : Annotated[Dict[str, StructuredResultDataId], Field(..., description="The data IDs to delete, each keyed by a unique, ephemeral correlation ID.")], async_req: Optional[bool]=None, **kwargs) -> Union[AnnulStructuredDataResponse, Awaitable[AnnulStructuredDataResponse]]: # noqa: E501
238
+ """[EXPERIMENTAL] DeleteStructuredResultData: Delete structured result data # noqa: E501
239
+
240
+ Delete one or more structured result data items from a particular scope. Each item is identified by a unique ID which includes information about its type as well as the exact effective datetime (to the microsecond) at which it entered the system (became valid). In the request, each data item must be keyed by a unique correlation ID. This ID is ephemeral and not stored by LUSID. It serves only to easily identify each data item in the response. The response returns both the collection of successfully deleted data items, as well as those that failed. For each failure, a reason is provided. It is important to check the failed set for any unsuccessful results. # noqa: E501
241
+ This method makes a synchronous HTTP request by default. To make an
242
+ asynchronous HTTP request, please pass async_req=True
189
243
 
190
- # Authentication setting
191
- auth_settings = ['oauth2'] # noqa: E501
244
+ >>> thread = api.delete_structured_result_data(scope, request_body, async_req=True)
245
+ >>> result = thread.get()
192
246
 
193
- response_types_map = {
194
- 200: "UpsertStructuredDataResponse",
195
- 400: "LusidValidationProblemDetails",
247
+ :param scope: The scope from which to delete data items. (required)
248
+ :type scope: str
249
+ :param request_body: The data IDs to delete, each keyed by a unique, ephemeral correlation ID. (required)
250
+ :type request_body: Dict[str, StructuredResultDataId]
251
+ :param async_req: Whether to execute the request asynchronously.
252
+ :type async_req: bool, optional
253
+ :param _request_timeout: timeout setting for this request.
254
+ If one number provided, it will be total request
255
+ timeout. It can also be a pair (tuple) of
256
+ (connection, read) timeouts.
257
+ :return: Returns the result object.
258
+ If the method is called asynchronously,
259
+ returns the request thread.
260
+ :rtype: AnnulStructuredDataResponse
261
+ """
262
+ kwargs['_return_http_data_only'] = True
263
+ if '_preload_content' in kwargs:
264
+ message = "Error! Please call the delete_structured_result_data_with_http_info method with `_preload_content` instead and obtain raw data from ApiResponse.raw_data" # noqa: E501
265
+ raise ValueError(message)
266
+ if async_req is not None:
267
+ kwargs['async_req'] = async_req
268
+ return self.delete_structured_result_data_with_http_info(scope, request_body, **kwargs) # noqa: E501
269
+
270
+ @validate_arguments
271
+ def delete_structured_result_data_with_http_info(self, scope : Annotated[constr(strict=True, max_length=64, min_length=1), Field(..., description="The scope from which to delete data items.")], request_body : Annotated[Dict[str, StructuredResultDataId], Field(..., description="The data IDs to delete, each keyed by a unique, ephemeral correlation ID.")], **kwargs) -> ApiResponse: # noqa: E501
272
+ """[EXPERIMENTAL] DeleteStructuredResultData: Delete structured result data # noqa: E501
273
+
274
+ Delete one or more structured result data items from a particular scope. Each item is identified by a unique ID which includes information about its type as well as the exact effective datetime (to the microsecond) at which it entered the system (became valid). In the request, each data item must be keyed by a unique correlation ID. This ID is ephemeral and not stored by LUSID. It serves only to easily identify each data item in the response. The response returns both the collection of successfully deleted data items, as well as those that failed. For each failure, a reason is provided. It is important to check the failed set for any unsuccessful results. # noqa: E501
275
+ This method makes a synchronous HTTP request by default. To make an
276
+ asynchronous HTTP request, please pass async_req=True
277
+
278
+ >>> thread = api.delete_structured_result_data_with_http_info(scope, request_body, async_req=True)
279
+ >>> result = thread.get()
280
+
281
+ :param scope: The scope from which to delete data items. (required)
282
+ :type scope: str
283
+ :param request_body: The data IDs to delete, each keyed by a unique, ephemeral correlation ID. (required)
284
+ :type request_body: Dict[str, StructuredResultDataId]
285
+ :param async_req: Whether to execute the request asynchronously.
286
+ :type async_req: bool, optional
287
+ :param _preload_content: if False, the ApiResponse.data will
288
+ be set to none and raw_data will store the
289
+ HTTP response body without reading/decoding.
290
+ Default is True.
291
+ :type _preload_content: bool, optional
292
+ :param _return_http_data_only: response data instead of ApiResponse
293
+ object with status code, headers, etc
294
+ :type _return_http_data_only: bool, optional
295
+ :param _request_timeout: timeout setting for this request. If one
296
+ number provided, it will be total request
297
+ timeout. It can also be a pair (tuple) of
298
+ (connection, read) timeouts.
299
+ :param _request_auth: set to override the auth_settings for an a single
300
+ request; this effectively ignores the authentication
301
+ in the spec for a single request.
302
+ :type _request_auth: dict, optional
303
+ :type _content_type: string, optional: force content-type for the request
304
+ :return: Returns the result object.
305
+ If the method is called asynchronously,
306
+ returns the request thread.
307
+ :rtype: tuple(AnnulStructuredDataResponse, status_code(int), headers(HTTPHeaderDict))
308
+ """
309
+
310
+ _params = locals()
311
+
312
+ _all_params = [
313
+ 'scope',
314
+ 'request_body'
315
+ ]
316
+ _all_params.extend(
317
+ [
318
+ 'async_req',
319
+ '_return_http_data_only',
320
+ '_preload_content',
321
+ '_request_timeout',
322
+ '_request_auth',
323
+ '_content_type',
324
+ '_headers'
325
+ ]
326
+ )
327
+
328
+ # validate the arguments
329
+ for _key, _val in _params['kwargs'].items():
330
+ if _key not in _all_params:
331
+ raise ApiTypeError(
332
+ "Got an unexpected keyword argument '%s'"
333
+ " to method delete_structured_result_data" % _key
334
+ )
335
+ _params[_key] = _val
336
+ del _params['kwargs']
337
+
338
+ _collection_formats = {}
339
+
340
+ # process the path parameters
341
+ _path_params = {}
342
+ if _params['scope']:
343
+ _path_params['scope'] = _params['scope']
344
+
345
+
346
+ # process the query parameters
347
+ _query_params = []
348
+ # process the header parameters
349
+ _header_params = dict(_params.get('_headers', {}))
350
+ # process the form parameters
351
+ _form_params = []
352
+ _files = {}
353
+ # process the body parameter
354
+ _body_params = None
355
+ if _params['request_body'] is not None:
356
+ _body_params = _params['request_body']
357
+
358
+ # set the HTTP header `Accept`
359
+ _header_params['Accept'] = self.api_client.select_header_accept(
360
+ ['text/plain', 'application/json', 'text/json']) # noqa: E501
361
+
362
+ # set the HTTP header `Content-Type`
363
+ _content_types_list = _params.get('_content_type',
364
+ self.api_client.select_header_content_type(
365
+ ['application/json-patch+json', 'application/json', 'text/json', 'application/*+json']))
366
+ if _content_types_list:
367
+ _header_params['Content-Type'] = _content_types_list
368
+
369
+ # authentication setting
370
+ _auth_settings = ['oauth2'] # noqa: E501
371
+
372
+ _response_types_map = {
373
+ '200': "AnnulStructuredDataResponse",
374
+ '400': "LusidValidationProblemDetails",
196
375
  }
197
376
 
198
377
  return self.api_client.call_api(
199
- '/api/unitresults/datamap/{scope}', 'POST',
200
- path_params,
201
- query_params,
202
- header_params,
203
- body=body_params,
204
- post_params=form_params,
205
- files=local_var_files,
206
- response_types_map=response_types_map,
207
- auth_settings=auth_settings,
208
- async_req=local_var_params.get('async_req'),
209
- _return_http_data_only=local_var_params.get('_return_http_data_only'), # noqa: E501
210
- _preload_content=local_var_params.get('_preload_content', True),
211
- _request_timeout=local_var_params.get('_request_timeout'),
212
- collection_formats=collection_formats,
213
- _request_auth=local_var_params.get('_request_auth'))
214
-
215
- def get_address_key_definitions_for_document(self, scope, code, source, result_type, **kwargs): # noqa: E501
378
+ '/api/unitresults/{scope}/$delete', 'POST',
379
+ _path_params,
380
+ _query_params,
381
+ _header_params,
382
+ body=_body_params,
383
+ post_params=_form_params,
384
+ files=_files,
385
+ response_types_map=_response_types_map,
386
+ auth_settings=_auth_settings,
387
+ async_req=_params.get('async_req'),
388
+ _return_http_data_only=_params.get('_return_http_data_only'), # noqa: E501
389
+ _preload_content=_params.get('_preload_content', True),
390
+ _request_timeout=_params.get('_request_timeout'),
391
+ collection_formats=_collection_formats,
392
+ _request_auth=_params.get('_request_auth'))
393
+
394
+ @overload
395
+ async def get_address_key_definitions_for_document(self, scope : Annotated[constr(strict=True, max_length=256, min_length=1), Field(..., description="The scope of the document for which address key definitions are retrieved.")], code : Annotated[constr(strict=True, max_length=256, min_length=1), Field(..., description="The code of the document for which address key definitions are retrieved.")], source : Annotated[constr(strict=True, max_length=256, min_length=1), Field(..., description="The source of the document for which address key definitions are retrieved.")], result_type : Annotated[StrictStr, Field(..., description="The result type of the document for which address key definitions are retrieved.")], effective_at : Annotated[Optional[StrictStr], Field(description="The effective datetime to query the document for which the address key definitions are retrieved. Defaults to querying the latest version if not specified.")] = None, as_at : Annotated[Optional[datetime], Field(description="The asAt datetime to query the document for which the address key definitions are retrieved. Defaults to querying the latest version if not specified.")] = None, **kwargs) -> ResourceListOfAddressKeyDefinition: # noqa: E501
396
+ ...
397
+
398
+ @overload
399
+ def get_address_key_definitions_for_document(self, scope : Annotated[constr(strict=True, max_length=256, min_length=1), Field(..., description="The scope of the document for which address key definitions are retrieved.")], code : Annotated[constr(strict=True, max_length=256, min_length=1), Field(..., description="The code of the document for which address key definitions are retrieved.")], source : Annotated[constr(strict=True, max_length=256, min_length=1), Field(..., description="The source of the document for which address key definitions are retrieved.")], result_type : Annotated[StrictStr, Field(..., description="The result type of the document for which address key definitions are retrieved.")], effective_at : Annotated[Optional[StrictStr], Field(description="The effective datetime to query the document for which the address key definitions are retrieved. Defaults to querying the latest version if not specified.")] = None, as_at : Annotated[Optional[datetime], Field(description="The asAt datetime to query the document for which the address key definitions are retrieved. Defaults to querying the latest version if not specified.")] = None, async_req: Optional[bool]=True, **kwargs) -> ResourceListOfAddressKeyDefinition: # noqa: E501
400
+ ...
401
+
402
+ @validate_arguments
403
+ def get_address_key_definitions_for_document(self, scope : Annotated[constr(strict=True, max_length=256, min_length=1), Field(..., description="The scope of the document for which address key definitions are retrieved.")], code : Annotated[constr(strict=True, max_length=256, min_length=1), Field(..., description="The code of the document for which address key definitions are retrieved.")], source : Annotated[constr(strict=True, max_length=256, min_length=1), Field(..., description="The source of the document for which address key definitions are retrieved.")], result_type : Annotated[StrictStr, Field(..., description="The result type of the document for which address key definitions are retrieved.")], effective_at : Annotated[Optional[StrictStr], Field(description="The effective datetime to query the document for which the address key definitions are retrieved. Defaults to querying the latest version if not specified.")] = None, as_at : Annotated[Optional[datetime], Field(description="The asAt datetime to query the document for which the address key definitions are retrieved. Defaults to querying the latest version if not specified.")] = None, async_req: Optional[bool]=None, **kwargs) -> Union[ResourceListOfAddressKeyDefinition, Awaitable[ResourceListOfAddressKeyDefinition]]: # noqa: E501
216
404
  """[EARLY ACCESS] GetAddressKeyDefinitionsForDocument: Get AddressKeyDefinitions for a virtual document. # noqa: E501
217
405
 
218
406
  For a given virtual document retrieve all the address key definitions that are in use. # noqa: E501
219
407
  This method makes a synchronous HTTP request by default. To make an
220
408
  asynchronous HTTP request, please pass async_req=True
221
409
 
222
- >>> thread = api.get_address_key_definitions_for_document(scope, code, source, result_type, async_req=True)
410
+ >>> thread = api.get_address_key_definitions_for_document(scope, code, source, result_type, effective_at, as_at, async_req=True)
223
411
  >>> result = thread.get()
224
412
 
225
413
  :param scope: The scope of the document for which address key definitions are retrieved. (required)
@@ -236,30 +424,32 @@ class StructuredResultDataApi(object):
236
424
  :type as_at: datetime
237
425
  :param async_req: Whether to execute the request asynchronously.
238
426
  :type async_req: bool, optional
239
- :param _preload_content: if False, the urllib3.HTTPResponse object will
240
- be returned without reading/decoding response
241
- data. Default is True.
242
- :type _preload_content: bool, optional
243
- :param _request_timeout: timeout setting for this request. If one
244
- number provided, it will be total request
245
- timeout. It can also be a pair (tuple) of
246
- (connection, read) timeouts.
427
+ :param _request_timeout: timeout setting for this request.
428
+ If one number provided, it will be total request
429
+ timeout. It can also be a pair (tuple) of
430
+ (connection, read) timeouts.
247
431
  :return: Returns the result object.
248
432
  If the method is called asynchronously,
249
433
  returns the request thread.
250
434
  :rtype: ResourceListOfAddressKeyDefinition
251
435
  """
252
436
  kwargs['_return_http_data_only'] = True
253
- return self.get_address_key_definitions_for_document_with_http_info(scope, code, source, result_type, **kwargs) # noqa: E501
254
-
255
- def get_address_key_definitions_for_document_with_http_info(self, scope, code, source, result_type, **kwargs): # noqa: E501
437
+ if '_preload_content' in kwargs:
438
+ message = "Error! Please call the get_address_key_definitions_for_document_with_http_info method with `_preload_content` instead and obtain raw data from ApiResponse.raw_data" # noqa: E501
439
+ raise ValueError(message)
440
+ if async_req is not None:
441
+ kwargs['async_req'] = async_req
442
+ return self.get_address_key_definitions_for_document_with_http_info(scope, code, source, result_type, effective_at, as_at, **kwargs) # noqa: E501
443
+
444
+ @validate_arguments
445
+ def get_address_key_definitions_for_document_with_http_info(self, scope : Annotated[constr(strict=True, max_length=256, min_length=1), Field(..., description="The scope of the document for which address key definitions are retrieved.")], code : Annotated[constr(strict=True, max_length=256, min_length=1), Field(..., description="The code of the document for which address key definitions are retrieved.")], source : Annotated[constr(strict=True, max_length=256, min_length=1), Field(..., description="The source of the document for which address key definitions are retrieved.")], result_type : Annotated[StrictStr, Field(..., description="The result type of the document for which address key definitions are retrieved.")], effective_at : Annotated[Optional[StrictStr], Field(description="The effective datetime to query the document for which the address key definitions are retrieved. Defaults to querying the latest version if not specified.")] = None, as_at : Annotated[Optional[datetime], Field(description="The asAt datetime to query the document for which the address key definitions are retrieved. Defaults to querying the latest version if not specified.")] = None, **kwargs) -> ApiResponse: # noqa: E501
256
446
  """[EARLY ACCESS] GetAddressKeyDefinitionsForDocument: Get AddressKeyDefinitions for a virtual document. # noqa: E501
257
447
 
258
448
  For a given virtual document retrieve all the address key definitions that are in use. # noqa: E501
259
449
  This method makes a synchronous HTTP request by default. To make an
260
450
  asynchronous HTTP request, please pass async_req=True
261
451
 
262
- >>> thread = api.get_address_key_definitions_for_document_with_http_info(scope, code, source, result_type, async_req=True)
452
+ >>> thread = api.get_address_key_definitions_for_document_with_http_info(scope, code, source, result_type, effective_at, as_at, async_req=True)
263
453
  >>> result = thread.get()
264
454
 
265
455
  :param scope: The scope of the document for which address key definitions are retrieved. (required)
@@ -276,13 +466,14 @@ class StructuredResultDataApi(object):
276
466
  :type as_at: datetime
277
467
  :param async_req: Whether to execute the request asynchronously.
278
468
  :type async_req: bool, optional
279
- :param _return_http_data_only: response data without head status code
280
- and headers
281
- :type _return_http_data_only: bool, optional
282
- :param _preload_content: if False, the urllib3.HTTPResponse object will
283
- be returned without reading/decoding response
284
- data. Default is True.
469
+ :param _preload_content: if False, the ApiResponse.data will
470
+ be set to none and raw_data will store the
471
+ HTTP response body without reading/decoding.
472
+ Default is True.
285
473
  :type _preload_content: bool, optional
474
+ :param _return_http_data_only: response data instead of ApiResponse
475
+ object with status code, headers, etc
476
+ :type _return_http_data_only: bool, optional
286
477
  :param _request_timeout: timeout setting for this request. If one
287
478
  number provided, it will be total request
288
479
  timeout. It can also be a pair (tuple) of
@@ -291,15 +482,16 @@ class StructuredResultDataApi(object):
291
482
  request; this effectively ignores the authentication
292
483
  in the spec for a single request.
293
484
  :type _request_auth: dict, optional
294
- :return: Returns the result object, the HTTP status code, and the headers.
485
+ :type _content_type: string, optional: force content-type for the request
486
+ :return: Returns the result object.
295
487
  If the method is called asynchronously,
296
488
  returns the request thread.
297
- :rtype: (ResourceListOfAddressKeyDefinition, int, HTTPHeaderDict)
489
+ :rtype: tuple(ResourceListOfAddressKeyDefinition, status_code(int), headers(HTTPHeaderDict))
298
490
  """
299
491
 
300
- local_var_params = locals()
492
+ _params = locals()
301
493
 
302
- all_params = [
494
+ _all_params = [
303
495
  'scope',
304
496
  'code',
305
497
  'source',
@@ -307,189 +499,333 @@ class StructuredResultDataApi(object):
307
499
  'effective_at',
308
500
  'as_at'
309
501
  ]
310
- all_params.extend(
502
+ _all_params.extend(
311
503
  [
312
504
  'async_req',
313
505
  '_return_http_data_only',
314
506
  '_preload_content',
315
507
  '_request_timeout',
316
508
  '_request_auth',
509
+ '_content_type',
317
510
  '_headers'
318
511
  ]
319
512
  )
320
513
 
321
- for key, val in six.iteritems(local_var_params['kwargs']):
322
- if key not in all_params:
514
+ # validate the arguments
515
+ for _key, _val in _params['kwargs'].items():
516
+ if _key not in _all_params:
323
517
  raise ApiTypeError(
324
518
  "Got an unexpected keyword argument '%s'"
325
- " to method get_address_key_definitions_for_document" % key
519
+ " to method get_address_key_definitions_for_document" % _key
326
520
  )
327
- local_var_params[key] = val
328
- del local_var_params['kwargs']
329
- # verify the required parameter 'scope' is set
330
- if self.api_client.client_side_validation and ('scope' not in local_var_params or # noqa: E501
331
- local_var_params['scope'] is None): # noqa: E501
332
- raise ApiValueError("Missing the required parameter `scope` when calling `get_address_key_definitions_for_document`") # noqa: E501
333
- # verify the required parameter 'code' is set
334
- if self.api_client.client_side_validation and ('code' not in local_var_params or # noqa: E501
335
- local_var_params['code'] is None): # noqa: E501
336
- raise ApiValueError("Missing the required parameter `code` when calling `get_address_key_definitions_for_document`") # noqa: E501
337
- # verify the required parameter 'source' is set
338
- if self.api_client.client_side_validation and ('source' not in local_var_params or # noqa: E501
339
- local_var_params['source'] is None): # noqa: E501
340
- raise ApiValueError("Missing the required parameter `source` when calling `get_address_key_definitions_for_document`") # noqa: E501
341
- # verify the required parameter 'result_type' is set
342
- if self.api_client.client_side_validation and ('result_type' not in local_var_params or # noqa: E501
343
- local_var_params['result_type'] is None): # noqa: E501
344
- raise ApiValueError("Missing the required parameter `result_type` when calling `get_address_key_definitions_for_document`") # noqa: E501
345
-
346
- if self.api_client.client_side_validation and ('scope' in local_var_params and # noqa: E501
347
- len(local_var_params['scope']) > 256): # noqa: E501
348
- raise ApiValueError("Invalid value for parameter `scope` when calling `get_address_key_definitions_for_document`, length must be less than or equal to `256`") # noqa: E501
349
- if self.api_client.client_side_validation and ('scope' in local_var_params and # noqa: E501
350
- len(local_var_params['scope']) < 1): # noqa: E501
351
- raise ApiValueError("Invalid value for parameter `scope` when calling `get_address_key_definitions_for_document`, length must be greater than or equal to `1`") # noqa: E501
352
- if self.api_client.client_side_validation and 'scope' in local_var_params and not re.search(r'^[a-zA-Z0-9\-_]+$', local_var_params['scope']): # noqa: E501
353
- raise ApiValueError("Invalid value for parameter `scope` when calling `get_address_key_definitions_for_document`, must conform to the pattern `/^[a-zA-Z0-9\-_]+$/`") # noqa: E501
354
- if self.api_client.client_side_validation and ('code' in local_var_params and # noqa: E501
355
- len(local_var_params['code']) > 256): # noqa: E501
356
- raise ApiValueError("Invalid value for parameter `code` when calling `get_address_key_definitions_for_document`, length must be less than or equal to `256`") # noqa: E501
357
- if self.api_client.client_side_validation and ('code' in local_var_params and # noqa: E501
358
- len(local_var_params['code']) < 1): # noqa: E501
359
- raise ApiValueError("Invalid value for parameter `code` when calling `get_address_key_definitions_for_document`, length must be greater than or equal to `1`") # noqa: E501
360
- if self.api_client.client_side_validation and 'code' in local_var_params and not re.search(r'^[a-zA-Z0-9\-_]+$', local_var_params['code']): # noqa: E501
361
- raise ApiValueError("Invalid value for parameter `code` when calling `get_address_key_definitions_for_document`, must conform to the pattern `/^[a-zA-Z0-9\-_]+$/`") # noqa: E501
362
- if self.api_client.client_side_validation and ('source' in local_var_params and # noqa: E501
363
- len(local_var_params['source']) > 256): # noqa: E501
364
- raise ApiValueError("Invalid value for parameter `source` when calling `get_address_key_definitions_for_document`, length must be less than or equal to `256`") # noqa: E501
365
- if self.api_client.client_side_validation and ('source' in local_var_params and # noqa: E501
366
- len(local_var_params['source']) < 1): # noqa: E501
367
- raise ApiValueError("Invalid value for parameter `source` when calling `get_address_key_definitions_for_document`, length must be greater than or equal to `1`") # noqa: E501
368
- if self.api_client.client_side_validation and 'source' in local_var_params and not re.search(r'^[a-zA-Z0-9\-_]+$', local_var_params['source']): # noqa: E501
369
- raise ApiValueError("Invalid value for parameter `source` when calling `get_address_key_definitions_for_document`, must conform to the pattern `/^[a-zA-Z0-9\-_]+$/`") # noqa: E501
370
- collection_formats = {}
371
-
372
- path_params = {}
373
- if 'scope' in local_var_params:
374
- path_params['scope'] = local_var_params['scope'] # noqa: E501
375
- if 'code' in local_var_params:
376
- path_params['code'] = local_var_params['code'] # noqa: E501
377
- if 'source' in local_var_params:
378
- path_params['source'] = local_var_params['source'] # noqa: E501
379
- if 'result_type' in local_var_params:
380
- path_params['resultType'] = local_var_params['result_type'] # noqa: E501
381
-
382
- query_params = []
383
- if 'effective_at' in local_var_params and local_var_params['effective_at'] is not None: # noqa: E501
384
- query_params.append(('effectiveAt', local_var_params['effective_at'])) # noqa: E501
385
- if 'as_at' in local_var_params and local_var_params['as_at'] is not None: # noqa: E501
386
- query_params.append(('asAt', local_var_params['as_at'])) # noqa: E501
387
-
388
- header_params = dict(local_var_params.get('_headers', {}))
389
-
390
- form_params = []
391
- local_var_files = {}
392
-
393
- body_params = None
394
- # HTTP header `Accept`
395
- header_params['Accept'] = self.api_client.select_header_accept(
521
+ _params[_key] = _val
522
+ del _params['kwargs']
523
+
524
+ _collection_formats = {}
525
+
526
+ # process the path parameters
527
+ _path_params = {}
528
+ if _params['scope']:
529
+ _path_params['scope'] = _params['scope']
530
+
531
+ if _params['code']:
532
+ _path_params['code'] = _params['code']
533
+
534
+ if _params['source']:
535
+ _path_params['source'] = _params['source']
536
+
537
+ if _params['result_type']:
538
+ _path_params['resultType'] = _params['result_type']
539
+
540
+
541
+ # process the query parameters
542
+ _query_params = []
543
+ if _params.get('effective_at') is not None: # noqa: E501
544
+ _query_params.append(('effectiveAt', _params['effective_at']))
545
+
546
+ if _params.get('as_at') is not None: # noqa: E501
547
+ if isinstance(_params['as_at'], datetime):
548
+ _query_params.append(('asAt', _params['as_at'].strftime(self.api_client.configuration.datetime_format)))
549
+ else:
550
+ _query_params.append(('asAt', _params['as_at']))
551
+
552
+ # process the header parameters
553
+ _header_params = dict(_params.get('_headers', {}))
554
+ # process the form parameters
555
+ _form_params = []
556
+ _files = {}
557
+ # process the body parameter
558
+ _body_params = None
559
+ # set the HTTP header `Accept`
560
+ _header_params['Accept'] = self.api_client.select_header_accept(
396
561
  ['text/plain', 'application/json', 'text/json']) # noqa: E501
397
562
 
398
- header_params['Accept-Encoding'] = "gzip, deflate, br"
563
+ # authentication setting
564
+ _auth_settings = ['oauth2'] # noqa: E501
565
+
566
+ _response_types_map = {
567
+ '200': "ResourceListOfAddressKeyDefinition",
568
+ '400': "LusidValidationProblemDetails",
569
+ }
570
+
571
+ return self.api_client.call_api(
572
+ '/api/unitresults/virtualdocument/{scope}/{code}/{source}/{resultType}/addresskeydefinitions', 'GET',
573
+ _path_params,
574
+ _query_params,
575
+ _header_params,
576
+ body=_body_params,
577
+ post_params=_form_params,
578
+ files=_files,
579
+ response_types_map=_response_types_map,
580
+ auth_settings=_auth_settings,
581
+ async_req=_params.get('async_req'),
582
+ _return_http_data_only=_params.get('_return_http_data_only'), # noqa: E501
583
+ _preload_content=_params.get('_preload_content', True),
584
+ _request_timeout=_params.get('_request_timeout'),
585
+ collection_formats=_collection_formats,
586
+ _request_auth=_params.get('_request_auth'))
587
+
588
+ @overload
589
+ async def get_data_map(self, scope : Annotated[constr(strict=True, max_length=64, min_length=1), Field(..., description="The scope from which to retrieve data maps.")], request_body : Annotated[Dict[str, DataMapKey], Field(..., description="The data map keys to look up, each keyed by a unique, ephemeral correlation ID.")], **kwargs) -> GetDataMapResponse: # noqa: E501
590
+ ...
591
+
592
+ @overload
593
+ def get_data_map(self, scope : Annotated[constr(strict=True, max_length=64, min_length=1), Field(..., description="The scope from which to retrieve data maps.")], request_body : Annotated[Dict[str, DataMapKey], Field(..., description="The data map keys to look up, each keyed by a unique, ephemeral correlation ID.")], async_req: Optional[bool]=True, **kwargs) -> GetDataMapResponse: # noqa: E501
594
+ ...
595
+
596
+ @validate_arguments
597
+ def get_data_map(self, scope : Annotated[constr(strict=True, max_length=64, min_length=1), Field(..., description="The scope from which to retrieve data maps.")], request_body : Annotated[Dict[str, DataMapKey], Field(..., description="The data map keys to look up, each keyed by a unique, ephemeral correlation ID.")], async_req: Optional[bool]=None, **kwargs) -> Union[GetDataMapResponse, Awaitable[GetDataMapResponse]]: # noqa: E501
598
+ """[EXPERIMENTAL] GetDataMap: Get data map # noqa: E501
599
+
600
+ Retrieve one or more structured result store address definition data maps from a particular scope. Each data map can be identified by its invariant key, which can be thought of as a permanent URL. For each ID, LUSID returns the most recently matched item. In the request, each data map must be keyed by a unique correlation ID. This ID is ephemeral and not stored by LUSID. It serves only to easily identify each data map in the response. The response returns three collections. The first contains successfully retrieved data maps. The second contains those with a valid identifier but that could not be found. The third contains those that failed because LUSID could not construct a valid identifier from the request. For the IDs that failed to resolve or could not be found, a reason is provided. It is important to check the failed sets for any unsuccessful results. # noqa: E501
601
+ This method makes a synchronous HTTP request by default. To make an
602
+ asynchronous HTTP request, please pass async_req=True
603
+
604
+ >>> thread = api.get_data_map(scope, request_body, async_req=True)
605
+ >>> result = thread.get()
606
+
607
+ :param scope: The scope from which to retrieve data maps. (required)
608
+ :type scope: str
609
+ :param request_body: The data map keys to look up, each keyed by a unique, ephemeral correlation ID. (required)
610
+ :type request_body: Dict[str, DataMapKey]
611
+ :param async_req: Whether to execute the request asynchronously.
612
+ :type async_req: bool, optional
613
+ :param _request_timeout: timeout setting for this request.
614
+ If one number provided, it will be total request
615
+ timeout. It can also be a pair (tuple) of
616
+ (connection, read) timeouts.
617
+ :return: Returns the result object.
618
+ If the method is called asynchronously,
619
+ returns the request thread.
620
+ :rtype: GetDataMapResponse
621
+ """
622
+ kwargs['_return_http_data_only'] = True
623
+ if '_preload_content' in kwargs:
624
+ message = "Error! Please call the get_data_map_with_http_info method with `_preload_content` instead and obtain raw data from ApiResponse.raw_data" # noqa: E501
625
+ raise ValueError(message)
626
+ if async_req is not None:
627
+ kwargs['async_req'] = async_req
628
+ return self.get_data_map_with_http_info(scope, request_body, **kwargs) # noqa: E501
629
+
630
+ @validate_arguments
631
+ def get_data_map_with_http_info(self, scope : Annotated[constr(strict=True, max_length=64, min_length=1), Field(..., description="The scope from which to retrieve data maps.")], request_body : Annotated[Dict[str, DataMapKey], Field(..., description="The data map keys to look up, each keyed by a unique, ephemeral correlation ID.")], **kwargs) -> ApiResponse: # noqa: E501
632
+ """[EXPERIMENTAL] GetDataMap: Get data map # noqa: E501
633
+
634
+ Retrieve one or more structured result store address definition data maps from a particular scope. Each data map can be identified by its invariant key, which can be thought of as a permanent URL. For each ID, LUSID returns the most recently matched item. In the request, each data map must be keyed by a unique correlation ID. This ID is ephemeral and not stored by LUSID. It serves only to easily identify each data map in the response. The response returns three collections. The first contains successfully retrieved data maps. The second contains those with a valid identifier but that could not be found. The third contains those that failed because LUSID could not construct a valid identifier from the request. For the IDs that failed to resolve or could not be found, a reason is provided. It is important to check the failed sets for any unsuccessful results. # noqa: E501
635
+ This method makes a synchronous HTTP request by default. To make an
636
+ asynchronous HTTP request, please pass async_req=True
637
+
638
+ >>> thread = api.get_data_map_with_http_info(scope, request_body, async_req=True)
639
+ >>> result = thread.get()
640
+
641
+ :param scope: The scope from which to retrieve data maps. (required)
642
+ :type scope: str
643
+ :param request_body: The data map keys to look up, each keyed by a unique, ephemeral correlation ID. (required)
644
+ :type request_body: Dict[str, DataMapKey]
645
+ :param async_req: Whether to execute the request asynchronously.
646
+ :type async_req: bool, optional
647
+ :param _preload_content: if False, the ApiResponse.data will
648
+ be set to none and raw_data will store the
649
+ HTTP response body without reading/decoding.
650
+ Default is True.
651
+ :type _preload_content: bool, optional
652
+ :param _return_http_data_only: response data instead of ApiResponse
653
+ object with status code, headers, etc
654
+ :type _return_http_data_only: bool, optional
655
+ :param _request_timeout: timeout setting for this request. If one
656
+ number provided, it will be total request
657
+ timeout. It can also be a pair (tuple) of
658
+ (connection, read) timeouts.
659
+ :param _request_auth: set to override the auth_settings for an a single
660
+ request; this effectively ignores the authentication
661
+ in the spec for a single request.
662
+ :type _request_auth: dict, optional
663
+ :type _content_type: string, optional: force content-type for the request
664
+ :return: Returns the result object.
665
+ If the method is called asynchronously,
666
+ returns the request thread.
667
+ :rtype: tuple(GetDataMapResponse, status_code(int), headers(HTTPHeaderDict))
668
+ """
669
+
670
+ _params = locals()
671
+
672
+ _all_params = [
673
+ 'scope',
674
+ 'request_body'
675
+ ]
676
+ _all_params.extend(
677
+ [
678
+ 'async_req',
679
+ '_return_http_data_only',
680
+ '_preload_content',
681
+ '_request_timeout',
682
+ '_request_auth',
683
+ '_content_type',
684
+ '_headers'
685
+ ]
686
+ )
399
687
 
688
+ # validate the arguments
689
+ for _key, _val in _params['kwargs'].items():
690
+ if _key not in _all_params:
691
+ raise ApiTypeError(
692
+ "Got an unexpected keyword argument '%s'"
693
+ " to method get_data_map" % _key
694
+ )
695
+ _params[_key] = _val
696
+ del _params['kwargs']
697
+
698
+ _collection_formats = {}
699
+
700
+ # process the path parameters
701
+ _path_params = {}
702
+ if _params['scope']:
703
+ _path_params['scope'] = _params['scope']
704
+
705
+
706
+ # process the query parameters
707
+ _query_params = []
708
+ # process the header parameters
709
+ _header_params = dict(_params.get('_headers', {}))
710
+ # process the form parameters
711
+ _form_params = []
712
+ _files = {}
713
+ # process the body parameter
714
+ _body_params = None
715
+ if _params['request_body'] is not None:
716
+ _body_params = _params['request_body']
717
+
718
+ # set the HTTP header `Accept`
719
+ _header_params['Accept'] = self.api_client.select_header_accept(
720
+ ['text/plain', 'application/json', 'text/json']) # noqa: E501
400
721
 
401
- # set the LUSID header
402
- header_params['X-LUSID-SDK-Language'] = 'Python'
403
- header_params['X-LUSID-SDK-Version'] = '1.1.257'
722
+ # set the HTTP header `Content-Type`
723
+ _content_types_list = _params.get('_content_type',
724
+ self.api_client.select_header_content_type(
725
+ ['application/json-patch+json', 'application/json', 'text/json', 'application/*+json']))
726
+ if _content_types_list:
727
+ _header_params['Content-Type'] = _content_types_list
404
728
 
405
- # Authentication setting
406
- auth_settings = ['oauth2'] # noqa: E501
729
+ # authentication setting
730
+ _auth_settings = ['oauth2'] # noqa: E501
407
731
 
408
- response_types_map = {
409
- 200: "ResourceListOfAddressKeyDefinition",
410
- 400: "LusidValidationProblemDetails",
732
+ _response_types_map = {
733
+ '200': "GetDataMapResponse",
734
+ '400': "LusidValidationProblemDetails",
411
735
  }
412
736
 
413
737
  return self.api_client.call_api(
414
- '/api/unitresults/virtualdocument/{scope}/{code}/{source}/{resultType}/addresskeydefinitions', 'GET',
415
- path_params,
416
- query_params,
417
- header_params,
418
- body=body_params,
419
- post_params=form_params,
420
- files=local_var_files,
421
- response_types_map=response_types_map,
422
- auth_settings=auth_settings,
423
- async_req=local_var_params.get('async_req'),
424
- _return_http_data_only=local_var_params.get('_return_http_data_only'), # noqa: E501
425
- _preload_content=local_var_params.get('_preload_content', True),
426
- _request_timeout=local_var_params.get('_request_timeout'),
427
- collection_formats=collection_formats,
428
- _request_auth=local_var_params.get('_request_auth'))
429
-
430
- def get_structured_result_data(self, scope, request_body, **kwargs): # noqa: E501
431
- """GetStructuredResultData: Get structured result data # noqa: E501
738
+ '/api/unitresults/datamap/{scope}/$get', 'POST',
739
+ _path_params,
740
+ _query_params,
741
+ _header_params,
742
+ body=_body_params,
743
+ post_params=_form_params,
744
+ files=_files,
745
+ response_types_map=_response_types_map,
746
+ auth_settings=_auth_settings,
747
+ async_req=_params.get('async_req'),
748
+ _return_http_data_only=_params.get('_return_http_data_only'), # noqa: E501
749
+ _preload_content=_params.get('_preload_content', True),
750
+ _request_timeout=_params.get('_request_timeout'),
751
+ collection_formats=_collection_formats,
752
+ _request_auth=_params.get('_request_auth'))
753
+
754
+ @overload
755
+ async def get_structured_result_data(self, scope : Annotated[constr(strict=True, max_length=64, min_length=1), Field(..., description="The scope from which to retrieve data items.")], request_body : Annotated[Dict[str, StructuredResultDataId], Field(..., description="The time invariant set of structured data identifiers to retrieve, keyed by a unique, ephemeral correlation ID.")], as_at : Annotated[Optional[datetime], Field(description="The asAt datetime at which to retrieve the structured result data. Defaults to returning the latest version if not specified.")] = None, max_age : Annotated[Optional[StrictStr], Field(description="The duration of the look-back window in ISO8601 time interval format, for example 'P1Y2M3DT4H30M' (1 year, 2 months, 3 days, 4 hours and 30 minutes). This is subtracted from the provided effectiveAt datetime to generate a effective datetime window inside which a data item must exist to be retrieved.")] = None, **kwargs) -> GetStructuredResultDataResponse: # noqa: E501
756
+ ...
757
+
758
+ @overload
759
+ def get_structured_result_data(self, scope : Annotated[constr(strict=True, max_length=64, min_length=1), Field(..., description="The scope from which to retrieve data items.")], request_body : Annotated[Dict[str, StructuredResultDataId], Field(..., description="The time invariant set of structured data identifiers to retrieve, keyed by a unique, ephemeral correlation ID.")], as_at : Annotated[Optional[datetime], Field(description="The asAt datetime at which to retrieve the structured result data. Defaults to returning the latest version if not specified.")] = None, max_age : Annotated[Optional[StrictStr], Field(description="The duration of the look-back window in ISO8601 time interval format, for example 'P1Y2M3DT4H30M' (1 year, 2 months, 3 days, 4 hours and 30 minutes). This is subtracted from the provided effectiveAt datetime to generate a effective datetime window inside which a data item must exist to be retrieved.")] = None, async_req: Optional[bool]=True, **kwargs) -> GetStructuredResultDataResponse: # noqa: E501
760
+ ...
761
+
762
+ @validate_arguments
763
+ def get_structured_result_data(self, scope : Annotated[constr(strict=True, max_length=64, min_length=1), Field(..., description="The scope from which to retrieve data items.")], request_body : Annotated[Dict[str, StructuredResultDataId], Field(..., description="The time invariant set of structured data identifiers to retrieve, keyed by a unique, ephemeral correlation ID.")], as_at : Annotated[Optional[datetime], Field(description="The asAt datetime at which to retrieve the structured result data. Defaults to returning the latest version if not specified.")] = None, max_age : Annotated[Optional[StrictStr], Field(description="The duration of the look-back window in ISO8601 time interval format, for example 'P1Y2M3DT4H30M' (1 year, 2 months, 3 days, 4 hours and 30 minutes). This is subtracted from the provided effectiveAt datetime to generate a effective datetime window inside which a data item must exist to be retrieved.")] = None, async_req: Optional[bool]=None, **kwargs) -> Union[GetStructuredResultDataResponse, Awaitable[GetStructuredResultDataResponse]]: # noqa: E501
764
+ """[EXPERIMENTAL] GetStructuredResultData: Get structured result data # noqa: E501
432
765
 
433
766
  Retrieve one or more structured result data items from a particular scope. Each item can be identified by its time invariant structured result data identifier. For each ID, LUSID returns the most recently matched item with respect to the provided (or default) effective datetime. An optional maximum age range window can be specified to control how far back to look from the specified effective datetime. LUSID returns the most recent item within this window. In the request, each data item must be keyed by a unique correlation ID. This ID is ephemeral and not stored by LUSID. It serves only to easily identify each data item in the response. The response returns three collections. The first contains successfully retrieved data items. The second contains those with a valid identifier but that could not be found. The third contains those that failed because LUSID could not construct a valid identifier from the request. For the IDs that failed to resolve or could not be found, a reason is provided. It is important to check the failed sets for any unsuccessful results. # noqa: E501
434
767
  This method makes a synchronous HTTP request by default. To make an
435
768
  asynchronous HTTP request, please pass async_req=True
436
769
 
437
- >>> thread = api.get_structured_result_data(scope, request_body, async_req=True)
770
+ >>> thread = api.get_structured_result_data(scope, request_body, as_at, max_age, async_req=True)
438
771
  >>> result = thread.get()
439
772
 
440
773
  :param scope: The scope from which to retrieve data items. (required)
441
774
  :type scope: str
442
775
  :param request_body: The time invariant set of structured data identifiers to retrieve, keyed by a unique, ephemeral correlation ID. (required)
443
- :type request_body: dict(str, StructuredResultDataId)
776
+ :type request_body: Dict[str, StructuredResultDataId]
444
777
  :param as_at: The asAt datetime at which to retrieve the structured result data. Defaults to returning the latest version if not specified.
445
778
  :type as_at: datetime
446
779
  :param max_age: The duration of the look-back window in ISO8601 time interval format, for example 'P1Y2M3DT4H30M' (1 year, 2 months, 3 days, 4 hours and 30 minutes). This is subtracted from the provided effectiveAt datetime to generate a effective datetime window inside which a data item must exist to be retrieved.
447
780
  :type max_age: str
448
781
  :param async_req: Whether to execute the request asynchronously.
449
782
  :type async_req: bool, optional
450
- :param _preload_content: if False, the urllib3.HTTPResponse object will
451
- be returned without reading/decoding response
452
- data. Default is True.
453
- :type _preload_content: bool, optional
454
- :param _request_timeout: timeout setting for this request. If one
455
- number provided, it will be total request
456
- timeout. It can also be a pair (tuple) of
457
- (connection, read) timeouts.
783
+ :param _request_timeout: timeout setting for this request.
784
+ If one number provided, it will be total request
785
+ timeout. It can also be a pair (tuple) of
786
+ (connection, read) timeouts.
458
787
  :return: Returns the result object.
459
788
  If the method is called asynchronously,
460
789
  returns the request thread.
461
790
  :rtype: GetStructuredResultDataResponse
462
791
  """
463
792
  kwargs['_return_http_data_only'] = True
464
- return self.get_structured_result_data_with_http_info(scope, request_body, **kwargs) # noqa: E501
793
+ if '_preload_content' in kwargs:
794
+ message = "Error! Please call the get_structured_result_data_with_http_info method with `_preload_content` instead and obtain raw data from ApiResponse.raw_data" # noqa: E501
795
+ raise ValueError(message)
796
+ if async_req is not None:
797
+ kwargs['async_req'] = async_req
798
+ return self.get_structured_result_data_with_http_info(scope, request_body, as_at, max_age, **kwargs) # noqa: E501
465
799
 
466
- def get_structured_result_data_with_http_info(self, scope, request_body, **kwargs): # noqa: E501
467
- """GetStructuredResultData: Get structured result data # noqa: E501
800
+ @validate_arguments
801
+ def get_structured_result_data_with_http_info(self, scope : Annotated[constr(strict=True, max_length=64, min_length=1), Field(..., description="The scope from which to retrieve data items.")], request_body : Annotated[Dict[str, StructuredResultDataId], Field(..., description="The time invariant set of structured data identifiers to retrieve, keyed by a unique, ephemeral correlation ID.")], as_at : Annotated[Optional[datetime], Field(description="The asAt datetime at which to retrieve the structured result data. Defaults to returning the latest version if not specified.")] = None, max_age : Annotated[Optional[StrictStr], Field(description="The duration of the look-back window in ISO8601 time interval format, for example 'P1Y2M3DT4H30M' (1 year, 2 months, 3 days, 4 hours and 30 minutes). This is subtracted from the provided effectiveAt datetime to generate a effective datetime window inside which a data item must exist to be retrieved.")] = None, **kwargs) -> ApiResponse: # noqa: E501
802
+ """[EXPERIMENTAL] GetStructuredResultData: Get structured result data # noqa: E501
468
803
 
469
804
  Retrieve one or more structured result data items from a particular scope. Each item can be identified by its time invariant structured result data identifier. For each ID, LUSID returns the most recently matched item with respect to the provided (or default) effective datetime. An optional maximum age range window can be specified to control how far back to look from the specified effective datetime. LUSID returns the most recent item within this window. In the request, each data item must be keyed by a unique correlation ID. This ID is ephemeral and not stored by LUSID. It serves only to easily identify each data item in the response. The response returns three collections. The first contains successfully retrieved data items. The second contains those with a valid identifier but that could not be found. The third contains those that failed because LUSID could not construct a valid identifier from the request. For the IDs that failed to resolve or could not be found, a reason is provided. It is important to check the failed sets for any unsuccessful results. # noqa: E501
470
805
  This method makes a synchronous HTTP request by default. To make an
471
806
  asynchronous HTTP request, please pass async_req=True
472
807
 
473
- >>> thread = api.get_structured_result_data_with_http_info(scope, request_body, async_req=True)
808
+ >>> thread = api.get_structured_result_data_with_http_info(scope, request_body, as_at, max_age, async_req=True)
474
809
  >>> result = thread.get()
475
810
 
476
811
  :param scope: The scope from which to retrieve data items. (required)
477
812
  :type scope: str
478
813
  :param request_body: The time invariant set of structured data identifiers to retrieve, keyed by a unique, ephemeral correlation ID. (required)
479
- :type request_body: dict(str, StructuredResultDataId)
814
+ :type request_body: Dict[str, StructuredResultDataId]
480
815
  :param as_at: The asAt datetime at which to retrieve the structured result data. Defaults to returning the latest version if not specified.
481
816
  :type as_at: datetime
482
817
  :param max_age: The duration of the look-back window in ISO8601 time interval format, for example 'P1Y2M3DT4H30M' (1 year, 2 months, 3 days, 4 hours and 30 minutes). This is subtracted from the provided effectiveAt datetime to generate a effective datetime window inside which a data item must exist to be retrieved.
483
818
  :type max_age: str
484
819
  :param async_req: Whether to execute the request asynchronously.
485
820
  :type async_req: bool, optional
486
- :param _return_http_data_only: response data without head status code
487
- and headers
488
- :type _return_http_data_only: bool, optional
489
- :param _preload_content: if False, the urllib3.HTTPResponse object will
490
- be returned without reading/decoding response
491
- data. Default is True.
821
+ :param _preload_content: if False, the ApiResponse.data will
822
+ be set to none and raw_data will store the
823
+ HTTP response body without reading/decoding.
824
+ Default is True.
492
825
  :type _preload_content: bool, optional
826
+ :param _return_http_data_only: response data instead of ApiResponse
827
+ object with status code, headers, etc
828
+ :type _return_http_data_only: bool, optional
493
829
  :param _request_timeout: timeout setting for this request. If one
494
830
  number provided, it will be total request
495
831
  timeout. It can also be a pair (tuple) of
@@ -498,123 +834,302 @@ class StructuredResultDataApi(object):
498
834
  request; this effectively ignores the authentication
499
835
  in the spec for a single request.
500
836
  :type _request_auth: dict, optional
501
- :return: Returns the result object, the HTTP status code, and the headers.
837
+ :type _content_type: string, optional: force content-type for the request
838
+ :return: Returns the result object.
502
839
  If the method is called asynchronously,
503
840
  returns the request thread.
504
- :rtype: (GetStructuredResultDataResponse, int, HTTPHeaderDict)
841
+ :rtype: tuple(GetStructuredResultDataResponse, status_code(int), headers(HTTPHeaderDict))
505
842
  """
506
843
 
507
- local_var_params = locals()
844
+ _params = locals()
508
845
 
509
- all_params = [
846
+ _all_params = [
510
847
  'scope',
511
848
  'request_body',
512
849
  'as_at',
513
850
  'max_age'
514
851
  ]
515
- all_params.extend(
852
+ _all_params.extend(
516
853
  [
517
854
  'async_req',
518
855
  '_return_http_data_only',
519
856
  '_preload_content',
520
857
  '_request_timeout',
521
858
  '_request_auth',
859
+ '_content_type',
522
860
  '_headers'
523
861
  ]
524
862
  )
525
863
 
526
- for key, val in six.iteritems(local_var_params['kwargs']):
527
- if key not in all_params:
864
+ # validate the arguments
865
+ for _key, _val in _params['kwargs'].items():
866
+ if _key not in _all_params:
528
867
  raise ApiTypeError(
529
868
  "Got an unexpected keyword argument '%s'"
530
- " to method get_structured_result_data" % key
869
+ " to method get_structured_result_data" % _key
531
870
  )
532
- local_var_params[key] = val
533
- del local_var_params['kwargs']
534
- # verify the required parameter 'scope' is set
535
- if self.api_client.client_side_validation and ('scope' not in local_var_params or # noqa: E501
536
- local_var_params['scope'] is None): # noqa: E501
537
- raise ApiValueError("Missing the required parameter `scope` when calling `get_structured_result_data`") # noqa: E501
538
- # verify the required parameter 'request_body' is set
539
- if self.api_client.client_side_validation and ('request_body' not in local_var_params or # noqa: E501
540
- local_var_params['request_body'] is None): # noqa: E501
541
- raise ApiValueError("Missing the required parameter `request_body` when calling `get_structured_result_data`") # noqa: E501
542
-
543
- if self.api_client.client_side_validation and ('scope' in local_var_params and # noqa: E501
544
- len(local_var_params['scope']) > 64): # noqa: E501
545
- raise ApiValueError("Invalid value for parameter `scope` when calling `get_structured_result_data`, length must be less than or equal to `64`") # noqa: E501
546
- if self.api_client.client_side_validation and ('scope' in local_var_params and # noqa: E501
547
- len(local_var_params['scope']) < 1): # noqa: E501
548
- raise ApiValueError("Invalid value for parameter `scope` when calling `get_structured_result_data`, length must be greater than or equal to `1`") # noqa: E501
549
- if self.api_client.client_side_validation and 'scope' in local_var_params and not re.search(r'^[a-zA-Z0-9\-_]+$', local_var_params['scope']): # noqa: E501
550
- raise ApiValueError("Invalid value for parameter `scope` when calling `get_structured_result_data`, must conform to the pattern `/^[a-zA-Z0-9\-_]+$/`") # noqa: E501
551
- collection_formats = {}
552
-
553
- path_params = {}
554
- if 'scope' in local_var_params:
555
- path_params['scope'] = local_var_params['scope'] # noqa: E501
556
-
557
- query_params = []
558
- if 'as_at' in local_var_params and local_var_params['as_at'] is not None: # noqa: E501
559
- query_params.append(('asAt', local_var_params['as_at'])) # noqa: E501
560
- if 'max_age' in local_var_params and local_var_params['max_age'] is not None: # noqa: E501
561
- query_params.append(('maxAge', local_var_params['max_age'])) # noqa: E501
562
-
563
- header_params = dict(local_var_params.get('_headers', {}))
564
-
565
- form_params = []
566
- local_var_files = {}
567
-
568
- body_params = None
569
- if 'request_body' in local_var_params:
570
- body_params = local_var_params['request_body']
571
- # HTTP header `Accept`
572
- header_params['Accept'] = self.api_client.select_header_accept(
871
+ _params[_key] = _val
872
+ del _params['kwargs']
873
+
874
+ _collection_formats = {}
875
+
876
+ # process the path parameters
877
+ _path_params = {}
878
+ if _params['scope']:
879
+ _path_params['scope'] = _params['scope']
880
+
881
+
882
+ # process the query parameters
883
+ _query_params = []
884
+ if _params.get('as_at') is not None: # noqa: E501
885
+ if isinstance(_params['as_at'], datetime):
886
+ _query_params.append(('asAt', _params['as_at'].strftime(self.api_client.configuration.datetime_format)))
887
+ else:
888
+ _query_params.append(('asAt', _params['as_at']))
889
+
890
+ if _params.get('max_age') is not None: # noqa: E501
891
+ _query_params.append(('maxAge', _params['max_age']))
892
+
893
+ # process the header parameters
894
+ _header_params = dict(_params.get('_headers', {}))
895
+ # process the form parameters
896
+ _form_params = []
897
+ _files = {}
898
+ # process the body parameter
899
+ _body_params = None
900
+ if _params['request_body'] is not None:
901
+ _body_params = _params['request_body']
902
+
903
+ # set the HTTP header `Accept`
904
+ _header_params['Accept'] = self.api_client.select_header_accept(
573
905
  ['text/plain', 'application/json', 'text/json']) # noqa: E501
574
906
 
575
- header_params['Accept-Encoding'] = "gzip, deflate, br"
907
+ # set the HTTP header `Content-Type`
908
+ _content_types_list = _params.get('_content_type',
909
+ self.api_client.select_header_content_type(
910
+ ['application/json-patch+json', 'application/json', 'text/json', 'application/*+json']))
911
+ if _content_types_list:
912
+ _header_params['Content-Type'] = _content_types_list
913
+
914
+ # authentication setting
915
+ _auth_settings = ['oauth2'] # noqa: E501
916
+
917
+ _response_types_map = {
918
+ '200': "GetStructuredResultDataResponse",
919
+ '400': "LusidValidationProblemDetails",
920
+ }
921
+
922
+ return self.api_client.call_api(
923
+ '/api/unitresults/{scope}/$get', 'POST',
924
+ _path_params,
925
+ _query_params,
926
+ _header_params,
927
+ body=_body_params,
928
+ post_params=_form_params,
929
+ files=_files,
930
+ response_types_map=_response_types_map,
931
+ auth_settings=_auth_settings,
932
+ async_req=_params.get('async_req'),
933
+ _return_http_data_only=_params.get('_return_http_data_only'), # noqa: E501
934
+ _preload_content=_params.get('_preload_content', True),
935
+ _request_timeout=_params.get('_request_timeout'),
936
+ collection_formats=_collection_formats,
937
+ _request_auth=_params.get('_request_auth'))
938
+
939
+ @overload
940
+ async def get_virtual_document(self, scope : Annotated[constr(strict=True, max_length=64, min_length=1), Field(..., description="The scope in which to construct the virtual documents.")], request_body : Annotated[Dict[str, StructuredResultDataId], Field(..., description="The time invariant set of structured data identifiers to retrieve, keyed by a unique, ephemeral correlation ID.")], as_at : Annotated[Optional[datetime], Field(description="The asAt datetime at which to retrieve the structured result data. Defaults to returning the latest version if not specified.")] = None, **kwargs) -> GetVirtualDocumentResponse: # noqa: E501
941
+ ...
942
+
943
+ @overload
944
+ def get_virtual_document(self, scope : Annotated[constr(strict=True, max_length=64, min_length=1), Field(..., description="The scope in which to construct the virtual documents.")], request_body : Annotated[Dict[str, StructuredResultDataId], Field(..., description="The time invariant set of structured data identifiers to retrieve, keyed by a unique, ephemeral correlation ID.")], as_at : Annotated[Optional[datetime], Field(description="The asAt datetime at which to retrieve the structured result data. Defaults to returning the latest version if not specified.")] = None, async_req: Optional[bool]=True, **kwargs) -> GetVirtualDocumentResponse: # noqa: E501
945
+ ...
946
+
947
+ @validate_arguments
948
+ def get_virtual_document(self, scope : Annotated[constr(strict=True, max_length=64, min_length=1), Field(..., description="The scope in which to construct the virtual documents.")], request_body : Annotated[Dict[str, StructuredResultDataId], Field(..., description="The time invariant set of structured data identifiers to retrieve, keyed by a unique, ephemeral correlation ID.")], as_at : Annotated[Optional[datetime], Field(description="The asAt datetime at which to retrieve the structured result data. Defaults to returning the latest version if not specified.")] = None, async_req: Optional[bool]=None, **kwargs) -> Union[GetVirtualDocumentResponse, Awaitable[GetVirtualDocumentResponse]]: # noqa: E501
949
+ """[EXPERIMENTAL] GetVirtualDocument: Get Virtual Documents # noqa: E501
950
+
951
+ Retrieve one or more virtual documents from a particular scope. Each item can be identified by its time invariant structured result data identifier. For each ID, LUSID returns the most recently matched item with respect to the provided effective datetime. In the request, each data item must be keyed by a unique correlation ID. This ID is ephemeral and not stored by LUSID. It serves only to easily identify each data item in the response. The response returns two collections. The first contains successfully retrieved data items. The second contains those with a valid identifier but that could not be found, or those that failed because LUSID could not construct a valid identifier from the request. For the IDs that failed to resolve or could not be found, a reason is provided. It is important to check the failed sets for any unsuccessful results. # noqa: E501
952
+ This method makes a synchronous HTTP request by default. To make an
953
+ asynchronous HTTP request, please pass async_req=True
954
+
955
+ >>> thread = api.get_virtual_document(scope, request_body, as_at, async_req=True)
956
+ >>> result = thread.get()
957
+
958
+ :param scope: The scope in which to construct the virtual documents. (required)
959
+ :type scope: str
960
+ :param request_body: The time invariant set of structured data identifiers to retrieve, keyed by a unique, ephemeral correlation ID. (required)
961
+ :type request_body: Dict[str, StructuredResultDataId]
962
+ :param as_at: The asAt datetime at which to retrieve the structured result data. Defaults to returning the latest version if not specified.
963
+ :type as_at: datetime
964
+ :param async_req: Whether to execute the request asynchronously.
965
+ :type async_req: bool, optional
966
+ :param _request_timeout: timeout setting for this request.
967
+ If one number provided, it will be total request
968
+ timeout. It can also be a pair (tuple) of
969
+ (connection, read) timeouts.
970
+ :return: Returns the result object.
971
+ If the method is called asynchronously,
972
+ returns the request thread.
973
+ :rtype: GetVirtualDocumentResponse
974
+ """
975
+ kwargs['_return_http_data_only'] = True
976
+ if '_preload_content' in kwargs:
977
+ message = "Error! Please call the get_virtual_document_with_http_info method with `_preload_content` instead and obtain raw data from ApiResponse.raw_data" # noqa: E501
978
+ raise ValueError(message)
979
+ if async_req is not None:
980
+ kwargs['async_req'] = async_req
981
+ return self.get_virtual_document_with_http_info(scope, request_body, as_at, **kwargs) # noqa: E501
982
+
983
+ @validate_arguments
984
+ def get_virtual_document_with_http_info(self, scope : Annotated[constr(strict=True, max_length=64, min_length=1), Field(..., description="The scope in which to construct the virtual documents.")], request_body : Annotated[Dict[str, StructuredResultDataId], Field(..., description="The time invariant set of structured data identifiers to retrieve, keyed by a unique, ephemeral correlation ID.")], as_at : Annotated[Optional[datetime], Field(description="The asAt datetime at which to retrieve the structured result data. Defaults to returning the latest version if not specified.")] = None, **kwargs) -> ApiResponse: # noqa: E501
985
+ """[EXPERIMENTAL] GetVirtualDocument: Get Virtual Documents # noqa: E501
986
+
987
+ Retrieve one or more virtual documents from a particular scope. Each item can be identified by its time invariant structured result data identifier. For each ID, LUSID returns the most recently matched item with respect to the provided effective datetime. In the request, each data item must be keyed by a unique correlation ID. This ID is ephemeral and not stored by LUSID. It serves only to easily identify each data item in the response. The response returns two collections. The first contains successfully retrieved data items. The second contains those with a valid identifier but that could not be found, or those that failed because LUSID could not construct a valid identifier from the request. For the IDs that failed to resolve or could not be found, a reason is provided. It is important to check the failed sets for any unsuccessful results. # noqa: E501
988
+ This method makes a synchronous HTTP request by default. To make an
989
+ asynchronous HTTP request, please pass async_req=True
990
+
991
+ >>> thread = api.get_virtual_document_with_http_info(scope, request_body, as_at, async_req=True)
992
+ >>> result = thread.get()
993
+
994
+ :param scope: The scope in which to construct the virtual documents. (required)
995
+ :type scope: str
996
+ :param request_body: The time invariant set of structured data identifiers to retrieve, keyed by a unique, ephemeral correlation ID. (required)
997
+ :type request_body: Dict[str, StructuredResultDataId]
998
+ :param as_at: The asAt datetime at which to retrieve the structured result data. Defaults to returning the latest version if not specified.
999
+ :type as_at: datetime
1000
+ :param async_req: Whether to execute the request asynchronously.
1001
+ :type async_req: bool, optional
1002
+ :param _preload_content: if False, the ApiResponse.data will
1003
+ be set to none and raw_data will store the
1004
+ HTTP response body without reading/decoding.
1005
+ Default is True.
1006
+ :type _preload_content: bool, optional
1007
+ :param _return_http_data_only: response data instead of ApiResponse
1008
+ object with status code, headers, etc
1009
+ :type _return_http_data_only: bool, optional
1010
+ :param _request_timeout: timeout setting for this request. If one
1011
+ number provided, it will be total request
1012
+ timeout. It can also be a pair (tuple) of
1013
+ (connection, read) timeouts.
1014
+ :param _request_auth: set to override the auth_settings for an a single
1015
+ request; this effectively ignores the authentication
1016
+ in the spec for a single request.
1017
+ :type _request_auth: dict, optional
1018
+ :type _content_type: string, optional: force content-type for the request
1019
+ :return: Returns the result object.
1020
+ If the method is called asynchronously,
1021
+ returns the request thread.
1022
+ :rtype: tuple(GetVirtualDocumentResponse, status_code(int), headers(HTTPHeaderDict))
1023
+ """
1024
+
1025
+ _params = locals()
1026
+
1027
+ _all_params = [
1028
+ 'scope',
1029
+ 'request_body',
1030
+ 'as_at'
1031
+ ]
1032
+ _all_params.extend(
1033
+ [
1034
+ 'async_req',
1035
+ '_return_http_data_only',
1036
+ '_preload_content',
1037
+ '_request_timeout',
1038
+ '_request_auth',
1039
+ '_content_type',
1040
+ '_headers'
1041
+ ]
1042
+ )
576
1043
 
577
- # HTTP header `Content-Type`
578
- header_params['Content-Type'] = self.api_client.select_header_content_type( # noqa: E501
579
- ['application/json-patch+json', 'application/json', 'text/json', 'application/*+json']) # noqa: E501
1044
+ # validate the arguments
1045
+ for _key, _val in _params['kwargs'].items():
1046
+ if _key not in _all_params:
1047
+ raise ApiTypeError(
1048
+ "Got an unexpected keyword argument '%s'"
1049
+ " to method get_virtual_document" % _key
1050
+ )
1051
+ _params[_key] = _val
1052
+ del _params['kwargs']
1053
+
1054
+ _collection_formats = {}
1055
+
1056
+ # process the path parameters
1057
+ _path_params = {}
1058
+ if _params['scope']:
1059
+ _path_params['scope'] = _params['scope']
1060
+
1061
+
1062
+ # process the query parameters
1063
+ _query_params = []
1064
+ if _params.get('as_at') is not None: # noqa: E501
1065
+ if isinstance(_params['as_at'], datetime):
1066
+ _query_params.append(('asAt', _params['as_at'].strftime(self.api_client.configuration.datetime_format)))
1067
+ else:
1068
+ _query_params.append(('asAt', _params['as_at']))
1069
+
1070
+ # process the header parameters
1071
+ _header_params = dict(_params.get('_headers', {}))
1072
+ # process the form parameters
1073
+ _form_params = []
1074
+ _files = {}
1075
+ # process the body parameter
1076
+ _body_params = None
1077
+ if _params['request_body'] is not None:
1078
+ _body_params = _params['request_body']
1079
+
1080
+ # set the HTTP header `Accept`
1081
+ _header_params['Accept'] = self.api_client.select_header_accept(
1082
+ ['text/plain', 'application/json', 'text/json']) # noqa: E501
580
1083
 
581
- # set the LUSID header
582
- header_params['X-LUSID-SDK-Language'] = 'Python'
583
- header_params['X-LUSID-SDK-Version'] = '1.1.257'
1084
+ # set the HTTP header `Content-Type`
1085
+ _content_types_list = _params.get('_content_type',
1086
+ self.api_client.select_header_content_type(
1087
+ ['application/json-patch+json', 'application/json', 'text/json', 'application/*+json']))
1088
+ if _content_types_list:
1089
+ _header_params['Content-Type'] = _content_types_list
584
1090
 
585
- # Authentication setting
586
- auth_settings = ['oauth2'] # noqa: E501
1091
+ # authentication setting
1092
+ _auth_settings = ['oauth2'] # noqa: E501
587
1093
 
588
- response_types_map = {
589
- 200: "GetStructuredResultDataResponse",
590
- 400: "LusidValidationProblemDetails",
1094
+ _response_types_map = {
1095
+ '200': "GetVirtualDocumentResponse",
1096
+ '400': "LusidValidationProblemDetails",
591
1097
  }
592
1098
 
593
1099
  return self.api_client.call_api(
594
- '/api/unitresults/{scope}/$get', 'POST',
595
- path_params,
596
- query_params,
597
- header_params,
598
- body=body_params,
599
- post_params=form_params,
600
- files=local_var_files,
601
- response_types_map=response_types_map,
602
- auth_settings=auth_settings,
603
- async_req=local_var_params.get('async_req'),
604
- _return_http_data_only=local_var_params.get('_return_http_data_only'), # noqa: E501
605
- _preload_content=local_var_params.get('_preload_content', True),
606
- _request_timeout=local_var_params.get('_request_timeout'),
607
- collection_formats=collection_formats,
608
- _request_auth=local_var_params.get('_request_auth'))
609
-
610
- def get_virtual_document_rows(self, scope, code, source, result_type, effective_at, **kwargs): # noqa: E501
1100
+ '/api/unitresults/virtualdocument/{scope}/$get', 'POST',
1101
+ _path_params,
1102
+ _query_params,
1103
+ _header_params,
1104
+ body=_body_params,
1105
+ post_params=_form_params,
1106
+ files=_files,
1107
+ response_types_map=_response_types_map,
1108
+ auth_settings=_auth_settings,
1109
+ async_req=_params.get('async_req'),
1110
+ _return_http_data_only=_params.get('_return_http_data_only'), # noqa: E501
1111
+ _preload_content=_params.get('_preload_content', True),
1112
+ _request_timeout=_params.get('_request_timeout'),
1113
+ collection_formats=_collection_formats,
1114
+ _request_auth=_params.get('_request_auth'))
1115
+
1116
+ @overload
1117
+ async def get_virtual_document_rows(self, scope : Annotated[constr(strict=True, max_length=256, min_length=1), Field(..., description="The scope in which to retrieve the virtual document.")], code : Annotated[constr(strict=True, max_length=256, min_length=1), Field(..., description="The code of the virtual document to retrieve.")], source : Annotated[constr(strict=True, max_length=256, min_length=1), Field(..., description="The source of the virtual document to retrieve.")], result_type : Annotated[StrictStr, Field(..., description="The result type of the virtual document to retrieve.")], effective_at : Annotated[StrictStr, Field(..., description="The effectiveAt datetime at which to retrieve the virtual document.")], as_at : Annotated[Optional[datetime], Field(description="The asAt datetime at which to retrieve the virtual document. Defaults to returning the latest version if not specified.")] = None, page : Annotated[Optional[constr(strict=True, max_length=500, min_length=1)], Field(description="The pagination token to use to continue listing virtual document rows from a previous call to list virtual document rows. This value is returned from the previous call. If a pagination token is provided the filter, effectiveAt, and asAt fields must not have changed since the original request.")] = None, limit : Annotated[Optional[conint(strict=True, le=5000, ge=1)], Field(description="When paginating, limit the number of returned results to this many.")] = None, filter : Annotated[Optional[constr(strict=True, max_length=16384, min_length=0)], Field(description="Expression to filter the result set. Read more about filtering results from LUSID here: https://support.lusid.com/filtering-results-from-lusid.")] = None, **kwargs) -> PagedResourceListOfVirtualRow: # noqa: E501
1118
+ ...
1119
+
1120
+ @overload
1121
+ def get_virtual_document_rows(self, scope : Annotated[constr(strict=True, max_length=256, min_length=1), Field(..., description="The scope in which to retrieve the virtual document.")], code : Annotated[constr(strict=True, max_length=256, min_length=1), Field(..., description="The code of the virtual document to retrieve.")], source : Annotated[constr(strict=True, max_length=256, min_length=1), Field(..., description="The source of the virtual document to retrieve.")], result_type : Annotated[StrictStr, Field(..., description="The result type of the virtual document to retrieve.")], effective_at : Annotated[StrictStr, Field(..., description="The effectiveAt datetime at which to retrieve the virtual document.")], as_at : Annotated[Optional[datetime], Field(description="The asAt datetime at which to retrieve the virtual document. Defaults to returning the latest version if not specified.")] = None, page : Annotated[Optional[constr(strict=True, max_length=500, min_length=1)], Field(description="The pagination token to use to continue listing virtual document rows from a previous call to list virtual document rows. This value is returned from the previous call. If a pagination token is provided the filter, effectiveAt, and asAt fields must not have changed since the original request.")] = None, limit : Annotated[Optional[conint(strict=True, le=5000, ge=1)], Field(description="When paginating, limit the number of returned results to this many.")] = None, filter : Annotated[Optional[constr(strict=True, max_length=16384, min_length=0)], Field(description="Expression to filter the result set. Read more about filtering results from LUSID here: https://support.lusid.com/filtering-results-from-lusid.")] = None, async_req: Optional[bool]=True, **kwargs) -> PagedResourceListOfVirtualRow: # noqa: E501
1122
+ ...
1123
+
1124
+ @validate_arguments
1125
+ def get_virtual_document_rows(self, scope : Annotated[constr(strict=True, max_length=256, min_length=1), Field(..., description="The scope in which to retrieve the virtual document.")], code : Annotated[constr(strict=True, max_length=256, min_length=1), Field(..., description="The code of the virtual document to retrieve.")], source : Annotated[constr(strict=True, max_length=256, min_length=1), Field(..., description="The source of the virtual document to retrieve.")], result_type : Annotated[StrictStr, Field(..., description="The result type of the virtual document to retrieve.")], effective_at : Annotated[StrictStr, Field(..., description="The effectiveAt datetime at which to retrieve the virtual document.")], as_at : Annotated[Optional[datetime], Field(description="The asAt datetime at which to retrieve the virtual document. Defaults to returning the latest version if not specified.")] = None, page : Annotated[Optional[constr(strict=True, max_length=500, min_length=1)], Field(description="The pagination token to use to continue listing virtual document rows from a previous call to list virtual document rows. This value is returned from the previous call. If a pagination token is provided the filter, effectiveAt, and asAt fields must not have changed since the original request.")] = None, limit : Annotated[Optional[conint(strict=True, le=5000, ge=1)], Field(description="When paginating, limit the number of returned results to this many.")] = None, filter : Annotated[Optional[constr(strict=True, max_length=16384, min_length=0)], Field(description="Expression to filter the result set. Read more about filtering results from LUSID here: https://support.lusid.com/filtering-results-from-lusid.")] = None, async_req: Optional[bool]=None, **kwargs) -> Union[PagedResourceListOfVirtualRow, Awaitable[PagedResourceListOfVirtualRow]]: # noqa: E501
611
1126
  """[EARLY ACCESS] GetVirtualDocumentRows: Get Virtual Document Rows # noqa: E501
612
1127
 
613
1128
  Retrieve the rows of the virtual document with the specified identifiers and the given effectiveAt date time. Get virtual document rows merges multiple StructuredResultData items upserted with UpsertStructuredResultData for a single StructuredResultDataId. Since an item of StructuredResultData is always upserted with a StructuredResultDataId, of which effectiveAt is a part, then merging across the asAt dimension is supported but not merging across the effectiveAt dimension. # noqa: E501
614
1129
  This method makes a synchronous HTTP request by default. To make an
615
1130
  asynchronous HTTP request, please pass async_req=True
616
1131
 
617
- >>> thread = api.get_virtual_document_rows(scope, code, source, result_type, effective_at, async_req=True)
1132
+ >>> thread = api.get_virtual_document_rows(scope, code, source, result_type, effective_at, as_at, page, limit, filter, async_req=True)
618
1133
  >>> result = thread.get()
619
1134
 
620
1135
  :param scope: The scope in which to retrieve the virtual document. (required)
@@ -637,30 +1152,32 @@ class StructuredResultDataApi(object):
637
1152
  :type filter: str
638
1153
  :param async_req: Whether to execute the request asynchronously.
639
1154
  :type async_req: bool, optional
640
- :param _preload_content: if False, the urllib3.HTTPResponse object will
641
- be returned without reading/decoding response
642
- data. Default is True.
643
- :type _preload_content: bool, optional
644
- :param _request_timeout: timeout setting for this request. If one
645
- number provided, it will be total request
646
- timeout. It can also be a pair (tuple) of
647
- (connection, read) timeouts.
1155
+ :param _request_timeout: timeout setting for this request.
1156
+ If one number provided, it will be total request
1157
+ timeout. It can also be a pair (tuple) of
1158
+ (connection, read) timeouts.
648
1159
  :return: Returns the result object.
649
1160
  If the method is called asynchronously,
650
1161
  returns the request thread.
651
1162
  :rtype: PagedResourceListOfVirtualRow
652
1163
  """
653
1164
  kwargs['_return_http_data_only'] = True
654
- return self.get_virtual_document_rows_with_http_info(scope, code, source, result_type, effective_at, **kwargs) # noqa: E501
655
-
656
- def get_virtual_document_rows_with_http_info(self, scope, code, source, result_type, effective_at, **kwargs): # noqa: E501
1165
+ if '_preload_content' in kwargs:
1166
+ message = "Error! Please call the get_virtual_document_rows_with_http_info method with `_preload_content` instead and obtain raw data from ApiResponse.raw_data" # noqa: E501
1167
+ raise ValueError(message)
1168
+ if async_req is not None:
1169
+ kwargs['async_req'] = async_req
1170
+ return self.get_virtual_document_rows_with_http_info(scope, code, source, result_type, effective_at, as_at, page, limit, filter, **kwargs) # noqa: E501
1171
+
1172
+ @validate_arguments
1173
+ def get_virtual_document_rows_with_http_info(self, scope : Annotated[constr(strict=True, max_length=256, min_length=1), Field(..., description="The scope in which to retrieve the virtual document.")], code : Annotated[constr(strict=True, max_length=256, min_length=1), Field(..., description="The code of the virtual document to retrieve.")], source : Annotated[constr(strict=True, max_length=256, min_length=1), Field(..., description="The source of the virtual document to retrieve.")], result_type : Annotated[StrictStr, Field(..., description="The result type of the virtual document to retrieve.")], effective_at : Annotated[StrictStr, Field(..., description="The effectiveAt datetime at which to retrieve the virtual document.")], as_at : Annotated[Optional[datetime], Field(description="The asAt datetime at which to retrieve the virtual document. Defaults to returning the latest version if not specified.")] = None, page : Annotated[Optional[constr(strict=True, max_length=500, min_length=1)], Field(description="The pagination token to use to continue listing virtual document rows from a previous call to list virtual document rows. This value is returned from the previous call. If a pagination token is provided the filter, effectiveAt, and asAt fields must not have changed since the original request.")] = None, limit : Annotated[Optional[conint(strict=True, le=5000, ge=1)], Field(description="When paginating, limit the number of returned results to this many.")] = None, filter : Annotated[Optional[constr(strict=True, max_length=16384, min_length=0)], Field(description="Expression to filter the result set. Read more about filtering results from LUSID here: https://support.lusid.com/filtering-results-from-lusid.")] = None, **kwargs) -> ApiResponse: # noqa: E501
657
1174
  """[EARLY ACCESS] GetVirtualDocumentRows: Get Virtual Document Rows # noqa: E501
658
1175
 
659
1176
  Retrieve the rows of the virtual document with the specified identifiers and the given effectiveAt date time. Get virtual document rows merges multiple StructuredResultData items upserted with UpsertStructuredResultData for a single StructuredResultDataId. Since an item of StructuredResultData is always upserted with a StructuredResultDataId, of which effectiveAt is a part, then merging across the asAt dimension is supported but not merging across the effectiveAt dimension. # noqa: E501
660
1177
  This method makes a synchronous HTTP request by default. To make an
661
1178
  asynchronous HTTP request, please pass async_req=True
662
1179
 
663
- >>> thread = api.get_virtual_document_rows_with_http_info(scope, code, source, result_type, effective_at, async_req=True)
1180
+ >>> thread = api.get_virtual_document_rows_with_http_info(scope, code, source, result_type, effective_at, as_at, page, limit, filter, async_req=True)
664
1181
  >>> result = thread.get()
665
1182
 
666
1183
  :param scope: The scope in which to retrieve the virtual document. (required)
@@ -683,13 +1200,14 @@ class StructuredResultDataApi(object):
683
1200
  :type filter: str
684
1201
  :param async_req: Whether to execute the request asynchronously.
685
1202
  :type async_req: bool, optional
686
- :param _return_http_data_only: response data without head status code
687
- and headers
688
- :type _return_http_data_only: bool, optional
689
- :param _preload_content: if False, the urllib3.HTTPResponse object will
690
- be returned without reading/decoding response
691
- data. Default is True.
1203
+ :param _preload_content: if False, the ApiResponse.data will
1204
+ be set to none and raw_data will store the
1205
+ HTTP response body without reading/decoding.
1206
+ Default is True.
692
1207
  :type _preload_content: bool, optional
1208
+ :param _return_http_data_only: response data instead of ApiResponse
1209
+ object with status code, headers, etc
1210
+ :type _return_http_data_only: bool, optional
693
1211
  :param _request_timeout: timeout setting for this request. If one
694
1212
  number provided, it will be total request
695
1213
  timeout. It can also be a pair (tuple) of
@@ -698,15 +1216,16 @@ class StructuredResultDataApi(object):
698
1216
  request; this effectively ignores the authentication
699
1217
  in the spec for a single request.
700
1218
  :type _request_auth: dict, optional
701
- :return: Returns the result object, the HTTP status code, and the headers.
1219
+ :type _content_type: string, optional: force content-type for the request
1220
+ :return: Returns the result object.
702
1221
  If the method is called asynchronously,
703
1222
  returns the request thread.
704
- :rtype: (PagedResourceListOfVirtualRow, int, HTTPHeaderDict)
1223
+ :rtype: tuple(PagedResourceListOfVirtualRow, status_code(int), headers(HTTPHeaderDict))
705
1224
  """
706
1225
 
707
- local_var_params = locals()
1226
+ _params = locals()
708
1227
 
709
- all_params = [
1228
+ _all_params = [
710
1229
  'scope',
711
1230
  'code',
712
1231
  'source',
@@ -717,190 +1236,312 @@ class StructuredResultDataApi(object):
717
1236
  'limit',
718
1237
  'filter'
719
1238
  ]
720
- all_params.extend(
1239
+ _all_params.extend(
721
1240
  [
722
1241
  'async_req',
723
1242
  '_return_http_data_only',
724
1243
  '_preload_content',
725
1244
  '_request_timeout',
726
1245
  '_request_auth',
1246
+ '_content_type',
727
1247
  '_headers'
728
1248
  ]
729
1249
  )
730
1250
 
731
- for key, val in six.iteritems(local_var_params['kwargs']):
732
- if key not in all_params:
1251
+ # validate the arguments
1252
+ for _key, _val in _params['kwargs'].items():
1253
+ if _key not in _all_params:
733
1254
  raise ApiTypeError(
734
1255
  "Got an unexpected keyword argument '%s'"
735
- " to method get_virtual_document_rows" % key
1256
+ " to method get_virtual_document_rows" % _key
736
1257
  )
737
- local_var_params[key] = val
738
- del local_var_params['kwargs']
739
- # verify the required parameter 'scope' is set
740
- if self.api_client.client_side_validation and ('scope' not in local_var_params or # noqa: E501
741
- local_var_params['scope'] is None): # noqa: E501
742
- raise ApiValueError("Missing the required parameter `scope` when calling `get_virtual_document_rows`") # noqa: E501
743
- # verify the required parameter 'code' is set
744
- if self.api_client.client_side_validation and ('code' not in local_var_params or # noqa: E501
745
- local_var_params['code'] is None): # noqa: E501
746
- raise ApiValueError("Missing the required parameter `code` when calling `get_virtual_document_rows`") # noqa: E501
747
- # verify the required parameter 'source' is set
748
- if self.api_client.client_side_validation and ('source' not in local_var_params or # noqa: E501
749
- local_var_params['source'] is None): # noqa: E501
750
- raise ApiValueError("Missing the required parameter `source` when calling `get_virtual_document_rows`") # noqa: E501
751
- # verify the required parameter 'result_type' is set
752
- if self.api_client.client_side_validation and ('result_type' not in local_var_params or # noqa: E501
753
- local_var_params['result_type'] is None): # noqa: E501
754
- raise ApiValueError("Missing the required parameter `result_type` when calling `get_virtual_document_rows`") # noqa: E501
755
- # verify the required parameter 'effective_at' is set
756
- if self.api_client.client_side_validation and ('effective_at' not in local_var_params or # noqa: E501
757
- local_var_params['effective_at'] is None): # noqa: E501
758
- raise ApiValueError("Missing the required parameter `effective_at` when calling `get_virtual_document_rows`") # noqa: E501
759
-
760
- if self.api_client.client_side_validation and ('scope' in local_var_params and # noqa: E501
761
- len(local_var_params['scope']) > 256): # noqa: E501
762
- raise ApiValueError("Invalid value for parameter `scope` when calling `get_virtual_document_rows`, length must be less than or equal to `256`") # noqa: E501
763
- if self.api_client.client_side_validation and ('scope' in local_var_params and # noqa: E501
764
- len(local_var_params['scope']) < 1): # noqa: E501
765
- raise ApiValueError("Invalid value for parameter `scope` when calling `get_virtual_document_rows`, length must be greater than or equal to `1`") # noqa: E501
766
- if self.api_client.client_side_validation and 'scope' in local_var_params and not re.search(r'^[a-zA-Z0-9\-_]+$', local_var_params['scope']): # noqa: E501
767
- raise ApiValueError("Invalid value for parameter `scope` when calling `get_virtual_document_rows`, must conform to the pattern `/^[a-zA-Z0-9\-_]+$/`") # noqa: E501
768
- if self.api_client.client_side_validation and ('code' in local_var_params and # noqa: E501
769
- len(local_var_params['code']) > 256): # noqa: E501
770
- raise ApiValueError("Invalid value for parameter `code` when calling `get_virtual_document_rows`, length must be less than or equal to `256`") # noqa: E501
771
- if self.api_client.client_side_validation and ('code' in local_var_params and # noqa: E501
772
- len(local_var_params['code']) < 1): # noqa: E501
773
- raise ApiValueError("Invalid value for parameter `code` when calling `get_virtual_document_rows`, length must be greater than or equal to `1`") # noqa: E501
774
- if self.api_client.client_side_validation and 'code' in local_var_params and not re.search(r'^[a-zA-Z0-9\-_]+$', local_var_params['code']): # noqa: E501
775
- raise ApiValueError("Invalid value for parameter `code` when calling `get_virtual_document_rows`, must conform to the pattern `/^[a-zA-Z0-9\-_]+$/`") # noqa: E501
776
- if self.api_client.client_side_validation and ('source' in local_var_params and # noqa: E501
777
- len(local_var_params['source']) > 256): # noqa: E501
778
- raise ApiValueError("Invalid value for parameter `source` when calling `get_virtual_document_rows`, length must be less than or equal to `256`") # noqa: E501
779
- if self.api_client.client_side_validation and ('source' in local_var_params and # noqa: E501
780
- len(local_var_params['source']) < 1): # noqa: E501
781
- raise ApiValueError("Invalid value for parameter `source` when calling `get_virtual_document_rows`, length must be greater than or equal to `1`") # noqa: E501
782
- if self.api_client.client_side_validation and 'source' in local_var_params and not re.search(r'^[a-zA-Z0-9\-_]+$', local_var_params['source']): # noqa: E501
783
- raise ApiValueError("Invalid value for parameter `source` when calling `get_virtual_document_rows`, must conform to the pattern `/^[a-zA-Z0-9\-_]+$/`") # noqa: E501
784
- if self.api_client.client_side_validation and ('page' in local_var_params and # noqa: E501
785
- len(local_var_params['page']) > 500): # noqa: E501
786
- raise ApiValueError("Invalid value for parameter `page` when calling `get_virtual_document_rows`, length must be less than or equal to `500`") # noqa: E501
787
- if self.api_client.client_side_validation and ('page' in local_var_params and # noqa: E501
788
- len(local_var_params['page']) < 1): # noqa: E501
789
- raise ApiValueError("Invalid value for parameter `page` when calling `get_virtual_document_rows`, length must be greater than or equal to `1`") # noqa: E501
790
- if self.api_client.client_side_validation and 'page' in local_var_params and not re.search(r'^[a-zA-Z0-9\+\/]*={0,3}$', local_var_params['page']): # noqa: E501
791
- raise ApiValueError("Invalid value for parameter `page` when calling `get_virtual_document_rows`, must conform to the pattern `/^[a-zA-Z0-9\+\/]*={0,3}$/`") # noqa: E501
792
- if self.api_client.client_side_validation and 'limit' in local_var_params and local_var_params['limit'] > 5000: # noqa: E501
793
- raise ApiValueError("Invalid value for parameter `limit` when calling `get_virtual_document_rows`, must be a value less than or equal to `5000`") # noqa: E501
794
- if self.api_client.client_side_validation and 'limit' in local_var_params and local_var_params['limit'] < 1: # noqa: E501
795
- raise ApiValueError("Invalid value for parameter `limit` when calling `get_virtual_document_rows`, must be a value greater than or equal to `1`") # noqa: E501
796
- if self.api_client.client_side_validation and ('filter' in local_var_params and # noqa: E501
797
- len(local_var_params['filter']) > 16384): # noqa: E501
798
- raise ApiValueError("Invalid value for parameter `filter` when calling `get_virtual_document_rows`, length must be less than or equal to `16384`") # noqa: E501
799
- if self.api_client.client_side_validation and ('filter' in local_var_params and # noqa: E501
800
- len(local_var_params['filter']) < 0): # noqa: E501
801
- raise ApiValueError("Invalid value for parameter `filter` when calling `get_virtual_document_rows`, length must be greater than or equal to `0`") # noqa: E501
802
- if self.api_client.client_side_validation and 'filter' in local_var_params and not re.search(r'^[\s\S]*$', local_var_params['filter']): # noqa: E501
803
- raise ApiValueError("Invalid value for parameter `filter` when calling `get_virtual_document_rows`, must conform to the pattern `/^[\s\S]*$/`") # noqa: E501
804
- collection_formats = {}
805
-
806
- path_params = {}
807
- if 'scope' in local_var_params:
808
- path_params['scope'] = local_var_params['scope'] # noqa: E501
809
- if 'code' in local_var_params:
810
- path_params['code'] = local_var_params['code'] # noqa: E501
811
- if 'source' in local_var_params:
812
- path_params['source'] = local_var_params['source'] # noqa: E501
813
- if 'result_type' in local_var_params:
814
- path_params['resultType'] = local_var_params['result_type'] # noqa: E501
815
-
816
- query_params = []
817
- if 'effective_at' in local_var_params and local_var_params['effective_at'] is not None: # noqa: E501
818
- query_params.append(('effectiveAt', local_var_params['effective_at'])) # noqa: E501
819
- if 'as_at' in local_var_params and local_var_params['as_at'] is not None: # noqa: E501
820
- query_params.append(('asAt', local_var_params['as_at'])) # noqa: E501
821
- if 'page' in local_var_params and local_var_params['page'] is not None: # noqa: E501
822
- query_params.append(('page', local_var_params['page'])) # noqa: E501
823
- if 'limit' in local_var_params and local_var_params['limit'] is not None: # noqa: E501
824
- query_params.append(('limit', local_var_params['limit'])) # noqa: E501
825
- if 'filter' in local_var_params and local_var_params['filter'] is not None: # noqa: E501
826
- query_params.append(('filter', local_var_params['filter'])) # noqa: E501
827
-
828
- header_params = dict(local_var_params.get('_headers', {}))
829
-
830
- form_params = []
831
- local_var_files = {}
832
-
833
- body_params = None
834
- # HTTP header `Accept`
835
- header_params['Accept'] = self.api_client.select_header_accept(
836
- ['text/plain', 'application/json', 'text/json']) # noqa: E501
1258
+ _params[_key] = _val
1259
+ del _params['kwargs']
1260
+
1261
+ _collection_formats = {}
837
1262
 
838
- header_params['Accept-Encoding'] = "gzip, deflate, br"
1263
+ # process the path parameters
1264
+ _path_params = {}
1265
+ if _params['scope']:
1266
+ _path_params['scope'] = _params['scope']
839
1267
 
1268
+ if _params['code']:
1269
+ _path_params['code'] = _params['code']
840
1270
 
841
- # set the LUSID header
842
- header_params['X-LUSID-SDK-Language'] = 'Python'
843
- header_params['X-LUSID-SDK-Version'] = '1.1.257'
1271
+ if _params['source']:
1272
+ _path_params['source'] = _params['source']
844
1273
 
845
- # Authentication setting
846
- auth_settings = ['oauth2'] # noqa: E501
1274
+ if _params['result_type']:
1275
+ _path_params['resultType'] = _params['result_type']
847
1276
 
848
- response_types_map = {
849
- 200: "PagedResourceListOfVirtualRow",
850
- 400: "LusidValidationProblemDetails",
1277
+
1278
+ # process the query parameters
1279
+ _query_params = []
1280
+ if _params.get('effective_at') is not None: # noqa: E501
1281
+ _query_params.append(('effectiveAt', _params['effective_at']))
1282
+
1283
+ if _params.get('as_at') is not None: # noqa: E501
1284
+ if isinstance(_params['as_at'], datetime):
1285
+ _query_params.append(('asAt', _params['as_at'].strftime(self.api_client.configuration.datetime_format)))
1286
+ else:
1287
+ _query_params.append(('asAt', _params['as_at']))
1288
+
1289
+ if _params.get('page') is not None: # noqa: E501
1290
+ _query_params.append(('page', _params['page']))
1291
+
1292
+ if _params.get('limit') is not None: # noqa: E501
1293
+ _query_params.append(('limit', _params['limit']))
1294
+
1295
+ if _params.get('filter') is not None: # noqa: E501
1296
+ _query_params.append(('filter', _params['filter']))
1297
+
1298
+ # process the header parameters
1299
+ _header_params = dict(_params.get('_headers', {}))
1300
+ # process the form parameters
1301
+ _form_params = []
1302
+ _files = {}
1303
+ # process the body parameter
1304
+ _body_params = None
1305
+ # set the HTTP header `Accept`
1306
+ _header_params['Accept'] = self.api_client.select_header_accept(
1307
+ ['text/plain', 'application/json', 'text/json']) # noqa: E501
1308
+
1309
+ # authentication setting
1310
+ _auth_settings = ['oauth2'] # noqa: E501
1311
+
1312
+ _response_types_map = {
1313
+ '200': "PagedResourceListOfVirtualRow",
1314
+ '400': "LusidValidationProblemDetails",
851
1315
  }
852
1316
 
853
1317
  return self.api_client.call_api(
854
1318
  '/api/unitresults/virtualdocument/{scope}/{code}/{source}/{resultType}', 'GET',
855
- path_params,
856
- query_params,
857
- header_params,
858
- body=body_params,
859
- post_params=form_params,
860
- files=local_var_files,
861
- response_types_map=response_types_map,
862
- auth_settings=auth_settings,
863
- async_req=local_var_params.get('async_req'),
864
- _return_http_data_only=local_var_params.get('_return_http_data_only'), # noqa: E501
865
- _preload_content=local_var_params.get('_preload_content', True),
866
- _request_timeout=local_var_params.get('_request_timeout'),
867
- collection_formats=collection_formats,
868
- _request_auth=local_var_params.get('_request_auth'))
869
-
870
- def upsert_structured_result_data(self, scope, request_body, **kwargs): # noqa: E501
871
- """UpsertStructuredResultData: Upsert structured result data # noqa: E501
1319
+ _path_params,
1320
+ _query_params,
1321
+ _header_params,
1322
+ body=_body_params,
1323
+ post_params=_form_params,
1324
+ files=_files,
1325
+ response_types_map=_response_types_map,
1326
+ auth_settings=_auth_settings,
1327
+ async_req=_params.get('async_req'),
1328
+ _return_http_data_only=_params.get('_return_http_data_only'), # noqa: E501
1329
+ _preload_content=_params.get('_preload_content', True),
1330
+ _request_timeout=_params.get('_request_timeout'),
1331
+ collection_formats=_collection_formats,
1332
+ _request_auth=_params.get('_request_auth'))
1333
+
1334
+ @overload
1335
+ async def upsert_result_value(self, scope : Annotated[constr(strict=True, max_length=64, min_length=1), Field(..., description="The scope in which to construct the virtual documents.")], request_body : Annotated[Dict[str, UpsertResultValuesDataRequest], Field(..., description="The time invariant set of structured data identifiers to retrieve, keyed by a unique, ephemeral correlation ID.")], **kwargs) -> UpsertStructuredDataResponse: # noqa: E501
1336
+ ...
1337
+
1338
+ @overload
1339
+ def upsert_result_value(self, scope : Annotated[constr(strict=True, max_length=64, min_length=1), Field(..., description="The scope in which to construct the virtual documents.")], request_body : Annotated[Dict[str, UpsertResultValuesDataRequest], Field(..., description="The time invariant set of structured data identifiers to retrieve, keyed by a unique, ephemeral correlation ID.")], async_req: Optional[bool]=True, **kwargs) -> UpsertStructuredDataResponse: # noqa: E501
1340
+ ...
1341
+
1342
+ @validate_arguments
1343
+ def upsert_result_value(self, scope : Annotated[constr(strict=True, max_length=64, min_length=1), Field(..., description="The scope in which to construct the virtual documents.")], request_body : Annotated[Dict[str, UpsertResultValuesDataRequest], Field(..., description="The time invariant set of structured data identifiers to retrieve, keyed by a unique, ephemeral correlation ID.")], async_req: Optional[bool]=None, **kwargs) -> Union[UpsertStructuredDataResponse, Awaitable[UpsertStructuredDataResponse]]: # noqa: E501
1344
+ """[EXPERIMENTAL] UpsertResultValue: Upsert result value # noqa: E501
1345
+
1346
+ Create or update one or more Upsert one or more result values in a particular scope. An item is updated if it already exists and created if it does not. In the request, each data item must be keyed by a unique correlation ID. This ID is ephemeral and not stored by LUSID. It serves only to easily identify each data item in the response. The response returns both the collection of successfully created or updated data items, as well as those that failed. For each failure, a reason is provided. It is important to check the failed set for any unsuccessful results. # noqa: E501
1347
+ This method makes a synchronous HTTP request by default. To make an
1348
+ asynchronous HTTP request, please pass async_req=True
872
1349
 
873
- Create or update one or more structured result data items in a particular scope. An item is updated if it already exists and created if it does not. In the request, each data item must be keyed by a unique correlation ID. This ID is ephemeral and not stored by LUSID. It serves only to easily identify each data item in the response. The response returns both the collection of successfully created or updated data items, as well as those that failed. For each failure, a reason is provided. It is important to check the failed set for any unsuccessful results. # noqa: E501
1350
+ >>> thread = api.upsert_result_value(scope, request_body, async_req=True)
1351
+ >>> result = thread.get()
1352
+
1353
+ :param scope: The scope in which to construct the virtual documents. (required)
1354
+ :type scope: str
1355
+ :param request_body: The time invariant set of structured data identifiers to retrieve, keyed by a unique, ephemeral correlation ID. (required)
1356
+ :type request_body: Dict[str, UpsertResultValuesDataRequest]
1357
+ :param async_req: Whether to execute the request asynchronously.
1358
+ :type async_req: bool, optional
1359
+ :param _request_timeout: timeout setting for this request.
1360
+ If one number provided, it will be total request
1361
+ timeout. It can also be a pair (tuple) of
1362
+ (connection, read) timeouts.
1363
+ :return: Returns the result object.
1364
+ If the method is called asynchronously,
1365
+ returns the request thread.
1366
+ :rtype: UpsertStructuredDataResponse
1367
+ """
1368
+ kwargs['_return_http_data_only'] = True
1369
+ if '_preload_content' in kwargs:
1370
+ message = "Error! Please call the upsert_result_value_with_http_info method with `_preload_content` instead and obtain raw data from ApiResponse.raw_data" # noqa: E501
1371
+ raise ValueError(message)
1372
+ if async_req is not None:
1373
+ kwargs['async_req'] = async_req
1374
+ return self.upsert_result_value_with_http_info(scope, request_body, **kwargs) # noqa: E501
1375
+
1376
+ @validate_arguments
1377
+ def upsert_result_value_with_http_info(self, scope : Annotated[constr(strict=True, max_length=64, min_length=1), Field(..., description="The scope in which to construct the virtual documents.")], request_body : Annotated[Dict[str, UpsertResultValuesDataRequest], Field(..., description="The time invariant set of structured data identifiers to retrieve, keyed by a unique, ephemeral correlation ID.")], **kwargs) -> ApiResponse: # noqa: E501
1378
+ """[EXPERIMENTAL] UpsertResultValue: Upsert result value # noqa: E501
1379
+
1380
+ Create or update one or more Upsert one or more result values in a particular scope. An item is updated if it already exists and created if it does not. In the request, each data item must be keyed by a unique correlation ID. This ID is ephemeral and not stored by LUSID. It serves only to easily identify each data item in the response. The response returns both the collection of successfully created or updated data items, as well as those that failed. For each failure, a reason is provided. It is important to check the failed set for any unsuccessful results. # noqa: E501
874
1381
  This method makes a synchronous HTTP request by default. To make an
875
1382
  asynchronous HTTP request, please pass async_req=True
876
1383
 
877
- >>> thread = api.upsert_structured_result_data(scope, request_body, async_req=True)
1384
+ >>> thread = api.upsert_result_value_with_http_info(scope, request_body, async_req=True)
878
1385
  >>> result = thread.get()
879
1386
 
880
- :param scope: The scope in which to create or update data items. (required)
1387
+ :param scope: The scope in which to construct the virtual documents. (required)
881
1388
  :type scope: str
882
- :param request_body: The set of data items to create or update, keyed by a unique, ephemeral correlation ID. (required)
883
- :type request_body: dict(str, UpsertStructuredResultDataRequest)
1389
+ :param request_body: The time invariant set of structured data identifiers to retrieve, keyed by a unique, ephemeral correlation ID. (required)
1390
+ :type request_body: Dict[str, UpsertResultValuesDataRequest]
884
1391
  :param async_req: Whether to execute the request asynchronously.
885
1392
  :type async_req: bool, optional
886
- :param _preload_content: if False, the urllib3.HTTPResponse object will
887
- be returned without reading/decoding response
888
- data. Default is True.
1393
+ :param _preload_content: if False, the ApiResponse.data will
1394
+ be set to none and raw_data will store the
1395
+ HTTP response body without reading/decoding.
1396
+ Default is True.
889
1397
  :type _preload_content: bool, optional
1398
+ :param _return_http_data_only: response data instead of ApiResponse
1399
+ object with status code, headers, etc
1400
+ :type _return_http_data_only: bool, optional
890
1401
  :param _request_timeout: timeout setting for this request. If one
891
1402
  number provided, it will be total request
892
1403
  timeout. It can also be a pair (tuple) of
893
1404
  (connection, read) timeouts.
1405
+ :param _request_auth: set to override the auth_settings for an a single
1406
+ request; this effectively ignores the authentication
1407
+ in the spec for a single request.
1408
+ :type _request_auth: dict, optional
1409
+ :type _content_type: string, optional: force content-type for the request
1410
+ :return: Returns the result object.
1411
+ If the method is called asynchronously,
1412
+ returns the request thread.
1413
+ :rtype: tuple(UpsertStructuredDataResponse, status_code(int), headers(HTTPHeaderDict))
1414
+ """
1415
+
1416
+ _params = locals()
1417
+
1418
+ _all_params = [
1419
+ 'scope',
1420
+ 'request_body'
1421
+ ]
1422
+ _all_params.extend(
1423
+ [
1424
+ 'async_req',
1425
+ '_return_http_data_only',
1426
+ '_preload_content',
1427
+ '_request_timeout',
1428
+ '_request_auth',
1429
+ '_content_type',
1430
+ '_headers'
1431
+ ]
1432
+ )
1433
+
1434
+ # validate the arguments
1435
+ for _key, _val in _params['kwargs'].items():
1436
+ if _key not in _all_params:
1437
+ raise ApiTypeError(
1438
+ "Got an unexpected keyword argument '%s'"
1439
+ " to method upsert_result_value" % _key
1440
+ )
1441
+ _params[_key] = _val
1442
+ del _params['kwargs']
1443
+
1444
+ _collection_formats = {}
1445
+
1446
+ # process the path parameters
1447
+ _path_params = {}
1448
+ if _params['scope']:
1449
+ _path_params['scope'] = _params['scope']
1450
+
1451
+
1452
+ # process the query parameters
1453
+ _query_params = []
1454
+ # process the header parameters
1455
+ _header_params = dict(_params.get('_headers', {}))
1456
+ # process the form parameters
1457
+ _form_params = []
1458
+ _files = {}
1459
+ # process the body parameter
1460
+ _body_params = None
1461
+ if _params['request_body'] is not None:
1462
+ _body_params = _params['request_body']
1463
+
1464
+ # set the HTTP header `Accept`
1465
+ _header_params['Accept'] = self.api_client.select_header_accept(
1466
+ ['text/plain', 'application/json', 'text/json']) # noqa: E501
1467
+
1468
+ # set the HTTP header `Content-Type`
1469
+ _content_types_list = _params.get('_content_type',
1470
+ self.api_client.select_header_content_type(
1471
+ ['application/json-patch+json', 'application/json', 'text/json', 'application/*+json']))
1472
+ if _content_types_list:
1473
+ _header_params['Content-Type'] = _content_types_list
1474
+
1475
+ # authentication setting
1476
+ _auth_settings = ['oauth2'] # noqa: E501
1477
+
1478
+ _response_types_map = {
1479
+ '200': "UpsertStructuredDataResponse",
1480
+ '400': "LusidValidationProblemDetails",
1481
+ }
1482
+
1483
+ return self.api_client.call_api(
1484
+ '/api/unitresults/resultvalue/{scope}', 'POST',
1485
+ _path_params,
1486
+ _query_params,
1487
+ _header_params,
1488
+ body=_body_params,
1489
+ post_params=_form_params,
1490
+ files=_files,
1491
+ response_types_map=_response_types_map,
1492
+ auth_settings=_auth_settings,
1493
+ async_req=_params.get('async_req'),
1494
+ _return_http_data_only=_params.get('_return_http_data_only'), # noqa: E501
1495
+ _preload_content=_params.get('_preload_content', True),
1496
+ _request_timeout=_params.get('_request_timeout'),
1497
+ collection_formats=_collection_formats,
1498
+ _request_auth=_params.get('_request_auth'))
1499
+
1500
+ @overload
1501
+ async def upsert_structured_result_data(self, scope : Annotated[constr(strict=True, max_length=64, min_length=1), Field(..., description="The scope in which to create or update data items.")], request_body : Annotated[Dict[str, UpsertStructuredResultDataRequest], Field(..., description="The set of data items to create or update, keyed by a unique, ephemeral correlation ID.")], **kwargs) -> UpsertStructuredDataResponse: # noqa: E501
1502
+ ...
1503
+
1504
+ @overload
1505
+ def upsert_structured_result_data(self, scope : Annotated[constr(strict=True, max_length=64, min_length=1), Field(..., description="The scope in which to create or update data items.")], request_body : Annotated[Dict[str, UpsertStructuredResultDataRequest], Field(..., description="The set of data items to create or update, keyed by a unique, ephemeral correlation ID.")], async_req: Optional[bool]=True, **kwargs) -> UpsertStructuredDataResponse: # noqa: E501
1506
+ ...
1507
+
1508
+ @validate_arguments
1509
+ def upsert_structured_result_data(self, scope : Annotated[constr(strict=True, max_length=64, min_length=1), Field(..., description="The scope in which to create or update data items.")], request_body : Annotated[Dict[str, UpsertStructuredResultDataRequest], Field(..., description="The set of data items to create or update, keyed by a unique, ephemeral correlation ID.")], async_req: Optional[bool]=None, **kwargs) -> Union[UpsertStructuredDataResponse, Awaitable[UpsertStructuredDataResponse]]: # noqa: E501
1510
+ """[BETA] UpsertStructuredResultData: Upsert structured result data # noqa: E501
1511
+
1512
+ Create or update one or more structured result data items in a particular scope. An item is updated if it already exists and created if it does not. In the request, each data item must be keyed by a unique correlation ID. This ID is ephemeral and not stored by LUSID. It serves only to easily identify each data item in the response. The response returns both the collection of successfully created or updated data items, as well as those that failed. For each failure, a reason is provided. It is important to check the failed set for any unsuccessful results. # noqa: E501
1513
+ This method makes a synchronous HTTP request by default. To make an
1514
+ asynchronous HTTP request, please pass async_req=True
1515
+
1516
+ >>> thread = api.upsert_structured_result_data(scope, request_body, async_req=True)
1517
+ >>> result = thread.get()
1518
+
1519
+ :param scope: The scope in which to create or update data items. (required)
1520
+ :type scope: str
1521
+ :param request_body: The set of data items to create or update, keyed by a unique, ephemeral correlation ID. (required)
1522
+ :type request_body: Dict[str, UpsertStructuredResultDataRequest]
1523
+ :param async_req: Whether to execute the request asynchronously.
1524
+ :type async_req: bool, optional
1525
+ :param _request_timeout: timeout setting for this request.
1526
+ If one number provided, it will be total request
1527
+ timeout. It can also be a pair (tuple) of
1528
+ (connection, read) timeouts.
894
1529
  :return: Returns the result object.
895
1530
  If the method is called asynchronously,
896
1531
  returns the request thread.
897
1532
  :rtype: UpsertStructuredDataResponse
898
1533
  """
899
1534
  kwargs['_return_http_data_only'] = True
1535
+ if '_preload_content' in kwargs:
1536
+ message = "Error! Please call the upsert_structured_result_data_with_http_info method with `_preload_content` instead and obtain raw data from ApiResponse.raw_data" # noqa: E501
1537
+ raise ValueError(message)
1538
+ if async_req is not None:
1539
+ kwargs['async_req'] = async_req
900
1540
  return self.upsert_structured_result_data_with_http_info(scope, request_body, **kwargs) # noqa: E501
901
1541
 
902
- def upsert_structured_result_data_with_http_info(self, scope, request_body, **kwargs): # noqa: E501
903
- """UpsertStructuredResultData: Upsert structured result data # noqa: E501
1542
+ @validate_arguments
1543
+ def upsert_structured_result_data_with_http_info(self, scope : Annotated[constr(strict=True, max_length=64, min_length=1), Field(..., description="The scope in which to create or update data items.")], request_body : Annotated[Dict[str, UpsertStructuredResultDataRequest], Field(..., description="The set of data items to create or update, keyed by a unique, ephemeral correlation ID.")], **kwargs) -> ApiResponse: # noqa: E501
1544
+ """[BETA] UpsertStructuredResultData: Upsert structured result data # noqa: E501
904
1545
 
905
1546
  Create or update one or more structured result data items in a particular scope. An item is updated if it already exists and created if it does not. In the request, each data item must be keyed by a unique correlation ID. This ID is ephemeral and not stored by LUSID. It serves only to easily identify each data item in the response. The response returns both the collection of successfully created or updated data items, as well as those that failed. For each failure, a reason is provided. It is important to check the failed set for any unsuccessful results. # noqa: E501
906
1547
  This method makes a synchronous HTTP request by default. To make an
@@ -912,16 +1553,17 @@ class StructuredResultDataApi(object):
912
1553
  :param scope: The scope in which to create or update data items. (required)
913
1554
  :type scope: str
914
1555
  :param request_body: The set of data items to create or update, keyed by a unique, ephemeral correlation ID. (required)
915
- :type request_body: dict(str, UpsertStructuredResultDataRequest)
1556
+ :type request_body: Dict[str, UpsertStructuredResultDataRequest]
916
1557
  :param async_req: Whether to execute the request asynchronously.
917
1558
  :type async_req: bool, optional
918
- :param _return_http_data_only: response data without head status code
919
- and headers
920
- :type _return_http_data_only: bool, optional
921
- :param _preload_content: if False, the urllib3.HTTPResponse object will
922
- be returned without reading/decoding response
923
- data. Default is True.
1559
+ :param _preload_content: if False, the ApiResponse.data will
1560
+ be set to none and raw_data will store the
1561
+ HTTP response body without reading/decoding.
1562
+ Default is True.
924
1563
  :type _preload_content: bool, optional
1564
+ :param _return_http_data_only: response data instead of ApiResponse
1565
+ object with status code, headers, etc
1566
+ :type _return_http_data_only: bool, optional
925
1567
  :param _request_timeout: timeout setting for this request. If one
926
1568
  number provided, it will be total request
927
1569
  timeout. It can also be a pair (tuple) of
@@ -930,105 +1572,93 @@ class StructuredResultDataApi(object):
930
1572
  request; this effectively ignores the authentication
931
1573
  in the spec for a single request.
932
1574
  :type _request_auth: dict, optional
933
- :return: Returns the result object, the HTTP status code, and the headers.
1575
+ :type _content_type: string, optional: force content-type for the request
1576
+ :return: Returns the result object.
934
1577
  If the method is called asynchronously,
935
1578
  returns the request thread.
936
- :rtype: (UpsertStructuredDataResponse, int, HTTPHeaderDict)
1579
+ :rtype: tuple(UpsertStructuredDataResponse, status_code(int), headers(HTTPHeaderDict))
937
1580
  """
938
1581
 
939
- local_var_params = locals()
1582
+ _params = locals()
940
1583
 
941
- all_params = [
1584
+ _all_params = [
942
1585
  'scope',
943
1586
  'request_body'
944
1587
  ]
945
- all_params.extend(
1588
+ _all_params.extend(
946
1589
  [
947
1590
  'async_req',
948
1591
  '_return_http_data_only',
949
1592
  '_preload_content',
950
1593
  '_request_timeout',
951
1594
  '_request_auth',
1595
+ '_content_type',
952
1596
  '_headers'
953
1597
  ]
954
1598
  )
955
1599
 
956
- for key, val in six.iteritems(local_var_params['kwargs']):
957
- if key not in all_params:
1600
+ # validate the arguments
1601
+ for _key, _val in _params['kwargs'].items():
1602
+ if _key not in _all_params:
958
1603
  raise ApiTypeError(
959
1604
  "Got an unexpected keyword argument '%s'"
960
- " to method upsert_structured_result_data" % key
1605
+ " to method upsert_structured_result_data" % _key
961
1606
  )
962
- local_var_params[key] = val
963
- del local_var_params['kwargs']
964
- # verify the required parameter 'scope' is set
965
- if self.api_client.client_side_validation and ('scope' not in local_var_params or # noqa: E501
966
- local_var_params['scope'] is None): # noqa: E501
967
- raise ApiValueError("Missing the required parameter `scope` when calling `upsert_structured_result_data`") # noqa: E501
968
- # verify the required parameter 'request_body' is set
969
- if self.api_client.client_side_validation and ('request_body' not in local_var_params or # noqa: E501
970
- local_var_params['request_body'] is None): # noqa: E501
971
- raise ApiValueError("Missing the required parameter `request_body` when calling `upsert_structured_result_data`") # noqa: E501
972
-
973
- if self.api_client.client_side_validation and ('scope' in local_var_params and # noqa: E501
974
- len(local_var_params['scope']) > 64): # noqa: E501
975
- raise ApiValueError("Invalid value for parameter `scope` when calling `upsert_structured_result_data`, length must be less than or equal to `64`") # noqa: E501
976
- if self.api_client.client_side_validation and ('scope' in local_var_params and # noqa: E501
977
- len(local_var_params['scope']) < 1): # noqa: E501
978
- raise ApiValueError("Invalid value for parameter `scope` when calling `upsert_structured_result_data`, length must be greater than or equal to `1`") # noqa: E501
979
- if self.api_client.client_side_validation and 'scope' in local_var_params and not re.search(r'^[a-zA-Z0-9\-_]+$', local_var_params['scope']): # noqa: E501
980
- raise ApiValueError("Invalid value for parameter `scope` when calling `upsert_structured_result_data`, must conform to the pattern `/^[a-zA-Z0-9\-_]+$/`") # noqa: E501
981
- collection_formats = {}
982
-
983
- path_params = {}
984
- if 'scope' in local_var_params:
985
- path_params['scope'] = local_var_params['scope'] # noqa: E501
986
-
987
- query_params = []
988
-
989
- header_params = dict(local_var_params.get('_headers', {}))
990
-
991
- form_params = []
992
- local_var_files = {}
993
-
994
- body_params = None
995
- if 'request_body' in local_var_params:
996
- body_params = local_var_params['request_body']
997
- # HTTP header `Accept`
998
- header_params['Accept'] = self.api_client.select_header_accept(
1607
+ _params[_key] = _val
1608
+ del _params['kwargs']
1609
+
1610
+ _collection_formats = {}
1611
+
1612
+ # process the path parameters
1613
+ _path_params = {}
1614
+ if _params['scope']:
1615
+ _path_params['scope'] = _params['scope']
1616
+
1617
+
1618
+ # process the query parameters
1619
+ _query_params = []
1620
+ # process the header parameters
1621
+ _header_params = dict(_params.get('_headers', {}))
1622
+ # process the form parameters
1623
+ _form_params = []
1624
+ _files = {}
1625
+ # process the body parameter
1626
+ _body_params = None
1627
+ if _params['request_body'] is not None:
1628
+ _body_params = _params['request_body']
1629
+
1630
+ # set the HTTP header `Accept`
1631
+ _header_params['Accept'] = self.api_client.select_header_accept(
999
1632
  ['text/plain', 'application/json', 'text/json']) # noqa: E501
1000
1633
 
1001
- header_params['Accept-Encoding'] = "gzip, deflate, br"
1002
-
1003
- # HTTP header `Content-Type`
1004
- header_params['Content-Type'] = self.api_client.select_header_content_type( # noqa: E501
1005
- ['application/json-patch+json', 'application/json', 'text/json', 'application/*+json']) # noqa: E501
1006
-
1007
- # set the LUSID header
1008
- header_params['X-LUSID-SDK-Language'] = 'Python'
1009
- header_params['X-LUSID-SDK-Version'] = '1.1.257'
1634
+ # set the HTTP header `Content-Type`
1635
+ _content_types_list = _params.get('_content_type',
1636
+ self.api_client.select_header_content_type(
1637
+ ['application/json-patch+json', 'application/json', 'text/json', 'application/*+json']))
1638
+ if _content_types_list:
1639
+ _header_params['Content-Type'] = _content_types_list
1010
1640
 
1011
- # Authentication setting
1012
- auth_settings = ['oauth2'] # noqa: E501
1641
+ # authentication setting
1642
+ _auth_settings = ['oauth2'] # noqa: E501
1013
1643
 
1014
- response_types_map = {
1015
- 200: "UpsertStructuredDataResponse",
1016
- 400: "LusidValidationProblemDetails",
1644
+ _response_types_map = {
1645
+ '200': "UpsertStructuredDataResponse",
1646
+ '400': "LusidValidationProblemDetails",
1017
1647
  }
1018
1648
 
1019
1649
  return self.api_client.call_api(
1020
1650
  '/api/unitresults/{scope}', 'POST',
1021
- path_params,
1022
- query_params,
1023
- header_params,
1024
- body=body_params,
1025
- post_params=form_params,
1026
- files=local_var_files,
1027
- response_types_map=response_types_map,
1028
- auth_settings=auth_settings,
1029
- async_req=local_var_params.get('async_req'),
1030
- _return_http_data_only=local_var_params.get('_return_http_data_only'), # noqa: E501
1031
- _preload_content=local_var_params.get('_preload_content', True),
1032
- _request_timeout=local_var_params.get('_request_timeout'),
1033
- collection_formats=collection_formats,
1034
- _request_auth=local_var_params.get('_request_auth'))
1651
+ _path_params,
1652
+ _query_params,
1653
+ _header_params,
1654
+ body=_body_params,
1655
+ post_params=_form_params,
1656
+ files=_files,
1657
+ response_types_map=_response_types_map,
1658
+ auth_settings=_auth_settings,
1659
+ async_req=_params.get('async_req'),
1660
+ _return_http_data_only=_params.get('_return_http_data_only'), # noqa: E501
1661
+ _preload_content=_params.get('_preload_content', True),
1662
+ _request_timeout=_params.get('_request_timeout'),
1663
+ collection_formats=_collection_formats,
1664
+ _request_auth=_params.get('_request_auth'))