langgraph-api 0.8.0__tar.gz → 0.8.1__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 (298) hide show
  1. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/PKG-INFO +2 -2
  2. langgraph_api-0.8.1/langgraph_api/__init__.py +1 -0
  3. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/api/runs.py +5 -5
  4. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/api/threads.py +2 -2
  5. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/config/__init__.py +13 -0
  6. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/grpc/ops/threads.py +44 -4
  7. langgraph_api-0.8.1/langgraph_grpc_common/proto/core_api_pb2.py +272 -0
  8. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/core_api_pb2.pyi +16 -2
  9. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/pyproject.toml +1 -1
  10. langgraph_api-0.8.0/langgraph_api/__init__.py +0 -1
  11. langgraph_api-0.8.0/langgraph_grpc_common/proto/core_api_pb2.py +0 -272
  12. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/.gitignore +0 -0
  13. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/LICENSE +0 -0
  14. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/Makefile +0 -0
  15. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/README.md +0 -0
  16. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/benchmark/.gitignore +0 -0
  17. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/benchmark/Makefile +0 -0
  18. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/benchmark/README.md +0 -0
  19. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/benchmark/benchmark-runners/assistant.ts +0 -0
  20. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/benchmark/benchmark-runners/benchmark-runner.ts +0 -0
  21. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/benchmark/benchmark-runners/benchmark_profiles.ts +0 -0
  22. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/benchmark/benchmark-runners/benchmarks.ts +0 -0
  23. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/benchmark/benchmark-runners/cancel_first_second_completes.ts +0 -0
  24. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/benchmark/benchmark-runners/enqueued_runs_order.ts +0 -0
  25. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/benchmark/benchmark-runners/log-failure.ts +0 -0
  26. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/benchmark/benchmark-runners/meta_workload.ts +0 -0
  27. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/benchmark/benchmark-runners/stream_write.ts +0 -0
  28. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/benchmark/benchmark-runners/thread.ts +0 -0
  29. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/benchmark/benchmark-runners/thread_runs_metadata_search.ts +0 -0
  30. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/benchmark/benchmark-runners/threads_search_metadata.ts +0 -0
  31. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/benchmark/benchmark-runners/types.ts +0 -0
  32. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/benchmark/benchmark-runners/wait_write.ts +0 -0
  33. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/benchmark/capacity_dd_report.py +0 -0
  34. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/benchmark/capacity_k6.js +0 -0
  35. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/benchmark/capacity_runner.mjs +0 -0
  36. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/benchmark/capacity_slack_report.py +0 -0
  37. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/benchmark/capacity_urls.mjs +0 -0
  38. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/benchmark/clean-cli.js +0 -0
  39. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/benchmark/clean.js +0 -0
  40. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/benchmark/continuous/README.md +0 -0
  41. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/benchmark/continuous/pyproject.toml +0 -0
  42. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/benchmark/continuous/runner.py +0 -0
  43. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/benchmark/continuous/uv.lock +0 -0
  44. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/benchmark/graphs.js +0 -0
  45. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/benchmark/mixed_workload_k6.js +0 -0
  46. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/benchmark/mixed_workload_runner.mjs +0 -0
  47. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/benchmark/package.json +0 -0
  48. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/benchmark/ramp.js +0 -0
  49. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/benchmark/reporting/dd_reporting.py +0 -0
  50. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/benchmark/reporting/slack_slowest_runs.py +0 -0
  51. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/benchmark/reporting/slack_summary.py +0 -0
  52. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/benchmark/run_local.sh +0 -0
  53. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/benchmark/staircase.py +0 -0
  54. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/benchmark/staircase_step_k6.js +0 -0
  55. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/benchmark/tsconfig.json +0 -0
  56. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/benchmark/update-revision.js +0 -0
  57. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/benchmark/weather.js +0 -0
  58. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/constraints.txt +0 -0
  59. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/custom_store.sql +0 -0
  60. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/forbidden.txt +0 -0
  61. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/hatch_build.py +0 -0
  62. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/healthcheck.py +0 -0
  63. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph-cloud-debugging-20260210132856.zip +0 -0
  64. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/_checkpointer/__init__.py +0 -0
  65. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/_checkpointer/_adapter.py +0 -0
  66. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/_checkpointer/protocol.py +0 -0
  67. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/_factory_utils.py +0 -0
  68. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/api/__init__.py +0 -0
  69. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/api/a2a.py +0 -0
  70. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/api/assistants.py +0 -0
  71. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/api/mcp/__init__.py +0 -0
  72. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/api/mcp/_constants.py +0 -0
  73. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/api/mcp/_handlers.py +0 -0
  74. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/api/mcp/_models.py +0 -0
  75. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/api/mcp/_routes.py +0 -0
  76. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/api/mcp/_sanitizers.py +0 -0
  77. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/api/meta.py +0 -0
  78. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/api/openapi.py +0 -0
  79. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/api/profile.py +0 -0
  80. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/api/store.py +0 -0
  81. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/api/ui.py +0 -0
  82. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/asgi_transport.py +0 -0
  83. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/asyncio.py +0 -0
  84. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/auth/__init__.py +0 -0
  85. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/auth/custom.py +0 -0
  86. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/auth/errors.py +0 -0
  87. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/auth/langsmith/__init__.py +0 -0
  88. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/auth/langsmith/backend.py +0 -0
  89. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/auth/langsmith/client.py +0 -0
  90. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/auth/middleware.py +0 -0
  91. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/auth/noop.py +0 -0
  92. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/auth/studio_user.py +0 -0
  93. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/cache.py +0 -0
  94. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/cli.py +0 -0
  95. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/command.py +0 -0
  96. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/config/_parse.py +0 -0
  97. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/config/schemas.py +0 -0
  98. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/cron_scheduler.py +0 -0
  99. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/encryption/__init__.py +0 -0
  100. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/encryption/aes_json.py +0 -0
  101. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/encryption/context.py +0 -0
  102. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/encryption/custom.py +0 -0
  103. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/encryption/middleware.py +0 -0
  104. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/encryption/shared.py +0 -0
  105. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/errors.py +0 -0
  106. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/executor_entrypoint.py +0 -0
  107. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/feature_flags.py +0 -0
  108. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/graph.py +0 -0
  109. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/grpc/__init__.py +0 -0
  110. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/grpc/client.py +0 -0
  111. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/grpc/generated/core_api_pb2.pyi +0 -0
  112. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/grpc/ops/__init__.py +0 -0
  113. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/grpc/ops/assistants.py +0 -0
  114. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/grpc/ops/cache.py +0 -0
  115. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/grpc/ops/crons.py +0 -0
  116. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/grpc/ops/runs.py +0 -0
  117. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/grpc/server.py +0 -0
  118. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/grpc/servicers/__init__.py +0 -0
  119. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/grpc/servicers/checkpointer.py +0 -0
  120. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/grpc/servicers/encryption.py +0 -0
  121. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/http.py +0 -0
  122. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/http_metrics.py +0 -0
  123. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/http_metrics_utils.py +0 -0
  124. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/js/.gitignore +0 -0
  125. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/js/.prettierrc +0 -0
  126. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/js/__init__.py +0 -0
  127. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/js/base.py +0 -0
  128. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/js/build.mts +0 -0
  129. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/js/client.http.mts +0 -0
  130. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/js/client.mts +0 -0
  131. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/js/errors.py +0 -0
  132. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/js/global.d.ts +0 -0
  133. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/js/package.json +0 -0
  134. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/js/remote.py +0 -0
  135. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/js/schema.py +0 -0
  136. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/js/src/graph.mts +0 -0
  137. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/js/src/load.hooks.mjs +0 -0
  138. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/js/src/preload.mjs +0 -0
  139. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/js/src/utils/files.mts +0 -0
  140. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/js/src/utils/importMap.mts +0 -0
  141. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/js/src/utils/pythonSchemas.mts +0 -0
  142. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/js/src/utils/serde.mts +0 -0
  143. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/js/sse.py +0 -0
  144. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/js/traceblock.mts +0 -0
  145. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/js/tsconfig.json +0 -0
  146. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/js/ui.py +0 -0
  147. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/js/yarn.lock +0 -0
  148. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/lc_security/__init__.py +0 -0
  149. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/lc_security/exceptions.py +0 -0
  150. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/lc_security/policy.py +0 -0
  151. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/lc_security/transport.py +0 -0
  152. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/logging.py +0 -0
  153. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/metadata.py +0 -0
  154. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/metrics_datadog.py +0 -0
  155. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/middleware/__init__.py +0 -0
  156. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/middleware/ensure_store.py +0 -0
  157. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/middleware/http_logger.py +0 -0
  158. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/middleware/private_network.py +0 -0
  159. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/middleware/request_id.py +0 -0
  160. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/models/__init__.py +0 -0
  161. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/models/run.py +0 -0
  162. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/otel_context.py +0 -0
  163. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/patch.py +0 -0
  164. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/queue_entrypoint.py +0 -0
  165. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/route.py +0 -0
  166. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/schema.py +0 -0
  167. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/self_hosted_logs.py +0 -0
  168. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/self_hosted_metrics.py +0 -0
  169. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/serde.py +0 -0
  170. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/server.py +0 -0
  171. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/sse.py +0 -0
  172. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/state.py +0 -0
  173. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/store.py +0 -0
  174. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/stream.py +0 -0
  175. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/timing/__init__.py +0 -0
  176. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/timing/profiler.py +0 -0
  177. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/timing/timer.py +0 -0
  178. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/traceblock.py +0 -0
  179. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/tunneling/cloudflare.py +0 -0
  180. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/utils/__init__.py +0 -0
  181. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/utils/cache.py +0 -0
  182. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/utils/config.py +0 -0
  183. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/utils/errors.py +0 -0
  184. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/utils/extract.py +0 -0
  185. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/utils/future.py +0 -0
  186. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/utils/headers.py +0 -0
  187. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/utils/network.py +0 -0
  188. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/utils/retriable_client.py +0 -0
  189. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/utils/stream_codec.py +0 -0
  190. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/utils/uuids.py +0 -0
  191. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/validation.py +0 -0
  192. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/webhook.py +0 -0
  193. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_api/worker.py +0 -0
  194. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/__init__.py +0 -0
  195. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/checkpointer.py +0 -0
  196. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/conversion/__init__.py +0 -0
  197. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/conversion/_compat.py +0 -0
  198. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/conversion/channel.py +0 -0
  199. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/conversion/checkpoint.py +0 -0
  200. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/conversion/config.py +0 -0
  201. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/conversion/durability.py +0 -0
  202. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/conversion/exception.py +0 -0
  203. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/conversion/graph.py +0 -0
  204. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/conversion/interrupt.py +0 -0
  205. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/conversion/messages.py +0 -0
  206. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/conversion/orchestrator_response.py +0 -0
  207. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/conversion/runopts.py +0 -0
  208. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/conversion/stream_mode.py +0 -0
  209. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/conversion/struct.py +0 -0
  210. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/conversion/task.py +0 -0
  211. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/conversion/value.py +0 -0
  212. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/__init__.py +0 -0
  213. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/checkpointer_pb2.py +0 -0
  214. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/checkpointer_pb2.pyi +0 -0
  215. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/checkpointer_pb2_grpc.py +0 -0
  216. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/checkpointer_pb2_grpc.pyi +0 -0
  217. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/core_api_pb2_grpc.py +0 -0
  218. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/core_api_pb2_grpc.pyi +0 -0
  219. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/encryption_pb2.py +0 -0
  220. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/encryption_pb2.pyi +0 -0
  221. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/encryption_pb2_grpc.py +0 -0
  222. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/encryption_pb2_grpc.pyi +0 -0
  223. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/engine_api_pb2.py +0 -0
  224. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/engine_api_pb2.pyi +0 -0
  225. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/engine_api_pb2_grpc.py +0 -0
  226. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/engine_api_pb2_grpc.pyi +0 -0
  227. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/engine_common_pb2.py +0 -0
  228. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/engine_common_pb2.pyi +0 -0
  229. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/engine_common_pb2_grpc.py +0 -0
  230. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/engine_common_pb2_grpc.pyi +0 -0
  231. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/enum_cancel_run_action_pb2.py +0 -0
  232. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/enum_cancel_run_action_pb2.pyi +0 -0
  233. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/enum_cancel_run_action_pb2_grpc.py +0 -0
  234. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/enum_cancel_run_action_pb2_grpc.pyi +0 -0
  235. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/enum_control_signal_pb2.py +0 -0
  236. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/enum_control_signal_pb2.pyi +0 -0
  237. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/enum_control_signal_pb2_grpc.py +0 -0
  238. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/enum_control_signal_pb2_grpc.pyi +0 -0
  239. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/enum_cron_on_run_completed_pb2.py +0 -0
  240. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/enum_cron_on_run_completed_pb2.pyi +0 -0
  241. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/enum_cron_on_run_completed_pb2_grpc.py +0 -0
  242. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/enum_cron_on_run_completed_pb2_grpc.pyi +0 -0
  243. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/enum_durability_pb2.py +0 -0
  244. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/enum_durability_pb2.pyi +0 -0
  245. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/enum_durability_pb2_grpc.py +0 -0
  246. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/enum_durability_pb2_grpc.pyi +0 -0
  247. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/enum_multitask_strategy_pb2.py +0 -0
  248. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/enum_multitask_strategy_pb2.pyi +0 -0
  249. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/enum_multitask_strategy_pb2_grpc.py +0 -0
  250. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/enum_multitask_strategy_pb2_grpc.pyi +0 -0
  251. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/enum_run_status_pb2.py +0 -0
  252. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/enum_run_status_pb2.pyi +0 -0
  253. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/enum_run_status_pb2_grpc.py +0 -0
  254. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/enum_run_status_pb2_grpc.pyi +0 -0
  255. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/enum_store_operation_entry_type_pb2.py +0 -0
  256. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/enum_store_operation_entry_type_pb2.pyi +0 -0
  257. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/enum_store_operation_entry_type_pb2_grpc.py +0 -0
  258. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/enum_store_operation_entry_type_pb2_grpc.pyi +0 -0
  259. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/enum_stream_mode_pb2.py +0 -0
  260. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/enum_stream_mode_pb2.pyi +0 -0
  261. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/enum_stream_mode_pb2_grpc.py +0 -0
  262. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/enum_stream_mode_pb2_grpc.pyi +0 -0
  263. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/enum_thread_status_pb2.py +0 -0
  264. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/enum_thread_status_pb2.pyi +0 -0
  265. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/enum_thread_status_pb2_grpc.py +0 -0
  266. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/enum_thread_status_pb2_grpc.pyi +0 -0
  267. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/enum_thread_stream_mode_pb2.py +0 -0
  268. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/enum_thread_stream_mode_pb2.pyi +0 -0
  269. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/enum_thread_stream_mode_pb2_grpc.py +0 -0
  270. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/enum_thread_stream_mode_pb2_grpc.pyi +0 -0
  271. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/errors_pb2.py +0 -0
  272. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/errors_pb2.pyi +0 -0
  273. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/errors_pb2_grpc.py +0 -0
  274. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/errors_pb2_grpc.pyi +0 -0
  275. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/executor_api_pb2.py +0 -0
  276. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/executor_api_pb2.pyi +0 -0
  277. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/executor_api_pb2_grpc.py +0 -0
  278. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/proto/executor_api_pb2_grpc.pyi +0 -0
  279. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/sanitize.py +0 -0
  280. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_grpc_common/serde.py +0 -0
  281. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_license/__init__.py +0 -0
  282. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_license/validation.py +0 -0
  283. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_runtime/__init__.py +0 -0
  284. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_runtime/checkpoint.py +0 -0
  285. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_runtime/database.py +0 -0
  286. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_runtime/lifespan.py +0 -0
  287. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_runtime/metrics.py +0 -0
  288. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_runtime/ops.py +0 -0
  289. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_runtime/queue.py +0 -0
  290. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_runtime/retry.py +0 -0
  291. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_runtime/routes.py +0 -0
  292. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/langgraph_runtime/store.py +0 -0
  293. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/logging.json +0 -0
  294. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/openapi.json +0 -0
  295. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/scripts/build_wheel.py +0 -0
  296. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/scripts/create_license.py +0 -0
  297. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/scripts/run_a2a_tck.py +0 -0
  298. {langgraph_api-0.8.0 → langgraph_api-0.8.1}/uv.lock +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: langgraph-api
3
- Version: 0.8.0
3
+ Version: 0.8.1
4
4
  Author-email: Will Fu-Hinthorn <will@langchain.dev>, Josh Rogers <josh@langchain.dev>, Parker Rule <parker@langchain.dev>
5
5
  License: Elastic-2.0
6
6
  License-File: LICENSE
@@ -15,7 +15,7 @@ Requires-Dist: httpx>=0.25.0
15
15
  Requires-Dist: jsonschema-rs<0.45,>=0.20.0
16
16
  Requires-Dist: langchain-core>=0.3.64
17
17
  Requires-Dist: langgraph-checkpoint<5,>=3.0.1
18
- Requires-Dist: langgraph-runtime-inmem<0.28.0,>=0.27.0
18
+ Requires-Dist: langgraph-runtime-inmem<0.29.0,>=0.28.0
19
19
  Requires-Dist: langgraph-sdk>=0.3.5
20
20
  Requires-Dist: langgraph<2,>=0.4.10
21
21
  Requires-Dist: langsmith[otel]>=0.6.3
@@ -0,0 +1 @@
1
+ __version__ = "0.8.1"
@@ -1,7 +1,7 @@
1
1
  import asyncio
2
2
  from collections.abc import AsyncIterator, Awaitable, Callable
3
3
  from typing import Any, Literal, cast
4
- from uuid import UUID, uuid4
4
+ from uuid import UUID
5
5
 
6
6
  import orjson
7
7
  import structlog
@@ -374,7 +374,7 @@ async def stream_run_stateless(
374
374
  payload["if_not_exists"] = "create"
375
375
  on_disconnect = payload.get("on_disconnect", "continue")
376
376
  run_id = uuid7()
377
- thread_id = uuid4()
377
+ thread_id = uuid7()
378
378
 
379
379
  sub = await Runs.Stream.subscribe(run_id, thread_id)
380
380
  try:
@@ -468,7 +468,7 @@ async def wait_run_stateless(request: ApiRequest):
468
468
  payload["if_not_exists"] = "create"
469
469
  on_disconnect = payload.get("on_disconnect", "continue")
470
470
  run_id = uuid7()
471
- thread_id = uuid4()
471
+ thread_id = uuid7()
472
472
 
473
473
  sub = await Runs.Stream.subscribe(run_id, thread_id)
474
474
  try:
@@ -533,7 +533,7 @@ async def list_runs(
533
533
 
534
534
  async with connect() as conn:
535
535
  thread, runs = await asyncio.gather(
536
- Threads.get(conn, thread_id),
536
+ Threads.get(conn, thread_id, read_mask_paths=[]),
537
537
  Runs.search(
538
538
  conn,
539
539
  thread_id,
@@ -562,7 +562,7 @@ async def get_run(request: ApiRequest):
562
562
 
563
563
  async with connect() as conn:
564
564
  thread, run = await asyncio.gather(
565
- Threads.get(conn, thread_id),
565
+ Threads.get(conn, thread_id, read_mask_paths=[]),
566
566
  Runs.get(
567
567
  conn,
568
568
  run_id,
@@ -1,5 +1,4 @@
1
1
  from typing import get_args
2
- from uuid import uuid4
3
2
 
4
3
  from starlette.exceptions import HTTPException
5
4
  from starlette.responses import Response
@@ -26,6 +25,7 @@ from langgraph_api.state import state_snapshot_to_thread_state
26
25
  from langgraph_api.utils import (
27
26
  fetchone,
28
27
  get_pagination_headers,
28
+ uuid7,
29
29
  validate_select_columns,
30
30
  validate_stream_id,
31
31
  validate_uuid,
@@ -69,7 +69,7 @@ async def create_thread(
69
69
  ["metadata"],
70
70
  )
71
71
 
72
- thread_id = thread_id or str(uuid4())
72
+ thread_id = thread_id or str(uuid7())
73
73
  supersteps = payload.get("supersteps")
74
74
 
75
75
  if IS_POSTGRES_OR_GRPC_BACKEND and not supersteps:
@@ -45,6 +45,17 @@ DATABASE_URI = env("DATABASE_URI", cast=str, default=getenv("POSTGRES_URI", unde
45
45
  # Not in public docs: infrastructure, set by platform
46
46
  MIGRATIONS_PATH = env("MIGRATIONS_PATH", cast=str, default="/storage/migrations")
47
47
  POSTGRES_POOL_MAX_SIZE = env("LANGGRAPH_POSTGRES_POOL_MAX_SIZE", cast=int, default=150)
48
+
49
+ # Checkpoint ingestion batch controls
50
+ # Go defaults (core/config/config.go): CHECKPOINT_MAX_BATCH_SIZE=1000, CHECKPOINT_BATCH_DELAY=0.005 (5ms)
51
+ # CHECKPOINT_BATCH_DELAY uses float seconds to match Go's time.Duration env parsing convention.
52
+ # storage_postgres/Makefile sets these to the Go defaults for CI/local dev.
53
+ # TODO(braa): flip these to match Go defaults once validated in production (LSD-1404)
54
+ CHECKPOINT_MAX_BATCH_SIZE: int | None = env(
55
+ "CHECKPOINT_MAX_BATCH_SIZE", cast=int, default=None
56
+ )
57
+ CHECKPOINT_BATCH_DELAY: float = env("CHECKPOINT_BATCH_DELAY", cast=float, default=0.0)
58
+
48
59
  RESUMABLE_STREAM_TTL_SECONDS = env(
49
60
  "RESUMABLE_STREAM_TTL_SECONDS",
50
61
  cast=int,
@@ -579,6 +590,8 @@ __all__ = [
579
590
  "BG_JOB_SHUTDOWN_GRACE_PERIOD_SECS",
580
591
  "BG_JOB_TIMEOUT_SECS",
581
592
  "CHECKPOINTER_CONFIG",
593
+ "CHECKPOINT_BATCH_DELAY",
594
+ "CHECKPOINT_MAX_BATCH_SIZE",
582
595
  "CORS_ALLOW_ORIGINS",
583
596
  "CORS_CONFIG",
584
597
  "CRON_SCHEDULER_SLEEP_TIME",
@@ -64,6 +64,12 @@ if TYPE_CHECKING:
64
64
  logger = structlog.stdlib.get_logger(__name__)
65
65
 
66
66
 
67
+ # Read-mask preset for Threads.get callers that need metadata/config but not
68
+ # the large "values" column. Used by state get/update/bulk/history which
69
+ # only need graph_id (from metadata) and the thread config.
70
+ THREAD_METADATA_READ_MASK_PATHS: list[str] = ["metadata", "config"]
71
+
72
+
67
73
  THREAD_STATUS_TO_PB = {
68
74
  "idle": enum_thread_status.idle,
69
75
  "busy": enum_thread_status.busy,
@@ -471,6 +477,7 @@ class Threads(Authenticated):
471
477
  ctx: Auth.types.BaseAuthContext | None = None,
472
478
  filters: Auth.types.FilterType | list[pb.AuthFilter] | None = None,
473
479
  include_ttl: bool = False,
480
+ read_mask_paths: list[str] | None = None,
474
481
  ) -> AsyncIterator[Thread]:
475
482
  """Get a thread by ID.
476
483
 
@@ -482,6 +489,11 @@ class Threads(Authenticated):
482
489
  Accepts either raw dict filters (FilterType) or pre-processed
483
490
  proto filters (list[pb.AuthFilter]).
484
491
  include_ttl: When True, include TTL information in the response.
492
+ read_mask_paths: Optional list of field names to fetch from the DB.
493
+ None (default) fetches all columns. When set, only those columns
494
+ (plus always-included identity/status columns) are queried.
495
+ Use ["metadata", "config"] to skip the large "values" column, or
496
+ [] for an auth/existence check that discards the thread body.
485
497
  """
486
498
  auth_filters = await Threads.handle_event(
487
499
  ctx, "read", {"thread_id": str(thread_id)}
@@ -496,10 +508,16 @@ class Threads(Authenticated):
496
508
  # Raw dict format, convert to proto
497
509
  auth_filters = (auth_filters or []) + _filters_to_proto(filters)
498
510
 
511
+ read_mask = (
512
+ field_mask_pb2.FieldMask(paths=read_mask_paths)
513
+ if read_mask_paths is not None
514
+ else None
515
+ )
499
516
  request = pb.GetThreadRequest(
500
517
  thread_id=pb.UUID(value=_normalize_uuid(thread_id)),
501
518
  filters=auth_filters,
502
519
  include_ttl=include_ttl if include_ttl else None,
520
+ read_mask=read_mask,
503
521
  )
504
522
  client = await get_shared_client()
505
523
  response = await client.threads.Get(request)
@@ -974,7 +992,12 @@ class Threads(Authenticated):
974
992
 
975
993
  async with conn.pipeline():
976
994
  thread, checkpoint_iter, graph_id = await asyncio.gather(
977
- Threads.get(conn, thread_id, ctx=ctx),
995
+ Threads.get(
996
+ conn,
997
+ thread_id,
998
+ ctx=ctx,
999
+ read_mask_paths=THREAD_METADATA_READ_MASK_PATHS,
1000
+ ),
978
1001
  checkpointer.aget_iter(config),
979
1002
  Threads.get_graph_id(thread_id),
980
1003
  )
@@ -1037,7 +1060,13 @@ class Threads(Authenticated):
1037
1060
 
1038
1061
  async with conn.pipeline():
1039
1062
  thread, checkpoint_iter, graph_id, run_count = await asyncio.gather(
1040
- Threads.get(conn, thread_id, ctx=ctx, filters=filters),
1063
+ Threads.get(
1064
+ conn,
1065
+ thread_id,
1066
+ ctx=ctx,
1067
+ filters=filters,
1068
+ read_mask_paths=THREAD_METADATA_READ_MASK_PATHS,
1069
+ ),
1041
1070
  checkpointer.aget_iter(config),
1042
1071
  Threads.get_graph_id(thread_id),
1043
1072
  Runs.count(thread_id=thread_id, statuses=["pending", "running"]),
@@ -1130,7 +1159,13 @@ class Threads(Authenticated):
1130
1159
 
1131
1160
  async with conn.pipeline():
1132
1161
  thread, graph_id = await asyncio.gather(
1133
- Threads.get(conn, thread_id, ctx=ctx, filters=filters),
1162
+ Threads.get(
1163
+ conn,
1164
+ thread_id,
1165
+ ctx=ctx,
1166
+ filters=filters,
1167
+ read_mask_paths=THREAD_METADATA_READ_MASK_PATHS,
1168
+ ),
1134
1169
  Threads.get_graph_id(config["configurable"]["thread_id"]),
1135
1170
  )
1136
1171
  thread = await fetchone(thread)
@@ -1218,7 +1253,12 @@ class Threads(Authenticated):
1218
1253
  """Get the history of a thread."""
1219
1254
  async with conn.pipeline():
1220
1255
  thread, graph_id = await asyncio.gather(
1221
- Threads.get(conn, config["configurable"]["thread_id"], ctx=ctx),
1256
+ Threads.get(
1257
+ conn,
1258
+ config["configurable"]["thread_id"],
1259
+ ctx=ctx,
1260
+ read_mask_paths=THREAD_METADATA_READ_MASK_PATHS,
1261
+ ),
1222
1262
  Threads.get_graph_id(config["configurable"]["thread_id"]),
1223
1263
  )
1224
1264
  thread = await fetchone(thread)
@@ -0,0 +1,272 @@
1
+ # -*- coding: utf-8 -*-
2
+ # Generated by the protocol buffer compiler. DO NOT EDIT!
3
+ # NO CHECKED-IN PROTOBUF GENCODE
4
+ # source: core-api.proto
5
+ # Protobuf Python Version: 6.31.1
6
+ """Generated protocol buffer code."""
7
+ from google.protobuf import descriptor as _descriptor
8
+ from google.protobuf import descriptor_pool as _descriptor_pool
9
+ from google.protobuf import runtime_version as _runtime_version
10
+ from google.protobuf import symbol_database as _symbol_database
11
+ from google.protobuf.internal import builder as _builder
12
+ _runtime_version.ValidateProtobufRuntimeVersion(
13
+ _runtime_version.Domain.PUBLIC,
14
+ 6,
15
+ 31,
16
+ 1,
17
+ '',
18
+ 'core-api.proto'
19
+ )
20
+ # @@protoc_insertion_point(imports)
21
+
22
+ _sym_db = _symbol_database.Default()
23
+
24
+
25
+ from google.protobuf import duration_pb2 as google_dot_protobuf_dot_duration__pb2
26
+ from google.protobuf import empty_pb2 as google_dot_protobuf_dot_empty__pb2
27
+ from google.protobuf import field_mask_pb2 as google_dot_protobuf_dot_field__mask__pb2
28
+ from google.protobuf import struct_pb2 as google_dot_protobuf_dot_struct__pb2
29
+ from google.protobuf import timestamp_pb2 as google_dot_protobuf_dot_timestamp__pb2
30
+ from . import encryption_pb2 as encryption__pb2
31
+ from . import engine_common_pb2 as engine__common__pb2
32
+ from . import enum_run_status_pb2 as enum__run__status__pb2
33
+ from . import enum_multitask_strategy_pb2 as enum__multitask__strategy__pb2
34
+ from . import enum_stream_mode_pb2 as enum__stream__mode__pb2
35
+ from . import enum_cancel_run_action_pb2 as enum__cancel__run__action__pb2
36
+ from . import enum_thread_status_pb2 as enum__thread__status__pb2
37
+ from . import enum_thread_stream_mode_pb2 as enum__thread__stream__mode__pb2
38
+ from . import enum_control_signal_pb2 as enum__control__signal__pb2
39
+ from . import enum_cron_on_run_completed_pb2 as enum__cron__on__run__completed__pb2
40
+
41
+
42
+ DESCRIPTOR = _descriptor_pool.Default().AddSerializedFile(b'\n\x0e\x63ore-api.proto\x12\x07\x63oreApi\x1a\x1egoogle/protobuf/duration.proto\x1a\x1bgoogle/protobuf/empty.proto\x1a google/protobuf/field_mask.proto\x1a\x1cgoogle/protobuf/struct.proto\x1a\x1fgoogle/protobuf/timestamp.proto\x1a\x10\x65ncryption.proto\x1a\x13\x65ngine-common.proto\x1a\x15\x65num_run_status.proto\x1a\x1d\x65num_multitask_strategy.proto\x1a\x16\x65num_stream_mode.proto\x1a\x1c\x65num_cancel_run_action.proto\x1a\x18\x65num_thread_status.proto\x1a\x1d\x65num_thread_stream_mode.proto\x1a\x19\x65num_control_signal.proto\x1a enum_cron_on_run_completed.proto\"\x16\n\x04Tags\x12\x0e\n\x06values\x18\x01 \x03(\t\"*\n\x0c\x45qAuthFilter\x12\x0b\n\x03key\x18\x01 \x01(\t\x12\r\n\x05match\x18\x02 \x01(\t\"2\n\x12\x43ontainsAuthFilter\x12\x0b\n\x03key\x18\x01 \x01(\t\x12\x0f\n\x07matches\x18\x02 \x03(\t\"4\n\x0cOrAuthFilter\x12$\n\x07\x66ilters\x18\x01 \x03(\x0b\x32\x13.coreApi.AuthFilter\"5\n\rAndAuthFilter\x12$\n\x07\x66ilters\x18\x01 \x03(\x0b\x32\x13.coreApi.AuthFilter\"\xc6\x01\n\nAuthFilter\x12#\n\x02\x65q\x18\x01 \x01(\x0b\x32\x15.coreApi.EqAuthFilterH\x00\x12/\n\x08\x63ontains\x18\x02 \x01(\x0b\x32\x1b.coreApi.ContainsAuthFilterH\x00\x12*\n\tor_filter\x18\x03 \x01(\x0b\x32\x15.coreApi.OrAuthFilterH\x00\x12,\n\nand_filter\x18\x04 \x01(\x0b\x32\x16.coreApi.AndAuthFilterH\x00\x42\x08\n\x06\x66ilter\"\x15\n\x04UUID\x12\r\n\x05value\x18\x01 \x01(\t\"\x1e\n\rCountResponse\x12\r\n\x05\x63ount\x18\x01 \x01(\x04\"X\n\x0bStreamEvent\x12\x12\n\nevent_type\x18\x01 \x01(\t\x12\x0f\n\x07message\x18\x02 \x01(\x0c\x12\x16\n\tstream_id\x18\x03 \x01(\tH\x00\x88\x01\x01\x42\x0c\n\n_stream_id\"\xfa\x02\n\tAssistant\x12\x14\n\x0c\x61ssistant_id\x18\x01 \x01(\t\x12\x10\n\x08graph_id\x18\x02 \x01(\t\x12\x0f\n\x07version\x18\x03 \x01(\x04\x12.\n\ncreated_at\x18\x04 \x01(\x0b\x32\x1a.google.protobuf.Timestamp\x12.\n\nupdated_at\x18\x05 \x01(\x0b\x32\x1a.google.protobuf.Timestamp\x12\x37\n\x06\x63onfig\x18\x06 \x01(\x0b\x32\".engineCommon.EngineRunnableConfigH\x00\x88\x01\x01\x12\x19\n\x0c\x63ontext_json\x18\x07 \x01(\x0cH\x01\x88\x01\x01\x12\x1a\n\rmetadata_json\x18\x08 \x01(\x0cH\x02\x88\x01\x01\x12\x0c\n\x04name\x18\t \x01(\t\x12\x18\n\x0b\x64\x65scription\x18\n \x01(\tH\x03\x88\x01\x01\x42\t\n\x07_configB\x0f\n\r_context_jsonB\x10\n\x0e_metadata_jsonB\x0e\n\x0c_description\"\xd1\x02\n\x10\x41ssistantVersion\x12\x14\n\x0c\x61ssistant_id\x18\x01 \x01(\t\x12\x10\n\x08graph_id\x18\x02 \x01(\t\x12\x0f\n\x07version\x18\x03 \x01(\x04\x12.\n\ncreated_at\x18\x04 \x01(\x0b\x32\x1a.google.protobuf.Timestamp\x12\x37\n\x06\x63onfig\x18\x05 \x01(\x0b\x32\".engineCommon.EngineRunnableConfigH\x00\x88\x01\x01\x12\x19\n\x0c\x63ontext_json\x18\x06 \x01(\x0cH\x01\x88\x01\x01\x12\x1a\n\rmetadata_json\x18\x07 \x01(\x0cH\x02\x88\x01\x01\x12\x0c\n\x04name\x18\x08 \x01(\t\x12\x18\n\x0b\x64\x65scription\x18\t \x01(\tH\x03\x88\x01\x01\x42\t\n\x07_configB\x0f\n\r_context_jsonB\x10\n\x0e_metadata_jsonB\x0e\n\x0c_description\"\x9d\x03\n\x16\x43reateAssistantRequest\x12\x14\n\x0c\x61ssistant_id\x18\x01 \x01(\t\x12\x10\n\x08graph_id\x18\x02 \x01(\t\x12$\n\x07\x66ilters\x18\x03 \x03(\x0b\x32\x13.coreApi.AuthFilter\x12.\n\tif_exists\x18\x04 \x01(\x0e\x32\x1b.coreApi.OnConflictBehavior\x12\x32\n\x06\x63onfig\x18\x05 \x01(\x0b\x32\".engineCommon.EngineRunnableConfig\x12\x14\n\x0c\x63ontext_json\x18\x06 \x01(\x0c\x12\x0c\n\x04name\x18\x07 \x01(\t\x12\x18\n\x0b\x64\x65scription\x18\x08 \x01(\tH\x00\x88\x01\x01\x12\x1a\n\rmetadata_json\x18\t \x01(\x0cH\x01\x88\x01\x01\x12>\n\x12\x65ncryption_context\x18\n \x01(\x0b\x32\x1d.encryption.EncryptionContextH\x02\x88\x01\x01\x42\x0e\n\x0c_descriptionB\x10\n\x0e_metadata_jsonB\x15\n\x13_encryption_context\"Q\n\x13GetAssistantRequest\x12\x14\n\x0c\x61ssistant_id\x18\x01 \x01(\t\x12$\n\x07\x66ilters\x18\x02 \x03(\x0b\x32\x13.coreApi.AuthFilter\"\xb2\x03\n\x15PatchAssistantRequest\x12\x14\n\x0c\x61ssistant_id\x18\x01 \x01(\t\x12$\n\x07\x66ilters\x18\x02 \x03(\x0b\x32\x13.coreApi.AuthFilter\x12\x15\n\x08graph_id\x18\x03 \x01(\tH\x00\x88\x01\x01\x12\x37\n\x06\x63onfig\x18\x04 \x01(\x0b\x32\".engineCommon.EngineRunnableConfigH\x01\x88\x01\x01\x12\x19\n\x0c\x63ontext_json\x18\x05 \x01(\x0cH\x02\x88\x01\x01\x12\x11\n\x04name\x18\x06 \x01(\tH\x03\x88\x01\x01\x12\x18\n\x0b\x64\x65scription\x18\x07 \x01(\tH\x04\x88\x01\x01\x12\x1a\n\rmetadata_json\x18\x08 \x01(\x0cH\x05\x88\x01\x01\x12>\n\x12\x65ncryption_context\x18\t \x01(\x0b\x32\x1d.encryption.EncryptionContextH\x06\x88\x01\x01\x42\x0b\n\t_graph_idB\t\n\x07_configB\x0f\n\r_context_jsonB\x07\n\x05_nameB\x0e\n\x0c_descriptionB\x10\n\x0e_metadata_jsonB\x15\n\x13_encryption_context\"\x84\x01\n\x16\x44\x65leteAssistantRequest\x12\x14\n\x0c\x61ssistant_id\x18\x01 \x01(\t\x12$\n\x07\x66ilters\x18\x02 \x03(\x0b\x32\x13.coreApi.AuthFilter\x12\x1b\n\x0e\x64\x65lete_threads\x18\x03 \x01(\x08H\x00\x88\x01\x01\x42\x11\n\x0f_delete_threads\"1\n\x18\x44\x65leteAssistantsResponse\x12\x15\n\rassistant_ids\x18\x01 \x03(\t\"h\n\x19SetLatestAssistantRequest\x12\x14\n\x0c\x61ssistant_id\x18\x01 \x01(\t\x12\x0f\n\x07version\x18\x02 \x01(\x03\x12$\n\x07\x66ilters\x18\x03 \x03(\x0b\x32\x13.coreApi.AuthFilter\"\xf4\x02\n\x17SearchAssistantsRequest\x12$\n\x07\x66ilters\x18\x01 \x03(\x0b\x32\x13.coreApi.AuthFilter\x12\x15\n\x08graph_id\x18\x02 \x01(\tH\x00\x88\x01\x01\x12\x1a\n\rmetadata_json\x18\x03 \x01(\x0cH\x01\x88\x01\x01\x12\x12\n\x05limit\x18\x04 \x01(\x04H\x02\x88\x01\x01\x12\x13\n\x06offset\x18\x05 \x01(\x04H\x03\x88\x01\x01\x12/\n\x07sort_by\x18\x06 \x01(\x0e\x32\x19.coreApi.AssistantsSortByH\x04\x88\x01\x01\x12+\n\nsort_order\x18\x07 \x01(\x0e\x32\x12.coreApi.SortOrderH\x05\x88\x01\x01\x12\x0e\n\x06select\x18\x08 \x03(\t\x12\x11\n\x04name\x18\t \x01(\tH\x06\x88\x01\x01\x42\x0b\n\t_graph_idB\x10\n\x0e_metadata_jsonB\x08\n\x06_limitB\t\n\x07_offsetB\n\n\x08_sort_byB\r\n\x0b_sort_orderB\x07\n\x05_name\"B\n\x18SearchAssistantsResponse\x12&\n\nassistants\x18\x01 \x03(\x0b\x32\x12.coreApi.Assistant\"\xc5\x01\n\x1bGetAssistantVersionsRequest\x12\x14\n\x0c\x61ssistant_id\x18\x01 \x01(\t\x12$\n\x07\x66ilters\x18\x02 \x03(\x0b\x32\x13.coreApi.AuthFilter\x12\x1a\n\rmetadata_json\x18\x03 \x01(\x0cH\x00\x88\x01\x01\x12\x12\n\x05limit\x18\x04 \x01(\x04H\x01\x88\x01\x01\x12\x13\n\x06offset\x18\x05 \x01(\x04H\x02\x88\x01\x01\x42\x10\n\x0e_metadata_jsonB\x08\n\x06_limitB\t\n\x07_offset\"K\n\x1cGetAssistantVersionsResponse\x12+\n\x08versions\x18\x01 \x03(\x0b\x32\x19.coreApi.AssistantVersion\"\xac\x01\n\x16\x43ountAssistantsRequest\x12$\n\x07\x66ilters\x18\x01 \x03(\x0b\x32\x13.coreApi.AuthFilter\x12\x15\n\x08graph_id\x18\x02 \x01(\tH\x00\x88\x01\x01\x12\x1a\n\rmetadata_json\x18\x03 \x01(\x0cH\x01\x88\x01\x01\x12\x11\n\x04name\x18\x04 \x01(\tH\x02\x88\x01\x01\x42\x0b\n\t_graph_idB\x10\n\x0e_metadata_jsonB\x07\n\x05_name\"i\n\x0fTruncateRequest\x12\x0c\n\x04runs\x18\x01 \x01(\x08\x12\x0f\n\x07threads\x18\x02 \x01(\x08\x12\x12\n\nassistants\x18\x03 \x01(\x08\x12\x14\n\x0c\x63heckpointer\x18\x04 \x01(\x08\x12\r\n\x05store\x18\x05 \x01(\x08\"\xbb\x01\n\x0fThreadTTLConfig\x12\x31\n\x08strategy\x18\x01 \x01(\x0e\x32\x1a.coreApi.ThreadTTLStrategyH\x00\x88\x01\x01\x12\x18\n\x0b\x64\x65\x66\x61ult_ttl\x18\x02 \x01(\x01H\x01\x88\x01\x01\x12#\n\x16sweep_interval_minutes\x18\x03 \x01(\x05H\x02\x88\x01\x01\x42\x0b\n\t_strategyB\x0e\n\x0c_default_ttlB\x19\n\x17_sweep_interval_minutes\"\x82\x01\n\rThreadTTLInfo\x12,\n\x08strategy\x18\x01 \x01(\x0e\x32\x1a.coreApi.ThreadTTLStrategy\x12\x13\n\x0bttl_minutes\x18\x02 \x01(\x01\x12.\n\nexpires_at\x18\x03 \x01(\x0b\x32\x1a.google.protobuf.Timestamp\"\x19\n\x08\x46ragment\x12\r\n\x05value\x18\x01 \x01(\x0c\"\x89\x01\n\x0e\x43heckpointTask\x12\n\n\x02id\x18\x01 \x01(\t\x12\x0c\n\x04name\x18\x02 \x01(\t\x12\x12\n\x05\x65rror\x18\x03 \x01(\tH\x00\x88\x01\x01\x12\x17\n\x0finterrupts_json\x18\x04 \x03(\x0c\x12\x17\n\nstate_json\x18\x05 \x01(\x0cH\x01\x88\x01\x01\x42\x08\n\x06_errorB\r\n\x0b_state_json\"\xd6\x01\n\x12\x43heckpointMetadata\x12.\n\x06source\x18\x01 \x01(\x0e\x32\x19.coreApi.CheckpointSourceH\x00\x88\x01\x01\x12\x11\n\x04step\x18\x02 \x01(\x04H\x01\x88\x01\x01\x12\x39\n\x07parents\x18\x03 \x03(\x0b\x32(.coreApi.CheckpointMetadata.ParentsEntry\x1a.\n\x0cParentsEntry\x12\x0b\n\x03key\x18\x01 \x01(\t\x12\r\n\x05value\x18\x02 \x01(\t:\x02\x38\x01\x42\t\n\x07_sourceB\x07\n\x05_step\"\xa3\x02\n\x11\x43heckpointPayload\x12\x37\n\x06\x63onfig\x18\x01 \x01(\x0b\x32\".engineCommon.EngineRunnableConfigH\x00\x88\x01\x01\x12-\n\x08metadata\x18\x02 \x01(\x0b\x32\x1b.coreApi.CheckpointMetadata\x12\x13\n\x0bvalues_json\x18\x03 \x01(\x0c\x12\x0c\n\x04next\x18\x04 \x03(\t\x12>\n\rparent_config\x18\x05 \x01(\x0b\x32\".engineCommon.EngineRunnableConfigH\x01\x88\x01\x01\x12&\n\x05tasks\x18\x06 \x03(\x0b\x32\x17.coreApi.CheckpointTaskB\t\n\x07_configB\x10\n\x0e_parent_config\"T\n\x16ThreadStatusCheckpoint\x12\x13\n\x0bvalues_json\x18\x01 \x01(\x0c\x12\x0c\n\x04next\x18\x02 \x03(\t\x12\x17\n\x0finterrupts_json\x18\x03 \x01(\x0c\"\x80\x01\n\tInterrupt\x12\x0f\n\x02id\x18\x01 \x01(\tH\x00\x88\x01\x01\x12\r\n\x05value\x18\x02 \x01(\x0c\x12\x11\n\x04when\x18\x03 \x01(\tH\x01\x88\x01\x01\x12\x16\n\tresumable\x18\x04 \x01(\x08H\x02\x88\x01\x01\x12\n\n\x02ns\x18\x05 \x03(\tB\x05\n\x03_idB\x07\n\x05_whenB\x0c\n\n_resumable\"4\n\nInterrupts\x12&\n\ninterrupts\x18\x01 \x03(\x0b\x32\x12.coreApi.Interrupt\"\xdc\x04\n\x06Thread\x12 \n\tthread_id\x18\x01 \x01(\x0b\x32\r.coreApi.UUID\x12.\n\ncreated_at\x18\x02 \x01(\x0b\x32\x1a.google.protobuf.Timestamp\x12.\n\nupdated_at\x18\x03 \x01(\x0b\x32\x1a.google.protobuf.Timestamp\x12#\n\x08metadata\x18\x04 \x01(\x0b\x32\x11.coreApi.Fragment\x12!\n\x06\x63onfig\x18\x05 \x01(\x0b\x32\x11.coreApi.Fragment\x12.\n\x06status\x18\x06 \x01(\x0e\x32\x1e.enumThreadStatus.ThreadStatus\x12!\n\x06values\x18\x07 \x01(\x0b\x32\x11.coreApi.Fragment\x12\x33\n\ninterrupts\x18\x08 \x03(\x0b\x32\x1f.coreApi.Thread.InterruptsEntry\x12 \n\x05\x65rror\x18\t \x01(\x0b\x32\x11.coreApi.Fragment\x12\x34\n\x10state_updated_at\x18\n \x01(\x0b\x32\x1a.google.protobuf.Timestamp\x12\x1b\n\x0e\x65xtracted_json\x18\x0b \x01(\x0cH\x00\x88\x01\x01\x12(\n\x03ttl\x18\x0c \x01(\x0b\x32\x16.coreApi.ThreadTTLInfoH\x01\x88\x01\x01\x1a\x46\n\x0fInterruptsEntry\x12\x0b\n\x03key\x18\x01 \x01(\t\x12\"\n\x05value\x18\x02 \x01(\x0b\x32\x13.coreApi.Interrupts:\x02\x38\x01\x42\x11\n\x0f_extracted_jsonB\x06\n\x04_ttl\"\xc6\x02\n\x13\x43reateThreadRequest\x12 \n\tthread_id\x18\x01 \x01(\x0b\x32\r.coreApi.UUID\x12$\n\x07\x66ilters\x18\x02 \x03(\x0b\x32\x13.coreApi.AuthFilter\x12.\n\tif_exists\x18\x03 \x01(\x0e\x32\x1b.coreApi.OnConflictBehavior\x12\x1a\n\rmetadata_json\x18\x04 \x01(\x0cH\x00\x88\x01\x01\x12*\n\x03ttl\x18\x05 \x01(\x0b\x32\x18.coreApi.ThreadTTLConfigH\x01\x88\x01\x01\x12>\n\x12\x65ncryption_context\x18\x06 \x01(\x0b\x32\x1d.encryption.EncryptionContextH\x02\x88\x01\x01\x42\x10\n\x0e_metadata_jsonB\x06\n\x04_ttlB\x15\n\x13_encryption_context\"\xc6\x01\n\x10GetThreadRequest\x12 \n\tthread_id\x18\x01 \x01(\x0b\x32\r.coreApi.UUID\x12$\n\x07\x66ilters\x18\x02 \x03(\x0b\x32\x13.coreApi.AuthFilter\x12\x18\n\x0binclude_ttl\x18\x03 \x01(\x08H\x00\x88\x01\x01\x12\x32\n\tread_mask\x18\x04 \x01(\x0b\x32\x1a.google.protobuf.FieldMaskH\x01\x88\x01\x01\x42\x0e\n\x0c_include_ttlB\x0c\n\n_read_mask\"\xd7\x02\n\x12PatchThreadRequest\x12 \n\tthread_id\x18\x01 \x01(\x0b\x32\r.coreApi.UUID\x12$\n\x07\x66ilters\x18\x02 \x03(\x0b\x32\x13.coreApi.AuthFilter\x12\x1a\n\rmetadata_json\x18\x03 \x01(\x0cH\x00\x88\x01\x01\x12*\n\x03ttl\x18\x04 \x01(\x0b\x32\x18.coreApi.ThreadTTLConfigH\x01\x88\x01\x01\x12>\n\x12\x65ncryption_context\x18\x05 \x01(\x0b\x32\x1d.encryption.EncryptionContextH\x02\x88\x01\x01\x12\x32\n\tread_mask\x18\x06 \x01(\x0b\x32\x1a.google.protobuf.FieldMaskH\x03\x88\x01\x01\x42\x10\n\x0e_metadata_jsonB\x06\n\x04_ttlB\x15\n\x13_encryption_contextB\x0c\n\n_read_mask\"]\n\x13\x44\x65leteThreadRequest\x12 \n\tthread_id\x18\x01 \x01(\x0b\x32\r.coreApi.UUID\x12$\n\x07\x66ilters\x18\x02 \x03(\x0b\x32\x13.coreApi.AuthFilter\"[\n\x11\x43opyThreadRequest\x12 \n\tthread_id\x18\x01 \x01(\x0b\x32\r.coreApi.UUID\x12$\n\x07\x66ilters\x18\x02 \x03(\x0b\x32\x13.coreApi.AuthFilter\"\xa1\x04\n\x14SearchThreadsRequest\x12$\n\x07\x66ilters\x18\x01 \x03(\x0b\x32\x13.coreApi.AuthFilter\x12\x1a\n\rmetadata_json\x18\x02 \x01(\x0cH\x00\x88\x01\x01\x12\x18\n\x0bvalues_json\x18\x03 \x01(\x0cH\x01\x88\x01\x01\x12\x33\n\x06status\x18\x04 \x01(\x0e\x32\x1e.enumThreadStatus.ThreadStatusH\x02\x88\x01\x01\x12\x12\n\x05limit\x18\x05 \x01(\x04H\x03\x88\x01\x01\x12\x13\n\x06offset\x18\x06 \x01(\x04H\x04\x88\x01\x01\x12,\n\x07sort_by\x18\x07 \x01(\x0e\x32\x16.coreApi.ThreadsSortByH\x05\x88\x01\x01\x12+\n\nsort_order\x18\x08 \x01(\x0e\x32\x12.coreApi.SortOrderH\x06\x88\x01\x01\x12\x0e\n\x06select\x18\t \x03(\t\x12\x1a\n\x03ids\x18\n \x03(\x0b\x32\r.coreApi.UUID\x12;\n\x07\x65xtract\x18\x0b \x03(\x0b\x32*.coreApi.SearchThreadsRequest.ExtractEntry\x1a.\n\x0c\x45xtractEntry\x12\x0b\n\x03key\x18\x01 \x01(\t\x12\r\n\x05value\x18\x02 \x01(\t:\x02\x38\x01\x42\x10\n\x0e_metadata_jsonB\x0e\n\x0c_values_jsonB\t\n\x07_statusB\x08\n\x06_limitB\t\n\x07_offsetB\n\n\x08_sort_byB\r\n\x0b_sort_order\"9\n\x15SearchThreadsResponse\x12 \n\x07threads\x18\x01 \x03(\x0b\x32\x0f.coreApi.Thread\"\xd3\x01\n\x13\x43ountThreadsRequest\x12$\n\x07\x66ilters\x18\x01 \x03(\x0b\x32\x13.coreApi.AuthFilter\x12\x1a\n\rmetadata_json\x18\x02 \x01(\x0cH\x00\x88\x01\x01\x12\x18\n\x0bvalues_json\x18\x03 \x01(\x0cH\x01\x88\x01\x01\x12\x33\n\x06status\x18\x04 \x01(\x0e\x32\x1e.enumThreadStatus.ThreadStatusH\x02\x88\x01\x01\x42\x10\n\x0e_metadata_jsonB\x0e\n\x0c_values_jsonB\t\n\x07_status\"\xc3\x02\n\x16SetThreadStatusRequest\x12 \n\tthread_id\x18\x01 \x01(\x0b\x32\r.coreApi.UUID\x12\x38\n\ncheckpoint\x18\x02 \x01(\x0b\x32\x1f.coreApi.ThreadStatusCheckpointH\x00\x88\x01\x01\x12\x1b\n\x0e\x65xception_json\x18\x03 \x01(\x0cH\x01\x88\x01\x01\x12\x37\n\x0f\x65xpected_status\x18\x04 \x03(\x0e\x32\x1e.enumThreadStatus.ThreadStatus\x12>\n\x12\x65ncryption_context\x18\x05 \x01(\x0b\x32\x1d.encryption.EncryptionContextH\x02\x88\x01\x01\x42\r\n\x0b_checkpointB\x11\n\x0f_exception_jsonB\x15\n\x13_encryption_context\"\xd4\x02\n\x1bSetThreadJointStatusRequest\x12 \n\tthread_id\x18\x01 \x01(\x0b\x32\r.coreApi.UUID\x12\x1d\n\x06run_id\x18\x02 \x01(\x0b\x32\r.coreApi.UUID\x12\x12\n\nrun_status\x18\x03 \x01(\t\x12\x10\n\x08graph_id\x18\x04 \x01(\t\x12\x38\n\ncheckpoint\x18\x05 \x01(\x0b\x32\x1f.coreApi.ThreadStatusCheckpointH\x00\x88\x01\x01\x12\x1b\n\x0e\x65xception_json\x18\x06 \x01(\x0cH\x01\x88\x01\x01\x12>\n\x12\x65ncryption_context\x18\x07 \x01(\x0b\x32\x1d.encryption.EncryptionContextH\x02\x88\x01\x01\x42\r\n\x0b_checkpointB\x11\n\x0f_exception_jsonB\x15\n\x13_encryption_context\"\xc9\x01\n\x13StreamThreadRequest\x12 \n\tthread_id\x18\x01 \x01(\x0b\x32\r.coreApi.UUID\x12$\n\x07\x66ilters\x18\x02 \x03(\x0b\x32\x13.coreApi.AuthFilter\x12<\n\x0cstream_modes\x18\x03 \x03(\x0e\x32&.enumThreadStreamMode.ThreadStreamMode\x12\x1a\n\rlast_event_id\x18\x04 \x01(\tH\x00\x88\x01\x01\x42\x10\n\x0e_last_event_id\"\xb9\x05\n\tRunKwargs\x12\x37\n\x06\x63onfig\x18\x01 \x01(\x0b\x32\".engineCommon.EngineRunnableConfigH\x00\x88\x01\x01\x12\x19\n\x0c\x63ontext_json\x18\x02 \x01(\x0cH\x01\x88\x01\x01\x12\x17\n\ninput_json\x18\x03 \x01(\x0cH\x02\x88\x01\x01\x12\x19\n\x0c\x63ommand_json\x18\x04 \x01(\x0cH\x03\x88\x01\x01\x12/\n\x0bstream_mode\x18\x05 \x03(\x0e\x32\x1a.enumStreamMode.StreamMode\x12\x42\n\x10interrupt_before\x18\x06 \x01(\x0b\x32#.engineCommon.StaticInterruptConfigH\x04\x88\x01\x01\x12\x41\n\x0finterrupt_after\x18\x07 \x01(\x0b\x32#.engineCommon.StaticInterruptConfigH\x05\x88\x01\x01\x12\x14\n\x07webhook\x18\x08 \x01(\tH\x06\x88\x01\x01\x12\x15\n\rfeedback_keys\x18\t \x03(\t\x12\x16\n\ttemporary\x18\n \x01(\x08H\x07\x88\x01\x01\x12\x16\n\tsubgraphs\x18\x0b \x01(\x08H\x08\x88\x01\x01\x12\x16\n\tresumable\x18\x0c \x01(\x08H\t\x88\x01\x01\x12\x1e\n\x11\x63heckpoint_during\x18\r \x01(\x08H\n\x88\x01\x01\x12\x17\n\ndurability\x18\x0e \x01(\tH\x0b\x88\x01\x01\x42\t\n\x07_configB\x0f\n\r_context_jsonB\r\n\x0b_input_jsonB\x0f\n\r_command_jsonB\x13\n\x11_interrupt_beforeB\x12\n\x10_interrupt_afterB\n\n\x08_webhookB\x0c\n\n_temporaryB\x0c\n\n_subgraphsB\x0c\n\n_resumableB\x14\n\x12_checkpoint_duringB\r\n\x0b_durability\"\x84\x03\n\x03Run\x12\x1d\n\x06run_id\x18\x01 \x01(\x0b\x32\r.coreApi.UUID\x12 \n\tthread_id\x18\x02 \x01(\x0b\x32\r.coreApi.UUID\x12#\n\x0c\x61ssistant_id\x18\x03 \x01(\x0b\x32\r.coreApi.UUID\x12.\n\ncreated_at\x18\x04 \x01(\x0b\x32\x1a.google.protobuf.Timestamp\x12.\n\nupdated_at\x18\x05 \x01(\x0b\x32\x1a.google.protobuf.Timestamp\x12(\n\x06status\x18\x06 \x01(\x0e\x32\x18.enumRunStatus.RunStatus\x12#\n\x08metadata\x18\x07 \x01(\x0b\x32\x11.coreApi.Fragment\x12\"\n\x06kwargs\x18\x08 \x01(\x0b\x32\x12.coreApi.RunKwargs\x12\x44\n\x12multitask_strategy\x18\t \x01(\x0e\x32(.enumMultitaskStrategy.MultitaskStrategy\"\xba\x02\n\x08RunStats\x12\x11\n\tn_pending\x18\x01 \x01(\x04\x12\x11\n\tn_running\x18\x02 \x01(\x04\x12,\n\x1fpending_runs_wait_time_max_secs\x18\x03 \x01(\x01H\x00\x88\x01\x01\x12,\n\x1fpending_runs_wait_time_med_secs\x18\x04 \x01(\x01H\x01\x88\x01\x01\x12\x36\n)pending_unblocked_runs_wait_time_max_secs\x18\x05 \x01(\x01H\x02\x88\x01\x01\x42\"\n _pending_runs_wait_time_max_secsB\"\n _pending_runs_wait_time_med_secsB,\n*_pending_unblocked_runs_wait_time_max_secs\"\x82\x01\n\x11PostgresPoolStats\x12\x10\n\x08pool_max\x18\x01 \x01(\x05\x12\x11\n\tpool_size\x18\x02 \x01(\x05\x12\x16\n\x0epool_available\x18\x03 \x01(\x05\x12\x17\n\x0frequests_queued\x18\x04 \x01(\x03\x12\x17\n\x0frequests_errors\x18\x05 \x01(\x03\"_\n\x0eRedisPoolStats\x12\x18\n\x10idle_connections\x18\x01 \x01(\x05\x12\x1a\n\x12in_use_connections\x18\x02 \x01(\x05\x12\x17\n\x0fmax_connections\x18\x03 \x01(\x05\"\x8c\x01\n\x13\x43onnectionPoolStats\x12\x31\n\x08postgres\x18\x01 \x01(\x0b\x32\x1a.coreApi.PostgresPoolStatsH\x00\x88\x01\x01\x12+\n\x05redis\x18\x02 \x01(\x0b\x32\x17.coreApi.RedisPoolStatsH\x01\x88\x01\x01\x42\x0b\n\t_postgresB\x08\n\x06_redis\"-\n\x0eNextRunRequest\x12\x0c\n\x04wait\x18\x01 \x01(\x08\x12\r\n\x05limit\x18\x02 \x01(\x04\"w\n\x0eRunWithAttempt\x12\x19\n\x03run\x18\x01 \x01(\x0b\x32\x0c.coreApi.Run\x12\x0f\n\x07\x61ttempt\x18\x02 \x01(\x04\x12\x39\n\x12\x65ncryption_context\x18\x03 \x01(\x0b\x32\x1d.encryption.EncryptionContext\"8\n\x0fNextRunResponse\x12%\n\x04runs\x18\x01 \x03(\x0b\x32\x17.coreApi.RunWithAttempt\"\xd2\x06\n\x10\x43reateRunRequest\x12#\n\x0c\x61ssistant_id\x18\x01 \x01(\x0b\x32\r.coreApi.UUID\x12\x13\n\x0bkwargs_json\x18\x02 \x01(\x0c\x12+\n\x0ethread_filters\x18\x03 \x03(\x0b\x32\x13.coreApi.AuthFilter\x12.\n\x11\x61ssistant_filters\x18\x0e \x03(\x0b\x32\x13.coreApi.AuthFilter\x12%\n\tthread_id\x18\x04 \x01(\x0b\x32\r.coreApi.UUIDH\x00\x88\x01\x01\x12\x14\n\x07user_id\x18\x05 \x01(\tH\x01\x88\x01\x01\x12\"\n\x06run_id\x18\x06 \x01(\x0b\x32\r.coreApi.UUIDH\x02\x88\x01\x01\x12-\n\x06status\x18\x07 \x01(\x0e\x32\x18.enumRunStatus.RunStatusH\x03\x88\x01\x01\x12\x1a\n\rmetadata_json\x18\x08 \x01(\x0cH\x04\x88\x01\x01\x12\'\n\x1aprevent_insert_if_inflight\x18\t \x01(\x08H\x05\x88\x01\x01\x12I\n\x12multitask_strategy\x18\n \x01(\x0e\x32(.enumMultitaskStrategy.MultitaskStrategyH\x06\x88\x01\x01\x12\x36\n\rif_not_exists\x18\x0b \x01(\x0e\x32\x1a.coreApi.CreateRunBehaviorH\x07\x88\x01\x01\x12\x1a\n\rafter_seconds\x18\x0c \x01(\x04H\x08\x88\x01\x01\x12\x31\n\nthread_ttl\x18\r \x01(\x0b\x32\x18.coreApi.ThreadTTLConfigH\t\x88\x01\x01\x12>\n\x12\x65ncryption_context\x18\x0f \x01(\x0b\x32\x1d.encryption.EncryptionContextH\n\x88\x01\x01\x42\x0c\n\n_thread_idB\n\n\x08_user_idB\t\n\x07_run_idB\t\n\x07_statusB\x10\n\x0e_metadata_jsonB\x1d\n\x1b_prevent_insert_if_inflightB\x15\n\x13_multitask_strategyB\x10\n\x0e_if_not_existsB\x10\n\x0e_after_secondsB\r\n\x0b_thread_ttlB\x15\n\x13_encryption_context\"v\n\rGetRunRequest\x12\x1d\n\x06run_id\x18\x01 \x01(\x0b\x32\r.coreApi.UUID\x12 \n\tthread_id\x18\x02 \x01(\x0b\x32\r.coreApi.UUID\x12$\n\x07\x66ilters\x18\x03 \x03(\x0b\x32\x13.coreApi.AuthFilter\"y\n\x10\x44\x65leteRunRequest\x12\x1d\n\x06run_id\x18\x01 \x01(\x0b\x32\r.coreApi.UUID\x12 \n\tthread_id\x18\x02 \x01(\x0b\x32\r.coreApi.UUID\x12$\n\x07\x66ilters\x18\x03 \x03(\x0b\x32\x13.coreApi.AuthFilter\"V\n\x12\x43\x61ncelRunIdsTarget\x12 \n\tthread_id\x18\x01 \x01(\x0b\x32\r.coreApi.UUID\x12\x1e\n\x07run_ids\x18\x02 \x03(\x0b\x32\r.coreApi.UUID\">\n\x12\x43\x61ncelStatusTarget\x12(\n\x06status\x18\x01 \x01(\x0e\x32\x18.coreApi.CancelRunStatus\"\xe7\x01\n\x10\x43\x61ncelRunRequest\x12$\n\x07\x66ilters\x18\x01 \x03(\x0b\x32\x13.coreApi.AuthFilter\x12.\n\x07run_ids\x18\x02 \x01(\x0b\x32\x1b.coreApi.CancelRunIdsTargetH\x00\x12-\n\x06status\x18\x03 \x01(\x0b\x32\x1b.coreApi.CancelStatusTargetH\x00\x12\x39\n\x06\x61\x63tion\x18\x04 \x01(\x0e\x32$.enumCancelRunAction.CancelRunActionH\x01\x88\x01\x01\x42\x08\n\x06targetB\t\n\x07_action\"\xe3\x01\n\x11SearchRunsRequest\x12 \n\tthread_id\x18\x01 \x01(\x0b\x32\r.coreApi.UUID\x12$\n\x07\x66ilters\x18\x02 \x03(\x0b\x32\x13.coreApi.AuthFilter\x12\x12\n\x05limit\x18\x03 \x01(\x04H\x00\x88\x01\x01\x12\x13\n\x06offset\x18\x04 \x01(\x04H\x01\x88\x01\x01\x12-\n\x06status\x18\x05 \x01(\x0e\x32\x18.enumRunStatus.RunStatusH\x02\x88\x01\x01\x12\x0e\n\x06select\x18\x06 \x03(\tB\x08\n\x06_limitB\t\n\x07_offsetB\t\n\x07_status\"0\n\x12SearchRunsResponse\x12\x1a\n\x04runs\x18\x01 \x03(\x0b\x32\x0c.coreApi.Run\"^\n\x13SetRunStatusRequest\x12\x1d\n\x06run_id\x18\x01 \x01(\x0b\x32\r.coreApi.UUID\x12(\n\x06status\x18\x02 \x01(\x0e\x32\x18.enumRunStatus.RunStatus\"3\n\x11SweepRunsResponse\x12\x1e\n\x07run_ids\x18\x01 \x03(\x0b\x32\r.coreApi.UUID\"F\n\x10\x43ountRunsRequest\x12 \n\tthread_id\x18\x01 \x01(\x0b\x32\r.coreApi.UUID\x12\x10\n\x08statuses\x18\x02 \x03(\t\"\x7f\n\x16StreamRunClientMessage\x12\x31\n\tsubscribe\x18\x01 \x01(\x0b\x32\x1c.coreApi.SubscribeRunRequestH\x00\x12\'\n\x04join\x18\x02 \x01(\x0b\x32\x17.coreApi.JoinRunRequestH\x00\x42\t\n\x07message\"V\n\x13SubscribeRunRequest\x12 \n\tthread_id\x18\x01 \x01(\x0b\x32\r.coreApi.UUID\x12\x1d\n\x06run_id\x18\x02 \x01(\x0b\x32\r.coreApi.UUID\"\xd2\x01\n\x0eJoinRunRequest\x12$\n\x07\x66ilters\x18\x01 \x03(\x0b\x32\x13.coreApi.AuthFilter\x12\x30\n\x0cstream_modes\x18\x02 \x03(\x0e\x32\x1a.enumStreamMode.StreamMode\x12\x1c\n\x14ignore_run_not_found\x18\x03 \x01(\x08\x12\x1c\n\x14\x63\x61ncel_on_disconnect\x18\x04 \x01(\x08\x12\x1a\n\rlast_event_id\x18\x05 \x01(\tH\x00\x88\x01\x01\x42\x10\n\x0e_last_event_id\"e\n\x0f\x45nterRunRequest\x12\x1d\n\x06run_id\x18\x01 \x01(\x0b\x32\r.coreApi.UUID\x12 \n\tthread_id\x18\x02 \x01(\x0b\x32\r.coreApi.UUID\x12\x11\n\tresumable\x18\x03 \x01(\x08\"h\n\x12MarkRunDoneRequest\x12\x1d\n\x06run_id\x18\x01 \x01(\x0b\x32\r.coreApi.UUID\x12 \n\tthread_id\x18\x02 \x01(\x0b\x32\r.coreApi.UUID\x12\x11\n\tresumable\x18\x03 \x01(\x08\"\xa4\x01\n\x19PublishStreamEventRequest\x12\"\n\x06run_id\x18\x01 \x01(\x0b\x32\r.coreApi.UUIDH\x00\x88\x01\x01\x12 \n\tthread_id\x18\x02 \x01(\x0b\x32\r.coreApi.UUID\x12\x12\n\nevent_type\x18\x03 \x01(\t\x12\x0f\n\x07message\x18\x04 \x01(\x0c\x12\x11\n\tresumable\x18\x05 \x01(\x08\x42\t\n\x07_run_id\"5\n\x11GetGraphIDRequest\x12 \n\tthread_id\x18\x01 \x01(\x0b\x32\r.coreApi.UUID\"8\n\x12GetGraphIDResponse\x12\x15\n\x08graph_id\x18\x01 \x01(\tH\x00\x88\x01\x01\x42\x0b\n\t_graph_id\"/\n\x11\x43reateRunResponse\x12\x1a\n\x04runs\x18\x01 \x03(\x0b\x32\x0c.coreApi.Run\"@\n\x0c\x43ontrolEvent\x12\x30\n\x06\x61\x63tion\x18\x01 \x01(\x0e\x32 .enumControlSignal.ControlSignal\"\x88\x05\n\x0b\x43ronPayload\x12\x14\n\x0c\x61ssistant_id\x18\x01 \x01(\t\x12\x17\n\ninput_json\x18\x02 \x01(\x0cH\x00\x88\x01\x01\x12\x37\n\x06\x63onfig\x18\x03 \x01(\x0b\x32\".engineCommon.EngineRunnableConfigH\x01\x88\x01\x01\x12\x19\n\x0c\x63ontext_json\x18\x04 \x01(\x0cH\x02\x88\x01\x01\x12\x14\n\x07webhook\x18\x05 \x01(\tH\x03\x88\x01\x01\x12\x42\n\x10interrupt_before\x18\x06 \x01(\x0b\x32#.engineCommon.StaticInterruptConfigH\x04\x88\x01\x01\x12\x41\n\x0finterrupt_after\x18\x07 \x01(\x0b\x32#.engineCommon.StaticInterruptConfigH\x05\x88\x01\x01\x12I\n\x12multitask_strategy\x18\x08 \x01(\x0e\x32(.enumMultitaskStrategy.MultitaskStrategyH\x06\x88\x01\x01\x12\x1a\n\rmetadata_json\x18\t \x01(\x0cH\x07\x88\x01\x01\x12\x37\n\nextra_json\x18\n \x03(\x0b\x32#.coreApi.CronPayload.ExtraJsonEntry\x1a\x30\n\x0e\x45xtraJsonEntry\x12\x0b\n\x03key\x18\x01 \x01(\t\x12\r\n\x05value\x18\x02 \x01(\x0c:\x02\x38\x01\x42\r\n\x0b_input_jsonB\t\n\x07_configB\x0f\n\r_context_jsonB\n\n\x08_webhookB\x13\n\x11_interrupt_beforeB\x12\n\x10_interrupt_afterB\x15\n\x13_multitask_strategyB\x10\n\x0e_metadata_json\"\xcb\x04\n\x04\x43ron\x12\x1e\n\x07\x63ron_id\x18\x01 \x01(\x0b\x32\r.coreApi.UUID\x12\x14\n\x0c\x61ssistant_id\x18\x02 \x01(\t\x12%\n\tthread_id\x18\x03 \x01(\x0b\x32\r.coreApi.UUIDH\x00\x88\x01\x01\x12I\n\x10on_run_completed\x18\x04 \x01(\x0e\x32*.enumCronOnRunCompleted.CronOnRunCompletedH\x01\x88\x01\x01\x12\x31\n\x08\x65nd_time\x18\x05 \x01(\x0b\x32\x1a.google.protobuf.TimestampH\x02\x88\x01\x01\x12\x10\n\x08schedule\x18\x06 \x01(\t\x12.\n\ncreated_at\x18\x07 \x01(\x0b\x32\x1a.google.protobuf.Timestamp\x12.\n\nupdated_at\x18\x08 \x01(\x0b\x32\x1a.google.protobuf.Timestamp\x12\x14\n\x07user_id\x18\t \x01(\tH\x03\x88\x01\x01\x12%\n\x07payload\x18\n \x01(\x0b\x32\x14.coreApi.CronPayload\x12\x31\n\rnext_run_date\x18\x0b \x01(\x0b\x32\x1a.google.protobuf.Timestamp\x12\x15\n\rmetadata_json\x18\x0c \x01(\x0c\x12\x0f\n\x07\x65nabled\x18\r \x01(\x08\x12\x15\n\x08timezone\x18\x0e \x01(\tH\x04\x88\x01\x01\x42\x0c\n\n_thread_idB\x13\n\x11_on_run_completedB\x0b\n\t_end_timeB\n\n\x08_user_idB\x0b\n\t_timezone\"\x9a\x05\n\x11\x43reateCronRequest\x12$\n\x07\x66ilters\x18\x01 \x03(\x0b\x32\x13.coreApi.AuthFilter\x12\x10\n\x08schedule\x18\x02 \x01(\t\x12%\n\x07payload\x18\x03 \x01(\x0b\x32\x14.coreApi.CronPayload\x12\x15\n\rmetadata_json\x18\x04 \x01(\x0c\x12#\n\x07\x63ron_id\x18\x05 \x01(\x0b\x32\r.coreApi.UUIDH\x00\x88\x01\x01\x12%\n\tthread_id\x18\x06 \x01(\x0b\x32\r.coreApi.UUIDH\x01\x88\x01\x01\x12I\n\x10on_run_completed\x18\x07 \x01(\x0e\x32*.enumCronOnRunCompleted.CronOnRunCompletedH\x02\x88\x01\x01\x12\x31\n\x08\x65nd_time\x18\x08 \x01(\x0b\x32\x1a.google.protobuf.TimestampH\x03\x88\x01\x01\x12\x0f\n\x07\x65nabled\x18\t \x01(\x08\x12.\n\x11\x61ssistant_filters\x18\n \x03(\x0b\x32\x13.coreApi.AuthFilter\x12+\n\x0ethread_filters\x18\x0b \x03(\x0b\x32\x13.coreApi.AuthFilter\x12\x14\n\x07user_id\x18\x0c \x01(\tH\x04\x88\x01\x01\x12>\n\x12\x65ncryption_context\x18\r \x01(\x0b\x32\x1d.encryption.EncryptionContextH\x05\x88\x01\x01\x12\x15\n\x08timezone\x18\x0e \x01(\tH\x06\x88\x01\x01\x42\n\n\x08_cron_idB\x0c\n\n_thread_idB\x13\n\x11_on_run_completedB\x0b\n\t_end_timeB\n\n\x08_user_idB\x15\n\x13_encryption_contextB\x0b\n\t_timezone\"Y\n\x11\x44\x65leteCronRequest\x12\x1e\n\x07\x63ron_id\x18\x01 \x01(\x0b\x32\r.coreApi.UUID\x12$\n\x07\x66ilters\x18\x02 \x03(\x0b\x32\x13.coreApi.AuthFilter\"\xbb\x03\n\x12SearchCronsRequest\x12$\n\x07\x66ilters\x18\x01 \x03(\x0b\x32\x13.coreApi.AuthFilter\x12+\n\x0ethread_filters\x18\n \x03(\x0b\x32\x13.coreApi.AuthFilter\x12(\n\x0c\x61ssistant_id\x18\x02 \x01(\x0b\x32\r.coreApi.UUIDH\x00\x88\x01\x01\x12%\n\tthread_id\x18\x03 \x01(\x0b\x32\r.coreApi.UUIDH\x01\x88\x01\x01\x12\x12\n\x05limit\x18\x04 \x01(\x04H\x02\x88\x01\x01\x12\x13\n\x06offset\x18\x05 \x01(\x04H\x03\x88\x01\x01\x12*\n\x07sort_by\x18\x06 \x01(\x0e\x32\x14.coreApi.CronsSortByH\x04\x88\x01\x01\x12+\n\nsort_order\x18\x07 \x01(\x0e\x32\x12.coreApi.SortOrderH\x05\x88\x01\x01\x12\x0e\n\x06select\x18\x08 \x03(\t\x12\x14\n\x07\x65nabled\x18\t \x01(\x08H\x06\x88\x01\x01\x42\x0f\n\r_assistant_idB\x0c\n\n_thread_idB\x08\n\x06_limitB\t\n\x07_offsetB\n\n\x08_sort_byB\r\n\x0b_sort_orderB\n\n\x08_enabled\"3\n\x13SearchCronsResponse\x12\x1c\n\x05\x63rons\x18\x01 \x03(\x0b\x32\r.coreApi.Cron\"\xd6\x01\n\x11\x43ountCronsRequest\x12$\n\x07\x66ilters\x18\x01 \x03(\x0b\x32\x13.coreApi.AuthFilter\x12+\n\x0ethread_filters\x18\x04 \x03(\x0b\x32\x13.coreApi.AuthFilter\x12(\n\x0c\x61ssistant_id\x18\x02 \x01(\x0b\x32\r.coreApi.UUIDH\x00\x88\x01\x01\x12%\n\tthread_id\x18\x03 \x01(\x0b\x32\r.coreApi.UUIDH\x01\x88\x01\x01\x42\x0f\n\r_assistant_idB\x0c\n\n_thread_id\"\x9f\x04\n\x10PatchCronRequest\x12\x1e\n\x07\x63ron_id\x18\x01 \x01(\x0b\x32\r.coreApi.UUID\x12$\n\x07\x66ilters\x18\x02 \x03(\x0b\x32\x13.coreApi.AuthFilter\x12\x15\n\x08schedule\x18\x03 \x01(\tH\x00\x88\x01\x01\x12\x31\n\x08\x65nd_time\x18\x04 \x01(\x0b\x32\x1a.google.protobuf.TimestampH\x01\x88\x01\x01\x12\x14\n\x07\x65nabled\x18\x05 \x01(\x08H\x02\x88\x01\x01\x12I\n\x10on_run_completed\x18\x06 \x01(\x0e\x32*.enumCronOnRunCompleted.CronOnRunCompletedH\x03\x88\x01\x01\x12*\n\x07payload\x18\x07 \x01(\x0b\x32\x14.coreApi.CronPayloadH\x04\x88\x01\x01\x12\x1a\n\rmetadata_json\x18\x08 \x01(\x0cH\x05\x88\x01\x01\x12>\n\x12\x65ncryption_context\x18\t \x01(\x0b\x32\x1d.encryption.EncryptionContextH\x06\x88\x01\x01\x12\x15\n\x08timezone\x18\n \x01(\tH\x07\x88\x01\x01\x42\x0b\n\t_scheduleB\x0b\n\t_end_timeB\n\n\x08_enabledB\x13\n\x11_on_run_completedB\n\n\x08_payloadB\x10\n\x0e_metadata_jsonB\x15\n\x13_encryption_contextB\x0b\n\t_timezone\"\xaa\x01\n\x0b\x43ronWithNow\x12\x1b\n\x04\x63ron\x18\x01 \x01(\x0b\x32\r.coreApi.Cron\x12\'\n\x03now\x18\x02 \x01(\x0b\x32\x1a.google.protobuf.Timestamp\x12>\n\x12\x65ncryption_context\x18\x03 \x01(\x0b\x32\x1d.encryption.EncryptionContextH\x00\x88\x01\x01\x42\x15\n\x13_encryption_context\"8\n\x11NextCronsResponse\x12#\n\x05\x63rons\x18\x01 \x03(\x0b\x32\x14.coreApi.CronWithNow\"j\n\x15SetNextRunDateRequest\x12\x1e\n\x07\x63ron_id\x18\x01 \x01(\x0b\x32\r.coreApi.UUID\x12\x31\n\rnext_run_date\x18\x02 \x01(\x0b\x32\x1a.google.protobuf.Timestamp\"b\n\x0f\x43\x61\x63heSetRequest\x12\x0b\n\x03key\x18\x01 \x01(\t\x12\r\n\x05value\x18\x02 \x01(\x0c\x12+\n\x03ttl\x18\x03 \x01(\x0b\x32\x19.google.protobuf.DurationH\x00\x88\x01\x01\x42\x06\n\x04_ttl\"\x1e\n\x0f\x43\x61\x63heGetRequest\x12\x0b\n\x03key\x18\x01 \x01(\t\"0\n\x10\x43\x61\x63heGetResponse\x12\x12\n\x05value\x18\x01 \x01(\x0cH\x00\x88\x01\x01\x42\x08\n\x06_value*/\n\x12OnConflictBehavior\x12\t\n\x05RAISE\x10\x00\x12\x0e\n\nDO_NOTHING\x10\x01*\x1e\n\tSortOrder\x12\x08\n\x04\x44\x45SC\x10\x00\x12\x07\n\x03\x41SC\x10\x01*m\n\x10\x41ssistantsSortBy\x12\x0f\n\x0bUNSPECIFIED\x10\x00\x12\x10\n\x0c\x41SSISTANT_ID\x10\x01\x12\x0c\n\x08GRAPH_ID\x10\x02\x12\x08\n\x04NAME\x10\x03\x12\x0e\n\nCREATED_AT\x10\x04\x12\x0e\n\nUPDATED_AT\x10\x05*X\n\x11ThreadTTLStrategy\x12\x1e\n\x1aTHREAD_TTL_STRATEGY_DELETE\x10\x00\x12#\n\x1fTHREAD_TTL_STRATEGY_KEEP_LATEST\x10\x01*\xa8\x01\n\x10\x43heckpointSource\x12!\n\x1d\x43HECKPOINT_SOURCE_UNSPECIFIED\x10\x00\x12\x1b\n\x17\x43HECKPOINT_SOURCE_INPUT\x10\x01\x12\x1a\n\x16\x43HECKPOINT_SOURCE_LOOP\x10\x02\x12\x1c\n\x18\x43HECKPOINT_SOURCE_UPDATE\x10\x03\x12\x1a\n\x16\x43HECKPOINT_SOURCE_FORK\x10\x04*\xd1\x01\n\rThreadsSortBy\x12\x1f\n\x1bTHREADS_SORT_BY_UNSPECIFIED\x10\x00\x12\x1d\n\x19THREADS_SORT_BY_THREAD_ID\x10\x01\x12\x1e\n\x1aTHREADS_SORT_BY_CREATED_AT\x10\x02\x12\x1e\n\x1aTHREADS_SORT_BY_UPDATED_AT\x10\x03\x12\x1a\n\x16THREADS_SORT_BY_STATUS\x10\x04\x12$\n THREADS_SORT_BY_STATE_UPDATED_AT\x10\x05*`\n\x11\x43reateRunBehavior\x12#\n\x1fREJECT_RUN_IF_THREAD_NOT_EXISTS\x10\x00\x12&\n\"CREATE_THREAD_IF_THREAD_NOT_EXISTS\x10\x01*j\n\x0f\x43\x61ncelRunStatus\x12\x1d\n\x19\x43\x41NCEL_RUN_STATUS_PENDING\x10\x00\x12\x1d\n\x19\x43\x41NCEL_RUN_STATUS_RUNNING\x10\x01\x12\x19\n\x15\x43\x41NCEL_RUN_STATUS_ALL\x10\x02*\xfd\x01\n\x0b\x43ronsSortBy\x12\x1d\n\x19\x43RONS_SORT_BY_UNSPECIFIED\x10\x00\x12\x19\n\x15\x43RONS_SORT_BY_CRON_ID\x10\x01\x12\x1e\n\x1a\x43RONS_SORT_BY_ASSISTANT_ID\x10\x02\x12\x1b\n\x17\x43RONS_SORT_BY_THREAD_ID\x10\x03\x12\x1f\n\x1b\x43RONS_SORT_BY_NEXT_RUN_DATE\x10\x04\x12\x1a\n\x16\x43RONS_SORT_BY_END_TIME\x10\x05\x12\x1c\n\x18\x43RONS_SORT_BY_CREATED_AT\x10\x06\x12\x1c\n\x18\x43RONS_SORT_BY_UPDATED_AT\x10\x07\x32\xc1\x04\n\nAssistants\x12\x37\n\x03Get\x12\x1c.coreApi.GetAssistantRequest\x1a\x12.coreApi.Assistant\x12=\n\x06\x43reate\x12\x1f.coreApi.CreateAssistantRequest\x1a\x12.coreApi.Assistant\x12;\n\x05Patch\x12\x1e.coreApi.PatchAssistantRequest\x1a\x12.coreApi.Assistant\x12L\n\x06\x44\x65lete\x12\x1f.coreApi.DeleteAssistantRequest\x1a!.coreApi.DeleteAssistantsResponse\x12M\n\x06Search\x12 .coreApi.SearchAssistantsRequest\x1a!.coreApi.SearchAssistantsResponse\x12\x43\n\tSetLatest\x12\".coreApi.SetLatestAssistantRequest\x1a\x12.coreApi.Assistant\x12Z\n\x0bGetVersions\x12$.coreApi.GetAssistantVersionsRequest\x1a%.coreApi.GetAssistantVersionsResponse\x12@\n\x05\x43ount\x12\x1f.coreApi.CountAssistantsRequest\x1a\x16.coreApi.CountResponse2E\n\x05\x41\x64min\x12<\n\x08Truncate\x12\x18.coreApi.TruncateRequest\x1a\x16.google.protobuf.Empty2\xbd\x05\n\x07Threads\x12\x37\n\x06\x43reate\x12\x1c.coreApi.CreateThreadRequest\x1a\x0f.coreApi.Thread\x12\x31\n\x03Get\x12\x19.coreApi.GetThreadRequest\x1a\x0f.coreApi.Thread\x12\x35\n\x05Patch\x12\x1b.coreApi.PatchThreadRequest\x1a\x0f.coreApi.Thread\x12\x35\n\x06\x44\x65lete\x12\x1c.coreApi.DeleteThreadRequest\x1a\r.coreApi.UUID\x12G\n\x06Search\x12\x1d.coreApi.SearchThreadsRequest\x1a\x1e.coreApi.SearchThreadsResponse\x12=\n\x05\x43ount\x12\x1c.coreApi.CountThreadsRequest\x1a\x16.coreApi.CountResponse\x12\x33\n\x04\x43opy\x12\x1a.coreApi.CopyThreadRequest\x1a\x0f.coreApi.Thread\x12\x44\n\tSetStatus\x12\x1f.coreApi.SetThreadStatusRequest\x1a\x16.google.protobuf.Empty\x12>\n\x06Stream\x12\x1c.coreApi.StreamThreadRequest\x1a\x14.coreApi.StreamEvent0\x01\x12N\n\x0eSetJointStatus\x12$.coreApi.SetThreadJointStatusRequest\x1a\x16.google.protobuf.Empty\x12\x45\n\nGetGraphID\x12\x1a.coreApi.GetGraphIDRequest\x1a\x1b.coreApi.GetGraphIDResponse2\x9f\x07\n\x04Runs\x12?\n\x06\x43reate\x12\x19.coreApi.CreateRunRequest\x1a\x1a.coreApi.CreateRunResponse\x12+\n\x03Get\x12\x16.coreApi.GetRunRequest\x1a\x0c.coreApi.Run\x12\x32\n\x06\x44\x65lete\x12\x19.coreApi.DeleteRunRequest\x1a\r.coreApi.UUID\x12\x41\n\x06Search\x12\x1a.coreApi.SearchRunsRequest\x1a\x1b.coreApi.SearchRunsResponse\x12;\n\x06\x43\x61ncel\x12\x19.coreApi.CancelRunRequest\x1a\x16.google.protobuf.Empty\x12\x41\n\tSetStatus\x12\x1c.coreApi.SetRunStatusRequest\x1a\x16.google.protobuf.Empty\x12\x43\n\x06Stream\x12\x1f.coreApi.StreamRunClientMessage\x1a\x14.coreApi.StreamEvent(\x01\x30\x01\x12\x45\n\x07Publish\x12\".coreApi.PublishStreamEventRequest\x1a\x16.google.protobuf.Empty\x12:\n\x05\x45nter\x12\x18.coreApi.EnterRunRequest\x1a\x15.coreApi.ControlEvent0\x01\x12?\n\x08MarkDone\x12\x1b.coreApi.MarkRunDoneRequest\x1a\x16.google.protobuf.Empty\x12\x32\n\x05Stats\x12\x16.google.protobuf.Empty\x1a\x11.coreApi.RunStats\x12\x41\n\tPoolStats\x12\x16.google.protobuf.Empty\x1a\x1c.coreApi.ConnectionPoolStats\x12:\n\x05\x43ount\x12\x19.coreApi.CountRunsRequest\x1a\x16.coreApi.CountResponse\x12\x39\n\x04Next\x12\x17.coreApi.NextRunRequest\x1a\x18.coreApi.NextRunResponse\x12;\n\x05Sweep\x12\x16.google.protobuf.Empty\x1a\x1a.coreApi.SweepRunsResponse2\xb5\x03\n\x05\x43rons\x12\x33\n\x06\x43reate\x12\x1a.coreApi.CreateCronRequest\x1a\r.coreApi.Cron\x12\x31\n\x05Patch\x12\x19.coreApi.PatchCronRequest\x1a\r.coreApi.Cron\x12<\n\x06\x44\x65lete\x12\x1a.coreApi.DeleteCronRequest\x1a\x16.google.protobuf.Empty\x12\x43\n\x06Search\x12\x1b.coreApi.SearchCronsRequest\x1a\x1c.coreApi.SearchCronsResponse\x12;\n\x05\x43ount\x12\x1a.coreApi.CountCronsRequest\x1a\x16.coreApi.CountResponse\x12:\n\x04Next\x12\x16.google.protobuf.Empty\x1a\x1a.coreApi.NextCronsResponse\x12H\n\x0eSetNextRunDate\x12\x1e.coreApi.SetNextRunDateRequest\x1a\x16.google.protobuf.Empty2|\n\x05\x43\x61\x63he\x12\x37\n\x03Set\x12\x18.coreApi.CacheSetRequest\x1a\x16.google.protobuf.Empty\x12:\n\x03Get\x12\x18.coreApi.CacheGetRequest\x1a\x19.coreApi.CacheGetResponseBAZ?github.com/langchain-ai/langgraph-api/core/internal/core-api/pbb\x06proto3')
43
+
44
+ _globals = globals()
45
+ _builder.BuildMessageAndEnumDescriptors(DESCRIPTOR, _globals)
46
+ _builder.BuildTopDescriptorsAndMessages(DESCRIPTOR, 'core_api_pb2', _globals)
47
+ if not _descriptor._USE_C_DESCRIPTORS:
48
+ _globals['DESCRIPTOR']._loaded_options = None
49
+ _globals['DESCRIPTOR']._serialized_options = b'Z?github.com/langchain-ai/langgraph-api/core/internal/core-api/pb'
50
+ _globals['_CHECKPOINTMETADATA_PARENTSENTRY']._loaded_options = None
51
+ _globals['_CHECKPOINTMETADATA_PARENTSENTRY']._serialized_options = b'8\001'
52
+ _globals['_THREAD_INTERRUPTSENTRY']._loaded_options = None
53
+ _globals['_THREAD_INTERRUPTSENTRY']._serialized_options = b'8\001'
54
+ _globals['_SEARCHTHREADSREQUEST_EXTRACTENTRY']._loaded_options = None
55
+ _globals['_SEARCHTHREADSREQUEST_EXTRACTENTRY']._serialized_options = b'8\001'
56
+ _globals['_CRONPAYLOAD_EXTRAJSONENTRY']._loaded_options = None
57
+ _globals['_CRONPAYLOAD_EXTRAJSONENTRY']._serialized_options = b'8\001'
58
+ _globals['_ONCONFLICTBEHAVIOR']._serialized_start=17421
59
+ _globals['_ONCONFLICTBEHAVIOR']._serialized_end=17468
60
+ _globals['_SORTORDER']._serialized_start=17470
61
+ _globals['_SORTORDER']._serialized_end=17500
62
+ _globals['_ASSISTANTSSORTBY']._serialized_start=17502
63
+ _globals['_ASSISTANTSSORTBY']._serialized_end=17611
64
+ _globals['_THREADTTLSTRATEGY']._serialized_start=17613
65
+ _globals['_THREADTTLSTRATEGY']._serialized_end=17701
66
+ _globals['_CHECKPOINTSOURCE']._serialized_start=17704
67
+ _globals['_CHECKPOINTSOURCE']._serialized_end=17872
68
+ _globals['_THREADSSORTBY']._serialized_start=17875
69
+ _globals['_THREADSSORTBY']._serialized_end=18084
70
+ _globals['_CREATERUNBEHAVIOR']._serialized_start=18086
71
+ _globals['_CREATERUNBEHAVIOR']._serialized_end=18182
72
+ _globals['_CANCELRUNSTATUS']._serialized_start=18184
73
+ _globals['_CANCELRUNSTATUS']._serialized_end=18290
74
+ _globals['_CRONSSORTBY']._serialized_start=18293
75
+ _globals['_CRONSSORTBY']._serialized_end=18546
76
+ _globals['_TAGS']._serialized_start=450
77
+ _globals['_TAGS']._serialized_end=472
78
+ _globals['_EQAUTHFILTER']._serialized_start=474
79
+ _globals['_EQAUTHFILTER']._serialized_end=516
80
+ _globals['_CONTAINSAUTHFILTER']._serialized_start=518
81
+ _globals['_CONTAINSAUTHFILTER']._serialized_end=568
82
+ _globals['_ORAUTHFILTER']._serialized_start=570
83
+ _globals['_ORAUTHFILTER']._serialized_end=622
84
+ _globals['_ANDAUTHFILTER']._serialized_start=624
85
+ _globals['_ANDAUTHFILTER']._serialized_end=677
86
+ _globals['_AUTHFILTER']._serialized_start=680
87
+ _globals['_AUTHFILTER']._serialized_end=878
88
+ _globals['_UUID']._serialized_start=880
89
+ _globals['_UUID']._serialized_end=901
90
+ _globals['_COUNTRESPONSE']._serialized_start=903
91
+ _globals['_COUNTRESPONSE']._serialized_end=933
92
+ _globals['_STREAMEVENT']._serialized_start=935
93
+ _globals['_STREAMEVENT']._serialized_end=1023
94
+ _globals['_ASSISTANT']._serialized_start=1026
95
+ _globals['_ASSISTANT']._serialized_end=1404
96
+ _globals['_ASSISTANTVERSION']._serialized_start=1407
97
+ _globals['_ASSISTANTVERSION']._serialized_end=1744
98
+ _globals['_CREATEASSISTANTREQUEST']._serialized_start=1747
99
+ _globals['_CREATEASSISTANTREQUEST']._serialized_end=2160
100
+ _globals['_GETASSISTANTREQUEST']._serialized_start=2162
101
+ _globals['_GETASSISTANTREQUEST']._serialized_end=2243
102
+ _globals['_PATCHASSISTANTREQUEST']._serialized_start=2246
103
+ _globals['_PATCHASSISTANTREQUEST']._serialized_end=2680
104
+ _globals['_DELETEASSISTANTREQUEST']._serialized_start=2683
105
+ _globals['_DELETEASSISTANTREQUEST']._serialized_end=2815
106
+ _globals['_DELETEASSISTANTSRESPONSE']._serialized_start=2817
107
+ _globals['_DELETEASSISTANTSRESPONSE']._serialized_end=2866
108
+ _globals['_SETLATESTASSISTANTREQUEST']._serialized_start=2868
109
+ _globals['_SETLATESTASSISTANTREQUEST']._serialized_end=2972
110
+ _globals['_SEARCHASSISTANTSREQUEST']._serialized_start=2975
111
+ _globals['_SEARCHASSISTANTSREQUEST']._serialized_end=3347
112
+ _globals['_SEARCHASSISTANTSRESPONSE']._serialized_start=3349
113
+ _globals['_SEARCHASSISTANTSRESPONSE']._serialized_end=3415
114
+ _globals['_GETASSISTANTVERSIONSREQUEST']._serialized_start=3418
115
+ _globals['_GETASSISTANTVERSIONSREQUEST']._serialized_end=3615
116
+ _globals['_GETASSISTANTVERSIONSRESPONSE']._serialized_start=3617
117
+ _globals['_GETASSISTANTVERSIONSRESPONSE']._serialized_end=3692
118
+ _globals['_COUNTASSISTANTSREQUEST']._serialized_start=3695
119
+ _globals['_COUNTASSISTANTSREQUEST']._serialized_end=3867
120
+ _globals['_TRUNCATEREQUEST']._serialized_start=3869
121
+ _globals['_TRUNCATEREQUEST']._serialized_end=3974
122
+ _globals['_THREADTTLCONFIG']._serialized_start=3977
123
+ _globals['_THREADTTLCONFIG']._serialized_end=4164
124
+ _globals['_THREADTTLINFO']._serialized_start=4167
125
+ _globals['_THREADTTLINFO']._serialized_end=4297
126
+ _globals['_FRAGMENT']._serialized_start=4299
127
+ _globals['_FRAGMENT']._serialized_end=4324
128
+ _globals['_CHECKPOINTTASK']._serialized_start=4327
129
+ _globals['_CHECKPOINTTASK']._serialized_end=4464
130
+ _globals['_CHECKPOINTMETADATA']._serialized_start=4467
131
+ _globals['_CHECKPOINTMETADATA']._serialized_end=4681
132
+ _globals['_CHECKPOINTMETADATA_PARENTSENTRY']._serialized_start=4615
133
+ _globals['_CHECKPOINTMETADATA_PARENTSENTRY']._serialized_end=4661
134
+ _globals['_CHECKPOINTPAYLOAD']._serialized_start=4684
135
+ _globals['_CHECKPOINTPAYLOAD']._serialized_end=4975
136
+ _globals['_THREADSTATUSCHECKPOINT']._serialized_start=4977
137
+ _globals['_THREADSTATUSCHECKPOINT']._serialized_end=5061
138
+ _globals['_INTERRUPT']._serialized_start=5064
139
+ _globals['_INTERRUPT']._serialized_end=5192
140
+ _globals['_INTERRUPTS']._serialized_start=5194
141
+ _globals['_INTERRUPTS']._serialized_end=5246
142
+ _globals['_THREAD']._serialized_start=5249
143
+ _globals['_THREAD']._serialized_end=5853
144
+ _globals['_THREAD_INTERRUPTSENTRY']._serialized_start=5756
145
+ _globals['_THREAD_INTERRUPTSENTRY']._serialized_end=5826
146
+ _globals['_CREATETHREADREQUEST']._serialized_start=5856
147
+ _globals['_CREATETHREADREQUEST']._serialized_end=6182
148
+ _globals['_GETTHREADREQUEST']._serialized_start=6185
149
+ _globals['_GETTHREADREQUEST']._serialized_end=6383
150
+ _globals['_PATCHTHREADREQUEST']._serialized_start=6386
151
+ _globals['_PATCHTHREADREQUEST']._serialized_end=6729
152
+ _globals['_DELETETHREADREQUEST']._serialized_start=6731
153
+ _globals['_DELETETHREADREQUEST']._serialized_end=6824
154
+ _globals['_COPYTHREADREQUEST']._serialized_start=6826
155
+ _globals['_COPYTHREADREQUEST']._serialized_end=6917
156
+ _globals['_SEARCHTHREADSREQUEST']._serialized_start=6920
157
+ _globals['_SEARCHTHREADSREQUEST']._serialized_end=7465
158
+ _globals['_SEARCHTHREADSREQUEST_EXTRACTENTRY']._serialized_start=7326
159
+ _globals['_SEARCHTHREADSREQUEST_EXTRACTENTRY']._serialized_end=7372
160
+ _globals['_SEARCHTHREADSRESPONSE']._serialized_start=7467
161
+ _globals['_SEARCHTHREADSRESPONSE']._serialized_end=7524
162
+ _globals['_COUNTTHREADSREQUEST']._serialized_start=7527
163
+ _globals['_COUNTTHREADSREQUEST']._serialized_end=7738
164
+ _globals['_SETTHREADSTATUSREQUEST']._serialized_start=7741
165
+ _globals['_SETTHREADSTATUSREQUEST']._serialized_end=8064
166
+ _globals['_SETTHREADJOINTSTATUSREQUEST']._serialized_start=8067
167
+ _globals['_SETTHREADJOINTSTATUSREQUEST']._serialized_end=8407
168
+ _globals['_STREAMTHREADREQUEST']._serialized_start=8410
169
+ _globals['_STREAMTHREADREQUEST']._serialized_end=8611
170
+ _globals['_RUNKWARGS']._serialized_start=8614
171
+ _globals['_RUNKWARGS']._serialized_end=9311
172
+ _globals['_RUN']._serialized_start=9314
173
+ _globals['_RUN']._serialized_end=9702
174
+ _globals['_RUNSTATS']._serialized_start=9705
175
+ _globals['_RUNSTATS']._serialized_end=10019
176
+ _globals['_POSTGRESPOOLSTATS']._serialized_start=10022
177
+ _globals['_POSTGRESPOOLSTATS']._serialized_end=10152
178
+ _globals['_REDISPOOLSTATS']._serialized_start=10154
179
+ _globals['_REDISPOOLSTATS']._serialized_end=10249
180
+ _globals['_CONNECTIONPOOLSTATS']._serialized_start=10252
181
+ _globals['_CONNECTIONPOOLSTATS']._serialized_end=10392
182
+ _globals['_NEXTRUNREQUEST']._serialized_start=10394
183
+ _globals['_NEXTRUNREQUEST']._serialized_end=10439
184
+ _globals['_RUNWITHATTEMPT']._serialized_start=10441
185
+ _globals['_RUNWITHATTEMPT']._serialized_end=10560
186
+ _globals['_NEXTRUNRESPONSE']._serialized_start=10562
187
+ _globals['_NEXTRUNRESPONSE']._serialized_end=10618
188
+ _globals['_CREATERUNREQUEST']._serialized_start=10621
189
+ _globals['_CREATERUNREQUEST']._serialized_end=11471
190
+ _globals['_GETRUNREQUEST']._serialized_start=11473
191
+ _globals['_GETRUNREQUEST']._serialized_end=11591
192
+ _globals['_DELETERUNREQUEST']._serialized_start=11593
193
+ _globals['_DELETERUNREQUEST']._serialized_end=11714
194
+ _globals['_CANCELRUNIDSTARGET']._serialized_start=11716
195
+ _globals['_CANCELRUNIDSTARGET']._serialized_end=11802
196
+ _globals['_CANCELSTATUSTARGET']._serialized_start=11804
197
+ _globals['_CANCELSTATUSTARGET']._serialized_end=11866
198
+ _globals['_CANCELRUNREQUEST']._serialized_start=11869
199
+ _globals['_CANCELRUNREQUEST']._serialized_end=12100
200
+ _globals['_SEARCHRUNSREQUEST']._serialized_start=12103
201
+ _globals['_SEARCHRUNSREQUEST']._serialized_end=12330
202
+ _globals['_SEARCHRUNSRESPONSE']._serialized_start=12332
203
+ _globals['_SEARCHRUNSRESPONSE']._serialized_end=12380
204
+ _globals['_SETRUNSTATUSREQUEST']._serialized_start=12382
205
+ _globals['_SETRUNSTATUSREQUEST']._serialized_end=12476
206
+ _globals['_SWEEPRUNSRESPONSE']._serialized_start=12478
207
+ _globals['_SWEEPRUNSRESPONSE']._serialized_end=12529
208
+ _globals['_COUNTRUNSREQUEST']._serialized_start=12531
209
+ _globals['_COUNTRUNSREQUEST']._serialized_end=12601
210
+ _globals['_STREAMRUNCLIENTMESSAGE']._serialized_start=12603
211
+ _globals['_STREAMRUNCLIENTMESSAGE']._serialized_end=12730
212
+ _globals['_SUBSCRIBERUNREQUEST']._serialized_start=12732
213
+ _globals['_SUBSCRIBERUNREQUEST']._serialized_end=12818
214
+ _globals['_JOINRUNREQUEST']._serialized_start=12821
215
+ _globals['_JOINRUNREQUEST']._serialized_end=13031
216
+ _globals['_ENTERRUNREQUEST']._serialized_start=13033
217
+ _globals['_ENTERRUNREQUEST']._serialized_end=13134
218
+ _globals['_MARKRUNDONEREQUEST']._serialized_start=13136
219
+ _globals['_MARKRUNDONEREQUEST']._serialized_end=13240
220
+ _globals['_PUBLISHSTREAMEVENTREQUEST']._serialized_start=13243
221
+ _globals['_PUBLISHSTREAMEVENTREQUEST']._serialized_end=13407
222
+ _globals['_GETGRAPHIDREQUEST']._serialized_start=13409
223
+ _globals['_GETGRAPHIDREQUEST']._serialized_end=13462
224
+ _globals['_GETGRAPHIDRESPONSE']._serialized_start=13464
225
+ _globals['_GETGRAPHIDRESPONSE']._serialized_end=13520
226
+ _globals['_CREATERUNRESPONSE']._serialized_start=13522
227
+ _globals['_CREATERUNRESPONSE']._serialized_end=13569
228
+ _globals['_CONTROLEVENT']._serialized_start=13571
229
+ _globals['_CONTROLEVENT']._serialized_end=13635
230
+ _globals['_CRONPAYLOAD']._serialized_start=13638
231
+ _globals['_CRONPAYLOAD']._serialized_end=14286
232
+ _globals['_CRONPAYLOAD_EXTRAJSONENTRY']._serialized_start=14101
233
+ _globals['_CRONPAYLOAD_EXTRAJSONENTRY']._serialized_end=14149
234
+ _globals['_CRON']._serialized_start=14289
235
+ _globals['_CRON']._serialized_end=14876
236
+ _globals['_CREATECRONREQUEST']._serialized_start=14879
237
+ _globals['_CREATECRONREQUEST']._serialized_end=15545
238
+ _globals['_DELETECRONREQUEST']._serialized_start=15547
239
+ _globals['_DELETECRONREQUEST']._serialized_end=15636
240
+ _globals['_SEARCHCRONSREQUEST']._serialized_start=15639
241
+ _globals['_SEARCHCRONSREQUEST']._serialized_end=16082
242
+ _globals['_SEARCHCRONSRESPONSE']._serialized_start=16084
243
+ _globals['_SEARCHCRONSRESPONSE']._serialized_end=16135
244
+ _globals['_COUNTCRONSREQUEST']._serialized_start=16138
245
+ _globals['_COUNTCRONSREQUEST']._serialized_end=16352
246
+ _globals['_PATCHCRONREQUEST']._serialized_start=16355
247
+ _globals['_PATCHCRONREQUEST']._serialized_end=16898
248
+ _globals['_CRONWITHNOW']._serialized_start=16901
249
+ _globals['_CRONWITHNOW']._serialized_end=17071
250
+ _globals['_NEXTCRONSRESPONSE']._serialized_start=17073
251
+ _globals['_NEXTCRONSRESPONSE']._serialized_end=17129
252
+ _globals['_SETNEXTRUNDATEREQUEST']._serialized_start=17131
253
+ _globals['_SETNEXTRUNDATEREQUEST']._serialized_end=17237
254
+ _globals['_CACHESETREQUEST']._serialized_start=17239
255
+ _globals['_CACHESETREQUEST']._serialized_end=17337
256
+ _globals['_CACHEGETREQUEST']._serialized_start=17339
257
+ _globals['_CACHEGETREQUEST']._serialized_end=17369
258
+ _globals['_CACHEGETRESPONSE']._serialized_start=17371
259
+ _globals['_CACHEGETRESPONSE']._serialized_end=17419
260
+ _globals['_ASSISTANTS']._serialized_start=18549
261
+ _globals['_ASSISTANTS']._serialized_end=19126
262
+ _globals['_ADMIN']._serialized_start=19128
263
+ _globals['_ADMIN']._serialized_end=19197
264
+ _globals['_THREADS']._serialized_start=19200
265
+ _globals['_THREADS']._serialized_end=19901
266
+ _globals['_RUNS']._serialized_start=19904
267
+ _globals['_RUNS']._serialized_end=20831
268
+ _globals['_CRONS']._serialized_start=20834
269
+ _globals['_CRONS']._serialized_end=21271
270
+ _globals['_CACHE']._serialized_start=21273
271
+ _globals['_CACHE']._serialized_end=21397
272
+ # @@protoc_insertion_point(module_scope)
@@ -1440,26 +1440,40 @@ class GetThreadRequest(_message.Message):
1440
1440
  THREAD_ID_FIELD_NUMBER: _builtins.int
1441
1441
  FILTERS_FIELD_NUMBER: _builtins.int
1442
1442
  INCLUDE_TTL_FIELD_NUMBER: _builtins.int
1443
+ READ_MASK_FIELD_NUMBER: _builtins.int
1443
1444
  include_ttl: _builtins.bool
1444
1445
  """When true, include TTL information in the response."""
1445
1446
  @_builtins.property
1446
1447
  def thread_id(self) -> Global___UUID: ...
1447
1448
  @_builtins.property
1448
1449
  def filters(self) -> _containers.RepeatedCompositeFieldContainer[Global___AuthFilter]: ...
1450
+ @_builtins.property
1451
+ def read_mask(self) -> _field_mask_pb2.FieldMask:
1452
+ """If set, only the specified fields are returned in the response.
1453
+ Omitting "values" avoids fetching large checkpoint state when the
1454
+ caller only needs metadata/config (e.g. state update operations).
1455
+ """
1456
+
1449
1457
  def __init__(
1450
1458
  self,
1451
1459
  *,
1452
1460
  thread_id: Global___UUID | None = ...,
1453
1461
  filters: _abc.Iterable[Global___AuthFilter] | None = ...,
1454
1462
  include_ttl: _builtins.bool | None = ...,
1463
+ read_mask: _field_mask_pb2.FieldMask | None = ...,
1455
1464
  ) -> None: ...
1456
- _HasFieldArgType: _TypeAlias = _typing.Literal["_include_ttl", b"_include_ttl", "include_ttl", b"include_ttl", "thread_id", b"thread_id"] # noqa: Y015
1465
+ _HasFieldArgType: _TypeAlias = _typing.Literal["_include_ttl", b"_include_ttl", "_read_mask", b"_read_mask", "include_ttl", b"include_ttl", "read_mask", b"read_mask", "thread_id", b"thread_id"] # noqa: Y015
1457
1466
  def HasField(self, field_name: _HasFieldArgType) -> _builtins.bool: ...
1458
- _ClearFieldArgType: _TypeAlias = _typing.Literal["_include_ttl", b"_include_ttl", "filters", b"filters", "include_ttl", b"include_ttl", "thread_id", b"thread_id"] # noqa: Y015
1467
+ _ClearFieldArgType: _TypeAlias = _typing.Literal["_include_ttl", b"_include_ttl", "_read_mask", b"_read_mask", "filters", b"filters", "include_ttl", b"include_ttl", "read_mask", b"read_mask", "thread_id", b"thread_id"] # noqa: Y015
1459
1468
  def ClearField(self, field_name: _ClearFieldArgType) -> None: ...
1460
1469
  _WhichOneofReturnType__include_ttl: _TypeAlias = _typing.Literal["include_ttl"] # noqa: Y015
1461
1470
  _WhichOneofArgType__include_ttl: _TypeAlias = _typing.Literal["_include_ttl", b"_include_ttl"] # noqa: Y015
1471
+ _WhichOneofReturnType__read_mask: _TypeAlias = _typing.Literal["read_mask"] # noqa: Y015
1472
+ _WhichOneofArgType__read_mask: _TypeAlias = _typing.Literal["_read_mask", b"_read_mask"] # noqa: Y015
1473
+ @_typing.overload
1462
1474
  def WhichOneof(self, oneof_group: _WhichOneofArgType__include_ttl) -> _WhichOneofReturnType__include_ttl | None: ...
1475
+ @_typing.overload
1476
+ def WhichOneof(self, oneof_group: _WhichOneofArgType__read_mask) -> _WhichOneofReturnType__read_mask | None: ...
1463
1477
 
1464
1478
  Global___GetThreadRequest: _TypeAlias = GetThreadRequest # noqa: Y015
1465
1479
 
@@ -34,7 +34,7 @@ dependencies = [
34
34
  "cryptography>=42.0.0,<47.0",
35
35
  "langgraph-sdk>=0.3.5",
36
36
  "cloudpickle>=3.0.0",
37
- "langgraph-runtime-inmem>=0.27.0,<0.28.0",
37
+ "langgraph-runtime-inmem>=0.28.0,<0.29.0",
38
38
  "truststore>=0.1",
39
39
  "protobuf>=6.32.1,<7.0.0",
40
40
  "grpcio>=1.78.0,<1.79.0",
@@ -1 +0,0 @@
1
- __version__ = "0.8.0"