lusid-sdk 1.1.118__py3-none-any.whl → 2.0.50b0__py3-none-any.whl

Sign up to get free protection for your applications and to get access to all the features.
Files changed (1100) hide show
  1. lusid/__init__.py +247 -180
  2. lusid/api/__init__.py +14 -2
  3. lusid/api/abor_api.py +1963 -0
  4. lusid/api/abor_configuration_api.py +943 -0
  5. lusid/api/address_key_definition_api.py +296 -269
  6. lusid/api/aggregation_api.py +469 -260
  7. lusid/api/allocations_api.py +419 -404
  8. lusid/api/application_metadata_api.py +266 -244
  9. lusid/api/blocks_api.py +409 -402
  10. lusid/api/calendars_api.py +1185 -1262
  11. lusid/api/chart_of_accounts_api.py +4087 -0
  12. lusid/api/complex_market_data_api.py +469 -308
  13. lusid/api/compliance_api.py +1081 -1169
  14. lusid/api/configuration_recipe_api.py +381 -375
  15. lusid/api/conventions_api.py +1982 -0
  16. lusid/api/corporate_action_sources_api.py +961 -885
  17. lusid/api/counterparties_api.py +729 -711
  18. lusid/api/custom_entities_api.py +1186 -1465
  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 +492 -453
  22. lusid/api/data_types_api.py +726 -734
  23. lusid/api/derived_transaction_portfolios_api.py +204 -213
  24. lusid/api/entities_api.py +113 -113
  25. lusid/api/executions_api.py +409 -402
  26. lusid/api/instrument_events_api.py +734 -0
  27. lusid/api/instruments_api.py +2407 -1721
  28. lusid/api/legacy_compliance_api.py +1449 -0
  29. lusid/api/legal_entities_api.py +1982 -2102
  30. lusid/api/order_graph_api.py +357 -364
  31. lusid/api/order_instructions_api.py +745 -0
  32. lusid/api/order_management_api.py +240 -342
  33. lusid/api/orders_api.py +423 -408
  34. lusid/api/packages_api.py +745 -0
  35. lusid/api/participations_api.py +407 -400
  36. lusid/api/persons_api.py +1791 -1945
  37. lusid/api/placements_api.py +411 -404
  38. lusid/api/portfolio_groups_api.py +2810 -2975
  39. lusid/api/portfolios_api.py +3022 -2898
  40. lusid/api/property_definitions_api.py +981 -1267
  41. lusid/api/quotes_api.py +1314 -517
  42. lusid/api/reconciliations_api.py +3548 -855
  43. lusid/api/reference_lists_api.py +388 -388
  44. lusid/api/reference_portfolio_api.py +409 -432
  45. lusid/api/relation_definitions_api.py +538 -0
  46. lusid/api/relations_api.py +414 -0
  47. lusid/api/relationship_definitions_api.py +484 -494
  48. lusid/api/relationships_api.py +204 -222
  49. lusid/api/schemas_api.py +374 -322
  50. lusid/api/scopes_api.py +100 -241
  51. lusid/api/scripted_translation_api.py +784 -795
  52. lusid/api/search_api.py +408 -423
  53. lusid/api/sequences_api.py +376 -404
  54. lusid/api/structured_result_data_api.py +1472 -325
  55. lusid/api/system_configuration_api.py +979 -143
  56. lusid/api/tax_rule_sets_api.py +900 -0
  57. lusid/api/transaction_configuration_api.py +1066 -1104
  58. lusid/api/transaction_fees_api.py +935 -0
  59. lusid/api/transaction_portfolios_api.py +5285 -3517
  60. lusid/api/translation_api.py +364 -0
  61. lusid/api_client.py +195 -124
  62. lusid/api_response.py +25 -0
  63. lusid/configuration.py +58 -81
  64. lusid/exceptions.py +17 -15
  65. lusid/extensions/__init__.py +15 -0
  66. lusid/extensions/api_client.py +764 -0
  67. lusid/extensions/api_client_builder.py +138 -0
  68. lusid/extensions/api_client_factory.py +137 -0
  69. lusid/{utilities → extensions}/api_configuration.py +4 -5
  70. lusid/extensions/configuration_loaders.py +203 -0
  71. lusid/{utilities → extensions}/proxy_config.py +21 -6
  72. lusid/{utilities → extensions}/refreshing_token.py +82 -35
  73. lusid/extensions/rest.py +300 -0
  74. lusid/extensions/retry.py +357 -0
  75. lusid/extensions/socket_keep_alive.py +53 -0
  76. lusid/extensions/tcp_keep_alive_connector.py +66 -0
  77. lusid/models/__init__.py +232 -172
  78. lusid/models/a2_b_breakdown.py +65 -187
  79. lusid/models/a2_b_category.py +60 -154
  80. lusid/models/a2_b_data_record.py +178 -540
  81. lusid/models/a2_b_movement_record.py +192 -635
  82. lusid/models/abor.py +150 -0
  83. lusid/models/abor_configuration.py +159 -0
  84. lusid/models/abor_configuration_properties.py +115 -0
  85. lusid/models/abor_configuration_request.py +145 -0
  86. lusid/models/abor_properties.py +115 -0
  87. lusid/models/abor_request.py +131 -0
  88. lusid/models/access_controlled_action.py +87 -221
  89. lusid/models/access_controlled_resource.py +105 -283
  90. lusid/models/access_metadata_operation.py +84 -234
  91. lusid/models/access_metadata_value.py +58 -166
  92. lusid/models/account.py +126 -0
  93. lusid/models/account_properties.py +115 -0
  94. lusid/models/accounting_method.py +42 -0
  95. lusid/models/accounts_upsert_response.py +110 -0
  96. lusid/models/action_id.py +55 -204
  97. lusid/models/action_result_of_portfolio.py +57 -154
  98. lusid/models/add_business_days_to_date_request.py +63 -214
  99. lusid/models/add_business_days_to_date_response.py +52 -127
  100. lusid/models/additional_payment.py +58 -228
  101. lusid/models/address_definition.py +97 -284
  102. lusid/models/address_key_compliance_parameter.py +80 -166
  103. lusid/models/address_key_definition.py +74 -222
  104. lusid/models/address_key_filter.py +69 -191
  105. lusid/models/address_key_list.py +73 -170
  106. lusid/models/address_key_list_compliance_parameter.py +77 -164
  107. lusid/models/address_key_option_definition.py +69 -293
  108. lusid/models/adjust_holding.py +101 -216
  109. lusid/models/adjust_holding_for_date_request.py +109 -285
  110. lusid/models/adjust_holding_request.py +107 -250
  111. lusid/models/aggregate_spec.py +67 -196
  112. lusid/models/aggregated_return.py +106 -373
  113. lusid/models/aggregated_returns_dispersion_request.py +102 -291
  114. lusid/models/aggregated_returns_request.py +128 -403
  115. lusid/models/aggregated_returns_response.py +95 -186
  116. lusid/models/aggregated_transactions_request.py +131 -0
  117. lusid/models/aggregation_context.py +55 -125
  118. lusid/models/aggregation_measure_failure_detail.py +80 -238
  119. lusid/models/aggregation_op.py +49 -0
  120. lusid/models/aggregation_options.py +55 -189
  121. lusid/models/aggregation_query.py +106 -439
  122. lusid/models/aggregation_type.py +44 -0
  123. lusid/models/allocation.py +207 -737
  124. lusid/models/allocation_request.py +175 -611
  125. lusid/models/allocation_service_run_response.py +102 -0
  126. lusid/models/allocation_set_request.py +64 -126
  127. lusid/models/amortisation_event.py +82 -266
  128. lusid/models/annul_quotes_response.py +99 -217
  129. lusid/models/annul_single_structured_data_response.py +74 -188
  130. lusid/models/annul_structured_data_response.py +99 -217
  131. lusid/models/asset_class.py +44 -0
  132. lusid/models/barrier.py +62 -228
  133. lusid/models/basket.py +85 -229
  134. lusid/models/basket_identifier.py +57 -224
  135. lusid/models/batch_adjust_holdings_response.py +128 -216
  136. lusid/models/batch_upsert_instrument_properties_response.py +101 -223
  137. lusid/models/batch_upsert_portfolio_transactions_response.py +128 -216
  138. lusid/models/batch_upsert_property_definition_properties_response.py +97 -223
  139. lusid/models/block.py +133 -544
  140. lusid/models/block_request.py +108 -448
  141. lusid/models/block_set_request.py +64 -126
  142. lusid/models/bond.py +144 -564
  143. lusid/models/bond_default_event.py +84 -167
  144. lusid/models/book_transactions_response.py +107 -0
  145. lusid/models/bool_compliance_parameter.py +73 -164
  146. lusid/models/bool_list_compliance_parameter.py +77 -164
  147. lusid/models/bucketed_cash_flow_request.py +172 -0
  148. lusid/models/bucketed_cash_flow_response.py +129 -0
  149. lusid/models/bucketing_schedule.py +74 -0
  150. lusid/models/calculation_info.py +73 -0
  151. lusid/models/calendar.py +88 -309
  152. lusid/models/calendar_date.py +84 -407
  153. lusid/models/calendar_dependency.py +73 -166
  154. lusid/models/cap_floor.py +85 -295
  155. lusid/models/cash_dependency.py +76 -199
  156. lusid/models/cash_dividend_event.py +78 -291
  157. lusid/models/cash_flow_event.py +82 -199
  158. lusid/models/cash_flow_lineage.py +91 -276
  159. lusid/models/cash_flow_value.py +90 -289
  160. lusid/models/cash_flow_value_set.py +86 -164
  161. lusid/models/cash_ladder_record.py +58 -216
  162. lusid/models/cash_perpetual.py +78 -231
  163. lusid/models/cds_flow_conventions.py +113 -514
  164. lusid/models/cds_index.py +100 -382
  165. lusid/models/cds_protection_detail_specification.py +57 -230
  166. lusid/models/change.py +110 -357
  167. lusid/models/change_history.py +90 -299
  168. lusid/models/change_history_action.py +39 -0
  169. lusid/models/change_item.py +80 -252
  170. lusid/models/chart_of_accounts.py +135 -0
  171. lusid/models/chart_of_accounts_properties.py +115 -0
  172. lusid/models/chart_of_accounts_request.py +120 -0
  173. lusid/models/client.py +75 -0
  174. lusid/models/close_event.py +76 -197
  175. lusid/models/complete_portfolio.py +142 -495
  176. lusid/models/complete_relation.py +96 -0
  177. lusid/models/complete_relationship.py +88 -378
  178. lusid/models/complex_bond.py +129 -320
  179. lusid/models/complex_market_data.py +81 -151
  180. lusid/models/complex_market_data_id.py +74 -274
  181. lusid/models/compliance_breached_order_info.py +83 -0
  182. lusid/models/compliance_parameter.py +83 -155
  183. lusid/models/compliance_parameter_type.py +53 -0
  184. lusid/models/compliance_rule.py +137 -0
  185. lusid/models/compliance_rule_breakdown.py +76 -257
  186. lusid/models/compliance_rule_breakdown_request.py +76 -252
  187. lusid/models/compliance_rule_response.py +149 -411
  188. lusid/models/compliance_rule_result.py +91 -0
  189. lusid/models/compliance_rule_result_detail.py +91 -414
  190. lusid/models/compliance_rule_result_portfolio_detail.py +57 -159
  191. lusid/models/compliance_rule_upsert_request.py +178 -0
  192. lusid/models/compliance_rule_upsert_response.py +82 -0
  193. lusid/models/compliance_run_info.py +81 -0
  194. lusid/models/compliance_run_info_v2.py +64 -253
  195. lusid/models/compliance_run_summary.py +72 -250
  196. lusid/models/compliance_summary_rule_result.py +97 -342
  197. lusid/models/compliance_summary_rule_result_request.py +97 -348
  198. lusid/models/compliance_template.py +89 -253
  199. lusid/models/compliance_template_parameter.py +55 -201
  200. lusid/models/compliance_template_variation.py +84 -292
  201. lusid/models/composite_breakdown.py +72 -188
  202. lusid/models/composite_breakdown_request.py +97 -281
  203. lusid/models/composite_breakdown_response.py +90 -188
  204. lusid/models/composite_dispersion.py +91 -339
  205. lusid/models/composite_dispersion_response.py +95 -186
  206. lusid/models/compounding.py +76 -299
  207. lusid/models/configuration_recipe.py +123 -362
  208. lusid/models/configuration_recipe_snippet.py +121 -354
  209. lusid/models/constituents_adjustment_header.py +73 -187
  210. lusid/models/contract_for_difference.py +90 -430
  211. lusid/models/corporate_action.py +82 -313
  212. lusid/models/corporate_action_source.py +104 -304
  213. lusid/models/corporate_action_transition.py +69 -155
  214. lusid/models/corporate_action_transition_component.py +59 -262
  215. lusid/models/corporate_action_transition_component_request.py +55 -192
  216. lusid/models/corporate_action_transition_request.py +69 -153
  217. lusid/models/counterparty_agreement.py +73 -292
  218. lusid/models/counterparty_risk_information.py +78 -197
  219. lusid/models/counterparty_signatory.py +57 -161
  220. lusid/models/create_address_key_definition_request.py +53 -163
  221. lusid/models/create_calendar_request.py +94 -262
  222. lusid/models/create_corporate_action_source_request.py +100 -291
  223. lusid/models/create_custom_entity_type_request.py +79 -242
  224. lusid/models/create_cut_label_definition_request.py +85 -256
  225. lusid/models/create_data_map_request.py +79 -0
  226. lusid/models/create_data_type_request.py +143 -462
  227. lusid/models/create_date_request.py +111 -368
  228. lusid/models/create_derived_property_definition_request.py +79 -331
  229. lusid/models/create_derived_transaction_portfolio_request.py +153 -506
  230. lusid/models/create_portfolio_details.py +55 -125
  231. lusid/models/create_portfolio_group_request.py +117 -314
  232. lusid/models/create_property_definition_request.py +98 -424
  233. lusid/models/create_recipe_request.py +90 -0
  234. lusid/models/create_reconciliation_request.py +140 -0
  235. lusid/models/create_reference_portfolio_request.py +102 -317
  236. lusid/models/create_relation_definition_request.py +95 -0
  237. lusid/models/create_relation_request.py +71 -0
  238. lusid/models/create_relationship_definition_request.py +112 -437
  239. lusid/models/create_relationship_request.py +87 -238
  240. lusid/models/create_sequence_request.py +105 -327
  241. lusid/models/create_tax_rule_set_request.py +103 -0
  242. lusid/models/create_transaction_portfolio_request.py +145 -545
  243. lusid/models/create_unit_definition.py +83 -241
  244. lusid/models/credit_default_swap.py +105 -384
  245. lusid/models/credit_rating.py +67 -178
  246. lusid/models/credit_spread_curve_data.py +109 -420
  247. lusid/models/credit_support_annex.py +73 -432
  248. lusid/models/criterion_type.py +39 -0
  249. lusid/models/currency_and_amount.py +58 -153
  250. lusid/models/curve_options.py +110 -0
  251. lusid/models/custodian_account.py +93 -396
  252. lusid/models/custodian_account_properties.py +115 -0
  253. lusid/models/custodian_account_request.py +148 -0
  254. lusid/models/custodian_accounts_upsert_response.py +110 -0
  255. lusid/models/custom_entity_definition.py +79 -323
  256. lusid/models/custom_entity_definition_request.py +79 -242
  257. lusid/models/custom_entity_field.py +73 -222
  258. lusid/models/custom_entity_field_definition.py +71 -296
  259. lusid/models/custom_entity_id.py +91 -280
  260. lusid/models/custom_entity_request.py +78 -228
  261. lusid/models/custom_entity_response.py +118 -382
  262. lusid/models/custom_entity_type.py +79 -323
  263. lusid/models/cut_label_definition.py +105 -324
  264. lusid/models/cut_local_time.py +53 -154
  265. lusid/models/data_definition.py +104 -0
  266. lusid/models/data_map_key.py +101 -0
  267. lusid/models/data_mapping.py +82 -0
  268. lusid/models/data_scope.py +80 -0
  269. lusid/models/data_type.py +139 -477
  270. lusid/models/data_type_summary.py +111 -398
  271. lusid/models/data_type_value_range.py +38 -0
  272. lusid/models/date_attributes.py +140 -371
  273. lusid/models/date_or_diary_entry.py +91 -0
  274. lusid/models/date_range.py +59 -155
  275. lusid/models/date_time_comparison_type.py +38 -0
  276. lusid/models/date_time_compliance_parameter.py +74 -165
  277. lusid/models/date_time_list_compliance_parameter.py +77 -164
  278. lusid/models/day_of_week.py +20 -102
  279. lusid/models/decimal_compliance_parameter.py +73 -164
  280. lusid/models/decimal_list.py +73 -170
  281. lusid/models/decimal_list_compliance_parameter.py +77 -164
  282. lusid/models/decorated_compliance_run_summary.py +65 -156
  283. lusid/models/delete_accounts_response.py +95 -0
  284. lusid/models/delete_custodian_accounts_response.py +103 -0
  285. lusid/models/delete_instrument_properties_response.py +67 -159
  286. lusid/models/delete_instrument_response.py +74 -189
  287. lusid/models/delete_instruments_response.py +74 -189
  288. lusid/models/delete_modes.py +38 -0
  289. lusid/models/delete_relation_request.py +71 -0
  290. lusid/models/delete_relationship_request.py +87 -238
  291. lusid/models/deleted_entity_response.py +81 -219
  292. lusid/models/dependency_source_filter.py +70 -198
  293. lusid/models/described_address_key.py +81 -0
  294. lusid/models/dialect.py +61 -185
  295. lusid/models/dialect_id.py +89 -330
  296. lusid/models/dialect_schema.py +58 -167
  297. lusid/models/diary_entry.py +155 -0
  298. lusid/models/diary_entry_request.py +120 -0
  299. lusid/models/discount_factor_curve_data.py +91 -296
  300. lusid/models/discounting_dependency.py +76 -199
  301. lusid/models/discounting_method.py +39 -0
  302. lusid/models/economic_dependency.py +82 -150
  303. lusid/models/economic_dependency_type.py +50 -0
  304. lusid/models/economic_dependency_with_complex_market_data.py +61 -156
  305. lusid/models/economic_dependency_with_quote.py +68 -186
  306. lusid/models/empty_model_options.py +71 -134
  307. lusid/models/entity_identifier.py +60 -190
  308. lusid/models/equity.py +84 -225
  309. lusid/models/equity_all_of_identifiers.py +83 -415
  310. lusid/models/equity_curve_by_prices_data.py +91 -296
  311. lusid/models/equity_curve_dependency.py +80 -281
  312. lusid/models/equity_model_options.py +73 -169
  313. lusid/models/equity_option.py +117 -554
  314. lusid/models/equity_swap.py +107 -487
  315. lusid/models/equity_vol_dependency.py +80 -275
  316. lusid/models/equity_vol_surface_data.py +101 -267
  317. lusid/models/error_detail.py +77 -216
  318. lusid/models/event_date_range.py +54 -155
  319. lusid/models/ex_dividend_configuration.py +57 -221
  320. lusid/models/exchange_traded_option.py +84 -261
  321. lusid/models/exchange_traded_option_contract_details.py +80 -535
  322. lusid/models/execution.py +144 -673
  323. lusid/models/execution_request.py +119 -577
  324. lusid/models/execution_set_request.py +64 -126
  325. lusid/models/exercise_event.py +85 -228
  326. lusid/models/exotic_instrument.py +79 -199
  327. lusid/models/expanded_group.py +121 -340
  328. lusid/models/fee_rule.py +138 -0
  329. lusid/models/fee_rule_upsert_request.py +142 -0
  330. lusid/models/fee_rule_upsert_response.py +97 -0
  331. lusid/models/field_definition.py +62 -195
  332. lusid/models/field_schema.py +83 -247
  333. lusid/models/field_value.py +60 -165
  334. lusid/models/file_response.py +69 -181
  335. lusid/models/fixed_leg.py +95 -287
  336. lusid/models/fixed_leg_all_of_overrides.py +65 -154
  337. lusid/models/fixed_schedule.py +136 -0
  338. lusid/models/float_schedule.py +147 -0
  339. lusid/models/floating_leg.py +109 -349
  340. lusid/models/flow_convention_name.py +60 -193
  341. lusid/models/flow_conventions.py +120 -542
  342. lusid/models/forward_rate_agreement.py +90 -356
  343. lusid/models/funding_leg.py +89 -259
  344. lusid/models/funding_leg_options.py +91 -0
  345. lusid/models/future.py +100 -388
  346. lusid/models/futures_contract_details.py +112 -537
  347. lusid/models/fx_dependency.py +78 -231
  348. lusid/models/fx_forward.py +97 -481
  349. lusid/models/fx_forward_curve_by_quote_reference.py +114 -387
  350. lusid/models/fx_forward_curve_data.py +95 -360
  351. lusid/models/fx_forward_model_options.py +91 -242
  352. lusid/models/fx_forward_pips_curve_data.py +95 -360
  353. lusid/models/fx_forward_tenor_curve_data.py +117 -420
  354. lusid/models/fx_forward_tenor_pips_curve_data.py +117 -420
  355. lusid/models/fx_forwards_dependency.py +80 -269
  356. lusid/models/fx_option.py +159 -629
  357. lusid/models/fx_rate_schedule.py +111 -0
  358. lusid/models/fx_swap.py +89 -224
  359. lusid/models/fx_tenor_convention.py +53 -166
  360. lusid/models/fx_vol_dependency.py +80 -269
  361. lusid/models/fx_vol_surface_data.py +101 -267
  362. lusid/models/general_ledger_profile_mapping.py +78 -0
  363. lusid/models/general_ledger_profile_request.py +112 -0
  364. lusid/models/general_ledger_profile_response.py +146 -0
  365. lusid/models/get_cds_flow_conventions_response.py +115 -0
  366. lusid/models/get_complex_market_data_response.py +111 -216
  367. lusid/models/get_counterparty_agreement_response.py +97 -215
  368. lusid/models/get_credit_support_annex_response.py +97 -215
  369. lusid/models/get_data_map_response.py +129 -0
  370. lusid/models/get_flow_conventions_response.py +115 -0
  371. lusid/models/get_index_convention_response.py +115 -0
  372. lusid/models/get_instruments_response.py +111 -216
  373. lusid/models/get_quotes_response.py +130 -246
  374. lusid/models/get_recipe_response.py +77 -185
  375. lusid/models/get_reference_portfolio_constituents_response.py +117 -321
  376. lusid/models/get_structured_result_data_response.py +129 -0
  377. lusid/models/get_virtual_document_response.py +129 -0
  378. lusid/models/grouped_result_of_address_key.py +89 -0
  379. lusid/models/holding_adjustment.py +121 -313
  380. lusid/models/holding_adjustment_with_date.py +124 -345
  381. lusid/models/holding_context.py +51 -127
  382. lusid/models/holding_contributor.py +55 -126
  383. lusid/models/holdings_adjustment.py +92 -259
  384. lusid/models/holdings_adjustment_header.py +82 -227
  385. lusid/models/i_unit_definition_dto.py +85 -217
  386. lusid/models/id_selector_definition.py +75 -227
  387. lusid/models/identifier_part_schema.py +74 -295
  388. lusid/models/index_convention.py +100 -388
  389. lusid/models/index_model_options.py +80 -172
  390. lusid/models/index_projection_dependency.py +80 -275
  391. lusid/models/industry_classifier.py +60 -172
  392. lusid/models/inflation_fixing_dependency.py +78 -237
  393. lusid/models/inflation_index_conventions.py +71 -307
  394. lusid/models/inflation_leg.py +120 -455
  395. lusid/models/inflation_linked_bond.py +153 -595
  396. lusid/models/inflation_swap.py +88 -259
  397. lusid/models/informational_error_event.py +78 -237
  398. lusid/models/informational_event.py +88 -262
  399. lusid/models/inline_valuation_request.py +150 -497
  400. lusid/models/inline_valuations_reconciliation_request.py +82 -216
  401. lusid/models/input_transition.py +53 -160
  402. lusid/models/instrument.py +160 -541
  403. lusid/models/instrument_capabilities.py +133 -0
  404. lusid/models/instrument_cash_flow.py +107 -0
  405. lusid/models/instrument_definition.py +93 -251
  406. lusid/models/instrument_definition_format.py +55 -201
  407. lusid/models/instrument_delete_modes.py +38 -0
  408. lusid/models/instrument_event.py +81 -157
  409. lusid/models/instrument_event_holder.py +106 -460
  410. lusid/models/instrument_event_type.py +50 -0
  411. lusid/models/instrument_id_type_descriptor.py +55 -195
  412. lusid/models/instrument_id_value.py +54 -163
  413. lusid/models/instrument_leg.py +82 -143
  414. lusid/models/instrument_list.py +73 -170
  415. lusid/models/instrument_list_compliance_parameter.py +77 -164
  416. lusid/models/instrument_match.py +78 -156
  417. lusid/models/instrument_models.py +78 -186
  418. lusid/models/instrument_payment_diary.py +131 -0
  419. lusid/models/instrument_payment_diary_leg.py +89 -0
  420. lusid/models/instrument_payment_diary_row.py +132 -0
  421. lusid/models/instrument_properties.py +97 -215
  422. lusid/models/instrument_search_property.py +53 -163
  423. lusid/models/instrument_type.py +72 -0
  424. lusid/models/interest_rate_swap.py +110 -322
  425. lusid/models/interest_rate_swaption.py +90 -296
  426. lusid/models/ir_vol_cube_data.py +101 -267
  427. lusid/models/ir_vol_dependency.py +78 -237
  428. lusid/models/is_business_day_response.py +54 -157
  429. lusid/models/je_lines_query_parameters.py +105 -0
  430. lusid/models/journal_entry_line.py +193 -0
  431. lusid/models/journal_entry_lines_query_parameters.py +109 -0
  432. lusid/models/label_value_set.py +51 -129
  433. lusid/models/leg_definition.py +130 -619
  434. lusid/models/legal_entity.py +158 -394
  435. lusid/models/level_step.py +54 -161
  436. lusid/models/life_cycle_event_lineage.py +84 -246
  437. lusid/models/life_cycle_event_value.py +86 -224
  438. lusid/models/link.py +62 -222
  439. lusid/models/list_aggregation_reconciliation.py +73 -211
  440. lusid/models/list_aggregation_response.py +111 -326
  441. lusid/models/list_complex_market_data_with_meta_data_response.py +86 -0
  442. lusid/models/loan_period.py +56 -187
  443. lusid/models/look_up_pricing_model_options.py +75 -198
  444. lusid/models/lusid_instrument.py +98 -166
  445. lusid/models/lusid_problem_details.py +95 -333
  446. lusid/models/lusid_trade_ticket.py +148 -639
  447. lusid/models/lusid_unique_id.py +53 -166
  448. lusid/models/lusid_validation_problem_details.py +106 -362
  449. lusid/models/mapped_string.py +72 -209
  450. lusid/models/mapping.py +93 -281
  451. lusid/models/mapping_rule.py +96 -308
  452. lusid/models/market_context.py +96 -243
  453. lusid/models/market_context_suppliers.py +59 -241
  454. lusid/models/market_data_key_rule.py +114 -462
  455. lusid/models/market_data_options.py +73 -141
  456. lusid/models/market_data_options_type.py +37 -0
  457. lusid/models/market_data_overrides.py +79 -156
  458. lusid/models/market_data_specific_rule.py +115 -494
  459. lusid/models/market_data_type.py +49 -0
  460. lusid/models/market_observable_type.py +41 -0
  461. lusid/models/market_options.py +108 -318
  462. lusid/models/market_quote.py +60 -166
  463. lusid/models/match_criterion.py +95 -0
  464. lusid/models/metric_value.py +58 -155
  465. lusid/models/model_options.py +77 -144
  466. lusid/models/model_options_type.py +44 -0
  467. lusid/models/model_property.py +72 -218
  468. lusid/models/model_schema.py +116 -0
  469. lusid/models/model_selection.py +67 -172
  470. lusid/models/movement_type.py +54 -0
  471. lusid/models/next_value_in_sequence_response.py +66 -158
  472. lusid/models/numeric_comparison_type.py +39 -0
  473. lusid/models/opaque_dependency.py +71 -134
  474. lusid/models/opaque_market_data.py +84 -275
  475. lusid/models/opaque_model_options.py +73 -164
  476. lusid/models/open_event.py +74 -166
  477. lusid/models/operand_type.py +38 -0
  478. lusid/models/operation.py +67 -227
  479. lusid/models/operation_type.py +37 -0
  480. lusid/models/operator.py +43 -0
  481. lusid/models/option_entry.py +71 -0
  482. lusid/models/optionality_schedule.py +118 -0
  483. lusid/models/order.py +173 -706
  484. lusid/models/order_by_spec.py +60 -166
  485. lusid/models/order_flow_configuration.py +51 -129
  486. lusid/models/order_graph_block.py +83 -351
  487. lusid/models/order_graph_block_allocation_detail.py +55 -126
  488. lusid/models/order_graph_block_allocation_synopsis.py +61 -160
  489. lusid/models/order_graph_block_execution_detail.py +55 -126
  490. lusid/models/order_graph_block_execution_synopsis.py +61 -160
  491. lusid/models/order_graph_block_order_detail.py +69 -314
  492. lusid/models/order_graph_block_order_synopsis.py +61 -160
  493. lusid/models/order_graph_block_placement_detail.py +55 -126
  494. lusid/models/order_graph_block_placement_synopsis.py +61 -160
  495. lusid/models/order_graph_placement.py +94 -341
  496. lusid/models/order_graph_placement_allocation_detail.py +55 -126
  497. lusid/models/order_graph_placement_allocation_synopsis.py +61 -160
  498. lusid/models/order_graph_placement_child_placement_detail.py +55 -126
  499. lusid/models/order_graph_placement_execution_detail.py +55 -126
  500. lusid/models/order_graph_placement_execution_synopsis.py +61 -160
  501. lusid/models/order_graph_placement_order_detail.py +55 -126
  502. lusid/models/order_graph_placement_order_synopsis.py +59 -128
  503. lusid/models/order_graph_placement_placement_synopsis.py +61 -160
  504. lusid/models/order_instruction.py +157 -0
  505. lusid/models/order_instruction_request.py +127 -0
  506. lusid/models/order_instruction_set_request.py +82 -0
  507. lusid/models/order_request.py +141 -580
  508. lusid/models/order_set_request.py +64 -126
  509. lusid/models/otc_confirmation.py +55 -125
  510. lusid/models/output_transaction.py +189 -815
  511. lusid/models/output_transition.py +77 -281
  512. lusid/models/package.py +132 -0
  513. lusid/models/package_request.py +111 -0
  514. lusid/models/package_set_request.py +82 -0
  515. lusid/models/paged_resource_list_of_abor.py +113 -0
  516. lusid/models/paged_resource_list_of_abor_configuration.py +113 -0
  517. lusid/models/paged_resource_list_of_account.py +113 -0
  518. lusid/models/paged_resource_list_of_address_key_definition.py +95 -248
  519. lusid/models/paged_resource_list_of_allocation.py +95 -248
  520. lusid/models/paged_resource_list_of_block.py +95 -248
  521. lusid/models/paged_resource_list_of_calendar.py +95 -248
  522. lusid/models/paged_resource_list_of_chart_of_accounts.py +113 -0
  523. lusid/models/paged_resource_list_of_compliance_rule_response.py +95 -248
  524. lusid/models/paged_resource_list_of_compliance_run_info_v2.py +95 -248
  525. lusid/models/paged_resource_list_of_compliance_template.py +95 -248
  526. lusid/models/paged_resource_list_of_corporate_action_source.py +95 -248
  527. lusid/models/paged_resource_list_of_custodian_account.py +113 -0
  528. lusid/models/paged_resource_list_of_custom_entity_definition.py +95 -248
  529. lusid/models/paged_resource_list_of_custom_entity_response.py +95 -248
  530. lusid/models/paged_resource_list_of_custom_entity_type.py +95 -248
  531. lusid/models/paged_resource_list_of_cut_label_definition.py +95 -248
  532. lusid/models/paged_resource_list_of_data_type_summary.py +95 -248
  533. lusid/models/paged_resource_list_of_dialect_id.py +95 -248
  534. lusid/models/paged_resource_list_of_diary_entry.py +113 -0
  535. lusid/models/paged_resource_list_of_execution.py +95 -248
  536. lusid/models/paged_resource_list_of_general_ledger_profile_response.py +113 -0
  537. lusid/models/paged_resource_list_of_instrument.py +95 -248
  538. lusid/models/paged_resource_list_of_instrument_event_holder.py +95 -248
  539. lusid/models/paged_resource_list_of_legal_entity.py +95 -248
  540. lusid/models/paged_resource_list_of_order.py +95 -248
  541. lusid/models/paged_resource_list_of_order_graph_block.py +95 -248
  542. lusid/models/paged_resource_list_of_order_graph_placement.py +95 -248
  543. lusid/models/paged_resource_list_of_order_instruction.py +113 -0
  544. lusid/models/paged_resource_list_of_package.py +113 -0
  545. lusid/models/paged_resource_list_of_participation.py +95 -248
  546. lusid/models/paged_resource_list_of_person.py +95 -248
  547. lusid/models/paged_resource_list_of_placement.py +95 -248
  548. lusid/models/paged_resource_list_of_portfolio_group.py +95 -248
  549. lusid/models/paged_resource_list_of_portfolio_group_search_result.py +95 -248
  550. lusid/models/paged_resource_list_of_portfolio_search_result.py +95 -248
  551. lusid/models/paged_resource_list_of_posting_module_response.py +113 -0
  552. lusid/models/paged_resource_list_of_posting_module_rule.py +113 -0
  553. lusid/models/paged_resource_list_of_property_definition_search_result.py +95 -248
  554. lusid/models/paged_resource_list_of_reconciliation.py +113 -0
  555. lusid/models/paged_resource_list_of_reconciliation_run.py +113 -0
  556. lusid/models/paged_resource_list_of_reconciliation_run_break.py +113 -0
  557. lusid/models/paged_resource_list_of_reference_list_response.py +95 -248
  558. lusid/models/paged_resource_list_of_relationship_definition.py +95 -248
  559. lusid/models/paged_resource_list_of_sequence_definition.py +95 -248
  560. lusid/models/paged_resource_list_of_translation_script_id.py +95 -248
  561. lusid/models/paged_resource_list_of_virtual_row.py +95 -248
  562. lusid/models/participation.py +86 -245
  563. lusid/models/participation_request.py +71 -186
  564. lusid/models/participation_set_request.py +64 -126
  565. lusid/models/performance_return.py +75 -251
  566. lusid/models/performance_returns_metric.py +83 -309
  567. lusid/models/period_type.py +41 -0
  568. lusid/models/perpetual_entity_state.py +39 -0
  569. lusid/models/perpetual_property.py +57 -157
  570. lusid/models/person.py +137 -335
  571. lusid/models/placement.py +161 -698
  572. lusid/models/placement_request.py +136 -614
  573. lusid/models/placement_set_request.py +64 -126
  574. lusid/models/portfolio.py +187 -688
  575. lusid/models/portfolio_cash_flow.py +139 -593
  576. lusid/models/portfolio_cash_ladder.py +116 -250
  577. lusid/models/portfolio_details.py +130 -491
  578. lusid/models/portfolio_entity_id.py +90 -210
  579. lusid/models/portfolio_group.py +138 -402
  580. lusid/models/portfolio_group_id_compliance_parameter.py +77 -164
  581. lusid/models/portfolio_group_id_list.py +81 -167
  582. lusid/models/portfolio_group_id_list_compliance_parameter.py +77 -164
  583. lusid/models/portfolio_group_properties.py +97 -215
  584. lusid/models/portfolio_group_search_result.py +123 -372
  585. lusid/models/portfolio_holding.py +142 -644
  586. lusid/models/portfolio_id_compliance_parameter.py +77 -164
  587. lusid/models/portfolio_id_list.py +81 -167
  588. lusid/models/portfolio_id_list_compliance_parameter.py +77 -164
  589. lusid/models/portfolio_properties.py +97 -215
  590. lusid/models/portfolio_reconciliation_request.py +65 -192
  591. lusid/models/portfolio_result_data_key_rule.py +133 -392
  592. lusid/models/portfolio_return_breakdown.py +109 -492
  593. lusid/models/portfolio_search_result.py +128 -442
  594. lusid/models/portfolio_trade_ticket.py +79 -0
  595. lusid/models/portfolio_type.py +39 -0
  596. lusid/models/portfolios_reconciliation_request.py +62 -188
  597. lusid/models/posting_module_details.py +95 -0
  598. lusid/models/posting_module_request.py +117 -0
  599. lusid/models/posting_module_response.py +139 -0
  600. lusid/models/posting_module_rule.py +94 -0
  601. lusid/models/posting_module_rules_updated_response.py +110 -0
  602. lusid/models/premium.py +56 -193
  603. lusid/models/pricing_context.py +105 -215
  604. lusid/models/pricing_model.py +54 -0
  605. lusid/models/pricing_options.py +80 -434
  606. lusid/models/processed_command.py +67 -224
  607. lusid/models/property_definition.py +221 -736
  608. lusid/models/property_definition_search_result.py +202 -648
  609. lusid/models/property_definition_type.py +38 -0
  610. lusid/models/property_domain.py +73 -0
  611. lusid/models/property_filter.py +87 -228
  612. lusid/models/property_interval.py +68 -221
  613. lusid/models/property_key_compliance_parameter.py +73 -166
  614. lusid/models/property_key_list_compliance_parameter.py +77 -164
  615. lusid/models/property_life_time.py +38 -0
  616. lusid/models/property_schema.py +91 -182
  617. lusid/models/property_type.py +39 -0
  618. lusid/models/property_value.py +68 -184
  619. lusid/models/property_value_equals.py +93 -0
  620. lusid/models/property_value_in.py +93 -0
  621. lusid/models/query_bucketed_cash_flows_request.py +162 -0
  622. lusid/models/query_cash_flows_request.py +96 -0
  623. lusid/models/query_instrument_events_request.py +113 -0
  624. lusid/models/query_trade_tickets_request.py +96 -0
  625. lusid/models/quote.py +87 -313
  626. lusid/models/quote_access_metadata_rule.py +92 -0
  627. lusid/models/quote_access_metadata_rule_id.py +129 -0
  628. lusid/models/quote_dependency.py +78 -240
  629. lusid/models/quote_id.py +57 -161
  630. lusid/models/quote_instrument_id_type.py +45 -0
  631. lusid/models/quote_series_id.py +96 -303
  632. lusid/models/quote_type.py +50 -0
  633. lusid/models/raw_vendor_event.py +84 -232
  634. lusid/models/realised_gain_loss.py +115 -462
  635. lusid/models/reconcile_date_time_rule.py +88 -233
  636. lusid/models/reconcile_numeric_rule.py +88 -233
  637. lusid/models/reconcile_string_rule.py +102 -232
  638. lusid/models/reconciled_transaction.py +69 -215
  639. lusid/models/reconciliation.py +165 -0
  640. lusid/models/reconciliation_break.py +105 -411
  641. lusid/models/reconciliation_break_id.py +88 -0
  642. lusid/models/reconciliation_configuration.py +84 -0
  643. lusid/models/reconciliation_id.py +80 -0
  644. lusid/models/reconciliation_left_right_address_key_pair.py +53 -160
  645. lusid/models/reconciliation_line.py +77 -216
  646. lusid/models/reconciliation_request.py +97 -246
  647. lusid/models/reconciliation_response.py +70 -155
  648. lusid/models/reconciliation_rule.py +74 -143
  649. lusid/models/reconciliation_rule_type.py +40 -0
  650. lusid/models/reconciliation_run.py +95 -0
  651. lusid/models/reconciliation_run_break.py +116 -0
  652. lusid/models/reconciliation_run_id.py +85 -0
  653. lusid/models/reconciliation_side_configuration.py +94 -0
  654. lusid/models/reconciliation_transactions.py +79 -0
  655. lusid/models/reference_data.py +69 -156
  656. lusid/models/reference_instrument.py +77 -239
  657. lusid/models/reference_list.py +77 -146
  658. lusid/models/reference_list_request.py +77 -251
  659. lusid/models/reference_list_response.py +98 -311
  660. lusid/models/reference_list_type.py +42 -0
  661. lusid/models/reference_portfolio_constituent.py +96 -307
  662. lusid/models/reference_portfolio_constituent_request.py +80 -214
  663. lusid/models/reference_portfolio_weight_type.py +39 -0
  664. lusid/models/related_entity.py +105 -349
  665. lusid/models/relation.py +70 -281
  666. lusid/models/relation_definition.py +143 -0
  667. lusid/models/relationship.py +76 -318
  668. lusid/models/relationship_definition.py +111 -448
  669. lusid/models/repo.py +136 -476
  670. lusid/models/reset_event.py +92 -262
  671. lusid/models/resource_id.py +53 -172
  672. lusid/models/resource_list_of_access_controlled_resource.py +95 -248
  673. lusid/models/resource_list_of_access_metadata_value_of.py +100 -248
  674. lusid/models/resource_list_of_address_key_definition.py +95 -248
  675. lusid/models/resource_list_of_aggregated_return.py +113 -0
  676. lusid/models/resource_list_of_aggregation_query.py +95 -248
  677. lusid/models/resource_list_of_allocation.py +95 -248
  678. lusid/models/resource_list_of_block.py +95 -248
  679. lusid/models/resource_list_of_calendar_date.py +95 -248
  680. lusid/models/resource_list_of_change.py +95 -248
  681. lusid/models/resource_list_of_change_history.py +95 -248
  682. lusid/models/resource_list_of_compliance_breached_order_info.py +113 -0
  683. lusid/models/resource_list_of_compliance_rule.py +113 -0
  684. lusid/models/resource_list_of_compliance_rule_result.py +113 -0
  685. lusid/models/resource_list_of_compliance_run_info.py +113 -0
  686. lusid/models/resource_list_of_constituents_adjustment_header.py +95 -248
  687. lusid/models/resource_list_of_corporate_action.py +95 -248
  688. lusid/models/resource_list_of_data_type.py +95 -248
  689. lusid/models/resource_list_of_execution.py +95 -248
  690. lusid/models/resource_list_of_fee_rule.py +113 -0
  691. lusid/models/resource_list_of_get_cds_flow_conventions_response.py +113 -0
  692. lusid/models/resource_list_of_get_counterparty_agreement_response.py +95 -248
  693. lusid/models/resource_list_of_get_credit_support_annex_response.py +95 -248
  694. lusid/models/resource_list_of_get_flow_conventions_response.py +113 -0
  695. lusid/models/resource_list_of_get_index_convention_response.py +113 -0
  696. lusid/models/resource_list_of_get_recipe_response.py +95 -248
  697. lusid/models/resource_list_of_holdings_adjustment_header.py +95 -248
  698. lusid/models/resource_list_of_i_unit_definition_dto.py +95 -248
  699. lusid/models/resource_list_of_instrument_cash_flow.py +113 -0
  700. lusid/models/resource_list_of_instrument_event_holder.py +113 -0
  701. lusid/models/resource_list_of_instrument_id_type_descriptor.py +95 -248
  702. lusid/models/resource_list_of_legal_entity.py +95 -248
  703. lusid/models/resource_list_of_list_complex_market_data_with_meta_data_response.py +113 -0
  704. lusid/models/resource_list_of_mapping.py +95 -248
  705. lusid/models/resource_list_of_order.py +95 -248
  706. lusid/models/resource_list_of_order_instruction.py +113 -0
  707. lusid/models/resource_list_of_package.py +113 -0
  708. lusid/models/resource_list_of_participation.py +95 -248
  709. lusid/models/resource_list_of_performance_return.py +95 -248
  710. lusid/models/resource_list_of_person.py +95 -248
  711. lusid/models/resource_list_of_placement.py +95 -248
  712. lusid/models/resource_list_of_portfolio.py +95 -248
  713. lusid/models/resource_list_of_portfolio_cash_flow.py +95 -248
  714. lusid/models/resource_list_of_portfolio_cash_ladder.py +95 -248
  715. lusid/models/resource_list_of_portfolio_trade_ticket.py +113 -0
  716. lusid/models/resource_list_of_processed_command.py +95 -248
  717. lusid/models/resource_list_of_property.py +95 -248
  718. lusid/models/resource_list_of_property_definition.py +95 -248
  719. lusid/models/resource_list_of_property_interval.py +95 -248
  720. lusid/models/resource_list_of_quote.py +95 -248
  721. lusid/models/resource_list_of_quote_access_metadata_rule.py +113 -0
  722. lusid/models/resource_list_of_reconciliation_break.py +95 -248
  723. lusid/models/resource_list_of_relation.py +95 -248
  724. lusid/models/resource_list_of_relationship.py +95 -248
  725. lusid/models/resource_list_of_scope_definition.py +95 -248
  726. lusid/models/resource_list_of_side_definition.py +95 -248
  727. lusid/models/resource_list_of_string.py +87 -248
  728. lusid/models/resource_list_of_tax_rule_set.py +113 -0
  729. lusid/models/resource_list_of_transaction.py +113 -0
  730. lusid/models/resource_list_of_transaction_type.py +95 -248
  731. lusid/models/resource_list_of_value_type.py +88 -248
  732. lusid/models/response_meta_data.py +77 -216
  733. lusid/models/result_data_key_rule.py +103 -389
  734. lusid/models/result_data_schema.py +108 -184
  735. lusid/models/result_key_rule.py +74 -143
  736. lusid/models/result_key_rule_type.py +39 -0
  737. lusid/models/result_value.py +80 -149
  738. lusid/models/result_value0_d.py +87 -225
  739. lusid/models/result_value_bool.py +73 -165
  740. lusid/models/result_value_currency.py +78 -164
  741. lusid/models/result_value_date_time_offset.py +81 -196
  742. lusid/models/result_value_decimal.py +80 -195
  743. lusid/models/result_value_dictionary.py +89 -163
  744. lusid/models/result_value_int.py +80 -195
  745. lusid/models/result_value_string.py +78 -164
  746. lusid/models/result_value_type.py +48 -0
  747. lusid/models/rounding_configuration.py +55 -125
  748. lusid/models/rounding_configuration_component.py +51 -131
  749. lusid/models/rounding_convention.py +67 -218
  750. lusid/models/scaling_methodology.py +39 -0
  751. lusid/models/schedule.py +77 -143
  752. lusid/models/schedule_type.py +43 -0
  753. lusid/models/scope_definition.py +51 -131
  754. lusid/models/sequence_definition.py +94 -376
  755. lusid/models/set_legal_entity_identifiers_request.py +69 -126
  756. lusid/models/set_legal_entity_properties_request.py +69 -126
  757. lusid/models/set_person_identifiers_request.py +69 -126
  758. lusid/models/set_person_properties_request.py +64 -128
  759. lusid/models/set_transaction_configuration_alias.py +84 -0
  760. lusid/models/set_transaction_configuration_source_request.py +107 -0
  761. lusid/models/side_configuration_data.py +76 -336
  762. lusid/models/side_configuration_data_request.py +79 -0
  763. lusid/models/side_definition.py +90 -390
  764. lusid/models/side_definition_request.py +66 -322
  765. lusid/models/sides_definition_request.py +64 -164
  766. lusid/models/simple_cash_flow_loan.py +88 -263
  767. lusid/models/simple_instrument.py +94 -301
  768. lusid/models/sort_order.py +38 -0
  769. lusid/models/step_schedule.py +85 -236
  770. lusid/models/stock_split_event.py +78 -231
  771. lusid/models/stream.py +70 -328
  772. lusid/models/string_comparison_type.py +41 -0
  773. lusid/models/string_compliance_parameter.py +73 -167
  774. lusid/models/string_list.py +73 -170
  775. lusid/models/string_list_compliance_parameter.py +77 -164
  776. lusid/models/structured_result_data.py +91 -0
  777. lusid/models/structured_result_data_id.py +107 -0
  778. lusid/models/sub_holding_key_value_equals.py +93 -0
  779. lusid/models/target_tax_lot.py +86 -278
  780. lusid/models/target_tax_lot_request.py +86 -278
  781. lusid/models/tax_rule.py +97 -0
  782. lusid/models/tax_rule_set.py +124 -0
  783. lusid/models/term_deposit.py +93 -323
  784. lusid/models/total_return_swap.py +88 -259
  785. lusid/models/touch.py +62 -228
  786. lusid/models/trade_ticket.py +76 -0
  787. lusid/models/trade_ticket_type.py +38 -0
  788. lusid/models/transaction.py +181 -782
  789. lusid/models/transaction_configuration_data.py +89 -190
  790. lusid/models/transaction_configuration_data_request.py +89 -190
  791. lusid/models/transaction_configuration_movement_data.py +110 -320
  792. lusid/models/transaction_configuration_movement_data_request.py +110 -320
  793. lusid/models/transaction_configuration_type_alias.py +90 -339
  794. lusid/models/transaction_price.py +63 -162
  795. lusid/models/transaction_price_type.py +39 -0
  796. lusid/models/transaction_property_mapping.py +65 -188
  797. lusid/models/transaction_property_mapping_request.py +65 -188
  798. lusid/models/transaction_query_mode.py +38 -0
  799. lusid/models/transaction_query_parameters.py +67 -234
  800. lusid/models/transaction_reconciliation_request.py +84 -302
  801. lusid/models/transaction_reconciliation_request_v2.py +115 -0
  802. lusid/models/transaction_request.py +143 -625
  803. lusid/models/transaction_roles.py +44 -0
  804. lusid/models/transaction_set_configuration_data.py +89 -188
  805. lusid/models/transaction_set_configuration_data_request.py +92 -0
  806. lusid/models/transaction_status.py +39 -0
  807. lusid/models/transaction_type.py +119 -250
  808. lusid/models/transaction_type_alias.py +80 -282
  809. lusid/models/transaction_type_calculation.py +60 -172
  810. lusid/models/transaction_type_movement.py +128 -366
  811. lusid/models/transaction_type_property_mapping.py +75 -197
  812. lusid/models/transaction_type_request.py +104 -220
  813. lusid/models/transactions_reconciliations_response.py +70 -155
  814. lusid/models/transition_event.py +101 -318
  815. lusid/models/translate_entities_inlined_request.py +72 -195
  816. lusid/models/translate_entities_request.py +76 -187
  817. lusid/models/translate_entities_response.py +104 -186
  818. lusid/models/translate_instrument_definitions_request.py +91 -0
  819. lusid/models/translate_instrument_definitions_response.py +129 -0
  820. lusid/models/translate_trade_ticket_request.py +91 -0
  821. lusid/models/translate_trade_tickets_response.py +129 -0
  822. lusid/models/translation_input.py +51 -134
  823. lusid/models/translation_result.py +66 -163
  824. lusid/models/translation_script.py +57 -193
  825. lusid/models/translation_script_id.py +76 -219
  826. lusid/models/trial_balance.py +103 -0
  827. lusid/models/trial_balance_query_parameters.py +102 -0
  828. lusid/models/trigger_event.py +82 -301
  829. lusid/models/typed_resource_id.py +76 -219
  830. lusid/models/underlying_leg.py +75 -0
  831. lusid/models/unit_schema.py +39 -0
  832. lusid/models/unmatched_holding_method.py +38 -0
  833. lusid/models/update_calendar_request.py +74 -195
  834. lusid/models/update_custom_entity_definition_request.py +77 -204
  835. lusid/models/update_custom_entity_type_request.py +77 -204
  836. lusid/models/update_cut_label_definition_request.py +83 -226
  837. lusid/models/update_data_type_request.py +105 -234
  838. lusid/models/update_derived_property_definition_request.py +66 -229
  839. lusid/models/update_instrument_identifier_request.py +65 -191
  840. lusid/models/update_portfolio_group_request.py +58 -161
  841. lusid/models/update_portfolio_request.py +58 -161
  842. lusid/models/update_property_definition_request.py +58 -164
  843. lusid/models/update_reconciliation_request.py +131 -0
  844. lusid/models/update_relationship_definition_request.py +76 -219
  845. lusid/models/update_tax_rule_set_request.py +95 -0
  846. lusid/models/update_unit_request.py +100 -207
  847. lusid/models/upsert_cds_flow_conventions_request.py +73 -0
  848. lusid/models/upsert_complex_market_data_request.py +61 -156
  849. lusid/models/upsert_compliance_rule_request.py +113 -380
  850. lusid/models/upsert_compliance_run_summary_request.py +72 -250
  851. lusid/models/upsert_corporate_action_request.py +94 -337
  852. lusid/models/upsert_corporate_actions_response.py +111 -216
  853. lusid/models/upsert_counterparty_agreement_request.py +55 -126
  854. lusid/models/upsert_credit_support_annex_request.py +55 -125
  855. lusid/models/upsert_custom_entities_response.py +111 -216
  856. lusid/models/upsert_custom_entity_access_metadata_request.py +64 -126
  857. lusid/models/upsert_flow_conventions_request.py +73 -0
  858. lusid/models/upsert_index_convention_request.py +73 -0
  859. lusid/models/upsert_instrument_event_request.py +98 -329
  860. lusid/models/upsert_instrument_events_response.py +111 -216
  861. lusid/models/upsert_instrument_properties_response.py +67 -159
  862. lusid/models/upsert_instrument_property_request.py +68 -196
  863. lusid/models/upsert_instruments_response.py +135 -246
  864. lusid/models/upsert_legal_entities_response.py +111 -216
  865. lusid/models/upsert_legal_entity_access_metadata_request.py +64 -126
  866. lusid/models/upsert_legal_entity_request.py +115 -267
  867. lusid/models/upsert_person_access_metadata_request.py +64 -126
  868. lusid/models/upsert_person_request.py +92 -232
  869. lusid/models/upsert_portfolio_access_metadata_request.py +59 -128
  870. lusid/models/upsert_portfolio_group_access_metadata_request.py +59 -128
  871. lusid/models/upsert_portfolio_transactions_response.py +101 -216
  872. lusid/models/upsert_quote_access_metadata_rule_request.py +92 -0
  873. lusid/models/upsert_quote_request.py +75 -215
  874. lusid/models/upsert_quotes_response.py +111 -216
  875. lusid/models/upsert_recipe_request.py +61 -125
  876. lusid/models/upsert_reconciliation_break_request.py +98 -0
  877. lusid/models/upsert_reconciliation_run_request.py +71 -0
  878. lusid/models/upsert_reference_portfolio_constituents_request.py +94 -265
  879. lusid/models/upsert_reference_portfolio_constituents_response.py +77 -183
  880. lusid/models/upsert_result_values_data_request.py +93 -0
  881. lusid/models/upsert_returns_response.py +100 -247
  882. lusid/models/upsert_single_structured_data_response.py +74 -188
  883. lusid/models/upsert_structured_data_response.py +99 -217
  884. lusid/models/upsert_structured_result_data_request.py +79 -0
  885. lusid/models/upsert_transaction_properties_response.py +97 -213
  886. lusid/models/user.py +56 -126
  887. lusid/models/valuation_request.py +156 -528
  888. lusid/models/valuation_schedule.py +86 -329
  889. lusid/models/valuations_reconciliation_request.py +82 -216
  890. lusid/models/value_type.py +34 -116
  891. lusid/models/vendor_dependency.py +95 -0
  892. lusid/models/vendor_library.py +43 -0
  893. lusid/models/vendor_model_rule.py +97 -335
  894. lusid/models/version.py +110 -371
  895. lusid/models/version_summary_dto.py +85 -210
  896. lusid/models/versioned_resource_list_of_a2_b_data_record.py +101 -278
  897. lusid/models/versioned_resource_list_of_a2_b_movement_record.py +101 -278
  898. lusid/models/versioned_resource_list_of_holding_contributor.py +101 -278
  899. lusid/models/versioned_resource_list_of_journal_entry_line.py +119 -0
  900. lusid/models/versioned_resource_list_of_output_transaction.py +101 -278
  901. lusid/models/versioned_resource_list_of_portfolio_holding.py +101 -278
  902. lusid/models/versioned_resource_list_of_transaction.py +101 -278
  903. lusid/models/versioned_resource_list_of_trial_balance.py +119 -0
  904. lusid/models/versioned_resource_list_with_warnings_of_portfolio_holding.py +134 -0
  905. lusid/models/virtual_document.py +88 -0
  906. lusid/models/virtual_document_row.py +80 -0
  907. lusid/models/virtual_row.py +76 -156
  908. lusid/models/warning.py +71 -0
  909. lusid/models/weekend_mask.py +61 -165
  910. lusid/models/weighted_instrument.py +64 -220
  911. lusid/models/weighted_instruments.py +59 -128
  912. lusid/models/yield_curve_data.py +107 -296
  913. lusid/py.typed +0 -0
  914. lusid/rest.py +171 -237
  915. lusid_sdk-2.0.50b0.dist-info/METADATA +1460 -0
  916. lusid_sdk-2.0.50b0.dist-info/RECORD +917 -0
  917. {lusid_sdk-1.1.118.dist-info → lusid_sdk-2.0.50b0.dist-info}/WHEEL +1 -2
  918. lusid/__version__.py +0 -1
  919. lusid/models/accumulation_event.py +0 -310
  920. lusid/models/accumulation_event_all_of.py +0 -310
  921. lusid/models/address_key_compliance_parameter_all_of.py +0 -184
  922. lusid/models/address_key_list_all_of.py +0 -188
  923. lusid/models/address_key_list_compliance_parameter_all_of.py +0 -182
  924. lusid/models/amortisation_event_all_of.py +0 -283
  925. lusid/models/asset_leg.py +0 -179
  926. lusid/models/basket_all_of.py +0 -247
  927. lusid/models/block_and_order_id_request.py +0 -174
  928. lusid/models/block_and_orders.py +0 -174
  929. lusid/models/block_and_orders_create_request.py +0 -152
  930. lusid/models/block_and_orders_request.py +0 -422
  931. lusid/models/blocked_order_request.py +0 -412
  932. lusid/models/bond_all_of.py +0 -581
  933. lusid/models/bond_coupon_event.py +0 -280
  934. lusid/models/bond_coupon_event_all_of.py +0 -280
  935. lusid/models/bond_default_event_all_of.py +0 -184
  936. lusid/models/bond_principal_event.py +0 -280
  937. lusid/models/bond_principal_event_all_of.py +0 -280
  938. lusid/models/bool_compliance_parameter_all_of.py +0 -182
  939. lusid/models/branch_step.py +0 -219
  940. lusid/models/branch_step_all_of.py +0 -219
  941. lusid/models/calendar_dependency_all_of.py +0 -184
  942. lusid/models/cap_floor_all_of.py +0 -313
  943. lusid/models/cash_dependency_all_of.py +0 -216
  944. lusid/models/cash_dividend_event_all_of.py +0 -308
  945. lusid/models/cash_election.py +0 -334
  946. lusid/models/cash_flow_event_all_of.py +0 -217
  947. lusid/models/cash_flow_value_all_of.py +0 -306
  948. lusid/models/cash_flow_value_set_all_of.py +0 -182
  949. lusid/models/cash_perpetual_all_of.py +0 -248
  950. lusid/models/cds_index_all_of.py +0 -399
  951. lusid/models/check_step.py +0 -251
  952. lusid/models/check_step_all_of.py +0 -251
  953. lusid/models/close_event_all_of.py +0 -214
  954. lusid/models/complex_bond_all_of.py +0 -338
  955. lusid/models/compliance_rule_result_v2.py +0 -267
  956. lusid/models/compliance_step.py +0 -167
  957. lusid/models/constant_volatility_surface.py +0 -285
  958. lusid/models/constant_volatility_surface_all_of.py +0 -285
  959. lusid/models/contract_for_difference_all_of.py +0 -447
  960. lusid/models/create_trade_tickets_response.py +0 -174
  961. lusid/models/credit_default_swap_all_of.py +0 -401
  962. lusid/models/credit_spread_curve_data_all_of.py +0 -437
  963. lusid/models/date_time_compliance_parameter_all_of.py +0 -182
  964. lusid/models/decimal_compliance_parameter_all_of.py +0 -182
  965. lusid/models/decimal_list_all_of.py +0 -188
  966. lusid/models/discount_factor_curve_data_all_of.py +0 -313
  967. lusid/models/discounting_dependency_all_of.py +0 -216
  968. lusid/models/dividend_option_event.py +0 -371
  969. lusid/models/dividend_option_event_all_of.py +0 -371
  970. lusid/models/dividend_reinvestment_event.py +0 -342
  971. lusid/models/dividend_reinvestment_event_all_of.py +0 -342
  972. lusid/models/empty_model_options_all_of.py +0 -152
  973. lusid/models/equity_all_of.py +0 -243
  974. lusid/models/equity_curve_by_prices_data_all_of.py +0 -313
  975. lusid/models/equity_curve_dependency_all_of.py +0 -298
  976. lusid/models/equity_model_options_all_of.py +0 -187
  977. lusid/models/equity_option_all_of.py +0 -571
  978. lusid/models/equity_swap_all_of.py +0 -504
  979. lusid/models/equity_vol_dependency_all_of.py +0 -292
  980. lusid/models/equity_vol_surface_data_all_of.py +0 -284
  981. lusid/models/exchange_traded_option_all_of.py +0 -278
  982. lusid/models/exercise_event_all_of.py +0 -245
  983. lusid/models/exotic_instrument_all_of.py +0 -217
  984. lusid/models/filter_predicate_compliance_parameter.py +0 -185
  985. lusid/models/filter_predicate_compliance_parameter_all_of.py +0 -185
  986. lusid/models/filter_step.py +0 -219
  987. lusid/models/fixed_leg_all_of.py +0 -304
  988. lusid/models/flexible_loan.py +0 -280
  989. lusid/models/flexible_loan_all_of.py +0 -280
  990. lusid/models/floating_leg_all_of.py +0 -366
  991. lusid/models/forward_rate_agreement_all_of.py +0 -373
  992. lusid/models/fund_share_class.py +0 -324
  993. lusid/models/fund_share_class_all_of.py +0 -324
  994. lusid/models/funding_leg_all_of.py +0 -276
  995. lusid/models/future_all_of.py +0 -405
  996. lusid/models/fx_conventions.py +0 -216
  997. lusid/models/fx_dependency_all_of.py +0 -248
  998. lusid/models/fx_forward_all_of.py +0 -498
  999. lusid/models/fx_forward_curve_by_quote_reference_all_of.py +0 -405
  1000. lusid/models/fx_forward_curve_data_all_of.py +0 -377
  1001. lusid/models/fx_forward_model_options_all_of.py +0 -260
  1002. lusid/models/fx_forward_pips_curve_data_all_of.py +0 -377
  1003. lusid/models/fx_forward_settlement_event.py +0 -494
  1004. lusid/models/fx_forward_settlement_event_all_of.py +0 -494
  1005. lusid/models/fx_forward_tenor_curve_data_all_of.py +0 -437
  1006. lusid/models/fx_forward_tenor_pips_curve_data_all_of.py +0 -437
  1007. lusid/models/fx_forwards_dependency_all_of.py +0 -286
  1008. lusid/models/fx_linked_notional_schedule.py +0 -273
  1009. lusid/models/fx_linked_notional_schedule_all_of.py +0 -273
  1010. lusid/models/fx_option_all_of.py +0 -646
  1011. lusid/models/fx_swap_all_of.py +0 -242
  1012. lusid/models/fx_vol_dependency_all_of.py +0 -286
  1013. lusid/models/group_by_selector_compliance_parameter.py +0 -185
  1014. lusid/models/group_by_step.py +0 -219
  1015. lusid/models/group_filter_predicate_compliance_parameter.py +0 -185
  1016. lusid/models/group_filter_step.py +0 -251
  1017. lusid/models/group_of_market_data_key_rules.py +0 -181
  1018. lusid/models/index_model_options_all_of.py +0 -190
  1019. lusid/models/index_projection_dependency_all_of.py +0 -292
  1020. lusid/models/inflation_fixing_dependency_all_of.py +0 -254
  1021. lusid/models/inflation_leg_all_of.py +0 -472
  1022. lusid/models/inflation_linked_bond_all_of.py +0 -612
  1023. lusid/models/inflation_swap_all_of.py +0 -276
  1024. lusid/models/informational_error_event_all_of.py +0 -254
  1025. lusid/models/informational_event_all_of.py +0 -279
  1026. lusid/models/instrument_event_configuration.py +0 -142
  1027. lusid/models/instrument_leg_all_of.py +0 -152
  1028. lusid/models/instrument_list_all_of.py +0 -188
  1029. lusid/models/interest_rate_swap_all_of.py +0 -339
  1030. lusid/models/interest_rate_swaption_all_of.py +0 -313
  1031. lusid/models/ir_vol_cube_data_all_of.py +0 -284
  1032. lusid/models/ir_vol_dependency_all_of.py +0 -254
  1033. lusid/models/life_cycle_event_value_all_of.py +0 -241
  1034. lusid/models/lineage_member.py +0 -294
  1035. lusid/models/look_up_pricing_model_options_all_of.py +0 -216
  1036. lusid/models/maturity_event.py +0 -184
  1037. lusid/models/maturity_event_all_of.py +0 -184
  1038. lusid/models/move_orders_to_different_blocks_request.py +0 -152
  1039. lusid/models/moved_order_to_different_block_response.py +0 -201
  1040. lusid/models/opaque_dependency_all_of.py +0 -152
  1041. lusid/models/opaque_market_data_all_of.py +0 -293
  1042. lusid/models/opaque_model_options_all_of.py +0 -182
  1043. lusid/models/open_event_all_of.py +0 -183
  1044. lusid/models/paged_resource_list_of_property_definition.py +0 -266
  1045. lusid/models/place_blocks_request.py +0 -152
  1046. lusid/models/portfolio_group_id_list_all_of.py +0 -185
  1047. lusid/models/portfolio_result_data_key_rule_all_of.py +0 -409
  1048. lusid/models/property_key_compliance_parameter_all_of.py +0 -184
  1049. lusid/models/quote_dependency_all_of.py +0 -257
  1050. lusid/models/raw_vendor_event_all_of.py +0 -249
  1051. lusid/models/recombine_step.py +0 -219
  1052. lusid/models/reconcile_date_time_rule_all_of.py +0 -251
  1053. lusid/models/reconcile_numeric_rule_all_of.py +0 -251
  1054. lusid/models/reconcile_string_rule_all_of.py +0 -250
  1055. lusid/models/reference_instrument_all_of.py +0 -257
  1056. lusid/models/relative_date_offset.py +0 -181
  1057. lusid/models/repo_all_of.py +0 -493
  1058. lusid/models/reset_event_all_of.py +0 -279
  1059. lusid/models/resource_list_of_block_and_orders.py +0 -266
  1060. lusid/models/resource_list_of_moved_order_to_different_block_response.py +0 -266
  1061. lusid/models/result_data_key_rule_all_of.py +0 -406
  1062. lusid/models/result_value0_d_all_of.py +0 -243
  1063. lusid/models/result_value_bool_all_of.py +0 -183
  1064. lusid/models/result_value_currency_all_of.py +0 -182
  1065. lusid/models/result_value_date_time_offset_all_of.py +0 -213
  1066. lusid/models/result_value_decimal_all_of.py +0 -213
  1067. lusid/models/result_value_dictionary_all_of.py +0 -182
  1068. lusid/models/result_value_int_all_of.py +0 -213
  1069. lusid/models/result_value_string_all_of.py +0 -182
  1070. lusid/models/schema.py +0 -228
  1071. lusid/models/script_map_reference.py +0 -237
  1072. lusid/models/security_election.py +0 -270
  1073. lusid/models/simple_cash_flow_loan_all_of.py +0 -280
  1074. lusid/models/simple_instrument_all_of.py +0 -318
  1075. lusid/models/step_schedule_all_of.py +0 -254
  1076. lusid/models/stock_split_event_all_of.py +0 -248
  1077. lusid/models/string_compliance_parameter_all_of.py +0 -185
  1078. lusid/models/term_deposit_all_of.py +0 -340
  1079. lusid/models/total_return_swap_all_of.py +0 -276
  1080. lusid/models/transition_event_all_of.py +0 -335
  1081. lusid/models/translation_context.py +0 -172
  1082. lusid/models/trigger_event_all_of.py +0 -318
  1083. lusid/models/units_ratio.py +0 -178
  1084. lusid/models/upsert_compliance_run_summary_result.py +0 -267
  1085. lusid/models/upsert_dialect_request.py +0 -174
  1086. lusid/models/upsert_translation_script_request.py +0 -182
  1087. lusid/models/weighted_instrument_in_line_lookup_identifiers.py +0 -433
  1088. lusid/models/yield_curve_data_all_of.py +0 -313
  1089. lusid/tcp/__init__.py +0 -1
  1090. lusid/tcp/tcp_keep_alive_probes.py +0 -110
  1091. lusid/utilities/__init__.py +0 -8
  1092. lusid/utilities/api_client_builder.py +0 -145
  1093. lusid/utilities/api_client_factory.py +0 -132
  1094. lusid/utilities/api_configuration_loader.py +0 -87
  1095. lusid/utilities/config_keys.json +0 -50
  1096. lusid/utilities/config_keys.py +0 -13
  1097. lusid/utilities/lusid_retry.py +0 -47
  1098. lusid_sdk-1.1.118.dist-info/METADATA +0 -21
  1099. lusid_sdk-1.1.118.dist-info/RECORD +0 -848
  1100. lusid_sdk-1.1.118.dist-info/top_level.txt +0 -1
@@ -5,113 +5,1008 @@
5
5
 
6
6
  FINBOURNE Technology # noqa: E501
7
7
 
8
- The version of the OpenAPI document: 1.1.118
9
8
  Contact: info@finbourne.com
10
- Generated by: https://openapi-generator.tech
9
+ Generated by OpenAPI Generator (https://openapi-generator.tech)
10
+
11
+ Do not edit the class manually.
11
12
  """
12
13
 
13
14
 
14
- from __future__ import absolute_import
15
+ import re # noqa: F401
16
+ import io
17
+ import warnings
18
+
19
+ from pydantic import validate_arguments, ValidationError
20
+ from typing import overload, Optional, Union, Awaitable
21
+
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
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
33
+ from lusid.models.get_structured_result_data_response import GetStructuredResultDataResponse
34
+ from lusid.models.get_virtual_document_response import GetVirtualDocumentResponse
35
+ from lusid.models.paged_resource_list_of_virtual_row import PagedResourceListOfVirtualRow
36
+ from lusid.models.resource_list_of_address_key_definition import ResourceListOfAddressKeyDefinition
37
+ from lusid.models.structured_result_data_id import StructuredResultDataId
38
+ from lusid.models.upsert_result_values_data_request import UpsertResultValuesDataRequest
39
+ from lusid.models.upsert_structured_data_response import UpsertStructuredDataResponse
40
+ from lusid.models.upsert_structured_result_data_request import UpsertStructuredResultDataRequest
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
+ )
48
+
49
+
50
+ class StructuredResultDataApi:
51
+ """NOTE: This class is auto generated by OpenAPI Generator
52
+ Ref: https://openapi-generator.tech
53
+
54
+ Do not edit the class manually.
55
+ """
56
+
57
+ def __init__(self, api_client=None) -> None:
58
+ if api_client is None:
59
+ api_client = ApiClient.get_default()
60
+ self.api_client = api_client
61
+
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
73
+
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
75
+ This method makes a synchronous HTTP request by default. To make an
76
+ asynchronous HTTP request, please pass async_req=True
77
+
78
+ >>> thread = api.create_data_map(scope, request_body, async_req=True)
79
+ >>> result = thread.get()
80
+
81
+ :param scope: The scope in which to create or update data maps. (required)
82
+ :type scope: str
83
+ :param request_body: Individual data map creation requests. (required)
84
+ :type request_body: Dict[str, CreateDataMapRequest]
85
+ :param async_req: Whether to execute the request asynchronously.
86
+ :type async_req: bool, optional
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.
91
+ :return: Returns the result object.
92
+ If the method is called asynchronously,
93
+ returns the request thread.
94
+ :rtype: UpsertStructuredDataResponse
95
+ """
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
102
+ return self.create_data_map_with_http_info(scope, request_body, **kwargs) # noqa: E501
103
+
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
107
+
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
109
+ This method makes a synchronous HTTP request by default. To make an
110
+ asynchronous HTTP request, please pass async_req=True
111
+
112
+ >>> thread = api.create_data_map_with_http_info(scope, request_body, async_req=True)
113
+ >>> result = thread.get()
114
+
115
+ :param scope: The scope in which to create or update data maps. (required)
116
+ :type scope: str
117
+ :param request_body: Individual data map creation requests. (required)
118
+ :type request_body: Dict[str, CreateDataMapRequest]
119
+ :param async_req: Whether to execute the request asynchronously.
120
+ :type async_req: bool, optional
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.
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
129
+ :param _request_timeout: timeout setting for this request. If one
130
+ number provided, it will be total request
131
+ timeout. It can also be a pair (tuple) of
132
+ (connection, read) timeouts.
133
+ :param _request_auth: set to override the auth_settings for an a single
134
+ request; this effectively ignores the authentication
135
+ in the spec for a single request.
136
+ :type _request_auth: dict, optional
137
+ :type _content_type: string, optional: force content-type for the request
138
+ :return: Returns the result object.
139
+ If the method is called asynchronously,
140
+ returns the request thread.
141
+ :rtype: tuple(UpsertStructuredDataResponse, status_code(int), headers(HTTPHeaderDict))
142
+ """
143
+
144
+ _params = locals()
145
+
146
+ _all_params = [
147
+ 'scope',
148
+ 'request_body'
149
+ ]
150
+ _all_params.extend(
151
+ [
152
+ 'async_req',
153
+ '_return_http_data_only',
154
+ '_preload_content',
155
+ '_request_timeout',
156
+ '_request_auth',
157
+ '_content_type',
158
+ '_headers'
159
+ ]
160
+ )
161
+
162
+ # validate the arguments
163
+ for _key, _val in _params['kwargs'].items():
164
+ if _key not in _all_params:
165
+ raise ApiTypeError(
166
+ "Got an unexpected keyword argument '%s'"
167
+ " to method create_data_map" % _key
168
+ )
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(
194
+ ['text/plain', 'application/json', 'text/json']) # noqa: E501
195
+
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
205
+
206
+ _response_types_map = {
207
+ '200': "UpsertStructuredDataResponse",
208
+ '400': "LusidValidationProblemDetails",
209
+ }
210
+
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
243
+
244
+ >>> thread = api.delete_structured_result_data(scope, request_body, async_req=True)
245
+ >>> result = thread.get()
246
+
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",
375
+ }
376
+
377
+ return self.api_client.call_api(
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
404
+ """[EARLY ACCESS] GetAddressKeyDefinitionsForDocument: Get AddressKeyDefinitions for a virtual document. # noqa: E501
405
+
406
+ For a given virtual document retrieve all the address key definitions that are in use. # noqa: E501
407
+ This method makes a synchronous HTTP request by default. To make an
408
+ asynchronous HTTP request, please pass async_req=True
409
+
410
+ >>> thread = api.get_address_key_definitions_for_document(scope, code, source, result_type, effective_at, as_at, async_req=True)
411
+ >>> result = thread.get()
412
+
413
+ :param scope: The scope of the document for which address key definitions are retrieved. (required)
414
+ :type scope: str
415
+ :param code: The code of the document for which address key definitions are retrieved. (required)
416
+ :type code: str
417
+ :param source: The source of the document for which address key definitions are retrieved. (required)
418
+ :type source: str
419
+ :param result_type: The result type of the document for which address key definitions are retrieved. (required)
420
+ :type result_type: str
421
+ :param effective_at: The effective datetime to query the document for which the address key definitions are retrieved. Defaults to querying the latest version if not specified.
422
+ :type effective_at: str
423
+ :param as_at: The asAt datetime to query the document for which the address key definitions are retrieved. Defaults to querying the latest version if not specified.
424
+ :type as_at: datetime
425
+ :param async_req: Whether to execute the request asynchronously.
426
+ :type async_req: bool, optional
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.
431
+ :return: Returns the result object.
432
+ If the method is called asynchronously,
433
+ returns the request thread.
434
+ :rtype: ResourceListOfAddressKeyDefinition
435
+ """
436
+ kwargs['_return_http_data_only'] = True
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
446
+ """[EARLY ACCESS] GetAddressKeyDefinitionsForDocument: Get AddressKeyDefinitions for a virtual document. # noqa: E501
447
+
448
+ For a given virtual document retrieve all the address key definitions that are in use. # noqa: E501
449
+ This method makes a synchronous HTTP request by default. To make an
450
+ asynchronous HTTP request, please pass async_req=True
451
+
452
+ >>> thread = api.get_address_key_definitions_for_document_with_http_info(scope, code, source, result_type, effective_at, as_at, async_req=True)
453
+ >>> result = thread.get()
454
+
455
+ :param scope: The scope of the document for which address key definitions are retrieved. (required)
456
+ :type scope: str
457
+ :param code: The code of the document for which address key definitions are retrieved. (required)
458
+ :type code: str
459
+ :param source: The source of the document for which address key definitions are retrieved. (required)
460
+ :type source: str
461
+ :param result_type: The result type of the document for which address key definitions are retrieved. (required)
462
+ :type result_type: str
463
+ :param effective_at: The effective datetime to query the document for which the address key definitions are retrieved. Defaults to querying the latest version if not specified.
464
+ :type effective_at: str
465
+ :param as_at: The asAt datetime to query the document for which the address key definitions are retrieved. Defaults to querying the latest version if not specified.
466
+ :type as_at: datetime
467
+ :param async_req: Whether to execute the request asynchronously.
468
+ :type async_req: bool, optional
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.
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
477
+ :param _request_timeout: timeout setting for this request. If one
478
+ number provided, it will be total request
479
+ timeout. It can also be a pair (tuple) of
480
+ (connection, read) timeouts.
481
+ :param _request_auth: set to override the auth_settings for an a single
482
+ request; this effectively ignores the authentication
483
+ in the spec for a single request.
484
+ :type _request_auth: dict, optional
485
+ :type _content_type: string, optional: force content-type for the request
486
+ :return: Returns the result object.
487
+ If the method is called asynchronously,
488
+ returns the request thread.
489
+ :rtype: tuple(ResourceListOfAddressKeyDefinition, status_code(int), headers(HTTPHeaderDict))
490
+ """
491
+
492
+ _params = locals()
493
+
494
+ _all_params = [
495
+ 'scope',
496
+ 'code',
497
+ 'source',
498
+ 'result_type',
499
+ 'effective_at',
500
+ 'as_at'
501
+ ]
502
+ _all_params.extend(
503
+ [
504
+ 'async_req',
505
+ '_return_http_data_only',
506
+ '_preload_content',
507
+ '_request_timeout',
508
+ '_request_auth',
509
+ '_content_type',
510
+ '_headers'
511
+ ]
512
+ )
513
+
514
+ # validate the arguments
515
+ for _key, _val in _params['kwargs'].items():
516
+ if _key not in _all_params:
517
+ raise ApiTypeError(
518
+ "Got an unexpected keyword argument '%s'"
519
+ " to method get_address_key_definitions_for_document" % _key
520
+ )
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(
561
+ ['text/plain', 'application/json', 'text/json']) # noqa: E501
562
+
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
+ )
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
721
+
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
728
+
729
+ # authentication setting
730
+ _auth_settings = ['oauth2'] # noqa: E501
731
+
732
+ _response_types_map = {
733
+ '200': "GetDataMapResponse",
734
+ '400': "LusidValidationProblemDetails",
735
+ }
736
+
737
+ return self.api_client.call_api(
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
765
+
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
767
+ This method makes a synchronous HTTP request by default. To make an
768
+ asynchronous HTTP request, please pass async_req=True
769
+
770
+ >>> thread = api.get_structured_result_data(scope, request_body, as_at, max_age, async_req=True)
771
+ >>> result = thread.get()
772
+
773
+ :param scope: The scope from which to retrieve data items. (required)
774
+ :type scope: str
775
+ :param request_body: The time invariant set of structured data identifiers to retrieve, keyed by a unique, ephemeral correlation ID. (required)
776
+ :type request_body: Dict[str, StructuredResultDataId]
777
+ :param as_at: The asAt datetime at which to retrieve the structured result data. Defaults to returning the latest version if not specified.
778
+ :type as_at: datetime
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.
780
+ :type max_age: str
781
+ :param async_req: Whether to execute the request asynchronously.
782
+ :type async_req: bool, optional
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.
787
+ :return: Returns the result object.
788
+ If the method is called asynchronously,
789
+ returns the request thread.
790
+ :rtype: GetStructuredResultDataResponse
791
+ """
792
+ kwargs['_return_http_data_only'] = True
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
799
+
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
803
+
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
805
+ This method makes a synchronous HTTP request by default. To make an
806
+ asynchronous HTTP request, please pass async_req=True
807
+
808
+ >>> thread = api.get_structured_result_data_with_http_info(scope, request_body, as_at, max_age, async_req=True)
809
+ >>> result = thread.get()
810
+
811
+ :param scope: The scope from which to retrieve data items. (required)
812
+ :type scope: str
813
+ :param request_body: The time invariant set of structured data identifiers to retrieve, keyed by a unique, ephemeral correlation ID. (required)
814
+ :type request_body: Dict[str, StructuredResultDataId]
815
+ :param as_at: The asAt datetime at which to retrieve the structured result data. Defaults to returning the latest version if not specified.
816
+ :type as_at: datetime
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.
818
+ :type max_age: str
819
+ :param async_req: Whether to execute the request asynchronously.
820
+ :type async_req: bool, optional
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.
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
829
+ :param _request_timeout: timeout setting for this request. If one
830
+ number provided, it will be total request
831
+ timeout. It can also be a pair (tuple) of
832
+ (connection, read) timeouts.
833
+ :param _request_auth: set to override the auth_settings for an a single
834
+ request; this effectively ignores the authentication
835
+ in the spec for a single request.
836
+ :type _request_auth: dict, optional
837
+ :type _content_type: string, optional: force content-type for the request
838
+ :return: Returns the result object.
839
+ If the method is called asynchronously,
840
+ returns the request thread.
841
+ :rtype: tuple(GetStructuredResultDataResponse, status_code(int), headers(HTTPHeaderDict))
842
+ """
843
+
844
+ _params = locals()
845
+
846
+ _all_params = [
847
+ 'scope',
848
+ 'request_body',
849
+ 'as_at',
850
+ 'max_age'
851
+ ]
852
+ _all_params.extend(
853
+ [
854
+ 'async_req',
855
+ '_return_http_data_only',
856
+ '_preload_content',
857
+ '_request_timeout',
858
+ '_request_auth',
859
+ '_content_type',
860
+ '_headers'
861
+ ]
862
+ )
15
863
 
16
- import re # noqa: F401
864
+ # validate the arguments
865
+ for _key, _val in _params['kwargs'].items():
866
+ if _key not in _all_params:
867
+ raise ApiTypeError(
868
+ "Got an unexpected keyword argument '%s'"
869
+ " to method get_structured_result_data" % _key
870
+ )
871
+ _params[_key] = _val
872
+ del _params['kwargs']
17
873
 
18
- # python 2 and python 3 compatibility library
19
- import six
874
+ _collection_formats = {}
20
875
 
21
- from lusid.api_client import ApiClient
22
- from lusid.exceptions import ( # noqa: F401
23
- ApiTypeError,
24
- ApiValueError
25
- )
26
- from lusid.models.lusid_problem_details import LusidProblemDetails
27
- from lusid.models.lusid_validation_problem_details import LusidValidationProblemDetails
28
- from lusid.models.paged_resource_list_of_virtual_row import PagedResourceListOfVirtualRow
29
- from lusid.models.resource_list_of_address_key_definition import ResourceListOfAddressKeyDefinition
876
+ # process the path parameters
877
+ _path_params = {}
878
+ if _params['scope']:
879
+ _path_params['scope'] = _params['scope']
30
880
 
31
881
 
32
- class StructuredResultDataApi(object):
33
- """NOTE: This class is auto generated by OpenAPI Generator
34
- Ref: https://openapi-generator.tech
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']))
35
889
 
36
- Do not edit the class manually.
37
- """
890
+ if _params.get('max_age') is not None: # noqa: E501
891
+ _query_params.append(('maxAge', _params['max_age']))
38
892
 
39
- def __init__(self, api_client=None):
40
- if api_client is None:
41
- api_client = ApiClient()
42
- self.api_client = api_client
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']
43
902
 
44
- def get_address_key_definitions_for_document(self, scope, code, source, result_type, **kwargs): # noqa: E501
45
- """[EARLY ACCESS] GetAddressKeyDefinitionsForDocument: Get AddressKeyDefinitions for a virtual document. # noqa: E501
903
+ # set the HTTP header `Accept`
904
+ _header_params['Accept'] = self.api_client.select_header_accept(
905
+ ['text/plain', 'application/json', 'text/json']) # noqa: E501
46
906
 
47
- For a given virtual document retrieve all the address key definitions that are in use. # noqa: E501
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
48
952
  This method makes a synchronous HTTP request by default. To make an
49
953
  asynchronous HTTP request, please pass async_req=True
50
954
 
51
- >>> thread = api.get_address_key_definitions_for_document(scope, code, source, result_type, async_req=True)
955
+ >>> thread = api.get_virtual_document(scope, request_body, as_at, async_req=True)
52
956
  >>> result = thread.get()
53
957
 
54
- :param scope: The scope of the document for which address key definitions are retrieved. (required)
958
+ :param scope: The scope in which to construct the virtual documents. (required)
55
959
  :type scope: str
56
- :param code: The code of the document for which address key definitions are retrieved. (required)
57
- :type code: str
58
- :param source: The source of the document for which address key definitions are retrieved. (required)
59
- :type source: str
60
- :param result_type: The result type of the document for which address key definitions are retrieved. (required)
61
- :type result_type: str
62
- :param effective_at: The effective datetime to query the document for which the address key definitions are retrieved. Defaults to querying the latest version if not specified.
63
- :type effective_at: str
64
- :param as_at: The asAt datetime to query the document for which the address key definitions are retrieved. Defaults to querying the latest version if not specified.
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.
65
963
  :type as_at: datetime
66
964
  :param async_req: Whether to execute the request asynchronously.
67
965
  :type async_req: bool, optional
68
- :param _preload_content: if False, the urllib3.HTTPResponse object will
69
- be returned without reading/decoding response
70
- data. Default is True.
71
- :type _preload_content: bool, optional
72
- :param _request_timeout: timeout setting for this request. If one
73
- number provided, it will be total request
74
- timeout. It can also be a pair (tuple) of
75
- (connection, read) timeouts.
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.
76
970
  :return: Returns the result object.
77
971
  If the method is called asynchronously,
78
972
  returns the request thread.
79
- :rtype: ResourceListOfAddressKeyDefinition
973
+ :rtype: GetVirtualDocumentResponse
80
974
  """
81
975
  kwargs['_return_http_data_only'] = True
82
- return self.get_address_key_definitions_for_document_with_http_info(scope, code, source, result_type, **kwargs) # noqa: E501
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
83
982
 
84
- def get_address_key_definitions_for_document_with_http_info(self, scope, code, source, result_type, **kwargs): # noqa: E501
85
- """[EARLY ACCESS] GetAddressKeyDefinitionsForDocument: Get AddressKeyDefinitions for a virtual document. # noqa: E501
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
86
986
 
87
- For a given virtual document retrieve all the address key definitions that are in use. # noqa: E501
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
88
988
  This method makes a synchronous HTTP request by default. To make an
89
989
  asynchronous HTTP request, please pass async_req=True
90
990
 
91
- >>> thread = api.get_address_key_definitions_for_document_with_http_info(scope, code, source, result_type, async_req=True)
991
+ >>> thread = api.get_virtual_document_with_http_info(scope, request_body, as_at, async_req=True)
92
992
  >>> result = thread.get()
93
993
 
94
- :param scope: The scope of the document for which address key definitions are retrieved. (required)
994
+ :param scope: The scope in which to construct the virtual documents. (required)
95
995
  :type scope: str
96
- :param code: The code of the document for which address key definitions are retrieved. (required)
97
- :type code: str
98
- :param source: The source of the document for which address key definitions are retrieved. (required)
99
- :type source: str
100
- :param result_type: The result type of the document for which address key definitions are retrieved. (required)
101
- :type result_type: str
102
- :param effective_at: The effective datetime to query the document for which the address key definitions are retrieved. Defaults to querying the latest version if not specified.
103
- :type effective_at: str
104
- :param as_at: The asAt datetime to query the document for which the address key definitions are retrieved. Defaults to querying the latest version if not specified.
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.
105
999
  :type as_at: datetime
106
1000
  :param async_req: Whether to execute the request asynchronously.
107
1001
  :type async_req: bool, optional
108
- :param _return_http_data_only: response data without head status code
109
- and headers
110
- :type _return_http_data_only: bool, optional
111
- :param _preload_content: if False, the urllib3.HTTPResponse object will
112
- be returned without reading/decoding response
113
- data. Default is True.
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.
114
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
115
1010
  :param _request_timeout: timeout setting for this request. If one
116
1011
  number provided, it will be total request
117
1012
  timeout. It can also be a pair (tuple) of
@@ -120,150 +1015,121 @@ class StructuredResultDataApi(object):
120
1015
  request; this effectively ignores the authentication
121
1016
  in the spec for a single request.
122
1017
  :type _request_auth: dict, optional
123
- :return: Returns the result object, the HTTP status code, and the headers.
1018
+ :type _content_type: string, optional: force content-type for the request
1019
+ :return: Returns the result object.
124
1020
  If the method is called asynchronously,
125
1021
  returns the request thread.
126
- :rtype: (ResourceListOfAddressKeyDefinition, int, HTTPHeaderDict)
1022
+ :rtype: tuple(GetVirtualDocumentResponse, status_code(int), headers(HTTPHeaderDict))
127
1023
  """
128
1024
 
129
- local_var_params = locals()
1025
+ _params = locals()
130
1026
 
131
- all_params = [
1027
+ _all_params = [
132
1028
  'scope',
133
- 'code',
134
- 'source',
135
- 'result_type',
136
- 'effective_at',
1029
+ 'request_body',
137
1030
  'as_at'
138
1031
  ]
139
- all_params.extend(
1032
+ _all_params.extend(
140
1033
  [
141
1034
  'async_req',
142
1035
  '_return_http_data_only',
143
1036
  '_preload_content',
144
1037
  '_request_timeout',
145
1038
  '_request_auth',
1039
+ '_content_type',
146
1040
  '_headers'
147
1041
  ]
148
1042
  )
149
1043
 
150
- for key, val in six.iteritems(local_var_params['kwargs']):
151
- if key not in all_params:
1044
+ # validate the arguments
1045
+ for _key, _val in _params['kwargs'].items():
1046
+ if _key not in _all_params:
152
1047
  raise ApiTypeError(
153
1048
  "Got an unexpected keyword argument '%s'"
154
- " to method get_address_key_definitions_for_document" % key
1049
+ " to method get_virtual_document" % _key
155
1050
  )
156
- local_var_params[key] = val
157
- del local_var_params['kwargs']
158
- # verify the required parameter 'scope' is set
159
- if self.api_client.client_side_validation and ('scope' not in local_var_params or # noqa: E501
160
- local_var_params['scope'] is None): # noqa: E501
161
- raise ApiValueError("Missing the required parameter `scope` when calling `get_address_key_definitions_for_document`") # noqa: E501
162
- # verify the required parameter 'code' is set
163
- if self.api_client.client_side_validation and ('code' not in local_var_params or # noqa: E501
164
- local_var_params['code'] is None): # noqa: E501
165
- raise ApiValueError("Missing the required parameter `code` when calling `get_address_key_definitions_for_document`") # noqa: E501
166
- # verify the required parameter 'source' is set
167
- if self.api_client.client_side_validation and ('source' not in local_var_params or # noqa: E501
168
- local_var_params['source'] is None): # noqa: E501
169
- raise ApiValueError("Missing the required parameter `source` when calling `get_address_key_definitions_for_document`") # noqa: E501
170
- # verify the required parameter 'result_type' is set
171
- if self.api_client.client_side_validation and ('result_type' not in local_var_params or # noqa: E501
172
- local_var_params['result_type'] is None): # noqa: E501
173
- raise ApiValueError("Missing the required parameter `result_type` when calling `get_address_key_definitions_for_document`") # noqa: E501
174
-
175
- if self.api_client.client_side_validation and ('scope' in local_var_params and # noqa: E501
176
- len(local_var_params['scope']) > 256): # noqa: E501
177
- 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
178
- if self.api_client.client_side_validation and ('scope' in local_var_params and # noqa: E501
179
- len(local_var_params['scope']) < 1): # noqa: E501
180
- 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
181
- 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
182
- 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
183
- if self.api_client.client_side_validation and ('code' in local_var_params and # noqa: E501
184
- len(local_var_params['code']) > 256): # noqa: E501
185
- 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
186
- if self.api_client.client_side_validation and ('code' in local_var_params and # noqa: E501
187
- len(local_var_params['code']) < 1): # noqa: E501
188
- 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
189
- 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
190
- 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
191
- if self.api_client.client_side_validation and ('source' in local_var_params and # noqa: E501
192
- len(local_var_params['source']) > 256): # noqa: E501
193
- 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
194
- if self.api_client.client_side_validation and ('source' in local_var_params and # noqa: E501
195
- len(local_var_params['source']) < 1): # noqa: E501
196
- 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
197
- 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
198
- 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
199
- collection_formats = {}
200
-
201
- path_params = {}
202
- if 'scope' in local_var_params:
203
- path_params['scope'] = local_var_params['scope'] # noqa: E501
204
- if 'code' in local_var_params:
205
- path_params['code'] = local_var_params['code'] # noqa: E501
206
- if 'source' in local_var_params:
207
- path_params['source'] = local_var_params['source'] # noqa: E501
208
- if 'result_type' in local_var_params:
209
- path_params['resultType'] = local_var_params['result_type'] # noqa: E501
210
-
211
- query_params = []
212
- if 'effective_at' in local_var_params and local_var_params['effective_at'] is not None: # noqa: E501
213
- query_params.append(('effectiveAt', local_var_params['effective_at'])) # noqa: E501
214
- if 'as_at' in local_var_params and local_var_params['as_at'] is not None: # noqa: E501
215
- query_params.append(('asAt', local_var_params['as_at'])) # noqa: E501
216
-
217
- header_params = dict(local_var_params.get('_headers', {}))
218
-
219
- form_params = []
220
- local_var_files = {}
221
-
222
- body_params = None
223
- # HTTP header `Accept`
224
- header_params['Accept'] = self.api_client.select_header_accept(
225
- ['text/plain', 'application/json', 'text/json']) # noqa: E501
1051
+ _params[_key] = _val
1052
+ del _params['kwargs']
226
1053
 
227
- header_params['Accept-Encoding'] = "gzip, deflate, br"
1054
+ _collection_formats = {}
228
1055
 
1056
+ # process the path parameters
1057
+ _path_params = {}
1058
+ if _params['scope']:
1059
+ _path_params['scope'] = _params['scope']
229
1060
 
230
- # set the LUSID header
231
- header_params['X-LUSID-SDK-Language'] = 'Python'
232
- header_params['X-LUSID-SDK-Version'] = '1.1.118'
233
1061
 
234
- # Authentication setting
235
- auth_settings = ['oauth2'] # noqa: E501
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']))
236
1069
 
237
- response_types_map = {
238
- 200: "ResourceListOfAddressKeyDefinition",
239
- 400: "LusidValidationProblemDetails",
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
1083
+
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
1090
+
1091
+ # authentication setting
1092
+ _auth_settings = ['oauth2'] # noqa: E501
1093
+
1094
+ _response_types_map = {
1095
+ '200': "GetVirtualDocumentResponse",
1096
+ '400': "LusidValidationProblemDetails",
240
1097
  }
241
1098
 
242
1099
  return self.api_client.call_api(
243
- '/api/unitresults/virtualdocument/{scope}/{code}/{source}/{resultType}/addresskeydefinitions', 'GET',
244
- path_params,
245
- query_params,
246
- header_params,
247
- body=body_params,
248
- post_params=form_params,
249
- files=local_var_files,
250
- response_types_map=response_types_map,
251
- auth_settings=auth_settings,
252
- async_req=local_var_params.get('async_req'),
253
- _return_http_data_only=local_var_params.get('_return_http_data_only'), # noqa: E501
254
- _preload_content=local_var_params.get('_preload_content', True),
255
- _request_timeout=local_var_params.get('_request_timeout'),
256
- collection_formats=collection_formats,
257
- _request_auth=local_var_params.get('_request_auth'))
258
-
259
- 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
260
1126
  """[EARLY ACCESS] GetVirtualDocumentRows: Get Virtual Document Rows # noqa: E501
261
1127
 
262
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
263
1129
  This method makes a synchronous HTTP request by default. To make an
264
1130
  asynchronous HTTP request, please pass async_req=True
265
1131
 
266
- >>> 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)
267
1133
  >>> result = thread.get()
268
1134
 
269
1135
  :param scope: The scope in which to retrieve the virtual document. (required)
@@ -286,30 +1152,32 @@ class StructuredResultDataApi(object):
286
1152
  :type filter: str
287
1153
  :param async_req: Whether to execute the request asynchronously.
288
1154
  :type async_req: bool, optional
289
- :param _preload_content: if False, the urllib3.HTTPResponse object will
290
- be returned without reading/decoding response
291
- data. Default is True.
292
- :type _preload_content: bool, optional
293
- :param _request_timeout: timeout setting for this request. If one
294
- number provided, it will be total request
295
- timeout. It can also be a pair (tuple) of
296
- (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.
297
1159
  :return: Returns the result object.
298
1160
  If the method is called asynchronously,
299
1161
  returns the request thread.
300
1162
  :rtype: PagedResourceListOfVirtualRow
301
1163
  """
302
1164
  kwargs['_return_http_data_only'] = True
303
- return self.get_virtual_document_rows_with_http_info(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
304
1171
 
305
- def get_virtual_document_rows_with_http_info(self, scope, code, source, result_type, effective_at, **kwargs): # noqa: E501
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
306
1174
  """[EARLY ACCESS] GetVirtualDocumentRows: Get Virtual Document Rows # noqa: E501
307
1175
 
308
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
309
1177
  This method makes a synchronous HTTP request by default. To make an
310
1178
  asynchronous HTTP request, please pass async_req=True
311
1179
 
312
- >>> 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)
313
1181
  >>> result = thread.get()
314
1182
 
315
1183
  :param scope: The scope in which to retrieve the virtual document. (required)
@@ -332,13 +1200,14 @@ class StructuredResultDataApi(object):
332
1200
  :type filter: str
333
1201
  :param async_req: Whether to execute the request asynchronously.
334
1202
  :type async_req: bool, optional
335
- :param _return_http_data_only: response data without head status code
336
- and headers
337
- :type _return_http_data_only: bool, optional
338
- :param _preload_content: if False, the urllib3.HTTPResponse object will
339
- be returned without reading/decoding response
340
- 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.
341
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
342
1211
  :param _request_timeout: timeout setting for this request. If one
343
1212
  number provided, it will be total request
344
1213
  timeout. It can also be a pair (tuple) of
@@ -347,15 +1216,16 @@ class StructuredResultDataApi(object):
347
1216
  request; this effectively ignores the authentication
348
1217
  in the spec for a single request.
349
1218
  :type _request_auth: dict, optional
350
- :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.
351
1221
  If the method is called asynchronously,
352
1222
  returns the request thread.
353
- :rtype: (PagedResourceListOfVirtualRow, int, HTTPHeaderDict)
1223
+ :rtype: tuple(PagedResourceListOfVirtualRow, status_code(int), headers(HTTPHeaderDict))
354
1224
  """
355
1225
 
356
- local_var_params = locals()
1226
+ _params = locals()
357
1227
 
358
- all_params = [
1228
+ _all_params = [
359
1229
  'scope',
360
1230
  'code',
361
1231
  'source',
@@ -366,152 +1236,429 @@ class StructuredResultDataApi(object):
366
1236
  'limit',
367
1237
  'filter'
368
1238
  ]
369
- all_params.extend(
1239
+ _all_params.extend(
370
1240
  [
371
1241
  'async_req',
372
1242
  '_return_http_data_only',
373
1243
  '_preload_content',
374
1244
  '_request_timeout',
375
1245
  '_request_auth',
1246
+ '_content_type',
376
1247
  '_headers'
377
1248
  ]
378
1249
  )
379
1250
 
380
- for key, val in six.iteritems(local_var_params['kwargs']):
381
- 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:
382
1254
  raise ApiTypeError(
383
1255
  "Got an unexpected keyword argument '%s'"
384
- " to method get_virtual_document_rows" % key
1256
+ " to method get_virtual_document_rows" % _key
385
1257
  )
386
- local_var_params[key] = val
387
- del local_var_params['kwargs']
388
- # verify the required parameter 'scope' is set
389
- if self.api_client.client_side_validation and ('scope' not in local_var_params or # noqa: E501
390
- local_var_params['scope'] is None): # noqa: E501
391
- raise ApiValueError("Missing the required parameter `scope` when calling `get_virtual_document_rows`") # noqa: E501
392
- # verify the required parameter 'code' is set
393
- if self.api_client.client_side_validation and ('code' not in local_var_params or # noqa: E501
394
- local_var_params['code'] is None): # noqa: E501
395
- raise ApiValueError("Missing the required parameter `code` when calling `get_virtual_document_rows`") # noqa: E501
396
- # verify the required parameter 'source' is set
397
- if self.api_client.client_side_validation and ('source' not in local_var_params or # noqa: E501
398
- local_var_params['source'] is None): # noqa: E501
399
- raise ApiValueError("Missing the required parameter `source` when calling `get_virtual_document_rows`") # noqa: E501
400
- # verify the required parameter 'result_type' is set
401
- if self.api_client.client_side_validation and ('result_type' not in local_var_params or # noqa: E501
402
- local_var_params['result_type'] is None): # noqa: E501
403
- raise ApiValueError("Missing the required parameter `result_type` when calling `get_virtual_document_rows`") # noqa: E501
404
- # verify the required parameter 'effective_at' is set
405
- if self.api_client.client_side_validation and ('effective_at' not in local_var_params or # noqa: E501
406
- local_var_params['effective_at'] is None): # noqa: E501
407
- raise ApiValueError("Missing the required parameter `effective_at` when calling `get_virtual_document_rows`") # noqa: E501
408
-
409
- if self.api_client.client_side_validation and ('scope' in local_var_params and # noqa: E501
410
- len(local_var_params['scope']) > 256): # noqa: E501
411
- raise ApiValueError("Invalid value for parameter `scope` when calling `get_virtual_document_rows`, length must be less than or equal to `256`") # noqa: E501
412
- if self.api_client.client_side_validation and ('scope' in local_var_params and # noqa: E501
413
- len(local_var_params['scope']) < 1): # noqa: E501
414
- raise ApiValueError("Invalid value for parameter `scope` when calling `get_virtual_document_rows`, length must be greater than or equal to `1`") # noqa: E501
415
- 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
416
- raise ApiValueError("Invalid value for parameter `scope` when calling `get_virtual_document_rows`, must conform to the pattern `/^[a-zA-Z0-9\-_]+$/`") # noqa: E501
417
- if self.api_client.client_side_validation and ('code' in local_var_params and # noqa: E501
418
- len(local_var_params['code']) > 256): # noqa: E501
419
- raise ApiValueError("Invalid value for parameter `code` when calling `get_virtual_document_rows`, length must be less than or equal to `256`") # noqa: E501
420
- if self.api_client.client_side_validation and ('code' in local_var_params and # noqa: E501
421
- len(local_var_params['code']) < 1): # noqa: E501
422
- raise ApiValueError("Invalid value for parameter `code` when calling `get_virtual_document_rows`, length must be greater than or equal to `1`") # noqa: E501
423
- 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
424
- raise ApiValueError("Invalid value for parameter `code` when calling `get_virtual_document_rows`, must conform to the pattern `/^[a-zA-Z0-9\-_]+$/`") # noqa: E501
425
- if self.api_client.client_side_validation and ('source' in local_var_params and # noqa: E501
426
- len(local_var_params['source']) > 256): # noqa: E501
427
- raise ApiValueError("Invalid value for parameter `source` when calling `get_virtual_document_rows`, length must be less than or equal to `256`") # noqa: E501
428
- if self.api_client.client_side_validation and ('source' in local_var_params and # noqa: E501
429
- len(local_var_params['source']) < 1): # noqa: E501
430
- raise ApiValueError("Invalid value for parameter `source` when calling `get_virtual_document_rows`, length must be greater than or equal to `1`") # noqa: E501
431
- 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
432
- raise ApiValueError("Invalid value for parameter `source` when calling `get_virtual_document_rows`, must conform to the pattern `/^[a-zA-Z0-9\-_]+$/`") # noqa: E501
433
- if self.api_client.client_side_validation and ('page' in local_var_params and # noqa: E501
434
- len(local_var_params['page']) > 500): # noqa: E501
435
- raise ApiValueError("Invalid value for parameter `page` when calling `get_virtual_document_rows`, length must be less than or equal to `500`") # noqa: E501
436
- if self.api_client.client_side_validation and ('page' in local_var_params and # noqa: E501
437
- len(local_var_params['page']) < 1): # noqa: E501
438
- raise ApiValueError("Invalid value for parameter `page` when calling `get_virtual_document_rows`, length must be greater than or equal to `1`") # noqa: E501
439
- 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
440
- 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
441
- if self.api_client.client_side_validation and 'limit' in local_var_params and local_var_params['limit'] > 5000: # noqa: E501
442
- 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
443
- if self.api_client.client_side_validation and 'limit' in local_var_params and local_var_params['limit'] < 1: # noqa: E501
444
- 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
445
- if self.api_client.client_side_validation and ('filter' in local_var_params and # noqa: E501
446
- len(local_var_params['filter']) > 16384): # noqa: E501
447
- raise ApiValueError("Invalid value for parameter `filter` when calling `get_virtual_document_rows`, length must be less than or equal to `16384`") # noqa: E501
448
- if self.api_client.client_side_validation and ('filter' in local_var_params and # noqa: E501
449
- len(local_var_params['filter']) < 0): # noqa: E501
450
- raise ApiValueError("Invalid value for parameter `filter` when calling `get_virtual_document_rows`, length must be greater than or equal to `0`") # noqa: E501
451
- 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
452
- raise ApiValueError("Invalid value for parameter `filter` when calling `get_virtual_document_rows`, must conform to the pattern `/^[\s\S]*$/`") # noqa: E501
453
- collection_formats = {}
454
-
455
- path_params = {}
456
- if 'scope' in local_var_params:
457
- path_params['scope'] = local_var_params['scope'] # noqa: E501
458
- if 'code' in local_var_params:
459
- path_params['code'] = local_var_params['code'] # noqa: E501
460
- if 'source' in local_var_params:
461
- path_params['source'] = local_var_params['source'] # noqa: E501
462
- if 'result_type' in local_var_params:
463
- path_params['resultType'] = local_var_params['result_type'] # noqa: E501
464
-
465
- query_params = []
466
- if 'effective_at' in local_var_params and local_var_params['effective_at'] is not None: # noqa: E501
467
- query_params.append(('effectiveAt', local_var_params['effective_at'])) # noqa: E501
468
- if 'as_at' in local_var_params and local_var_params['as_at'] is not None: # noqa: E501
469
- query_params.append(('asAt', local_var_params['as_at'])) # noqa: E501
470
- if 'page' in local_var_params and local_var_params['page'] is not None: # noqa: E501
471
- query_params.append(('page', local_var_params['page'])) # noqa: E501
472
- if 'limit' in local_var_params and local_var_params['limit'] is not None: # noqa: E501
473
- query_params.append(('limit', local_var_params['limit'])) # noqa: E501
474
- if 'filter' in local_var_params and local_var_params['filter'] is not None: # noqa: E501
475
- query_params.append(('filter', local_var_params['filter'])) # noqa: E501
476
-
477
- header_params = dict(local_var_params.get('_headers', {}))
478
-
479
- form_params = []
480
- local_var_files = {}
481
-
482
- body_params = None
483
- # HTTP header `Accept`
484
- header_params['Accept'] = self.api_client.select_header_accept(
485
- ['text/plain', 'application/json', 'text/json']) # noqa: E501
1258
+ _params[_key] = _val
1259
+ del _params['kwargs']
1260
+
1261
+ _collection_formats = {}
1262
+
1263
+ # process the path parameters
1264
+ _path_params = {}
1265
+ if _params['scope']:
1266
+ _path_params['scope'] = _params['scope']
1267
+
1268
+ if _params['code']:
1269
+ _path_params['code'] = _params['code']
1270
+
1271
+ if _params['source']:
1272
+ _path_params['source'] = _params['source']
1273
+
1274
+ if _params['result_type']:
1275
+ _path_params['resultType'] = _params['result_type']
1276
+
486
1277
 
487
- header_params['Accept-Encoding'] = "gzip, deflate, br"
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']))
488
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']))
489
1288
 
490
- # set the LUSID header
491
- header_params['X-LUSID-SDK-Language'] = 'Python'
492
- header_params['X-LUSID-SDK-Version'] = '1.1.118'
1289
+ if _params.get('page') is not None: # noqa: E501
1290
+ _query_params.append(('page', _params['page']))
493
1291
 
494
- # Authentication setting
495
- auth_settings = ['oauth2'] # noqa: E501
1292
+ if _params.get('limit') is not None: # noqa: E501
1293
+ _query_params.append(('limit', _params['limit']))
496
1294
 
497
- response_types_map = {
498
- 200: "PagedResourceListOfVirtualRow",
499
- 400: "LusidValidationProblemDetails",
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",
500
1315
  }
501
1316
 
502
1317
  return self.api_client.call_api(
503
1318
  '/api/unitresults/virtualdocument/{scope}/{code}/{source}/{resultType}', 'GET',
504
- path_params,
505
- query_params,
506
- header_params,
507
- body=body_params,
508
- post_params=form_params,
509
- files=local_var_files,
510
- response_types_map=response_types_map,
511
- auth_settings=auth_settings,
512
- async_req=local_var_params.get('async_req'),
513
- _return_http_data_only=local_var_params.get('_return_http_data_only'), # noqa: E501
514
- _preload_content=local_var_params.get('_preload_content', True),
515
- _request_timeout=local_var_params.get('_request_timeout'),
516
- collection_formats=collection_formats,
517
- _request_auth=local_var_params.get('_request_auth'))
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
1349
+
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
1381
+ This method makes a synchronous HTTP request by default. To make an
1382
+ asynchronous HTTP request, please pass async_req=True
1383
+
1384
+ >>> thread = api.upsert_result_value_with_http_info(scope, request_body, async_req=True)
1385
+ >>> result = thread.get()
1386
+
1387
+ :param scope: The scope in which to construct the virtual documents. (required)
1388
+ :type scope: str
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]
1391
+ :param async_req: Whether to execute the request asynchronously.
1392
+ :type async_req: bool, optional
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.
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
1401
+ :param _request_timeout: timeout setting for this request. If one
1402
+ number provided, it will be total request
1403
+ timeout. It can also be a pair (tuple) of
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.
1529
+ :return: Returns the result object.
1530
+ If the method is called asynchronously,
1531
+ returns the request thread.
1532
+ :rtype: UpsertStructuredDataResponse
1533
+ """
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
1540
+ return self.upsert_structured_result_data_with_http_info(scope, request_body, **kwargs) # noqa: E501
1541
+
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
1545
+
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
1547
+ This method makes a synchronous HTTP request by default. To make an
1548
+ asynchronous HTTP request, please pass async_req=True
1549
+
1550
+ >>> thread = api.upsert_structured_result_data_with_http_info(scope, request_body, async_req=True)
1551
+ >>> result = thread.get()
1552
+
1553
+ :param scope: The scope in which to create or update data items. (required)
1554
+ :type scope: str
1555
+ :param request_body: The set of data items to create or update, keyed by a unique, ephemeral correlation ID. (required)
1556
+ :type request_body: Dict[str, UpsertStructuredResultDataRequest]
1557
+ :param async_req: Whether to execute the request asynchronously.
1558
+ :type async_req: bool, optional
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.
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
1567
+ :param _request_timeout: timeout setting for this request. If one
1568
+ number provided, it will be total request
1569
+ timeout. It can also be a pair (tuple) of
1570
+ (connection, read) timeouts.
1571
+ :param _request_auth: set to override the auth_settings for an a single
1572
+ request; this effectively ignores the authentication
1573
+ in the spec for a single request.
1574
+ :type _request_auth: dict, optional
1575
+ :type _content_type: string, optional: force content-type for the request
1576
+ :return: Returns the result object.
1577
+ If the method is called asynchronously,
1578
+ returns the request thread.
1579
+ :rtype: tuple(UpsertStructuredDataResponse, status_code(int), headers(HTTPHeaderDict))
1580
+ """
1581
+
1582
+ _params = locals()
1583
+
1584
+ _all_params = [
1585
+ 'scope',
1586
+ 'request_body'
1587
+ ]
1588
+ _all_params.extend(
1589
+ [
1590
+ 'async_req',
1591
+ '_return_http_data_only',
1592
+ '_preload_content',
1593
+ '_request_timeout',
1594
+ '_request_auth',
1595
+ '_content_type',
1596
+ '_headers'
1597
+ ]
1598
+ )
1599
+
1600
+ # validate the arguments
1601
+ for _key, _val in _params['kwargs'].items():
1602
+ if _key not in _all_params:
1603
+ raise ApiTypeError(
1604
+ "Got an unexpected keyword argument '%s'"
1605
+ " to method upsert_structured_result_data" % _key
1606
+ )
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(
1632
+ ['text/plain', 'application/json', 'text/json']) # noqa: E501
1633
+
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
1640
+
1641
+ # authentication setting
1642
+ _auth_settings = ['oauth2'] # noqa: E501
1643
+
1644
+ _response_types_map = {
1645
+ '200': "UpsertStructuredDataResponse",
1646
+ '400': "LusidValidationProblemDetails",
1647
+ }
1648
+
1649
+ return self.api_client.call_api(
1650
+ '/api/unitresults/{scope}', 'POST',
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'))