cribl-control-plane 0.0.38__py3-none-any.whl → 0.4.0a6__py3-none-any.whl

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

Potentially problematic release.


This version of cribl-control-plane might be problematic. Click here for more details.

Files changed (241) hide show
  1. cribl_control_plane/_hooks/clientcredentials.py +92 -42
  2. cribl_control_plane/_version.py +4 -4
  3. cribl_control_plane/acl.py +5 -3
  4. cribl_control_plane/auth_sdk.py +6 -3
  5. cribl_control_plane/basesdk.py +11 -1
  6. cribl_control_plane/commits.py +7 -5
  7. cribl_control_plane/destinations.py +6 -4
  8. cribl_control_plane/destinations_pq.py +2 -2
  9. cribl_control_plane/errors/__init__.py +23 -8
  10. cribl_control_plane/errors/apierror.py +2 -0
  11. cribl_control_plane/errors/criblcontrolplaneerror.py +11 -7
  12. cribl_control_plane/errors/error.py +4 -2
  13. cribl_control_plane/errors/healthserverstatus_error.py +41 -0
  14. cribl_control_plane/errors/no_response_error.py +5 -1
  15. cribl_control_plane/errors/responsevalidationerror.py +2 -0
  16. cribl_control_plane/groups_configs.py +8 -3
  17. cribl_control_plane/groups_sdk.py +64 -38
  18. cribl_control_plane/health.py +22 -12
  19. cribl_control_plane/httpclient.py +0 -1
  20. cribl_control_plane/lakedatasets.py +40 -12
  21. cribl_control_plane/models/__init__.py +1180 -54
  22. cribl_control_plane/models/authtoken.py +5 -1
  23. cribl_control_plane/models/{routecloneconf.py → branchinfo.py} +4 -4
  24. cribl_control_plane/models/cacheconnection.py +30 -2
  25. cribl_control_plane/models/cacheconnectionbackfillstatus.py +2 -1
  26. cribl_control_plane/models/cloudprovider.py +2 -1
  27. cribl_control_plane/models/configgroup.py +66 -11
  28. cribl_control_plane/models/configgroupcloud.py +17 -3
  29. cribl_control_plane/models/createconfiggroupbyproductop.py +27 -9
  30. cribl_control_plane/models/createinputhectokenbyidop.py +6 -5
  31. cribl_control_plane/models/createroutesappendbyidop.py +2 -2
  32. cribl_control_plane/models/createversionpushop.py +5 -5
  33. cribl_control_plane/models/createversionrevertop.py +2 -2
  34. cribl_control_plane/models/createversionundoop.py +3 -3
  35. cribl_control_plane/models/cribllakedataset.py +22 -2
  36. cribl_control_plane/models/cribllakedatasetupdate.py +95 -0
  37. cribl_control_plane/models/datasetmetadata.py +18 -2
  38. cribl_control_plane/models/deleteconfiggroupbyproductandidop.py +18 -2
  39. cribl_control_plane/models/deleteoutputpqbyidop.py +5 -5
  40. cribl_control_plane/models/deletepipelinebyidop.py +2 -2
  41. cribl_control_plane/models/difffiles.py +171 -0
  42. cribl_control_plane/models/distributedsummary.py +6 -0
  43. cribl_control_plane/models/getconfiggroupaclbyproductandidop.py +24 -2
  44. cribl_control_plane/models/getconfiggroupaclteamsbyproductandidop.py +24 -2
  45. cribl_control_plane/models/getconfiggroupbyproductandidop.py +14 -1
  46. cribl_control_plane/models/getconfiggroupconfigversionbyproductandidop.py +18 -2
  47. cribl_control_plane/models/getoutputpqbyidop.py +6 -5
  48. cribl_control_plane/models/getpipelinebyidop.py +2 -2
  49. cribl_control_plane/models/getroutesbyidop.py +2 -2
  50. cribl_control_plane/models/getsummaryop.py +18 -2
  51. cribl_control_plane/models/getversionbranchop.py +6 -5
  52. cribl_control_plane/models/getversioncountop.py +6 -5
  53. cribl_control_plane/models/getversiondiffop.py +6 -5
  54. cribl_control_plane/models/getversionshowop.py +6 -5
  55. cribl_control_plane/models/gitcountresult.py +13 -0
  56. cribl_control_plane/models/gitdiffresult.py +16 -0
  57. cribl_control_plane/models/gitinfo.py +14 -3
  58. cribl_control_plane/models/gitshowresult.py +19 -0
  59. cribl_control_plane/models/groupcreaterequest.py +171 -0
  60. cribl_control_plane/models/hbcriblinfo.py +39 -3
  61. cribl_control_plane/models/healthserverstatus.py +55 -0
  62. cribl_control_plane/models/heartbeatmetadata.py +3 -0
  63. cribl_control_plane/models/input.py +83 -78
  64. cribl_control_plane/models/inputappscope.py +126 -30
  65. cribl_control_plane/models/inputazureblob.py +62 -6
  66. cribl_control_plane/models/inputcloudflarehec.py +513 -0
  67. cribl_control_plane/models/inputcollection.py +47 -4
  68. cribl_control_plane/models/inputconfluentcloud.py +254 -30
  69. cribl_control_plane/models/inputcribl.py +47 -4
  70. cribl_control_plane/models/inputcriblhttp.py +121 -30
  71. cribl_control_plane/models/inputcribllakehttp.py +122 -30
  72. cribl_control_plane/models/inputcriblmetrics.py +48 -4
  73. cribl_control_plane/models/inputcribltcp.py +122 -24
  74. cribl_control_plane/models/inputcrowdstrike.py +92 -10
  75. cribl_control_plane/models/inputdatadogagent.py +98 -24
  76. cribl_control_plane/models/inputdatagen.py +47 -4
  77. cribl_control_plane/models/inputedgeprometheus.py +210 -50
  78. cribl_control_plane/models/inputelastic.py +167 -36
  79. cribl_control_plane/models/inputeventhub.py +209 -6
  80. cribl_control_plane/models/inputexec.py +59 -6
  81. cribl_control_plane/models/inputfile.py +78 -10
  82. cribl_control_plane/models/inputfirehose.py +97 -24
  83. cribl_control_plane/models/inputgooglepubsub.py +67 -6
  84. cribl_control_plane/models/inputgrafana.py +251 -71
  85. cribl_control_plane/models/inputhttp.py +97 -24
  86. cribl_control_plane/models/inputhttpraw.py +97 -24
  87. cribl_control_plane/models/inputjournalfiles.py +48 -4
  88. cribl_control_plane/models/inputkafka.py +248 -26
  89. cribl_control_plane/models/inputkinesis.py +130 -14
  90. cribl_control_plane/models/inputkubeevents.py +47 -4
  91. cribl_control_plane/models/inputkubelogs.py +61 -8
  92. cribl_control_plane/models/inputkubemetrics.py +61 -8
  93. cribl_control_plane/models/inputloki.py +113 -34
  94. cribl_control_plane/models/inputmetrics.py +97 -24
  95. cribl_control_plane/models/inputmodeldriventelemetry.py +107 -26
  96. cribl_control_plane/models/inputmsk.py +141 -30
  97. cribl_control_plane/models/inputnetflow.py +47 -4
  98. cribl_control_plane/models/inputoffice365mgmt.py +112 -14
  99. cribl_control_plane/models/inputoffice365msgtrace.py +114 -16
  100. cribl_control_plane/models/inputoffice365service.py +114 -16
  101. cribl_control_plane/models/inputopentelemetry.py +143 -32
  102. cribl_control_plane/models/inputprometheus.py +193 -44
  103. cribl_control_plane/models/inputprometheusrw.py +114 -27
  104. cribl_control_plane/models/inputrawudp.py +47 -4
  105. cribl_control_plane/models/inputs3.py +78 -8
  106. cribl_control_plane/models/inputs3inventory.py +92 -10
  107. cribl_control_plane/models/inputsecuritylake.py +93 -10
  108. cribl_control_plane/models/inputsnmp.py +68 -6
  109. cribl_control_plane/models/inputsplunk.py +130 -28
  110. cribl_control_plane/models/inputsplunkhec.py +111 -25
  111. cribl_control_plane/models/inputsplunksearch.py +108 -14
  112. cribl_control_plane/models/inputsqs.py +99 -16
  113. cribl_control_plane/models/inputsyslog.py +189 -47
  114. cribl_control_plane/models/inputsystemmetrics.py +202 -32
  115. cribl_control_plane/models/inputsystemstate.py +61 -8
  116. cribl_control_plane/models/inputtcp.py +122 -26
  117. cribl_control_plane/models/inputtcpjson.py +112 -26
  118. cribl_control_plane/models/inputwef.py +121 -15
  119. cribl_control_plane/models/inputwindowsmetrics.py +186 -33
  120. cribl_control_plane/models/inputwineventlogs.py +93 -11
  121. cribl_control_plane/models/inputwiz.py +78 -8
  122. cribl_control_plane/models/inputwizwebhook.py +97 -24
  123. cribl_control_plane/models/inputzscalerhec.py +111 -25
  124. cribl_control_plane/models/jobinfo.py +34 -0
  125. cribl_control_plane/models/jobstatus.py +48 -0
  126. cribl_control_plane/models/lakedatasetmetrics.py +17 -0
  127. cribl_control_plane/models/lakehouseconnectiontype.py +2 -1
  128. cribl_control_plane/models/listconfiggroupbyproductop.py +14 -1
  129. cribl_control_plane/models/logininfo.py +3 -3
  130. cribl_control_plane/models/masterworkerentry.py +17 -2
  131. cribl_control_plane/models/nodeactiveupgradestatus.py +2 -1
  132. cribl_control_plane/models/nodefailedupgradestatus.py +2 -1
  133. cribl_control_plane/models/nodeprovidedinfo.py +11 -1
  134. cribl_control_plane/models/nodeskippedupgradestatus.py +2 -1
  135. cribl_control_plane/models/nodeupgradestate.py +2 -1
  136. cribl_control_plane/models/nodeupgradestatus.py +51 -5
  137. cribl_control_plane/models/outpostnodeinfo.py +16 -0
  138. cribl_control_plane/models/output.py +104 -90
  139. cribl_control_plane/models/outputazureblob.py +171 -18
  140. cribl_control_plane/models/outputazuredataexplorer.py +514 -90
  141. cribl_control_plane/models/outputazureeventhub.py +315 -31
  142. cribl_control_plane/models/outputazurelogs.py +145 -26
  143. cribl_control_plane/models/outputchronicle.py +532 -0
  144. cribl_control_plane/models/outputclickhouse.py +205 -34
  145. cribl_control_plane/models/outputcloudflarer2.py +632 -0
  146. cribl_control_plane/models/outputcloudwatch.py +129 -23
  147. cribl_control_plane/models/outputconfluentcloud.py +384 -57
  148. cribl_control_plane/models/outputcriblhttp.py +199 -32
  149. cribl_control_plane/models/outputcribllake.py +156 -16
  150. cribl_control_plane/models/outputcribltcp.py +194 -29
  151. cribl_control_plane/models/outputcrowdstrikenextgensiem.py +172 -28
  152. cribl_control_plane/models/outputdatabricks.py +501 -0
  153. cribl_control_plane/models/outputdatadog.py +199 -31
  154. cribl_control_plane/models/outputdataset.py +181 -29
  155. cribl_control_plane/models/outputdiskspool.py +17 -2
  156. cribl_control_plane/models/outputdls3.py +233 -24
  157. cribl_control_plane/models/outputdynatracehttp.py +208 -34
  158. cribl_control_plane/models/outputdynatraceotlp.py +210 -36
  159. cribl_control_plane/models/outputelastic.py +199 -30
  160. cribl_control_plane/models/outputelasticcloud.py +171 -26
  161. cribl_control_plane/models/outputexabeam.py +96 -10
  162. cribl_control_plane/models/outputfilesystem.py +139 -14
  163. cribl_control_plane/models/outputgooglechronicle.py +216 -35
  164. cribl_control_plane/models/outputgooglecloudlogging.py +174 -31
  165. cribl_control_plane/models/outputgooglecloudstorage.py +215 -24
  166. cribl_control_plane/models/outputgooglepubsub.py +131 -23
  167. cribl_control_plane/models/outputgrafanacloud.py +376 -74
  168. cribl_control_plane/models/outputgraphite.py +128 -25
  169. cribl_control_plane/models/outputhoneycomb.py +145 -26
  170. cribl_control_plane/models/outputhumiohec.py +162 -28
  171. cribl_control_plane/models/outputinfluxdb.py +165 -28
  172. cribl_control_plane/models/outputkafka.py +375 -52
  173. cribl_control_plane/models/outputkinesis.py +165 -27
  174. cribl_control_plane/models/outputloki.py +164 -34
  175. cribl_control_plane/models/outputmicrosoftfabric.py +540 -0
  176. cribl_control_plane/models/outputminio.py +225 -25
  177. cribl_control_plane/models/outputmsk.py +267 -54
  178. cribl_control_plane/models/outputnewrelic.py +171 -29
  179. cribl_control_plane/models/outputnewrelicevents.py +163 -28
  180. cribl_control_plane/models/outputopentelemetry.py +240 -40
  181. cribl_control_plane/models/outputprometheus.py +145 -26
  182. cribl_control_plane/models/outputring.py +49 -8
  183. cribl_control_plane/models/outputs3.py +233 -26
  184. cribl_control_plane/models/outputsecuritylake.py +179 -18
  185. cribl_control_plane/models/outputsentinel.py +172 -29
  186. cribl_control_plane/models/outputsentineloneaisiem.py +181 -35
  187. cribl_control_plane/models/outputservicenow.py +223 -38
  188. cribl_control_plane/models/outputsignalfx.py +145 -26
  189. cribl_control_plane/models/outputsns.py +143 -25
  190. cribl_control_plane/models/outputsplunk.py +206 -36
  191. cribl_control_plane/models/outputsplunkhec.py +238 -26
  192. cribl_control_plane/models/outputsplunklb.py +253 -43
  193. cribl_control_plane/models/outputsqs.py +163 -33
  194. cribl_control_plane/models/outputstatsd.py +127 -25
  195. cribl_control_plane/models/outputstatsdext.py +128 -25
  196. cribl_control_plane/models/outputsumologic.py +146 -25
  197. cribl_control_plane/models/outputsyslog.py +318 -46
  198. cribl_control_plane/models/outputtcpjson.py +186 -32
  199. cribl_control_plane/models/outputwavefront.py +145 -26
  200. cribl_control_plane/models/outputwebhook.py +211 -33
  201. cribl_control_plane/models/outputxsiam.py +143 -26
  202. cribl_control_plane/models/packinfo.py +8 -5
  203. cribl_control_plane/models/packinstallinfo.py +11 -8
  204. cribl_control_plane/models/productscore.py +2 -1
  205. cribl_control_plane/models/rbacresource.py +2 -1
  206. cribl_control_plane/models/resourcepolicy.py +15 -2
  207. cribl_control_plane/models/routeconf.py +3 -4
  208. cribl_control_plane/models/runnablejob.py +27 -0
  209. cribl_control_plane/models/runnablejobcollection.py +669 -0
  210. cribl_control_plane/models/runnablejobexecutor.py +368 -0
  211. cribl_control_plane/models/runnablejobscheduledsearch.py +286 -0
  212. cribl_control_plane/models/updateconfiggroupbyproductandidop.py +19 -2
  213. cribl_control_plane/models/updateconfiggroupdeploybyproductandidop.py +19 -2
  214. cribl_control_plane/models/updatecribllakedatasetbylakeidandidop.py +9 -5
  215. cribl_control_plane/models/updateinputhectokenbyidandtokenop.py +6 -5
  216. cribl_control_plane/models/updatepacksop.py +25 -0
  217. cribl_control_plane/models/updatepipelinebyidop.py +6 -6
  218. cribl_control_plane/models/updateroutesbyidop.py +2 -2
  219. cribl_control_plane/models/uploadpackresponse.py +13 -0
  220. cribl_control_plane/models/workertypes.py +2 -1
  221. cribl_control_plane/nodes.py +5 -3
  222. cribl_control_plane/packs.py +202 -7
  223. cribl_control_plane/pipelines.py +18 -18
  224. cribl_control_plane/routes_sdk.py +22 -22
  225. cribl_control_plane/sdk.py +19 -6
  226. cribl_control_plane/sources.py +5 -3
  227. cribl_control_plane/tokens.py +23 -15
  228. cribl_control_plane/utils/__init__.py +15 -3
  229. cribl_control_plane/utils/annotations.py +32 -8
  230. cribl_control_plane/utils/eventstreaming.py +10 -0
  231. cribl_control_plane/utils/retries.py +69 -5
  232. cribl_control_plane/utils/unmarshal_json_response.py +15 -1
  233. cribl_control_plane/versions.py +11 -6
  234. {cribl_control_plane-0.0.38.dist-info → cribl_control_plane-0.4.0a6.dist-info}/METADATA +69 -23
  235. cribl_control_plane-0.4.0a6.dist-info/RECORD +336 -0
  236. {cribl_control_plane-0.0.38.dist-info → cribl_control_plane-0.4.0a6.dist-info}/WHEEL +1 -1
  237. cribl_control_plane-0.4.0a6.dist-info/licenses/LICENSE +201 -0
  238. cribl_control_plane/errors/healthstatus_error.py +0 -32
  239. cribl_control_plane/models/appmode.py +0 -13
  240. cribl_control_plane/models/healthstatus.py +0 -33
  241. cribl_control_plane-0.0.38.dist-info/RECORD +0 -315
@@ -0,0 +1,368 @@
1
+ """Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT."""
2
+
3
+ from __future__ import annotations
4
+ from cribl_control_plane import models, utils
5
+ from cribl_control_plane.types import BaseModel
6
+ from cribl_control_plane.utils import validate_open_enum
7
+ from enum import Enum
8
+ import pydantic
9
+ from pydantic import field_serializer
10
+ from pydantic.functional_validators import PlainValidator
11
+ from typing import Any, List, Optional
12
+ from typing_extensions import Annotated, NotRequired, TypedDict
13
+
14
+
15
+ class RunnableJobExecutorJobType(str, Enum, metaclass=utils.OpenEnumMeta):
16
+ COLLECTION = "collection"
17
+ EXECUTOR = "executor"
18
+ SCHEDULED_SEARCH = "scheduledSearch"
19
+
20
+
21
+ class RunnableJobExecutorType(str, Enum):
22
+ COLLECTION = "collection"
23
+
24
+
25
+ class RunnableJobExecutorScheduleLogLevel(str, Enum):
26
+ r"""Level at which to set task logging"""
27
+
28
+ ERROR = "error"
29
+ WARN = "warn"
30
+ INFO = "info"
31
+ DEBUG = "debug"
32
+ SILLY = "silly"
33
+
34
+
35
+ class RunnableJobExecutorTimeWarningTypedDict(TypedDict):
36
+ pass
37
+
38
+
39
+ class RunnableJobExecutorTimeWarning(BaseModel):
40
+ pass
41
+
42
+
43
+ class RunnableJobExecutorRunSettingsTypedDict(TypedDict):
44
+ type: NotRequired[RunnableJobExecutorType]
45
+ reschedule_dropped_tasks: NotRequired[bool]
46
+ r"""Reschedule tasks that failed with non-fatal errors"""
47
+ max_task_reschedule: NotRequired[float]
48
+ r"""Maximum number of times a task can be rescheduled"""
49
+ log_level: NotRequired[RunnableJobExecutorScheduleLogLevel]
50
+ r"""Level at which to set task logging"""
51
+ job_timeout: NotRequired[str]
52
+ r"""Maximum time the job is allowed to run. Time unit defaults to seconds if not specified (examples: 30, 45s, 15m). Enter 0 for unlimited time."""
53
+ mode: NotRequired[str]
54
+ r"""Job run mode. Preview will either return up to N matching results, or will run until capture time T is reached. Discovery will gather the list of files to turn into streaming tasks, without running the data collection job. Full Run will run the collection job."""
55
+ time_range_type: NotRequired[str]
56
+ earliest: NotRequired[float]
57
+ r"""Earliest time to collect data for the selected timezone"""
58
+ latest: NotRequired[float]
59
+ r"""Latest time to collect data for the selected timezone"""
60
+ timestamp_timezone: NotRequired[Any]
61
+ time_warning: NotRequired[RunnableJobExecutorTimeWarningTypedDict]
62
+ expression: NotRequired[str]
63
+ r"""A filter for tokens in the provided collect path and/or the events being collected"""
64
+ min_task_size: NotRequired[str]
65
+ r"""Limits the bundle size for small tasks. For example,
66
+
67
+
68
+
69
+
70
+
71
+
72
+
73
+
74
+
75
+
76
+ if your lower bundle size is 1MB, you can bundle up to five 200KB files into one task.
77
+ """
78
+ max_task_size: NotRequired[str]
79
+ r"""Limits the bundle size for files above the lower task bundle size. For example, if your upper bundle size is 10MB,
80
+
81
+
82
+
83
+
84
+
85
+
86
+
87
+
88
+
89
+
90
+ you can bundle up to five 2MB files into one task. Files greater than this size will be assigned to individual tasks.
91
+ """
92
+
93
+
94
+ class RunnableJobExecutorRunSettings(BaseModel):
95
+ type: Optional[RunnableJobExecutorType] = None
96
+
97
+ reschedule_dropped_tasks: Annotated[
98
+ Optional[bool], pydantic.Field(alias="rescheduleDroppedTasks")
99
+ ] = True
100
+ r"""Reschedule tasks that failed with non-fatal errors"""
101
+
102
+ max_task_reschedule: Annotated[
103
+ Optional[float], pydantic.Field(alias="maxTaskReschedule")
104
+ ] = 1
105
+ r"""Maximum number of times a task can be rescheduled"""
106
+
107
+ log_level: Annotated[
108
+ Optional[RunnableJobExecutorScheduleLogLevel], pydantic.Field(alias="logLevel")
109
+ ] = RunnableJobExecutorScheduleLogLevel.INFO
110
+ r"""Level at which to set task logging"""
111
+
112
+ job_timeout: Annotated[Optional[str], pydantic.Field(alias="jobTimeout")] = "0"
113
+ r"""Maximum time the job is allowed to run. Time unit defaults to seconds if not specified (examples: 30, 45s, 15m). Enter 0 for unlimited time."""
114
+
115
+ mode: Optional[str] = "list"
116
+ r"""Job run mode. Preview will either return up to N matching results, or will run until capture time T is reached. Discovery will gather the list of files to turn into streaming tasks, without running the data collection job. Full Run will run the collection job."""
117
+
118
+ time_range_type: Annotated[Optional[str], pydantic.Field(alias="timeRangeType")] = (
119
+ "relative"
120
+ )
121
+
122
+ earliest: Optional[float] = None
123
+ r"""Earliest time to collect data for the selected timezone"""
124
+
125
+ latest: Optional[float] = None
126
+ r"""Latest time to collect data for the selected timezone"""
127
+
128
+ timestamp_timezone: Annotated[
129
+ Optional[Any], pydantic.Field(alias="timestampTimezone")
130
+ ] = None
131
+
132
+ time_warning: Annotated[
133
+ Optional[RunnableJobExecutorTimeWarning], pydantic.Field(alias="timeWarning")
134
+ ] = None
135
+
136
+ expression: Optional[str] = "true"
137
+ r"""A filter for tokens in the provided collect path and/or the events being collected"""
138
+
139
+ min_task_size: Annotated[Optional[str], pydantic.Field(alias="minTaskSize")] = "1MB"
140
+ r"""Limits the bundle size for small tasks. For example,
141
+
142
+
143
+
144
+
145
+
146
+
147
+
148
+
149
+
150
+
151
+ if your lower bundle size is 1MB, you can bundle up to five 200KB files into one task.
152
+ """
153
+
154
+ max_task_size: Annotated[Optional[str], pydantic.Field(alias="maxTaskSize")] = (
155
+ "10MB"
156
+ )
157
+ r"""Limits the bundle size for files above the lower task bundle size. For example, if your upper bundle size is 10MB,
158
+
159
+
160
+
161
+
162
+
163
+
164
+
165
+
166
+
167
+
168
+ you can bundle up to five 2MB files into one task. Files greater than this size will be assigned to individual tasks.
169
+ """
170
+
171
+
172
+ class RunnableJobExecutorScheduleTypedDict(TypedDict):
173
+ r"""Configuration for a scheduled job"""
174
+
175
+ enabled: NotRequired[bool]
176
+ r"""Enable to configure scheduling for this Collector"""
177
+ skippable: NotRequired[bool]
178
+ r"""Skippable jobs can be delayed, up to their next run time, if the system is hitting concurrency limits"""
179
+ resume_missed: NotRequired[bool]
180
+ r"""If Stream Leader (or single instance) restarts, run all missed jobs according to their original schedules"""
181
+ cron_schedule: NotRequired[str]
182
+ r"""A cron schedule on which to run this job"""
183
+ max_concurrent_runs: NotRequired[float]
184
+ r"""The maximum number of instances of this scheduled job that may be running at any time"""
185
+ run: NotRequired[RunnableJobExecutorRunSettingsTypedDict]
186
+
187
+
188
+ class RunnableJobExecutorSchedule(BaseModel):
189
+ r"""Configuration for a scheduled job"""
190
+
191
+ enabled: Optional[bool] = None
192
+ r"""Enable to configure scheduling for this Collector"""
193
+
194
+ skippable: Optional[bool] = True
195
+ r"""Skippable jobs can be delayed, up to their next run time, if the system is hitting concurrency limits"""
196
+
197
+ resume_missed: Annotated[Optional[bool], pydantic.Field(alias="resumeMissed")] = (
198
+ False
199
+ )
200
+ r"""If Stream Leader (or single instance) restarts, run all missed jobs according to their original schedules"""
201
+
202
+ cron_schedule: Annotated[Optional[str], pydantic.Field(alias="cronSchedule")] = (
203
+ "*/5 * * * *"
204
+ )
205
+ r"""A cron schedule on which to run this job"""
206
+
207
+ max_concurrent_runs: Annotated[
208
+ Optional[float], pydantic.Field(alias="maxConcurrentRuns")
209
+ ] = 1
210
+ r"""The maximum number of instances of this scheduled job that may be running at any time"""
211
+
212
+ run: Optional[RunnableJobExecutorRunSettings] = None
213
+
214
+
215
+ class ExecutorSpecificSettingsTypedDict(TypedDict):
216
+ pass
217
+
218
+
219
+ class ExecutorSpecificSettings(BaseModel):
220
+ pass
221
+
222
+
223
+ class ExecutorTypedDict(TypedDict):
224
+ type: str
225
+ r"""The type of executor to run"""
226
+ store_task_results: NotRequired[bool]
227
+ r"""Determines whether or not to write task results to disk"""
228
+ conf: NotRequired[ExecutorSpecificSettingsTypedDict]
229
+
230
+
231
+ class Executor(BaseModel):
232
+ type: str
233
+ r"""The type of executor to run"""
234
+
235
+ store_task_results: Annotated[
236
+ Optional[bool], pydantic.Field(alias="storeTaskResults")
237
+ ] = True
238
+ r"""Determines whether or not to write task results to disk"""
239
+
240
+ conf: Optional[ExecutorSpecificSettings] = None
241
+
242
+
243
+ class RunnableJobExecutorLogLevel(str, Enum, metaclass=utils.OpenEnumMeta):
244
+ r"""Level at which to set task logging"""
245
+
246
+ ERROR = "error"
247
+ WARN = "warn"
248
+ INFO = "info"
249
+ DEBUG = "debug"
250
+ SILLY = "silly"
251
+
252
+
253
+ class RunnableJobExecutorRunTypedDict(TypedDict):
254
+ reschedule_dropped_tasks: NotRequired[bool]
255
+ r"""Reschedule tasks that failed with non-fatal errors"""
256
+ max_task_reschedule: NotRequired[float]
257
+ r"""Maximum number of times a task can be rescheduled"""
258
+ log_level: NotRequired[RunnableJobExecutorLogLevel]
259
+ r"""Level at which to set task logging"""
260
+ job_timeout: NotRequired[str]
261
+ r"""Maximum time the job is allowed to run. Time unit defaults to seconds if not specified (examples: 30, 45s, 15m). Enter 0 for unlimited time."""
262
+
263
+
264
+ class RunnableJobExecutorRun(BaseModel):
265
+ reschedule_dropped_tasks: Annotated[
266
+ Optional[bool], pydantic.Field(alias="rescheduleDroppedTasks")
267
+ ] = True
268
+ r"""Reschedule tasks that failed with non-fatal errors"""
269
+
270
+ max_task_reschedule: Annotated[
271
+ Optional[float], pydantic.Field(alias="maxTaskReschedule")
272
+ ] = 1
273
+ r"""Maximum number of times a task can be rescheduled"""
274
+
275
+ log_level: Annotated[
276
+ Annotated[
277
+ Optional[RunnableJobExecutorLogLevel],
278
+ PlainValidator(validate_open_enum(False)),
279
+ ],
280
+ pydantic.Field(alias="logLevel"),
281
+ ] = RunnableJobExecutorLogLevel.INFO
282
+ r"""Level at which to set task logging"""
283
+
284
+ job_timeout: Annotated[Optional[str], pydantic.Field(alias="jobTimeout")] = "0"
285
+ r"""Maximum time the job is allowed to run. Time unit defaults to seconds if not specified (examples: 30, 45s, 15m). Enter 0 for unlimited time."""
286
+
287
+ @field_serializer("log_level")
288
+ def serialize_log_level(self, value):
289
+ if isinstance(value, str):
290
+ try:
291
+ return models.RunnableJobExecutorLogLevel(value)
292
+ except ValueError:
293
+ return value
294
+ return value
295
+
296
+
297
+ class RunnableJobExecutorTypedDict(TypedDict):
298
+ executor: ExecutorTypedDict
299
+ run: RunnableJobExecutorRunTypedDict
300
+ id: NotRequired[str]
301
+ r"""Unique ID for this Job"""
302
+ description: NotRequired[str]
303
+ type: NotRequired[RunnableJobExecutorJobType]
304
+ ttl: NotRequired[str]
305
+ r"""Time to keep the job's artifacts on disk after job completion. This also affects how long a job is listed in the Job Inspector."""
306
+ ignore_group_jobs_limit: NotRequired[bool]
307
+ r"""When enabled, this job's artifacts are not counted toward the Worker Group's finished job artifacts limit. Artifacts will be removed only after the Collector's configured time to live."""
308
+ remove_fields: NotRequired[List[str]]
309
+ r"""List of fields to remove from Discover results. Wildcards (for example, aws*) are allowed. This is useful when discovery returns sensitive fields that should not be exposed in the Jobs user interface."""
310
+ resume_on_boot: NotRequired[bool]
311
+ r"""Resume the ad hoc job if a failure condition causes Stream to restart during job execution"""
312
+ environment: NotRequired[str]
313
+ r"""Optionally, enable this config only on a specified Git branch. If empty, will be enabled everywhere."""
314
+ schedule: NotRequired[RunnableJobExecutorScheduleTypedDict]
315
+ r"""Configuration for a scheduled job"""
316
+ streamtags: NotRequired[List[str]]
317
+ r"""Tags for filtering and grouping in @{product}"""
318
+
319
+
320
+ class RunnableJobExecutor(BaseModel):
321
+ executor: Executor
322
+
323
+ run: RunnableJobExecutorRun
324
+
325
+ id: Optional[str] = None
326
+ r"""Unique ID for this Job"""
327
+
328
+ description: Optional[str] = None
329
+
330
+ type: Annotated[
331
+ Optional[RunnableJobExecutorJobType], PlainValidator(validate_open_enum(False))
332
+ ] = None
333
+
334
+ ttl: Optional[str] = "4h"
335
+ r"""Time to keep the job's artifacts on disk after job completion. This also affects how long a job is listed in the Job Inspector."""
336
+
337
+ ignore_group_jobs_limit: Annotated[
338
+ Optional[bool], pydantic.Field(alias="ignoreGroupJobsLimit")
339
+ ] = False
340
+ r"""When enabled, this job's artifacts are not counted toward the Worker Group's finished job artifacts limit. Artifacts will be removed only after the Collector's configured time to live."""
341
+
342
+ remove_fields: Annotated[
343
+ Optional[List[str]], pydantic.Field(alias="removeFields")
344
+ ] = None
345
+ r"""List of fields to remove from Discover results. Wildcards (for example, aws*) are allowed. This is useful when discovery returns sensitive fields that should not be exposed in the Jobs user interface."""
346
+
347
+ resume_on_boot: Annotated[Optional[bool], pydantic.Field(alias="resumeOnBoot")] = (
348
+ False
349
+ )
350
+ r"""Resume the ad hoc job if a failure condition causes Stream to restart during job execution"""
351
+
352
+ environment: Optional[str] = None
353
+ r"""Optionally, enable this config only on a specified Git branch. If empty, will be enabled everywhere."""
354
+
355
+ schedule: Optional[RunnableJobExecutorSchedule] = None
356
+ r"""Configuration for a scheduled job"""
357
+
358
+ streamtags: Optional[List[str]] = None
359
+ r"""Tags for filtering and grouping in @{product}"""
360
+
361
+ @field_serializer("type")
362
+ def serialize_type(self, value):
363
+ if isinstance(value, str):
364
+ try:
365
+ return models.RunnableJobExecutorJobType(value)
366
+ except ValueError:
367
+ return value
368
+ return value
@@ -0,0 +1,286 @@
1
+ """Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT."""
2
+
3
+ from __future__ import annotations
4
+ from cribl_control_plane import models, utils
5
+ from cribl_control_plane.types import BaseModel
6
+ from cribl_control_plane.utils import validate_open_enum
7
+ from enum import Enum
8
+ import pydantic
9
+ from pydantic import field_serializer
10
+ from pydantic.functional_validators import PlainValidator
11
+ from typing import Any, List, Optional
12
+ from typing_extensions import Annotated, NotRequired, TypedDict
13
+
14
+
15
+ class RunnableJobScheduledSearchJobType(str, Enum, metaclass=utils.OpenEnumMeta):
16
+ COLLECTION = "collection"
17
+ EXECUTOR = "executor"
18
+ SCHEDULED_SEARCH = "scheduledSearch"
19
+
20
+
21
+ class RunnableJobScheduledSearchType(str, Enum):
22
+ COLLECTION = "collection"
23
+
24
+
25
+ class RunnableJobScheduledSearchLogLevel(str, Enum):
26
+ r"""Level at which to set task logging"""
27
+
28
+ ERROR = "error"
29
+ WARN = "warn"
30
+ INFO = "info"
31
+ DEBUG = "debug"
32
+ SILLY = "silly"
33
+
34
+
35
+ class RunnableJobScheduledSearchTimeWarningTypedDict(TypedDict):
36
+ pass
37
+
38
+
39
+ class RunnableJobScheduledSearchTimeWarning(BaseModel):
40
+ pass
41
+
42
+
43
+ class RunnableJobScheduledSearchRunSettingsTypedDict(TypedDict):
44
+ type: NotRequired[RunnableJobScheduledSearchType]
45
+ reschedule_dropped_tasks: NotRequired[bool]
46
+ r"""Reschedule tasks that failed with non-fatal errors"""
47
+ max_task_reschedule: NotRequired[float]
48
+ r"""Maximum number of times a task can be rescheduled"""
49
+ log_level: NotRequired[RunnableJobScheduledSearchLogLevel]
50
+ r"""Level at which to set task logging"""
51
+ job_timeout: NotRequired[str]
52
+ r"""Maximum time the job is allowed to run. Time unit defaults to seconds if not specified (examples: 30, 45s, 15m). Enter 0 for unlimited time."""
53
+ mode: NotRequired[str]
54
+ r"""Job run mode. Preview will either return up to N matching results, or will run until capture time T is reached. Discovery will gather the list of files to turn into streaming tasks, without running the data collection job. Full Run will run the collection job."""
55
+ time_range_type: NotRequired[str]
56
+ earliest: NotRequired[float]
57
+ r"""Earliest time to collect data for the selected timezone"""
58
+ latest: NotRequired[float]
59
+ r"""Latest time to collect data for the selected timezone"""
60
+ timestamp_timezone: NotRequired[Any]
61
+ time_warning: NotRequired[RunnableJobScheduledSearchTimeWarningTypedDict]
62
+ expression: NotRequired[str]
63
+ r"""A filter for tokens in the provided collect path and/or the events being collected"""
64
+ min_task_size: NotRequired[str]
65
+ r"""Limits the bundle size for small tasks. For example,
66
+
67
+
68
+
69
+
70
+
71
+
72
+
73
+
74
+
75
+
76
+ if your lower bundle size is 1MB, you can bundle up to five 200KB files into one task.
77
+ """
78
+ max_task_size: NotRequired[str]
79
+ r"""Limits the bundle size for files above the lower task bundle size. For example, if your upper bundle size is 10MB,
80
+
81
+
82
+
83
+
84
+
85
+
86
+
87
+
88
+
89
+
90
+ you can bundle up to five 2MB files into one task. Files greater than this size will be assigned to individual tasks.
91
+ """
92
+
93
+
94
+ class RunnableJobScheduledSearchRunSettings(BaseModel):
95
+ type: Optional[RunnableJobScheduledSearchType] = None
96
+
97
+ reschedule_dropped_tasks: Annotated[
98
+ Optional[bool], pydantic.Field(alias="rescheduleDroppedTasks")
99
+ ] = True
100
+ r"""Reschedule tasks that failed with non-fatal errors"""
101
+
102
+ max_task_reschedule: Annotated[
103
+ Optional[float], pydantic.Field(alias="maxTaskReschedule")
104
+ ] = 1
105
+ r"""Maximum number of times a task can be rescheduled"""
106
+
107
+ log_level: Annotated[
108
+ Optional[RunnableJobScheduledSearchLogLevel], pydantic.Field(alias="logLevel")
109
+ ] = RunnableJobScheduledSearchLogLevel.INFO
110
+ r"""Level at which to set task logging"""
111
+
112
+ job_timeout: Annotated[Optional[str], pydantic.Field(alias="jobTimeout")] = "0"
113
+ r"""Maximum time the job is allowed to run. Time unit defaults to seconds if not specified (examples: 30, 45s, 15m). Enter 0 for unlimited time."""
114
+
115
+ mode: Optional[str] = "list"
116
+ r"""Job run mode. Preview will either return up to N matching results, or will run until capture time T is reached. Discovery will gather the list of files to turn into streaming tasks, without running the data collection job. Full Run will run the collection job."""
117
+
118
+ time_range_type: Annotated[Optional[str], pydantic.Field(alias="timeRangeType")] = (
119
+ "relative"
120
+ )
121
+
122
+ earliest: Optional[float] = None
123
+ r"""Earliest time to collect data for the selected timezone"""
124
+
125
+ latest: Optional[float] = None
126
+ r"""Latest time to collect data for the selected timezone"""
127
+
128
+ timestamp_timezone: Annotated[
129
+ Optional[Any], pydantic.Field(alias="timestampTimezone")
130
+ ] = None
131
+
132
+ time_warning: Annotated[
133
+ Optional[RunnableJobScheduledSearchTimeWarning],
134
+ pydantic.Field(alias="timeWarning"),
135
+ ] = None
136
+
137
+ expression: Optional[str] = "true"
138
+ r"""A filter for tokens in the provided collect path and/or the events being collected"""
139
+
140
+ min_task_size: Annotated[Optional[str], pydantic.Field(alias="minTaskSize")] = "1MB"
141
+ r"""Limits the bundle size for small tasks. For example,
142
+
143
+
144
+
145
+
146
+
147
+
148
+
149
+
150
+
151
+
152
+ if your lower bundle size is 1MB, you can bundle up to five 200KB files into one task.
153
+ """
154
+
155
+ max_task_size: Annotated[Optional[str], pydantic.Field(alias="maxTaskSize")] = (
156
+ "10MB"
157
+ )
158
+ r"""Limits the bundle size for files above the lower task bundle size. For example, if your upper bundle size is 10MB,
159
+
160
+
161
+
162
+
163
+
164
+
165
+
166
+
167
+
168
+
169
+ you can bundle up to five 2MB files into one task. Files greater than this size will be assigned to individual tasks.
170
+ """
171
+
172
+
173
+ class RunnableJobScheduledSearchScheduleTypedDict(TypedDict):
174
+ r"""Configuration for a scheduled job"""
175
+
176
+ enabled: NotRequired[bool]
177
+ r"""Enable to configure scheduling for this Collector"""
178
+ skippable: NotRequired[bool]
179
+ r"""Skippable jobs can be delayed, up to their next run time, if the system is hitting concurrency limits"""
180
+ resume_missed: NotRequired[bool]
181
+ r"""If Stream Leader (or single instance) restarts, run all missed jobs according to their original schedules"""
182
+ cron_schedule: NotRequired[str]
183
+ r"""A cron schedule on which to run this job"""
184
+ max_concurrent_runs: NotRequired[float]
185
+ r"""The maximum number of instances of this scheduled job that may be running at any time"""
186
+ run: NotRequired[RunnableJobScheduledSearchRunSettingsTypedDict]
187
+
188
+
189
+ class RunnableJobScheduledSearchSchedule(BaseModel):
190
+ r"""Configuration for a scheduled job"""
191
+
192
+ enabled: Optional[bool] = None
193
+ r"""Enable to configure scheduling for this Collector"""
194
+
195
+ skippable: Optional[bool] = True
196
+ r"""Skippable jobs can be delayed, up to their next run time, if the system is hitting concurrency limits"""
197
+
198
+ resume_missed: Annotated[Optional[bool], pydantic.Field(alias="resumeMissed")] = (
199
+ False
200
+ )
201
+ r"""If Stream Leader (or single instance) restarts, run all missed jobs according to their original schedules"""
202
+
203
+ cron_schedule: Annotated[Optional[str], pydantic.Field(alias="cronSchedule")] = (
204
+ "*/5 * * * *"
205
+ )
206
+ r"""A cron schedule on which to run this job"""
207
+
208
+ max_concurrent_runs: Annotated[
209
+ Optional[float], pydantic.Field(alias="maxConcurrentRuns")
210
+ ] = 1
211
+ r"""The maximum number of instances of this scheduled job that may be running at any time"""
212
+
213
+ run: Optional[RunnableJobScheduledSearchRunSettings] = None
214
+
215
+
216
+ class RunnableJobScheduledSearchTypedDict(TypedDict):
217
+ type: RunnableJobScheduledSearchJobType
218
+ saved_query_id: str
219
+ r"""Identifies which search query to run"""
220
+ id: NotRequired[str]
221
+ r"""Unique ID for this Job"""
222
+ description: NotRequired[str]
223
+ ttl: NotRequired[str]
224
+ r"""Time to keep the job's artifacts on disk after job completion. This also affects how long a job is listed in the Job Inspector."""
225
+ ignore_group_jobs_limit: NotRequired[bool]
226
+ r"""When enabled, this job's artifacts are not counted toward the Worker Group's finished job artifacts limit. Artifacts will be removed only after the Collector's configured time to live."""
227
+ remove_fields: NotRequired[List[str]]
228
+ r"""List of fields to remove from Discover results. Wildcards (for example, aws*) are allowed. This is useful when discovery returns sensitive fields that should not be exposed in the Jobs user interface."""
229
+ resume_on_boot: NotRequired[bool]
230
+ r"""Resume the ad hoc job if a failure condition causes Stream to restart during job execution"""
231
+ environment: NotRequired[str]
232
+ r"""Optionally, enable this config only on a specified Git branch. If empty, will be enabled everywhere."""
233
+ schedule: NotRequired[RunnableJobScheduledSearchScheduleTypedDict]
234
+ r"""Configuration for a scheduled job"""
235
+ streamtags: NotRequired[List[str]]
236
+ r"""Tags for filtering and grouping in @{product}"""
237
+
238
+
239
+ class RunnableJobScheduledSearch(BaseModel):
240
+ type: Annotated[
241
+ RunnableJobScheduledSearchJobType, PlainValidator(validate_open_enum(False))
242
+ ]
243
+
244
+ saved_query_id: Annotated[str, pydantic.Field(alias="savedQueryId")]
245
+ r"""Identifies which search query to run"""
246
+
247
+ id: Optional[str] = None
248
+ r"""Unique ID for this Job"""
249
+
250
+ description: Optional[str] = None
251
+
252
+ ttl: Optional[str] = "4h"
253
+ r"""Time to keep the job's artifacts on disk after job completion. This also affects how long a job is listed in the Job Inspector."""
254
+
255
+ ignore_group_jobs_limit: Annotated[
256
+ Optional[bool], pydantic.Field(alias="ignoreGroupJobsLimit")
257
+ ] = False
258
+ r"""When enabled, this job's artifacts are not counted toward the Worker Group's finished job artifacts limit. Artifacts will be removed only after the Collector's configured time to live."""
259
+
260
+ remove_fields: Annotated[
261
+ Optional[List[str]], pydantic.Field(alias="removeFields")
262
+ ] = None
263
+ r"""List of fields to remove from Discover results. Wildcards (for example, aws*) are allowed. This is useful when discovery returns sensitive fields that should not be exposed in the Jobs user interface."""
264
+
265
+ resume_on_boot: Annotated[Optional[bool], pydantic.Field(alias="resumeOnBoot")] = (
266
+ False
267
+ )
268
+ r"""Resume the ad hoc job if a failure condition causes Stream to restart during job execution"""
269
+
270
+ environment: Optional[str] = None
271
+ r"""Optionally, enable this config only on a specified Git branch. If empty, will be enabled everywhere."""
272
+
273
+ schedule: Optional[RunnableJobScheduledSearchSchedule] = None
274
+ r"""Configuration for a scheduled job"""
275
+
276
+ streamtags: Optional[List[str]] = None
277
+ r"""Tags for filtering and grouping in @{product}"""
278
+
279
+ @field_serializer("type")
280
+ def serialize_type(self, value):
281
+ if isinstance(value, str):
282
+ try:
283
+ return models.RunnableJobScheduledSearchJobType(value)
284
+ except ValueError:
285
+ return value
286
+ return value