cribl-control-plane 0.0.21__py3-none-any.whl → 0.4.0b23__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.
Files changed (436) hide show
  1. cribl_control_plane/_hooks/clientcredentials.py +113 -48
  2. cribl_control_plane/_version.py +4 -4
  3. cribl_control_plane/acl.py +225 -0
  4. cribl_control_plane/auth_sdk.py +12 -176
  5. cribl_control_plane/basesdk.py +17 -1
  6. cribl_control_plane/branches.py +351 -0
  7. cribl_control_plane/commits.py +1403 -0
  8. cribl_control_plane/commits_files.py +391 -0
  9. cribl_control_plane/configs_versions.py +201 -0
  10. cribl_control_plane/cribl.py +495 -0
  11. cribl_control_plane/destinations.py +146 -805
  12. cribl_control_plane/destinations_pq.py +379 -0
  13. cribl_control_plane/errors/__init__.py +26 -10
  14. cribl_control_plane/errors/apierror.py +2 -0
  15. cribl_control_plane/errors/criblcontrolplaneerror.py +11 -7
  16. cribl_control_plane/errors/error.py +4 -2
  17. cribl_control_plane/errors/healthserverstatus_error.py +41 -0
  18. cribl_control_plane/errors/no_response_error.py +5 -1
  19. cribl_control_plane/errors/responsevalidationerror.py +2 -0
  20. cribl_control_plane/functions.py +367 -0
  21. cribl_control_plane/groups_configs.py +22 -0
  22. cribl_control_plane/groups_sdk.py +333 -578
  23. cribl_control_plane/health.py +38 -18
  24. cribl_control_plane/hectokens.py +503 -0
  25. cribl_control_plane/httpclient.py +0 -1
  26. cribl_control_plane/{lake.py → lakedatasets.py} +207 -115
  27. cribl_control_plane/models/__init__.py +3644 -5986
  28. cribl_control_plane/models/addhectokenrequest.py +7 -1
  29. cribl_control_plane/models/authtoken.py +5 -1
  30. cribl_control_plane/models/backupssettings_union.py +37 -0
  31. cribl_control_plane/models/{lookupversions.py → branchinfo.py} +4 -4
  32. cribl_control_plane/models/cacheconnection.py +30 -2
  33. cribl_control_plane/models/cacheconnectionbackfillstatus.py +2 -1
  34. cribl_control_plane/models/cloudprovider.py +2 -1
  35. cribl_control_plane/models/collectorazureblob.py +130 -0
  36. cribl_control_plane/models/collectorconf.py +56 -0
  37. cribl_control_plane/models/collectorcribllake.py +27 -0
  38. cribl_control_plane/models/collectordatabase.py +92 -0
  39. cribl_control_plane/models/collectorfilesystem.py +66 -0
  40. cribl_control_plane/models/collectorgooglecloudstorage.py +131 -0
  41. cribl_control_plane/models/collectorhealthcheck.py +269 -0
  42. cribl_control_plane/models/collectorrest.py +340 -0
  43. cribl_control_plane/models/collectors3.py +239 -0
  44. cribl_control_plane/models/collectorscript.py +59 -0
  45. cribl_control_plane/models/collectorsplunk.py +253 -0
  46. cribl_control_plane/models/configgroup.py +67 -11
  47. cribl_control_plane/models/configgroupcloud.py +17 -3
  48. cribl_control_plane/models/countedbranchinfo.py +20 -0
  49. cribl_control_plane/models/countedconfiggroup.py +20 -0
  50. cribl_control_plane/models/countedcribllakedataset.py +20 -0
  51. cribl_control_plane/models/counteddistributedsummary.py +20 -0
  52. cribl_control_plane/models/countedfunctionresponse.py +20 -0
  53. cribl_control_plane/models/countedgitcommitsummary.py +20 -0
  54. cribl_control_plane/models/countedgitcountresult.py +20 -0
  55. cribl_control_plane/models/countedgitdiffresult.py +20 -0
  56. cribl_control_plane/models/countedgitfilesresponse.py +20 -0
  57. cribl_control_plane/models/{getversioninfoop.py → countedgitinfo.py} +2 -6
  58. cribl_control_plane/models/countedgitlogresult.py +20 -0
  59. cribl_control_plane/models/countedgitrevertresult.py +20 -0
  60. cribl_control_plane/models/countedgitshowresult.py +20 -0
  61. cribl_control_plane/models/countedgitstatusresult.py +20 -0
  62. cribl_control_plane/models/{listinputop.py → countedinput.py} +2 -6
  63. cribl_control_plane/models/countedinputsplunkhec.py +20 -0
  64. cribl_control_plane/models/countedjobinfo.py +20 -0
  65. cribl_control_plane/models/countedmasterworkerentry.py +20 -0
  66. cribl_control_plane/models/countednumber.py +19 -0
  67. cribl_control_plane/models/{getversionbranchop.py → countedobject.py} +2 -6
  68. cribl_control_plane/models/{listoutputop.py → countedoutput.py} +2 -6
  69. cribl_control_plane/models/countedoutputsamplesresponse.py +20 -0
  70. cribl_control_plane/models/countedoutputtestresponse.py +20 -0
  71. cribl_control_plane/models/countedpackinfo.py +20 -0
  72. cribl_control_plane/models/{createpacksop.py → countedpackinstallinfo.py} +2 -6
  73. cribl_control_plane/models/{listpipelineop.py → countedpipeline.py} +2 -6
  74. cribl_control_plane/models/{listroutesop.py → countedroutes.py} +2 -6
  75. cribl_control_plane/models/countedstring.py +19 -0
  76. cribl_control_plane/models/countedsystemsettingsconf.py +20 -0
  77. cribl_control_plane/models/countedteamaccesscontrollist.py +20 -0
  78. cribl_control_plane/models/counteduseraccesscontrollist.py +20 -0
  79. cribl_control_plane/models/createauthloginop.py +18 -0
  80. cribl_control_plane/models/createconfiggroupbyproductop.py +46 -0
  81. cribl_control_plane/models/createcribllakedatasetbylakeidop.py +3 -21
  82. cribl_control_plane/models/createinputhectokenbyidop.py +3 -21
  83. cribl_control_plane/models/createoutputtestbyidop.py +3 -22
  84. cribl_control_plane/models/createroutesappendbyidop.py +4 -21
  85. cribl_control_plane/models/createversioncommitop.py +27 -20
  86. cribl_control_plane/models/createversionrevertop.py +7 -23
  87. cribl_control_plane/models/createversionundoop.py +7 -22
  88. cribl_control_plane/models/criblevent.py +15 -0
  89. cribl_control_plane/models/cribllakedataset.py +23 -3
  90. cribl_control_plane/models/cribllakedatasetupdate.py +95 -0
  91. cribl_control_plane/models/currentbranchresult.py +13 -0
  92. cribl_control_plane/models/datasetmetadata.py +18 -2
  93. cribl_control_plane/models/deleteconfiggroupbyproductandidop.py +43 -0
  94. cribl_control_plane/models/deletecribllakedatasetbylakeidandidop.py +5 -24
  95. cribl_control_plane/models/deleteinputbyidop.py +3 -22
  96. cribl_control_plane/models/deleteoutputbyidop.py +3 -22
  97. cribl_control_plane/models/deleteoutputpqbyidop.py +3 -21
  98. cribl_control_plane/models/deletepacksbyidop.py +3 -22
  99. cribl_control_plane/models/deletepipelinebyidop.py +3 -22
  100. cribl_control_plane/models/difffiles.py +130 -0
  101. cribl_control_plane/models/diffline.py +26 -0
  102. cribl_control_plane/models/difflinecontext.py +28 -0
  103. cribl_control_plane/models/difflinedelete.py +25 -0
  104. cribl_control_plane/models/difflineinsert.py +25 -0
  105. cribl_control_plane/models/distributedsummary.py +6 -0
  106. cribl_control_plane/models/functionaggregatemetrics.py +206 -0
  107. cribl_control_plane/models/functionaggregation.py +172 -0
  108. cribl_control_plane/models/functionautotimestamp.py +173 -0
  109. cribl_control_plane/models/functioncef.py +111 -0
  110. cribl_control_plane/models/functionchain.py +75 -0
  111. cribl_control_plane/models/functionclone.py +75 -0
  112. cribl_control_plane/models/functioncode.py +96 -0
  113. cribl_control_plane/models/functioncomment.py +75 -0
  114. cribl_control_plane/models/functiondistinct.py +99 -0
  115. cribl_control_plane/models/functiondnslookup.py +250 -0
  116. cribl_control_plane/models/functiondrop.py +73 -0
  117. cribl_control_plane/models/functiondropdimensions.py +87 -0
  118. cribl_control_plane/models/functiondynamicsampling.py +121 -0
  119. cribl_control_plane/models/functioneval.py +103 -0
  120. cribl_control_plane/models/functioneventbreaker.py +103 -0
  121. cribl_control_plane/models/functioneventstats.py +92 -0
  122. cribl_control_plane/models/functionexternaldata.py +73 -0
  123. cribl_control_plane/models/functionflatten.py +90 -0
  124. cribl_control_plane/models/functionfoldkeys.py +89 -0
  125. cribl_control_plane/models/functiongenstats.py +73 -0
  126. cribl_control_plane/models/functiongeoip.py +120 -0
  127. cribl_control_plane/models/functiongrok.py +95 -0
  128. cribl_control_plane/models/functionhandlebar.py +112 -0
  129. cribl_control_plane/models/functionjoin.py +112 -0
  130. cribl_control_plane/models/functionjsonunroll.py +80 -0
  131. cribl_control_plane/models/functionlakeexport.py +102 -0
  132. cribl_control_plane/models/functionlimit.py +75 -0
  133. cribl_control_plane/models/functionlocalsearchdatatypeparser.py +76 -0
  134. cribl_control_plane/models/functionlocalsearchrulesetrunner.py +97 -0
  135. cribl_control_plane/models/functionlookup.py +148 -0
  136. cribl_control_plane/models/functionmask.py +121 -0
  137. cribl_control_plane/models/functionmvexpand.py +128 -0
  138. cribl_control_plane/models/functionmvpull.py +99 -0
  139. cribl_control_plane/models/functionnotificationpolicies.py +186 -0
  140. cribl_control_plane/models/functionnotifications.py +85 -0
  141. cribl_control_plane/models/functionnotify.py +196 -0
  142. cribl_control_plane/models/functionnumerify.py +119 -0
  143. cribl_control_plane/models/functionotlplogs.py +82 -0
  144. cribl_control_plane/models/functionotlpmetrics.py +118 -0
  145. cribl_control_plane/models/functionotlptraces.py +111 -0
  146. cribl_control_plane/models/functionpack.py +80 -0
  147. cribl_control_plane/models/functionpivot.py +85 -0
  148. cribl_control_plane/models/functionpublishmetrics.py +153 -0
  149. cribl_control_plane/models/functionredis.py +173 -0
  150. cribl_control_plane/models/functionregexextract.py +112 -0
  151. cribl_control_plane/models/functionregexfilter.py +95 -0
  152. cribl_control_plane/models/functionrename.py +107 -0
  153. cribl_control_plane/models/functionresponse.py +242 -0
  154. cribl_control_plane/models/functionrollupmetrics.py +114 -0
  155. cribl_control_plane/models/functionsampling.py +90 -0
  156. cribl_control_plane/models/functionsend.py +141 -0
  157. cribl_control_plane/models/functionsensitivedatascanner.py +128 -0
  158. cribl_control_plane/models/functionserde.py +161 -0
  159. cribl_control_plane/models/functionserialize.py +134 -0
  160. cribl_control_plane/models/functionsidlookup.py +93 -0
  161. cribl_control_plane/models/functionsnmptrapserialize.py +144 -0
  162. cribl_control_plane/models/functionsort.py +97 -0
  163. cribl_control_plane/models/functionstore.py +132 -0
  164. cribl_control_plane/models/functionsuppress.py +115 -0
  165. cribl_control_plane/models/functiontee.py +90 -0
  166. cribl_control_plane/models/functiontrimtimestamp.py +75 -0
  167. cribl_control_plane/models/functionunion.py +80 -0
  168. cribl_control_plane/models/functionunroll.py +80 -0
  169. cribl_control_plane/models/functionwindow.py +96 -0
  170. cribl_control_plane/models/functionxmlunroll.py +92 -0
  171. cribl_control_plane/models/getconfiggroupaclbyproductandidop.py +63 -0
  172. cribl_control_plane/models/getconfiggroupaclteamsbyproductandidop.py +63 -0
  173. cribl_control_plane/models/getconfiggroupbyproductandidop.py +53 -0
  174. cribl_control_plane/models/getconfiggroupconfigversionbyproductandidop.py +43 -0
  175. cribl_control_plane/models/getcribllakedatasetbylakeidandidop.py +5 -24
  176. cribl_control_plane/models/getcribllakedatasetbylakeidop.py +56 -16
  177. cribl_control_plane/models/getfunctionsbyidop.py +18 -0
  178. cribl_control_plane/models/getinputbyidop.py +3 -22
  179. cribl_control_plane/models/getmasterworkerentryop.py +22 -0
  180. cribl_control_plane/models/getoutputbyidop.py +3 -22
  181. cribl_control_plane/models/getoutputpqbyidop.py +3 -21
  182. cribl_control_plane/models/getoutputsamplesbyidop.py +3 -22
  183. cribl_control_plane/models/getpacksbyidop.py +18 -0
  184. cribl_control_plane/models/getpacksop.py +3 -21
  185. cribl_control_plane/models/getpipelinebyidop.py +3 -22
  186. cribl_control_plane/models/getroutesbyidop.py +3 -22
  187. cribl_control_plane/models/getsummaryop.py +23 -32
  188. cribl_control_plane/models/getversioncountop.py +10 -27
  189. cribl_control_plane/models/getversiondiffop.py +12 -28
  190. cribl_control_plane/models/getversionfilesop.py +10 -28
  191. cribl_control_plane/models/getversionop.py +30 -0
  192. cribl_control_plane/models/getversionshowop.py +12 -28
  193. cribl_control_plane/models/getversionstatusop.py +7 -23
  194. cribl_control_plane/models/gitcommitsummary.py +3 -3
  195. cribl_control_plane/models/{routecloneconf.py → gitcountresult.py} +4 -4
  196. cribl_control_plane/models/gitdiffresult.py +16 -0
  197. cribl_control_plane/models/gitfilesresponse.py +7 -5
  198. cribl_control_plane/models/gitinfo.py +14 -3
  199. cribl_control_plane/models/gitlogresult.py +33 -0
  200. cribl_control_plane/models/gitrevertparams.py +3 -3
  201. cribl_control_plane/models/gitrevertresult.py +5 -5
  202. cribl_control_plane/models/gitshowresult.py +19 -0
  203. cribl_control_plane/models/gitstatusresult.py +0 -3
  204. cribl_control_plane/models/groupcreaterequest.py +172 -0
  205. cribl_control_plane/models/hbcriblinfo.py +42 -7
  206. cribl_control_plane/models/healthserverstatus.py +55 -0
  207. cribl_control_plane/models/heartbeatmetadata.py +6 -11
  208. cribl_control_plane/models/input.py +89 -81
  209. cribl_control_plane/models/inputappscope.py +131 -35
  210. cribl_control_plane/models/inputazureblob.py +62 -6
  211. cribl_control_plane/models/inputcloudflarehec.py +518 -0
  212. cribl_control_plane/models/inputcollection.py +49 -6
  213. cribl_control_plane/models/inputconfluentcloud.py +262 -22
  214. cribl_control_plane/models/inputcribl.py +52 -9
  215. cribl_control_plane/models/inputcriblhttp.py +124 -33
  216. cribl_control_plane/models/inputcribllakehttp.py +199 -29
  217. cribl_control_plane/models/inputcriblmetrics.py +53 -9
  218. cribl_control_plane/models/inputcribltcp.py +125 -27
  219. cribl_control_plane/models/inputcrowdstrike.py +99 -10
  220. cribl_control_plane/models/inputdatadogagent.py +101 -27
  221. cribl_control_plane/models/inputdatagen.py +47 -4
  222. cribl_control_plane/models/inputedgeprometheus.py +215 -58
  223. cribl_control_plane/models/inputelastic.py +170 -39
  224. cribl_control_plane/models/inputeventhub.py +212 -9
  225. cribl_control_plane/models/inputexec.py +59 -6
  226. cribl_control_plane/models/inputfile.py +83 -15
  227. cribl_control_plane/models/inputfirehose.py +100 -27
  228. cribl_control_plane/models/inputgooglepubsub.py +83 -15
  229. cribl_control_plane/models/{inputgrafana_union.py → inputgrafana.py} +261 -67
  230. cribl_control_plane/models/inputhttp.py +100 -27
  231. cribl_control_plane/models/inputhttpraw.py +100 -27
  232. cribl_control_plane/models/inputjournalfiles.py +51 -7
  233. cribl_control_plane/models/inputkafka.py +257 -19
  234. cribl_control_plane/models/inputkinesis.py +133 -17
  235. cribl_control_plane/models/inputkubeevents.py +52 -9
  236. cribl_control_plane/models/inputkubelogs.py +66 -13
  237. cribl_control_plane/models/inputkubemetrics.py +66 -13
  238. cribl_control_plane/models/inputloki.py +116 -30
  239. cribl_control_plane/models/inputmetrics.py +97 -24
  240. cribl_control_plane/models/inputmodeldriventelemetry.py +110 -29
  241. cribl_control_plane/models/inputmsk.py +148 -21
  242. cribl_control_plane/models/inputnetflow.py +50 -7
  243. cribl_control_plane/models/inputoffice365mgmt.py +115 -17
  244. cribl_control_plane/models/inputoffice365msgtrace.py +117 -19
  245. cribl_control_plane/models/inputoffice365service.py +117 -19
  246. cribl_control_plane/models/inputopentelemetry.py +146 -35
  247. cribl_control_plane/models/inputprometheus.py +196 -47
  248. cribl_control_plane/models/inputprometheusrw.py +117 -30
  249. cribl_control_plane/models/inputrawudp.py +50 -7
  250. cribl_control_plane/models/inputs3.py +85 -8
  251. cribl_control_plane/models/inputs3inventory.py +99 -10
  252. cribl_control_plane/models/inputsecuritylake.py +100 -10
  253. cribl_control_plane/models/inputsnmp.py +115 -24
  254. cribl_control_plane/models/inputsplunk.py +133 -31
  255. cribl_control_plane/models/inputsplunkhec.py +122 -32
  256. cribl_control_plane/models/inputsplunksearch.py +115 -18
  257. cribl_control_plane/models/inputsqs.py +102 -19
  258. cribl_control_plane/models/{inputsyslog_union.py → inputsyslog.py} +193 -51
  259. cribl_control_plane/models/inputsystemmetrics.py +207 -37
  260. cribl_control_plane/models/inputsystemstate.py +66 -13
  261. cribl_control_plane/models/inputtcp.py +125 -29
  262. cribl_control_plane/models/inputtcpjson.py +115 -29
  263. cribl_control_plane/models/inputwef.py +151 -22
  264. cribl_control_plane/models/inputwindowsmetrics.py +191 -38
  265. cribl_control_plane/models/inputwineventlogs.py +93 -11
  266. cribl_control_plane/models/inputwiz.py +176 -11
  267. cribl_control_plane/models/inputwizwebhook.py +466 -0
  268. cribl_control_plane/models/inputzscalerhec.py +122 -32
  269. cribl_control_plane/models/jobinfo.py +34 -0
  270. cribl_control_plane/models/jobstatus.py +48 -0
  271. cribl_control_plane/models/lakedatasetmetrics.py +17 -0
  272. cribl_control_plane/models/lakehouseconnectiontype.py +2 -1
  273. cribl_control_plane/models/listconfiggroupbyproductop.py +46 -0
  274. cribl_control_plane/models/listmasterworkerentryop.py +64 -0
  275. cribl_control_plane/models/logininfo.py +3 -3
  276. cribl_control_plane/models/masterworkerentry.py +20 -13
  277. cribl_control_plane/models/nodeactiveupgradestatus.py +2 -1
  278. cribl_control_plane/models/nodefailedupgradestatus.py +2 -1
  279. cribl_control_plane/models/nodeprovidedinfo.py +13 -11
  280. cribl_control_plane/models/nodeskippedupgradestatus.py +2 -1
  281. cribl_control_plane/models/nodeupgradestate.py +2 -1
  282. cribl_control_plane/models/nodeupgradestatus.py +51 -5
  283. cribl_control_plane/models/outpostnodeinfo.py +16 -0
  284. cribl_control_plane/models/output.py +103 -89
  285. cribl_control_plane/models/outputazureblob.py +174 -21
  286. cribl_control_plane/models/outputazuredataexplorer.py +517 -93
  287. cribl_control_plane/models/outputazureeventhub.py +318 -34
  288. cribl_control_plane/models/outputazurelogs.py +145 -26
  289. cribl_control_plane/models/outputchronicle.py +532 -0
  290. cribl_control_plane/models/outputclickhouse.py +208 -37
  291. cribl_control_plane/models/outputcloudflarer2.py +632 -0
  292. cribl_control_plane/models/outputcloudwatch.py +132 -26
  293. cribl_control_plane/models/outputconfluentcloud.py +387 -46
  294. cribl_control_plane/models/outputcriblhttp.py +203 -36
  295. cribl_control_plane/models/outputcribllake.py +161 -21
  296. cribl_control_plane/models/outputcribltcp.py +199 -34
  297. cribl_control_plane/models/outputcrowdstrikenextgensiem.py +176 -32
  298. cribl_control_plane/models/outputdatabricks.py +501 -0
  299. cribl_control_plane/models/outputdatadog.py +204 -36
  300. cribl_control_plane/models/outputdataset.py +186 -34
  301. cribl_control_plane/models/outputdevnull.py +5 -5
  302. cribl_control_plane/models/outputdiskspool.py +22 -7
  303. cribl_control_plane/models/outputdls3.py +238 -29
  304. cribl_control_plane/models/outputdynatracehttp.py +211 -37
  305. cribl_control_plane/models/outputdynatraceotlp.py +213 -39
  306. cribl_control_plane/models/outputelastic.py +199 -30
  307. cribl_control_plane/models/outputelasticcloud.py +174 -29
  308. cribl_control_plane/models/outputexabeam.py +99 -13
  309. cribl_control_plane/models/outputfilesystem.py +139 -14
  310. cribl_control_plane/models/outputgooglechronicle.py +216 -35
  311. cribl_control_plane/models/outputgooglecloudlogging.py +177 -34
  312. cribl_control_plane/models/outputgooglecloudstorage.py +220 -29
  313. cribl_control_plane/models/outputgooglepubsub.py +138 -51
  314. cribl_control_plane/models/outputgrafanacloud.py +386 -70
  315. cribl_control_plane/models/outputgraphite.py +131 -28
  316. cribl_control_plane/models/outputhoneycomb.py +145 -26
  317. cribl_control_plane/models/outputhumiohec.py +165 -31
  318. cribl_control_plane/models/outputinfluxdb.py +165 -28
  319. cribl_control_plane/models/outputkafka.py +378 -41
  320. cribl_control_plane/models/outputkinesis.py +168 -30
  321. cribl_control_plane/models/outputloki.py +171 -27
  322. cribl_control_plane/models/outputmicrosoftfabric.py +540 -0
  323. cribl_control_plane/models/outputminio.py +228 -28
  324. cribl_control_plane/models/outputmsk.py +270 -43
  325. cribl_control_plane/models/outputnewrelic.py +176 -34
  326. cribl_control_plane/models/outputnewrelicevents.py +166 -31
  327. cribl_control_plane/models/outputopentelemetry.py +240 -40
  328. cribl_control_plane/models/outputprometheus.py +145 -26
  329. cribl_control_plane/models/outputring.py +54 -13
  330. cribl_control_plane/models/outputs3.py +238 -31
  331. cribl_control_plane/models/outputsecuritylake.py +182 -21
  332. cribl_control_plane/models/outputsentinel.py +175 -32
  333. cribl_control_plane/models/outputsentineloneaisiem.py +184 -38
  334. cribl_control_plane/models/outputservicenow.py +226 -41
  335. cribl_control_plane/models/outputsignalfx.py +145 -26
  336. cribl_control_plane/models/outputsns.py +146 -28
  337. cribl_control_plane/models/outputsplunk.py +209 -39
  338. cribl_control_plane/models/outputsplunkhec.py +243 -31
  339. cribl_control_plane/models/outputsplunklb.py +266 -46
  340. cribl_control_plane/models/outputsqs.py +166 -36
  341. cribl_control_plane/models/outputstatsd.py +130 -28
  342. cribl_control_plane/models/outputstatsdext.py +131 -28
  343. cribl_control_plane/models/outputsumologic.py +146 -25
  344. cribl_control_plane/models/outputsyslog.py +323 -51
  345. cribl_control_plane/models/outputtcpjson.py +191 -37
  346. cribl_control_plane/models/outputwavefront.py +145 -26
  347. cribl_control_plane/models/outputwebhook.py +216 -38
  348. cribl_control_plane/models/outputxsiam.py +148 -31
  349. cribl_control_plane/models/packinfo.py +11 -8
  350. cribl_control_plane/models/packinstallinfo.py +14 -11
  351. cribl_control_plane/models/packrequestbody_union.py +140 -0
  352. cribl_control_plane/models/packupgraderequest.py +26 -0
  353. cribl_control_plane/models/piisettings_union.py +31 -0
  354. cribl_control_plane/models/productscore.py +10 -0
  355. cribl_control_plane/models/rbacresource.py +2 -1
  356. cribl_control_plane/models/resourcepolicy.py +15 -2
  357. cribl_control_plane/models/rollbacksettings_union.py +44 -0
  358. cribl_control_plane/models/routeconf.py +3 -4
  359. cribl_control_plane/models/routes.py +0 -24
  360. cribl_control_plane/models/runnablejob.py +27 -0
  361. cribl_control_plane/models/runnablejobcollection.py +628 -0
  362. cribl_control_plane/models/runnablejobexecutor.py +360 -0
  363. cribl_control_plane/models/runnablejobscheduledsearch.py +279 -0
  364. cribl_control_plane/models/schemeclientoauth.py +5 -0
  365. cribl_control_plane/models/snisettings_union.py +31 -0
  366. cribl_control_plane/models/systemsettingsconf.py +291 -0
  367. cribl_control_plane/models/tlssettings_union.py +43 -0
  368. cribl_control_plane/models/updateconfiggroupbyproductandidop.py +56 -0
  369. cribl_control_plane/models/updateconfiggroupdeploybyproductandidop.py +53 -0
  370. cribl_control_plane/models/updatecribllakedatasetbylakeidandidop.py +14 -29
  371. cribl_control_plane/models/updatehectokenrequest.py +7 -1
  372. cribl_control_plane/models/updateinputbyidop.py +5 -23
  373. cribl_control_plane/models/updateinputhectokenbyidandtokenop.py +5 -23
  374. cribl_control_plane/models/updateoutputbyidop.py +5 -23
  375. cribl_control_plane/models/updatepacksbyidop.py +12 -50
  376. cribl_control_plane/models/updatepacksop.py +12 -24
  377. cribl_control_plane/models/updatepipelinebyidop.py +5 -23
  378. cribl_control_plane/models/updateroutesbyidop.py +8 -27
  379. cribl_control_plane/models/upgradegroupsettings_union.py +43 -0
  380. cribl_control_plane/models/upgradepackageurls.py +20 -0
  381. cribl_control_plane/models/upgradesettings.py +38 -0
  382. cribl_control_plane/models/uploadpackresponse.py +13 -0
  383. cribl_control_plane/models/{appmode.py → workertypes.py} +2 -5
  384. cribl_control_plane/{workers_sdk.py → nodes.py} +102 -234
  385. cribl_control_plane/packs.py +385 -184
  386. cribl_control_plane/pipelines.py +116 -66
  387. cribl_control_plane/routes_sdk.py +102 -70
  388. cribl_control_plane/samples.py +407 -0
  389. cribl_control_plane/sdk.py +35 -25
  390. cribl_control_plane/settings.py +20 -0
  391. cribl_control_plane/sources.py +143 -545
  392. cribl_control_plane/statuses.py +195 -0
  393. cribl_control_plane/summaries.py +195 -0
  394. cribl_control_plane/system_sdk.py +20 -0
  395. cribl_control_plane/teams.py +36 -28
  396. cribl_control_plane/tokens.py +210 -0
  397. cribl_control_plane/utils/__init__.py +18 -5
  398. cribl_control_plane/utils/annotations.py +32 -8
  399. cribl_control_plane/utils/eventstreaming.py +10 -0
  400. cribl_control_plane/utils/forms.py +21 -10
  401. cribl_control_plane/utils/queryparams.py +14 -2
  402. cribl_control_plane/utils/retries.py +69 -5
  403. cribl_control_plane/utils/security.py +5 -0
  404. cribl_control_plane/utils/unmarshal_json_response.py +15 -1
  405. cribl_control_plane/versions.py +31 -0
  406. cribl_control_plane/{distributed.py → versions_configs.py} +29 -35
  407. cribl_control_plane-0.4.0b23.dist-info/METADATA +855 -0
  408. cribl_control_plane-0.4.0b23.dist-info/RECORD +450 -0
  409. {cribl_control_plane-0.0.21.dist-info → cribl_control_plane-0.4.0b23.dist-info}/WHEEL +1 -1
  410. cribl_control_plane-0.4.0b23.dist-info/licenses/LICENSE +201 -0
  411. cribl_control_plane/errors/healthstatus_error.py +0 -32
  412. cribl_control_plane/models/createinputop.py +0 -18238
  413. cribl_control_plane/models/createoutputop.py +0 -18437
  414. cribl_control_plane/models/createpipelineop.py +0 -24
  415. cribl_control_plane/models/createproductsgroupsbyproductop.py +0 -54
  416. cribl_control_plane/models/createversionpushop.py +0 -23
  417. cribl_control_plane/models/createversionsyncop.py +0 -23
  418. cribl_control_plane/models/deletegroupsbyidop.py +0 -37
  419. cribl_control_plane/models/getgroupsaclbyidop.py +0 -63
  420. cribl_control_plane/models/getgroupsbyidop.py +0 -49
  421. cribl_control_plane/models/getgroupsconfigversionbyidop.py +0 -36
  422. cribl_control_plane/models/getproductsgroupsaclteamsbyproductandidop.py +0 -78
  423. cribl_control_plane/models/getproductsgroupsbyproductop.py +0 -58
  424. cribl_control_plane/models/getsummaryworkersop.py +0 -39
  425. cribl_control_plane/models/getversioncurrentbranchop.py +0 -23
  426. cribl_control_plane/models/getworkersop.py +0 -82
  427. cribl_control_plane/models/healthstatus.py +0 -33
  428. cribl_control_plane/models/packrequestbody.py +0 -75
  429. cribl_control_plane/models/restartresponse.py +0 -26
  430. cribl_control_plane/models/routesroute_input.py +0 -67
  431. cribl_control_plane/models/updategroupsbyidop.py +0 -48
  432. cribl_control_plane/models/updategroupsdeploybyidop.py +0 -46
  433. cribl_control_plane/models/updateworkersrestartop.py +0 -24
  434. cribl_control_plane/versioning.py +0 -2309
  435. cribl_control_plane-0.0.21.dist-info/METADATA +0 -561
  436. cribl_control_plane-0.0.21.dist-info/RECORD +0 -301
@@ -1,9 +1,13 @@
1
1
  """Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT."""
2
2
 
3
3
  from __future__ import annotations
4
+ from cribl_control_plane import models, utils
4
5
  from cribl_control_plane.types import BaseModel
6
+ from cribl_control_plane.utils import validate_open_enum
5
7
  from enum import Enum
6
8
  import pydantic
9
+ from pydantic import field_serializer
10
+ from pydantic.functional_validators import PlainValidator
7
11
  from typing import List, Optional
8
12
  from typing_extensions import Annotated, NotRequired, TypedDict
9
13
 
@@ -12,29 +16,41 @@ class OutputMskType(str, Enum):
12
16
  MSK = "msk"
13
17
 
14
18
 
15
- class OutputMskAcknowledgments(int, Enum):
19
+ class OutputMskAcknowledgments(int, Enum, metaclass=utils.OpenEnumMeta):
16
20
  r"""Control the number of required acknowledgments."""
17
21
 
22
+ # Leader
18
23
  ONE = 1
24
+ # None
19
25
  ZERO = 0
26
+ # All
20
27
  MINUS_1 = -1
21
28
 
22
29
 
23
- class OutputMskRecordDataFormat(str, Enum):
30
+ class OutputMskRecordDataFormat(str, Enum, metaclass=utils.OpenEnumMeta):
24
31
  r"""Format to use to serialize events before writing to Kafka."""
25
32
 
33
+ # JSON
26
34
  JSON = "json"
35
+ # Field _raw
27
36
  RAW = "raw"
37
+ # Protobuf
28
38
  PROTOBUF = "protobuf"
29
39
 
30
40
 
31
- class OutputMskCompression(str, Enum):
41
+ class OutputMskCompression(str, Enum, metaclass=utils.OpenEnumMeta):
32
42
  r"""Codec to use to compress the data before sending to Kafka"""
33
43
 
44
+ # None
34
45
  NONE = "none"
46
+ # Gzip
35
47
  GZIP = "gzip"
48
+ # Snappy
36
49
  SNAPPY = "snappy"
50
+ # LZ4
37
51
  LZ4 = "lz4"
52
+ # ZSTD
53
+ ZSTD = "zstd"
38
54
 
39
55
 
40
56
  class OutputMskAuthTypedDict(TypedDict):
@@ -56,14 +72,18 @@ class OutputMskAuth(BaseModel):
56
72
  r"""Select or create a secret that references your credentials"""
57
73
 
58
74
 
59
- class OutputMskKafkaSchemaRegistryMinimumTLSVersion(str, Enum):
75
+ class OutputMskKafkaSchemaRegistryMinimumTLSVersion(
76
+ str, Enum, metaclass=utils.OpenEnumMeta
77
+ ):
60
78
  TL_SV1 = "TLSv1"
61
79
  TL_SV1_1 = "TLSv1.1"
62
80
  TL_SV1_2 = "TLSv1.2"
63
81
  TL_SV1_3 = "TLSv1.3"
64
82
 
65
83
 
66
- class OutputMskKafkaSchemaRegistryMaximumTLSVersion(str, Enum):
84
+ class OutputMskKafkaSchemaRegistryMaximumTLSVersion(
85
+ str, Enum, metaclass=utils.OpenEnumMeta
86
+ ):
67
87
  TL_SV1 = "TLSv1"
68
88
  TL_SV1_1 = "TLSv1.1"
69
89
  TL_SV1_2 = "TLSv1.2"
@@ -123,15 +143,39 @@ class OutputMskKafkaSchemaRegistryTLSSettingsClientSide(BaseModel):
123
143
  r"""Passphrase to use to decrypt private key"""
124
144
 
125
145
  min_version: Annotated[
126
- Optional[OutputMskKafkaSchemaRegistryMinimumTLSVersion],
146
+ Annotated[
147
+ Optional[OutputMskKafkaSchemaRegistryMinimumTLSVersion],
148
+ PlainValidator(validate_open_enum(False)),
149
+ ],
127
150
  pydantic.Field(alias="minVersion"),
128
151
  ] = None
129
152
 
130
153
  max_version: Annotated[
131
- Optional[OutputMskKafkaSchemaRegistryMaximumTLSVersion],
154
+ Annotated[
155
+ Optional[OutputMskKafkaSchemaRegistryMaximumTLSVersion],
156
+ PlainValidator(validate_open_enum(False)),
157
+ ],
132
158
  pydantic.Field(alias="maxVersion"),
133
159
  ] = None
134
160
 
161
+ @field_serializer("min_version")
162
+ def serialize_min_version(self, value):
163
+ if isinstance(value, str):
164
+ try:
165
+ return models.OutputMskKafkaSchemaRegistryMinimumTLSVersion(value)
166
+ except ValueError:
167
+ return value
168
+ return value
169
+
170
+ @field_serializer("max_version")
171
+ def serialize_max_version(self, value):
172
+ if isinstance(value, str):
173
+ try:
174
+ return models.OutputMskKafkaSchemaRegistryMaximumTLSVersion(value)
175
+ except ValueError:
176
+ return value
177
+ return value
178
+
135
179
 
136
180
  class OutputMskKafkaSchemaRegistryAuthenticationTypedDict(TypedDict):
137
181
  disabled: NotRequired[bool]
@@ -189,29 +233,32 @@ class OutputMskKafkaSchemaRegistryAuthentication(BaseModel):
189
233
  r"""Used when __valueSchemaIdOut is not present, to transform _raw, leave blank if value transformation is not required by default."""
190
234
 
191
235
 
192
- class OutputMskAuthenticationMethod(str, Enum):
236
+ class OutputMskAuthenticationMethod(str, Enum, metaclass=utils.OpenEnumMeta):
193
237
  r"""AWS authentication method. Choose Auto to use IAM roles."""
194
238
 
239
+ # Auto
195
240
  AUTO = "auto"
241
+ # Manual
196
242
  MANUAL = "manual"
243
+ # Secret Key pair
197
244
  SECRET = "secret"
198
245
 
199
246
 
200
- class OutputMskSignatureVersion(str, Enum):
247
+ class OutputMskSignatureVersion(str, Enum, metaclass=utils.OpenEnumMeta):
201
248
  r"""Signature version to use for signing MSK cluster requests"""
202
249
 
203
250
  V2 = "v2"
204
251
  V4 = "v4"
205
252
 
206
253
 
207
- class OutputMskMinimumTLSVersion(str, Enum):
254
+ class OutputMskMinimumTLSVersion(str, Enum, metaclass=utils.OpenEnumMeta):
208
255
  TL_SV1 = "TLSv1"
209
256
  TL_SV1_1 = "TLSv1.1"
210
257
  TL_SV1_2 = "TLSv1.2"
211
258
  TL_SV1_3 = "TLSv1.3"
212
259
 
213
260
 
214
- class OutputMskMaximumTLSVersion(str, Enum):
261
+ class OutputMskMaximumTLSVersion(str, Enum, metaclass=utils.OpenEnumMeta):
215
262
  TL_SV1 = "TLSv1"
216
263
  TL_SV1_1 = "TLSv1.1"
217
264
  TL_SV1_2 = "TLSv1.2"
@@ -271,44 +318,80 @@ class OutputMskTLSSettingsClientSide(BaseModel):
271
318
  r"""Passphrase to use to decrypt private key"""
272
319
 
273
320
  min_version: Annotated[
274
- Optional[OutputMskMinimumTLSVersion], pydantic.Field(alias="minVersion")
321
+ Annotated[
322
+ Optional[OutputMskMinimumTLSVersion],
323
+ PlainValidator(validate_open_enum(False)),
324
+ ],
325
+ pydantic.Field(alias="minVersion"),
275
326
  ] = None
276
327
 
277
328
  max_version: Annotated[
278
- Optional[OutputMskMaximumTLSVersion], pydantic.Field(alias="maxVersion")
329
+ Annotated[
330
+ Optional[OutputMskMaximumTLSVersion],
331
+ PlainValidator(validate_open_enum(False)),
332
+ ],
333
+ pydantic.Field(alias="maxVersion"),
279
334
  ] = None
280
335
 
281
-
282
- class OutputMskBackpressureBehavior(str, Enum):
336
+ @field_serializer("min_version")
337
+ def serialize_min_version(self, value):
338
+ if isinstance(value, str):
339
+ try:
340
+ return models.OutputMskMinimumTLSVersion(value)
341
+ except ValueError:
342
+ return value
343
+ return value
344
+
345
+ @field_serializer("max_version")
346
+ def serialize_max_version(self, value):
347
+ if isinstance(value, str):
348
+ try:
349
+ return models.OutputMskMaximumTLSVersion(value)
350
+ except ValueError:
351
+ return value
352
+ return value
353
+
354
+
355
+ class OutputMskBackpressureBehavior(str, Enum, metaclass=utils.OpenEnumMeta):
283
356
  r"""How to handle events when all receivers are exerting backpressure"""
284
357
 
358
+ # Block
285
359
  BLOCK = "block"
360
+ # Drop
286
361
  DROP = "drop"
362
+ # Persistent Queue
287
363
  QUEUE = "queue"
288
364
 
289
365
 
290
- class OutputMskPqCompressCompression(str, Enum):
366
+ class OutputMskMode(str, Enum, metaclass=utils.OpenEnumMeta):
367
+ r"""In Error mode, PQ writes events to the filesystem if the Destination is unavailable. In Backpressure mode, PQ writes events to the filesystem when it detects backpressure from the Destination. In Always On mode, PQ always writes events to the filesystem."""
368
+
369
+ # Error
370
+ ERROR = "error"
371
+ # Backpressure
372
+ ALWAYS = "always"
373
+ # Always On
374
+ BACKPRESSURE = "backpressure"
375
+
376
+
377
+ class OutputMskPqCompressCompression(str, Enum, metaclass=utils.OpenEnumMeta):
291
378
  r"""Codec to use to compress the persisted data"""
292
379
 
380
+ # None
293
381
  NONE = "none"
382
+ # Gzip
294
383
  GZIP = "gzip"
295
384
 
296
385
 
297
- class OutputMskQueueFullBehavior(str, Enum):
386
+ class OutputMskQueueFullBehavior(str, Enum, metaclass=utils.OpenEnumMeta):
298
387
  r"""How to handle events when the queue is exerting backpressure (full capacity or low disk). 'Block' is the same behavior as non-PQ blocking. 'Drop new data' throws away incoming data, while leaving the contents of the PQ unchanged."""
299
388
 
389
+ # Block
300
390
  BLOCK = "block"
391
+ # Drop new data
301
392
  DROP = "drop"
302
393
 
303
394
 
304
- class OutputMskMode(str, Enum):
305
- r"""In Error mode, PQ writes events to the filesystem if the Destination is unavailable. In Backpressure mode, PQ writes events to the filesystem when it detects backpressure from the Destination. In Always On mode, PQ always writes events to the filesystem."""
306
-
307
- ERROR = "error"
308
- BACKPRESSURE = "backpressure"
309
- ALWAYS = "always"
310
-
311
-
312
395
  class OutputMskPqControlsTypedDict(TypedDict):
313
396
  pass
314
397
 
@@ -318,6 +401,7 @@ class OutputMskPqControls(BaseModel):
318
401
 
319
402
 
320
403
  class OutputMskTypedDict(TypedDict):
404
+ type: OutputMskType
321
405
  brokers: List[str]
322
406
  r"""Enter each Kafka bootstrap server you want to use. Specify hostname and port, e.g., mykafkabroker:9092, or just hostname, in which case @{product} will assign port 9092."""
323
407
  topic: str
@@ -326,7 +410,6 @@ class OutputMskTypedDict(TypedDict):
326
410
  r"""Region where the MSK cluster is located"""
327
411
  id: NotRequired[str]
328
412
  r"""Unique ID for this output"""
329
- type: NotRequired[OutputMskType]
330
413
  pipeline: NotRequired[str]
331
414
  r"""Pipeline to process data before sending out to this output"""
332
415
  system_fields: NotRequired[List[str]]
@@ -394,6 +477,18 @@ class OutputMskTypedDict(TypedDict):
394
477
  r"""Select or create a stored secret that references your access key and secret key"""
395
478
  protobuf_library_id: NotRequired[str]
396
479
  r"""Select a set of Protobuf definitions for the events you want to send"""
480
+ protobuf_encoding_id: NotRequired[str]
481
+ r"""Select the type of object you want the Protobuf definitions to use for event encoding"""
482
+ pq_strict_ordering: NotRequired[bool]
483
+ r"""Use FIFO (first in, first out) processing. Disable to forward new events to receivers before queue is flushed."""
484
+ pq_rate_per_sec: NotRequired[float]
485
+ r"""Throttling rate (in events per second) to impose while writing to Destinations from PQ. Defaults to 0, which disables throttling."""
486
+ pq_mode: NotRequired[OutputMskMode]
487
+ r"""In Error mode, PQ writes events to the filesystem if the Destination is unavailable. In Backpressure mode, PQ writes events to the filesystem when it detects backpressure from the Destination. In Always On mode, PQ always writes events to the filesystem."""
488
+ pq_max_buffer_size: NotRequired[float]
489
+ r"""The maximum number of events to hold in memory before writing the events to disk"""
490
+ pq_max_backpressure_sec: NotRequired[float]
491
+ r"""How long (in seconds) to wait for backpressure to resolve before engaging the queue"""
397
492
  pq_max_file_size: NotRequired[str]
398
493
  r"""The maximum size to store in each queue file before closing and optionally compressing (KB, MB, etc.)"""
399
494
  pq_max_size: NotRequired[str]
@@ -404,12 +499,12 @@ class OutputMskTypedDict(TypedDict):
404
499
  r"""Codec to use to compress the persisted data"""
405
500
  pq_on_backpressure: NotRequired[OutputMskQueueFullBehavior]
406
501
  r"""How to handle events when the queue is exerting backpressure (full capacity or low disk). 'Block' is the same behavior as non-PQ blocking. 'Drop new data' throws away incoming data, while leaving the contents of the PQ unchanged."""
407
- pq_mode: NotRequired[OutputMskMode]
408
- r"""In Error mode, PQ writes events to the filesystem if the Destination is unavailable. In Backpressure mode, PQ writes events to the filesystem when it detects backpressure from the Destination. In Always On mode, PQ always writes events to the filesystem."""
409
502
  pq_controls: NotRequired[OutputMskPqControlsTypedDict]
410
503
 
411
504
 
412
505
  class OutputMsk(BaseModel):
506
+ type: OutputMskType
507
+
413
508
  brokers: List[str]
414
509
  r"""Enter each Kafka bootstrap server you want to use. Specify hostname and port, e.g., mykafkabroker:9092, or just hostname, in which case @{product} will assign port 9092."""
415
510
 
@@ -422,8 +517,6 @@ class OutputMsk(BaseModel):
422
517
  id: Optional[str] = None
423
518
  r"""Unique ID for this output"""
424
519
 
425
- type: Optional[OutputMskType] = None
426
-
427
520
  pipeline: Optional[str] = None
428
521
  r"""Pipeline to process data before sending out to this output"""
429
522
 
@@ -438,15 +531,23 @@ class OutputMsk(BaseModel):
438
531
  streamtags: Optional[List[str]] = None
439
532
  r"""Tags for filtering and grouping in @{product}"""
440
533
 
441
- ack: Optional[OutputMskAcknowledgments] = OutputMskAcknowledgments.ONE
534
+ ack: Annotated[
535
+ Optional[OutputMskAcknowledgments], PlainValidator(validate_open_enum(True))
536
+ ] = OutputMskAcknowledgments.ONE
442
537
  r"""Control the number of required acknowledgments."""
443
538
 
444
539
  format_: Annotated[
445
- Optional[OutputMskRecordDataFormat], pydantic.Field(alias="format")
540
+ Annotated[
541
+ Optional[OutputMskRecordDataFormat],
542
+ PlainValidator(validate_open_enum(False)),
543
+ ],
544
+ pydantic.Field(alias="format"),
446
545
  ] = OutputMskRecordDataFormat.JSON
447
546
  r"""Format to use to serialize events before writing to Kafka."""
448
547
 
449
- compression: Optional[OutputMskCompression] = OutputMskCompression.GZIP
548
+ compression: Annotated[
549
+ Optional[OutputMskCompression], PlainValidator(validate_open_enum(False))
550
+ ] = OutputMskCompression.GZIP
450
551
  r"""Codec to use to compress the data before sending to Kafka"""
451
552
 
452
553
  max_record_size_kb: Annotated[
@@ -504,7 +605,10 @@ class OutputMsk(BaseModel):
504
605
  r"""Specifies a time window during which @{product} can reauthenticate if needed. Creates the window measuring backward from the moment when credentials are set to expire."""
505
606
 
506
607
  aws_authentication_method: Annotated[
507
- Optional[OutputMskAuthenticationMethod],
608
+ Annotated[
609
+ Optional[OutputMskAuthenticationMethod],
610
+ PlainValidator(validate_open_enum(False)),
611
+ ],
508
612
  pydantic.Field(alias="awsAuthenticationMethod"),
509
613
  ] = OutputMskAuthenticationMethod.AUTO
510
614
  r"""AWS authentication method. Choose Auto to use IAM roles."""
@@ -517,7 +621,11 @@ class OutputMsk(BaseModel):
517
621
  r"""MSK cluster service endpoint. If empty, defaults to the AWS Region-specific endpoint. Otherwise, it must point to MSK cluster-compatible endpoint."""
518
622
 
519
623
  signature_version: Annotated[
520
- Optional[OutputMskSignatureVersion], pydantic.Field(alias="signatureVersion")
624
+ Annotated[
625
+ Optional[OutputMskSignatureVersion],
626
+ PlainValidator(validate_open_enum(False)),
627
+ ],
628
+ pydantic.Field(alias="signatureVersion"),
521
629
  ] = OutputMskSignatureVersion.V4
522
630
  r"""Signature version to use for signing MSK cluster requests"""
523
631
 
@@ -554,7 +662,11 @@ class OutputMsk(BaseModel):
554
662
  tls: Optional[OutputMskTLSSettingsClientSide] = None
555
663
 
556
664
  on_backpressure: Annotated[
557
- Optional[OutputMskBackpressureBehavior], pydantic.Field(alias="onBackpressure")
665
+ Annotated[
666
+ Optional[OutputMskBackpressureBehavior],
667
+ PlainValidator(validate_open_enum(False)),
668
+ ],
669
+ pydantic.Field(alias="onBackpressure"),
558
670
  ] = OutputMskBackpressureBehavior.BLOCK
559
671
  r"""How to handle events when all receivers are exerting backpressure"""
560
672
 
@@ -570,6 +682,37 @@ class OutputMsk(BaseModel):
570
682
  ] = None
571
683
  r"""Select a set of Protobuf definitions for the events you want to send"""
572
684
 
685
+ protobuf_encoding_id: Annotated[
686
+ Optional[str], pydantic.Field(alias="protobufEncodingId")
687
+ ] = None
688
+ r"""Select the type of object you want the Protobuf definitions to use for event encoding"""
689
+
690
+ pq_strict_ordering: Annotated[
691
+ Optional[bool], pydantic.Field(alias="pqStrictOrdering")
692
+ ] = True
693
+ r"""Use FIFO (first in, first out) processing. Disable to forward new events to receivers before queue is flushed."""
694
+
695
+ pq_rate_per_sec: Annotated[
696
+ Optional[float], pydantic.Field(alias="pqRatePerSec")
697
+ ] = 0
698
+ r"""Throttling rate (in events per second) to impose while writing to Destinations from PQ. Defaults to 0, which disables throttling."""
699
+
700
+ pq_mode: Annotated[
701
+ Annotated[Optional[OutputMskMode], PlainValidator(validate_open_enum(False))],
702
+ pydantic.Field(alias="pqMode"),
703
+ ] = OutputMskMode.ERROR
704
+ r"""In Error mode, PQ writes events to the filesystem if the Destination is unavailable. In Backpressure mode, PQ writes events to the filesystem when it detects backpressure from the Destination. In Always On mode, PQ always writes events to the filesystem."""
705
+
706
+ pq_max_buffer_size: Annotated[
707
+ Optional[float], pydantic.Field(alias="pqMaxBufferSize")
708
+ ] = 42
709
+ r"""The maximum number of events to hold in memory before writing the events to disk"""
710
+
711
+ pq_max_backpressure_sec: Annotated[
712
+ Optional[float], pydantic.Field(alias="pqMaxBackpressureSec")
713
+ ] = 30
714
+ r"""How long (in seconds) to wait for backpressure to resolve before engaging the queue"""
715
+
573
716
  pq_max_file_size: Annotated[
574
717
  Optional[str], pydantic.Field(alias="pqMaxFileSize")
575
718
  ] = "1 MB"
@@ -584,20 +727,104 @@ class OutputMsk(BaseModel):
584
727
  r"""The location for the persistent queue files. To this field's value, the system will append: /<worker-id>/<output-id>."""
585
728
 
586
729
  pq_compress: Annotated[
587
- Optional[OutputMskPqCompressCompression], pydantic.Field(alias="pqCompress")
730
+ Annotated[
731
+ Optional[OutputMskPqCompressCompression],
732
+ PlainValidator(validate_open_enum(False)),
733
+ ],
734
+ pydantic.Field(alias="pqCompress"),
588
735
  ] = OutputMskPqCompressCompression.NONE
589
736
  r"""Codec to use to compress the persisted data"""
590
737
 
591
738
  pq_on_backpressure: Annotated[
592
- Optional[OutputMskQueueFullBehavior], pydantic.Field(alias="pqOnBackpressure")
739
+ Annotated[
740
+ Optional[OutputMskQueueFullBehavior],
741
+ PlainValidator(validate_open_enum(False)),
742
+ ],
743
+ pydantic.Field(alias="pqOnBackpressure"),
593
744
  ] = OutputMskQueueFullBehavior.BLOCK
594
745
  r"""How to handle events when the queue is exerting backpressure (full capacity or low disk). 'Block' is the same behavior as non-PQ blocking. 'Drop new data' throws away incoming data, while leaving the contents of the PQ unchanged."""
595
746
 
596
- pq_mode: Annotated[Optional[OutputMskMode], pydantic.Field(alias="pqMode")] = (
597
- OutputMskMode.ERROR
598
- )
599
- r"""In Error mode, PQ writes events to the filesystem if the Destination is unavailable. In Backpressure mode, PQ writes events to the filesystem when it detects backpressure from the Destination. In Always On mode, PQ always writes events to the filesystem."""
600
-
601
747
  pq_controls: Annotated[
602
748
  Optional[OutputMskPqControls], pydantic.Field(alias="pqControls")
603
749
  ] = None
750
+
751
+ @field_serializer("ack")
752
+ def serialize_ack(self, value):
753
+ if isinstance(value, str):
754
+ try:
755
+ return models.OutputMskAcknowledgments(value)
756
+ except ValueError:
757
+ return value
758
+ return value
759
+
760
+ @field_serializer("format_")
761
+ def serialize_format_(self, value):
762
+ if isinstance(value, str):
763
+ try:
764
+ return models.OutputMskRecordDataFormat(value)
765
+ except ValueError:
766
+ return value
767
+ return value
768
+
769
+ @field_serializer("compression")
770
+ def serialize_compression(self, value):
771
+ if isinstance(value, str):
772
+ try:
773
+ return models.OutputMskCompression(value)
774
+ except ValueError:
775
+ return value
776
+ return value
777
+
778
+ @field_serializer("aws_authentication_method")
779
+ def serialize_aws_authentication_method(self, value):
780
+ if isinstance(value, str):
781
+ try:
782
+ return models.OutputMskAuthenticationMethod(value)
783
+ except ValueError:
784
+ return value
785
+ return value
786
+
787
+ @field_serializer("signature_version")
788
+ def serialize_signature_version(self, value):
789
+ if isinstance(value, str):
790
+ try:
791
+ return models.OutputMskSignatureVersion(value)
792
+ except ValueError:
793
+ return value
794
+ return value
795
+
796
+ @field_serializer("on_backpressure")
797
+ def serialize_on_backpressure(self, value):
798
+ if isinstance(value, str):
799
+ try:
800
+ return models.OutputMskBackpressureBehavior(value)
801
+ except ValueError:
802
+ return value
803
+ return value
804
+
805
+ @field_serializer("pq_mode")
806
+ def serialize_pq_mode(self, value):
807
+ if isinstance(value, str):
808
+ try:
809
+ return models.OutputMskMode(value)
810
+ except ValueError:
811
+ return value
812
+ return value
813
+
814
+ @field_serializer("pq_compress")
815
+ def serialize_pq_compress(self, value):
816
+ if isinstance(value, str):
817
+ try:
818
+ return models.OutputMskPqCompressCompression(value)
819
+ except ValueError:
820
+ return value
821
+ return value
822
+
823
+ @field_serializer("pq_on_backpressure")
824
+ def serialize_pq_on_backpressure(self, value):
825
+ if isinstance(value, str):
826
+ try:
827
+ return models.OutputMskQueueFullBehavior(value)
828
+ except ValueError:
829
+ return value
830
+ return value