cli-jaw 0.1.7 → 0.1.8

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 (744) hide show
  1. package/README.ko.md +68 -71
  2. package/README.md +65 -79
  3. package/README.zh-CN.md +68 -73
  4. package/dist/bin/cli-claw.js +96 -0
  5. package/dist/bin/cli-claw.js.map +1 -0
  6. package/dist/bin/cli-jaw.js +0 -0
  7. package/dist/bin/commands/init.js +36 -19
  8. package/dist/bin/commands/init.js.map +1 -1
  9. package/dist/bin/postinstall.js +175 -104
  10. package/dist/bin/postinstall.js.map +1 -1
  11. package/dist/lib/mcp-sync.js +43 -4
  12. package/dist/lib/mcp-sync.js.map +1 -1
  13. package/dist/server.js +22 -103
  14. package/dist/server.js.map +1 -1
  15. package/dist/src/cli/acp-client.js +1 -1
  16. package/dist/src/cli/command-context.js +73 -0
  17. package/dist/src/cli/command-context.js.map +1 -0
  18. package/dist/src/core/db.js +1 -1
  19. package/dist/src/memory/heartbeat.js +2 -1
  20. package/dist/src/memory/heartbeat.js.map +1 -1
  21. package/dist/src/orchestrator/collect.js +53 -0
  22. package/dist/src/orchestrator/collect.js.map +1 -0
  23. package/dist/src/orchestrator/gateway.js +49 -0
  24. package/dist/src/orchestrator/gateway.js.map +1 -0
  25. package/dist/src/telegram/bot.js +32 -119
  26. package/dist/src/telegram/bot.js.map +1 -1
  27. package/package.json +7 -7
  28. package/public/css/sidebar.css +14 -0
  29. package/public/dist/bundle.js +21 -21
  30. package/public/dist/bundle.js.map +3 -3
  31. package/public/index.html +2 -2
  32. package/public/js/features/settings.js +1 -2
  33. package/public/js/main.js +0 -1
  34. package/scripts/check-copilot-gap.js +57 -0
  35. package/scripts/check-deps-offline.mjs +75 -0
  36. package/scripts/check-deps-online.sh +26 -0
  37. package/scripts/i18n-registry.py +208 -0
  38. package/scripts/postinstall-guard.cjs +63 -0
  39. package/scripts/release.sh +30 -0
  40. package/skills_ref/1password/SKILL.md +0 -70
  41. package/skills_ref/agents-sdk/SKILL.md +0 -155
  42. package/skills_ref/agents-sdk/references/callable.md +0 -92
  43. package/skills_ref/agents-sdk/references/codemode.md +0 -207
  44. package/skills_ref/agents-sdk/references/email.md +0 -146
  45. package/skills_ref/agents-sdk/references/mcp.md +0 -154
  46. package/skills_ref/agents-sdk/references/state-scheduling.md +0 -164
  47. package/skills_ref/agents-sdk/references/streaming-chat.md +0 -178
  48. package/skills_ref/agents-sdk/references/workflows.md +0 -132
  49. package/skills_ref/algorithmic-art/LICENSE.txt +0 -202
  50. package/skills_ref/algorithmic-art/SKILL.md +0 -405
  51. package/skills_ref/algorithmic-art/templates/generator_template.js +0 -223
  52. package/skills_ref/algorithmic-art/templates/viewer.html +0 -599
  53. package/skills_ref/apple-notes/SKILL.md +0 -77
  54. package/skills_ref/apple-reminders/SKILL.md +0 -118
  55. package/skills_ref/atlas/SKILL.md +0 -99
  56. package/skills_ref/brainstorming/SKILL.md +0 -96
  57. package/skills_ref/browser/SKILL.md +0 -179
  58. package/skills_ref/canvas-design/LICENSE.txt +0 -202
  59. package/skills_ref/canvas-design/SKILL.md +0 -130
  60. package/skills_ref/canvas-design/canvas-fonts/ArsenalSC-OFL.txt +0 -93
  61. package/skills_ref/canvas-design/canvas-fonts/ArsenalSC-Regular.ttf +0 -0
  62. package/skills_ref/canvas-design/canvas-fonts/BigShoulders-Bold.ttf +0 -0
  63. package/skills_ref/canvas-design/canvas-fonts/BigShoulders-OFL.txt +0 -93
  64. package/skills_ref/canvas-design/canvas-fonts/BigShoulders-Regular.ttf +0 -0
  65. package/skills_ref/canvas-design/canvas-fonts/Boldonse-OFL.txt +0 -93
  66. package/skills_ref/canvas-design/canvas-fonts/Boldonse-Regular.ttf +0 -0
  67. package/skills_ref/canvas-design/canvas-fonts/BricolageGrotesque-Bold.ttf +0 -0
  68. package/skills_ref/canvas-design/canvas-fonts/BricolageGrotesque-OFL.txt +0 -93
  69. package/skills_ref/canvas-design/canvas-fonts/BricolageGrotesque-Regular.ttf +0 -0
  70. package/skills_ref/canvas-design/canvas-fonts/CrimsonPro-Bold.ttf +0 -0
  71. package/skills_ref/canvas-design/canvas-fonts/CrimsonPro-Italic.ttf +0 -0
  72. package/skills_ref/canvas-design/canvas-fonts/CrimsonPro-OFL.txt +0 -93
  73. package/skills_ref/canvas-design/canvas-fonts/CrimsonPro-Regular.ttf +0 -0
  74. package/skills_ref/canvas-design/canvas-fonts/DMMono-OFL.txt +0 -93
  75. package/skills_ref/canvas-design/canvas-fonts/DMMono-Regular.ttf +0 -0
  76. package/skills_ref/canvas-design/canvas-fonts/EricaOne-OFL.txt +0 -94
  77. package/skills_ref/canvas-design/canvas-fonts/EricaOne-Regular.ttf +0 -0
  78. package/skills_ref/canvas-design/canvas-fonts/GeistMono-Bold.ttf +0 -0
  79. package/skills_ref/canvas-design/canvas-fonts/GeistMono-OFL.txt +0 -93
  80. package/skills_ref/canvas-design/canvas-fonts/GeistMono-Regular.ttf +0 -0
  81. package/skills_ref/canvas-design/canvas-fonts/Gloock-OFL.txt +0 -93
  82. package/skills_ref/canvas-design/canvas-fonts/Gloock-Regular.ttf +0 -0
  83. package/skills_ref/canvas-design/canvas-fonts/IBMPlexMono-Bold.ttf +0 -0
  84. package/skills_ref/canvas-design/canvas-fonts/IBMPlexMono-OFL.txt +0 -93
  85. package/skills_ref/canvas-design/canvas-fonts/IBMPlexMono-Regular.ttf +0 -0
  86. package/skills_ref/canvas-design/canvas-fonts/IBMPlexSerif-Bold.ttf +0 -0
  87. package/skills_ref/canvas-design/canvas-fonts/IBMPlexSerif-BoldItalic.ttf +0 -0
  88. package/skills_ref/canvas-design/canvas-fonts/IBMPlexSerif-Italic.ttf +0 -0
  89. package/skills_ref/canvas-design/canvas-fonts/IBMPlexSerif-Regular.ttf +0 -0
  90. package/skills_ref/canvas-design/canvas-fonts/InstrumentSans-Bold.ttf +0 -0
  91. package/skills_ref/canvas-design/canvas-fonts/InstrumentSans-BoldItalic.ttf +0 -0
  92. package/skills_ref/canvas-design/canvas-fonts/InstrumentSans-Italic.ttf +0 -0
  93. package/skills_ref/canvas-design/canvas-fonts/InstrumentSans-OFL.txt +0 -93
  94. package/skills_ref/canvas-design/canvas-fonts/InstrumentSans-Regular.ttf +0 -0
  95. package/skills_ref/canvas-design/canvas-fonts/InstrumentSerif-Italic.ttf +0 -0
  96. package/skills_ref/canvas-design/canvas-fonts/InstrumentSerif-Regular.ttf +0 -0
  97. package/skills_ref/canvas-design/canvas-fonts/Italiana-OFL.txt +0 -93
  98. package/skills_ref/canvas-design/canvas-fonts/Italiana-Regular.ttf +0 -0
  99. package/skills_ref/canvas-design/canvas-fonts/JetBrainsMono-Bold.ttf +0 -0
  100. package/skills_ref/canvas-design/canvas-fonts/JetBrainsMono-OFL.txt +0 -93
  101. package/skills_ref/canvas-design/canvas-fonts/JetBrainsMono-Regular.ttf +0 -0
  102. package/skills_ref/canvas-design/canvas-fonts/Jura-Light.ttf +0 -0
  103. package/skills_ref/canvas-design/canvas-fonts/Jura-Medium.ttf +0 -0
  104. package/skills_ref/canvas-design/canvas-fonts/Jura-OFL.txt +0 -93
  105. package/skills_ref/canvas-design/canvas-fonts/LibreBaskerville-OFL.txt +0 -93
  106. package/skills_ref/canvas-design/canvas-fonts/LibreBaskerville-Regular.ttf +0 -0
  107. package/skills_ref/canvas-design/canvas-fonts/Lora-Bold.ttf +0 -0
  108. package/skills_ref/canvas-design/canvas-fonts/Lora-BoldItalic.ttf +0 -0
  109. package/skills_ref/canvas-design/canvas-fonts/Lora-Italic.ttf +0 -0
  110. package/skills_ref/canvas-design/canvas-fonts/Lora-OFL.txt +0 -93
  111. package/skills_ref/canvas-design/canvas-fonts/Lora-Regular.ttf +0 -0
  112. package/skills_ref/canvas-design/canvas-fonts/NationalPark-Bold.ttf +0 -0
  113. package/skills_ref/canvas-design/canvas-fonts/NationalPark-OFL.txt +0 -93
  114. package/skills_ref/canvas-design/canvas-fonts/NationalPark-Regular.ttf +0 -0
  115. package/skills_ref/canvas-design/canvas-fonts/NothingYouCouldDo-OFL.txt +0 -93
  116. package/skills_ref/canvas-design/canvas-fonts/NothingYouCouldDo-Regular.ttf +0 -0
  117. package/skills_ref/canvas-design/canvas-fonts/Outfit-Bold.ttf +0 -0
  118. package/skills_ref/canvas-design/canvas-fonts/Outfit-OFL.txt +0 -93
  119. package/skills_ref/canvas-design/canvas-fonts/Outfit-Regular.ttf +0 -0
  120. package/skills_ref/canvas-design/canvas-fonts/PixelifySans-Medium.ttf +0 -0
  121. package/skills_ref/canvas-design/canvas-fonts/PixelifySans-OFL.txt +0 -93
  122. package/skills_ref/canvas-design/canvas-fonts/PoiretOne-OFL.txt +0 -93
  123. package/skills_ref/canvas-design/canvas-fonts/PoiretOne-Regular.ttf +0 -0
  124. package/skills_ref/canvas-design/canvas-fonts/RedHatMono-Bold.ttf +0 -0
  125. package/skills_ref/canvas-design/canvas-fonts/RedHatMono-OFL.txt +0 -93
  126. package/skills_ref/canvas-design/canvas-fonts/RedHatMono-Regular.ttf +0 -0
  127. package/skills_ref/canvas-design/canvas-fonts/Silkscreen-OFL.txt +0 -93
  128. package/skills_ref/canvas-design/canvas-fonts/Silkscreen-Regular.ttf +0 -0
  129. package/skills_ref/canvas-design/canvas-fonts/SmoochSans-Medium.ttf +0 -0
  130. package/skills_ref/canvas-design/canvas-fonts/SmoochSans-OFL.txt +0 -93
  131. package/skills_ref/canvas-design/canvas-fonts/Tektur-Medium.ttf +0 -0
  132. package/skills_ref/canvas-design/canvas-fonts/Tektur-OFL.txt +0 -93
  133. package/skills_ref/canvas-design/canvas-fonts/Tektur-Regular.ttf +0 -0
  134. package/skills_ref/canvas-design/canvas-fonts/WorkSans-Bold.ttf +0 -0
  135. package/skills_ref/canvas-design/canvas-fonts/WorkSans-BoldItalic.ttf +0 -0
  136. package/skills_ref/canvas-design/canvas-fonts/WorkSans-Italic.ttf +0 -0
  137. package/skills_ref/canvas-design/canvas-fonts/WorkSans-OFL.txt +0 -93
  138. package/skills_ref/canvas-design/canvas-fonts/WorkSans-Regular.ttf +0 -0
  139. package/skills_ref/canvas-design/canvas-fonts/YoungSerif-OFL.txt +0 -93
  140. package/skills_ref/canvas-design/canvas-fonts/YoungSerif-Regular.ttf +0 -0
  141. package/skills_ref/changelog-generator/SKILL.md +0 -104
  142. package/skills_ref/cloudflare-deploy/SKILL.md +0 -207
  143. package/skills_ref/codebase-orientation/SKILL.md +0 -29
  144. package/skills_ref/config-file-explainer/SKILL.md +0 -26
  145. package/skills_ref/context-compression/SKILL.md +0 -265
  146. package/skills_ref/context-compression/references/evaluation-framework.md +0 -213
  147. package/skills_ref/context-compression/scripts/compression_evaluator.py +0 -658
  148. package/skills_ref/data-structure-chooser/SKILL.md +0 -26
  149. package/skills_ref/debugging-checklist/SKILL.md +0 -26
  150. package/skills_ref/debugging-helpers/CREATION-LOG.md +0 -119
  151. package/skills_ref/debugging-helpers/SKILL.md +0 -296
  152. package/skills_ref/debugging-helpers/condition-based-waiting-example.ts +0 -158
  153. package/skills_ref/debugging-helpers/condition-based-waiting.md +0 -115
  154. package/skills_ref/debugging-helpers/defense-in-depth.md +0 -122
  155. package/skills_ref/debugging-helpers/find-polluter.sh +0 -63
  156. package/skills_ref/debugging-helpers/root-cause-tracing.md +0 -169
  157. package/skills_ref/debugging-helpers/test-academic.md +0 -14
  158. package/skills_ref/debugging-helpers/test-pressure-1.md +0 -58
  159. package/skills_ref/debugging-helpers/test-pressure-2.md +0 -68
  160. package/skills_ref/debugging-helpers/test-pressure-3.md +0 -69
  161. package/skills_ref/deep-research/.env.example +0 -7
  162. package/skills_ref/deep-research/README.md +0 -246
  163. package/skills_ref/deep-research/SKILL.md +0 -106
  164. package/skills_ref/deep-research/requirements.txt +0 -2
  165. package/skills_ref/deep-research/scripts/research.py +0 -692
  166. package/skills_ref/dependency-install-helper/SKILL.md +0 -26
  167. package/skills_ref/dev/SKILL.md +0 -65
  168. package/skills_ref/dev-backend/SKILL.md +0 -61
  169. package/skills_ref/dev-data/SKILL.md +0 -76
  170. package/skills_ref/dev-frontend/LICENSE.txt +0 -177
  171. package/skills_ref/dev-frontend/SKILL.md +0 -42
  172. package/skills_ref/dev-testing/LICENSE.txt +0 -202
  173. package/skills_ref/dev-testing/SKILL.md +0 -96
  174. package/skills_ref/dev-testing/examples/console_logging.py +0 -35
  175. package/skills_ref/dev-testing/examples/element_discovery.py +0 -40
  176. package/skills_ref/dev-testing/examples/static_html_automation.py +0 -33
  177. package/skills_ref/dev-testing/scripts/with_server.py +0 -106
  178. package/skills_ref/develop-web-game/SKILL.md +0 -149
  179. package/skills_ref/differential-review/.claude-plugin/plugin.json +0 -10
  180. package/skills_ref/differential-review/README.md +0 -109
  181. package/skills_ref/differential-review/commands/diff-review.md +0 -21
  182. package/skills_ref/differential-review/skills/differential-review/SKILL.md +0 -220
  183. package/skills_ref/differential-review/skills/differential-review/adversarial.md +0 -203
  184. package/skills_ref/differential-review/skills/differential-review/methodology.md +0 -234
  185. package/skills_ref/differential-review/skills/differential-review/patterns.md +0 -300
  186. package/skills_ref/differential-review/skills/differential-review/reporting.md +0 -369
  187. package/skills_ref/dispatching-parallel-agents/SKILL.md +0 -180
  188. package/skills_ref/doc-coauthoring/SKILL.md +0 -375
  189. package/skills_ref/docx/LICENSE.txt +0 -30
  190. package/skills_ref/docx/SKILL.md +0 -481
  191. package/skills_ref/docx/scripts/__init__.py +0 -1
  192. package/skills_ref/docx/scripts/accept_changes.py +0 -135
  193. package/skills_ref/docx/scripts/comment.py +0 -318
  194. package/skills_ref/docx/scripts/office/helpers/__init__.py +0 -0
  195. package/skills_ref/docx/scripts/office/helpers/merge_runs.py +0 -199
  196. package/skills_ref/docx/scripts/office/helpers/simplify_redlines.py +0 -197
  197. package/skills_ref/docx/scripts/office/pack.py +0 -159
  198. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +0 -1499
  199. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +0 -146
  200. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +0 -1085
  201. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +0 -11
  202. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-main.xsd +0 -3081
  203. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +0 -23
  204. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +0 -185
  205. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +0 -287
  206. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/pml.xsd +0 -1676
  207. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +0 -28
  208. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +0 -144
  209. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +0 -174
  210. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +0 -25
  211. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +0 -18
  212. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +0 -59
  213. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +0 -56
  214. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +0 -195
  215. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-math.xsd +0 -582
  216. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +0 -25
  217. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/sml.xsd +0 -4439
  218. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-main.xsd +0 -570
  219. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +0 -509
  220. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +0 -12
  221. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +0 -108
  222. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +0 -96
  223. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/wml.xsd +0 -3646
  224. package/skills_ref/docx/scripts/office/schemas/ISO-IEC29500-4_2016/xml.xsd +0 -116
  225. package/skills_ref/docx/scripts/office/schemas/ecma/fouth-edition/opc-contentTypes.xsd +0 -42
  226. package/skills_ref/docx/scripts/office/schemas/ecma/fouth-edition/opc-coreProperties.xsd +0 -50
  227. package/skills_ref/docx/scripts/office/schemas/ecma/fouth-edition/opc-digSig.xsd +0 -49
  228. package/skills_ref/docx/scripts/office/schemas/ecma/fouth-edition/opc-relationships.xsd +0 -33
  229. package/skills_ref/docx/scripts/office/schemas/mce/mc.xsd +0 -75
  230. package/skills_ref/docx/scripts/office/schemas/microsoft/wml-2010.xsd +0 -560
  231. package/skills_ref/docx/scripts/office/schemas/microsoft/wml-2012.xsd +0 -67
  232. package/skills_ref/docx/scripts/office/schemas/microsoft/wml-2018.xsd +0 -14
  233. package/skills_ref/docx/scripts/office/schemas/microsoft/wml-cex-2018.xsd +0 -20
  234. package/skills_ref/docx/scripts/office/schemas/microsoft/wml-cid-2016.xsd +0 -13
  235. package/skills_ref/docx/scripts/office/schemas/microsoft/wml-sdtdatahash-2020.xsd +0 -4
  236. package/skills_ref/docx/scripts/office/schemas/microsoft/wml-symex-2015.xsd +0 -8
  237. package/skills_ref/docx/scripts/office/soffice.py +0 -183
  238. package/skills_ref/docx/scripts/office/unpack.py +0 -132
  239. package/skills_ref/docx/scripts/office/validate.py +0 -111
  240. package/skills_ref/docx/scripts/office/validators/__init__.py +0 -15
  241. package/skills_ref/docx/scripts/office/validators/base.py +0 -847
  242. package/skills_ref/docx/scripts/office/validators/docx.py +0 -446
  243. package/skills_ref/docx/scripts/office/validators/pptx.py +0 -275
  244. package/skills_ref/docx/scripts/office/validators/redlining.py +0 -247
  245. package/skills_ref/docx/scripts/templates/comments.xml +0 -3
  246. package/skills_ref/docx/scripts/templates/commentsExtended.xml +0 -3
  247. package/skills_ref/docx/scripts/templates/commentsExtensible.xml +0 -3
  248. package/skills_ref/docx/scripts/templates/commentsIds.xml +0 -3
  249. package/skills_ref/docx/scripts/templates/people.xml +0 -3
  250. package/skills_ref/durable-objects/SKILL.md +0 -186
  251. package/skills_ref/durable-objects/references/rules.md +0 -286
  252. package/skills_ref/durable-objects/references/testing.md +0 -264
  253. package/skills_ref/durable-objects/references/workers.md +0 -346
  254. package/skills_ref/email-draft-polish/SKILL.md +0 -24
  255. package/skills_ref/error-message-explainer/SKILL.md +0 -27
  256. package/skills_ref/fal-image-edit/SKILL.md +0 -249
  257. package/skills_ref/fal-image-edit/scripts/edit-image.sh +0 -199
  258. package/skills_ref/figma-implement-design/SKILL.md +0 -264
  259. package/skills_ref/git-worktrees/SKILL.md +0 -218
  260. package/skills_ref/github/SKILL.md +0 -210
  261. package/skills_ref/gog/SKILL.md +0 -116
  262. package/skills_ref/goplaces/SKILL.md +0 -52
  263. package/skills_ref/himalaya/SKILL.md +0 -257
  264. package/skills_ref/hugging-face-cli/SKILL.md +0 -186
  265. package/skills_ref/hugging-face-cli/references/commands.md +0 -954
  266. package/skills_ref/hugging-face-cli/references/examples.md +0 -374
  267. package/skills_ref/hugging-face-evaluation/SKILL.md +0 -651
  268. package/skills_ref/hugging-face-evaluation/examples/.env.example +0 -7
  269. package/skills_ref/hugging-face-evaluation/examples/USAGE_EXAMPLES.md +0 -382
  270. package/skills_ref/hugging-face-evaluation/examples/artificial_analysis_to_hub.py +0 -141
  271. package/skills_ref/hugging-face-evaluation/examples/example_readme_tables.md +0 -135
  272. package/skills_ref/hugging-face-evaluation/examples/metric_mapping.json +0 -50
  273. package/skills_ref/hugging-face-evaluation/requirements.txt +0 -20
  274. package/skills_ref/hugging-face-evaluation/scripts/evaluation_manager.py +0 -1374
  275. package/skills_ref/hugging-face-evaluation/scripts/inspect_eval_uv.py +0 -104
  276. package/skills_ref/hugging-face-evaluation/scripts/inspect_vllm_uv.py +0 -317
  277. package/skills_ref/hugging-face-evaluation/scripts/lighteval_vllm_uv.py +0 -303
  278. package/skills_ref/hugging-face-evaluation/scripts/run_eval_job.py +0 -98
  279. package/skills_ref/hugging-face-evaluation/scripts/run_vllm_eval_job.py +0 -331
  280. package/skills_ref/hugging-face-evaluation/scripts/test_extraction.py +0 -206
  281. package/skills_ref/hugging-face-model-trainer/SKILL.md +0 -718
  282. package/skills_ref/hugging-face-model-trainer/references/gguf_conversion.md +0 -296
  283. package/skills_ref/hugging-face-model-trainer/references/hardware_guide.md +0 -283
  284. package/skills_ref/hugging-face-model-trainer/references/hub_saving.md +0 -364
  285. package/skills_ref/hugging-face-model-trainer/references/reliability_principles.md +0 -371
  286. package/skills_ref/hugging-face-model-trainer/references/trackio_guide.md +0 -189
  287. package/skills_ref/hugging-face-model-trainer/references/training_methods.md +0 -150
  288. package/skills_ref/hugging-face-model-trainer/references/training_patterns.md +0 -203
  289. package/skills_ref/hugging-face-model-trainer/references/troubleshooting.md +0 -282
  290. package/skills_ref/hugging-face-model-trainer/references/unsloth.md +0 -313
  291. package/skills_ref/hugging-face-model-trainer/scripts/convert_to_gguf.py +0 -424
  292. package/skills_ref/hugging-face-model-trainer/scripts/dataset_inspector.py +0 -417
  293. package/skills_ref/hugging-face-model-trainer/scripts/estimate_cost.py +0 -150
  294. package/skills_ref/hugging-face-model-trainer/scripts/train_dpo_example.py +0 -106
  295. package/skills_ref/hugging-face-model-trainer/scripts/train_grpo_example.py +0 -89
  296. package/skills_ref/hugging-face-model-trainer/scripts/train_sft_example.py +0 -122
  297. package/skills_ref/hugging-face-model-trainer/scripts/unsloth_sft_example.py +0 -512
  298. package/skills_ref/imagegen/SKILL.md +0 -174
  299. package/skills_ref/insecure-defaults/.claude-plugin/plugin.json +0 -10
  300. package/skills_ref/insecure-defaults/README.md +0 -45
  301. package/skills_ref/insecure-defaults/skills/insecure-defaults/SKILL.md +0 -117
  302. package/skills_ref/insecure-defaults/skills/insecure-defaults/references/examples.md +0 -409
  303. package/skills_ref/jupyter-notebook/SKILL.md +0 -107
  304. package/skills_ref/linear/SKILL.md +0 -87
  305. package/skills_ref/linter-fix-guide/SKILL.md +0 -27
  306. package/skills_ref/log-summarizer/SKILL.md +0 -27
  307. package/skills_ref/mcp-builder/LICENSE.txt +0 -202
  308. package/skills_ref/mcp-builder/SKILL.md +0 -236
  309. package/skills_ref/mcp-builder/reference/evaluation.md +0 -602
  310. package/skills_ref/mcp-builder/reference/mcp_best_practices.md +0 -249
  311. package/skills_ref/mcp-builder/reference/node_mcp_server.md +0 -970
  312. package/skills_ref/mcp-builder/reference/python_mcp_server.md +0 -719
  313. package/skills_ref/mcp-builder/scripts/connections.py +0 -151
  314. package/skills_ref/mcp-builder/scripts/evaluation.py +0 -373
  315. package/skills_ref/mcp-builder/scripts/example_evaluation.xml +0 -22
  316. package/skills_ref/mcp-builder/scripts/requirements.txt +0 -2
  317. package/skills_ref/memory/SKILL.md +0 -129
  318. package/skills_ref/modern-python/.claude-plugin/plugin.json +0 -10
  319. package/skills_ref/modern-python/README.md +0 -66
  320. package/skills_ref/modern-python/hooks/hooks.json +0 -16
  321. package/skills_ref/modern-python/hooks/setup-shims.bats +0 -70
  322. package/skills_ref/modern-python/hooks/setup-shims.sh +0 -24
  323. package/skills_ref/modern-python/hooks/shims/pip +0 -27
  324. package/skills_ref/modern-python/hooks/shims/pip-shim.bats +0 -45
  325. package/skills_ref/modern-python/hooks/shims/pip3 +0 -27
  326. package/skills_ref/modern-python/hooks/shims/pipx +0 -41
  327. package/skills_ref/modern-python/hooks/shims/pipx-shim.bats +0 -64
  328. package/skills_ref/modern-python/hooks/shims/python +0 -26
  329. package/skills_ref/modern-python/hooks/shims/python-shim.bats +0 -53
  330. package/skills_ref/modern-python/hooks/shims/python3 +0 -26
  331. package/skills_ref/modern-python/hooks/shims/uv +0 -27
  332. package/skills_ref/modern-python/hooks/shims/uv-shim.bats +0 -47
  333. package/skills_ref/modern-python/skills/modern-python/SKILL.md +0 -333
  334. package/skills_ref/modern-python/skills/modern-python/references/dependabot.md +0 -43
  335. package/skills_ref/modern-python/skills/modern-python/references/migration-checklist.md +0 -141
  336. package/skills_ref/modern-python/skills/modern-python/references/pep723-scripts.md +0 -259
  337. package/skills_ref/modern-python/skills/modern-python/references/prek.md +0 -211
  338. package/skills_ref/modern-python/skills/modern-python/references/pyproject.md +0 -254
  339. package/skills_ref/modern-python/skills/modern-python/references/ruff-config.md +0 -240
  340. package/skills_ref/modern-python/skills/modern-python/references/security-setup.md +0 -255
  341. package/skills_ref/modern-python/skills/modern-python/references/testing.md +0 -284
  342. package/skills_ref/modern-python/skills/modern-python/references/uv-commands.md +0 -200
  343. package/skills_ref/modern-python/skills/modern-python/templates/dependabot.yml +0 -36
  344. package/skills_ref/modern-python/skills/modern-python/templates/pre-commit-config.yaml +0 -66
  345. package/skills_ref/nano-banana-pro/SKILL.md +0 -58
  346. package/skills_ref/netlify-deploy/SKILL.md +0 -233
  347. package/skills_ref/notion/SKILL.md +0 -304
  348. package/skills_ref/notion-knowledge-capture/SKILL.md +0 -56
  349. package/skills_ref/notion-meeting-intelligence/SKILL.md +0 -60
  350. package/skills_ref/notion-research-documentation/SKILL.md +0 -59
  351. package/skills_ref/notion-spec-to-implementation/SKILL.md +0 -58
  352. package/skills_ref/obsidian/SKILL.md +0 -81
  353. package/skills_ref/openai-docs/SKILL.md +0 -56
  354. package/skills_ref/openhue/SKILL.md +0 -112
  355. package/skills_ref/pdf/SKILL.md +0 -69
  356. package/skills_ref/postgres/README.md +0 -77
  357. package/skills_ref/postgres/SKILL.md +0 -129
  358. package/skills_ref/postgres/connections.example.json +0 -34
  359. package/skills_ref/postgres/requirements.txt +0 -1
  360. package/skills_ref/postgres/scripts/query.py +0 -262
  361. package/skills_ref/pptx/LICENSE.txt +0 -30
  362. package/skills_ref/pptx/SKILL.md +0 -232
  363. package/skills_ref/pptx/editing.md +0 -205
  364. package/skills_ref/pptx/pptxgenjs.md +0 -420
  365. package/skills_ref/pptx/scripts/__init__.py +0 -0
  366. package/skills_ref/pptx/scripts/add_slide.py +0 -195
  367. package/skills_ref/pptx/scripts/clean.py +0 -286
  368. package/skills_ref/pptx/scripts/office/helpers/__init__.py +0 -0
  369. package/skills_ref/pptx/scripts/office/helpers/merge_runs.py +0 -199
  370. package/skills_ref/pptx/scripts/office/helpers/simplify_redlines.py +0 -197
  371. package/skills_ref/pptx/scripts/office/pack.py +0 -159
  372. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +0 -1499
  373. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +0 -146
  374. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +0 -1085
  375. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +0 -11
  376. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-main.xsd +0 -3081
  377. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +0 -23
  378. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +0 -185
  379. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +0 -287
  380. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/pml.xsd +0 -1676
  381. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +0 -28
  382. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +0 -144
  383. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +0 -174
  384. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +0 -25
  385. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +0 -18
  386. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +0 -59
  387. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +0 -56
  388. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +0 -195
  389. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-math.xsd +0 -582
  390. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +0 -25
  391. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/sml.xsd +0 -4439
  392. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-main.xsd +0 -570
  393. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +0 -509
  394. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +0 -12
  395. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +0 -108
  396. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +0 -96
  397. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/wml.xsd +0 -3646
  398. package/skills_ref/pptx/scripts/office/schemas/ISO-IEC29500-4_2016/xml.xsd +0 -116
  399. package/skills_ref/pptx/scripts/office/schemas/ecma/fouth-edition/opc-contentTypes.xsd +0 -42
  400. package/skills_ref/pptx/scripts/office/schemas/ecma/fouth-edition/opc-coreProperties.xsd +0 -50
  401. package/skills_ref/pptx/scripts/office/schemas/ecma/fouth-edition/opc-digSig.xsd +0 -49
  402. package/skills_ref/pptx/scripts/office/schemas/ecma/fouth-edition/opc-relationships.xsd +0 -33
  403. package/skills_ref/pptx/scripts/office/schemas/mce/mc.xsd +0 -75
  404. package/skills_ref/pptx/scripts/office/schemas/microsoft/wml-2010.xsd +0 -560
  405. package/skills_ref/pptx/scripts/office/schemas/microsoft/wml-2012.xsd +0 -67
  406. package/skills_ref/pptx/scripts/office/schemas/microsoft/wml-2018.xsd +0 -14
  407. package/skills_ref/pptx/scripts/office/schemas/microsoft/wml-cex-2018.xsd +0 -20
  408. package/skills_ref/pptx/scripts/office/schemas/microsoft/wml-cid-2016.xsd +0 -13
  409. package/skills_ref/pptx/scripts/office/schemas/microsoft/wml-sdtdatahash-2020.xsd +0 -4
  410. package/skills_ref/pptx/scripts/office/schemas/microsoft/wml-symex-2015.xsd +0 -8
  411. package/skills_ref/pptx/scripts/office/soffice.py +0 -183
  412. package/skills_ref/pptx/scripts/office/unpack.py +0 -132
  413. package/skills_ref/pptx/scripts/office/validate.py +0 -111
  414. package/skills_ref/pptx/scripts/office/validators/__init__.py +0 -15
  415. package/skills_ref/pptx/scripts/office/validators/base.py +0 -847
  416. package/skills_ref/pptx/scripts/office/validators/docx.py +0 -446
  417. package/skills_ref/pptx/scripts/office/validators/pptx.py +0 -275
  418. package/skills_ref/pptx/scripts/office/validators/redlining.py +0 -247
  419. package/skills_ref/pptx/scripts/thumbnail.py +0 -289
  420. package/skills_ref/property-based-testing/.claude-plugin/plugin.json +0 -9
  421. package/skills_ref/property-based-testing/README.md +0 -47
  422. package/skills_ref/property-based-testing/skills/property-based-testing/README.md +0 -88
  423. package/skills_ref/property-based-testing/skills/property-based-testing/SKILL.md +0 -123
  424. package/skills_ref/property-based-testing/skills/property-based-testing/references/design.md +0 -191
  425. package/skills_ref/property-based-testing/skills/property-based-testing/references/generating.md +0 -204
  426. package/skills_ref/property-based-testing/skills/property-based-testing/references/interpreting-failures.md +0 -239
  427. package/skills_ref/property-based-testing/skills/property-based-testing/references/libraries.md +0 -130
  428. package/skills_ref/property-based-testing/skills/property-based-testing/references/refactoring.md +0 -181
  429. package/skills_ref/property-based-testing/skills/property-based-testing/references/reviewing.md +0 -209
  430. package/skills_ref/property-based-testing/skills/property-based-testing/references/strategies.md +0 -124
  431. package/skills_ref/react-best-practices/AGENTS.md +0 -2934
  432. package/skills_ref/react-best-practices/README.md +0 -123
  433. package/skills_ref/react-best-practices/SKILL.md +0 -136
  434. package/skills_ref/react-best-practices/metadata.json +0 -15
  435. package/skills_ref/react-best-practices/rules/_sections.md +0 -46
  436. package/skills_ref/react-best-practices/rules/_template.md +0 -28
  437. package/skills_ref/react-best-practices/rules/advanced-event-handler-refs.md +0 -55
  438. package/skills_ref/react-best-practices/rules/advanced-init-once.md +0 -42
  439. package/skills_ref/react-best-practices/rules/advanced-use-latest.md +0 -39
  440. package/skills_ref/react-best-practices/rules/async-api-routes.md +0 -38
  441. package/skills_ref/react-best-practices/rules/async-defer-await.md +0 -80
  442. package/skills_ref/react-best-practices/rules/async-dependencies.md +0 -51
  443. package/skills_ref/react-best-practices/rules/async-parallel.md +0 -28
  444. package/skills_ref/react-best-practices/rules/async-suspense-boundaries.md +0 -99
  445. package/skills_ref/react-best-practices/rules/bundle-barrel-imports.md +0 -59
  446. package/skills_ref/react-best-practices/rules/bundle-conditional.md +0 -31
  447. package/skills_ref/react-best-practices/rules/bundle-defer-third-party.md +0 -49
  448. package/skills_ref/react-best-practices/rules/bundle-dynamic-imports.md +0 -35
  449. package/skills_ref/react-best-practices/rules/bundle-preload.md +0 -50
  450. package/skills_ref/react-best-practices/rules/client-event-listeners.md +0 -74
  451. package/skills_ref/react-best-practices/rules/client-localstorage-schema.md +0 -71
  452. package/skills_ref/react-best-practices/rules/client-passive-event-listeners.md +0 -48
  453. package/skills_ref/react-best-practices/rules/client-swr-dedup.md +0 -56
  454. package/skills_ref/react-best-practices/rules/js-batch-dom-css.md +0 -107
  455. package/skills_ref/react-best-practices/rules/js-cache-function-results.md +0 -80
  456. package/skills_ref/react-best-practices/rules/js-cache-property-access.md +0 -28
  457. package/skills_ref/react-best-practices/rules/js-cache-storage.md +0 -70
  458. package/skills_ref/react-best-practices/rules/js-combine-iterations.md +0 -32
  459. package/skills_ref/react-best-practices/rules/js-early-exit.md +0 -50
  460. package/skills_ref/react-best-practices/rules/js-hoist-regexp.md +0 -45
  461. package/skills_ref/react-best-practices/rules/js-index-maps.md +0 -37
  462. package/skills_ref/react-best-practices/rules/js-length-check-first.md +0 -49
  463. package/skills_ref/react-best-practices/rules/js-min-max-loop.md +0 -82
  464. package/skills_ref/react-best-practices/rules/js-set-map-lookups.md +0 -24
  465. package/skills_ref/react-best-practices/rules/js-tosorted-immutable.md +0 -57
  466. package/skills_ref/react-best-practices/rules/rendering-activity.md +0 -26
  467. package/skills_ref/react-best-practices/rules/rendering-animate-svg-wrapper.md +0 -47
  468. package/skills_ref/react-best-practices/rules/rendering-conditional-render.md +0 -40
  469. package/skills_ref/react-best-practices/rules/rendering-content-visibility.md +0 -38
  470. package/skills_ref/react-best-practices/rules/rendering-hoist-jsx.md +0 -46
  471. package/skills_ref/react-best-practices/rules/rendering-hydration-no-flicker.md +0 -82
  472. package/skills_ref/react-best-practices/rules/rendering-hydration-suppress-warning.md +0 -30
  473. package/skills_ref/react-best-practices/rules/rendering-svg-precision.md +0 -28
  474. package/skills_ref/react-best-practices/rules/rendering-usetransition-loading.md +0 -75
  475. package/skills_ref/react-best-practices/rules/rerender-defer-reads.md +0 -39
  476. package/skills_ref/react-best-practices/rules/rerender-dependencies.md +0 -45
  477. package/skills_ref/react-best-practices/rules/rerender-derived-state-no-effect.md +0 -40
  478. package/skills_ref/react-best-practices/rules/rerender-derived-state.md +0 -29
  479. package/skills_ref/react-best-practices/rules/rerender-functional-setstate.md +0 -74
  480. package/skills_ref/react-best-practices/rules/rerender-lazy-state-init.md +0 -58
  481. package/skills_ref/react-best-practices/rules/rerender-memo-with-default-value.md +0 -38
  482. package/skills_ref/react-best-practices/rules/rerender-memo.md +0 -44
  483. package/skills_ref/react-best-practices/rules/rerender-move-effect-to-event.md +0 -45
  484. package/skills_ref/react-best-practices/rules/rerender-simple-expression-in-memo.md +0 -35
  485. package/skills_ref/react-best-practices/rules/rerender-transitions.md +0 -40
  486. package/skills_ref/react-best-practices/rules/rerender-use-ref-transient-values.md +0 -73
  487. package/skills_ref/react-best-practices/rules/server-after-nonblocking.md +0 -73
  488. package/skills_ref/react-best-practices/rules/server-auth-actions.md +0 -96
  489. package/skills_ref/react-best-practices/rules/server-cache-lru.md +0 -41
  490. package/skills_ref/react-best-practices/rules/server-cache-react.md +0 -76
  491. package/skills_ref/react-best-practices/rules/server-dedup-props.md +0 -65
  492. package/skills_ref/react-best-practices/rules/server-parallel-fetching.md +0 -83
  493. package/skills_ref/react-best-practices/rules/server-serialization.md +0 -38
  494. package/skills_ref/receiving-code-review/SKILL.md +0 -213
  495. package/skills_ref/registry.json +0 -1493
  496. package/skills_ref/render-deploy/SKILL.md +0 -462
  497. package/skills_ref/requesting-code-review/SKILL.md +0 -105
  498. package/skills_ref/requesting-code-review/code-reviewer.md +0 -146
  499. package/skills_ref/screen-capture/SKILL.md +0 -162
  500. package/skills_ref/security-best-practices/LICENSE.txt +0 -201
  501. package/skills_ref/security-best-practices/SKILL.md +0 -86
  502. package/skills_ref/security-best-practices/agents/openai.yaml +0 -4
  503. package/skills_ref/security-best-practices/references/golang-general-backend-security.md +0 -826
  504. package/skills_ref/security-best-practices/references/javascript-express-web-server-security.md +0 -1158
  505. package/skills_ref/security-best-practices/references/javascript-general-web-frontend-security.md +0 -747
  506. package/skills_ref/security-best-practices/references/javascript-jquery-web-frontend-security.md +0 -678
  507. package/skills_ref/security-best-practices/references/javascript-typescript-nextjs-web-server-security.md +0 -1144
  508. package/skills_ref/security-best-practices/references/javascript-typescript-react-web-frontend-security.md +0 -990
  509. package/skills_ref/security-best-practices/references/javascript-typescript-vue-web-frontend-security.md +0 -791
  510. package/skills_ref/security-best-practices/references/python-django-web-server-security.md +0 -882
  511. package/skills_ref/security-best-practices/references/python-fastapi-web-server-security.md +0 -1036
  512. package/skills_ref/security-best-practices/references/python-flask-web-server-security.md +0 -705
  513. package/skills_ref/security-ownership-map/LICENSE.txt +0 -201
  514. package/skills_ref/security-ownership-map/SKILL.md +0 -206
  515. package/skills_ref/security-ownership-map/agents/openai.yaml +0 -4
  516. package/skills_ref/security-ownership-map/references/neo4j-import.md +0 -60
  517. package/skills_ref/security-ownership-map/scripts/build_ownership_map.py +0 -956
  518. package/skills_ref/security-ownership-map/scripts/community_maintainers.py +0 -544
  519. package/skills_ref/security-ownership-map/scripts/query_ownership.py +0 -483
  520. package/skills_ref/security-ownership-map/scripts/run_ownership_map.py +0 -200
  521. package/skills_ref/security-threat-model/LICENSE.txt +0 -201
  522. package/skills_ref/security-threat-model/SKILL.md +0 -81
  523. package/skills_ref/security-threat-model/agents/openai.yaml +0 -4
  524. package/skills_ref/security-threat-model/references/prompt-template.md +0 -255
  525. package/skills_ref/security-threat-model/references/security-controls-and-assets.md +0 -32
  526. package/skills_ref/sentry/SKILL.md +0 -123
  527. package/skills_ref/skill-creator/SKILL.md +0 -372
  528. package/skills_ref/sora/SKILL.md +0 -153
  529. package/skills_ref/speech/SKILL.md +0 -144
  530. package/skills_ref/spotify-player/SKILL.md +0 -64
  531. package/skills_ref/static-analysis/.claude-plugin/plugin.json +0 -8
  532. package/skills_ref/static-analysis/README.md +0 -65
  533. package/skills_ref/static-analysis/agents/semgrep-scanner.md +0 -71
  534. package/skills_ref/static-analysis/agents/semgrep-triager.md +0 -107
  535. package/skills_ref/static-analysis/skills/codeql/SKILL.md +0 -119
  536. package/skills_ref/static-analysis/skills/codeql/references/diagnostic-query-templates.md +0 -339
  537. package/skills_ref/static-analysis/skills/codeql/references/language-details.md +0 -207
  538. package/skills_ref/static-analysis/skills/codeql/references/performance-tuning.md +0 -111
  539. package/skills_ref/static-analysis/skills/codeql/references/ruleset-catalog.md +0 -63
  540. package/skills_ref/static-analysis/skills/codeql/references/threat-models.md +0 -44
  541. package/skills_ref/static-analysis/skills/codeql/workflows/build-database.md +0 -669
  542. package/skills_ref/static-analysis/skills/codeql/workflows/create-data-extensions.md +0 -536
  543. package/skills_ref/static-analysis/skills/codeql/workflows/run-analysis.md +0 -436
  544. package/skills_ref/static-analysis/skills/sarif-parsing/SKILL.md +0 -479
  545. package/skills_ref/static-analysis/skills/sarif-parsing/resources/jq-queries.md +0 -162
  546. package/skills_ref/static-analysis/skills/sarif-parsing/resources/sarif_helpers.py +0 -331
  547. package/skills_ref/static-analysis/skills/semgrep/SKILL.md +0 -431
  548. package/skills_ref/static-analysis/skills/semgrep/references/rulesets.md +0 -162
  549. package/skills_ref/static-analysis/skills/semgrep/references/scanner-task-prompt.md +0 -102
  550. package/skills_ref/static-analysis/skills/semgrep/references/triage-task-prompt.md +0 -122
  551. package/skills_ref/static-analysis/skills/semgrep/scripts/merge_triaged_sarif.py +0 -252
  552. package/skills_ref/summarize/SKILL.md +0 -87
  553. package/skills_ref/tdd/SKILL.md +0 -371
  554. package/skills_ref/tdd/testing-anti-patterns.md +0 -299
  555. package/skills_ref/telegram-send/SKILL.md +0 -99
  556. package/skills_ref/terraform/README.md +0 -105
  557. package/skills_ref/terraform/code-generation/.claude-plugin/plugin.json +0 -30
  558. package/skills_ref/terraform/code-generation/skills/azure-verified-modules/SKILL.md +0 -613
  559. package/skills_ref/terraform/code-generation/skills/terraform-style-guide/SKILL.md +0 -353
  560. package/skills_ref/terraform/code-generation/skills/terraform-test/SKILL.md +0 -1669
  561. package/skills_ref/terraform/module-generation/.claude-plugin/plugin.json +0 -30
  562. package/skills_ref/terraform/module-generation/skills/refactor-module/SKILL.md +0 -538
  563. package/skills_ref/terraform/module-generation/skills/terraform-stacks/SKILL.md +0 -468
  564. package/skills_ref/terraform/module-generation/skills/terraform-stacks/references/api-monitoring.md +0 -543
  565. package/skills_ref/terraform/module-generation/skills/terraform-stacks/references/component-blocks.md +0 -476
  566. package/skills_ref/terraform/module-generation/skills/terraform-stacks/references/deployment-blocks.md +0 -391
  567. package/skills_ref/terraform/module-generation/skills/terraform-stacks/references/examples.md +0 -1529
  568. package/skills_ref/terraform/module-generation/skills/terraform-stacks/references/linked-stacks.md +0 -187
  569. package/skills_ref/terraform/module-generation/skills/terraform-stacks/references/troubleshooting.md +0 -671
  570. package/skills_ref/terraform/provider-development/.claude-plugin/plugin.json +0 -13
  571. package/skills_ref/terraform/provider-development/skills/new-terraform-provider/SKILL.md +0 -25
  572. package/skills_ref/terraform/provider-development/skills/new-terraform-provider/assets/main.go +0 -40
  573. package/skills_ref/terraform/provider-development/skills/provider-actions/SKILL.md +0 -478
  574. package/skills_ref/terraform/provider-development/skills/provider-resources/SKILL.md +0 -599
  575. package/skills_ref/terraform/provider-development/skills/run-acceptance-tests/SKILL.md +0 -41
  576. package/skills_ref/theme-factory/LICENSE.txt +0 -202
  577. package/skills_ref/theme-factory/SKILL.md +0 -59
  578. package/skills_ref/theme-factory/theme-showcase.pdf +0 -0
  579. package/skills_ref/theme-factory/themes/arctic-frost.md +0 -19
  580. package/skills_ref/theme-factory/themes/botanical-garden.md +0 -19
  581. package/skills_ref/theme-factory/themes/desert-rose.md +0 -19
  582. package/skills_ref/theme-factory/themes/forest-canopy.md +0 -19
  583. package/skills_ref/theme-factory/themes/golden-hour.md +0 -19
  584. package/skills_ref/theme-factory/themes/midnight-galaxy.md +0 -19
  585. package/skills_ref/theme-factory/themes/modern-minimalist.md +0 -19
  586. package/skills_ref/theme-factory/themes/ocean-depths.md +0 -19
  587. package/skills_ref/theme-factory/themes/sunset-boulevard.md +0 -19
  588. package/skills_ref/theme-factory/themes/tech-innovation.md +0 -19
  589. package/skills_ref/things-mac/SKILL.md +0 -86
  590. package/skills_ref/tmux/SKILL.md +0 -153
  591. package/skills_ref/transcribe/SKILL.md +0 -81
  592. package/skills_ref/trello/SKILL.md +0 -95
  593. package/skills_ref/tts/SKILL.md +0 -99
  594. package/skills_ref/vercel-deploy/SKILL.md +0 -115
  595. package/skills_ref/video-downloader/SKILL.md +0 -99
  596. package/skills_ref/video-downloader/scripts/download_video.py +0 -145
  597. package/skills_ref/video-frames/SKILL.md +0 -46
  598. package/skills_ref/vision-click/SKILL.md +0 -128
  599. package/skills_ref/weather/SKILL.md +0 -112
  600. package/skills_ref/web-artifacts-builder/LICENSE.txt +0 -202
  601. package/skills_ref/web-artifacts-builder/SKILL.md +0 -74
  602. package/skills_ref/web-artifacts-builder/scripts/bundle-artifact.sh +0 -54
  603. package/skills_ref/web-artifacts-builder/scripts/init-artifact.sh +0 -322
  604. package/skills_ref/web-artifacts-builder/scripts/shadcn-components.tar.gz +0 -0
  605. package/skills_ref/web-perf/SKILL.md +0 -193
  606. package/skills_ref/web-routing/SKILL.md +0 -26
  607. package/skills_ref/whatsapp/SKILL.md +0 -255
  608. package/skills_ref/whatsapp/assets/agent-app-integration-example.json +0 -35
  609. package/skills_ref/whatsapp/assets/databases-example.json +0 -11
  610. package/skills_ref/whatsapp/assets/function-decide-route-interactive-buttons.json +0 -6
  611. package/skills_ref/whatsapp/assets/functions-example.json +0 -5
  612. package/skills_ref/whatsapp/assets/workflow-agent-simple.json +0 -31
  613. package/skills_ref/whatsapp/assets/workflow-api-template-wait-agent.json +0 -59
  614. package/skills_ref/whatsapp/assets/workflow-customer-support-intake-agent.json +0 -56
  615. package/skills_ref/whatsapp/assets/workflow-decision.json +0 -83
  616. package/skills_ref/whatsapp/assets/workflow-interactive-buttons-decide-ai.json +0 -89
  617. package/skills_ref/whatsapp/assets/workflow-interactive-buttons-decide-function.json +0 -88
  618. package/skills_ref/whatsapp/assets/workflow-linear.json +0 -53
  619. package/skills_ref/whatsapp/package.json +0 -10
  620. package/skills_ref/whatsapp/references/app-integrations.md +0 -89
  621. package/skills_ref/whatsapp/references/databases-reference.md +0 -21
  622. package/skills_ref/whatsapp/references/execution-context.md +0 -42
  623. package/skills_ref/whatsapp/references/function-contracts.md +0 -55
  624. package/skills_ref/whatsapp/references/functions-payloads.md +0 -87
  625. package/skills_ref/whatsapp/references/functions-reference.md +0 -133
  626. package/skills_ref/whatsapp/references/graph-contract.md +0 -145
  627. package/skills_ref/whatsapp/references/node-types.md +0 -430
  628. package/skills_ref/whatsapp/references/triggers.md +0 -20
  629. package/skills_ref/whatsapp/references/workflow-overview.md +0 -22
  630. package/skills_ref/whatsapp/references/workflow-reference.md +0 -123
  631. package/skills_ref/whatsapp/scripts/configure-prop.js +0 -113
  632. package/skills_ref/whatsapp/scripts/create-connect-token.js +0 -38
  633. package/skills_ref/whatsapp/scripts/create-function.js +0 -64
  634. package/skills_ref/whatsapp/scripts/create-integration.js +0 -137
  635. package/skills_ref/whatsapp/scripts/create-row.js +0 -47
  636. package/skills_ref/whatsapp/scripts/create-trigger.js +0 -88
  637. package/skills_ref/whatsapp/scripts/create-workflow.js +0 -85
  638. package/skills_ref/whatsapp/scripts/delete-integration.js +0 -44
  639. package/skills_ref/whatsapp/scripts/delete-row.js +0 -49
  640. package/skills_ref/whatsapp/scripts/delete-trigger.js +0 -44
  641. package/skills_ref/whatsapp/scripts/deploy-function.js +0 -47
  642. package/skills_ref/whatsapp/scripts/edit-graph.js +0 -289
  643. package/skills_ref/whatsapp/scripts/get-action-schema.js +0 -44
  644. package/skills_ref/whatsapp/scripts/get-context-value.js +0 -80
  645. package/skills_ref/whatsapp/scripts/get-execution-event.js +0 -55
  646. package/skills_ref/whatsapp/scripts/get-execution.js +0 -44
  647. package/skills_ref/whatsapp/scripts/get-function.js +0 -43
  648. package/skills_ref/whatsapp/scripts/get-graph.js +0 -85
  649. package/skills_ref/whatsapp/scripts/get-table.js +0 -45
  650. package/skills_ref/whatsapp/scripts/get-workflow.js +0 -44
  651. package/skills_ref/whatsapp/scripts/invoke-function.js +0 -60
  652. package/skills_ref/whatsapp/scripts/lib/databases/args.js +0 -87
  653. package/skills_ref/whatsapp/scripts/lib/databases/filters.js +0 -30
  654. package/skills_ref/whatsapp/scripts/lib/databases/kapso-api.js +0 -70
  655. package/skills_ref/whatsapp/scripts/lib/functions/args.js +0 -55
  656. package/skills_ref/whatsapp/scripts/lib/functions/kapso-api.js +0 -70
  657. package/skills_ref/whatsapp/scripts/lib/workflows/args.js +0 -53
  658. package/skills_ref/whatsapp/scripts/lib/workflows/kapso-api.js +0 -123
  659. package/skills_ref/whatsapp/scripts/lib/workflows/result.js +0 -16
  660. package/skills_ref/whatsapp/scripts/list-accounts.js +0 -62
  661. package/skills_ref/whatsapp/scripts/list-apps.js +0 -42
  662. package/skills_ref/whatsapp/scripts/list-execution-events.js +0 -61
  663. package/skills_ref/whatsapp/scripts/list-executions.js +0 -53
  664. package/skills_ref/whatsapp/scripts/list-function-invocations.js +0 -53
  665. package/skills_ref/whatsapp/scripts/list-functions.js +0 -41
  666. package/skills_ref/whatsapp/scripts/list-integrations.js +0 -41
  667. package/skills_ref/whatsapp/scripts/list-provider-models.js +0 -48
  668. package/skills_ref/whatsapp/scripts/list-tables.js +0 -41
  669. package/skills_ref/whatsapp/scripts/list-triggers.js +0 -44
  670. package/skills_ref/whatsapp/scripts/list-whatsapp-phone-numbers.js +0 -56
  671. package/skills_ref/whatsapp/scripts/list-workflows.js +0 -44
  672. package/skills_ref/whatsapp/scripts/openapi-explore.mjs +0 -1273
  673. package/skills_ref/whatsapp/scripts/query-rows.js +0 -71
  674. package/skills_ref/whatsapp/scripts/reload-props.js +0 -110
  675. package/skills_ref/whatsapp/scripts/resume-execution.js +0 -75
  676. package/skills_ref/whatsapp/scripts/search-actions.js +0 -64
  677. package/skills_ref/whatsapp/scripts/update-execution-status.js +0 -51
  678. package/skills_ref/whatsapp/scripts/update-function.js +0 -65
  679. package/skills_ref/whatsapp/scripts/update-graph.js +0 -154
  680. package/skills_ref/whatsapp/scripts/update-integration.js +0 -82
  681. package/skills_ref/whatsapp/scripts/update-row.js +0 -51
  682. package/skills_ref/whatsapp/scripts/update-trigger.js +0 -60
  683. package/skills_ref/whatsapp/scripts/update-workflow-settings.js +0 -67
  684. package/skills_ref/whatsapp/scripts/upsert-row.js +0 -64
  685. package/skills_ref/whatsapp/scripts/validate-graph.js +0 -293
  686. package/skills_ref/whatsapp/scripts/variables-delete.js +0 -37
  687. package/skills_ref/whatsapp/scripts/variables-list.js +0 -55
  688. package/skills_ref/whatsapp/scripts/variables-set.js +0 -39
  689. package/skills_ref/writing-plans/SKILL.md +0 -116
  690. package/skills_ref/xlsx/LICENSE.txt +0 -30
  691. package/skills_ref/xlsx/SKILL.md +0 -292
  692. package/skills_ref/xlsx/scripts/office/helpers/__init__.py +0 -0
  693. package/skills_ref/xlsx/scripts/office/helpers/merge_runs.py +0 -199
  694. package/skills_ref/xlsx/scripts/office/helpers/simplify_redlines.py +0 -197
  695. package/skills_ref/xlsx/scripts/office/pack.py +0 -159
  696. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +0 -1499
  697. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +0 -146
  698. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +0 -1085
  699. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +0 -11
  700. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-main.xsd +0 -3081
  701. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +0 -23
  702. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +0 -185
  703. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +0 -287
  704. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/pml.xsd +0 -1676
  705. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +0 -28
  706. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +0 -144
  707. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +0 -174
  708. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +0 -25
  709. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +0 -18
  710. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +0 -59
  711. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +0 -56
  712. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +0 -195
  713. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-math.xsd +0 -582
  714. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +0 -25
  715. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/sml.xsd +0 -4439
  716. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-main.xsd +0 -570
  717. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +0 -509
  718. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +0 -12
  719. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +0 -108
  720. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +0 -96
  721. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/wml.xsd +0 -3646
  722. package/skills_ref/xlsx/scripts/office/schemas/ISO-IEC29500-4_2016/xml.xsd +0 -116
  723. package/skills_ref/xlsx/scripts/office/schemas/ecma/fouth-edition/opc-contentTypes.xsd +0 -42
  724. package/skills_ref/xlsx/scripts/office/schemas/ecma/fouth-edition/opc-coreProperties.xsd +0 -50
  725. package/skills_ref/xlsx/scripts/office/schemas/ecma/fouth-edition/opc-digSig.xsd +0 -49
  726. package/skills_ref/xlsx/scripts/office/schemas/ecma/fouth-edition/opc-relationships.xsd +0 -33
  727. package/skills_ref/xlsx/scripts/office/schemas/mce/mc.xsd +0 -75
  728. package/skills_ref/xlsx/scripts/office/schemas/microsoft/wml-2010.xsd +0 -560
  729. package/skills_ref/xlsx/scripts/office/schemas/microsoft/wml-2012.xsd +0 -67
  730. package/skills_ref/xlsx/scripts/office/schemas/microsoft/wml-2018.xsd +0 -14
  731. package/skills_ref/xlsx/scripts/office/schemas/microsoft/wml-cex-2018.xsd +0 -20
  732. package/skills_ref/xlsx/scripts/office/schemas/microsoft/wml-cid-2016.xsd +0 -13
  733. package/skills_ref/xlsx/scripts/office/schemas/microsoft/wml-sdtdatahash-2020.xsd +0 -4
  734. package/skills_ref/xlsx/scripts/office/schemas/microsoft/wml-symex-2015.xsd +0 -8
  735. package/skills_ref/xlsx/scripts/office/soffice.py +0 -183
  736. package/skills_ref/xlsx/scripts/office/unpack.py +0 -132
  737. package/skills_ref/xlsx/scripts/office/validate.py +0 -111
  738. package/skills_ref/xlsx/scripts/office/validators/__init__.py +0 -15
  739. package/skills_ref/xlsx/scripts/office/validators/base.py +0 -847
  740. package/skills_ref/xlsx/scripts/office/validators/docx.py +0 -446
  741. package/skills_ref/xlsx/scripts/office/validators/pptx.py +0 -275
  742. package/skills_ref/xlsx/scripts/office/validators/redlining.py +0 -247
  743. package/skills_ref/xlsx/scripts/recalc.py +0 -184
  744. package/skills_ref/xurl/SKILL.md +0 -461
@@ -1,882 +0,0 @@
1
- # Django (Python) Web Security Spec (Django 6.0.x, Python 3.x)
2
-
3
- This document is designed as a **security spec** that supports:
4
-
5
- 1. **Secure-by-default code generation** for new Django code.
6
- 2. **Security review / vulnerability hunting** in existing Django code (passive “notice issues while working” and active “scan the repo and report findings”).
7
-
8
- It is intentionally written as a set of **normative requirements** (“MUST/SHOULD/MAY”) plus **audit rules** (what bad patterns look like, how to detect them, and how to fix/mitigate them).
9
-
10
- ---
11
-
12
- ## 0) Safety, boundaries, and anti-abuse constraints (MUST FOLLOW)
13
-
14
- * MUST NOT request, output, log, or commit secrets (API keys, passwords, private keys, session cookies, `SECRET_KEY`, `SECRET_KEY_FALLBACKS`, database passwords).
15
- * MUST NOT “fix” security by disabling protections (e.g., removing `CsrfViewMiddleware`, sprinkling `@csrf_exempt`, loosening `ALLOWED_HOSTS` to `['*']`, disabling `SecurityMiddleware`, disabling template auto-escaping, disabling permission checks).
16
- * MUST provide **evidence-based findings** during audits: cite file paths, code snippets, and concrete configuration values that justify the claim.
17
- * MUST treat uncertainty honestly: if a protection might exist in infrastructure (reverse proxy, WAF, CDN, ingress controller), report it as “not visible in app code; verify at runtime / edge config”.
18
- * MUST keep fixes compatible with Django’s intended security model: prefer Django’s built-ins (middleware, auth, forms, ORM) over custom security logic whenever possible. Django’s deployment checklist and system checks are part of the intended model. ([Django Project][1])
19
-
20
- ---
21
-
22
- ## 1) Operating modes
23
-
24
- ### 1.1 Generation mode (default)
25
-
26
- When asked to write new Django code or modify existing code:
27
-
28
- * MUST follow every **MUST** requirement in this spec.
29
- * SHOULD follow every **SHOULD** requirement unless the user explicitly says otherwise.
30
- * MUST prefer safe-by-default Django APIs and proven libraries over custom security code.
31
- * MUST avoid introducing new risky sinks (dynamic template rendering from untrusted strings, unsafe redirects, unsafe file serving, shell execution, raw SQL string formatting, SSRF-capable URL fetchers from untrusted input).
32
-
33
- ### 1.2 Passive review mode (always on while editing)
34
-
35
- While working anywhere in a Django repo (even if the user did not ask for a security scan):
36
-
37
- * MUST “notice” violations of this spec in touched/nearby code.
38
- * SHOULD mention issues as they come up, with a brief explanation + safe fix.
39
-
40
- ### 1.3 Active audit mode (explicit scan request)
41
-
42
- When the user asks to “scan”, “audit”, or “hunt for vulns”:
43
-
44
- * MUST systematically search the codebase for violations of this spec.
45
- * MUST output findings in a structured format (see §2.3).
46
-
47
- Recommended audit order:
48
-
49
- 1. Deployment entrypoints (ASGI/WSGI), Dockerfiles, Procfiles, systemd units, platform manifests.
50
- 2. `settings.py` and environment-specific settings modules.
51
- 3. Middleware ordering and enabled protections.
52
- 4. Authn/authz (login, session management, permissions, admin).
53
- 5. CSRF protections and state-changing endpoints.
54
- 6. Templates and XSS.
55
- 7. File handling (uploads/downloads/static/media) and path traversal.
56
- 8. Injection classes (SQL, command execution, unsafe deserialization).
57
- 9. Outbound requests (SSRF).
58
- 10. Redirect handling (open redirects) + CORS + security headers (CSP, HSTS, etc.).
59
- 11. Dependency/pinning and patch posture.
60
-
61
- ---
62
-
63
- ## 2) Definitions and review guidance
64
-
65
- ### 2.1 Untrusted input (treat as attacker-controlled unless proven otherwise)
66
-
67
- Examples include:
68
-
69
- * `request.GET`, `request.POST`, `request.FILES`
70
- * `request.body`, JSON bodies (e.g., `json.loads(request.body)`), DRF `request.data`
71
- * URL path parameters (e.g., `<int:id>`, `<slug:...>`)
72
- * `request.headers` / `request.META` (including `HTTP_HOST`, `HTTP_ORIGIN`, `HTTP_REFERER`, `HTTP_X_FORWARDED_*`)
73
- * `request.COOKIES`
74
- * Any data from external systems (webhooks, third-party APIs, message queues)
75
- * Any persisted content that originated from users (DB rows, cached content, file uploads)
76
-
77
- Django explicitly emphasizes “never trust user-controlled data” and recommends using forms/validation. ([Django Project][2])
78
-
79
- ### 2.2 State-changing request
80
-
81
- A request is state-changing if it can create/update/delete data, change auth/session state, trigger side effects (purchase, email send, webhook send), or initiate privileged actions.
82
-
83
- ### 2.3 Required audit finding format
84
-
85
- For each issue found, output:
86
-
87
- * Rule ID:
88
- * Severity: Critical / High / Medium / Low
89
- * Location: file path + function/class/view name + line(s)
90
- * Evidence: the exact code/config snippet
91
- * Impact: what could go wrong, who can exploit it
92
- * Fix: safe change (prefer minimal diff)
93
- * Mitigation: defense-in-depth if immediate fix is hard
94
- * False positive notes: what to verify if uncertain
95
-
96
- ---
97
-
98
- ## 3) Secure baseline: minimum production configuration (MUST in production)
99
-
100
- This is the smallest “production baseline” that prevents common Django misconfigurations. Django provides a “Deployment checklist” and recommends running `manage.py check --deploy` against production settings. ([Django Project][1])
101
-
102
- ### 3.1 Settings management pattern (SHOULD)
103
-
104
- * SHOULD use environment-based configuration (or a secret manager) so production settings are not hard-coded.
105
- * MUST treat sensitive settings as confidential (e.g., `SECRET_KEY`, DB passwords) and keep them out of source control. Django’s checklist explicitly recommends loading `SECRET_KEY` from env or a file rather than hardcoding. ([Django Project][1])
106
- * SHOULD separate dev vs prod settings modules, with safe defaults for production (fail closed if critical settings are missing). ([Django Project][1])
107
-
108
- ### 3.2 Minimum baseline targets (production)
109
-
110
- * MUST NOT use `manage.py runserver` as the production entrypoint; use a production-ready WSGI or ASGI server. ([Django Project][1])
111
- * MUST set `DEBUG = False` in production. ([Django Project][1])
112
- * MUST set a strong, secret `SECRET_KEY` and keep it secret; MAY use `SECRET_KEY_FALLBACKS` for safe rotation. ([Django Project][1])
113
- * MUST set `ALLOWED_HOSTS` to expected hosts (no wildcard unless you do your own host validation). ([Django Project][1])
114
- * MUST enforce HTTPS for authenticated areas (ideally site-wide for any login-capable app) and set `CSRF_COOKIE_SECURE=True` and `SESSION_COOKIE_SECURE=True` when HTTPS is used. ([Django Project][1])
115
- * SHOULD enable key `SecurityMiddleware` headers/settings: HSTS, Referrer-Policy, COOP, nosniff, SSL redirect (with correct proxy configuration). ([Django Project][3])
116
- * MUST treat user uploads as untrusted; ensure your web server never interprets them as executable content; keep `MEDIA_ROOT` separate from `STATIC_ROOT`. ([Django Project][1])
117
-
118
- ---
119
-
120
- ## 4) Rules (generation + audit)
121
-
122
- Each rule contains: required practice, insecure patterns, detection hints, and remediation.
123
-
124
- ### DJANGO-DEPLOY-001: Do not use Django’s development server in production
125
-
126
- Severity: High (if production)
127
-
128
- Required:
129
-
130
- * MUST NOT deploy `manage.py runserver` as the production server.
131
- * MUST run behind a production-grade WSGI or ASGI server. ([Django Project][1])
132
-
133
- Insecure patterns:
134
-
135
- * Production docs/scripts using `python manage.py runserver 0.0.0.0:8000`.
136
- * Docker `CMD`/entrypoint uses `runserver`.
137
- * Kubernetes/Procfile/systemd units invoking `runserver`.
138
-
139
- Detection hints:
140
-
141
- * Search for `manage.py runserver`, `runserver 0.0.0.0`, `--insecure`.
142
- * Check Docker `CMD/ENTRYPOINT`, Procfile, systemd unit files, Helm charts.
143
-
144
- Fix:
145
-
146
- * Use a production server (WSGI/ASGI) as recommended in Django’s deployment checklist. ([Django Project][1])
147
-
148
- Note:
149
-
150
- * `runserver` is fine for local development. Only flag if it’s used as the production entrypoint.
151
-
152
- ---
153
-
154
- ### DJANGO-DEPLOY-002: `DEBUG` MUST be disabled in production
155
-
156
- Severity: High
157
-
158
- Required:
159
-
160
- * MUST set `DEBUG = False` in production.
161
- * MUST treat any mechanism that exposes debug pages/tracebacks to untrusted users as a critical information disclosure risk. Django’s checklist explicitly warns `DEBUG=True` leaks source excerpts, local variables, settings, and more. ([Django Project][1])
162
-
163
- Insecure patterns:
164
-
165
- * `DEBUG = True` in production settings.
166
- * Environment defaults to `DEBUG=True` unless explicitly overridden.
167
-
168
- Detection hints:
169
-
170
- * Search `DEBUG = True`, `DEBUG=os.environ.get(..., True)`, `DJANGO_DEBUG`, `.env` files.
171
- * Look for “production” settings modules that import from dev defaults.
172
-
173
- Fix:
174
-
175
- * Set `DEBUG=False` in prod settings; use explicit environment config.
176
- * Ensure error reporting is via safe logging/monitoring, not debug pages. ([Django Project][1])
177
-
178
- ---
179
-
180
- ### DJANGO-CONFIG-001: `SECRET_KEY` must be strong, secret, and rotated safely
181
-
182
- Severity: High (Critical if missing in production with signing/sessions)
183
-
184
- Required:
185
-
186
- * MUST set a large random `SECRET_KEY` in production and keep it secret. ([Django Project][1])
187
- * MUST NOT commit it to source control or print/log it. ([Django Project][1])
188
- * SHOULD load it from env or a file/secret store (not hard-coded). ([Django Project][1])
189
- * MAY rotate keys using `SECRET_KEY_FALLBACKS` to avoid instantly invalidating all signed data; MUST remove old keys from fallbacks in a timely manner. ([Django Project][1])
190
-
191
- Insecure patterns:
192
-
193
- * Hard-coded `SECRET_KEY = "..."` in repo for production.
194
- * `SECRET_KEY` reused across environments.
195
- * `SECRET_KEY_FALLBACKS` contains long-expired keys indefinitely.
196
-
197
- Detection hints:
198
-
199
- * Search for `SECRET_KEY =`, `SECRET_KEY_FALLBACKS`, `.env` committed files, `print(settings.SECRET_KEY)`.
200
-
201
- Fix:
202
-
203
- * Load from secret manager / environment variable.
204
- * If rotating:
205
-
206
- * Set new `SECRET_KEY`
207
- * Keep old key(s) temporarily in `SECRET_KEY_FALLBACKS`
208
- * Remove old key(s) after the rotation window. ([Django Project][1])
209
-
210
- ---
211
-
212
- ### DJANGO-HOST-001: Host header must be validated (`ALLOWED_HOSTS` must be strict)
213
-
214
- Severity: Medium
215
-
216
- Required:
217
-
218
- * MUST set `ALLOWED_HOSTS` in production to your expected domains/hosts. ([Django Project][1])
219
- * MUST NOT set `ALLOWED_HOSTS = ['*']` in production unless you also implement your own robust `Host` validation (Django warns that wildcards require your own validation to avoid CSRF-class attacks). ([Django Project][1])
220
- * SHOULD configure the fronting web server to reject unknown hosts early (defense-in-depth). ([Django Project][1])
221
-
222
- Insecure patterns:
223
-
224
- * `ALLOWED_HOSTS = ['*']` (or env expands to `*`) in production.
225
- * `ALLOWED_HOSTS = []` with `DEBUG=False` (site won’t run, or misconfigured deployments attempt workarounds).
226
-
227
- Detection hints:
228
-
229
- * Search `ALLOWED_HOSTS`.
230
- * Check platform environment settings that override `ALLOWED_HOSTS`.
231
-
232
- Fix:
233
-
234
- * Set `ALLOWED_HOSTS = ['example.com', 'www.example.com', ...]` for prod.
235
- * Keep dev hosts separate.
236
-
237
- Notes:
238
-
239
- * Django uses the Host header for URL construction; fake Host values can lead to CSRF, cache poisoning, and poisoned email links (Django security docs call this out). ([Django Project][2])
240
-
241
- ---
242
-
243
- ### DJANGO-HTTPS-001: If TLS is used cookie transport must be secured
244
-
245
- Severity: High (Critical for auth-enabled apps)
246
-
247
- NOTE: Only enforce this if TLS is enabled, as it will break non-TLS applications
248
-
249
- If using TLS:
250
- * MUST set:
251
-
252
- * `CSRF_COOKIE_SECURE = True` ([Django Project][1])
253
- * `SESSION_COOKIE_SECURE = True` ([Django Project][1])
254
- * SHOULD consider enabling:
255
-
256
- * `SECURE_SSL_REDIRECT = True` (with correct proxy config) ([Django Project][3])
257
- * HSTS via `SECURE_HSTS_SECONDS` (+ includeSubDomains/preload as appropriate). ([Django Project][3])
258
-
259
- Insecure patterns:
260
-
261
- * Login pages over HTTP, or mixed HTTP/HTTPS with the same session cookie.
262
- * `CSRF_COOKIE_SECURE=False` or `SESSION_COOKIE_SECURE=False` in production HTTPS.
263
- * HSTS enabled incorrectly (can break site for the duration).
264
-
265
- Detection hints:
266
-
267
- * Inspect `settings.py` for `CSRF_COOKIE_SECURE`, `SESSION_COOKIE_SECURE`, `SECURE_SSL_REDIRECT`, `SECURE_HSTS_SECONDS`.
268
- * Inspect proxy/ingress config for HTTP->HTTPS redirect behavior.
269
-
270
- Fix:
271
-
272
- * Enable HTTPS redirect and secure cookies.
273
- * Add HSTS carefully (start with low value, validate, then increase). Django warns misconfig can break your site for the HSTS duration. ([Django Project][3])
274
-
275
- ---
276
-
277
- ### DJANGO-PROXY-001: Reverse proxy trust must be configured correctly (`SECURE_PROXY_SSL_HEADER`)
278
-
279
- Severity: Medium (when behind a TLS proxy)
280
-
281
- Required:
282
-
283
- * If behind a reverse proxy that terminates TLS, MUST configure Django so `request.is_secure()` reflects the *external* scheme, otherwise CSRF and other logic can break. Django documents using `SECURE_PROXY_SSL_HEADER` for this. ([Django Project][3])
284
- * MUST only set `SECURE_PROXY_SSL_HEADER` if you control the proxy (or have guarantees) and it strips inbound spoofed headers. Django explicitly warns misconfig can compromise security and lists required conditions. ([Django Project][3])
285
-
286
- Insecure patterns:
287
-
288
- * `SECURE_PROXY_SSL_HEADER = ("HTTP_X_FORWARDED_PROTO", "https")` in an environment where the proxy does not strip user-supplied `X-Forwarded-Proto`.
289
- * Infinite redirect loops after setting `SECURE_SSL_REDIRECT=True` (often indicates proxy HTTPS detection is wrong). ([Django Project][3])
290
-
291
- Detection hints:
292
-
293
- * Search `SECURE_PROXY_SSL_HEADER`, `SECURE_SSL_REDIRECT`.
294
- * Inspect ingress/proxy behavior for stripping forwarded headers.
295
-
296
- Fix:
297
-
298
- * Set `SECURE_PROXY_SSL_HEADER` only if the proxy strips and sets the header correctly (per Django’s documented prerequisites). ([Django Project][3])
299
-
300
- ---
301
-
302
- ### DJANGO-SESS-001: Session cookies must use secure attributes in production
303
-
304
- Severity: Medium (Only if TLS enabled)
305
-
306
- Required (production, HTTPS):
307
-
308
- * MUST set `SESSION_COOKIE_SECURE=True` (only transmit over HTTPS). ([Django Project][3])
309
- * MUST keep `SESSION_COOKIE_HTTPONLY=True` (Django default is `True`). ([Django Project][3])
310
- * SHOULD keep `SESSION_COOKIE_SAMESITE='Lax'` (Django default is `Lax`) unless a justified cross-site flow requires `None`. ([Django Project][3])
311
- * SHOULD avoid setting `SESSION_COOKIE_DOMAIN` unless you truly need cross-subdomain cookies (subdomain-wide cookies expand attack surface).
312
-
313
- Insecure patterns:
314
-
315
- * `SESSION_COOKIE_SECURE=False` in production HTTPS.
316
-
317
- IMPORTANT NOTE: Only set `Secure` in production environment when TLS is configured. When running in a local dev environment over HTTP, do not set `Secure` property on cookies. You should do this conditionally based on if the app is running in production mode. You should also include a property like `SESSION_COOKIE_SECURE` which can be used to disable `Secure` cookies when testing over HTTP.
318
-
319
- * `SESSION_COOKIE_HTTPONLY=False`.
320
- * `SESSION_COOKIE_SAMESITE=None` combined with cookie-authenticated state-changing endpoints (higher CSRF risk).
321
-
322
- Detection hints:
323
-
324
- * Search for `SESSION_COOKIE_` settings, `response.set_cookie(..., httponly=..., secure=..., samesite=...)`.
325
-
326
- Fix:
327
-
328
- * Set the above explicitly in production settings.
329
- * Validate compatibility with your auth flows. ([Django Project][3])
330
-
331
- ---
332
-
333
- ### DJANGO-SESS-002: CSRF cookie settings must be deliberate (HttpOnly has tradeoffs)
334
-
335
- Severity: Medium
336
-
337
- Required:
338
-
339
- * SHOULD set `CSRF_COOKIE_SECURE=True` when using HTTPS/TLS. ([Django Project][3])
340
- * SHOULD keep `CSRF_COOKIE_SAMESITE='Lax'` unless you have a cross-site requirement. Django default is `Lax`. ([Django Project][3])
341
- * MAY set `CSRF_COOKIE_HTTPONLY=True` (default is `False`) if your frontend does not need to read the CSRF cookie. If you enable it, your JS must read the CSRF token from the DOM instead (Django documents this). ([Django Project][3])
342
-
343
- Insecure patterns:
344
-
345
- * `CSRF_COOKIE_SECURE=False` in production HTTPS/TLS.
346
- * Setting `CSRF_COOKIE_HTTPONLY=True` but still relying on “read csrftoken cookie in JS” patterns (breaks CSRF for AJAX).
347
- * `CSRF_COOKIE_SAMESITE=None` without a clear reason.
348
-
349
- Detection hints:
350
-
351
- * Search for `CSRF_COOKIE_` settings.
352
- * Search JS for `document.cookie` usage to fetch `csrftoken`.
353
-
354
- Fix:
355
-
356
- * Align cookie settings with your CSRF token acquisition method (cookie vs DOM) as Django describes. ([Django Project][4])
357
-
358
- ---
359
-
360
- ### DJANGO-CSRF-001: Cookie-authenticated state-changing requests MUST be CSRF-protected
361
-
362
- Severity: High
363
-
364
- Required:
365
-
366
- * MUST keep `django.middleware.csrf.CsrfViewMiddleware` enabled (it is activated by default). ([Django Project][4])
367
- * MUST include `{% csrf_token %}` in internal POST forms; MUST NOT include it in forms that POST to external URLs (Django warns this leaks the token). ([Django Project][4])
368
- * MUST protect all state-changing endpoints (POST/PUT/PATCH/DELETE) that rely on cookies for authentication.
369
- * For AJAX/SPA calls, MUST send the CSRF token via the `X-CSRFToken` header (or configured header name) as documented. ([Django Project][4])
370
- * MUST be very careful with `@csrf_exempt` and use it only when absolutely necessary; if used, MUST replace CSRF with an appropriate alternative control (e.g., request signing for webhooks). Django explicitly warns about `csrf_exempt`. ([Django Project][2])
371
-
372
- Insecure patterns:
373
-
374
- * Missing `CsrfViewMiddleware` in `MIDDLEWARE`.
375
- * `@csrf_exempt` on general-purpose authenticated views.
376
- * POST/PUT/PATCH/DELETE endpoints with session auth and no CSRF tokens.
377
- * Using GET for state-changing actions (amplifies CSRF risk).
378
-
379
- Detection hints:
380
-
381
- * Inspect `settings.py` `MIDDLEWARE` for `CsrfViewMiddleware` and its order (Django notes it should come before middleware that assumes CSRF is handled). ([Django Project][4])
382
- * Search for `csrf_exempt`, `csrf_protect`, `ensure_csrf_cookie`.
383
- * Enumerate URL patterns for non-GET methods; confirm CSRF coverage.
384
-
385
- Fix:
386
-
387
- * Re-enable `CsrfViewMiddleware`, add CSRF tokens to forms, and add AJAX header handling.
388
- * For caching decorators: if you cache a view that needs CSRF tokens, apply `@csrf_protect` as Django documents to avoid caching a response without CSRF cookie/Vary headers. ([Django Project][4])
389
-
390
- Notes:
391
-
392
- * When deployed with HTTPS, Django’s CSRF middleware also checks the Referer header for same-origin (Django security docs mention this). ([Django Project][2])
393
-
394
- ---
395
-
396
- ### DJANGO-XSS-001: Prevent reflected/stored XSS in templates and HTML generation
397
-
398
- Severity: High
399
-
400
- Required:
401
-
402
- * MUST rely on Django template auto-escaping (safe-by-default) for HTML templates. Django security docs highlight that Django templates escape dangerous characters but have limitations. ([Django Project][2])
403
- * MUST NOT disable auto-escaping broadly (`{% autoescape off %}`) unless the content is trusted or safely sanitized. ([Django Project][5])
404
- * MUST NOT mark untrusted content as safe:
405
-
406
- * Avoid `mark_safe(...)` on user data.
407
- * Avoid `|safe` on user-controlled content.
408
- * MUST be careful about HTML context pitfalls (e.g., unquoted attributes); Django explicitly shows an example where escaping does not protect an unquoted attribute context. ([Django Project][2])
409
- * SHOULD prefer safe HTML construction helpers (e.g., `format_html`) rather than manual concatenation that risks missing escapes. ([Django Project][6])
410
-
411
- Insecure patterns:
412
-
413
- * `{% autoescape off %}{{ user_input }}{% endautoescape %}`
414
- * `{{ user_input|safe }}`
415
- * `mark_safe(request.GET["q"])`
416
- * Unquoted attribute injections: `<style class={{ var }}>...` (Django’s own example). ([Django Project][2])
417
-
418
- Detection hints:
419
-
420
- * Search templates for `|safe`, `autoescape off`, `safeseq`.
421
- * Search Python for `mark_safe`, `SafeString`, or direct HTML concatenation with request/DB values.
422
- * Review any code returning `HttpResponse(user_value)` where `user_value` contains HTML.
423
-
424
- Fix:
425
-
426
- * Remove unsafe marking; sanitize only when strictly necessary (use an allowlist-based HTML sanitizer).
427
- * Quote attributes and avoid placing untrusted values into dangerous contexts.
428
- * Add CSP as defense-in-depth (see DJANGO-CSP-001). ([Django Project][2])
429
-
430
- ---
431
-
432
- ### DJANGO-TEMPLATE-001: Never render untrusted template source strings
433
-
434
- Severity: High to Critical (depends on context and exposure)
435
-
436
- Required:
437
-
438
- * MUST NOT render templates where the template source string is influenced by untrusted input (request, user content, DB rows editable by untrusted users).
439
- * MUST treat “template from string” patterns as dangerous, even if Django templates are more constrained than some other engines: they can still leak data from context, bypass escaping, and create XSS or content injection.
440
-
441
- Insecure patterns:
442
-
443
- * `Template(request.GET["tmpl"]).render(Context(...))`
444
- * Saving user templates in the DB and rendering them with normal privileges/context.
445
-
446
- Detection hints:
447
-
448
- * Search for `django.template.Template(`, `Engine.from_string`, `.render(Context(` with non-constant strings.
449
- * Trace where the template string comes from (admin panels, DB, uploads, requests).
450
-
451
- Fix:
452
-
453
- * Replace with non-executing formatting (e.g., `string.Template`, explicit placeholders) or a strict allowlisted rendering model.
454
- * If you *must* support user-defined templates, isolate heavily (separate service/tenant context, strict allowlists, and assume bypasses are possible).
455
-
456
- ---
457
-
458
- ### DJANGO-SQL-001: Prevent SQL injection (use ORM or parameterized raw SQL)
459
-
460
- Severity: High
461
-
462
- Required:
463
-
464
- * MUST use Django ORM/querysets for normal DB access; Django notes querysets are parameterized and protected from SQL injection under typical use. ([Django Project][2])
465
- * MUST be very careful with raw SQL; if using `raw()`, `cursor.execute()`, `extra()`, or `RawSQL`, MUST pass parameters separately (e.g., `params=`) and MUST NOT string-interpolate untrusted input into SQL. Django’s raw SQL docs warn to escape user-controlled parameters using `params`. ([Django Project][7])
466
- * MUST NOT quote placeholders in SQL templates (Django docs explicitly warn that quoting `%s` placeholders makes it unsafe). ([Django Project][8])
467
- * SHOULD avoid `extra()` and `RawSQL` unless necessary; Django security docs call for caution. ([Django Project][2])
468
-
469
- Insecure patterns:
470
-
471
- * `cursor.execute(f"SELECT ... WHERE id={request.GET['id']}")`
472
- * `Model.objects.raw("... %s" % user_input)` (string formatting)
473
- * `extra(where=[f"headline='{q}'"])`
474
- * Quoted placeholders: `WHERE othercol = '%s'` (explicitly documented as unsafe). ([Django Project][8])
475
-
476
- Detection hints:
477
-
478
- * Grep for `.raw(`, `.extra(`, `RawSQL(`, `connection.cursor()`, `.execute(`.
479
- * Grep for SQL keywords (`SELECT`, `UPDATE`, `DELETE`, `INSERT`) in Python strings.
480
- * Track untrusted inputs into these call sites.
481
-
482
- Fix:
483
-
484
- * Prefer ORM queries.
485
- * If raw SQL is unavoidable, use parameters (`params`, DB-API param binding) and do not quote placeholders. ([Django Project][7])
486
-
487
- ---
488
-
489
- ### DJANGO-CMD-001: Prevent OS command injection
490
-
491
- Severity: Critical to High (depends on exposure)
492
-
493
- Required:
494
-
495
- * MUST avoid executing system commands with attacker-influenced input.
496
- * If subprocess is necessary:
497
-
498
- * MUST pass args as a list (not a shell string).
499
- * MUST NOT use `shell=True` with attacker-influenced content.
500
- * SHOULD use strict allowlists for variable components.
501
- * SHOULD prefer pure-Python libraries instead of shelling out.
502
-
503
- Insecure patterns:
504
-
505
- * `os.system(request.GET["cmd"])`
506
- * `subprocess.run(f"convert {path}", shell=True)` where `path` is user-controlled.
507
-
508
- Detection hints:
509
-
510
- * Search `os.system`, `subprocess`, `Popen`, `shell=True`.
511
- * Trace request/DB inputs into those calls.
512
-
513
- Fix:
514
-
515
- * Replace with library APIs; if unavoidable, hard-code executable and allowlist validated parameters.
516
-
517
- ---
518
-
519
- ### DJANGO-UPLOAD-001: File uploads must be validated, stored safely, and served safely
520
-
521
- Severity: High
522
-
523
- Required:
524
-
525
- * MUST treat all user uploads as untrusted. Django explicitly warns “Media files are uploaded by your users. They’re untrusted!” ([Django Project][1])
526
- * MUST ensure the web server never interprets user uploads as executable code (e.g., don’t allow uploaded `.php` or HTML to execute/inline as active content). ([Django Project][1])
527
- * MUST enforce size limits (at least at the web server; Django security docs recommend limiting upload size at the server to prevent DoS). ([Django Project][2])
528
- * SHOULD validate file types using allowlists and content checks (not only extensions).
529
- * SHOULD store uploads outside the application code directory and outside any static root.
530
- * SHOULD consider serving uploads from a separate top-level/second-level domain to reduce same-origin impact; Django security docs recommend a distinct domain and note that a subdomain may be insufficient for some protections. ([Django Project][2])
531
- * MUST be aware of polyglot upload risks: Django documents a case where HTML can be uploaded “as an image” by using a valid PNG header (and may be served as HTML depending on the web server). ([Django Project][2])
532
-
533
- Insecure patterns:
534
-
535
- * Serving uploads inline with `text/html` or without forcing download for potentially active formats.
536
- * Upload allowlist based only on extension.
537
- * Upload storage inside static roots or code roots.
538
-
539
- Detection hints:
540
-
541
- * Search for `request.FILES`, `FileField`, `ImageField`, upload forms/views.
542
- * Inspect upload serving paths and Nginx/Apache config (media handlers).
543
- * Check `MEDIA_URL`, `MEDIA_ROOT`, and static config.
544
-
545
- Fix:
546
-
547
- * Configure the web server to serve uploads as inert bytes (no execution), and consider forcing `Content-Disposition: attachment` for risky types.
548
- * Use a separate domain for user content when warranted. ([Django Project][2])
549
-
550
- ---
551
-
552
- ### DJANGO-PATH-001: Prevent path traversal and unsafe file serving (static/media separation)
553
-
554
- Severity: High
555
-
556
- Required:
557
-
558
- * MUST NOT treat user input as a filesystem path for reads/writes/serving.
559
- * MUST keep `MEDIA_ROOT` and `STATIC_ROOT` distinct; Django settings docs explicitly warn they must have different values to avoid security implications. ([Django Project][3])
560
- * SHOULD prefer using Django storage APIs keyed by server-side identifiers rather than accepting arbitrary relative paths from users.
561
-
562
- Insecure patterns:
563
-
564
- * `open(os.path.join(MEDIA_ROOT, request.GET["path"]))`
565
- * Download endpoints that take `?file=../../...` style parameters.
566
- * Misconfigured `MEDIA_ROOT == STATIC_ROOT`.
567
-
568
- Detection hints:
569
-
570
- * Grep for `open(`, `Path(`, `os.path.join(` used with request values.
571
- * Check `MEDIA_ROOT`, `STATIC_ROOT` in settings. ([Django Project][3])
572
-
573
- Fix:
574
-
575
- * Use server-side IDs mapped to known files.
576
- * Keep static and media separated and ensure the web server treats media as untrusted. ([Django Project][3])
577
-
578
- ---
579
-
580
- ### DJANGO-REDIRECT-001: Prevent open redirects (`next`, `return_to`, `redirect`)
581
-
582
- Severity: Medium (High when combined with auth flows)
583
-
584
- Required:
585
-
586
- * MUST validate redirect targets derived from untrusted input (e.g., `next`, `return_to`).
587
- * SHOULD restrict to same-site relative paths or allowlisted hosts/schemes.
588
- * SHOULD use Django’s safe URL helpers (e.g., `django.utils.http.url_has_allowed_host_and_scheme`) rather than custom parsing.
589
-
590
- Insecure patterns:
591
-
592
- * `return redirect(request.GET.get("next"))` with no validation.
593
- * Redirect allowlist implemented with naive string checks.
594
-
595
- Detection hints:
596
-
597
- * Search for `redirect(` and track origin of the target.
598
- * Search for parameters named `next`, `return_to`, `redirect`, `url`.
599
-
600
- Fix:
601
-
602
- * Validate with allowlists and default to a safe internal path if validation fails.
603
- * Ensure host validation via `ALLOWED_HOSTS` remains strict (see DJANGO-HOST-001). ([Django Project][3])
604
-
605
- ---
606
-
607
- ### DJANGO-HEADERS-001: Enable essential security headers (SecurityMiddleware + clickjacking protection)
608
-
609
- Severity: Medium to High
610
-
611
- Required:
612
-
613
- * SHOULD use `django.middleware.security.SecurityMiddleware` and configure it appropriately (production) for:
614
-
615
- * `X-Content-Type-Options: nosniff` (Django setting `SECURE_CONTENT_TYPE_NOSNIFF`, default `True`). ([Django Project][3])
616
- * `Referrer-Policy` (Django setting `SECURE_REFERRER_POLICY`, default `'same-origin'`). ([Django Project][3])
617
- * COOP (Django setting `SECURE_CROSS_ORIGIN_OPENER_POLICY`, default `'same-origin'`). ([Django Project][3])
618
- * HTTPS redirects and HSTS as appropriate (see DJANGO-HTTPS-001). ([Django Project][3])
619
- * SHOULD enable clickjacking protection via X-Frame-Options middleware; Django security docs strongly recommend it for sites that don’t need third-party framing. ([Django Project][2])
620
-
621
- Insecure patterns:
622
-
623
- * Missing SecurityMiddleware.
624
- * Missing clickjacking protection (or disabling it globally) without a clear framing requirement.
625
- * Over-broad framing allowances for sensitive endpoints.
626
-
627
- Detection hints:
628
-
629
- * Inspect `MIDDLEWARE` for SecurityMiddleware and XFrameOptionsMiddleware.
630
- * Search for per-view disabling of framing/CSRF protections.
631
-
632
- Fix:
633
-
634
- * Add/enable middleware and configure the settings intentionally. ([Django Project][3])
635
-
636
- NOTE:
637
-
638
- * Some headers may be set at the edge (CDN/reverse proxy). If not visible in app code, flag as “verify at edge”.
639
-
640
- ---
641
-
642
- ### DJANGO-CSP-001: Deploy a Content Security Policy (CSP) as defense-in-depth
643
-
644
- Severity: Medium (High for apps rendering untrusted content)
645
-
646
- NOTE: It is most important to set the CSP's script-src. All other directives are not as important and can generally be excluded for the ease of development.
647
-
648
- Required:
649
-
650
- * SHOULD deploy a CSP to mitigate XSS and content injection classes; Django’s security docs recommend CSP and note it is new in Django 6.0. ([Django Project][2])
651
- * MUST understand CSP limitations:
652
-
653
- * Avoid excluding routes from CSP coverage; Django warns that an unprotected page can undermine protected pages due to same-origin policy. ([Django Project][2])
654
- * MAY start with `SECURE_CSP_REPORT_ONLY` to iterate safely (Django provides report-only support). ([Django Project][3])
655
-
656
- Insecure patterns:
657
-
658
- * No CSP on apps that render user-controlled content.
659
- * CSP excludes “just a couple pages” (weakens overall protection), especially pages with any injection surface. ([Django Project][2])
660
- * CSP uses overly permissive directives (e.g., widespread `unsafe-inline`) without justification.
661
-
662
- Detection hints:
663
-
664
- * Search `SECURE_CSP`, `SECURE_CSP_REPORT_ONLY`, and CSP middleware configuration.
665
- * Inspect reverse proxy/CDN config for CSP headers.
666
-
667
- Fix:
668
-
669
- * Implement a realistic CSP, ideally report-only first, then enforce. ([Django Project][3])
670
-
671
- ---
672
-
673
- ### DJANGO-AUTH-001: Password storage must use Django’s secure hashers; password policy must be configured
674
-
675
- Severity: High
676
-
677
- Required:
678
-
679
- * MUST use Django’s built-in password hashing (never store plaintext or reversible encrypted passwords).
680
- * SHOULD prefer modern hashers and keep defaults updated; Django documents `PASSWORD_HASHERS` and includes modern options (Argon2, bcrypt, scrypt, PBKDF2 variants). ([Django Project][3])
681
- * SHOULD configure `AUTH_PASSWORD_VALIDATORS` (default is empty) for production password policy. ([Django Project][3])
682
-
683
- Insecure patterns:
684
-
685
- * Custom password storage or hashing.
686
- * Plaintext passwords stored in DB fields.
687
- * No password validation on consumer-facing apps.
688
-
689
- Detection hints:
690
-
691
- * Search for `.set_password(` usage vs manual hashing.
692
- * Inspect settings for `PASSWORD_HASHERS` and `AUTH_PASSWORD_VALIDATORS`. ([Django Project][3])
693
-
694
- Fix:
695
-
696
- * Use Django auth user model APIs.
697
- * Enable password validators appropriate to the product’s risk profile. ([Django Project][3])
698
-
699
- ---
700
-
701
- ### DJANGO-AUTHZ-001: Authorization must be explicit and consistent
702
-
703
- Severity: High
704
-
705
- Required:
706
-
707
- * MUST enforce authorization checks on every privileged action (view, modify, admin-like operations).
708
- * MUST NOT rely on UI-only restrictions (e.g., hiding buttons) without server-side permission checks.
709
- * SHOULD use Django’s permissions/groups and per-object authorization patterns where applicable.
710
-
711
- Insecure patterns:
712
-
713
- * Views that assume “user is logged in” implies “user may do action”.
714
- * Missing authorization checks on update/delete endpoints.
715
-
716
- Detection hints:
717
-
718
- * Enumerate views that modify state; ensure they validate ownership/permission.
719
- * Look for use of only `is_authenticated` or only `is_staff` without checking object-level access.
720
-
721
- Fix:
722
-
723
- * Add explicit permission checks and tests for unauthorized access.
724
-
725
- ---
726
-
727
- ### DJANGO-ADMIN-001: Django admin must be treated as a high-value target
728
-
729
- Severity: High
730
-
731
- Required:
732
-
733
- * MUST ensure admin is protected by strong authentication and HTTPS-only transport (see DJANGO-HTTPS-001). ([Django Project][1])
734
- * SHOULD restrict admin exposure (network allowlists, VPN, SSO, or additional authentication controls) when possible.
735
- * SHOULD audit installed admin extensions and third-party apps for XSS/CSRF exposure.
736
-
737
- Insecure patterns:
738
-
739
- * Admin exposed to the internet with weak authentication.
740
- * Admin served over HTTP.
741
-
742
- Detection hints:
743
-
744
- * Search `urlpatterns` for `admin.site.urls`.
745
- * Check deployment config for IP allowlisting or auth gateways.
746
-
747
- Fix:
748
-
749
- * Add network controls and enforce HTTPS.
750
-
751
- ---
752
-
753
- ### DJANGO-LOG-001: Logging and error reporting must not leak secrets
754
-
755
- Severity: Medium to High
756
-
757
- Required:
758
-
759
- * MUST NOT log secrets (including `SECRET_KEY`, session cookies, auth headers, password reset tokens).
760
- * MUST configure production logging deliberately; Django’s deployment checklist explicitly calls out reviewing logging before production. ([Django Project][1])
761
- * MUST ensure `DEBUG=False` in production so exceptions aren’t rendered with sensitive context. ([Django Project][1])
762
-
763
- Insecure patterns:
764
-
765
- * Logging full request headers or cookies in production.
766
- * Printing settings dictionaries.
767
- * Debug error pages.
768
-
769
- Detection hints:
770
-
771
- * Inspect `LOGGING` config; search for middleware that logs request headers/cookies.
772
- * Grep for `print(settings` / `logging.info(request.META)` patterns.
773
-
774
- Fix:
775
-
776
- * Redact sensitive values; log IDs not secrets.
777
- * Use structured logging and a safe error monitoring tool. ([Django Project][1])
778
-
779
- ---
780
-
781
- ### DJANGO-SUPPLY-001: Dependency and patch hygiene (Django + security-critical deps)
782
-
783
- Severity: Medium (High if known vulnerable versions)
784
-
785
- Required:
786
-
787
- * SHOULD pin and regularly update Django and security-critical dependencies.
788
- * MUST respond to Django security releases promptly.
789
-
790
- Detection hints:
791
-
792
- * Check `requirements.txt`, lockfiles, build images.
793
- * Identify Django version; compare against latest supported release (Django’s download page publishes current stable and supported branches). ([Django Project][9])
794
-
795
- Fix:
796
-
797
- * Upgrade to patched versions; add regression tests for previously vulnerable classes.
798
-
799
- ---
800
-
801
- ## 5) Practical scanning heuristics (how to “hunt”)
802
-
803
- When actively scanning, use these high-signal patterns:
804
-
805
- * Deployment/dev server:
806
-
807
- * `manage.py runserver`, `runserver 0.0.0.0`, `--insecure` ([Django Project][1])
808
- * Debug / settings:
809
-
810
- * `DEBUG = True` ([Django Project][1])
811
- * `SECRET_KEY =`, `SECRET_KEY_FALLBACKS` ([Django Project][1])
812
- * Host validation:
813
-
814
- * `ALLOWED_HOSTS = ['*']` ([Django Project][3])
815
- * HTTPS and proxy:
816
-
817
- * `SECURE_SSL_REDIRECT`, `SECURE_HSTS_SECONDS`, `SECURE_PROXY_SSL_HEADER` ([Django Project][3])
818
- * Cookies / sessions:
819
-
820
- * `SESSION_COOKIE_SECURE`, `SESSION_COOKIE_HTTPONLY`, `SESSION_COOKIE_SAMESITE` ([Django Project][3])
821
- * `CSRF_COOKIE_SECURE`, `CSRF_COOKIE_HTTPONLY`, `CSRF_COOKIE_SAMESITE` ([Django Project][3])
822
- * CSRF bypasses:
823
-
824
- * `csrf_exempt`, missing `CsrfViewMiddleware`, POST forms without `{% csrf_token %}` ([Django Project][4])
825
- * XSS:
826
-
827
- * `|safe`, `autoescape off`, `mark_safe(`, HTML string concatenation ([Django Project][5])
828
- * SQL injection:
829
-
830
- * `.raw(`, `.extra(`, `RawSQL(`, `cursor.execute(` with formatted SQL strings ([Django Project][7])
831
- * User uploads / media:
832
-
833
- * `request.FILES`, `MEDIA_ROOT`, `MEDIA_URL`, serving media inline; `MEDIA_ROOT == STATIC_ROOT` ([Django Project][1])
834
- * Redirects:
835
-
836
- * `redirect(request.GET.get("next"))` patterns; missing allowlist validation
837
- * Security headers and CSP:
838
-
839
- * Missing `SecurityMiddleware`, missing X-Frame-Options protection, missing `SECURE_CSP` adoption (where appropriate) ([Django Project][2])
840
-
841
- Always try to confirm:
842
-
843
- * data origin (untrusted vs trusted)
844
- * sink type (template/SQL/subprocess/files/redirect/http)
845
- * protective controls present (middleware, validation, allowlists, authz checks)
846
- * whether security headers/controls are set in-app vs at the edge
847
-
848
- ---
849
-
850
- ## 6) Sources (accessed 2026-01-27)
851
-
852
- Primary Django documentation:
853
-
854
- ```text
855
- - Django Downloads (current stable & supported branches): https://www.djangoproject.com/download/
856
- - Django 6.0 Release Notes: https://docs.djangoproject.com/en/6.0/releases/6.0/
857
- - Django: Deployment checklist (incl. check --deploy, runserver warning, HTTPS/cookies guidance): https://docs.djangoproject.com/en/6.0/howto/deployment/checklist/
858
- - Django: Settings reference (SecurityMiddleware settings, cookies, SECRET_KEY_FALLBACKS, CSP settings): https://docs.djangoproject.com/en/6.0/ref/settings/
859
- - Django: Security in Django (XSS/CSRF/SQLi/clickjacking/HTTPS/host header validation/uploads/CSP): https://docs.djangoproject.com/en/6.0/topics/security/
860
- - Django: CSRF how-to (middleware, csrf_token usage, AJAX header patterns, csrf_exempt cautions): https://docs.djangoproject.com/en/6.0/howto/csrf/
861
- - Django: Performing raw SQL queries (parameterization guidance): https://docs.djangoproject.com/en/6.0/topics/db/sql/
862
- - Django: QuerySet API reference (extra() cautions; “do not quote placeholders” guidance): https://docs.djangoproject.com/en/6.0/ref/models/querysets/
863
- - Django: Template built-ins (autoescape tag): https://docs.djangoproject.com/en/6.0/ref/templates/builtins/
864
- - Django: Template language reference (turning off autoescape & risks): https://docs.djangoproject.com/en/6.0/ref/templates/language/
865
- - Django: Utilities reference (e.g., format_html): https://docs.djangoproject.com/en/6.0/ref/utils/
866
- ```
867
-
868
- OWASP:
869
-
870
- ```text
871
- - OWASP Cheat Sheet Series: Django Security Cheat Sheet: https://cheatsheetseries.owasp.org/cheatsheets/Django_Security_Cheat_Sheet.html
872
- ```
873
-
874
- [1]: https://docs.djangoproject.com/en/6.0/howto/deployment/checklist/ "https://docs.djangoproject.com/en/6.0/howto/deployment/checklist/"
875
- [2]: https://docs.djangoproject.com/en/6.0/topics/security/ "Security in Django | Django documentation | Django"
876
- [3]: https://docs.djangoproject.com/en/6.0/ref/settings/ "Settings | Django documentation | Django"
877
- [4]: https://docs.djangoproject.com/en/6.0/howto/csrf/ "How to use Django’s CSRF protection | Django documentation | Django"
878
- [5]: https://docs.djangoproject.com/en/6.0/ref/templates/builtins/ "https://docs.djangoproject.com/en/6.0/ref/templates/builtins/"
879
- [6]: https://docs.djangoproject.com/en/6.0/ref/utils/ "https://docs.djangoproject.com/en/6.0/ref/utils/"
880
- [7]: https://docs.djangoproject.com/en/6.0/topics/db/sql/ "https://docs.djangoproject.com/en/6.0/topics/db/sql/"
881
- [8]: https://docs.djangoproject.com/en/6.0/ref/models/querysets/ "https://docs.djangoproject.com/en/6.0/ref/models/querysets/"
882
- [9]: https://www.djangoproject.com/download/ "Download Django | Django"