flock-core 0.1.1__py3-none-any.whl → 0.2.1__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 flock-core might be problematic. Click here for more details.

Files changed (405) hide show
  1. flock/__init__.py +1 -4
  2. flock/agents/__init__.py +0 -3
  3. flock/agents/batch_agent.py +140 -175
  4. flock/agents/loop_agent.py +117 -178
  5. flock/agents/trigger_agent.py +113 -191
  6. flock/agents/user_agent.py +145 -230
  7. flock/core/__init__.py +1 -7
  8. flock/core/context/context.py +211 -0
  9. flock/core/context/context_manager.py +34 -0
  10. flock/core/{context_vars.py → context/context_vars.py} +8 -6
  11. flock/core/execution/local_executor.py +27 -0
  12. flock/core/execution/temporal_executor.py +40 -0
  13. flock/core/flock.py +199 -208
  14. flock/core/flock_agent.py +492 -0
  15. flock/core/logging/__init__.py +2 -18
  16. flock/core/logging/formatters/base_formatter.py +36 -0
  17. flock/core/logging/formatters/formatter_factory.py +38 -0
  18. flock/core/logging/formatters/pprint_formatter.py +18 -0
  19. flock/core/logging/formatters/rich_formatters.py +132 -0
  20. flock/core/logging/formatters/theme_builder.py +480 -0
  21. flock/core/logging/formatters/themed_formatter.py +442 -0
  22. flock/core/logging/logging.py +123 -0
  23. flock/core/mixin/dspy_integration.py +171 -0
  24. flock/core/mixin/prompt_parser.py +125 -0
  25. flock/core/registry/agent_registry.py +103 -0
  26. flock/core/tools/basic_tools.py +273 -98
  27. flock/core/tools/dev_tools/github.py +161 -0
  28. flock/core/util/cli_helper.py +21 -0
  29. flock/core/util/input_resolver.py +156 -0
  30. flock/core/util/serializable.py +93 -0
  31. flock/themes/3024-day.toml +39 -0
  32. flock/themes/3024-night.toml +77 -0
  33. flock/themes/aardvark-blue.toml +77 -0
  34. flock/themes/abernathy.toml +77 -0
  35. flock/themes/adventure.toml +77 -0
  36. flock/themes/adventuretime.toml +77 -0
  37. flock/themes/afterglow.toml +77 -0
  38. flock/themes/alabaster.toml +77 -0
  39. flock/themes/alienblood.toml +77 -0
  40. flock/themes/andromeda.toml +77 -0
  41. flock/themes/apple-classic.toml +77 -0
  42. flock/themes/apple-system-colors.toml +77 -0
  43. flock/themes/arcoiris.toml +77 -0
  44. flock/themes/argonaut copy.toml +77 -0
  45. flock/themes/argonaut.toml +39 -0
  46. flock/themes/arthur.toml +77 -0
  47. flock/themes/ateliersulphurpool.toml +77 -0
  48. flock/themes/atom.toml +38 -0
  49. flock/themes/atom_test.toml +65 -0
  50. flock/themes/atomonelight.toml +77 -0
  51. flock/themes/aurora.toml +77 -0
  52. flock/themes/ayu copy.toml +77 -0
  53. flock/themes/ayu-light.toml +77 -0
  54. flock/themes/ayu-mirage.toml +77 -0
  55. flock/themes/ayu.toml +39 -0
  56. flock/themes/banana-blueberry.toml +77 -0
  57. flock/themes/batman.toml +77 -0
  58. flock/themes/belafonte-day.toml +77 -0
  59. flock/themes/belafonte-night.toml +77 -0
  60. flock/themes/birdsofparadise.toml +77 -0
  61. flock/themes/blazer.toml +77 -0
  62. flock/themes/blue-matrix.toml +77 -0
  63. flock/themes/blueberrypie.toml +77 -0
  64. flock/themes/bluedolphin.toml +77 -0
  65. flock/themes/blulocodark.toml +77 -0
  66. flock/themes/blulocolight.toml +77 -0
  67. flock/themes/borland.toml +77 -0
  68. flock/themes/breeze.toml +77 -0
  69. flock/themes/bright-lights.toml +77 -0
  70. flock/themes/broadcast.toml +77 -0
  71. flock/themes/brogrammer.toml +77 -0
  72. flock/themes/builtin-dark.toml +77 -0
  73. flock/themes/builtin-light.toml +77 -0
  74. flock/themes/builtin-pastel-dark.toml +77 -0
  75. flock/themes/builtin-solarized-dark.toml +77 -0
  76. flock/themes/builtin-solarized-light.toml +77 -0
  77. flock/themes/builtin-tango-dark.toml +77 -0
  78. flock/themes/builtin-tango-light.toml +77 -0
  79. flock/themes/c64.toml +77 -0
  80. flock/themes/calamity.toml +77 -0
  81. flock/themes/catppuccin-frappe.toml +77 -0
  82. flock/themes/catppuccin-latte.toml +77 -0
  83. flock/themes/catppuccin-macchiato.toml +77 -0
  84. flock/themes/catppuccin-mocha.toml +77 -0
  85. flock/themes/cga.toml +77 -0
  86. flock/themes/chalk.toml +77 -0
  87. flock/themes/chalkboard.toml +77 -0
  88. flock/themes/challengerdeep.toml +77 -0
  89. flock/themes/chester.toml +77 -0
  90. flock/themes/ciapre.toml +77 -0
  91. flock/themes/clrs.toml +77 -0
  92. flock/themes/cobalt-neon.toml +77 -0
  93. flock/themes/cobalt2.toml +77 -0
  94. flock/themes/coffee-theme.toml +77 -0
  95. flock/themes/crayonponyfish.toml +77 -0
  96. flock/themes/cutiepro.toml +77 -0
  97. flock/themes/cyberdyne.toml +77 -0
  98. flock/themes/cyberpunk.toml +77 -0
  99. flock/themes/cyberpunkscarletprotocol.toml +77 -0
  100. flock/themes/dark+.toml +77 -0
  101. flock/themes/dark-pastel.toml +77 -0
  102. flock/themes/darkermatrix.toml +77 -0
  103. flock/themes/darkmatrix.toml +77 -0
  104. flock/themes/darkside.toml +77 -0
  105. flock/themes/dayfox.toml +77 -0
  106. flock/themes/deep.toml +77 -0
  107. flock/themes/desert.toml +77 -0
  108. flock/themes/dimidium.toml +77 -0
  109. flock/themes/dimmedmonokai.toml +77 -0
  110. flock/themes/django.toml +77 -0
  111. flock/themes/djangorebornagain.toml +77 -0
  112. flock/themes/djangosmooth.toml +77 -0
  113. flock/themes/doom-peacock.toml +77 -0
  114. flock/themes/doomone.toml +77 -0
  115. flock/themes/dotgov.toml +77 -0
  116. flock/themes/dracula+.toml +77 -0
  117. flock/themes/dracula.toml +77 -0
  118. flock/themes/duckbones.toml +77 -0
  119. flock/themes/duotone-dark.toml +77 -0
  120. flock/themes/earthsong.toml +77 -0
  121. flock/themes/elemental.toml +77 -0
  122. flock/themes/elementary.toml +77 -0
  123. flock/themes/encom.toml +77 -0
  124. flock/themes/espresso-libre.toml +77 -0
  125. flock/themes/espresso.toml +77 -0
  126. flock/themes/everblush.toml +77 -0
  127. flock/themes/fahrenheit.toml +77 -0
  128. flock/themes/fairyfloss.toml +77 -0
  129. flock/themes/farmhouse-dark.toml +77 -0
  130. flock/themes/farmhouse-light.toml +77 -0
  131. flock/themes/fideloper.toml +77 -0
  132. flock/themes/firefly-traditional.toml +77 -0
  133. flock/themes/firefoxdev.toml +77 -0
  134. flock/themes/firewatch.toml +77 -0
  135. flock/themes/fishtank.toml +77 -0
  136. flock/themes/flat.toml +77 -0
  137. flock/themes/flatland.toml +77 -0
  138. flock/themes/flexoki-dark.toml +77 -0
  139. flock/themes/flexoki-light.toml +77 -0
  140. flock/themes/floraverse.toml +77 -0
  141. flock/themes/forestblue.toml +77 -0
  142. flock/themes/framer.toml +77 -0
  143. flock/themes/frontenddelight.toml +77 -0
  144. flock/themes/funforrest.toml +77 -0
  145. flock/themes/galaxy.toml +77 -0
  146. flock/themes/galizur.toml +77 -0
  147. flock/themes/github-dark.toml +77 -0
  148. flock/themes/github.toml +77 -0
  149. flock/themes/glacier.toml +77 -0
  150. flock/themes/grape.toml +77 -0
  151. flock/themes/grass.toml +77 -0
  152. flock/themes/grey-green.toml +77 -0
  153. flock/themes/gruber-darker.toml +77 -0
  154. flock/themes/gruvboxdark.toml +77 -0
  155. flock/themes/gruvboxdarkhard.toml +77 -0
  156. flock/themes/gruvboxlight.toml +77 -0
  157. flock/themes/guezwhoz.toml +77 -0
  158. flock/themes/hacktober.toml +77 -0
  159. flock/themes/hardcore.toml +77 -0
  160. flock/themes/harper.toml +77 -0
  161. flock/themes/hax0r-blue.toml +77 -0
  162. flock/themes/hax0r-gr33n.toml +77 -0
  163. flock/themes/hax0r-r3d.toml +77 -0
  164. flock/themes/highway.toml +77 -0
  165. flock/themes/hipster-green.toml +77 -0
  166. flock/themes/hivacruz.toml +77 -0
  167. flock/themes/homebrew.toml +77 -0
  168. flock/themes/hopscotch.256.toml +77 -0
  169. flock/themes/hopscotch.toml +77 -0
  170. flock/themes/hurtado.toml +77 -0
  171. flock/themes/hybrid.toml +77 -0
  172. flock/themes/ic-green-ppl.toml +77 -0
  173. flock/themes/ic-orange-ppl.toml +77 -0
  174. flock/themes/iceberg-dark.toml +77 -0
  175. flock/themes/iceberg-light.toml +77 -0
  176. flock/themes/idea.toml +77 -0
  177. flock/themes/idletoes.toml +77 -0
  178. flock/themes/ir-black.toml +77 -0
  179. flock/themes/iterm2-dark-background.toml +77 -0
  180. flock/themes/iterm2-default.toml +77 -0
  181. flock/themes/iterm2-light-background.toml +77 -0
  182. flock/themes/iterm2-pastel-dark-background.toml +77 -0
  183. flock/themes/iterm2-smoooooth.toml +77 -0
  184. flock/themes/iterm2-solarized-dark.toml +77 -0
  185. flock/themes/iterm2-solarized-light.toml +77 -0
  186. flock/themes/iterm2-tango-dark.toml +77 -0
  187. flock/themes/iterm2-tango-light.toml +77 -0
  188. flock/themes/jackie-brown.toml +77 -0
  189. flock/themes/japanesque.toml +77 -0
  190. flock/themes/jellybeans.toml +77 -0
  191. flock/themes/jetbrains-darcula.toml +77 -0
  192. flock/themes/jubi.toml +77 -0
  193. flock/themes/kanagawabones.toml +77 -0
  194. flock/themes/kibble.toml +77 -0
  195. flock/themes/kolorit.toml +77 -0
  196. flock/themes/konsolas.toml +77 -0
  197. flock/themes/kurokula.toml +77 -0
  198. flock/themes/lab-fox.toml +77 -0
  199. flock/themes/laser.toml +77 -0
  200. flock/themes/later-this-evening.toml +77 -0
  201. flock/themes/lavandula.toml +77 -0
  202. flock/themes/liquidcarbon.toml +77 -0
  203. flock/themes/liquidcarbontransparent.toml +77 -0
  204. flock/themes/liquidcarbontransparentinverse.toml +77 -0
  205. flock/themes/lovelace.toml +77 -0
  206. flock/themes/man-page.toml +77 -0
  207. flock/themes/mariana.toml +77 -0
  208. flock/themes/material.toml +77 -0
  209. flock/themes/materialdark.toml +77 -0
  210. flock/themes/materialdarker.toml +77 -0
  211. flock/themes/materialdesigncolors.toml +77 -0
  212. flock/themes/materialocean.toml +77 -0
  213. flock/themes/mathias.toml +77 -0
  214. flock/themes/matrix.toml +77 -0
  215. flock/themes/medallion.toml +77 -0
  216. flock/themes/mellifluous.toml +77 -0
  217. flock/themes/midnight-in-mojave.toml +77 -0
  218. flock/themes/mirage.toml +77 -0
  219. flock/themes/misterioso.toml +77 -0
  220. flock/themes/molokai.toml +77 -0
  221. flock/themes/monalisa.toml +77 -0
  222. flock/themes/monokai-remastered.toml +77 -0
  223. flock/themes/monokai-soda.toml +77 -0
  224. flock/themes/monokai-vivid.toml +77 -0
  225. flock/themes/n0tch2k.toml +77 -0
  226. flock/themes/neobones-dark.toml +77 -0
  227. flock/themes/neobones-light.toml +77 -0
  228. flock/themes/neon.toml +77 -0
  229. flock/themes/neopolitan.toml +77 -0
  230. flock/themes/neutron.toml +77 -0
  231. flock/themes/night-owlish-light.toml +77 -0
  232. flock/themes/nightfox.toml +77 -0
  233. flock/themes/nightlion-v1.toml +77 -0
  234. flock/themes/nightlion-v2.toml +77 -0
  235. flock/themes/niji.toml +77 -0
  236. flock/themes/nocturnal-winter.toml +77 -0
  237. flock/themes/nord-light.toml +77 -0
  238. flock/themes/nord.toml +77 -0
  239. flock/themes/novel.toml +77 -0
  240. flock/themes/nvimdark.toml +77 -0
  241. flock/themes/nvimlight.toml +77 -0
  242. flock/themes/obsidian.toml +77 -0
  243. flock/themes/ocean.toml +77 -0
  244. flock/themes/oceanic-next.toml +77 -0
  245. flock/themes/oceanicmaterial.toml +77 -0
  246. flock/themes/ollie.toml +77 -0
  247. flock/themes/onehalfdark.toml +77 -0
  248. flock/themes/onehalflight.toml +77 -0
  249. flock/themes/operator-mono-dark.toml +77 -0
  250. flock/themes/overnight-slumber.toml +77 -0
  251. flock/themes/oxocarbon.toml +77 -0
  252. flock/themes/palenighthc.toml +77 -0
  253. flock/themes/pandora.toml +77 -0
  254. flock/themes/paraiso-dark.toml +77 -0
  255. flock/themes/paulmillr.toml +77 -0
  256. flock/themes/pencildark.toml +77 -0
  257. flock/themes/pencillight.toml +77 -0
  258. flock/themes/peppermint.toml +77 -0
  259. flock/themes/piatto-light.toml +77 -0
  260. flock/themes/pnevma.toml +77 -0
  261. flock/themes/popping-and-locking.toml +77 -0
  262. flock/themes/primary.toml +77 -0
  263. flock/themes/pro-light.toml +77 -0
  264. flock/themes/pro.toml +77 -0
  265. flock/themes/purple-rain.toml +77 -0
  266. flock/themes/purplepeter.toml +77 -0
  267. flock/themes/rapture.toml +77 -0
  268. flock/themes/raycast-dark.toml +77 -0
  269. flock/themes/raycast-light.toml +77 -0
  270. flock/themes/rebecca.toml +77 -0
  271. flock/themes/red-alert.toml +77 -0
  272. flock/themes/red-planet.toml +77 -0
  273. flock/themes/red-sands.toml +77 -0
  274. flock/themes/relaxed.toml +77 -0
  275. flock/themes/retro.toml +77 -0
  276. flock/themes/rippedcasts.toml +77 -0
  277. flock/themes/rose-pine-dawn.toml +77 -0
  278. flock/themes/rose-pine-moon.toml +77 -0
  279. flock/themes/rose-pine.toml +77 -0
  280. flock/themes/rouge-2.toml +77 -0
  281. flock/themes/royal.toml +77 -0
  282. flock/themes/ryuuko.toml +77 -0
  283. flock/themes/sakura.toml +77 -0
  284. flock/themes/scarlet-protocol.toml +77 -0
  285. flock/themes/seafoam-pastel.toml +77 -0
  286. flock/themes/seashells.toml +77 -0
  287. flock/themes/seoulbones-dark.toml +77 -0
  288. flock/themes/seoulbones-light.toml +77 -0
  289. flock/themes/seti.toml +77 -0
  290. flock/themes/shades-of-purple.toml +77 -0
  291. flock/themes/shaman.toml +77 -0
  292. flock/themes/slate.toml +77 -0
  293. flock/themes/sleepyhollow.toml +77 -0
  294. flock/themes/smyck.toml +77 -0
  295. flock/themes/snazzy.toml +77 -0
  296. flock/themes/softserver.toml +77 -0
  297. flock/themes/solarized-darcula.toml +77 -0
  298. flock/themes/solarized-dark---patched.toml +77 -0
  299. flock/themes/solarized-dark-higher-contrast.toml +77 -0
  300. flock/themes/spacedust.toml +77 -0
  301. flock/themes/spacegray-eighties-dull.toml +77 -0
  302. flock/themes/spacegray-eighties.toml +77 -0
  303. flock/themes/spacegray.toml +77 -0
  304. flock/themes/spiderman.toml +77 -0
  305. flock/themes/spring.toml +77 -0
  306. flock/themes/square.toml +77 -0
  307. flock/themes/sublette.toml +77 -0
  308. flock/themes/subliminal.toml +77 -0
  309. flock/themes/sugarplum.toml +77 -0
  310. flock/themes/sundried.toml +77 -0
  311. flock/themes/symfonic.toml +77 -0
  312. flock/themes/synthwave-everything.toml +77 -0
  313. flock/themes/synthwave.toml +77 -0
  314. flock/themes/synthwavealpha.toml +77 -0
  315. flock/themes/tango-adapted.toml +77 -0
  316. flock/themes/tango-half-adapted.toml +77 -0
  317. flock/themes/teerb.toml +77 -0
  318. flock/themes/terafox.toml +77 -0
  319. flock/themes/terminal-basic.toml +77 -0
  320. flock/themes/thayer-bright.toml +77 -0
  321. flock/themes/the-hulk.toml +77 -0
  322. flock/themes/tinacious-design-(dark).toml +77 -0
  323. flock/themes/tinacious-design-(light).toml +77 -0
  324. flock/themes/tokyonight-day.toml +77 -0
  325. flock/themes/tokyonight-storm.toml +77 -0
  326. flock/themes/tokyonight.toml +77 -0
  327. flock/themes/tomorrow-night-blue.toml +77 -0
  328. flock/themes/tomorrow-night-bright.toml +77 -0
  329. flock/themes/tomorrow-night-burns.toml +77 -0
  330. flock/themes/tomorrow-night-eighties.toml +77 -0
  331. flock/themes/tomorrow-night.toml +77 -0
  332. flock/themes/tomorrow.toml +77 -0
  333. flock/themes/toychest.toml +77 -0
  334. flock/themes/treehouse.toml +77 -0
  335. flock/themes/twilight.toml +77 -0
  336. flock/themes/ubuntu.toml +77 -0
  337. flock/themes/ultradark.toml +77 -0
  338. flock/themes/ultraviolent.toml +77 -0
  339. flock/themes/underthesea.toml +77 -0
  340. flock/themes/unikitty.toml +77 -0
  341. flock/themes/urple.toml +77 -0
  342. flock/themes/vaughn.toml +77 -0
  343. flock/themes/vesper.toml +77 -0
  344. flock/themes/vibrantink.toml +77 -0
  345. flock/themes/vimbones.toml +77 -0
  346. flock/themes/violet-dark.toml +77 -0
  347. flock/themes/violet-light.toml +77 -0
  348. flock/themes/warmneon.toml +77 -0
  349. flock/themes/wez.toml +77 -0
  350. flock/themes/whimsy.toml +77 -0
  351. flock/themes/wildcherry.toml +77 -0
  352. flock/themes/wilmersdorf.toml +77 -0
  353. flock/themes/wombat.toml +77 -0
  354. flock/themes/wryan.toml +77 -0
  355. flock/themes/xcodedark.toml +77 -0
  356. flock/themes/xcodedarkhc.toml +77 -0
  357. flock/themes/xcodelight.toml +77 -0
  358. flock/themes/xcodelighthc.toml +77 -0
  359. flock/themes/xcodewwdc.toml +77 -0
  360. flock/themes/zenbones-dark.toml +77 -0
  361. flock/themes/zenbones-light.toml +77 -0
  362. flock/themes/zenbones.toml +77 -0
  363. flock/themes/zenburn.toml +77 -0
  364. flock/themes/zenburned.toml +77 -0
  365. flock/themes/zenwritten-dark.toml +77 -0
  366. flock/themes/zenwritten-light.toml +77 -0
  367. flock/workflow/activities.py +117 -115
  368. flock/workflow/agent_activities.py +24 -26
  369. flock/workflow/temporal_setup.py +38 -37
  370. flock/workflow/workflow.py +58 -53
  371. flock_core-0.2.1.dist-info/METADATA +287 -0
  372. flock_core-0.2.1.dist-info/RECORD +375 -0
  373. {flock_core-0.1.1.dist-info → flock_core-0.2.1.dist-info}/licenses/LICENSE +21 -21
  374. flock/agents/declarative_agent.py +0 -166
  375. flock/app/components/__init__.py +0 -14
  376. flock/app/components/charts/agent_workflow.py +0 -14
  377. flock/app/components/charts/core_architecture.py +0 -14
  378. flock/app/components/charts/tool_system.py +0 -14
  379. flock/app/components/history_grid.py +0 -168
  380. flock/app/components/history_grid_alt.py +0 -189
  381. flock/app/components/sidebar.py +0 -19
  382. flock/app/components/theme.py +0 -9
  383. flock/app/components/util.py +0 -18
  384. flock/app/hive_app.py +0 -118
  385. flock/app/html/d3.html +0 -179
  386. flock/app/modules/__init__.py +0 -12
  387. flock/app/modules/about.py +0 -17
  388. flock/app/modules/agent_detail.py +0 -70
  389. flock/app/modules/agent_list.py +0 -59
  390. flock/app/modules/playground.py +0 -322
  391. flock/app/modules/settings.py +0 -96
  392. flock/core/agent.py +0 -150
  393. flock/core/agent_registry.py +0 -162
  394. flock/core/context.py +0 -279
  395. flock/core/handoff/handoff_base.py +0 -12
  396. flock/core/logging/error_handler.py +0 -84
  397. flock/core/logging/formatters.py +0 -122
  398. flock/core/logging/handlers.py +0 -117
  399. flock/core/logging/logger.py +0 -107
  400. flock/core/serializable.py +0 -206
  401. flock_core-0.1.1.dist-info/METADATA +0 -449
  402. flock_core-0.1.1.dist-info/RECORD +0 -48
  403. flock_core-0.1.1.dist-info/entry_points.txt +0 -2
  404. /flock/{core/config/declarative_agent_config.py → workflow/__init__.py} +0 -0
  405. {flock_core-0.1.1.dist-info → flock_core-0.2.1.dist-info}/WHEEL +0 -0
@@ -1,96 +0,0 @@
1
- """FrankenUI Forms Example built with MonsterUI (original design by ShadCN)"""
2
-
3
- from fasthtml.common import *
4
- from fasthtml.svg import *
5
- from monsterui.all import *
6
-
7
- from flock.app.components import ThemeDialog
8
-
9
-
10
- def HelpText(c):
11
- return P(c, cls=TextFont.muted_sm)
12
-
13
-
14
- def heading():
15
- return Div(cls="px-4 py-2 ")(
16
- H3("Settings"),
17
- P("Manage your account settings and set e-mail preferences.", cls=TextFont.muted_lg),
18
- DividerSplit(),
19
- )
20
-
21
-
22
- sidebar_items = ["API Keys", "Appearance", "Display"]
23
-
24
- sidebar = NavContainer(
25
- *map(lambda x: Li(A(x)), sidebar_items),
26
- uk_switcher="connect: #component-nav; animation: uk-animation-fade",
27
- cls=(NavT.secondary, "space-y-4 p-4 w-1/5"),
28
- )
29
-
30
-
31
- def FormSectionDiv(*c, cls="space-y-2", **kwargs):
32
- return Div(*c, cls=cls, **kwargs)
33
-
34
-
35
- def api_key_form():
36
- content = (
37
- FormSectionDiv(
38
- LabelInput("Open AI API Key", placeholder="sk-...", id="username"),
39
- HelpText("This is your Open AI API key. You can find it in your account settings. "),
40
- ),
41
- )
42
-
43
- return UkFormSection("API Keys", "Manage API keys of your agents", button_txt="Update api keys", *content)
44
-
45
-
46
- def appearance_form():
47
- content = (
48
- FormSectionDiv(
49
- LabelUkSelect(
50
- *Options("Select a font family", "Inter", "Geist", "Open Sans", selected_idx=2, disabled_idxs={0}),
51
- label="Font Family",
52
- id="font_family",
53
- ),
54
- HelpText("Set the font you want to use in the dashboard."),
55
- ),
56
- FormSectionDiv(
57
- FormLabel("Theme"),
58
- HelpText("Select the theme for the dashboard."),
59
- ThemeDialog(),
60
- ),
61
- )
62
-
63
- return UkFormSection(
64
- "Appearance",
65
- "Customize the appearance of the app. Automatically switch between day and night themes.",
66
- button_txt="Update preferences",
67
- *content,
68
- )
69
-
70
-
71
- def display_form():
72
- content = Div(cls="space-y-2")(
73
- Div(cls="mb-4")(
74
- Span("Sidebar", cls="text-base font-medium"),
75
- HelpText("Select the items you want to display in the sidebar."),
76
- ),
77
- *[
78
- Div(CheckboxX(id=f"display_{i}", checked=i in [0, 1, 2]), FormLabel(label))
79
- for i, label in enumerate(["Recents", "Home", "Applications", "Desktop", "Downloads", "Documents"])
80
- ],
81
- )
82
- return UkFormSection(
83
- "Display", "Turn items on or off to control what's displayed in the app.", button_txt="Update display", *content
84
- )
85
-
86
-
87
- def Settings():
88
- return Title("Settings form"), Container(
89
- heading(),
90
- Div(cls="flex gap-x-12")(
91
- sidebar,
92
- Ul(id="component-nav", cls="uk-switcher max-w-2xl")(
93
- Li(cls="uk-active")(api_key_form(), *map(Li, [appearance_form(), display_form()]))
94
- ),
95
- ),
96
- )
flock/core/agent.py DELETED
@@ -1,150 +0,0 @@
1
- from abc import ABC, abstractmethod
2
- from collections.abc import Callable
3
- from dataclasses import dataclass
4
- from typing import Any, Literal, TypeVar
5
-
6
- import cloudpickle
7
- from pydantic import BaseModel, Field
8
-
9
- from flock.core.context import FlockContext
10
- from flock.core.logging import flock_logger, live_update_handler, performance_handler
11
- from flock.core.serializable import Serializable
12
-
13
- T = TypeVar("T", bound="Agent")
14
-
15
-
16
- @dataclass
17
- class AgentConfig:
18
- save_to_file: bool = False
19
- data_type: Literal["json", "cloudpickle", "msgpack"] = "cloudpickle"
20
-
21
-
22
- class Agent(Serializable, BaseModel, ABC):
23
- """Base class for all agents in the framework.
24
-
25
- Attributes:
26
- - name: A unique identifier for the agent.
27
- - model: The model identifier (e.g., an LLM specification).
28
- - description: A human‑readable description of the agent.
29
- - hand_off: Defines the next agent to invoke (can be a string or callable).
30
- - termination: (Optional) A termination condition or phrase; can be used in lifecycle hooks.
31
-
32
- Lifecycle Hooks:
33
- - initialize(): Called before the agent runs.
34
- - terminate(): Called after the agent finishes running.
35
-
36
- Temporal Execution:
37
- The default run_temporal() method serializes the agent and the current FlockContext
38
- and calls a Temporal activity (run_agent_activity) to perform the execution in a Temporal worker.
39
- Subclasses may override run_temporal() if custom behavior is required.
40
- """
41
-
42
- name: str = Field(description="Identifier name for the agent")
43
- model: str = Field(default="", description="Model of the agent")
44
- description: str | Callable[..., str] = Field(default="", description="Description of the agent")
45
- # Use a default factory for hand_off so it defaults to an empty list.
46
- hand_off: list[str | Callable[..., Any]] = Field(default_factory=list, description="Handoff to another agent")
47
- termination: str | None = Field(default=None, description="Optional termination condition or phrase")
48
-
49
- def register(self, registry) -> None:
50
- """Register this agent with the provided registry."""
51
- registry.register_agent(self)
52
-
53
- @abstractmethod
54
- async def run(self, context: FlockContext) -> dict:
55
- """Execute the agent's logic locally.
56
-
57
- This method must be implemented by each concrete agent.
58
- """
59
- pass
60
-
61
- async def run_temporal(self, context: FlockContext) -> dict:
62
- """Execute the agent's logic via Temporal."""
63
- # Run initialization tasks
64
- await self.initialize(context)
65
-
66
- from temporalio.client import Client
67
-
68
- from flock.workflow.agent_activities import run_agent_activity
69
- from flock.workflow.temporal_setup import run_activity
70
-
71
- try:
72
- with performance_handler.track_time("temporal_connection"):
73
- flock_logger.info("Connecting to Temporal service...")
74
- client = await Client.connect("localhost:7233", namespace="default")
75
-
76
- # Convert the FlockContext to a serializable dictionary
77
- context_data = {
78
- "state": context.state,
79
- "history": [record.__dict__ for record in context.history],
80
- "agent_definitions": [definition.__dict__ for definition in context.agent_definitions],
81
- }
82
- agent_data = self.dict()
83
-
84
- # Execute the Temporal activity
85
- with performance_handler.track_time("temporal_execution"):
86
- with live_update_handler.update_workflow_status(self.name, "Running", {"phase": "temporal_activity"}):
87
- result = await run_activity(
88
- client,
89
- self.name,
90
- run_agent_activity,
91
- {"agent_data": agent_data, "context_data": context_data},
92
- )
93
-
94
- flock_logger.success(f"Temporal activity completed: {self.name}")
95
- return result
96
-
97
- except Exception as e:
98
- flock_logger.error(f"Temporal execution failed: {e}", agent=self.name)
99
- raise
100
- finally:
101
- await self.terminate(context)
102
-
103
- async def initialize(self, context: FlockContext) -> None:
104
- """Lifecycle hook for agent initialization."""
105
- flock_logger.set_context(workflow_id=context.state.get("workflow_id"))
106
- flock_logger.info(f"Initializing agent: {self.name}")
107
- flock_logger.debug("Agent configuration", config=self.dict())
108
- flock_logger.debug("Context state", state=context.state)
109
-
110
- async def terminate(self, context: FlockContext) -> None:
111
- """Lifecycle hook for agent termination."""
112
- if self.termination and context.get_variable("init_input") == self.termination:
113
- flock_logger.warning(
114
- "Termination condition met",
115
- condition=self.termination,
116
- input=context.get_variable("init_input"),
117
- )
118
- flock_logger.info(f"Terminating agent: {self.name}")
119
-
120
- def to_dict(self) -> dict[str, Any]:
121
- def convert_callable(obj):
122
- if callable(obj) and not isinstance(obj, type):
123
- return cloudpickle.dumps(obj).hex() # Serialize functions to hex string
124
- if isinstance(obj, list):
125
- return [convert_callable(x) for x in obj]
126
- if isinstance(obj, dict):
127
- return {k: convert_callable(v) for k, v in obj.items()}
128
- return obj
129
-
130
- # Use Pydantic's model_dump and handle callables
131
- return convert_callable(self.model_dump())
132
-
133
- @classmethod
134
- def from_dict(cls: type[T], data: dict[str, Any]) -> T:
135
- def convert_callable(obj):
136
- if isinstance(obj, str) and len(obj) > 2:
137
- try:
138
- # Try to deserialize hex string back to callable
139
- return cloudpickle.loads(bytes.fromhex(obj))
140
- except:
141
- return obj
142
- if isinstance(obj, list):
143
- return [convert_callable(x) for x in obj]
144
- if isinstance(obj, dict):
145
- return {k: convert_callable(v) for k, v in obj.items()}
146
- return obj
147
-
148
- # Convert callable strings back to functions
149
- converted = convert_callable(data)
150
- return cls(**converted)
@@ -1,162 +0,0 @@
1
- from collections.abc import Callable
2
-
3
- from flock.core.agent import Agent
4
- from flock.core.logging import flock_logger, performance_handler
5
-
6
-
7
- class Registry:
8
- """Registry for storing and managing agents and tools.
9
-
10
- This singleton class maintains a centralized registry of agents and tools,
11
- which is particularly important for Temporal workflows where only basic Python
12
- types can be passed between activities.
13
- """
14
-
15
- _instance = None
16
-
17
- def __new__(cls):
18
- """Singleton pattern implementation."""
19
- if cls._instance is None:
20
- cls._instance = super().__new__(cls)
21
- with performance_handler.track_time("registry_initialization"):
22
- flock_logger.info("Initializing new Registry instance")
23
- cls._instance._initialize()
24
- return cls._instance
25
-
26
- def _initialize(self):
27
- """Initialize the registry's storage."""
28
- self._agents: list[Agent] = []
29
- self._tools: list[tuple[str, Callable]] = []
30
- flock_logger.debug("Registry storage initialized")
31
-
32
- def register_tool(self, tool_name: str, tool: Callable) -> None:
33
- """Register a tool with the registry.
34
-
35
- Args:
36
- tool_name: The name to register the tool under
37
- tool: The tool function to register
38
- """
39
- try:
40
- with performance_handler.track_time("tool_registration"):
41
- self._tools.append((tool_name, tool))
42
- flock_logger.info(f"Registered tool: {tool_name}")
43
- flock_logger.debug("Tool details", tool_name=tool_name, tool_type=type(tool).__name__)
44
- except Exception as e:
45
- flock_logger.error(
46
- "Tool registration failed",
47
- tool_name=tool_name,
48
- error=str(e),
49
- )
50
- raise
51
-
52
- def register_agent(self, agent: Agent) -> None:
53
- """Register an agent with the registry.
54
-
55
- Args:
56
- agent: The agent instance to register
57
- """
58
- try:
59
- with performance_handler.track_time("agent_registration"):
60
- self._agents.append(agent)
61
- flock_logger.info(f"Registered agent: {agent.name}")
62
- flock_logger.debug(
63
- "Agent details",
64
- name=agent.name,
65
- type=type(agent).__name__,
66
- model=agent.model,
67
- )
68
- except Exception as e:
69
- flock_logger.error(
70
- "Agent registration failed",
71
- agent_name=getattr(agent, "name", "unknown"),
72
- error=str(e),
73
- )
74
- raise
75
-
76
- def get_agent(self, name: str) -> Agent | None:
77
- """Retrieve an agent by name.
78
-
79
- Args:
80
- name: The name of the agent to retrieve
81
-
82
- Returns:
83
- The agent instance if found, None otherwise
84
- """
85
- try:
86
- with performance_handler.track_time("agent_retrieval"):
87
- for agent in self._agents:
88
- if agent.name == name:
89
- flock_logger.debug(f"Retrieved agent: {name}")
90
- return agent
91
-
92
- flock_logger.warning(f"Agent not found: {name}")
93
- return None
94
- except Exception as e:
95
- flock_logger.error(
96
- "Agent retrieval failed",
97
- agent_name=name,
98
- error=str(e),
99
- )
100
- raise
101
-
102
- def get_tool(self, name: str) -> Callable | None:
103
- """Retrieve a tool by name.
104
-
105
- Args:
106
- name: The name of the tool to retrieve
107
-
108
- Returns:
109
- The tool function if found, None otherwise
110
- """
111
- try:
112
- with performance_handler.track_time("tool_retrieval"):
113
- for tool_name, tool in self._tools:
114
- if tool_name == name:
115
- flock_logger.debug(f"Retrieved tool: {name}")
116
- return tool
117
-
118
- flock_logger.warning(f"Tool not found: {name}")
119
- return None
120
- except Exception as e:
121
- flock_logger.error(
122
- "Tool retrieval failed",
123
- tool_name=name,
124
- error=str(e),
125
- )
126
- raise
127
-
128
- def get_tools(self, names: list[str] | None) -> list[Callable]:
129
- """Retrieve multiple tools by name.
130
-
131
- Args:
132
- names: List of tool names to retrieve
133
-
134
- Returns:
135
- List of found tool functions (may be empty if none found)
136
- """
137
- try:
138
- with performance_handler.track_time("tools_retrieval"):
139
- if not names:
140
- flock_logger.debug("No tool names provided")
141
- return []
142
-
143
- tools = [self.get_tool(name) for name in names]
144
- found_tools = [name for name, tool in zip(names, tools) if tool is not None]
145
-
146
- if found_tools:
147
- flock_logger.debug(
148
- "Retrieved tools",
149
- requested=len(names),
150
- found=len(found_tools),
151
- )
152
- return [tool for tool in tools if tool is not None]
153
-
154
- flock_logger.warning("No tools found", requested=names)
155
- return []
156
- except Exception as e:
157
- flock_logger.error(
158
- "Tools retrieval failed",
159
- tool_names=names,
160
- error=str(e),
161
- )
162
- raise
flock/core/context.py DELETED
@@ -1,279 +0,0 @@
1
- from dataclasses import asdict, dataclass, field
2
- from datetime import datetime
3
- from typing import Any, Literal
4
-
5
- from flock.core.context_vars import FLOCK_LAST_AGENT, FLOCK_LAST_RESULT
6
- from flock.core.logging import flock_logger, performance_handler
7
- from flock.core.serializable import Serializable
8
-
9
-
10
- @dataclass
11
- class AgentRunRecord:
12
- agent: str = field(default="") # Agent name
13
- input_data: dict[str, Any] = field(default_factory=dict)
14
- output_data: dict[str, Any] = field(default_factory=dict)
15
- timestamp: str = field(default="")
16
- hand_off: str = field(default="") # Next agent name
17
-
18
-
19
- @dataclass
20
- class AgentDefinition:
21
- agent_type: str = field(default="")
22
- agent_name: str = field(default="")
23
- agent_data: dict = field(default=dict)
24
- serializer: Literal["json", "cloudpickle", "msgpack"] = field(default="cloudpickle")
25
-
26
-
27
- @dataclass
28
- class FlockContext(Serializable):
29
- state: dict[str, Any] = field(default_factory=dict)
30
- history: list[AgentRunRecord] = field(default_factory=list)
31
- agent_definitions: dict[str, AgentDefinition] = field(default_factory=dict)
32
- run_id: str = field(default="")
33
- workflow_id: str = field(default="")
34
- workflow_timestamp: str = field(default="")
35
-
36
- def record(self, agent_name: str, data: dict[str, Any], timestamp: str, hand_off: str) -> None:
37
- """Record an agent run and update the state with the agent's output."""
38
- try:
39
- with performance_handler.track_time("record_agent_run"):
40
- flock_logger.info(f"Recording agent run: {agent_name}")
41
- record = AgentRunRecord(
42
- agent=agent_name, output_data=data.copy(), timestamp=timestamp, hand_off=hand_off
43
- )
44
- self.history.append(record)
45
- flock_logger.debug(
46
- "Created run record",
47
- agent=agent_name,
48
- output_keys=list(data.keys()),
49
- )
50
-
51
- self.set_variable(f"{agent_name}.result", data)
52
- self.set_variable(FLOCK_LAST_RESULT, data)
53
- self.set_variable(FLOCK_LAST_AGENT, agent_name)
54
- flock_logger.debug("Updated context state with agent output")
55
-
56
- except Exception as e:
57
- flock_logger.error(
58
- "Failed to record agent run",
59
- agent=agent_name,
60
- error=str(e),
61
- )
62
- raise
63
-
64
- def get_variable(self, key: str) -> Any:
65
- """Get the current value of a state variable."""
66
- try:
67
- with performance_handler.track_time("get_variable"):
68
- value = self.state.get(key)
69
- if value is None:
70
- flock_logger.warning(f"Variable not found in state: {key}")
71
- else:
72
- flock_logger.debug(f"Retrieved variable: {key}")
73
- return value
74
- except Exception as e:
75
- flock_logger.error(
76
- "Failed to get variable",
77
- key=key,
78
- error=str(e),
79
- )
80
- raise
81
-
82
- def set_variable(self, key: str, value: Any) -> None:
83
- """Set the value of a state variable."""
84
- try:
85
- with performance_handler.track_time("set_variable"):
86
- self.state[key] = value
87
- flock_logger.debug(f"Set variable: {key}")
88
- except Exception as e:
89
- flock_logger.error(
90
- "Failed to set variable",
91
- key=key,
92
- error=str(e),
93
- )
94
- raise
95
-
96
- def deepcopy(self) -> "FlockContext":
97
- """Create a deep copy of the context."""
98
- try:
99
- with performance_handler.track_time("context_deepcopy"):
100
- flock_logger.debug("Creating deep copy of context")
101
- copy = FlockContext.from_dict(self.to_dict())
102
- flock_logger.debug(
103
- "Context copied",
104
- state_vars=len(copy.state),
105
- history_records=len(copy.history),
106
- )
107
- return copy
108
- except Exception as e:
109
- flock_logger.error(
110
- "Failed to create context copy",
111
- error=str(e),
112
- )
113
- raise
114
-
115
- def get_agent_history(self, agent_name: str) -> list[AgentRunRecord]:
116
- """Return all agent run records for a given agent name."""
117
- try:
118
- with performance_handler.track_time("get_agent_history"):
119
- records = [record for record in self.history if record.agent == agent_name]
120
- flock_logger.debug(
121
- f"Retrieved history records for {agent_name}",
122
- count=len(records),
123
- )
124
- return records
125
- except Exception as e:
126
- flock_logger.error(
127
- "Failed to get history records",
128
- agent=agent_name,
129
- error=str(e),
130
- )
131
- raise
132
-
133
- def next_input_for(self, agent) -> Any:
134
- """By default, the next input for an agent is taken from the context state.
135
-
136
- If the agent.input is a comma-separated list (e.g., "input1, input2"),
137
- this method will return a dictionary with keys for each of the input names,
138
- fetching the latest values from the state.
139
-
140
- If only a single input is specified, the raw value is returned.
141
- """
142
- try:
143
- with performance_handler.track_time("next_input_preparation"):
144
- flock_logger.info(f"Preparing next input for agent: {agent.name}")
145
-
146
- if hasattr(agent, "input") and isinstance(agent.input, str):
147
- keys = [k.strip() for k in agent.input.split(",") if k.strip()]
148
- flock_logger.debug(f"Input keys: {keys}")
149
-
150
- if len(keys) == 1:
151
- value = self.get_variable(keys[0])
152
- flock_logger.debug(f"Single input value retrieved for key: {keys[0]}")
153
- return value
154
- else:
155
- values = {key: self.get_variable(key) for key in keys}
156
- flock_logger.debug(f"Multiple input values retrieved for keys: {keys}")
157
- return values
158
- else:
159
- # Fallback to "init_input"
160
- flock_logger.debug("No input defined, falling back to init_input")
161
- return self.get_variable("init_input")
162
- except Exception as e:
163
- flock_logger.error(
164
- "Failed to prepare next input",
165
- agent=getattr(agent, "name", str(agent)),
166
- error=str(e),
167
- )
168
- raise
169
-
170
- def get_agent_definition(self, agent_name: str) -> AgentDefinition | None:
171
- """Get the definition for a specific agent."""
172
- try:
173
- with performance_handler.track_time("get_agent_definition"):
174
- for definition in self.agent_definitions:
175
- if definition.name == agent_name:
176
- flock_logger.debug(f"Retrieved definition for agent: {agent_name}")
177
- return definition
178
-
179
- flock_logger.warning(f"No definition found for agent: {agent_name}")
180
- return None
181
- except Exception as e:
182
- flock_logger.error(
183
- "Failed to get agent definition",
184
- agent=agent_name,
185
- error=str(e),
186
- )
187
- raise
188
-
189
- def add_agent_definition(self, agent_type: type, agent_name: str, agent_data: Any) -> None:
190
- """Add a new agent definition to the context."""
191
- try:
192
- with performance_handler.track_time("add_agent_definition"):
193
- definition = AgentDefinition(
194
- agent_type=agent_type.__name__,
195
- agent_name=agent_name,
196
- agent_data=agent_data,
197
- )
198
- self.agent_definitions[agent_name] = definition
199
- flock_logger.info(
200
- f"Added agent definition",
201
- agent=agent_name,
202
- type=agent_type.__name__,
203
- )
204
- except Exception as e:
205
- flock_logger.error(
206
- "Failed to add agent definition",
207
- agent=agent_name,
208
- type=agent_type.__name__,
209
- error=str(e),
210
- )
211
- raise
212
-
213
- # Allow dict-like access for convenience.
214
- def __getitem__(self, key: str) -> Any:
215
- value = self.state[key]
216
- return value
217
-
218
- def __setitem__(self, key: str, value: Any) -> None:
219
- self.state[key] = value
220
-
221
- def to_dict(self) -> dict[str, Any]:
222
- """Convert the context to a dictionary for serialization."""
223
- try:
224
- with performance_handler.track_time("context_to_dict"):
225
- flock_logger.debug("Converting context to dictionary")
226
-
227
- def convert(obj):
228
- if isinstance(obj, datetime):
229
- return obj.isoformat()
230
- if hasattr(obj, "__dataclass_fields__"): # Is a dataclass
231
- return asdict(obj, dict_factory=lambda x: {k: convert(v) for k, v in x})
232
- return obj
233
-
234
- result = convert(asdict(self))
235
- flock_logger.debug(
236
- "Context converted to dictionary",
237
- state_size=len(result.get("state", {})),
238
- history_size=len(result.get("history", [])),
239
- )
240
- return result
241
- except Exception as e:
242
- flock_logger.error(
243
- "Failed to convert context to dictionary",
244
- error=str(e),
245
- )
246
- raise
247
-
248
- @classmethod
249
- def from_dict(cls, data: dict[str, Any]) -> "FlockContext":
250
- """Create a context instance from a dictionary."""
251
- try:
252
- with performance_handler.track_time("context_from_dict"):
253
- flock_logger.debug("Creating context from dictionary")
254
-
255
- def convert(obj):
256
- if isinstance(obj, dict):
257
- if "timestamp" in obj: # AgentRunRecord
258
- return AgentRunRecord(**{**obj, "timestamp": datetime.fromisoformat(obj["timestamp"])})
259
- if "agent_type" in obj: # AgentDefinition
260
- return AgentDefinition(**obj)
261
- return {k: convert(v) for k, v in obj.items()}
262
- if isinstance(obj, list):
263
- return [convert(v) for v in obj]
264
- return obj
265
-
266
- converted = convert(data)
267
- context = cls(**converted)
268
- flock_logger.debug(
269
- "Created context from dictionary",
270
- state_vars=len(context.state),
271
- history_records=len(context.history),
272
- )
273
- return context
274
- except Exception as e:
275
- flock_logger.error(
276
- "Failed to create context from dictionary",
277
- error=str(e),
278
- )
279
- raise