architect-py 3.2.1__tar.gz → 3.2.2__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (152) hide show
  1. architect_py-3.2.2/PKG-INFO +191 -0
  2. architect_py-3.2.2/README.md +166 -0
  3. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/__init__.py +1 -1
  4. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/async_client.py +14 -5
  5. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/client.py +16 -12
  6. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/client_protocol.py +3 -2
  7. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Cpty/CptyRequest.py +3 -2
  8. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Cpty/CptyResponse.py +3 -3
  9. architect_py-3.2.2/architect_py/grpc_client/Cpty/CptyStatus.py +48 -0
  10. architect_py-3.2.2/architect_py/grpc_client/Cpty/CptyStatusRequest.py +45 -0
  11. architect_py-3.2.2/architect_py/grpc_client/Cpty/CptysRequest.py +37 -0
  12. architect_py-3.2.2/architect_py/grpc_client/Cpty/CptysResponse.py +27 -0
  13. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Marketdata/Ticker.py +13 -2
  14. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Orderflow/OrderflowRequest.py +1 -0
  15. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/definitions.py +45 -157
  16. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/grpc_client.py +8 -0
  17. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/grpc_server.py +7 -6
  18. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/tests/conftest.py +4 -2
  19. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/tests/test_order_sending.py +7 -3
  20. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/tests/test_subscriptions.py +2 -5
  21. {architect_py-3.2.1 → architect_py-3.2.2}/pyproject.toml +1 -1
  22. architect_py-3.2.1/PKG-INFO +0 -212
  23. architect_py-3.2.1/README.md +0 -187
  24. architect_py-3.2.1/architect_py/grpc_client/Folio/AggregatedAccountSummariesRequest.py +0 -59
  25. architect_py-3.2.1/architect_py/grpc_client/Folio/AggregatedAccountSummariesResponse.py +0 -27
  26. {architect_py-3.2.1 → architect_py-3.2.2}/LICENSE +0 -0
  27. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/graphql_client/__init__.py +0 -0
  28. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/graphql_client/base_model.py +0 -0
  29. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/graphql_client/cancel_all_orders_mutation.py +0 -0
  30. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/graphql_client/cancel_order_mutation.py +0 -0
  31. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/graphql_client/client.py +0 -0
  32. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/graphql_client/create_jwt.py +0 -0
  33. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/graphql_client/enums.py +0 -0
  34. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/graphql_client/exceptions.py +0 -0
  35. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/graphql_client/fragments.py +0 -0
  36. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/graphql_client/get_account_history_query.py +0 -0
  37. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/graphql_client/get_account_query.py +0 -0
  38. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/graphql_client/get_account_summaries_query.py +0 -0
  39. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/graphql_client/get_account_summary_query.py +0 -0
  40. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/graphql_client/get_candle_snapshot_query.py +0 -0
  41. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/graphql_client/get_execution_info_query.py +0 -0
  42. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/graphql_client/get_execution_infos_query.py +0 -0
  43. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/graphql_client/get_fills_query.py +0 -0
  44. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/graphql_client/get_first_notice_date_query.py +0 -0
  45. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/graphql_client/get_future_series_query.py +0 -0
  46. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/graphql_client/get_historical_orders_query.py +0 -0
  47. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/graphql_client/get_l_1_book_snapshot_query.py +0 -0
  48. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/graphql_client/get_l_1_book_snapshots_query.py +0 -0
  49. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/graphql_client/get_l_2_book_snapshot_query.py +0 -0
  50. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/graphql_client/get_market_status_query.py +0 -0
  51. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/graphql_client/get_open_orders_query.py +0 -0
  52. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/graphql_client/get_product_info_query.py +0 -0
  53. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/graphql_client/get_product_infos_query.py +0 -0
  54. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/graphql_client/input_types.py +0 -0
  55. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/graphql_client/juniper_base_client.py +0 -0
  56. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/graphql_client/list_accounts_query.py +0 -0
  57. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/graphql_client/place_order_mutation.py +0 -0
  58. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/graphql_client/search_symbols_query.py +0 -0
  59. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/graphql_client/subscribe_candles.py +0 -0
  60. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/graphql_client/subscribe_orderflow.py +0 -0
  61. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/graphql_client/subscribe_trades.py +0 -0
  62. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/graphql_client/user_email_query.py +0 -0
  63. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/graphql_client/user_id_query.py +0 -0
  64. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Accounts/AccountsRequest.py +0 -0
  65. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Accounts/AccountsResponse.py +0 -0
  66. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Accounts/__init__.py +0 -0
  67. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Algo/AlgoOrderForTwapAlgo.py +0 -0
  68. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Algo/CreateAlgoOrderRequestForTwapAlgo.py +0 -0
  69. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Algo/ModifyAlgoOrderRequestForTwapAlgo.py +0 -0
  70. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Algo/__init__.py +0 -0
  71. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Cpty/__init__.py +0 -0
  72. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Folio/AccountHistoryRequest.py +0 -0
  73. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Folio/AccountHistoryResponse.py +0 -0
  74. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Folio/AccountSummariesRequest.py +0 -0
  75. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Folio/AccountSummariesResponse.py +0 -0
  76. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Folio/AccountSummary.py +0 -0
  77. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Folio/AccountSummaryRequest.py +0 -0
  78. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Folio/HistoricalFillsRequest.py +0 -0
  79. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Folio/HistoricalFillsResponse.py +0 -0
  80. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Folio/HistoricalOrdersRequest.py +0 -0
  81. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Folio/HistoricalOrdersResponse.py +0 -0
  82. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Folio/__init__.py +0 -0
  83. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Health/HealthCheckRequest.py +0 -0
  84. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Health/HealthCheckResponse.py +0 -0
  85. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Health/__init__.py +0 -0
  86. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Marketdata/ArrayOfL1BookSnapshot.py +0 -0
  87. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Marketdata/Candle.py +0 -0
  88. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Marketdata/HistoricalCandlesRequest.py +0 -0
  89. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Marketdata/HistoricalCandlesResponse.py +0 -0
  90. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Marketdata/L1BookSnapshot.py +0 -0
  91. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Marketdata/L1BookSnapshotRequest.py +0 -0
  92. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Marketdata/L1BookSnapshotsRequest.py +0 -0
  93. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Marketdata/L2BookSnapshot.py +0 -0
  94. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Marketdata/L2BookSnapshotRequest.py +0 -0
  95. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Marketdata/L2BookUpdate.py +0 -0
  96. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Marketdata/Liquidation.py +0 -0
  97. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Marketdata/MarketStatus.py +0 -0
  98. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Marketdata/MarketStatusRequest.py +0 -0
  99. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Marketdata/SubscribeCandlesRequest.py +0 -0
  100. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Marketdata/SubscribeCurrentCandlesRequest.py +0 -0
  101. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Marketdata/SubscribeL1BookSnapshotsRequest.py +0 -0
  102. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Marketdata/SubscribeL2BookUpdatesRequest.py +0 -0
  103. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Marketdata/SubscribeLiquidationsRequest.py +0 -0
  104. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Marketdata/SubscribeManyCandlesRequest.py +0 -0
  105. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Marketdata/SubscribeTickersRequest.py +0 -0
  106. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Marketdata/SubscribeTradesRequest.py +0 -0
  107. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Marketdata/TickerRequest.py +0 -0
  108. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Marketdata/TickerUpdate.py +0 -0
  109. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Marketdata/TickersRequest.py +0 -0
  110. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Marketdata/TickersResponse.py +0 -0
  111. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Marketdata/Trade.py +0 -0
  112. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Marketdata/__init__.py +0 -0
  113. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Oms/Cancel.py +0 -0
  114. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Oms/CancelAllOrdersRequest.py +0 -0
  115. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Oms/CancelAllOrdersResponse.py +0 -0
  116. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Oms/CancelOrderRequest.py +0 -0
  117. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Oms/OpenOrdersRequest.py +0 -0
  118. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Oms/OpenOrdersResponse.py +0 -0
  119. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Oms/Order.py +0 -0
  120. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Oms/PendingCancelsRequest.py +0 -0
  121. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Oms/PendingCancelsResponse.py +0 -0
  122. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Oms/PlaceOrderRequest.py +0 -0
  123. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Oms/__init__.py +0 -0
  124. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Orderflow/Dropcopy.py +0 -0
  125. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Orderflow/DropcopyRequest.py +0 -0
  126. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Orderflow/Orderflow.py +0 -0
  127. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Orderflow/SubscribeOrderflowRequest.py +0 -0
  128. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Orderflow/__init__.py +0 -0
  129. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Symbology/PruneExpiredSymbolsRequest.py +0 -0
  130. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Symbology/PruneExpiredSymbolsResponse.py +0 -0
  131. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Symbology/SubscribeSymbology.py +0 -0
  132. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Symbology/SymbologyRequest.py +0 -0
  133. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Symbology/SymbologySnapshot.py +0 -0
  134. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Symbology/SymbologyUpdate.py +0 -0
  135. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Symbology/SymbolsRequest.py +0 -0
  136. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Symbology/SymbolsResponse.py +0 -0
  137. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Symbology/UploadSymbologyRequest.py +0 -0
  138. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Symbology/UploadSymbologyResponse.py +0 -0
  139. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/Symbology/__init__.py +0 -0
  140. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/grpc_client/__init__.py +0 -0
  141. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/scalars.py +0 -0
  142. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/tests/__init__.py +0 -0
  143. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/tests/test_accounts.py +0 -0
  144. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/tests/test_book_building.py +0 -0
  145. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/tests/test_client.py +0 -0
  146. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/tests/test_grpc_client.py +0 -0
  147. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/tests/test_rounding.py +0 -0
  148. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/tests/test_snapshots.py +0 -0
  149. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/tests/test_symbology.py +0 -0
  150. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/utils/nearest_tick.py +0 -0
  151. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/utils/nearest_tick_2.py +0 -0
  152. {architect_py-3.2.1 → architect_py-3.2.2}/architect_py/utils/price_bands.py +0 -0
@@ -0,0 +1,191 @@
1
+ Metadata-Version: 2.3
2
+ Name: architect-py
3
+ Version: 3.2.2
4
+ Summary: Client library for the Architect trading platform.
5
+ Author: Architect Financial Technologies, Inc.
6
+ Author-email: hello@architect.xyz
7
+ Requires-Python: >=3.10,<4
8
+ Classifier: Development Status :: 3 - Alpha
9
+ Classifier: License :: OSI Approved :: Apache Software License
10
+ Classifier: Operating System :: OS Independent
11
+ Classifier: Programming Language :: Python :: 3
12
+ Classifier: Programming Language :: Python :: 3.10
13
+ Classifier: Programming Language :: Python :: 3.11
14
+ Classifier: Programming Language :: Python :: 3.12
15
+ Classifier: Programming Language :: Python :: 3.13
16
+ Requires-Dist: asyncio (>=3)
17
+ Requires-Dist: dnspython (>=2.0)
18
+ Requires-Dist: gql[httpx] (>=3.5.0,<4.0.0)
19
+ Requires-Dist: grpcio (>=1.66.1)
20
+ Requires-Dist: msgspec (>=0.19,<0.20)
21
+ Requires-Dist: pydantic (>=2.10,<3.0)
22
+ Requires-Dist: websockets (>=11)
23
+ Description-Content-Type: text/markdown
24
+
25
+ # [![Architect](https://avatars.githubusercontent.com/u/116864654?s=29&v=2)](https://architect.co) architect_py
26
+ [![PyPI version](https://img.shields.io/pypi/v/architect-py.svg)](https://pypi.org/project/architect-py/)
27
+
28
+ A Python API for [Architect](https://architect.co).
29
+
30
+ Just some of the features of this API:
31
+ symbology, market snapshots, past trades, account queries, order management (including sending advanced algos!), and market feed subscriptions.
32
+
33
+ This repo heavily uses type hinting, so using a type checker such as Pylance or mypy is suggestible to reduce potential for error.
34
+
35
+
36
+ ## Example usage
37
+
38
+ `AsyncClient` and `Client` are the entryways into making calls to the Architect backend.
39
+ Note that the sync `Client` does not have access to any subscription functions, because they are async by nature.
40
+
41
+
42
+ ```python
43
+ import asyncio
44
+
45
+ from architect_py.async_client import AsyncClient
46
+ from architect_py.scalars import TradableProduct
47
+
48
+ async def main():
49
+ c = await AsyncClient.connect(
50
+ host="<your installation domain>", # e.g. app.architect.co for the brokerage
51
+ api_key="<api key>",
52
+ api_secret="<api secret>"
53
+ paper_trading=True,
54
+ )
55
+ print(await c.who_am_i())
56
+
57
+ series = await async_client.get_cme_futures_series("ES CME Futures")
58
+ front_ES_future = series[0][1]
59
+
60
+ s = c.subscribe_trades_stream(front_ES_future)
61
+ async for trade in s:
62
+ print(trade)
63
+
64
+ asyncio.run(main())
65
+ ```
66
+
67
+ ```python
68
+ from architect_py.client import Client
69
+
70
+ def main():
71
+ c = Client(
72
+ host="<your installation domain>",
73
+ api_key="<api key>",
74
+ api_secret="<api secret>"
75
+ paper_trading=True,
76
+ )
77
+ print(c.who_am_i())
78
+
79
+ print(client.get_account_summaries())
80
+
81
+ print(client.search_symbols("ES"))
82
+ ```
83
+
84
+ While the AsyncClient is the recommended way to use the Architect API, the Client instead without any familiarity with `async/await`.
85
+ The sync clients and async clients usage is identical, except one removes the `await` before the call. The only exception to this is that the sync client does not support any subscriptions, because they are inherently asynchronous.
86
+
87
+ Check the `examples` folder or the `architect_py/tests` folders for example usages.
88
+
89
+
90
+ ## Function Breakdown
91
+
92
+
93
+ The `async` client has the following functions
94
+
95
+ ### 🚀 Initialization
96
+
97
+ - **`connect`**: The main way to create an AsyncClient object.
98
+ - **`__init__`**: Users should not be using this constructor directly, unless they do not want to use any subscription methods.
99
+
100
+ ---
101
+
102
+ ### 🔍 Symbology
103
+
104
+ - **`search_symbols`**: Search for symbols in the Architect database.
105
+ - **`get_product_info`**: Get the product information (product_type, underlying, multiplier, etc.) for a symbol.
106
+ - **`get_product_infos`**: Get the product information (product_type, underlying, multiplier, etc.) for a list of symbols.
107
+ - **`get_execution_info`**: Get the execution information (tick_size, step_size, margin, etc.) for a symbol.
108
+ - **`get_execution_infos`**: Get the execution information (tick_size, step_size, etc.) for a list of symbols.
109
+ - **`get_cme_first_notice_date`**: Get the first notice date for a CME future.
110
+ - **`get_future_series`**: Get the series of futures for a given series symbol.
111
+ - **`get_expiration_from_CME_name`**: Get the expiration date from a CME future name.
112
+ - **`get_cme_futures_series`**: Get the futures in a series from the CME.
113
+ - **`get_cme_future_from_root_month_year`**: Get the symbol for a CME future from the root, month, and year.
114
+
115
+ ---
116
+
117
+ ### 👤 Account Management
118
+
119
+ - **`who_am_i`**: Gets the user_id and user_email for the user that the API key belongs to.
120
+ - **`list_accounts`**: List accounts for the user that the API key belongs to.
121
+ - **`get_account_summary`**: Gets the account summary for the given account.
122
+ - **`get_account_summaries`**: Gets the account summaries for the given accounts and trader.
123
+ - **`get_account_history`**: Gets the account history for the given account and dates.
124
+
125
+ ---
126
+
127
+ ### 📑 Order Management
128
+
129
+ - **`get_open_orders`**: Returns a list of open orders for the user that match the filters.
130
+ - **`get_all_open_orders`**: Returns a list of all open orders for the user.
131
+ - **`get_historical_orders`**: Gets the historical orders that match the filters.
132
+ - **`get_order`**: Returns the OrderFields object for the specified order.
133
+ - **`get_orders`**: Returns a list of OrderFields objects for the specified orders.
134
+ - **`get_fills`**: Returns a list of fills for the given filters.
135
+
136
+ ---
137
+
138
+ ### 📈 Market Data
139
+
140
+ - **`get_market_status`**: Returns market status for symbol (ie if it is quoting and trading).
141
+ - **`get_market_snapshot`**: This is an alias for l1_book_snapshot.
142
+ - **`get_market_snapshots`**: This is an alias for l1_book_snapshot.
143
+ - **`get_historical_candles`**: Gets the historical candles for a symbol.
144
+ - **`get_l1_book_snapshot`**: Gets the L1 book snapshot for a symbol.
145
+ - **`get_l1_book_snapshots`**: Gets the L1 book snapshots for a list of symbols.
146
+ - **`get_l2_book_snapshot`**: Gets the L2 book snapshot for a symbol.
147
+ - **`subscribe_l1_book_stream`**: Subscribe to the stream of L1BookSnapshots for a symbol.
148
+ - **`subscribe_l2_book_stream`**: Subscribe to the stream of L2BookUpdates for a symbol.
149
+ - **`subscribe_l1_book`**: Returns a L1BookSnapshot object that is constantly updating in the background.
150
+ - **`subscribe_l2_book`**: Returns a L2BookSnapshot object that is constantly updating in the background.
151
+ - **`subscribe_trades_stream`**: Subscribe to a stream of trades for a symbol.
152
+ - **`subscribe_candles_stream`**: Subscribe to a stream of candles for a symbol.
153
+
154
+ ---
155
+
156
+ ### 📝 Order Entry and Cancellation
157
+
158
+ - **`send_limit_order`**: Sends a regular limit order.
159
+ - **`send_market_pro_order`**: Sends a market-order like limit price based on the BBO.
160
+ - **`cancel_order`**: Cancels an order by order id.
161
+ - **`cancel_all_orders`**: Cancels all open orders.
162
+
163
+
164
+ ### Running examples from this package
165
+
166
+ Clone this repository to run examples in the `examples` directory. This package
167
+ uses poetry for dependency management. To enter a poetry virtual environment, make
168
+ sure you have [poetry](https://python-poetry.org/docs/) installed and run the
169
+ following from the repository root.
170
+
171
+ ```bash
172
+ poetry shell
173
+ poetry install --sync
174
+
175
+ export ARCHITECT_HOST="<your installation domain>"
176
+ export ARCHITECT_API_KEY="<api key>"
177
+ export ARCHITECT_API_SECRET="<api secret>"
178
+
179
+ python -m examples.trades
180
+ ```
181
+
182
+ You can exit the poetry shell by running `exit`. Environment variables set
183
+ within the shell are not persisted.
184
+
185
+
186
+ ## API keys for the brokerage
187
+
188
+ API keys/secrets for the brokerage can be generated on the [user account page](https://app.architect.co/user/account).
189
+
190
+
191
+
@@ -0,0 +1,166 @@
1
+ # [![Architect](https://avatars.githubusercontent.com/u/116864654?s=29&v=2)](https://architect.co) architect_py
2
+ [![PyPI version](https://img.shields.io/pypi/v/architect-py.svg)](https://pypi.org/project/architect-py/)
3
+
4
+ A Python API for [Architect](https://architect.co).
5
+
6
+ Just some of the features of this API:
7
+ symbology, market snapshots, past trades, account queries, order management (including sending advanced algos!), and market feed subscriptions.
8
+
9
+ This repo heavily uses type hinting, so using a type checker such as Pylance or mypy is suggestible to reduce potential for error.
10
+
11
+
12
+ ## Example usage
13
+
14
+ `AsyncClient` and `Client` are the entryways into making calls to the Architect backend.
15
+ Note that the sync `Client` does not have access to any subscription functions, because they are async by nature.
16
+
17
+
18
+ ```python
19
+ import asyncio
20
+
21
+ from architect_py.async_client import AsyncClient
22
+ from architect_py.scalars import TradableProduct
23
+
24
+ async def main():
25
+ c = await AsyncClient.connect(
26
+ host="<your installation domain>", # e.g. app.architect.co for the brokerage
27
+ api_key="<api key>",
28
+ api_secret="<api secret>"
29
+ paper_trading=True,
30
+ )
31
+ print(await c.who_am_i())
32
+
33
+ series = await async_client.get_cme_futures_series("ES CME Futures")
34
+ front_ES_future = series[0][1]
35
+
36
+ s = c.subscribe_trades_stream(front_ES_future)
37
+ async for trade in s:
38
+ print(trade)
39
+
40
+ asyncio.run(main())
41
+ ```
42
+
43
+ ```python
44
+ from architect_py.client import Client
45
+
46
+ def main():
47
+ c = Client(
48
+ host="<your installation domain>",
49
+ api_key="<api key>",
50
+ api_secret="<api secret>"
51
+ paper_trading=True,
52
+ )
53
+ print(c.who_am_i())
54
+
55
+ print(client.get_account_summaries())
56
+
57
+ print(client.search_symbols("ES"))
58
+ ```
59
+
60
+ While the AsyncClient is the recommended way to use the Architect API, the Client instead without any familiarity with `async/await`.
61
+ The sync clients and async clients usage is identical, except one removes the `await` before the call. The only exception to this is that the sync client does not support any subscriptions, because they are inherently asynchronous.
62
+
63
+ Check the `examples` folder or the `architect_py/tests` folders for example usages.
64
+
65
+
66
+ ## Function Breakdown
67
+
68
+
69
+ The `async` client has the following functions
70
+
71
+ ### 🚀 Initialization
72
+
73
+ - **`connect`**: The main way to create an AsyncClient object.
74
+ - **`__init__`**: Users should not be using this constructor directly, unless they do not want to use any subscription methods.
75
+
76
+ ---
77
+
78
+ ### 🔍 Symbology
79
+
80
+ - **`search_symbols`**: Search for symbols in the Architect database.
81
+ - **`get_product_info`**: Get the product information (product_type, underlying, multiplier, etc.) for a symbol.
82
+ - **`get_product_infos`**: Get the product information (product_type, underlying, multiplier, etc.) for a list of symbols.
83
+ - **`get_execution_info`**: Get the execution information (tick_size, step_size, margin, etc.) for a symbol.
84
+ - **`get_execution_infos`**: Get the execution information (tick_size, step_size, etc.) for a list of symbols.
85
+ - **`get_cme_first_notice_date`**: Get the first notice date for a CME future.
86
+ - **`get_future_series`**: Get the series of futures for a given series symbol.
87
+ - **`get_expiration_from_CME_name`**: Get the expiration date from a CME future name.
88
+ - **`get_cme_futures_series`**: Get the futures in a series from the CME.
89
+ - **`get_cme_future_from_root_month_year`**: Get the symbol for a CME future from the root, month, and year.
90
+
91
+ ---
92
+
93
+ ### 👤 Account Management
94
+
95
+ - **`who_am_i`**: Gets the user_id and user_email for the user that the API key belongs to.
96
+ - **`list_accounts`**: List accounts for the user that the API key belongs to.
97
+ - **`get_account_summary`**: Gets the account summary for the given account.
98
+ - **`get_account_summaries`**: Gets the account summaries for the given accounts and trader.
99
+ - **`get_account_history`**: Gets the account history for the given account and dates.
100
+
101
+ ---
102
+
103
+ ### 📑 Order Management
104
+
105
+ - **`get_open_orders`**: Returns a list of open orders for the user that match the filters.
106
+ - **`get_all_open_orders`**: Returns a list of all open orders for the user.
107
+ - **`get_historical_orders`**: Gets the historical orders that match the filters.
108
+ - **`get_order`**: Returns the OrderFields object for the specified order.
109
+ - **`get_orders`**: Returns a list of OrderFields objects for the specified orders.
110
+ - **`get_fills`**: Returns a list of fills for the given filters.
111
+
112
+ ---
113
+
114
+ ### 📈 Market Data
115
+
116
+ - **`get_market_status`**: Returns market status for symbol (ie if it is quoting and trading).
117
+ - **`get_market_snapshot`**: This is an alias for l1_book_snapshot.
118
+ - **`get_market_snapshots`**: This is an alias for l1_book_snapshot.
119
+ - **`get_historical_candles`**: Gets the historical candles for a symbol.
120
+ - **`get_l1_book_snapshot`**: Gets the L1 book snapshot for a symbol.
121
+ - **`get_l1_book_snapshots`**: Gets the L1 book snapshots for a list of symbols.
122
+ - **`get_l2_book_snapshot`**: Gets the L2 book snapshot for a symbol.
123
+ - **`subscribe_l1_book_stream`**: Subscribe to the stream of L1BookSnapshots for a symbol.
124
+ - **`subscribe_l2_book_stream`**: Subscribe to the stream of L2BookUpdates for a symbol.
125
+ - **`subscribe_l1_book`**: Returns a L1BookSnapshot object that is constantly updating in the background.
126
+ - **`subscribe_l2_book`**: Returns a L2BookSnapshot object that is constantly updating in the background.
127
+ - **`subscribe_trades_stream`**: Subscribe to a stream of trades for a symbol.
128
+ - **`subscribe_candles_stream`**: Subscribe to a stream of candles for a symbol.
129
+
130
+ ---
131
+
132
+ ### 📝 Order Entry and Cancellation
133
+
134
+ - **`send_limit_order`**: Sends a regular limit order.
135
+ - **`send_market_pro_order`**: Sends a market-order like limit price based on the BBO.
136
+ - **`cancel_order`**: Cancels an order by order id.
137
+ - **`cancel_all_orders`**: Cancels all open orders.
138
+
139
+
140
+ ### Running examples from this package
141
+
142
+ Clone this repository to run examples in the `examples` directory. This package
143
+ uses poetry for dependency management. To enter a poetry virtual environment, make
144
+ sure you have [poetry](https://python-poetry.org/docs/) installed and run the
145
+ following from the repository root.
146
+
147
+ ```bash
148
+ poetry shell
149
+ poetry install --sync
150
+
151
+ export ARCHITECT_HOST="<your installation domain>"
152
+ export ARCHITECT_API_KEY="<api key>"
153
+ export ARCHITECT_API_SECRET="<api secret>"
154
+
155
+ python -m examples.trades
156
+ ```
157
+
158
+ You can exit the poetry shell by running `exit`. Environment variables set
159
+ within the shell are not persisted.
160
+
161
+
162
+ ## API keys for the brokerage
163
+
164
+ API keys/secrets for the brokerage can be generated on the [user account page](https://app.architect.co/user/account).
165
+
166
+
@@ -1,2 +1,2 @@
1
- __version__ = "3.2.1"
1
+ __version__ = "3.2.2"
2
2
  # this is automatically updated by poetry-dynamic-versioning, see README.md
@@ -161,9 +161,9 @@ class AsyncClient:
161
161
  **kwargs: Any,
162
162
  ):
163
163
  """
164
- Users should not be using this constructor directly, unless they do not want to use any subscription methods.
164
+ Users should essentially never be using this constructor directly.
165
165
 
166
- Use the create method instead.
166
+ Use the connect method instead.
167
167
  See self.connect for arg explanations
168
168
  """
169
169
 
@@ -199,6 +199,14 @@ class AsyncClient:
199
199
  api_key=api_key, api_secret=api_secret, host=host, port=_port, **kwargs
200
200
  )
201
201
 
202
+ async def enable_orderflow(self):
203
+ """
204
+ Load and cache product and execution info so that the SDK can send orders.
205
+
206
+ CR alee: determine if this is better than @functools.lru_cache
207
+ """
208
+ pass
209
+
202
210
  # ------------------------------------------------------------
203
211
  # Symbology
204
212
  # ------------------------------------------------------------
@@ -244,7 +252,6 @@ class AsyncClient:
244
252
  info = await self.graphql_client.get_product_info_query(symbol)
245
253
  return info.product_info
246
254
 
247
- @functools.lru_cache
248
255
  async def get_product_infos(
249
256
  self, symbols: Optional[list[str]]
250
257
  ) -> Sequence[ProductInfoFields]:
@@ -264,7 +271,6 @@ class AsyncClient:
264
271
  infos = await self.graphql_client.get_product_infos_query(symbols)
265
272
  return infos.product_infos
266
273
 
267
- @functools.lru_cache
268
274
  async def get_execution_info(
269
275
  self, symbol: TradableProduct, execution_venue: str
270
276
  ) -> Optional[ExecutionInfoFields]:
@@ -949,6 +955,7 @@ class AsyncClient:
949
955
  async def send_limit_order(
950
956
  self,
951
957
  *,
958
+ id: Optional[str] = None,
952
959
  symbol: TradableProduct,
953
960
  execution_venue: Optional[str],
954
961
  odir: OrderDir,
@@ -1027,7 +1034,7 @@ class AsyncClient:
1027
1034
  quantity,
1028
1035
  order_type,
1029
1036
  time_in_force,
1030
- None,
1037
+ id,
1031
1038
  trader,
1032
1039
  account,
1033
1040
  limit_price,
@@ -1042,6 +1049,7 @@ class AsyncClient:
1042
1049
  async def send_market_pro_order(
1043
1050
  self,
1044
1051
  *,
1052
+ id: Optional[str] = None,
1045
1053
  symbol: TradableProduct,
1046
1054
  execution_venue: str,
1047
1055
  odir: OrderDir,
@@ -1118,6 +1126,7 @@ class AsyncClient:
1118
1126
  limit_price = tick_round_method(limit_price, tick_size)
1119
1127
 
1120
1128
  return await self.send_limit_order(
1129
+ id=id,
1121
1130
  symbol=symbol,
1122
1131
  execution_venue=execution_venue,
1123
1132
  odir=odir,
@@ -24,6 +24,8 @@ class Client(AsyncClientProtocol):
24
24
  This class is a wrapper around the AsyncClient class that allows you to call async methods synchronously.
25
25
  This does not work for subscription based methods.
26
26
 
27
+ This Client takes control of the event loop, which you can pass in.
28
+
27
29
  One can find the function definition in the AsyncClient class.
28
30
 
29
31
  The AsyncClient is more performant and powerful, so it is recommended to use that class if possible.
@@ -48,18 +50,6 @@ class Client(AsyncClientProtocol):
48
50
  loop: Optional[AbstractEventLoop] = None,
49
51
  **kwargs,
50
52
  ):
51
- super().__setattr__(
52
- "client",
53
- AsyncClient(
54
- api_key=api_key,
55
- api_secret=api_secret,
56
- host=host,
57
- paper_trading=paper_trading,
58
- _i_know_what_i_am_doing=True,
59
- **kwargs,
60
- ),
61
- )
62
-
63
53
  if loop is None:
64
54
  try:
65
55
  loop = asyncio.get_running_loop()
@@ -68,6 +58,20 @@ class Client(AsyncClientProtocol):
68
58
  asyncio.set_event_loop(loop)
69
59
  super().__setattr__("_loop", loop)
70
60
 
61
+ async_client = loop.run_until_complete(
62
+ AsyncClient.connect(
63
+ api_key=api_key,
64
+ api_secret=api_secret,
65
+ host=host,
66
+ paper_trading=paper_trading,
67
+ **kwargs,
68
+ )
69
+ )
70
+ super().__setattr__(
71
+ "client",
72
+ async_client,
73
+ )
74
+
71
75
  if "ipykernel" in sys.modules:
72
76
  # for jupyter notebooks
73
77
  import atexit
@@ -19,6 +19,7 @@ class AsyncClientProtocol:
19
19
  def cancel_order(self, order_id: str) -> CancelFields: ...
20
20
  @staticmethod
21
21
  def connect(*, api_key: str, api_secret: str, paper_trading: bool, host: str = 'app.architect.co', grpc_endpoint: str = 'cme.marketdata.architect.co', _port: Optional[int] = None, **kwargs: Any) -> AsyncClient: ...
22
+ def enable_orderflow(self) -> Any: ...
22
23
  def get_account_history(self, account: str, from_inclusive: Optional[datetime] = None, to_exclusive: Optional[datetime] = None) -> Sequence[AccountSummaryFields]: ...
23
24
  def get_account_summaries(self, accounts: Optional[list[str]] = None, trader: Optional[str] = None) -> Sequence[AccountSummaryFields]: ...
24
25
  def get_account_summary(self, account: str) -> AccountSummaryFields: ...
@@ -47,6 +48,6 @@ class AsyncClientProtocol:
47
48
  def get_product_infos(self, symbols: Optional[list[str]]) -> Sequence[ProductInfoFields]: ...
48
49
  def list_accounts(self) -> Sequence[AccountWithPermissionsFields]: ...
49
50
  def search_symbols(self, search_string: Optional[str] = None, execution_venue: Optional[str] = None, offset: int = 0, limit: int = 20) -> list[TradableProduct]: ...
50
- def send_limit_order(self, *, symbol: TradableProduct, execution_venue: Optional[str], odir: OrderDir, quantity: Decimal, limit_price: Decimal, order_type: OrderType = OrderType.LIMIT, time_in_force: TimeInForce = TimeInForce.DAY, good_til_date: Optional[datetime] = None, price_round_method: Optional[TickRoundMethod] = None, account: Optional[str] = None, trader: Optional[str] = None, post_only: bool = False, trigger_price: Optional[Decimal] = None) -> OrderFields: ...
51
- def send_market_pro_order(self, *, symbol: TradableProduct, execution_venue: str, odir: OrderDir, quantity: Decimal, time_in_force: TimeInForce = TimeInForce.DAY, account: Optional[str] = None, fraction_through_market: Decimal = Decimal('0.001')) -> OrderFields: ...
51
+ def send_limit_order(self, *, id: Optional[str] = None, symbol: TradableProduct, execution_venue: Optional[str], odir: OrderDir, quantity: Decimal, limit_price: Decimal, order_type: OrderType = OrderType.LIMIT, time_in_force: TimeInForce = TimeInForce.DAY, good_til_date: Optional[datetime] = None, price_round_method: Optional[TickRoundMethod] = None, account: Optional[str] = None, trader: Optional[str] = None, post_only: bool = False, trigger_price: Optional[Decimal] = None) -> OrderFields: ...
52
+ def send_market_pro_order(self, *, id: Optional[str] = None, symbol: TradableProduct, execution_venue: str, odir: OrderDir, quantity: Decimal, time_in_force: TimeInForce = TimeInForce.DAY, account: Optional[str] = None, fraction_through_market: Decimal = Decimal('0.001')) -> OrderFields: ...
52
53
  def who_am_i(self) -> tuple[str, str]: ...
@@ -6,7 +6,7 @@ from architect_py.grpc_client.Cpty.CptyResponse import (
6
6
  CptyResponse,
7
7
  Symbology,
8
8
  ReconcileOrder,
9
- ReconcileOpenOrder,
9
+ ReconcileOpenOrders,
10
10
  UpdateAccountSummary,
11
11
  )
12
12
 
@@ -60,8 +60,9 @@ CptyRequest = Annotated[
60
60
  ]
61
61
 
62
62
  CptyRequest_rpc_method = "duplex_stream"
63
+ UnannotatedCptyRequest = Login | Logout | PlaceOrder | CancelOrder
63
64
  CptyRequestResponseType = CptyResponse
64
65
  CptyRequestUnannotatedResponseType = (
65
- Symbology | ReconcileOrder | ReconcileOpenOrder | UpdateAccountSummary
66
+ Symbology | ReconcileOrder | ReconcileOpenOrders | UpdateAccountSummary
66
67
  )
67
68
  CptyRequest_route = "/json.architect.Cpty/Cpty"
@@ -63,7 +63,7 @@ class Symbology(Struct, omit_defaults=True, tag_field="t", tag="xs"):
63
63
  return f"Symbology(execution_info={self.execution_info})"
64
64
 
65
65
 
66
- class ReconcileOpenOrder(Struct, omit_defaults=True, tag_field="t", tag="oo"):
66
+ class ReconcileOpenOrders(Struct, omit_defaults=True, tag_field="t", tag="oo"):
67
67
  orders: List[Order]
68
68
  snapshot_for_account: Optional[definitions.AccountIdOrName] = None
69
69
 
@@ -80,7 +80,7 @@ class ReconcileOpenOrder(Struct, omit_defaults=True, tag_field="t", tag="oo"):
80
80
  )
81
81
 
82
82
  def __str__(self) -> str:
83
- return f"ReconcileOpenOrder(orders={self.orders},snapshot_for_account={self.snapshot_for_account})"
83
+ return f"ReconcileOpenOrders(orders={self.orders},snapshot_for_account={self.snapshot_for_account})"
84
84
 
85
85
 
86
86
  class ReconcileOrder(Order, omit_defaults=True, tag_field="t", tag="ro"):
@@ -88,6 +88,6 @@ class ReconcileOrder(Order, omit_defaults=True, tag_field="t", tag="ro"):
88
88
 
89
89
 
90
90
  CptyResponse = Annotated[
91
- Union[Symbology, ReconcileOrder, ReconcileOpenOrder, UpdateAccountSummary],
91
+ Union[Symbology, ReconcileOrder, ReconcileOpenOrders, UpdateAccountSummary],
92
92
  Meta(title="CptyResponse"),
93
93
  ]
@@ -0,0 +1,48 @@
1
+ # generated by datamodel-codegen:
2
+ # filename: Cpty/CptyStatus.json
3
+
4
+ from __future__ import annotations
5
+
6
+ from typing import Annotated, Optional
7
+
8
+ from msgspec import Meta, Struct
9
+
10
+
11
+ class CptyStatus(Struct, omit_defaults=True):
12
+ connected: bool
13
+ kind: str
14
+ last_heartbeat: Annotated[int, Meta(description="UNIX epoch time or -1 for never")]
15
+ """
16
+ UNIX epoch time or -1 for never
17
+ """
18
+ last_heartbeat_stale_threshold: Annotated[
19
+ int, Meta(description="Stale threshold in seconds, or -1 for never stale")
20
+ ]
21
+ """
22
+ Stale threshold in seconds, or -1 for never stale
23
+ """
24
+ logged_in: bool
25
+ instance: Optional[str] = None
26
+
27
+ # below is a constructor that takes all field titles as arguments for convenience
28
+ @classmethod
29
+ def new(
30
+ cls,
31
+ connected: bool,
32
+ kind: str,
33
+ last_heartbeat: int,
34
+ last_heartbeat_stale_threshold: int,
35
+ logged_in: bool,
36
+ instance: Optional[str] = None,
37
+ ):
38
+ return cls(
39
+ connected,
40
+ kind,
41
+ last_heartbeat,
42
+ last_heartbeat_stale_threshold,
43
+ logged_in,
44
+ instance,
45
+ )
46
+
47
+ def __str__(self) -> str:
48
+ return f"CptyStatus(connected={self.connected},kind={self.kind},last_heartbeat={self.last_heartbeat},last_heartbeat_stale_threshold={self.last_heartbeat_stale_threshold},logged_in={self.logged_in},instance={self.instance})"
@@ -0,0 +1,45 @@
1
+ # generated by datamodel-codegen:
2
+ # filename: Cpty/CptyStatusRequest.json
3
+
4
+ from __future__ import annotations
5
+ from architect_py.grpc_client.Cpty.CptyStatus import CptyStatus
6
+
7
+ from typing import Optional
8
+
9
+ from msgspec import Struct
10
+
11
+
12
+ class CptyStatusRequest(Struct, omit_defaults=True):
13
+ kind: str
14
+ instance: Optional[str] = None
15
+
16
+ # below is a constructor that takes all field titles as arguments for convenience
17
+ @classmethod
18
+ def new(
19
+ cls,
20
+ kind: str,
21
+ instance: Optional[str] = None,
22
+ ):
23
+ return cls(
24
+ kind,
25
+ instance,
26
+ )
27
+
28
+ def __str__(self) -> str:
29
+ return f"CptyStatusRequest(kind={self.kind},instance={self.instance})"
30
+
31
+ @staticmethod
32
+ def get_response_type():
33
+ return CptyStatus
34
+
35
+ @staticmethod
36
+ def get_unannotated_response_type():
37
+ return CptyStatus
38
+
39
+ @staticmethod
40
+ def get_route() -> str:
41
+ return "/json.architect.Cpty/CptyStatus"
42
+
43
+ @staticmethod
44
+ def get_rpc_method():
45
+ return "unary"
@@ -0,0 +1,37 @@
1
+ # generated by datamodel-codegen:
2
+ # filename: Cpty/CptysRequest.json
3
+
4
+ from __future__ import annotations
5
+ from architect_py.grpc_client.Cpty.CptysResponse import CptysResponse
6
+
7
+ from msgspec import Struct
8
+
9
+
10
+ class CptysRequest(Struct, omit_defaults=True):
11
+ pass
12
+
13
+ # below is a constructor that takes all field titles as arguments for convenience
14
+ @classmethod
15
+ def new(
16
+ cls,
17
+ ):
18
+ return cls()
19
+
20
+ def __str__(self) -> str:
21
+ return f"CptysRequest()"
22
+
23
+ @staticmethod
24
+ def get_response_type():
25
+ return CptysResponse
26
+
27
+ @staticmethod
28
+ def get_unannotated_response_type():
29
+ return CptysResponse
30
+
31
+ @staticmethod
32
+ def get_route() -> str:
33
+ return "/json.architect.Cpty/Cptys"
34
+
35
+ @staticmethod
36
+ def get_rpc_method():
37
+ return "unary"