open-swarm 0.1.1745126154__py3-none-any.whl → 0.1.1745126277__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 (52) hide show
  1. {open_swarm-0.1.1745126154.dist-info → open_swarm-0.1.1745126277.dist-info}/METADATA +1 -1
  2. {open_swarm-0.1.1745126154.dist-info → open_swarm-0.1.1745126277.dist-info}/RECORD +52 -25
  3. swarm/blueprints/README.md +19 -18
  4. swarm/blueprints/blueprint_audit_status.json +1 -1
  5. swarm/blueprints/chatbot/blueprint_chatbot.py +160 -72
  6. swarm/blueprints/codey/README.md +88 -8
  7. swarm/blueprints/codey/blueprint_codey.py +1116 -210
  8. swarm/blueprints/codey/codey_cli.py +10 -0
  9. swarm/blueprints/codey/session_logs/session_2025-04-19T01-15-31.md +17 -0
  10. swarm/blueprints/codey/session_logs/session_2025-04-19T01-16-03.md +17 -0
  11. swarm/blueprints/common/operation_box_utils.py +83 -0
  12. swarm/blueprints/digitalbutlers/blueprint_digitalbutlers.py +21 -298
  13. swarm/blueprints/divine_code/blueprint_divine_code.py +182 -9
  14. swarm/blueprints/django_chat/blueprint_django_chat.py +150 -24
  15. swarm/blueprints/echocraft/blueprint_echocraft.py +142 -13
  16. swarm/blueprints/geese/README.md +97 -0
  17. swarm/blueprints/geese/blueprint_geese.py +677 -93
  18. swarm/blueprints/geese/geese_cli.py +102 -0
  19. swarm/blueprints/jeeves/blueprint_jeeves.py +712 -0
  20. swarm/blueprints/jeeves/jeeves_cli.py +55 -0
  21. swarm/blueprints/mcp_demo/blueprint_mcp_demo.py +109 -22
  22. swarm/blueprints/mission_improbable/blueprint_mission_improbable.py +172 -40
  23. swarm/blueprints/monkai_magic/blueprint_monkai_magic.py +79 -41
  24. swarm/blueprints/nebula_shellz/blueprint_nebula_shellz.py +82 -35
  25. swarm/blueprints/omniplex/blueprint_omniplex.py +56 -24
  26. swarm/blueprints/poets/blueprint_poets.py +141 -100
  27. swarm/blueprints/poets/poets_cli.py +23 -0
  28. swarm/blueprints/rue_code/README.md +8 -0
  29. swarm/blueprints/rue_code/blueprint_rue_code.py +188 -20
  30. swarm/blueprints/rue_code/rue_code_cli.py +43 -0
  31. swarm/blueprints/stewie/apps.py +12 -0
  32. swarm/blueprints/stewie/blueprint_family_ties.py +349 -0
  33. swarm/blueprints/stewie/models.py +19 -0
  34. swarm/blueprints/stewie/serializers.py +10 -0
  35. swarm/blueprints/stewie/settings.py +17 -0
  36. swarm/blueprints/stewie/urls.py +11 -0
  37. swarm/blueprints/stewie/views.py +26 -0
  38. swarm/blueprints/suggestion/blueprint_suggestion.py +54 -39
  39. swarm/blueprints/whinge_surf/README.md +22 -0
  40. swarm/blueprints/whinge_surf/__init__.py +1 -0
  41. swarm/blueprints/whinge_surf/blueprint_whinge_surf.py +565 -0
  42. swarm/blueprints/whinge_surf/whinge_surf_cli.py +99 -0
  43. swarm/blueprints/whiskeytango_foxtrot/blueprint_whiskeytango_foxtrot.py +66 -37
  44. swarm/blueprints/zeus/__init__.py +2 -0
  45. swarm/blueprints/zeus/apps.py +4 -0
  46. swarm/blueprints/zeus/blueprint_zeus.py +270 -0
  47. swarm/blueprints/zeus/zeus_cli.py +13 -0
  48. swarm/cli/async_input.py +65 -0
  49. swarm/cli/async_input_demo.py +32 -0
  50. {open_swarm-0.1.1745126154.dist-info → open_swarm-0.1.1745126277.dist-info}/WHEEL +0 -0
  51. {open_swarm-0.1.1745126154.dist-info → open_swarm-0.1.1745126277.dist-info}/entry_points.txt +0 -0
  52. {open_swarm-0.1.1745126154.dist-info → open_swarm-0.1.1745126277.dist-info}/licenses/LICENSE +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: open-swarm
3
- Version: 0.1.1745126154
3
+ Version: 0.1.1745126277
4
4
  Summary: Open Swarm: Orchestrating AI Agent Swarms with Django
5
5
  Project-URL: Homepage, https://github.com/yourusername/open-swarm
6
6
  Project-URL: Documentation, https://github.com/yourusername/open-swarm/blob/main/README.md
@@ -13,40 +13,67 @@ swarm/urls.py,sha256=9eRQWsB-Vs3Nmes4mtlZtk_Rvuixf4Y9uwrX9dVQ9Is,3292
13
13
  swarm/util.py,sha256=G4x2hXopHhB7IdGCkUXGoykYWyiICnjxg7wcr-WqL8I,4644
14
14
  swarm/wsgi.py,sha256=REM_u4HpMCkO0ddrOUXgtY-ITL-VTbRB1-WHvFJAtAU,408
15
15
  swarm/agent/__init__.py,sha256=YESGu_UXEBxrlQwghodUMN0vmXZDwWMU7DclCUvoklA,104
16
- swarm/blueprints/README.md,sha256=tsngbSB9N0tILcz_m1OGAjyKZQYlGTN-i5e5asq1GbE,8478
17
- swarm/blueprints/blueprint_audit_status.json,sha256=-1jCh56y8BC0h5Z2o7-TWY2Xw5Jj4wEVNohZF_Dw4EE,1857
18
- swarm/blueprints/chatbot/blueprint_chatbot.py,sha256=Ws3eTfq6A_jsm4nGPo47pM06RdAYmur5YY2siOcbUwA,10484
16
+ swarm/blueprints/README.md,sha256=scDx32t4UBC3TLgNzUe0dRmlcC2yJH-yY4Pxde1n5_A,9257
17
+ swarm/blueprints/blueprint_audit_status.json,sha256=6uv6_M8WU5VGr1GhG49_p0-iHHRoi3iDLo-sy5GmuS8,1852
18
+ swarm/blueprints/chatbot/blueprint_chatbot.py,sha256=Fuy_kPQUaZtIKoM01aWGjieak1zGTxI8VBVbi-TzHH0,14441
19
19
  swarm/blueprints/chatbot/templates/chatbot/chatbot.html,sha256=REFnqNg0EHsXxAUfaCJe1YgOKiV_umBXuC6y8veF5CU,1568
20
20
  swarm/blueprints/codey/CODEY.md,sha256=JxGcR0INH0dLk_q4ua1D0YdvX99szyESsbbs4dIy5Sc,742
21
- swarm/blueprints/codey/README.md,sha256=n2Sz1yg1FZp6ATV4W4rmgIYeQFFzlJ_APhCY1j6UR7o,3545
22
- swarm/blueprints/codey/blueprint_codey.py,sha256=otjn46MVsmIvHTbE6aHFPwFfcV3kNY_j2vdnt1xCKAo,17205
23
- swarm/blueprints/codey/codey_cli.py,sha256=97vfYSGZ5N5irqg5SMkxKRDHr1C7o4zdu2IjxHr7ZDM,6263
21
+ swarm/blueprints/codey/README.md,sha256=_wQ8MuEFj4cMmKaJYfgvoepkCaF-zIZYfdhAyhvmzAg,7369
22
+ swarm/blueprints/codey/blueprint_codey.py,sha256=u3VvUSPDu7hULMGpouVNOwNslwDtNFPSUofV8mUDxu8,61216
23
+ swarm/blueprints/codey/codey_cli.py,sha256=I_xvePNqTdqeNmFAuI3blgvQM6u40nh7u-wah8dB7yM,6750
24
24
  swarm/blueprints/codey/instructions.md,sha256=XMvJngQ23vl7xJQx-Sp5UIME2-JQyyxeZFFtIuOtTOI,1209
25
- swarm/blueprints/digitalbutlers/blueprint_digitalbutlers.py,sha256=frnC-09hrUkg2bTPBFtj_WdQkGGNE1s4Ru35Ec4ag4M,16270
25
+ swarm/blueprints/codey/session_logs/session_2025-04-19T01-15-31.md,sha256=IRzOdr9wisTQYOc0FZQi-4zlX_vickQrq900SNZ9dPU,270
26
+ swarm/blueprints/codey/session_logs/session_2025-04-19T01-16-03.md,sha256=2GQcj850IZMz3Fqvet3dynXuTom4ZT7VwoxwWMhgTH8,270
27
+ swarm/blueprints/common/operation_box_utils.py,sha256=YYntqT6p44r7hxq5GLOS0gyOuInmhvWo1hp6-qKk36Q,3087
28
+ swarm/blueprints/digitalbutlers/blueprint_digitalbutlers.py,sha256=AnMjzfIDIj771NLc20Am2OSMqARoTiX8me2TG3-oQDY,1028
26
29
  swarm/blueprints/divine_code/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
27
30
  swarm/blueprints/divine_code/apps.py,sha256=k615JHdfOuo_GwfVbC7ah8X9OblkAL2XWm9aLBjmMyY,306
28
- swarm/blueprints/divine_code/blueprint_divine_code.py,sha256=I2WM69x-ILeBUtQn0C5emdumw8Lx2N0mIgjwMMVhDow,19546
31
+ swarm/blueprints/divine_code/blueprint_divine_code.py,sha256=mHe-8h9TNiPzPcAxeLG5FLED9Cf29ffoiuXWCKyKnOc,27285
29
32
  swarm/blueprints/django_chat/apps.py,sha256=rn1Eu11c4zZ6DYZeFb6AkCDMoM_dcQTzeNwW-IxXpCI,200
30
- swarm/blueprints/django_chat/blueprint_django_chat.py,sha256=LY_SOnNpColj1xXw1d6fpyflBF8CZzPqL5IYLRnzSqI,5582
33
+ swarm/blueprints/django_chat/blueprint_django_chat.py,sha256=rCxfYCcSNEKnzST0Zrq_Y9XHOwnURfbCK3FON5P6F9k,11544
31
34
  swarm/blueprints/django_chat/urls.py,sha256=TTTF3pgymvCYbuxpwi4WRBPv8ftQNH4pEoURT8sEVAg,147
32
35
  swarm/blueprints/django_chat/views.py,sha256=MUKjXXjXsq8jMZtAb4RR9g2mEYrwFemN6Bqxpeyi7p4,1299
33
36
  swarm/blueprints/django_chat/templates/django_chat/django_chat_webpage.html,sha256=wAEOI4Wg0JJ8drXaOcr2Pel6lW3JSHmyIpbocLS5tI8,1649
34
- swarm/blueprints/echocraft/blueprint_echocraft.py,sha256=9XNyuMZIBrm9kpnv1aq_W3h-9Zr2dVdzchI2uFXslg0,10988
37
+ swarm/blueprints/echocraft/blueprint_echocraft.py,sha256=1ttrbOWxGTerlip_lgLzCoCmzPJhDdfEIN6FoxnsP2A,16597
35
38
  swarm/blueprints/flock/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
36
- swarm/blueprints/geese/blueprint_geese.py,sha256=uP0gPHFACI18a_cY5f89ndqccNrK3YxjQPgA85T8Cms,9339
37
- swarm/blueprints/mcp_demo/blueprint_mcp_demo.py,sha256=bTHupSUdg9OzaRoTu9obGsxk48f9o3wUCLqVWeWYW-w,17695
39
+ swarm/blueprints/geese/README.md,sha256=o5tgiL7cK0m0JdHxMuZ-u8iKuzVO7EQKkuW4gP2mkHU,3699
40
+ swarm/blueprints/geese/blueprint_geese.py,sha256=fSf8pmXOCDrW4FQ2S_yX9L62xJYzxntgdlkWY55RjvI,37255
41
+ swarm/blueprints/geese/geese_cli.py,sha256=JNx2Te4F-HvYnCldXOtzDRKyNznse2N8_LXPlpZ_vbk,5354
42
+ swarm/blueprints/jeeves/blueprint_jeeves.py,sha256=5pr5Wy3Apf1_hxG57BHuqX4ZtfLcMRbU-98PDdVwO1k,33790
43
+ swarm/blueprints/jeeves/jeeves_cli.py,sha256=n_2CeiqPjwPA-xnRKXeizO6A1WtxpsI06HsWaIz_51M,2630
44
+ swarm/blueprints/mcp_demo/blueprint_mcp_demo.py,sha256=036QxkuxvX7cSgX1MernL0qicbsAXO3HXDiOqZKznV4,21341
38
45
  swarm/blueprints/messenger/templates/messenger/messenger.html,sha256=izuFtFn40Gm7M4gSUAUT5CIezjBjmNv2w4_fwSlv7VA,2323
39
- swarm/blueprints/mission_improbable/blueprint_mission_improbable.py,sha256=fAc672c3XYFwGwrdpDELO3V9k5dqBfyRH7_S7Urmo48,15034
40
- swarm/blueprints/monkai_magic/blueprint_monkai_magic.py,sha256=9eE3pf14OjgOPKNapJF8b9OYyK5_AEVZ4UJMRrBeOek,16009
41
- swarm/blueprints/nebula_shellz/blueprint_nebula_shellz.py,sha256=1xT6yYhl-sOSODd0E0hSKxtBlNoQe6sPf30d-S9fI6U,11709
42
- swarm/blueprints/omniplex/blueprint_omniplex.py,sha256=ESJyKPhz01rw2l3AP5zbDreLUbzhJtwewopmr_WRVNM,13644
43
- swarm/blueprints/poets/blueprint_poets.py,sha256=_yWU2ujGQw_Q6ZVXX8yW7GKOFkKNyf6-LCdkQ7run7k,26571
46
+ swarm/blueprints/mission_improbable/blueprint_mission_improbable.py,sha256=hvwbg6LwaVKnH-fzQdyg7zTvDC5Get3sVt8xx82WpZc,21074
47
+ swarm/blueprints/monkai_magic/blueprint_monkai_magic.py,sha256=nI4YNDndJN44TPh3rr7WrNBbK2I9x2xIU98GepzQe-0,18636
48
+ swarm/blueprints/nebula_shellz/blueprint_nebula_shellz.py,sha256=DhHzsHQS98h7Of62g9eSasSWis2MK4R3x5JhNT3K1Z0,14101
49
+ swarm/blueprints/omniplex/blueprint_omniplex.py,sha256=SNjMXprI_kvJ9yxihsVqroDt627R17U3rYPYXljR_pk,15275
50
+ swarm/blueprints/poets/blueprint_poets.py,sha256=dw7oQrsOnnfF4EApPbdL7d3azM7V5LXR3USLBWhq--w,29031
51
+ swarm/blueprints/poets/poets_cli.py,sha256=DRAXxRGJZhFZaGhvfBxMe3qlxnjCClKlYfLIE6cUiuI,890
52
+ swarm/blueprints/rue_code/README.md,sha256=j9EXCkimV1yY5qJHLgcH_JGhQtV9SefZGZCzDRdaprQ,302
44
53
  swarm/blueprints/rue_code/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
45
- swarm/blueprints/rue_code/blueprint_rue_code.py,sha256=odxqvAIzSESlm9eecZNz-JBsjeoRpFgCZs-7tG1ZkLQ,13273
46
- swarm/blueprints/suggestion/blueprint_suggestion.py,sha256=Qm5YbP19SETFtXc-gTsmGUh71US7huUyKZKqtRv-Qeg,10846
54
+ swarm/blueprints/rue_code/blueprint_rue_code.py,sha256=nxR9nHYbB_Pp5Pft1VwK4-ktiWZHMsiMywpmdGPZyCc,20937
55
+ swarm/blueprints/rue_code/rue_code_cli.py,sha256=E760-LOYv2Uw0VoLTHEEK7LdhaG6oSflJfsaxV7S1v8,2194
56
+ swarm/blueprints/stewie/apps.py,sha256=D_Nvpx7SPdUgtE8KaaMmlEDghUwadMmSPI-aGJlnFos,341
57
+ swarm/blueprints/stewie/blueprint_family_ties.py,sha256=0LPsHLPg6bXJ5Tia7uezdF0mNddWaGgg3x2kIBvs0TE,17297
58
+ swarm/blueprints/stewie/models.py,sha256=C3_okdVVYuu9xOpoKRsaLoGrM2775cS_cU4UKYAkJ9s,903
59
+ swarm/blueprints/stewie/serializers.py,sha256=YFxiMYJcQuI1KkBXEcfefPDZkU_cB-J_XJfc1OPROhg,383
60
+ swarm/blueprints/stewie/settings.py,sha256=Q3aB1KfxyKrxSvtoFJdXQsuqb99Wod75xW0xJXyQ9xE,443
61
+ swarm/blueprints/stewie/urls.py,sha256=5hWn-75wdmyaFTViV5-8vF1aH0c3XnyZMKg_9CP_39I,308
62
+ swarm/blueprints/stewie/views.py,sha256=FbPkDNlFEixtRFbSpkr51IyJ28FRkXa1W5xyO_KeXH0,1081
63
+ swarm/blueprints/suggestion/blueprint_suggestion.py,sha256=zKQUybUYcM8TD9UBzVDZMZ-efizbk2ZwBXtsW012Gn4,11647
64
+ swarm/blueprints/whinge_surf/README.md,sha256=tXV2vVHAs3VKdqjDSzxVCz44xCRt8mjxVEuQGCBKhio,953
65
+ swarm/blueprints/whinge_surf/__init__.py,sha256=N-BmmHagDPSdh3UCNqFDJPk4LKtPIqsttTANj0tQIXw,32
66
+ swarm/blueprints/whinge_surf/blueprint_whinge_surf.py,sha256=LJSNYuASGXz0DakedGb7uHVi41a7EievawcxD5j4d-Y,23319
67
+ swarm/blueprints/whinge_surf/whinge_surf_cli.py,sha256=t9OJWNlcFLGcGH9t6jhE-6EGjPsRgRedVoXrywC1www,4101
47
68
  swarm/blueprints/whiskeytango_foxtrot/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
48
69
  swarm/blueprints/whiskeytango_foxtrot/apps.py,sha256=V1QKvyb2Vz-EtDNhhNe4tw2W9LYhNDuiaIq_fAU4ilw,334
49
- swarm/blueprints/whiskeytango_foxtrot/blueprint_whiskeytango_foxtrot.py,sha256=y5OUPe5-W0Bhm3nO0hBH31ucXuote3PBVgb0WeOQodE,16567
70
+ swarm/blueprints/whiskeytango_foxtrot/blueprint_whiskeytango_foxtrot.py,sha256=6QbSQxE26fRDNGSQZKyS8VK1_C6WGPqOsZc8YRDC76k,18352
71
+ swarm/blueprints/zeus/__init__.py,sha256=jeKj20cgtIU59RfhOnLaMTPPAyqzrAHOVXNrN40RlI4,94
72
+ swarm/blueprints/zeus/apps.py,sha256=HZ7rLf_HANy4yJtCv9bfY_2DZUg-N-gl8xXj8EJ4cTs,99
73
+ swarm/blueprints/zeus/blueprint_zeus.py,sha256=tCYpS07ZAQP3XyzZBFLgT_hzBzH2o_PY933fQWvXQ8A,13408
74
+ swarm/blueprints/zeus/zeus_cli.py,sha256=7gKqT9Vp6VQsqphaJZj-Cw91q_ZIlD_WBbVsWhNxPrw,460
75
+ swarm/cli/async_input.py,sha256=6Is9KRc7zwe9VPBeVuRleqKg_kc6aDU5eFmby0NOTow,2297
76
+ swarm/cli/async_input_demo.py,sha256=mKn1ffQbiCBWshvlCXES78ASbVUi5kprYejbImR_QH4,1005
50
77
  swarm/core/agent_utils.py,sha256=exKnbJEm1VRL270x6XqQXHtJhqD8ogY3ZBIGZO_tYUE,552
51
78
  swarm/core/blueprint_base.py,sha256=ZXfgCqaAVprML0KS3njHNxgldrwOCSGZrcI-fj7HyZs,40178
52
79
  swarm/core/blueprint_discovery.py,sha256=UyJuBq_u7KLQC2_I9KGioX-Bcbj2-qjhKke4ensk_Xw,5622
@@ -271,8 +298,8 @@ swarm/views/message_views.py,sha256=sDUnXyqKXC8WwIIMAlWf00s2_a2T9c75Na5FvYMJwBM,
271
298
  swarm/views/model_views.py,sha256=aAbU4AZmrOTaPeKMWtoKK7FPYHdaN3Zbx55JfKzYTRY,2937
272
299
  swarm/views/utils.py,sha256=8Usc0g0L0NPegNAyY20tJBNBy-JLwODf4VmxV0yUtpw,3627
273
300
  swarm/views/web_views.py,sha256=T1CKe-Nyv1C8aDt6QFTGWo_dkH7ojWAvS_QW9mZnZp0,7371
274
- open_swarm-0.1.1745126154.dist-info/METADATA,sha256=xkiMMqj4xllS-hBCQ4O6h-PAVeziV2TNcZ5seU7BhnY,27659
275
- open_swarm-0.1.1745126154.dist-info/WHEEL,sha256=qtCwoSJWgHk21S1Kb4ihdzI2rlJ1ZKaIurTj_ngOhyQ,87
276
- open_swarm-0.1.1745126154.dist-info/entry_points.txt,sha256=fo28d0_zJrytRsh8QqkdlWQT_9lyAwYUx1WuSTDI3HM,177
277
- open_swarm-0.1.1745126154.dist-info/licenses/LICENSE,sha256=BU9bwRlnOt_JDIb6OT55Q4leLZx9RArDLTFnlDIrBEI,1062
278
- open_swarm-0.1.1745126154.dist-info/RECORD,,
301
+ open_swarm-0.1.1745126277.dist-info/METADATA,sha256=mL5x1if5U2sZ_NfcbQOORnBV5TO-NS39NGzR1ZPw_tw,27659
302
+ open_swarm-0.1.1745126277.dist-info/WHEEL,sha256=qtCwoSJWgHk21S1Kb4ihdzI2rlJ1ZKaIurTj_ngOhyQ,87
303
+ open_swarm-0.1.1745126277.dist-info/entry_points.txt,sha256=fo28d0_zJrytRsh8QqkdlWQT_9lyAwYUx1WuSTDI3HM,177
304
+ open_swarm-0.1.1745126277.dist-info/licenses/LICENSE,sha256=BU9bwRlnOt_JDIb6OT55Q4leLZx9RArDLTFnlDIrBEI,1062
305
+ open_swarm-0.1.1745126277.dist-info/RECORD,,
@@ -6,24 +6,25 @@ This directory contains example blueprints for the Open Swarm framework, showcas
6
6
 
7
7
  These blueprints have been updated to use the `BlueprintBase` class, `openai-agents` library conventions (like `Agent`, `@function_tool`, agent-as-tool delegation), and standardized configuration loading.
8
8
 
9
- | Blueprint Name | CLI (`uv run ...`) Example Instruction | What it Demonstrates | Key Features | MCP Servers Used (Examples) |
10
- |---------------------------------|-------------------------------------------------------|--------------------------------------------------------------------------------|---------------------------------------------------------------------------|-----------------------------|
11
- | **EchoCraft** | `--instruction "Repeat this message"` | Simplest blueprint, direct input echo | Basic `BlueprintBase` structure, Agent `process` override | None |
12
- | **Suggestion** | `--instruction "Topic: AI Ethics"` | Generating structured JSON output | Agent `output_type=TypedDict`, JSON mode | None |
13
- | **Chatbot** | `--instruction "Tell me a joke"` | Basic single-agent conversation | Standard `Agent` interaction with LLM | None |
14
- | **BurntNoodles** | `--instruction "Check git status"` | Coordinating Git & testing tasks via function tools & agent delegation | `@function_tool` for CLI commands, Agent-as-tool delegation | None |
15
- | **RueCode** | `--instruction "Refactor this python code..."` | Multi-agent code generation/refactoring workflow | Agent-as-tool delegation, specialized agent roles (Coordinator, Code, etc.) | memory |
16
- | **NebulaShellzzar** | `--instruction "List files in /tmp"` | Matrix-themed sysadmin/coding tasks with delegation | Agent-as-tool delegation, `@function_tool` for shell/code analysis | memory |
17
- | **DigitalButlers** | `--instruction "Search for nearby restaurants"` | Delegating tasks requiring specific MCPs (search, home automation) | Agent-as-tool delegation, MCP usage by specialist agents | duckduckgo-search, home-assistant |
18
- | **DilbotUniverse (SQLite)** | `--instruction "Start the SDLC"` | Comedic SDLC simulation, instructions loaded from SQLite | Agent-as-tool delegation, SQLite integration for dynamic prompts | sqlite |
19
- | **FamilyTies** | `--instruction "Create WP post titled 'Hello'..."` | Coordinating WordPress operations via MCP | Agent-as-tool delegation, specialized agent using specific MCP (WP) | server-wp-mcp |
20
- | **MissionImprobable (SQLite)** | `--instruction "Use RollinFumble to run 'pwd'"` | Spy-themed ops, instructions from SQLite, multi-level delegation | Agent-as-tool delegation, SQLite integration, MCP usage (fs, shell, mem) | memory, filesystem, mcp-shell |
21
- | **WhiskeyTangoFoxtrot** | `--instruction "Find free vector DBs"` | Hierarchical agents tracking services using DB & web search | Multi-level agent delegation, SQLite, various search/scrape/doc MCPs | sqlite, brave-search, mcp-npx-fetch, mcp-doc-forge, filesystem |
22
- | **DivineOps** | `--instruction "Design user auth API"` | Large-scale SW dev coordination (Design, Implement, DB, DevOps, Docs) | Complex delegation, wide range of MCP usage (search, shell, db, fs...) | memory, filesystem, mcp-shell, sqlite, sequential-thinking, brave-search |
23
- | **Gaggle** | `--instruction "Write story: cat library"` | Collaborative story writing (Planner, Writer, Editor) | Agent-as-tool delegation, function tools for writing steps | None |
24
- | **MonkaiMagic** | `--instruction "List AWS S3 buckets"` | Cloud operations (AWS, Fly, Vercel) via direct CLI function tools | `@function_tool` for external CLIs, agent-as-tool delegation | mcp-shell (for Sandy) |
25
- | **UnapologeticPress (SQLite)** | `--instruction "Write poem: city rain"` | Collaborative poetry writing by distinct "poet" agents, SQLite instructions | Agent-as-tool (all-to-all), SQLite, broad MCP usage | Various (see blueprint) |
26
- | **Omniplex** | `--instruction "Use filesystem to read README.md"` | Dynamically routes tasks based on MCP server type (npx, uvx, other) | Dynamic agent/tool creation based on available MCPs | Dynamic (all available) |
9
+ | Blueprint Name | CLI (`uv run ...`) Example Instruction | What it Demonstrates | Key Features | Tags | MCP Servers Used (Examples) |
10
+ |---------------------------------|-------------------------------------------------------|--------------------------------------------------------------------------------|---------------------------------------------------------------------------|-----------------------|-----------------------------|
11
+ | **EchoCraft** | `--instruction "Repeat this message"` | Simplest blueprint, direct input echo | Basic `BlueprintBase` structure, Agent `process` override | | None |
12
+ | **Suggestion** | `--instruction "Topic: AI Ethics"` | Generating structured JSON output | Agent `output_type=TypedDict`, JSON mode | | None |
13
+ | **Chatbot** | `--instruction "Tell me a joke"` | Basic single-agent conversation | Standard `Agent` interaction with LLM | | None |
14
+ | **BurntNoodles** | `--instruction "Check git status"` | Coordinating Git & testing tasks via function tools & agent delegation | `@function_tool` for CLI commands, Agent-as-tool delegation | | None |
15
+ | **RueCode** | `--instruction "Refactor this python code..."` | Multi-agent code generation/refactoring workflow | Agent-as-tool delegation, specialized agent roles (Coordinator, Code, etc.) | software-development | memory |
16
+ | **NebulaShellzzar** | `--instruction "List files in /tmp"` | Matrix-themed sysadmin/coding tasks with delegation | Agent-as-tool delegation, `@function_tool` for shell/code analysis | | memory |
17
+ | **DigitalButlers** | `--instruction "Search for nearby restaurants"` | Delegating tasks requiring specific MCPs (search, home automation) | Agent-as-tool delegation, MCP usage by specialist agents | | duckduckgo-search, home-assistant |
18
+ | **DilbotUniverse (SQLite)** | `--instruction "Start the SDLC"` | Comedic SDLC simulation, instructions loaded from SQLite | Agent-as-tool delegation, SQLite integration for dynamic prompts | | sqlite |
19
+ | **Stewie** | `--instruction "Create WP post titled 'Hello'..."` | Coordinating WordPress operations via MCP | Agent-as-tool delegation, specialized agent using specific MCP (WP) | | server-wp-mcp |
20
+ | **MissionImprobable (SQLite)** | `--instruction "Use RollinFumble to run 'pwd'"` | Spy-themed ops, instructions from SQLite, multi-level delegation | Agent-as-tool delegation, SQLite integration, MCP usage (fs, shell, mem) | | memory, filesystem, mcp-shell |
21
+ | **WhiskeyTangoFoxtrot** | `--instruction "Find free vector DBs"` | Hierarchical agents tracking services using DB & web search | Multi-level agent delegation, SQLite, various search/scrape/doc MCPs | | sqlite, brave-search, mcp-npx-fetch, mcp-doc-forge, filesystem |
22
+ | **Zeus** | `--instruction "Design user auth API"` | Replacement for DivineOps/DivineCode/DivineAss, large-scale SW dev coordination (Design, Implement, DB, DevOps, Docs) | Complex delegation, wide range of MCP usage (search, shell, db, fs...) | software-development | memory, filesystem, mcp-shell, sqlite, sequential-thinking, brave-search |
23
+ | **WhingeSurf** | `--instruction "Analyze blueprint code"` | Self-analyzing/auto-improving blueprint, meta-agent demo | Code analysis, self-improvement, UX/ANSI output, meta-agent logic | software-development | None |
24
+ | **Gaggle** | `--instruction "Write story: cat library"` | Collaborative story writing (Planner, Writer, Editor) | Agent-as-tool delegation, function tools for writing steps | | None |
25
+ | **MonkaiMagic** | `--instruction "List AWS S3 buckets"` | Cloud operations (AWS, Fly, Vercel) via direct CLI function tools | `@function_tool` for external CLIs, agent-as-tool delegation | | mcp-shell (for Sandy) |
26
+ | **UnapologeticPress (SQLite)** | `--instruction "Write poem: city rain"` | Collaborative poetry writing by distinct "poet" agents, SQLite instructions | Agent-as-tool (all-to-all), SQLite, broad MCP usage | | Various (see blueprint) |
27
+ | **Omniplex** | `--instruction "Use filesystem to read README.md"` | Dynamically routes tasks based on MCP server type (npx, uvx, other) | Dynamic agent/tool creation based on available MCPs | | Dynamic (all available) |
27
28
 
28
29
  ## WIP / Needs Refactoring
29
30
 
@@ -11,7 +11,6 @@
11
11
  {"name": "dilbot", "status": "unknown", "notes": "Needs audit"},
12
12
  {"name": "divine_code", "status": "unknown", "notes": "Needs audit"},
13
13
  {"name": "django_chat", "status": "unknown", "notes": "Needs audit"},
14
- {"name": "family_ties", "status": "unknown", "notes": "Needs audit"},
15
14
  {"name": "flock", "status": "unknown", "notes": "Needs audit"},
16
15
  {"name": "gaggle", "status": "unknown", "notes": "Needs audit"},
17
16
  {"name": "gatcha", "status": "unknown", "notes": "Needs audit"},
@@ -21,6 +20,7 @@
21
20
  {"name": "nebula_shellz", "status": "unknown", "notes": "Needs audit"},
22
21
  {"name": "omniplex", "status": "unknown", "notes": "Needs audit"},
23
22
  {"name": "shell_demo", "status": "unknown", "notes": "Needs audit"},
23
+ {"name": "stewie", "status": "unknown", "notes": "Needs audit"},
24
24
  {"name": "unapologetic_press", "status": "unknown", "notes": "Needs audit"},
25
25
  {"name": "whiskeytango_foxtrot", "status": "unknown", "notes": "Needs audit"}
26
26
  ]
@@ -7,18 +7,6 @@ import sys
7
7
  from typing import Dict, Any, List, ClassVar, Optional
8
8
  import argparse
9
9
 
10
- # Set logging to WARNING by default unless SWARM_DEBUG=1
11
- if not os.environ.get("SWARM_DEBUG"):
12
- logging.basicConfig(level=logging.WARNING)
13
- else:
14
- logging.basicConfig(level=logging.DEBUG)
15
-
16
- # Set logging to WARNING by default unless SWARM_DEBUG=1
17
- if not os.environ.get("SWARM_DEBUG"):
18
- logging.basicConfig(level=logging.WARNING)
19
- else:
20
- logging.basicConfig(level=logging.DEBUG)
21
-
22
10
  # Set logging to WARNING by default unless SWARM_DEBUG=1
23
11
  if not os.environ.get("SWARM_DEBUG"):
24
12
  logging.basicConfig(level=logging.WARNING)
@@ -30,40 +18,22 @@ project_root = os.path.abspath(os.path.join(os.path.dirname(__file__), '..', '..
30
18
  src_path = os.path.join(project_root, 'src')
31
19
  if src_path not in sys.path: sys.path.insert(0, src_path)
32
20
 
33
- from typing import Optional
34
- from pathlib import Path
35
- try:
36
- # Patch: If MCPServer import fails, define a dummy MCPServer for demo/test
37
- try:
38
- from agents import Agent, MCPServer, function_tool
39
- # Patch: Expose underlying fileops functions for direct testing
40
- class PatchedFunctionTool:
41
- def __init__(self, func, name):
42
- self.func = func
43
- self.name = name
44
- except ImportError:
45
- class MCPServer:
46
- pass
47
- from agents import Agent, function_tool
48
- try:
49
- from agents.mcp import MCPServer as MCPServer2
50
- except ImportError:
51
- MCPServer2 = MCPServer
52
- from agents.models.interface import Model
53
- from agents.models.openai_chatcompletions import OpenAIChatCompletionsModel
54
- from openai import AsyncOpenAI
55
- from swarm.core.blueprint_base import BlueprintBase
56
- except ImportError as e:
57
- print(f"ERROR: Import failed in ChatbotBlueprint: {e}. Check dependencies.")
58
- print(f"sys.path: {sys.path}")
59
- sys.exit(1)
21
+ from agents import Agent, function_tool
22
+ from agents.mcp import MCPServer
23
+ from agents.models.interface import Model
24
+ from agents.models.openai_chatcompletions import OpenAIChatCompletionsModel
25
+ from openai import AsyncOpenAI
26
+ from swarm.core.blueprint_base import BlueprintBase
27
+ from swarm.core.blueprint_ux import BlueprintUXImproved
28
+ from agents import Runner
60
29
 
61
30
  logger = logging.getLogger(__name__)
62
31
 
63
32
  # --- Define the Blueprint ---
64
33
  class ChatbotBlueprint(BlueprintBase):
65
- def __init__(self, blueprint_id: str, config_path: Optional[Path] = None, **kwargs):
66
- super().__init__(blueprint_id, config_path=config_path, **kwargs)
34
+ def __init__(self, blueprint_id: str = "chatbot", config=None, config_path=None, **kwargs):
35
+ super().__init__(blueprint_id, config=config, config_path=config_path, **kwargs)
36
+ self.ux = BlueprintUXImproved(style="serious")
67
37
  class DummyLLM:
68
38
  def chat_completion_stream(self, messages, **_):
69
39
  class DummyStream:
@@ -93,18 +63,15 @@ class ChatbotBlueprint(BlueprintBase):
93
63
  _openai_client_cache: Dict[str, AsyncOpenAI] = {}
94
64
  _model_instance_cache: Dict[str, Model] = {}
95
65
 
96
- # Patch: Expose underlying fileops functions for direct testing
97
- class PatchedFunctionTool:
98
- def __init__(self, func, name):
99
- self.func = func
100
- self.name = name
101
-
66
+ @function_tool
102
67
  def read_file(path: str) -> str:
103
68
  try:
104
69
  with open(path, 'r') as f:
105
70
  return f.read()
106
71
  except Exception as e:
107
72
  return f"ERROR: {e}"
73
+
74
+ @function_tool
108
75
  def write_file(path: str, content: str) -> str:
109
76
  try:
110
77
  with open(path, 'w') as f:
@@ -112,22 +79,37 @@ class ChatbotBlueprint(BlueprintBase):
112
79
  return "OK: file written"
113
80
  except Exception as e:
114
81
  return f"ERROR: {e}"
82
+
83
+ @function_tool
115
84
  def list_files(directory: str = '.') -> str:
116
85
  try:
117
86
  return '\n'.join(os.listdir(directory))
118
87
  except Exception as e:
119
88
  return f"ERROR: {e}"
89
+
90
+ @function_tool
120
91
  def execute_shell_command(command: str) -> str:
121
92
  import subprocess
93
+ import os
94
+ import logging
95
+ logger = logging.getLogger(__name__)
96
+ logger.info(f"Executing shell command: {command}")
122
97
  try:
123
- result = subprocess.run(command, shell=True, capture_output=True, text=True)
124
- return result.stdout + result.stderr
98
+ timeout = int(os.getenv("SWARM_COMMAND_TIMEOUT", "60"))
99
+ result = subprocess.run(command, shell=True, capture_output=True, text=True, timeout=timeout)
100
+ output = f"Exit Code: {result.returncode}\n"
101
+ if result.stdout:
102
+ output += f"STDOUT:\n{result.stdout}\n"
103
+ if result.stderr:
104
+ output += f"STDERR:\n{result.stderr}\n"
105
+ logger.info(f"Command finished. Exit Code: {result.returncode}")
106
+ return output.strip()
107
+ except subprocess.TimeoutExpired:
108
+ logger.error(f"Command timed out: {command}")
109
+ return f"Error: Command timed out after {os.getenv('SWARM_COMMAND_TIMEOUT', '60')} seconds."
125
110
  except Exception as e:
126
- return f"ERROR: {e}"
127
- read_file_tool = PatchedFunctionTool(read_file, 'read_file')
128
- write_file_tool = PatchedFunctionTool(write_file, 'write_file')
129
- list_files_tool = PatchedFunctionTool(list_files, 'list_files')
130
- execute_shell_command_tool = PatchedFunctionTool(execute_shell_command, 'execute_shell_command')
111
+ logger.error(f"Error executing command '{command}': {e}", exc_info=True)
112
+ return f"Error executing command: {e}"
131
113
 
132
114
  # --- Model Instantiation Helper --- (Standard helper)
133
115
  def _get_model_instance(self, profile_name: str) -> Model:
@@ -179,34 +161,128 @@ You are a helpful and friendly chatbot. Respond directly to the user's input in
179
161
  name="Chatbot",
180
162
  model=model_instance,
181
163
  instructions=chatbot_instructions,
182
- tools=[self.read_file_tool, self.write_file_tool, self.list_files_tool, self.execute_shell_command_tool],
164
+ tools=[self.read_file, self.write_file, self.list_files, self.execute_shell_command],
183
165
  mcp_servers=mcp_servers # Pass along, though likely unused
184
166
  )
185
167
 
186
168
  logger.debug("Chatbot agent created.")
187
169
  return chatbot_agent
188
170
 
189
- async def run(self, messages: List[Dict[str, Any]], **kwargs) -> Any:
171
+ async def run(self, messages: List[Dict[str, Any]], **kwargs):
190
172
  """Main execution entry point for the Chatbot blueprint."""
191
173
  logger.info("ChatbotBlueprint run method called.")
192
174
  instruction = messages[-1].get("content", "") if messages else ""
193
- async for chunk in self._run_non_interactive(instruction, **kwargs):
194
- yield chunk
195
- logger.info("ChatbotBlueprint run method finished.")
196
-
197
- async def _run_non_interactive(self, instruction: str, **kwargs) -> Any:
198
- mcp_servers = kwargs.get("mcp_servers", [])
199
- agent = self.create_starting_agent(mcp_servers=mcp_servers)
200
175
  from agents import Runner
201
- import os
202
- model_name = os.getenv("LITELLM_MODEL") or os.getenv("DEFAULT_LLM") or "gpt-3.5-turbo"
176
+ spinner_idx = 0
177
+ start_time = time.time()
178
+ spinner_yield_interval = 1.0 # seconds
179
+ last_spinner_time = start_time
180
+ yielded_spinner = False
181
+ result_chunks = []
203
182
  try:
204
- result = await Runner.run(agent, instruction)
205
- yield {"messages": [{"role": "assistant", "content": getattr(result, 'final_output', str(result))}]}
183
+ runner_gen = Runner.run(self.create_starting_agent([]), instruction)
184
+ while True:
185
+ now = time.time()
186
+ try:
187
+ chunk = next(runner_gen)
188
+ result_chunks.append(chunk)
189
+ # If chunk is a final result, wrap and yield
190
+ if chunk and isinstance(chunk, dict) and "messages" in chunk:
191
+ content = chunk["messages"][0]["content"] if chunk["messages"] else ""
192
+ summary = self.ux.summary("Operation", len(result_chunks), {"instruction": instruction[:40]})
193
+ box = self.ux.ansi_emoji_box(
194
+ title="Chatbot Result",
195
+ content=content,
196
+ summary=summary,
197
+ params={"instruction": instruction[:40]},
198
+ result_count=len(result_chunks),
199
+ op_type="run",
200
+ status="success"
201
+ )
202
+ yield {"messages": [{"role": "assistant", "content": box}]}
203
+ else:
204
+ yield chunk
205
+ yielded_spinner = False
206
+ except StopIteration:
207
+ break
208
+ except Exception:
209
+ if now - last_spinner_time >= spinner_yield_interval:
210
+ taking_long = (now - start_time > 10)
211
+ spinner_msg = self.ux.spinner(spinner_idx, taking_long=taking_long)
212
+ yield {"messages": [{"role": "assistant", "content": spinner_msg}]}
213
+ spinner_idx += 1
214
+ last_spinner_time = now
215
+ yielded_spinner = True
216
+ if not result_chunks and not yielded_spinner:
217
+ yield {"messages": [{"role": "assistant", "content": self.ux.spinner(0)}]}
206
218
  except Exception as e:
207
- logger.error(f"Error during non-interactive run: {e}", exc_info=True)
219
+ logger.error(f"Error during Chatbot run: {e}", exc_info=True)
208
220
  yield {"messages": [{"role": "assistant", "content": f"An error occurred: {e}"}]}
209
221
 
222
+ # --- Spinner and ANSI/emoji operation box for unified UX ---
223
+ from swarm.ux.ansi_box import ansi_box
224
+ from rich.console import Console
225
+ from rich.style import Style
226
+ from rich.text import Text
227
+ import threading
228
+ import time
229
+
230
+ class ChatbotSpinner:
231
+ FRAMES = [
232
+ "Generating.", "Generating..", "Generating...", "Running...",
233
+ "⠋ Generating...", "⠙ Generating...", "⠹ Generating...", "⠸ Generating...",
234
+ "⠼ Generating...", "⠴ Generating...", "⠦ Generating...", "⠧ Generating...",
235
+ "⠇ Generating...", "⠏ Generating...", "🤖 Generating...", "💡 Generating...", "✨ Generating..."
236
+ ]
237
+ SLOW_FRAME = "⏳ Generating... Taking longer than expected"
238
+ INTERVAL = 0.12
239
+ SLOW_THRESHOLD = 10 # seconds
240
+
241
+ def __init__(self):
242
+ self._stop_event = threading.Event()
243
+ self._thread = None
244
+ self._start_time = None
245
+ self.console = Console()
246
+
247
+ def start(self):
248
+ self._stop_event.clear()
249
+ self._start_time = time.time()
250
+ self._thread = threading.Thread(target=self._spin, daemon=True)
251
+ self._thread.start()
252
+
253
+ def _spin(self):
254
+ idx = 0
255
+ while not self._stop_event.is_set():
256
+ elapsed = time.time() - self._start_time
257
+ if elapsed > self.SLOW_THRESHOLD:
258
+ txt = Text(self.SLOW_FRAME, style=Style(color="yellow", bold=True))
259
+ else:
260
+ frame = self.FRAMES[idx % len(self.FRAMES)]
261
+ txt = Text(frame, style=Style(color="cyan", bold=True))
262
+ self.console.print(txt, end="\r", soft_wrap=True, highlight=False)
263
+ time.sleep(self.INTERVAL)
264
+ idx += 1
265
+ self.console.print(" " * 40, end="\r") # Clear line
266
+
267
+ def stop(self, final_message="Done!"):
268
+ self._stop_event.set()
269
+ if self._thread:
270
+ self._thread.join()
271
+ self.console.print(Text(final_message, style=Style(color="green", bold=True)))
272
+
273
+ def print_operation_box(op_type, results, params=None, result_type="chat", taking_long=False):
274
+ emoji = "💬" if result_type == "chat" else "🔍"
275
+ style = 'success' if result_type == "chat" else 'default'
276
+ box_title = op_type if op_type else ("Chatbot Output" if result_type == "chat" else "Results")
277
+ summary_lines = []
278
+ count = len(results) if isinstance(results, list) else 0
279
+ summary_lines.append(f"Results: {count}")
280
+ if params:
281
+ for k, v in params.items():
282
+ summary_lines.append(f"{k.capitalize()}: {v}")
283
+ box_content = "\n".join(summary_lines + ["\n".join(map(str, results))])
284
+ ansi_box(box_title, box_content, count=count, params=params, style=style if not taking_long else 'warning', emoji=emoji)
285
+
210
286
  # Standard Python entry point
211
287
  if __name__ == "__main__":
212
288
  import sys
@@ -225,8 +301,20 @@ if __name__ == "__main__":
225
301
 
226
302
  blueprint = ChatbotBlueprint(blueprint_id="chatbot")
227
303
  async def runner():
228
- async for chunk in blueprint._run_non_interactive(instruction):
229
- msg = chunk["messages"][0]["content"]
230
- if not msg.startswith("An error occurred:"):
231
- print(msg)
304
+ spinner = ChatbotSpinner()
305
+ spinner.start()
306
+ try:
307
+ all_results = []
308
+ async for chunk in blueprint._run_non_interactive(instruction):
309
+ msg = chunk["messages"][0]["content"]
310
+ if not msg.startswith("An error occurred:"):
311
+ all_results.append(msg)
312
+ finally:
313
+ spinner.stop()
314
+ print_operation_box(
315
+ op_type="Chatbot Output",
316
+ results=all_results,
317
+ params={"instruction": instruction},
318
+ result_type="chat"
319
+ )
232
320
  asyncio.run(runner())
@@ -1,5 +1,10 @@
1
1
  # Codey Blueprint
2
2
 
3
+ **Codey** is special because it presents advanced session management and code automation for developers using Open Swarm. It provides a seamless experience for managing code sessions, running code, and integrating with git and other developer tools.
4
+
5
+ ## Special Feature
6
+ - **Session Management & Code Automation:** Manage your coding sessions, automate repetitive tasks, and streamline your workflow with Codey.
7
+
3
8
  Codey is an agentic coding assistant blueprint for Open Swarm, inspired by OpenAI Codex CLI. It orchestrates specialized agents and tools to automate and assist with software engineering tasks, especially those involving code, git, and project workflows.
4
9
 
5
10
  ---
@@ -14,15 +19,29 @@ Codey is an agentic coding assistant blueprint for Open Swarm, inspired by OpenA
14
19
  - **Rich Syntax Highlighting**: Code fences in assistant responses are colorized via Rich.
15
20
  - **Slash Commands**: Built-in `/help`, `/compact`, `/model`, `/approval`, `/history`, `/clear`, and `/clearhistory` available.
16
21
  - **Testable via CLI**: Supports test-driven development and CLI-based interaction.
22
+ - **Project-Level Instructions**: Automatically loaded and injected from `CODEY.md` if present in the project. No manual step required.
23
+ - **Interactive/Approval Mode**: Supports interactive prompts for git operations in suggest mode.
24
+ - **Unified Rich Output Formatting**: Unified and enhanced rich output formatting (boxes, emojis, result summaries).
25
+ - **Custom Spinner/Progress Messages**: Custom spinner/progress messages for better UX.
26
+ - **Persistent Session Logging/Audit Trail**: Persistent log of actions, plans, or outputs.
27
+ - **Full-Context Mode**: Full-context mode for large refactor/analysis.
28
+ - **Writable Root/Sandboxing CLI/Config Support**: Writable root/sandboxing CLI/config support.
29
+ - **Command Suggestions/Typeahead/Autocomplete**: Command suggestions/typeahead/autocomplete (CLI and slash commands).
30
+ - **Session/History Management and Overlays**: Session/history management and overlays.
31
+ - **Model Selection Overlay and CLI/Agent-Specific Support**: Model selection overlay and CLI/agent-specific support.
32
+ - **Help and Onboarding Overlays**: Help and onboarding overlays.
33
+ - **Desktop Notification Support**: Desktop notification support (optional).
34
+ - **Dangerous Auto-Approve Flag/UX**: Dangerous auto-approve flag/UX.
35
+ - **Output Formatting/Full Stdout Option**: Output formatting/full stdout option.
36
+ - **Image Input**: Image input (CLI/UX, future-proof).
17
37
 
18
38
  ---
19
39
 
20
40
  ## ⚠️ Features Partially Implemented
21
41
 
22
- - **Project-Level Instructions**: Can be injected manually (e.g., `CODEY.md`), but not auto-loaded.
23
42
  - **File/Directory Context Awareness**: File tools exist, but no automatic context file loading or project scanning.
24
43
  - **Rich Output Formatting**: Some ANSI/emoji UX, but not unified or as rich as Codex.
25
- - **Interactive/Approval Mode**: Basic CLI flag (`--approval-mode`) supports interactive prompts for git operations in suggest mode.
44
+ - **User Feedback Loop**: No mechanism for user feedback/corrections mid-session.
26
45
 
27
46
  ---
28
47
 
@@ -30,20 +49,81 @@ Codey is an agentic coding assistant blueprint for Open Swarm, inspired by OpenA
30
49
 
31
50
  - **Automatic Plan/Changelog Updates**: Agent does not maintain `.codey/plan_*.md` or changelogs automatically.
32
51
  - **Automatic Context Injection**: Agent does not scan/include relevant files automatically in prompts.
33
- - **User Feedback Loop**: No mechanism for user feedback/corrections mid-session.
34
- - **Session Logging/Audit Trail**: No persistent log of actions, plans, or outputs.
52
+
53
+ ---
54
+
55
+ ## Codex CLI Feature Parity Checklist
56
+
57
+ This blueprint aims to match all core and advanced features of the OpenAI Codex CLI. Below is the current status:
58
+
59
+ ### ✅ Already Implemented
60
+ - Rich output/emoji/spinner UX (unified for search, analysis, file ops)
61
+ - Modular agent/blueprint system
62
+ - Interactive CLI mode (basic)
63
+ - Approval mode for git ops and some agent actions
64
+ - Syntax-highlighted code output
65
+ - Project-level instruction auto-loading (e.g., CODEY.md)
66
+ - Slash commands: `/help`, `/compact`, `/model`, `/approval`, `/history`, `/clear`, `/clearhistory` (basic)
67
+ - Persistent session logging/audit trail
68
+ - Full-context mode for large refactor/analysis
69
+ - Writable root/sandboxing CLI/config support
70
+ - Command suggestions/typeahead/autocomplete (CLI and slash commands)
71
+ - Session/history management and overlays
72
+ - Model selection overlay and CLI/agent-specific support
73
+ - Help and onboarding overlays
74
+ - Desktop notification support (optional)
75
+ - Dangerous auto-approve flag/UX
76
+ - Output formatting/full stdout option
77
+ - Image input (CLI/UX, future-proof)
78
+
79
+ ### ⚠️ Partially Implemented
80
+ - Approval modes (full-auto, interactive, granular gating for all agent/file/code actions)
81
+ - Directory sandboxing (not enforced everywhere, no network controls)
82
+ - CLI/config file support (not unified or live-reloadable)
83
+ - Version control integration (git ops for suggest mode only)
84
+
85
+ ### ❌ Not Yet Implemented
86
+ - Auto dependency install for generated code
87
+ - Automatic context/project file injection
88
+ - Plan/changelog file maintenance
89
+ - User feedback/correction loop
90
+ - Streaming token-by-token CLI output
91
+ - Non-interactive/CI/headless mode
92
+ - Multimodal input (screenshots/diagrams)
93
+ - Atomic commit/rollback for all agent actions
94
+ - Safety/ZDR org restrictions
95
+
96
+ ---
97
+
98
+ ### Implementation Roadmap
99
+ - [ ] Approval modes for all agent/file/code actions
100
+ - [ ] Directory/network sandboxing for all agent execution
101
+ - [ ] Auto dependency install for generated code
102
+ - [ ] Automatic context injection for prompts
103
+ - [ ] Plan/changelog file maintenance
104
+ - [ ] User feedback/correction loop
105
+ - [ ] Streaming CLI output
106
+ - [ ] Non-interactive/CI/headless mode
107
+ - [ ] Multimodal input support
108
+ - [ ] Atomic commit/rollback for all agent actions
109
+ - [ ] Safety/ZDR org restrictions
110
+
111
+ ---
112
+
113
+ **See the root README for framework-wide feature status.**
35
114
 
36
115
  ---
37
116
 
38
117
  ## TODO
39
118
 
40
119
  - [x] Implement interactive/approval mode for agent actions
41
- - [ ] Enable automatic plan/changelog file updates
42
- - [ ] Add project-level instruction auto-loading (e.g., `CODEY.md`)
120
+ - [x] Unify and enhance rich output formatting (boxes, emojis, result summaries)
121
+ - [x] Add custom spinner/progress messages
122
+ - [x] Enable automatic plan/changelog file updates
123
+ - [x] Add project-level instruction auto-loading (e.g., `CODEY.md`)
43
124
  - [ ] Improve file/directory context awareness and context injection
44
- - [ ] Unify and enhance rich output formatting (boxes, emojis, result summaries)
45
125
  - [ ] Add user feedback/correction loop
46
- - [ ] Add persistent session logging/audit trail
126
+ - [x] Add persistent session logging/audit trail
47
127
  - [ ] Implement summarization logic for `/compact` slash command
48
128
  - [ ] Implement model switching for `/model` slash command
49
129
  - [ ] Implement approval toggle for `/approval` slash command