@oriro/orirocli 0.1.11 → 0.1.12
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.
- package/ATTRIBUTION.md +53 -53
- package/LICENSE +21 -21
- package/README.md +2 -7
- package/dist/cli.js +402 -40
- package/package.json +64 -64
- package/skills/1password/SKILL.md +118 -118
- package/skills/1password/references/cli-examples.md +29 -29
- package/skills/1password/references/get-started.md +21 -21
- package/skills/21stdev/SKILL.md +64 -64
- package/skills/algorithmic-art/LICENSE +21 -21
- package/skills/algorithmic-art/SKILL.md +446 -446
- package/skills/algorithmic-art/templates/generator_template.js +223 -223
- package/skills/algorithmic-art/templates/viewer.html +598 -598
- package/skills/apple-notes/SKILL.md +81 -81
- package/skills/apple-reminders/SKILL.md +122 -122
- package/skills/bear-notes/SKILL.md +111 -111
- package/skills/blogwatcher/SKILL.md +73 -73
- package/skills/blucli/SKILL.md +51 -51
- package/skills/brand-guidelines/LICENSE +21 -21
- package/skills/brand-guidelines/SKILL.md +76 -76
- package/skills/business/biz-analysis/LICENSE +21 -21
- package/skills/business/biz-analysis/SKILL.md +103 -103
- package/skills/business/biz-corporate-strategy/LICENSE +21 -21
- package/skills/business/biz-corporate-strategy/SKILL.md +76 -76
- package/skills/business/biz-customer-success/LICENSE +21 -21
- package/skills/business/biz-customer-success/SKILL.md +55 -55
- package/skills/business/biz-entrepreneurship/LICENSE +21 -21
- package/skills/business/biz-entrepreneurship/SKILL.md +72 -72
- package/skills/business/biz-hr/LICENSE +21 -21
- package/skills/business/biz-hr/SKILL.md +67 -67
- package/skills/business/biz-international/LICENSE +21 -21
- package/skills/business/biz-international/SKILL.md +51 -51
- package/skills/business/biz-leadership/LICENSE +21 -21
- package/skills/business/biz-leadership/SKILL.md +106 -106
- package/skills/business/biz-marketing-strategy/LICENSE +21 -21
- package/skills/business/biz-marketing-strategy/SKILL.md +119 -119
- package/skills/business/biz-negotiation/LICENSE +21 -21
- package/skills/business/biz-negotiation/SKILL.md +152 -152
- package/skills/business/biz-operations/LICENSE +21 -21
- package/skills/business/biz-operations/SKILL.md +74 -74
- package/skills/business/biz-project/LICENSE +21 -21
- package/skills/business/biz-project/SKILL.md +203 -203
- package/skills/business/biz-risk/LICENSE +21 -21
- package/skills/business/biz-risk/SKILL.md +85 -85
- package/skills/business/biz-sales/LICENSE +21 -21
- package/skills/business/biz-sales/SKILL.md +92 -92
- package/skills/business/biz-startup-ops/LICENSE +21 -21
- package/skills/business/biz-startup-ops/SKILL.md +70 -70
- package/skills/business/biz-strategy/LICENSE +21 -21
- package/skills/business/biz-strategy/SKILL.md +233 -233
- package/skills/business/biz-supply-chain-advanced/LICENSE +21 -21
- package/skills/business/biz-supply-chain-advanced/SKILL.md +68 -68
- package/skills/business/fin-chartered-exams/LICENSE +21 -21
- package/skills/business/fin-chartered-exams/SKILL.md +69 -69
- package/skills/camsnap/SKILL.md +49 -49
- package/skills/canvas/SKILL.md +82 -82
- package/skills/canvas-design/LICENSE +21 -21
- package/skills/canvas-design/SKILL.md +140 -140
- package/skills/canvas-design/canvas-fonts/ArsenalSC-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/BigShoulders-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/Boldonse-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/BricolageGrotesque-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/CrimsonPro-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/DMMono-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/EricaOne-OFL.txt +94 -94
- package/skills/canvas-design/canvas-fonts/GeistMono-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/Gloock-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/IBMPlexMono-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/InstrumentSans-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/JetBrainsMono-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/Jura-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/LibreBaskerville-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/Lora-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/NationalPark-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/Outfit-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/PixelifySans-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/RedHatMono-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/Silkscreen-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/SmoochSans-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/Tektur-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/WorkSans-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/YoungSerif-OFL.txt +93 -93
- package/skills/coding-agent/SKILL.md +146 -146
- package/skills/communication/comm-business-writing/LICENSE +21 -21
- package/skills/communication/comm-business-writing/SKILL.md +67 -67
- package/skills/communication/comm-cross-cultural/LICENSE +21 -21
- package/skills/communication/comm-cross-cultural/SKILL.md +88 -88
- package/skills/communication/comm-journalism/LICENSE +21 -21
- package/skills/communication/comm-journalism/SKILL.md +81 -81
- package/skills/communication/comm-linguistics/LICENSE +21 -21
- package/skills/communication/comm-linguistics/SKILL.md +82 -82
- package/skills/communication/comm-negotiation/LICENSE +21 -21
- package/skills/communication/comm-negotiation/SKILL.md +120 -120
- package/skills/communication/comm-presentations/LICENSE +21 -21
- package/skills/communication/comm-presentations/SKILL.md +93 -93
- package/skills/communication/comm-public-speaking/LICENSE +21 -21
- package/skills/communication/comm-public-speaking/SKILL.md +68 -68
- package/skills/communication/comm-writing/LICENSE +21 -21
- package/skills/communication/comm-writing/SKILL.md +69 -69
- package/skills/craft/ai-engineering/LICENSE +21 -21
- package/skills/craft/ai-engineering/SKILL.md +828 -828
- package/skills/craft/app-builder-guide/LICENSE +21 -21
- package/skills/craft/app-builder-guide/SKILL.md +332 -332
- package/skills/craft/become-an-ai-engineer-26/CONTRIBUTING.md +46 -46
- package/skills/craft/become-an-ai-engineer-26/LICENSE +21 -21
- package/skills/craft/become-an-ai-engineer-26/README.md +270 -270
- package/skills/craft/become-an-ai-engineer-26/SKILL.md +667 -667
- package/skills/craft/become-an-ai-engineer-26/community/BUILDS.md +13 -13
- package/skills/craft/become-an-ai-engineer-26/community/DISCUSSIONS.md +8 -8
- package/skills/craft/become-an-ai-engineer-26/phases/phase-0-mental-models/README.md +14 -14
- package/skills/craft/become-an-ai-engineer-26/phases/phase-0-mental-models/project/TEMPLATE.md +33 -33
- package/skills/craft/become-an-ai-engineer-26/phases/phase-1-first-agent/README.md +25 -25
- package/skills/craft/become-an-ai-engineer-26/phases/phase-1-first-agent/code/raw_loop.py +126 -126
- package/skills/craft/become-an-ai-engineer-26/phases/phase-2-architecture/README.md +17 -17
- package/skills/craft/become-an-ai-engineer-26/phases/phase-3-harness/README.md +17 -17
- package/skills/craft/become-an-ai-engineer-26/phases/phase-4-evals/README.md +21 -21
- package/skills/craft/become-an-ai-engineer-26/phases/phase-4-evals/code/.github/workflows/eval.yml +40 -40
- package/skills/craft/become-an-ai-engineer-26/phases/phase-5-production/README.md +16 -16
- package/skills/craft/become-an-ai-engineer-26/projects/1-mobile-app-slm/README.md +11 -11
- package/skills/craft/become-an-ai-engineer-26/projects/2-self-improving-coder/README.md +11 -11
- package/skills/craft/become-an-ai-engineer-26/projects/3-video-editor-agent/README.md +11 -11
- package/skills/craft/become-an-ai-engineer-26/projects/4-personal-life-os/README.md +12 -12
- package/skills/craft/become-an-ai-engineer-26/projects/5-enterprise-workflow/README.md +12 -12
- package/skills/craft/become-an-ai-engineer-26/references/benchmark-numbers.md +41 -41
- package/skills/craft/become-an-ai-engineer-26/references/mhc-stable-training.md +73 -73
- package/skills/craft/become-an-ai-engineer-26/references/stack-decisions.md +37 -37
- package/skills/craft/become-an-ai-engineer-26/references/yarn-context-extension.md +123 -123
- package/skills/craft/codex-result-handling/LICENSE +21 -21
- package/skills/craft/codex-result-handling/SKILL.md +26 -26
- package/skills/craft/debug-and-build-methodology/LICENSE +21 -21
- package/skills/craft/debug-and-build-methodology/SKILL.md +432 -432
- package/skills/craft/design/LICENSE +21 -21
- package/skills/craft/design/SKILL.md +274 -274
- package/skills/craft/dev/LICENSE +21 -21
- package/skills/craft/dev/SKILL.md +12 -12
- package/skills/craft/dev/release.md +85 -85
- package/skills/craft/dev/roll.md +50 -50
- package/skills/craft/doc-coauthoring/LICENSE +21 -21
- package/skills/craft/doc-coauthoring/SKILL.md +397 -397
- package/skills/craft/focus/LICENSE +21 -21
- package/skills/craft/focus/SKILL.md +432 -432
- package/skills/craft/focus/UPSTREAM_README.md +233 -233
- package/skills/craft/gh/LICENSE +21 -21
- package/skills/craft/gh/SKILL.md +84 -84
- package/skills/craft/gh-skill/LICENSE +21 -21
- package/skills/craft/gh-skill/SKILL.md +121 -121
- package/skills/craft/godmode/LICENSE +21 -21
- package/skills/craft/godmode/SKILL.md +87 -87
- package/skills/craft/godmode/references/android-launch.md +680 -680
- package/skills/craft/godmode/references/data-gcp.md +1038 -1038
- package/skills/craft/godmode/references/expo-eas.md +816 -816
- package/skills/craft/godmode/references/ios-launch.md +734 -734
- package/skills/craft/google-ai-latest/LICENSE +21 -21
- package/skills/craft/google-ai-latest/SKILL.md +682 -682
- package/skills/craft/gpt-5-4-prompting/LICENSE +21 -21
- package/skills/craft/gpt-5-4-prompting/SKILL.md +63 -63
- package/skills/craft/gpt-5-4-prompting/references/codex-prompt-antipatterns.md +101 -101
- package/skills/craft/gpt-5-4-prompting/references/codex-prompt-recipes.md +150 -150
- package/skills/craft/gpt-5-4-prompting/references/prompt-blocks.md +172 -172
- package/skills/craft/grill-me/LICENSE +21 -21
- package/skills/craft/grill-me/SKILL.md +13 -13
- package/skills/craft/idea-to-deploy/LICENSE +21 -21
- package/skills/craft/idea-to-deploy/SKILL.md +292 -292
- package/skills/craft/idea-to-deploy/references/auth-playbook.md +195 -195
- package/skills/craft/idea-to-deploy/references/gcp-deployment.md +268 -268
- package/skills/craft/idea-to-deploy/references/stack-selection.md +117 -117
- package/skills/craft/image-generation-engineer/LICENSE +21 -21
- package/skills/craft/image-generation-engineer/SKILL.md +183 -183
- package/skills/craft/image-generation-engineer/references/architectures.md +260 -260
- package/skills/craft/image-generation-engineer/references/foundations.md +107 -107
- package/skills/craft/image-generation-engineer/references/inference-and-serving.md +253 -253
- package/skills/craft/image-generation-engineer/references/training.md +149 -149
- package/skills/craft/marketing/LICENSE +21 -21
- package/skills/craft/marketing/SKILL.md +1954 -1954
- package/skills/craft/master-architect/LICENSE +21 -21
- package/skills/craft/master-architect/SKILL.md +361 -361
- package/skills/craft/master-architect/references/ai-ml.md +317 -317
- package/skills/craft/master-architect/references/architecture.md +268 -268
- package/skills/craft/master-architect/references/auth-playbook.md +195 -195
- package/skills/craft/master-architect/references/cloud.md +323 -323
- package/skills/craft/master-architect/references/cyber.md +839 -839
- package/skills/craft/master-architect/references/data-eng.md +366 -366
- package/skills/craft/master-architect/references/devops.md +550 -550
- package/skills/craft/master-architect/references/gcp-deployment.md +268 -268
- package/skills/craft/master-architect/references/languages.md +748 -748
- package/skills/craft/master-architect/references/legacy.md +240 -240
- package/skills/craft/master-architect/references/mobile.md +447 -447
- package/skills/craft/master-architect/references/patterns.md +451 -451
- package/skills/craft/master-architect/references/saas-patterns.md +379 -379
- package/skills/craft/master-architect/references/sdlc.md +349 -349
- package/skills/craft/master-architect/references/stack-selection.md +117 -117
- package/skills/craft/oriro-ui-2026/LICENSE +21 -21
- package/skills/craft/oriro-ui-2026/SKILL.md +329 -329
- package/skills/craft/playwright-cli/LICENSE +21 -21
- package/skills/craft/playwright-cli/SKILL.md +393 -393
- package/skills/craft/playwright-cli/references/element-attributes.md +23 -23
- package/skills/craft/playwright-cli/references/playwright-tests.md +39 -39
- package/skills/craft/playwright-cli/references/request-mocking.md +87 -87
- package/skills/craft/playwright-cli/references/running-code.md +240 -240
- package/skills/craft/playwright-cli/references/session-management.md +226 -226
- package/skills/craft/playwright-cli/references/spec-driven-testing.md +312 -312
- package/skills/craft/playwright-cli/references/storage-state.md +275 -275
- package/skills/craft/playwright-cli/references/test-generation.md +134 -134
- package/skills/craft/playwright-cli/references/tracing.md +142 -142
- package/skills/craft/playwright-cli/references/video-recording.md +150 -150
- package/skills/craft/remotion-best-practices/LICENSE +21 -21
- package/skills/craft/remotion-best-practices/SKILL.md +345 -345
- package/skills/craft/remotion-best-practices/rules/3d.md +86 -86
- package/skills/craft/remotion-best-practices/rules/assets/charts-bar-chart.tsx +165 -165
- package/skills/craft/remotion-best-practices/rules/assets/text-animations-typewriter.tsx +89 -89
- package/skills/craft/remotion-best-practices/rules/assets/text-animations-word-highlight.tsx +101 -101
- package/skills/craft/remotion-best-practices/rules/audio-visualization.md +195 -195
- package/skills/craft/remotion-best-practices/rules/audio.md +167 -167
- package/skills/craft/remotion-best-practices/rules/calculate-metadata.md +118 -118
- package/skills/craft/remotion-best-practices/rules/compositions.md +132 -132
- package/skills/craft/remotion-best-practices/rules/display-captions.md +176 -176
- package/skills/craft/remotion-best-practices/rules/ffmpeg.md +34 -34
- package/skills/craft/remotion-best-practices/rules/get-audio-duration.md +58 -58
- package/skills/craft/remotion-best-practices/rules/get-video-dimensions.md +68 -68
- package/skills/craft/remotion-best-practices/rules/get-video-duration.md +60 -60
- package/skills/craft/remotion-best-practices/rules/gifs.md +135 -135
- package/skills/craft/remotion-best-practices/rules/google-fonts.md +72 -72
- package/skills/craft/remotion-best-practices/rules/html-in-canvas.md +122 -122
- package/skills/craft/remotion-best-practices/rules/images.md +67 -67
- package/skills/craft/remotion-best-practices/rules/import-srt-captions.md +69 -69
- package/skills/craft/remotion-best-practices/rules/light-leaks.md +73 -73
- package/skills/craft/remotion-best-practices/rules/local-fonts.md +65 -65
- package/skills/craft/remotion-best-practices/rules/lottie.md +67 -67
- package/skills/craft/remotion-best-practices/rules/maplibre.md +441 -441
- package/skills/craft/remotion-best-practices/rules/measuring-dom-nodes.md +34 -34
- package/skills/craft/remotion-best-practices/rules/measuring-text.md +140 -140
- package/skills/craft/remotion-best-practices/rules/parameters.md +109 -109
- package/skills/craft/remotion-best-practices/rules/sequencing.md +144 -144
- package/skills/craft/remotion-best-practices/rules/sfx.md +30 -30
- package/skills/craft/remotion-best-practices/rules/silence-detection.md +73 -73
- package/skills/craft/remotion-best-practices/rules/subtitles.md +36 -36
- package/skills/craft/remotion-best-practices/rules/tailwind.md +11 -11
- package/skills/craft/remotion-best-practices/rules/text-animations.md +20 -20
- package/skills/craft/remotion-best-practices/rules/timing.md +130 -130
- package/skills/craft/remotion-best-practices/rules/transcribe-captions.md +70 -70
- package/skills/craft/remotion-best-practices/rules/transitions.md +193 -193
- package/skills/craft/remotion-best-practices/rules/transparent-videos.md +102 -102
- package/skills/craft/remotion-best-practices/rules/trimming.md +51 -51
- package/skills/craft/remotion-best-practices/rules/videos.md +169 -169
- package/skills/craft/remotion-best-practices/rules/voiceover.md +94 -94
- package/skills/craft/supabase-postgres-best-practices/CHANGELOG.md +25 -25
- package/skills/craft/supabase-postgres-best-practices/LICENSE +21 -21
- package/skills/craft/supabase-postgres-best-practices/SKILL.md +69 -69
- package/skills/craft/supabase-postgres-best-practices/references/_contributing.md +166 -166
- package/skills/craft/supabase-postgres-best-practices/references/_sections.md +47 -47
- package/skills/craft/supabase-postgres-best-practices/references/_template.md +34 -34
- package/skills/craft/supabase-postgres-best-practices/references/advanced-full-text-search.md +55 -55
- package/skills/craft/supabase-postgres-best-practices/references/advanced-jsonb-indexing.md +49 -49
- package/skills/craft/supabase-postgres-best-practices/references/conn-idle-timeout.md +46 -46
- package/skills/craft/supabase-postgres-best-practices/references/conn-limits.md +44 -44
- package/skills/craft/supabase-postgres-best-practices/references/conn-pooling.md +41 -41
- package/skills/craft/supabase-postgres-best-practices/references/conn-prepared-statements.md +46 -46
- package/skills/craft/supabase-postgres-best-practices/references/data-batch-inserts.md +54 -54
- package/skills/craft/supabase-postgres-best-practices/references/data-n-plus-one.md +53 -53
- package/skills/craft/supabase-postgres-best-practices/references/data-pagination.md +50 -50
- package/skills/craft/supabase-postgres-best-practices/references/data-upsert.md +50 -50
- package/skills/craft/supabase-postgres-best-practices/references/lock-advisory.md +56 -56
- package/skills/craft/supabase-postgres-best-practices/references/lock-deadlock-prevention.md +68 -68
- package/skills/craft/supabase-postgres-best-practices/references/lock-short-transactions.md +50 -50
- package/skills/craft/supabase-postgres-best-practices/references/lock-skip-locked.md +54 -54
- package/skills/craft/supabase-postgres-best-practices/references/monitor-explain-analyze.md +45 -45
- package/skills/craft/supabase-postgres-best-practices/references/monitor-pg-stat-statements.md +55 -55
- package/skills/craft/supabase-postgres-best-practices/references/monitor-vacuum-analyze.md +55 -55
- package/skills/craft/supabase-postgres-best-practices/references/query-composite-indexes.md +44 -44
- package/skills/craft/supabase-postgres-best-practices/references/query-covering-indexes.md +40 -40
- package/skills/craft/supabase-postgres-best-practices/references/query-index-types.md +48 -48
- package/skills/craft/supabase-postgres-best-practices/references/query-missing-indexes.md +43 -43
- package/skills/craft/supabase-postgres-best-practices/references/query-partial-indexes.md +45 -45
- package/skills/craft/supabase-postgres-best-practices/references/schema-constraints.md +80 -80
- package/skills/craft/supabase-postgres-best-practices/references/schema-data-types.md +46 -46
- package/skills/craft/supabase-postgres-best-practices/references/schema-foreign-key-indexes.md +59 -59
- package/skills/craft/supabase-postgres-best-practices/references/schema-lowercase-identifiers.md +55 -55
- package/skills/craft/supabase-postgres-best-practices/references/schema-partitioning.md +55 -55
- package/skills/craft/supabase-postgres-best-practices/references/schema-primary-keys.md +61 -61
- package/skills/craft/supabase-postgres-best-practices/references/security-privileges.md +54 -54
- package/skills/craft/supabase-postgres-best-practices/references/security-rls-basics.md +50 -50
- package/skills/craft/supabase-postgres-best-practices/references/security-rls-performance.md +63 -63
- package/skills/craft/uipm-banner-design/LICENSE +21 -21
- package/skills/craft/uipm-banner-design/SKILL.md +201 -201
- package/skills/craft/uipm-banner-design/references/banner-sizes-and-styles.md +129 -129
- package/skills/craft/uipm-brand/LICENSE +21 -21
- package/skills/craft/uipm-brand/SKILL.md +104 -104
- package/skills/craft/uipm-brand/references/approval-checklist.md +184 -184
- package/skills/craft/uipm-brand/references/asset-organization.md +167 -167
- package/skills/craft/uipm-brand/references/brand-guideline-template.md +161 -161
- package/skills/craft/uipm-brand/references/color-palette-management.md +203 -203
- package/skills/craft/uipm-brand/references/consistency-checklist.md +105 -105
- package/skills/craft/uipm-brand/references/logo-usage-rules.md +204 -204
- package/skills/craft/uipm-brand/references/messaging-framework.md +91 -91
- package/skills/craft/uipm-brand/references/typography-specifications.md +265 -265
- package/skills/craft/uipm-brand/references/update.md +128 -128
- package/skills/craft/uipm-brand/references/visual-identity.md +109 -109
- package/skills/craft/uipm-brand/references/voice-framework.md +99 -99
- package/skills/craft/uipm-brand/scripts/extract-colors.cjs +333 -333
- package/skills/craft/uipm-brand/scripts/inject-brand-context.cjs +324 -324
- package/skills/craft/uipm-brand/scripts/sync-brand-to-tokens.cjs +269 -269
- package/skills/craft/uipm-brand/scripts/validate-asset.cjs +361 -361
- package/skills/craft/uipm-brand/templates/brand-guidelines-starter.md +280 -280
- package/skills/craft/uipm-design/LICENSE +21 -21
- package/skills/craft/uipm-design/SKILL.md +305 -305
- package/skills/craft/uipm-design/data/cip/deliverables.csv +50 -50
- package/skills/craft/uipm-design/data/cip/industries.csv +20 -20
- package/skills/craft/uipm-design/data/cip/mockup-contexts.csv +20 -20
- package/skills/craft/uipm-design/data/cip/styles.csv +20 -20
- package/skills/craft/uipm-design/data/icon/styles.csv +16 -16
- package/skills/craft/uipm-design/data/logo/colors.csv +56 -56
- package/skills/craft/uipm-design/data/logo/industries.csv +56 -56
- package/skills/craft/uipm-design/data/logo/styles.csv +56 -56
- package/skills/craft/uipm-design/references/banner-sizes-and-styles.md +129 -129
- package/skills/craft/uipm-design/references/cip-deliverable-guide.md +111 -111
- package/skills/craft/uipm-design/references/cip-design.md +121 -121
- package/skills/craft/uipm-design/references/cip-prompt-engineering.md +94 -94
- package/skills/craft/uipm-design/references/cip-style-guide.md +76 -76
- package/skills/craft/uipm-design/references/design-routing.md +226 -226
- package/skills/craft/uipm-design/references/icon-design.md +122 -122
- package/skills/craft/uipm-design/references/logo-color-psychology.md +113 -113
- package/skills/craft/uipm-design/references/logo-design.md +92 -92
- package/skills/craft/uipm-design/references/logo-prompt-engineering.md +176 -176
- package/skills/craft/uipm-design/references/logo-style-guide.md +129 -129
- package/skills/craft/uipm-design/references/slides-copywriting-formulas.md +92 -92
- package/skills/craft/uipm-design/references/slides-create.md +5 -5
- package/skills/craft/uipm-design/references/slides-html-template.md +374 -374
- package/skills/craft/uipm-design/references/slides-layout-patterns.md +155 -155
- package/skills/craft/uipm-design/references/slides-strategies.md +97 -97
- package/skills/craft/uipm-design/references/slides.md +42 -42
- package/skills/craft/uipm-design/references/social-photos-design.md +353 -353
- package/skills/craft/uipm-design/scripts/cip/core.py +215 -215
- package/skills/craft/uipm-design/scripts/cip/generate.py +484 -484
- package/skills/craft/uipm-design/scripts/cip/render-html.py +424 -424
- package/skills/craft/uipm-design/scripts/cip/search.py +127 -127
- package/skills/craft/uipm-design/scripts/icon/generate.py +487 -487
- package/skills/craft/uipm-design/scripts/logo/core.py +175 -175
- package/skills/craft/uipm-design/scripts/logo/generate.py +362 -362
- package/skills/craft/uipm-design/scripts/logo/search.py +114 -114
- package/skills/craft/uipm-design-system/LICENSE +21 -21
- package/skills/craft/uipm-design-system/SKILL.md +255 -255
- package/skills/craft/uipm-design-system/data/slide-backgrounds.csv +11 -11
- package/skills/craft/uipm-design-system/data/slide-charts.csv +26 -26
- package/skills/craft/uipm-design-system/data/slide-color-logic.csv +14 -14
- package/skills/craft/uipm-design-system/data/slide-copy.csv +26 -26
- package/skills/craft/uipm-design-system/data/slide-layout-logic.csv +16 -16
- package/skills/craft/uipm-design-system/data/slide-layouts.csv +26 -26
- package/skills/craft/uipm-design-system/data/slide-strategies.csv +16 -16
- package/skills/craft/uipm-design-system/data/slide-typography.csv +15 -15
- package/skills/craft/uipm-design-system/references/component-specs.md +236 -236
- package/skills/craft/uipm-design-system/references/component-tokens.md +214 -214
- package/skills/craft/uipm-design-system/references/primitive-tokens.md +199 -199
- package/skills/craft/uipm-design-system/references/semantic-tokens.md +215 -215
- package/skills/craft/uipm-design-system/references/states-and-variants.md +243 -243
- package/skills/craft/uipm-design-system/references/tailwind-integration.md +257 -257
- package/skills/craft/uipm-design-system/references/token-architecture.md +226 -226
- package/skills/craft/uipm-design-system/scripts/embed-tokens.cjs +97 -97
- package/skills/craft/uipm-design-system/scripts/fetch-background.py +317 -317
- package/skills/craft/uipm-design-system/scripts/generate-slide.py +753 -753
- package/skills/craft/uipm-design-system/scripts/generate-tokens.cjs +213 -213
- package/skills/craft/uipm-design-system/scripts/html-token-validator.py +327 -327
- package/skills/craft/uipm-design-system/scripts/search-slides.py +218 -218
- package/skills/craft/uipm-design-system/scripts/slide-token-validator.py +35 -35
- package/skills/craft/uipm-design-system/scripts/slide_search_core.py +453 -453
- package/skills/craft/uipm-design-system/scripts/validate-tokens.cjs +254 -254
- package/skills/craft/uipm-design-system/templates/design-tokens-starter.json +143 -143
- package/skills/craft/uipm-slides/LICENSE +21 -21
- package/skills/craft/uipm-slides/SKILL.md +45 -45
- package/skills/craft/uipm-slides/references/copywriting-formulas.md +92 -92
- package/skills/craft/uipm-slides/references/create.md +5 -5
- package/skills/craft/uipm-slides/references/html-template.md +374 -374
- package/skills/craft/uipm-slides/references/layout-patterns.md +155 -155
- package/skills/craft/uipm-slides/references/slide-strategies.md +97 -97
- package/skills/craft/uipm-ui-ux-pro-max/LICENSE +21 -21
- package/skills/craft/uipm-ui-ux-pro-max/SKILL.md +678 -678
- package/skills/craft/uipm-ui-ux-pro-max/data/_sync_all.py +414 -414
- package/skills/craft/uipm-ui-ux-pro-max/data/app-interface.csv +30 -30
- package/skills/craft/uipm-ui-ux-pro-max/data/charts.csv +26 -26
- package/skills/craft/uipm-ui-ux-pro-max/data/colors.csv +161 -161
- package/skills/craft/uipm-ui-ux-pro-max/data/design.csv +1775 -1775
- package/skills/craft/uipm-ui-ux-pro-max/data/draft.csv +1778 -1778
- package/skills/craft/uipm-ui-ux-pro-max/data/google-fonts.csv +1924 -1924
- package/skills/craft/uipm-ui-ux-pro-max/data/icons.csv +105 -105
- package/skills/craft/uipm-ui-ux-pro-max/data/landing.csv +35 -35
- package/skills/craft/uipm-ui-ux-pro-max/data/products.csv +162 -162
- package/skills/craft/uipm-ui-ux-pro-max/data/react-performance.csv +45 -45
- package/skills/craft/uipm-ui-ux-pro-max/data/stacks/angular.csv +51 -51
- package/skills/craft/uipm-ui-ux-pro-max/data/stacks/astro.csv +54 -54
- package/skills/craft/uipm-ui-ux-pro-max/data/stacks/flutter.csv +53 -53
- package/skills/craft/uipm-ui-ux-pro-max/data/stacks/html-tailwind.csv +56 -56
- package/skills/craft/uipm-ui-ux-pro-max/data/stacks/jetpack-compose.csv +53 -53
- package/skills/craft/uipm-ui-ux-pro-max/data/stacks/laravel.csv +51 -51
- package/skills/craft/uipm-ui-ux-pro-max/data/stacks/nextjs.csv +53 -53
- package/skills/craft/uipm-ui-ux-pro-max/data/stacks/nuxt-ui.csv +51 -51
- package/skills/craft/uipm-ui-ux-pro-max/data/stacks/nuxtjs.csv +59 -59
- package/skills/craft/uipm-ui-ux-pro-max/data/stacks/react-native.csv +52 -52
- package/skills/craft/uipm-ui-ux-pro-max/data/stacks/react.csv +54 -54
- package/skills/craft/uipm-ui-ux-pro-max/data/stacks/shadcn.csv +61 -61
- package/skills/craft/uipm-ui-ux-pro-max/data/stacks/svelte.csv +54 -54
- package/skills/craft/uipm-ui-ux-pro-max/data/stacks/swiftui.csv +51 -51
- package/skills/craft/uipm-ui-ux-pro-max/data/stacks/threejs.csv +54 -54
- package/skills/craft/uipm-ui-ux-pro-max/data/stacks/vue.csv +50 -50
- package/skills/craft/uipm-ui-ux-pro-max/data/styles.csv +85 -85
- package/skills/craft/uipm-ui-ux-pro-max/data/typography.csv +74 -74
- package/skills/craft/uipm-ui-ux-pro-max/data/ui-reasoning.csv +162 -162
- package/skills/craft/uipm-ui-ux-pro-max/data/ux-guidelines.csv +99 -99
- package/skills/craft/uipm-ui-ux-pro-max/scripts/core.py +262 -262
- package/skills/craft/uipm-ui-ux-pro-max/scripts/design_system.py +1148 -1148
- package/skills/craft/uipm-ui-ux-pro-max/scripts/search.py +114 -114
- package/skills/craft/uipm-ui-ux-pro-max/templates/base/quick-reference.md +297 -297
- package/skills/craft/uipm-ui-ux-pro-max/templates/base/skill-content.md +375 -375
- package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/agent.json +21 -21
- package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/augment.json +18 -18
- package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/claude.json +21 -21
- package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/codebuddy.json +21 -21
- package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/codex.json +21 -21
- package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/continue.json +21 -21
- package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/copilot.json +21 -21
- package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/cursor.json +21 -21
- package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/droid.json +21 -21
- package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/gemini.json +21 -21
- package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/kilocode.json +21 -21
- package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/kiro.json +21 -21
- package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/opencode.json +21 -21
- package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/qoder.json +21 -21
- package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/roocode.json +21 -21
- package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/trae.json +21 -21
- package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/warp.json +18 -18
- package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/windsurf.json +21 -21
- package/skills/craft/vercel-optimize/AGENTS.md +48 -48
- package/skills/craft/vercel-optimize/CONTRIBUTING.md +41 -41
- package/skills/craft/vercel-optimize/LICENSE +21 -21
- package/skills/craft/vercel-optimize/README.md +91 -91
- package/skills/craft/vercel-optimize/SKILL.md +325 -325
- package/skills/craft/vercel-optimize/lib/auth-route.mjs +23 -23
- package/skills/craft/vercel-optimize/lib/budget-summary.mjs +208 -208
- package/skills/craft/vercel-optimize/lib/citations.mjs +147 -147
- package/skills/craft/vercel-optimize/lib/cost-coverage.mjs +162 -162
- package/skills/craft/vercel-optimize/lib/dedup-recs.mjs +340 -340
- package/skills/craft/vercel-optimize/lib/deep-dive.mjs +371 -371
- package/skills/craft/vercel-optimize/lib/display-labels.mjs +219 -219
- package/skills/craft/vercel-optimize/lib/extract-claims.mjs +640 -640
- package/skills/craft/vercel-optimize/lib/framework-support.mjs +69 -69
- package/skills/craft/vercel-optimize/lib/gates/build-minutes-fanout.mjs +73 -73
- package/skills/craft/vercel-optimize/lib/gates/cold-start.mjs +72 -72
- package/skills/craft/vercel-optimize/lib/gates/contract.mjs +82 -82
- package/skills/craft/vercel-optimize/lib/gates/cwv-poor.mjs +95 -95
- package/skills/craft/vercel-optimize/lib/gates/external-api-slow.mjs +60 -60
- package/skills/craft/vercel-optimize/lib/gates/hard-gates.mjs +70 -70
- package/skills/craft/vercel-optimize/lib/gates/index.mjs +45 -45
- package/skills/craft/vercel-optimize/lib/gates/isr-overrevalidation.mjs +62 -62
- package/skills/craft/vercel-optimize/lib/gates/middleware-heavy.mjs +53 -53
- package/skills/craft/vercel-optimize/lib/gates/observability-events-attribution.mjs +58 -58
- package/skills/craft/vercel-optimize/lib/gates/platform-bot-protection.mjs +123 -123
- package/skills/craft/vercel-optimize/lib/gates/platform-fluid-compute.mjs +94 -94
- package/skills/craft/vercel-optimize/lib/gates/region-misconfig.mjs +71 -71
- package/skills/craft/vercel-optimize/lib/gates/route-errors.mjs +95 -95
- package/skills/craft/vercel-optimize/lib/gates/scanner-driven.mjs +150 -150
- package/skills/craft/vercel-optimize/lib/gates/select-candidates.mjs +137 -137
- package/skills/craft/vercel-optimize/lib/gates/slow-route.mjs +97 -97
- package/skills/craft/vercel-optimize/lib/gates/types.d.ts +38 -38
- package/skills/craft/vercel-optimize/lib/gates/uncached-route.mjs +103 -103
- package/skills/craft/vercel-optimize/lib/gates/usage-spike-triage.mjs +122 -122
- package/skills/craft/vercel-optimize/lib/grade-recommendation.mjs +170 -170
- package/skills/craft/vercel-optimize/lib/impact-label.mjs +128 -128
- package/skills/craft/vercel-optimize/lib/impact-magnitude.mjs +66 -66
- package/skills/craft/vercel-optimize/lib/investigation-brief.mjs +751 -751
- package/skills/craft/vercel-optimize/lib/observation-safety.mjs +217 -217
- package/skills/craft/vercel-optimize/lib/project-facts.mjs +101 -101
- package/skills/craft/vercel-optimize/lib/queries.mjs +333 -333
- package/skills/craft/vercel-optimize/lib/reconcile-candidates.mjs +388 -388
- package/skills/craft/vercel-optimize/lib/render-report.mjs +1065 -1065
- package/skills/craft/vercel-optimize/lib/repo-root.mjs +97 -97
- package/skills/craft/vercel-optimize/lib/route-normalize.mjs +224 -224
- package/skills/craft/vercel-optimize/lib/sanitizers/bot-protection-certainty.mjs +56 -56
- package/skills/craft/vercel-optimize/lib/sanitizers/cache-tag-invalidation-certainty.mjs +33 -33
- package/skills/craft/vercel-optimize/lib/sanitizers/count-correct.mjs +53 -53
- package/skills/craft/vercel-optimize/lib/sanitizers/function-duration-invocations.mjs +32 -32
- package/skills/craft/vercel-optimize/lib/sanitizers/index.mjs +87 -87
- package/skills/craft/vercel-optimize/lib/sanitizers/middleware-conflict.mjs +37 -37
- package/skills/craft/vercel-optimize/lib/sanitizers/missing-citation.mjs +16 -16
- package/skills/craft/vercel-optimize/lib/sanitizers/pre-release.mjs +75 -75
- package/skills/craft/vercel-optimize/lib/sanitizers/rate-limit.mjs +73 -73
- package/skills/craft/vercel-optimize/lib/sanitizers/rendering-mode-mislabel.mjs +42 -42
- package/skills/craft/vercel-optimize/lib/sanitizers/undeclared-dep.mjs +110 -110
- package/skills/craft/vercel-optimize/lib/sanitizers/vercel-directive-strip.mjs +37 -37
- package/skills/craft/vercel-optimize/lib/sanitizers/window-units.mjs +26 -26
- package/skills/craft/vercel-optimize/lib/scanners/cache-components-suspense-dedupe.mjs +114 -114
- package/skills/craft/vercel-optimize/lib/scanners/edge-heavy-import.mjs +102 -102
- package/skills/craft/vercel-optimize/lib/scanners/force-dynamic.mjs +39 -39
- package/skills/craft/vercel-optimize/lib/scanners/headers-in-page.mjs +43 -43
- package/skills/craft/vercel-optimize/lib/scanners/index.mjs +35 -35
- package/skills/craft/vercel-optimize/lib/scanners/large-static-asset.mjs +93 -93
- package/skills/craft/vercel-optimize/lib/scanners/max-age-without-s-maxage.mjs +47 -47
- package/skills/craft/vercel-optimize/lib/scanners/middleware-broad-matcher.mjs +53 -53
- package/skills/craft/vercel-optimize/lib/scanners/missing-cache-headers.mjs +97 -97
- package/skills/craft/vercel-optimize/lib/scanners/prisma-include-tree.mjs +39 -39
- package/skills/craft/vercel-optimize/lib/scanners/region-pin-in-config.mjs +89 -89
- package/skills/craft/vercel-optimize/lib/scanners/source-maps-production.mjs +33 -33
- package/skills/craft/vercel-optimize/lib/scanners/sveltekit-prerender-missing.mjs +47 -47
- package/skills/craft/vercel-optimize/lib/scanners/turbo-force-bypass.mjs +136 -136
- package/skills/craft/vercel-optimize/lib/scanners/unoptimized-image.mjs +127 -127
- package/skills/craft/vercel-optimize/lib/scanners/use-cache-date-stamp.mjs +112 -112
- package/skills/craft/vercel-optimize/lib/support-topics.mjs +365 -365
- package/skills/craft/vercel-optimize/lib/throttle.mjs +280 -280
- package/skills/craft/vercel-optimize/lib/util.mjs +17 -17
- package/skills/craft/vercel-optimize/lib/vercel.mjs +855 -855
- package/skills/craft/vercel-optimize/lib/verify-claim.mjs +1843 -1843
- package/skills/craft/vercel-optimize/lib/workspace-resolver.mjs +552 -552
- package/skills/craft/vercel-optimize/metadata.json +14 -14
- package/skills/craft/vercel-optimize/references/candidates.md +176 -176
- package/skills/craft/vercel-optimize/references/data-collection.md +224 -224
- package/skills/craft/vercel-optimize/references/docs-library.json +683 -683
- package/skills/craft/vercel-optimize/references/doctrine.md +108 -108
- package/skills/craft/vercel-optimize/references/observability-plus.md +109 -109
- package/skills/craft/vercel-optimize/references/playbooks/README.md +57 -57
- package/skills/craft/vercel-optimize/references/playbooks/ai-application.md +32 -32
- package/skills/craft/vercel-optimize/references/playbooks/api-service.md +30 -30
- package/skills/craft/vercel-optimize/references/playbooks/content-site.md +30 -30
- package/skills/craft/vercel-optimize/references/playbooks/ecommerce.md +30 -30
- package/skills/craft/vercel-optimize/references/playbooks/marketing.md +30 -30
- package/skills/craft/vercel-optimize/references/playbooks/saas.md +31 -31
- package/skills/craft/vercel-optimize/references/playbooks/sveltekit.md +75 -75
- package/skills/craft/vercel-optimize/references/recommendations.md +214 -214
- package/skills/craft/vercel-optimize/references/scanner-patterns.md +266 -266
- package/skills/craft/vercel-optimize/references/scoring.md +208 -208
- package/skills/craft/vercel-optimize/references/support-topics/README.md +50 -50
- package/skills/craft/vercel-optimize/references/support-topics/astro-edge-middleware-scope.md +30 -30
- package/skills/craft/vercel-optimize/references/support-topics/astro-output-mode-and-isr.md +31 -31
- package/skills/craft/vercel-optimize/references/support-topics/auth-preserving-parallelization.md +30 -30
- package/skills/craft/vercel-optimize/references/support-topics/bot-protection-product-guardrails.md +32 -32
- package/skills/craft/vercel-optimize/references/support-topics/build-minutes-monorepo-fanout.md +32 -32
- package/skills/craft/vercel-optimize/references/support-topics/cache-components-static-shell-boundaries.md +31 -31
- package/skills/craft/vercel-optimize/references/support-topics/cache-components-suspense-dedupe-pitfall.md +32 -32
- package/skills/craft/vercel-optimize/references/support-topics/cdn-cache-auth-safety.md +31 -31
- package/skills/craft/vercel-optimize/references/support-topics/cold-start-initialization-bundle.md +31 -31
- package/skills/craft/vercel-optimize/references/support-topics/core-web-vitals-client-bottlenecks.md +33 -33
- package/skills/craft/vercel-optimize/references/support-topics/database-egress-pooling-region.md +32 -32
- package/skills/craft/vercel-optimize/references/support-topics/dynamic-rendering-traps.md +31 -31
- package/skills/craft/vercel-optimize/references/support-topics/external-api-critical-path-platform.md +31 -31
- package/skills/craft/vercel-optimize/references/support-topics/external-api-critical-path.md +31 -31
- package/skills/craft/vercel-optimize/references/support-topics/fast-data-transfer-payloads.md +26 -26
- package/skills/craft/vercel-optimize/references/support-topics/fluid-compute-caveats.md +26 -26
- package/skills/craft/vercel-optimize/references/support-topics/function-duration-io-and-after.md +31 -31
- package/skills/craft/vercel-optimize/references/support-topics/function-invocation-reduction.md +31 -31
- package/skills/craft/vercel-optimize/references/support-topics/function-region-misconfiguration-ttfb.md +31 -31
- package/skills/craft/vercel-optimize/references/support-topics/image-optimization-cost-control.md +31 -31
- package/skills/craft/vercel-optimize/references/support-topics/isr-revalidation-static-generation.md +31 -31
- package/skills/craft/vercel-optimize/references/support-topics/middleware-proxy-edge-cost.md +30 -30
- package/skills/craft/vercel-optimize/references/support-topics/next-fetch-revalidate-floor.md +30 -30
- package/skills/craft/vercel-optimize/references/support-topics/next-font-cls-self-hosting.md +31 -31
- package/skills/craft/vercel-optimize/references/support-topics/next-heavy-ui-lazy-load-boundaries.md +28 -28
- package/skills/craft/vercel-optimize/references/support-topics/next-image-lcp-preload-sizes.md +31 -31
- package/skills/craft/vercel-optimize/references/support-topics/next-route-handler-get-cache-defaults.md +30 -30
- package/skills/craft/vercel-optimize/references/support-topics/next-script-third-party-strategy.md +31 -31
- package/skills/craft/vercel-optimize/references/support-topics/nextjs-version-cache-semantics.md +31 -31
- package/skills/craft/vercel-optimize/references/support-topics/not-found-catchall-request-waste.md +33 -33
- package/skills/craft/vercel-optimize/references/support-topics/nuxt-route-rules-cache-isr.md +31 -31
- package/skills/craft/vercel-optimize/references/support-topics/observability-events-cost-attribution.md +27 -27
- package/skills/craft/vercel-optimize/references/support-topics/post-response-work-waituntil.md +26 -26
- package/skills/craft/vercel-optimize/references/support-topics/route-error-durable-offload.md +33 -33
- package/skills/craft/vercel-optimize/references/support-topics/route-error-runtime-limits.md +31 -31
- package/skills/craft/vercel-optimize/references/support-topics/runtime-cache-reusable-data.md +30 -30
- package/skills/craft/vercel-optimize/references/support-topics/sveltekit-isr-prerender-safety.md +31 -31
- package/skills/craft/vercel-optimize/references/support-topics/sveltekit-split-cold-start-tradeoff.md +30 -30
- package/skills/craft/vercel-optimize/references/support-topics/usage-spike-triage.md +31 -31
- package/skills/craft/vercel-optimize/references/support-topics/use-cache-date-stamp-isr-write-amplifier.md +31 -31
- package/skills/craft/vercel-optimize/references/support-topics/use-cache-remote-shared-origin-data.md +30 -30
- package/skills/craft/vercel-optimize/references/support-topics/workflow-resumable-stream-routes.md +32 -32
- package/skills/craft/vercel-optimize/references/verification.md +102 -102
- package/skills/craft/vercel-optimize/references/voice.md +76 -76
- package/skills/craft/vercel-optimize/scripts/budget-summary.mjs +58 -58
- package/skills/craft/vercel-optimize/scripts/build-docs.mjs +76 -76
- package/skills/craft/vercel-optimize/scripts/check-citations.mjs +91 -91
- package/skills/craft/vercel-optimize/scripts/check-docs-fresh.mjs +100 -100
- package/skills/craft/vercel-optimize/scripts/collect-signals.mjs +638 -638
- package/skills/craft/vercel-optimize/scripts/collect-sub-agent-outputs.mjs +306 -306
- package/skills/craft/vercel-optimize/scripts/deep-dive.mjs +358 -358
- package/skills/craft/vercel-optimize/scripts/gate-investigations.mjs +178 -178
- package/skills/craft/vercel-optimize/scripts/merge-signals.mjs +203 -203
- package/skills/craft/vercel-optimize/scripts/prepare-investigation-brief.mjs +249 -249
- package/skills/craft/vercel-optimize/scripts/reconcile-candidates.mjs +69 -69
- package/skills/craft/vercel-optimize/scripts/render-report.mjs +462 -462
- package/skills/craft/vercel-optimize/scripts/scan-codebase.mjs +361 -361
- package/skills/craft/vercel-optimize/scripts/verify-and-regen.mjs +379 -379
- package/skills/craft/vercel-optimize/scripts/verify-finding.mjs +21 -21
- package/skills/craft/web-design-guidelines/LICENSE +21 -21
- package/skills/craft/web-design-guidelines/SKILL.md +43 -43
- package/skills/craft/zero-to-live/LICENSE +21 -21
- package/skills/craft/zero-to-live/SKILL.md +422 -422
- package/skills/creative/creative-3d-modeling/LICENSE +21 -21
- package/skills/creative/creative-3d-modeling/SKILL.md +70 -70
- package/skills/creative/creative-architecture/LICENSE +21 -21
- package/skills/creative/creative-architecture/SKILL.md +94 -94
- package/skills/creative/creative-design-principles/LICENSE +21 -21
- package/skills/creative/creative-design-principles/SKILL.md +95 -95
- package/skills/creative/creative-fashion-advanced/LICENSE +21 -21
- package/skills/creative/creative-fashion-advanced/SKILL.md +68 -68
- package/skills/creative/creative-fashion-design/LICENSE +21 -21
- package/skills/creative/creative-fashion-design/SKILL.md +66 -66
- package/skills/creative/creative-game-design/LICENSE +21 -21
- package/skills/creative/creative-game-design/SKILL.md +77 -77
- package/skills/creative/creative-industrial-design/LICENSE +21 -21
- package/skills/creative/creative-industrial-design/SKILL.md +57 -57
- package/skills/creative/creative-interior-design/LICENSE +21 -21
- package/skills/creative/creative-interior-design/SKILL.md +59 -59
- package/skills/creative/creative-music-theory/LICENSE +21 -21
- package/skills/creative/creative-music-theory/SKILL.md +98 -98
- package/skills/creative/creative-photography/LICENSE +21 -21
- package/skills/creative/creative-photography/SKILL.md +87 -87
- package/skills/creative/creative-textile-science/LICENSE +21 -21
- package/skills/creative/creative-textile-science/SKILL.md +67 -67
- package/skills/creative/creative-ux/LICENSE +21 -21
- package/skills/creative/creative-ux/SKILL.md +81 -81
- package/skills/creative/creative-video/LICENSE +21 -21
- package/skills/creative/creative-video/SKILL.md +84 -84
- package/skills/creative/creative-writing-craft/LICENSE +21 -21
- package/skills/creative/creative-writing-craft/SKILL.md +91 -91
- package/skills/diagram-maker/SKILL.md +56 -56
- package/skills/diagram-maker/references/excalidraw-patterns.md +85 -85
- package/skills/diagram-maker/references/svg-template.md +112 -112
- package/skills/discord/SKILL.md +140 -140
- package/skills/education/edu-adult-learning/LICENSE +21 -21
- package/skills/education/edu-adult-learning/SKILL.md +81 -81
- package/skills/education/edu-africa-multilingual/LICENSE +21 -21
- package/skills/education/edu-africa-multilingual/SKILL.md +55 -55
- package/skills/education/edu-arabic/LICENSE +21 -21
- package/skills/education/edu-arabic/SKILL.md +60 -60
- package/skills/education/edu-australia-nz/LICENSE +21 -21
- package/skills/education/edu-australia-nz/SKILL.md +48 -48
- package/skills/education/edu-china-mandarin/LICENSE +21 -21
- package/skills/education/edu-china-mandarin/SKILL.md +58 -58
- package/skills/education/edu-critical-thinking/LICENSE +21 -21
- package/skills/education/edu-critical-thinking/SKILL.md +86 -86
- package/skills/education/edu-curriculum/LICENSE +21 -21
- package/skills/education/edu-curriculum/SKILL.md +87 -87
- package/skills/education/edu-ed-tech/LICENSE +21 -21
- package/skills/education/edu-ed-tech/SKILL.md +73 -73
- package/skills/education/edu-france/LICENSE +21 -21
- package/skills/education/edu-france/SKILL.md +42 -42
- package/skills/education/edu-germany/LICENSE +21 -21
- package/skills/education/edu-germany/SKILL.md +46 -46
- package/skills/education/edu-india-competitive/LICENSE +21 -21
- package/skills/education/edu-india-competitive/SKILL.md +159 -159
- package/skills/education/edu-india-east/LICENSE +21 -21
- package/skills/education/edu-india-east/SKILL.md +60 -60
- package/skills/education/edu-india-hindi/LICENSE +21 -21
- package/skills/education/edu-india-hindi/SKILL.md +107 -107
- package/skills/education/edu-india-south/LICENSE +21 -21
- package/skills/education/edu-india-south/SKILL.md +64 -64
- package/skills/education/edu-india-west/LICENSE +21 -21
- package/skills/education/edu-india-west/SKILL.md +68 -68
- package/skills/education/edu-indonesia-malay/LICENSE +21 -21
- package/skills/education/edu-indonesia-malay/SKILL.md +57 -57
- package/skills/education/edu-international-ib/LICENSE +21 -21
- package/skills/education/edu-international-ib/SKILL.md +61 -61
- package/skills/education/edu-japan/LICENSE +21 -21
- package/skills/education/edu-japan/SKILL.md +48 -48
- package/skills/education/edu-korea/LICENSE +21 -21
- package/skills/education/edu-korea/SKILL.md +48 -48
- package/skills/education/edu-learning-science/LICENSE +21 -21
- package/skills/education/edu-learning-science/SKILL.md +76 -76
- package/skills/education/edu-portuguese-brazil/LICENSE +21 -21
- package/skills/education/edu-portuguese-brazil/SKILL.md +51 -51
- package/skills/education/edu-russia/LICENSE +21 -21
- package/skills/education/edu-russia/SKILL.md +50 -50
- package/skills/education/edu-spain-latam/LICENSE +21 -21
- package/skills/education/edu-spain-latam/SKILL.md +55 -55
- package/skills/education/edu-special/LICENSE +21 -21
- package/skills/education/edu-special/SKILL.md +76 -76
- package/skills/education/edu-thailand/LICENSE +21 -21
- package/skills/education/edu-thailand/SKILL.md +55 -55
- package/skills/education/edu-turkey/LICENSE +21 -21
- package/skills/education/edu-turkey/SKILL.md +58 -58
- package/skills/education/edu-uk-gcse-alevel/LICENSE +21 -21
- package/skills/education/edu-uk-gcse-alevel/SKILL.md +51 -51
- package/skills/education/edu-usa-graduate/LICENSE +21 -21
- package/skills/education/edu-usa-graduate/SKILL.md +57 -57
- package/skills/education/edu-usa-sat-act/LICENSE +21 -21
- package/skills/education/edu-usa-sat-act/SKILL.md +55 -55
- package/skills/education/edu-vietnam/LICENSE +21 -21
- package/skills/education/edu-vietnam/SKILL.md +53 -53
- package/skills/eightctl/SKILL.md +54 -54
- package/skills/engineering/eng-aerospace/LICENSE +21 -21
- package/skills/engineering/eng-aerospace/SKILL.md +117 -117
- package/skills/engineering/eng-chemical/LICENSE +21 -21
- package/skills/engineering/eng-chemical/SKILL.md +63 -63
- package/skills/engineering/eng-civil/LICENSE +21 -21
- package/skills/engineering/eng-civil/SKILL.md +223 -223
- package/skills/engineering/eng-control-systems/LICENSE +21 -21
- package/skills/engineering/eng-control-systems/SKILL.md +158 -158
- package/skills/engineering/eng-cryogenics/LICENSE +21 -21
- package/skills/engineering/eng-cryogenics/SKILL.md +151 -151
- package/skills/engineering/eng-electrical/LICENSE +21 -21
- package/skills/engineering/eng-electrical/SKILL.md +70 -70
- package/skills/engineering/eng-electronics-embedded/LICENSE +21 -21
- package/skills/engineering/eng-electronics-embedded/SKILL.md +89 -89
- package/skills/engineering/eng-environmental/LICENSE +21 -21
- package/skills/engineering/eng-environmental/SKILL.md +66 -66
- package/skills/engineering/eng-manufacturing/LICENSE +21 -21
- package/skills/engineering/eng-manufacturing/SKILL.md +78 -78
- package/skills/engineering/eng-mechanical/LICENSE +21 -21
- package/skills/engineering/eng-mechanical/SKILL.md +66 -66
- package/skills/engineering/eng-project/LICENSE +21 -21
- package/skills/engineering/eng-project/SKILL.md +72 -72
- package/skills/engineering/eng-propulsion/LICENSE +21 -21
- package/skills/engineering/eng-propulsion/SKILL.md +133 -133
- package/skills/engineering/eng-robotics/LICENSE +21 -21
- package/skills/engineering/eng-robotics/SKILL.md +92 -92
- package/skills/engineering/eng-systems/LICENSE +21 -21
- package/skills/engineering/eng-systems/SKILL.md +81 -81
- package/skills/environment/env-biodiversity/LICENSE +21 -21
- package/skills/environment/env-biodiversity/SKILL.md +66 -66
- package/skills/environment/env-circular-economy/LICENSE +21 -21
- package/skills/environment/env-circular-economy/SKILL.md +71 -71
- package/skills/environment/env-climate-action/LICENSE +21 -21
- package/skills/environment/env-climate-action/SKILL.md +55 -55
- package/skills/environment/env-energy/LICENSE +21 -21
- package/skills/environment/env-energy/SKILL.md +83 -83
- package/skills/environment/env-sustainability-biz/LICENSE +21 -21
- package/skills/environment/env-sustainability-biz/SKILL.md +65 -65
- package/skills/environment/env-water/LICENSE +21 -21
- package/skills/environment/env-water/SKILL.md +67 -67
- package/skills/finance/finance-accounting/LICENSE +21 -21
- package/skills/finance/finance-accounting/SKILL.md +239 -239
- package/skills/finance/finance-banking/LICENSE +21 -21
- package/skills/finance/finance-banking/SKILL.md +54 -54
- package/skills/finance/finance-corporate/LICENSE +21 -21
- package/skills/finance/finance-corporate/SKILL.md +105 -105
- package/skills/finance/finance-crypto/LICENSE +21 -21
- package/skills/finance/finance-crypto/SKILL.md +94 -94
- package/skills/finance/finance-debt-management/LICENSE +21 -21
- package/skills/finance/finance-debt-management/SKILL.md +87 -87
- package/skills/finance/finance-insurance/LICENSE +21 -21
- package/skills/finance/finance-insurance/SKILL.md +91 -91
- package/skills/finance/finance-investing/LICENSE +21 -21
- package/skills/finance/finance-investing/SKILL.md +269 -269
- package/skills/finance/finance-options-derivatives/LICENSE +21 -21
- package/skills/finance/finance-options-derivatives/SKILL.md +68 -68
- package/skills/finance/finance-personal/LICENSE +21 -21
- package/skills/finance/finance-personal/SKILL.md +268 -268
- package/skills/finance/finance-real-estate/LICENSE +21 -21
- package/skills/finance/finance-real-estate/SKILL.md +110 -110
- package/skills/finance/finance-startup/LICENSE +21 -21
- package/skills/finance/finance-startup/SKILL.md +253 -253
- package/skills/finance/finance-tax-planning/LICENSE +21 -21
- package/skills/finance/finance-tax-planning/SKILL.md +89 -89
- package/skills/finance/finance-trading/LICENSE +21 -21
- package/skills/finance/finance-trading/SKILL.md +112 -112
- package/skills/gemini/SKILL.md +51 -51
- package/skills/gh-issues/SKILL.md +216 -216
- package/skills/gifgrep/SKILL.md +89 -89
- package/skills/github/SKILL.md +87 -87
- package/skills/gog/SKILL.md +120 -120
- package/skills/goplaces/SKILL.md +56 -56
- package/skills/health/health-aging/LICENSE +21 -21
- package/skills/health/health-aging/SKILL.md +82 -82
- package/skills/health/health-chronic/LICENSE +21 -21
- package/skills/health/health-chronic/SKILL.md +202 -202
- package/skills/health/health-dental/LICENSE +21 -21
- package/skills/health/health-dental/SKILL.md +41 -41
- package/skills/health/health-eye-care/LICENSE +21 -21
- package/skills/health/health-eye-care/SKILL.md +56 -56
- package/skills/health/health-first-aid/LICENSE +21 -21
- package/skills/health/health-first-aid/SKILL.md +201 -201
- package/skills/health/health-fitness/LICENSE +21 -21
- package/skills/health/health-fitness/SKILL.md +111 -111
- package/skills/health/health-general/LICENSE +21 -21
- package/skills/health/health-general/SKILL.md +277 -277
- package/skills/health/health-mens/LICENSE +21 -21
- package/skills/health/health-mens/SKILL.md +53 -53
- package/skills/health/health-mental/LICENSE +21 -21
- package/skills/health/health-mental/SKILL.md +221 -221
- package/skills/health/health-naturopathy-ayurveda/LICENSE +21 -21
- package/skills/health/health-naturopathy-ayurveda/SKILL.md +60 -60
- package/skills/health/health-nutrition/LICENSE +21 -21
- package/skills/health/health-nutrition/SKILL.md +262 -262
- package/skills/health/health-pediatric/LICENSE +21 -21
- package/skills/health/health-pediatric/SKILL.md +94 -94
- package/skills/health/health-pharmacology/LICENSE +21 -21
- package/skills/health/health-pharmacology/SKILL.md +87 -87
- package/skills/health/health-pregnancy/LICENSE +21 -21
- package/skills/health/health-pregnancy/SKILL.md +71 -71
- package/skills/health/health-skin/LICENSE +21 -21
- package/skills/health/health-skin/SKILL.md +71 -71
- package/skills/health/health-sleep/LICENSE +21 -21
- package/skills/health/health-sleep/SKILL.md +81 -81
- package/skills/health/health-womens/LICENSE +21 -21
- package/skills/health/health-womens/SKILL.md +72 -72
- package/skills/health/health-yoga-wellness/LICENSE +21 -21
- package/skills/health/health-yoga-wellness/SKILL.md +58 -58
- package/skills/healthcare-systems/health-sys-global/LICENSE +21 -21
- package/skills/healthcare-systems/health-sys-global/SKILL.md +69 -69
- package/skills/healthcare-systems/health-sys-management/LICENSE +21 -21
- package/skills/healthcare-systems/health-sys-management/SKILL.md +71 -71
- package/skills/healthcare-systems/health-sys-navigation/LICENSE +21 -21
- package/skills/healthcare-systems/health-sys-navigation/SKILL.md +60 -60
- package/skills/healthcare-systems/health-sys-public/LICENSE +21 -21
- package/skills/healthcare-systems/health-sys-public/SKILL.md +71 -71
- package/skills/healthcheck/SKILL.md +109 -109
- package/skills/himalaya/SKILL.md +84 -84
- package/skills/himalaya/references/configuration.md +184 -184
- package/skills/himalaya/references/message-composition.md +199 -199
- package/skills/humanities/humanities-history-world/LICENSE +21 -21
- package/skills/humanities/humanities-history-world/SKILL.md +59 -59
- package/skills/humanities/humanities-indian-classical/LICENSE +21 -21
- package/skills/humanities/humanities-indian-classical/SKILL.md +104 -104
- package/skills/humanities/humanities-philosophy/LICENSE +21 -21
- package/skills/humanities/humanities-philosophy/SKILL.md +105 -105
- package/skills/humanities/humanities-world-religions/LICENSE +21 -21
- package/skills/humanities/humanities-world-religions/SKILL.md +67 -67
- package/skills/impeccable/SKILL.md +185 -185
- package/skills/imsg/SKILL.md +126 -126
- package/skills/industry/industry-construction/LICENSE +21 -21
- package/skills/industry/industry-construction/SKILL.md +81 -81
- package/skills/industry/industry-education-sector/LICENSE +21 -21
- package/skills/industry/industry-education-sector/SKILL.md +49 -49
- package/skills/industry/industry-fashion/LICENSE +21 -21
- package/skills/industry/industry-fashion/SKILL.md +82 -82
- package/skills/industry/industry-food/LICENSE +21 -21
- package/skills/industry/industry-food/SKILL.md +79 -79
- package/skills/industry/industry-government/LICENSE +21 -21
- package/skills/industry/industry-government/SKILL.md +80 -80
- package/skills/industry/industry-hospitality/LICENSE +21 -21
- package/skills/industry/industry-hospitality/SKILL.md +73 -73
- package/skills/industry/industry-insurance-sector/LICENSE +21 -21
- package/skills/industry/industry-insurance-sector/SKILL.md +57 -57
- package/skills/industry/industry-logistics/LICENSE +21 -21
- package/skills/industry/industry-logistics/SKILL.md +80 -80
- package/skills/industry/industry-media/LICENSE +21 -21
- package/skills/industry/industry-media/SKILL.md +66 -66
- package/skills/industry/industry-nonprofit/LICENSE +21 -21
- package/skills/industry/industry-nonprofit/SKILL.md +77 -77
- package/skills/industry/industry-pharma/LICENSE +21 -21
- package/skills/industry/industry-pharma/SKILL.md +69 -69
- package/skills/industry/industry-real-estate/LICENSE +21 -21
- package/skills/industry/industry-real-estate/SKILL.md +61 -61
- package/skills/industry/industry-sports/LICENSE +21 -21
- package/skills/industry/industry-sports/SKILL.md +71 -71
- package/skills/industry/industry-tech-startup/LICENSE +21 -21
- package/skills/industry/industry-tech-startup/SKILL.md +82 -82
- package/skills/internal-comms/LICENSE +21 -21
- package/skills/internal-comms/SKILL.md +38 -38
- package/skills/internal-comms/examples/3p-updates.md +49 -49
- package/skills/internal-comms/examples/company-newsletter.md +76 -76
- package/skills/internal-comms/examples/faq-answers.md +35 -35
- package/skills/internal-comms/examples/general-comms.md +19 -19
- package/skills/legal/legal-business/LICENSE +21 -21
- package/skills/legal/legal-business/SKILL.md +227 -227
- package/skills/legal/legal-consumer/LICENSE +21 -21
- package/skills/legal/legal-consumer/SKILL.md +155 -155
- package/skills/legal/legal-contracts/LICENSE +21 -21
- package/skills/legal/legal-contracts/SKILL.md +268 -268
- package/skills/legal/legal-corporate-governance/LICENSE +21 -21
- package/skills/legal/legal-corporate-governance/SKILL.md +53 -53
- package/skills/legal/legal-employment/LICENSE +21 -21
- package/skills/legal/legal-employment/SKILL.md +291 -291
- package/skills/legal/legal-immigration/LICENSE +21 -21
- package/skills/legal/legal-immigration/SKILL.md +146 -146
- package/skills/legal/legal-international/LICENSE +21 -21
- package/skills/legal/legal-international/SKILL.md +51 -51
- package/skills/legal/legal-ip/LICENSE +21 -21
- package/skills/legal/legal-ip/SKILL.md +264 -264
- package/skills/legal/legal-privacy/LICENSE +21 -21
- package/skills/legal/legal-privacy/SKILL.md +161 -161
- package/skills/legal/legal-real-estate/LICENSE +21 -21
- package/skills/legal/legal-real-estate/SKILL.md +142 -142
- package/skills/legal/legal-startup/LICENSE +21 -21
- package/skills/legal/legal-startup/SKILL.md +182 -182
- package/skills/legal/legal-tax/LICENSE +21 -21
- package/skills/legal/legal-tax/SKILL.md +156 -156
- package/skills/mcp-builder/LICENSE +21 -21
- package/skills/mcp-builder/SKILL.md +257 -257
- package/skills/mcp-builder/reference/evaluation.md +630 -630
- package/skills/mcp-builder/reference/mcp_best_practices.md +269 -269
- package/skills/mcp-builder/reference/node_mcp_server.md +980 -980
- package/skills/mcp-builder/reference/python_mcp_server.md +737 -737
- package/skills/mcp-builder/scripts/connections.py +151 -151
- package/skills/mcp-builder/scripts/evaluation.py +373 -373
- package/skills/mcp-builder/scripts/example_evaluation.xml +22 -22
- package/skills/mcp-builder/scripts/requirements.txt +2 -2
- package/skills/mcporter/SKILL.md +65 -65
- package/skills/meme-maker/SKILL.md +46 -46
- package/skills/meme-maker/references/templates.json +358 -358
- package/skills/meme-maker/scripts/meme.mjs +398 -398
- package/skills/mental-health/mental-health-cbt/LICENSE +21 -21
- package/skills/mental-health/mental-health-cbt/SKILL.md +254 -254
- package/skills/mental-health/psych-addiction/LICENSE +21 -21
- package/skills/mental-health/psych-addiction/SKILL.md +79 -79
- package/skills/mental-health/psych-behavioral-econ/LICENSE +21 -21
- package/skills/mental-health/psych-behavioral-econ/SKILL.md +84 -84
- package/skills/mental-health/psych-child/LICENSE +21 -21
- package/skills/mental-health/psych-child/SKILL.md +84 -84
- package/skills/mental-health/psych-grief/LICENSE +21 -21
- package/skills/mental-health/psych-grief/SKILL.md +85 -85
- package/skills/mental-health/psych-mindfulness/LICENSE +21 -21
- package/skills/mental-health/psych-mindfulness/SKILL.md +71 -71
- package/skills/mental-health/psych-org/LICENSE +21 -21
- package/skills/mental-health/psych-org/SKILL.md +115 -115
- package/skills/mental-health/psych-positive/LICENSE +21 -21
- package/skills/mental-health/psych-positive/SKILL.md +86 -86
- package/skills/mental-health/psych-relationships/LICENSE +21 -21
- package/skills/mental-health/psych-relationships/SKILL.md +100 -100
- package/skills/mental-health/psych-trauma/LICENSE +21 -21
- package/skills/mental-health/psych-trauma/SKILL.md +109 -109
- package/skills/model-usage/SKILL.md +75 -75
- package/skills/model-usage/references/codexbar-cli.md +33 -33
- package/skills/model-usage/scripts/model_usage.py +319 -319
- package/skills/model-usage/scripts/test_model_usage.py +40 -40
- package/skills/nano-pdf/SKILL.md +42 -42
- package/skills/node-connect/SKILL.md +147 -147
- package/skills/node-inspect-debugger/SKILL.md +88 -88
- package/skills/notion/SKILL.md +154 -154
- package/skills/obsidian/SKILL.md +123 -123
- package/skills/openai-whisper/SKILL.md +42 -42
- package/skills/openai-whisper-api/SKILL.md +75 -75
- package/skills/openai-whisper-api/scripts/transcribe.sh +154 -154
- package/skills/openhue/SKILL.md +116 -116
- package/skills/oracle/SKILL.md +130 -130
- package/skills/ordercli/SKILL.md +82 -82
- package/skills/peekaboo/SKILL.md +217 -217
- package/skills/pyproject.toml +10 -10
- package/skills/python-debugpy/SKILL.md +76 -76
- package/skills/sag/SKILL.md +91 -91
- package/skills/science/sci-astronomy/LICENSE +21 -21
- package/skills/science/sci-astronomy/SKILL.md +80 -80
- package/skills/science/sci-biology/LICENSE +21 -21
- package/skills/science/sci-biology/SKILL.md +74 -74
- package/skills/science/sci-chemistry/LICENSE +21 -21
- package/skills/science/sci-chemistry/SKILL.md +89 -89
- package/skills/science/sci-climate/LICENSE +21 -21
- package/skills/science/sci-climate/SKILL.md +72 -72
- package/skills/science/sci-data-analysis/LICENSE +21 -21
- package/skills/science/sci-data-analysis/SKILL.md +87 -87
- package/skills/science/sci-environmental-science/LICENSE +21 -21
- package/skills/science/sci-environmental-science/SKILL.md +69 -69
- package/skills/science/sci-geology/LICENSE +21 -21
- package/skills/science/sci-geology/SKILL.md +56 -56
- package/skills/science/sci-method/LICENSE +21 -21
- package/skills/science/sci-method/SKILL.md +77 -77
- package/skills/science/sci-neuroscience/LICENSE +21 -21
- package/skills/science/sci-neuroscience/SKILL.md +79 -79
- package/skills/science/sci-physics/LICENSE +21 -21
- package/skills/science/sci-physics/SKILL.md +78 -78
- package/skills/science/sci-research-methods/LICENSE +21 -21
- package/skills/science/sci-research-methods/SKILL.md +83 -83
- package/skills/science/sci-statistics/LICENSE +21 -21
- package/skills/science/sci-statistics/SKILL.md +249 -249
- package/skills/session-logs/SKILL.md +155 -155
- package/skills/sherpa-onnx-tts/SKILL.md +113 -113
- package/skills/skill-creator/SKILL.md +81 -81
- package/skills/skill-creator/license.txt +202 -202
- package/skills/skill-creator/scripts/init_skill.py +378 -378
- package/skills/skill-creator/scripts/package_skill.py +144 -144
- package/skills/skill-creator/scripts/quick_validate.py +169 -169
- package/skills/skill-creator/scripts/test_init_skill.py +51 -51
- package/skills/skill-creator/scripts/test_package_skill.py +199 -199
- package/skills/skill-creator/scripts/test_quick_validate.py +116 -116
- package/skills/slack/SKILL.md +82 -82
- package/skills/slack-gif-creator/LICENSE +21 -21
- package/skills/slack-gif-creator/SKILL.md +293 -293
- package/skills/slack-gif-creator/requirements.txt +3 -3
- package/skills/social-sciences/social-anthropology/LICENSE +21 -21
- package/skills/social-sciences/social-anthropology/SKILL.md +62 -62
- package/skills/social-sciences/social-economics/LICENSE +21 -21
- package/skills/social-sciences/social-economics/SKILL.md +88 -88
- package/skills/social-sciences/social-geography/LICENSE +21 -21
- package/skills/social-sciences/social-geography/SKILL.md +61 -61
- package/skills/social-sciences/social-international-dev/LICENSE +21 -21
- package/skills/social-sciences/social-international-dev/SKILL.md +76 -76
- package/skills/social-sciences/social-political-science/LICENSE +21 -21
- package/skills/social-sciences/social-political-science/SKILL.md +70 -70
- package/skills/social-sciences/social-public-policy/LICENSE +21 -21
- package/skills/social-sciences/social-public-policy/SKILL.md +73 -73
- package/skills/social-sciences/social-sociology/LICENSE +21 -21
- package/skills/social-sciences/social-sociology/SKILL.md +78 -78
- package/skills/songsee/SKILL.md +53 -53
- package/skills/sonoscli/SKILL.md +69 -69
- package/skills/spike/SKILL.md +55 -55
- package/skills/spotify-player/SKILL.md +68 -68
- package/skills/summarize/SKILL.md +90 -90
- package/skills/taskflow/SKILL.md +153 -153
- package/skills/taskflow/examples/inbox-triage.lobster +33 -33
- package/skills/taskflow/examples/pr-intake.lobster +32 -32
- package/skills/taskflow-inbox-triage/SKILL.md +123 -123
- package/skills/technical/ai-ethics/LICENSE +21 -21
- package/skills/technical/ai-ethics/SKILL.md +92 -92
- package/skills/technical/ai-product-builder/LICENSE +21 -21
- package/skills/technical/ai-product-builder/SKILL.md +180 -180
- package/skills/technical/analytics-setup/LICENSE +21 -21
- package/skills/technical/analytics-setup/SKILL.md +125 -125
- package/skills/technical/api-builder/LICENSE +21 -21
- package/skills/technical/api-builder/SKILL.md +202 -202
- package/skills/technical/architecture-decisions/LICENSE +21 -21
- package/skills/technical/architecture-decisions/SKILL.md +120 -120
- package/skills/technical/auth-security/LICENSE +21 -21
- package/skills/technical/auth-security/SKILL.md +209 -209
- package/skills/technical/blockchain-web3/LICENSE +21 -21
- package/skills/technical/blockchain-web3/SKILL.md +84 -84
- package/skills/technical/cloud-architecture/LICENSE +21 -21
- package/skills/technical/cloud-architecture/SKILL.md +85 -85
- package/skills/technical/content-platform/LICENSE +21 -21
- package/skills/technical/content-platform/SKILL.md +134 -134
- package/skills/technical/cybersecurity-advanced/LICENSE +21 -21
- package/skills/technical/cybersecurity-advanced/SKILL.md +99 -99
- package/skills/technical/data-engineering/LICENSE +21 -21
- package/skills/technical/data-engineering/SKILL.md +117 -117
- package/skills/technical/database-design/LICENSE +21 -21
- package/skills/technical/database-design/SKILL.md +185 -185
- package/skills/technical/devops-cicd/LICENSE +21 -21
- package/skills/technical/devops-cicd/SKILL.md +181 -181
- package/skills/technical/ecommerce-builder/LICENSE +21 -21
- package/skills/technical/ecommerce-builder/SKILL.md +123 -123
- package/skills/technical/email-marketing/LICENSE +21 -21
- package/skills/technical/email-marketing/SKILL.md +128 -128
- package/skills/technical/fintech-builder/LICENSE +21 -21
- package/skills/technical/fintech-builder/SKILL.md +141 -141
- package/skills/technical/full-stack-web/LICENSE +21 -21
- package/skills/technical/full-stack-web/SKILL.md +173 -173
- package/skills/technical/gdpr-basics/LICENSE +21 -21
- package/skills/technical/gdpr-basics/SKILL.md +145 -145
- package/skills/technical/launch-playbook/LICENSE +21 -21
- package/skills/technical/launch-playbook/SKILL.md +95 -95
- package/skills/technical/marketing-copy/LICENSE +21 -21
- package/skills/technical/marketing-copy/SKILL.md +126 -126
- package/skills/technical/marketplace-builder/LICENSE +21 -21
- package/skills/technical/marketplace-builder/SKILL.md +105 -105
- package/skills/technical/mobile-pwa/LICENSE +21 -21
- package/skills/technical/mobile-pwa/SKILL.md +191 -191
- package/skills/technical/no-code-tools/LICENSE +21 -21
- package/skills/technical/no-code-tools/SKILL.md +80 -80
- package/skills/technical/open-source/LICENSE +21 -21
- package/skills/technical/open-source/SKILL.md +71 -71
- package/skills/technical/performance-optimization/LICENSE +21 -21
- package/skills/technical/performance-optimization/SKILL.md +155 -155
- package/skills/technical/pricing-design/LICENSE +21 -21
- package/skills/technical/pricing-design/SKILL.md +87 -87
- package/skills/technical/product-management/LICENSE +21 -21
- package/skills/technical/product-management/SKILL.md +94 -94
- package/skills/technical/saas-builder/LICENSE +21 -21
- package/skills/technical/saas-builder/SKILL.md +138 -138
- package/skills/technical/scope-estimation/LICENSE +21 -21
- package/skills/technical/scope-estimation/SKILL.md +99 -99
- package/skills/technical/secrets-management/LICENSE +21 -21
- package/skills/technical/secrets-management/SKILL.md +135 -135
- package/skills/technical/seo-technical/LICENSE +21 -21
- package/skills/technical/seo-technical/SKILL.md +136 -136
- package/skills/technical/technical-writing/LICENSE +21 -21
- package/skills/technical/technical-writing/SKILL.md +149 -149
- package/skills/technical/ux-research-tools/LICENSE +21 -21
- package/skills/technical/ux-research-tools/SKILL.md +54 -54
- package/skills/theme-factory/LICENSE +21 -21
- package/skills/theme-factory/SKILL.md +65 -65
- package/skills/theme-factory/themes/arctic-frost.md +19 -19
- package/skills/theme-factory/themes/botanical-garden.md +19 -19
- package/skills/theme-factory/themes/desert-rose.md +19 -19
- package/skills/theme-factory/themes/forest-canopy.md +19 -19
- package/skills/theme-factory/themes/golden-hour.md +19 -19
- package/skills/theme-factory/themes/midnight-galaxy.md +19 -19
- package/skills/theme-factory/themes/modern-minimalist.md +19 -19
- package/skills/theme-factory/themes/ocean-depths.md +19 -19
- package/skills/theme-factory/themes/sunset-boulevard.md +19 -19
- package/skills/theme-factory/themes/tech-innovation.md +19 -19
- package/skills/things-mac/SKILL.md +90 -90
- package/skills/tmux/SKILL.md +95 -95
- package/skills/tmux/scripts/find-sessions.sh +112 -112
- package/skills/tmux/scripts/wait-for-text.sh +83 -83
- package/skills/trades/trades-agriculture/LICENSE +21 -21
- package/skills/trades/trades-agriculture/SKILL.md +80 -80
- package/skills/trades/trades-automotive/LICENSE +21 -21
- package/skills/trades/trades-automotive/SKILL.md +84 -84
- package/skills/trades/trades-carpentry/LICENSE +21 -21
- package/skills/trades/trades-carpentry/SKILL.md +71 -71
- package/skills/trades/trades-cooking-pro/LICENSE +21 -21
- package/skills/trades/trades-cooking-pro/SKILL.md +90 -90
- package/skills/trades/trades-electrical/LICENSE +21 -21
- package/skills/trades/trades-electrical/SKILL.md +146 -146
- package/skills/trades/trades-hvac/LICENSE +21 -21
- package/skills/trades/trades-hvac/SKILL.md +80 -80
- package/skills/trades/trades-landscaping/LICENSE +21 -21
- package/skills/trades/trades-landscaping/SKILL.md +60 -60
- package/skills/trades/trades-metalworking/LICENSE +21 -21
- package/skills/trades/trades-metalworking/SKILL.md +64 -64
- package/skills/trades/trades-painting/LICENSE +21 -21
- package/skills/trades/trades-painting/SKILL.md +70 -70
- package/skills/trades/trades-plumbing/LICENSE +21 -21
- package/skills/trades/trades-plumbing/SKILL.md +160 -160
- package/skills/trades/trades-welding/LICENSE +21 -21
- package/skills/trades/trades-welding/SKILL.md +82 -82
- package/skills/trello/SKILL.md +112 -112
- package/skills/uipm-ui-styling/SKILL.md +328 -328
- package/skills/video-frames/SKILL.md +50 -50
- package/skills/video-frames/scripts/frame.sh +81 -81
- package/skills/voice-call/SKILL.md +49 -49
- package/skills/wacli/SKILL.md +76 -76
- package/skills/weather/SKILL.md +91 -91
- package/skills/web-artifacts-builder/LICENSE +21 -21
- package/skills/web-artifacts-builder/SKILL.md +82 -82
- package/skills/web-artifacts-builder/scripts/bundle-artifact.sh +53 -53
- package/skills/web-artifacts-builder/scripts/init-artifact.sh +322 -322
- package/skills/xurl/SKILL.md +124 -124
- package/skills/graphify/SKILL.md +0 -619
- package/skills/graphify/__init__.py +0 -28
- package/skills/graphify/__main__.py +0 -4582
- package/skills/graphify/affected.py +0 -154
- package/skills/graphify/always_on/agents-md.md +0 -12
- package/skills/graphify/always_on/antigravity-rules.md +0 -14
- package/skills/graphify/always_on/claude-md.md +0 -9
- package/skills/graphify/always_on/gemini-md.md +0 -9
- package/skills/graphify/always_on/kiro-steering.md +0 -5
- package/skills/graphify/always_on/vscode-instructions.md +0 -17
- package/skills/graphify/analyze.py +0 -724
- package/skills/graphify/benchmark.py +0 -155
- package/skills/graphify/build.py +0 -487
- package/skills/graphify/cache.py +0 -417
- package/skills/graphify/callflow_html.py +0 -2020
- package/skills/graphify/cluster.py +0 -272
- package/skills/graphify/command-kilo.md +0 -15
- package/skills/graphify/dedup.py +0 -429
- package/skills/graphify/detect.py +0 -1379
- package/skills/graphify/diagnostics.py +0 -390
- package/skills/graphify/export.py +0 -1408
- package/skills/graphify/extract.py +0 -11570
- package/skills/graphify/global_graph.py +0 -159
- package/skills/graphify/google_workspace.py +0 -223
- package/skills/graphify/hooks.py +0 -457
- package/skills/graphify/ingest.py +0 -331
- package/skills/graphify/llm.py +0 -1896
- package/skills/graphify/manifest.py +0 -4
- package/skills/graphify/mcp_ingest.py +0 -392
- package/skills/graphify/multigraph_compat.py +0 -212
- package/skills/graphify/pg_introspect.py +0 -142
- package/skills/graphify/prs.py +0 -748
- package/skills/graphify/querylog.py +0 -70
- package/skills/graphify/report.py +0 -218
- package/skills/graphify/scip_ingest.py +0 -363
- package/skills/graphify/security.py +0 -336
- package/skills/graphify/semantic_cleanup.py +0 -319
- package/skills/graphify/serve.py +0 -1309
- package/skills/graphify/skill-aider.md +0 -1246
- package/skills/graphify/skill-amp.md +0 -613
- package/skills/graphify/skill-claw.md +0 -616
- package/skills/graphify/skill-codex.md +0 -613
- package/skills/graphify/skill-copilot.md +0 -616
- package/skills/graphify/skill-devin.md +0 -1372
- package/skills/graphify/skill-droid.md +0 -613
- package/skills/graphify/skill-kilo.md +0 -625
- package/skills/graphify/skill-kiro.md +0 -615
- package/skills/graphify/skill-opencode.md +0 -608
- package/skills/graphify/skill-pi.md +0 -615
- package/skills/graphify/skill-trae.md +0 -614
- package/skills/graphify/skill-vscode.md +0 -612
- package/skills/graphify/skill-windows.md +0 -651
- package/skills/graphify/skills/amp/references/add-watch.md +0 -56
- package/skills/graphify/skills/amp/references/exports.md +0 -71
- package/skills/graphify/skills/amp/references/extraction-spec.md +0 -68
- package/skills/graphify/skills/amp/references/github-and-merge.md +0 -46
- package/skills/graphify/skills/amp/references/hooks.md +0 -33
- package/skills/graphify/skills/amp/references/query.md +0 -249
- package/skills/graphify/skills/amp/references/transcribe.md +0 -48
- package/skills/graphify/skills/amp/references/update.md +0 -179
- package/skills/graphify/skills/claude/references/add-watch.md +0 -56
- package/skills/graphify/skills/claude/references/exports.md +0 -71
- package/skills/graphify/skills/claude/references/extraction-spec.md +0 -68
- package/skills/graphify/skills/claude/references/github-and-merge.md +0 -46
- package/skills/graphify/skills/claude/references/hooks.md +0 -33
- package/skills/graphify/skills/claude/references/query.md +0 -103
- package/skills/graphify/skills/claude/references/transcribe.md +0 -48
- package/skills/graphify/skills/claude/references/update.md +0 -179
- package/skills/graphify/skills/claw/references/add-watch.md +0 -56
- package/skills/graphify/skills/claw/references/exports.md +0 -71
- package/skills/graphify/skills/claw/references/extraction-spec.md +0 -29
- package/skills/graphify/skills/claw/references/github-and-merge.md +0 -46
- package/skills/graphify/skills/claw/references/hooks.md +0 -33
- package/skills/graphify/skills/claw/references/query.md +0 -249
- package/skills/graphify/skills/claw/references/transcribe.md +0 -48
- package/skills/graphify/skills/claw/references/update.md +0 -179
- package/skills/graphify/skills/codex/references/add-watch.md +0 -56
- package/skills/graphify/skills/codex/references/exports.md +0 -71
- package/skills/graphify/skills/codex/references/extraction-spec.md +0 -29
- package/skills/graphify/skills/codex/references/github-and-merge.md +0 -46
- package/skills/graphify/skills/codex/references/hooks.md +0 -33
- package/skills/graphify/skills/codex/references/query.md +0 -249
- package/skills/graphify/skills/codex/references/transcribe.md +0 -48
- package/skills/graphify/skills/codex/references/update.md +0 -179
- package/skills/graphify/skills/copilot/references/add-watch.md +0 -56
- package/skills/graphify/skills/copilot/references/exports.md +0 -71
- package/skills/graphify/skills/copilot/references/extraction-spec.md +0 -68
- package/skills/graphify/skills/copilot/references/github-and-merge.md +0 -46
- package/skills/graphify/skills/copilot/references/hooks.md +0 -33
- package/skills/graphify/skills/copilot/references/query.md +0 -249
- package/skills/graphify/skills/copilot/references/transcribe.md +0 -48
- package/skills/graphify/skills/copilot/references/update.md +0 -179
- package/skills/graphify/skills/droid/references/add-watch.md +0 -56
- package/skills/graphify/skills/droid/references/exports.md +0 -71
- package/skills/graphify/skills/droid/references/extraction-spec.md +0 -68
- package/skills/graphify/skills/droid/references/github-and-merge.md +0 -46
- package/skills/graphify/skills/droid/references/hooks.md +0 -33
- package/skills/graphify/skills/droid/references/query.md +0 -249
- package/skills/graphify/skills/droid/references/transcribe.md +0 -48
- package/skills/graphify/skills/droid/references/update.md +0 -179
- package/skills/graphify/skills/kilo/references/add-watch.md +0 -56
- package/skills/graphify/skills/kilo/references/exports.md +0 -71
- package/skills/graphify/skills/kilo/references/extraction-spec.md +0 -68
- package/skills/graphify/skills/kilo/references/github-and-merge.md +0 -46
- package/skills/graphify/skills/kilo/references/hooks.md +0 -33
- package/skills/graphify/skills/kilo/references/query.md +0 -249
- package/skills/graphify/skills/kilo/references/transcribe.md +0 -48
- package/skills/graphify/skills/kilo/references/update.md +0 -179
- package/skills/graphify/skills/kiro/references/add-watch.md +0 -56
- package/skills/graphify/skills/kiro/references/exports.md +0 -71
- package/skills/graphify/skills/kiro/references/extraction-spec.md +0 -29
- package/skills/graphify/skills/kiro/references/github-and-merge.md +0 -46
- package/skills/graphify/skills/kiro/references/hooks.md +0 -33
- package/skills/graphify/skills/kiro/references/query.md +0 -249
- package/skills/graphify/skills/kiro/references/transcribe.md +0 -48
- package/skills/graphify/skills/kiro/references/update.md +0 -179
- package/skills/graphify/skills/opencode/references/add-watch.md +0 -56
- package/skills/graphify/skills/opencode/references/exports.md +0 -71
- package/skills/graphify/skills/opencode/references/extraction-spec.md +0 -68
- package/skills/graphify/skills/opencode/references/github-and-merge.md +0 -46
- package/skills/graphify/skills/opencode/references/hooks.md +0 -33
- package/skills/graphify/skills/opencode/references/query.md +0 -249
- package/skills/graphify/skills/opencode/references/transcribe.md +0 -48
- package/skills/graphify/skills/opencode/references/update.md +0 -179
- package/skills/graphify/skills/pi/references/add-watch.md +0 -56
- package/skills/graphify/skills/pi/references/exports.md +0 -71
- package/skills/graphify/skills/pi/references/extraction-spec.md +0 -29
- package/skills/graphify/skills/pi/references/github-and-merge.md +0 -46
- package/skills/graphify/skills/pi/references/hooks.md +0 -33
- package/skills/graphify/skills/pi/references/query.md +0 -249
- package/skills/graphify/skills/pi/references/transcribe.md +0 -48
- package/skills/graphify/skills/pi/references/update.md +0 -179
- package/skills/graphify/skills/trae/references/add-watch.md +0 -56
- package/skills/graphify/skills/trae/references/exports.md +0 -71
- package/skills/graphify/skills/trae/references/extraction-spec.md +0 -68
- package/skills/graphify/skills/trae/references/github-and-merge.md +0 -46
- package/skills/graphify/skills/trae/references/hooks.md +0 -35
- package/skills/graphify/skills/trae/references/query.md +0 -249
- package/skills/graphify/skills/trae/references/transcribe.md +0 -48
- package/skills/graphify/skills/trae/references/update.md +0 -179
- package/skills/graphify/skills/vscode/references/add-watch.md +0 -56
- package/skills/graphify/skills/vscode/references/exports.md +0 -71
- package/skills/graphify/skills/vscode/references/extraction-spec.md +0 -68
- package/skills/graphify/skills/vscode/references/github-and-merge.md +0 -46
- package/skills/graphify/skills/vscode/references/hooks.md +0 -33
- package/skills/graphify/skills/vscode/references/query.md +0 -249
- package/skills/graphify/skills/vscode/references/transcribe.md +0 -48
- package/skills/graphify/skills/vscode/references/update.md +0 -179
- package/skills/graphify/skills/windows/references/add-watch.md +0 -56
- package/skills/graphify/skills/windows/references/exports.md +0 -71
- package/skills/graphify/skills/windows/references/extraction-spec.md +0 -68
- package/skills/graphify/skills/windows/references/github-and-merge.md +0 -46
- package/skills/graphify/skills/windows/references/hooks.md +0 -33
- package/skills/graphify/skills/windows/references/query.md +0 -249
- package/skills/graphify/skills/windows/references/transcribe.md +0 -48
- package/skills/graphify/skills/windows/references/update.md +0 -179
- package/skills/graphify/symbol_resolution.py +0 -538
- package/skills/graphify/transcribe.py +0 -184
- package/skills/graphify/tree_html.py +0 -582
- package/skills/graphify/validate.py +0 -72
- package/skills/graphify/watch.py +0 -898
- package/skills/graphify/wiki.py +0 -282
|
@@ -1,748 +1,748 @@
|
|
|
1
|
-
# Language Reference — Deep Patterns & Best Practices
|
|
2
|
-
|
|
3
|
-
## JAVA 21 (Current LTS)
|
|
4
|
-
|
|
5
|
-
### Modern Java Patterns
|
|
6
|
-
|
|
7
|
-
```java
|
|
8
|
-
// Records (replace Lombok @Data)
|
|
9
|
-
record TransactionDto(String id, BigDecimal amount, String currency, Instant createdAt) {}
|
|
10
|
-
|
|
11
|
-
// Sealed classes (exhaustive type hierarchies)
|
|
12
|
-
sealed interface PaymentResult permits PaymentSuccess, PaymentFailure, PaymentPending {}
|
|
13
|
-
record PaymentSuccess(String transactionId) implements PaymentResult {}
|
|
14
|
-
record PaymentFailure(String errorCode, String message) implements PaymentResult {}
|
|
15
|
-
|
|
16
|
-
// Pattern matching switch (exhaustive, compiler-checked)
|
|
17
|
-
String describe(PaymentResult result) {
|
|
18
|
-
return switch (result) {
|
|
19
|
-
case PaymentSuccess s -> "Approved: " + s.transactionId();
|
|
20
|
-
case PaymentFailure f -> "Declined: " + f.message();
|
|
21
|
-
case PaymentPending p -> "Processing";
|
|
22
|
-
};
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
// Virtual threads (Project Loom) — handle 1M+ concurrent connections
|
|
26
|
-
try (var executor = Executors.newVirtualThreadPerTaskExecutor()) {
|
|
27
|
-
IntStream.range(0, 100_000).forEach(i ->
|
|
28
|
-
executor.submit(() -> handleRequest(i))
|
|
29
|
-
);
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
// Text blocks
|
|
33
|
-
String json = """
|
|
34
|
-
{
|
|
35
|
-
"type": "fraud_detected",
|
|
36
|
-
"transactionId": "%s"
|
|
37
|
-
}
|
|
38
|
-
""".formatted(txId);
|
|
39
|
-
```
|
|
40
|
-
|
|
41
|
-
### Spring Boot 3.x Essentials
|
|
42
|
-
|
|
43
|
-
```java
|
|
44
|
-
// Minimal REST controller
|
|
45
|
-
@RestController @RequestMapping("/api/v1/transactions")
|
|
46
|
-
@RequiredArgsConstructor
|
|
47
|
-
public class TransactionController {
|
|
48
|
-
private final TransactionService service;
|
|
49
|
-
|
|
50
|
-
@GetMapping
|
|
51
|
-
public Page<TransactionDto> list(
|
|
52
|
-
@AuthenticationPrincipal UserDetails user,
|
|
53
|
-
@RequestParam(defaultValue = "0") int page,
|
|
54
|
-
@RequestParam(defaultValue = "20") int size
|
|
55
|
-
) {
|
|
56
|
-
return service.findByUser(user.getUsername(), PageRequest.of(page, size));
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
@PostMapping
|
|
60
|
-
@ResponseStatus(HttpStatus.CREATED)
|
|
61
|
-
public TransactionDto create(@Valid @RequestBody CreateTransactionRequest req,
|
|
62
|
-
@AuthenticationPrincipal UserDetails user) {
|
|
63
|
-
return service.create(req, user.getUsername());
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
// Global exception handler
|
|
68
|
-
@RestControllerAdvice
|
|
69
|
-
public class GlobalExceptionHandler {
|
|
70
|
-
@ExceptionHandler(NotFoundException.class)
|
|
71
|
-
@ResponseStatus(HttpStatus.NOT_FOUND)
|
|
72
|
-
public ProblemDetail handleNotFound(NotFoundException ex) {
|
|
73
|
-
return ProblemDetail.forStatusAndDetail(HttpStatus.NOT_FOUND, ex.getMessage());
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
```
|
|
77
|
-
|
|
78
|
-
### Java Pitfalls
|
|
79
|
-
|
|
80
|
-
```
|
|
81
|
-
BigDecimal for money: NEVER double/float. new BigDecimal("19.99") not new BigDecimal(19.99)
|
|
82
|
-
Optional correctly: Never as method param. Never .get() without .isPresent(). Use .orElseThrow()
|
|
83
|
-
String concatenation: StringBuilder in loops. Never "str" + var in loop body.
|
|
84
|
-
equals/hashCode: Always override together. Records do this automatically.
|
|
85
|
-
Static analysis: SpotBugs + CheckStyle + SonarQube — run in CI.
|
|
86
|
-
```
|
|
87
|
-
|
|
88
|
-
---
|
|
89
|
-
|
|
90
|
-
## PYTHON 3.12+
|
|
91
|
-
|
|
92
|
-
### Modern Python Patterns
|
|
93
|
-
|
|
94
|
-
```python
|
|
95
|
-
from __future__ import annotations
|
|
96
|
-
from typing import TypeVar, Generic
|
|
97
|
-
from dataclasses import dataclass, field
|
|
98
|
-
from datetime import datetime
|
|
99
|
-
import asyncio
|
|
100
|
-
|
|
101
|
-
# Dataclasses (not dicts for structured data)
|
|
102
|
-
@dataclass(frozen=True, slots=True) # frozen=immutable, slots=memory-efficient
|
|
103
|
-
class Transaction:
|
|
104
|
-
id: str
|
|
105
|
-
amount: Decimal
|
|
106
|
-
currency: str
|
|
107
|
-
created_at: datetime = field(default_factory=datetime.utcnow)
|
|
108
|
-
|
|
109
|
-
# Type aliases and generics
|
|
110
|
-
type UserId = str
|
|
111
|
-
type TransactionId = str
|
|
112
|
-
|
|
113
|
-
# Structural pattern matching (3.10+)
|
|
114
|
-
match result:
|
|
115
|
-
case {"status": "success", "data": data}:
|
|
116
|
-
process(data)
|
|
117
|
-
case {"status": "error", "code": code} if code >= 500:
|
|
118
|
-
alert_team(code)
|
|
119
|
-
case _:
|
|
120
|
-
log_unknown(result)
|
|
121
|
-
|
|
122
|
-
# Async patterns (always use async for I/O)
|
|
123
|
-
async def fetch_fraud_signals(tx_ids: list[str]) -> dict[str, float]:
|
|
124
|
-
async with aiohttp.ClientSession() as session:
|
|
125
|
-
tasks = [fetch_signal(session, tx_id) for tx_id in tx_ids]
|
|
126
|
-
results = await asyncio.gather(*tasks, return_exceptions=True)
|
|
127
|
-
return {
|
|
128
|
-
tx_id: score
|
|
129
|
-
for tx_id, score in zip(tx_ids, results)
|
|
130
|
-
if not isinstance(score, Exception)
|
|
131
|
-
}
|
|
132
|
-
```
|
|
133
|
-
|
|
134
|
-
### FastAPI (Production Patterns)
|
|
135
|
-
|
|
136
|
-
```python
|
|
137
|
-
from fastapi import FastAPI, Depends, HTTPException, status
|
|
138
|
-
from fastapi.middleware.cors import CORSMiddleware
|
|
139
|
-
from contextlib import asynccontextmanager
|
|
140
|
-
|
|
141
|
-
@asynccontextmanager
|
|
142
|
-
async def lifespan(app: FastAPI):
|
|
143
|
-
# Startup
|
|
144
|
-
await db.connect()
|
|
145
|
-
await redis.ping()
|
|
146
|
-
yield
|
|
147
|
-
# Shutdown
|
|
148
|
-
await db.disconnect()
|
|
149
|
-
await redis.aclose()
|
|
150
|
-
|
|
151
|
-
app = FastAPI(lifespan=lifespan)
|
|
152
|
-
|
|
153
|
-
# Dependency injection
|
|
154
|
-
async def get_current_user(token: str = Depends(oauth2_scheme), db = Depends(get_db)):
|
|
155
|
-
payload = verify_jwt(token)
|
|
156
|
-
user = await db.users.get(payload["sub"])
|
|
157
|
-
if not user:
|
|
158
|
-
raise HTTPException(status.HTTP_401_UNAUTHORIZED)
|
|
159
|
-
return user
|
|
160
|
-
|
|
161
|
-
@app.get("/transactions", response_model=Page[TransactionResponse])
|
|
162
|
-
async def list_transactions(
|
|
163
|
-
page: int = Query(1, ge=1),
|
|
164
|
-
limit: int = Query(20, le=100),
|
|
165
|
-
current_user: User = Depends(get_current_user),
|
|
166
|
-
db: AsyncSession = Depends(get_db)
|
|
167
|
-
):
|
|
168
|
-
return await transaction_service.paginate(db, current_user.id, page, limit)
|
|
169
|
-
```
|
|
170
|
-
|
|
171
|
-
### Python Pitfalls
|
|
172
|
-
|
|
173
|
-
```python
|
|
174
|
-
# Mutable default args — classic bug
|
|
175
|
-
def bad(items=[]): items.append(1); return items # SAME list across calls
|
|
176
|
-
def good(items=None): items = items or []; items.append(1); return items
|
|
177
|
-
|
|
178
|
-
# Late binding closures
|
|
179
|
-
# bad: all lambdas capture same i
|
|
180
|
-
funcs = [lambda: i for i in range(3)] # all return 2
|
|
181
|
-
# good: capture by value
|
|
182
|
-
funcs = [lambda i=i: i for i in range(3)] # 0, 1, 2
|
|
183
|
-
|
|
184
|
-
# Blocking in async — kills performance
|
|
185
|
-
async def bad(): time.sleep(1) # blocks entire event loop
|
|
186
|
-
async def good(): await asyncio.sleep(1) # yields to other coroutines
|
|
187
|
-
|
|
188
|
-
# String formatting — always f-strings (fastest)
|
|
189
|
-
name = "World"
|
|
190
|
-
bad = "Hello, " + name # concatenation
|
|
191
|
-
bad = "Hello, %s" % name # old style
|
|
192
|
-
good = f"Hello, {name}" # f-strings — fastest, most readable
|
|
193
|
-
```
|
|
194
|
-
|
|
195
|
-
---
|
|
196
|
-
|
|
197
|
-
## TYPESCRIPT (Strict Mode Always)
|
|
198
|
-
|
|
199
|
-
### Type System Mastery
|
|
200
|
-
|
|
201
|
-
```typescript
|
|
202
|
-
// Discriminated unions — exhaustive pattern matching
|
|
203
|
-
type Result<T, E = Error> = { ok: true; value: T } | { ok: false; error: E };
|
|
204
|
-
|
|
205
|
-
function divide(a: number, b: number): Result<number> {
|
|
206
|
-
if (b === 0) return { ok: false, error: new Error("Division by zero") };
|
|
207
|
-
return { ok: true, value: a / b };
|
|
208
|
-
}
|
|
209
|
-
|
|
210
|
-
// Template literal types — type-safe event names
|
|
211
|
-
type EventName = `${string}.created` | `${string}.updated` | `${string}.deleted`;
|
|
212
|
-
type UserEvent = `user.${"created" | "updated" | "deleted"}`;
|
|
213
|
-
|
|
214
|
-
// Conditional types — advanced type transformations
|
|
215
|
-
type NonNullable<T> = T extends null | undefined ? never : T;
|
|
216
|
-
type ReturnType<T> = T extends (...args: any[]) => infer R ? R : never;
|
|
217
|
-
type Awaited<T> = T extends Promise<infer U> ? Awaited<U> : T;
|
|
218
|
-
|
|
219
|
-
// Branded types — prevent primitive obsession
|
|
220
|
-
type UserId = string & { readonly _brand: "UserId" };
|
|
221
|
-
type Amount = number & { readonly _brand: "Amount" };
|
|
222
|
-
const userId = "abc-123" as UserId; // explicit cast required
|
|
223
|
-
function getUser(id: UserId) {} // compiler prevents passing arbitrary string
|
|
224
|
-
|
|
225
|
-
// Satisfies operator (4.9+) — check type without widening
|
|
226
|
-
const config = {
|
|
227
|
-
db: { host: "localhost", port: 5432 },
|
|
228
|
-
redis: { host: "localhost", port: 6379 },
|
|
229
|
-
} satisfies Record<string, { host: string; port: number }>;
|
|
230
|
-
// config.db.host is still string literal type (not widened to string)
|
|
231
|
-
```
|
|
232
|
-
|
|
233
|
-
### Next.js 14 App Router Patterns
|
|
234
|
-
|
|
235
|
-
```typescript
|
|
236
|
-
// Server component (default — zero JS sent to client)
|
|
237
|
-
async function TransactionList({ userId }: { userId: string }) {
|
|
238
|
-
const transactions = await db.transaction.findMany({ where: { userId } })
|
|
239
|
-
return <ul>{transactions.map(tx => <TransactionItem key={tx.id} tx={tx} />)}</ul>
|
|
240
|
-
}
|
|
241
|
-
|
|
242
|
-
// Server action (form mutation without API route)
|
|
243
|
-
async function createTransaction(formData: FormData) {
|
|
244
|
-
'use server'
|
|
245
|
-
const amount = formData.get('amount') as string
|
|
246
|
-
await db.transaction.create({ data: { amount: parseFloat(amount), userId: await getUserId() }})
|
|
247
|
-
revalidatePath('/dashboard')
|
|
248
|
-
}
|
|
249
|
-
|
|
250
|
-
// Route handler with proper error handling
|
|
251
|
-
export async function POST(request: Request) {
|
|
252
|
-
try {
|
|
253
|
-
const body = await request.json()
|
|
254
|
-
const validated = schema.parse(body) // Zod validation
|
|
255
|
-
const result = await service.create(validated)
|
|
256
|
-
return Response.json(result, { status: 201 })
|
|
257
|
-
} catch (err) {
|
|
258
|
-
if (err instanceof ZodError) {
|
|
259
|
-
return Response.json({ error: err.errors }, { status: 400 })
|
|
260
|
-
}
|
|
261
|
-
return Response.json({ error: 'Internal error' }, { status: 500 })
|
|
262
|
-
}
|
|
263
|
-
}
|
|
264
|
-
```
|
|
265
|
-
|
|
266
|
-
---
|
|
267
|
-
|
|
268
|
-
## GO 1.22+
|
|
269
|
-
|
|
270
|
-
### Production Patterns
|
|
271
|
-
|
|
272
|
-
```go
|
|
273
|
-
// Error handling — always explicit, never ignore
|
|
274
|
-
func getUser(ctx context.Context, id string) (*User, error) {
|
|
275
|
-
user, err := db.QueryRowContext(ctx, "SELECT * FROM users WHERE id = $1", id).Scan(&user)
|
|
276
|
-
if err != nil {
|
|
277
|
-
if errors.Is(err, sql.ErrNoRows) {
|
|
278
|
-
return nil, fmt.Errorf("user %s: %w", id, ErrNotFound) // wrap for context
|
|
279
|
-
}
|
|
280
|
-
return nil, fmt.Errorf("query user %s: %w", id, err)
|
|
281
|
-
}
|
|
282
|
-
return user, nil
|
|
283
|
-
}
|
|
284
|
-
|
|
285
|
-
// Context propagation — always pass ctx as first param
|
|
286
|
-
func (s *Service) ProcessTransaction(ctx context.Context, req Request) (*Response, error) {
|
|
287
|
-
ctx, cancel := context.WithTimeout(ctx, 5*time.Second)
|
|
288
|
-
defer cancel()
|
|
289
|
-
// All downstream calls use this ctx — cancellation propagates automatically
|
|
290
|
-
return s.repo.Create(ctx, req)
|
|
291
|
-
}
|
|
292
|
-
|
|
293
|
-
// Goroutine leak prevention — always use errgroup or WaitGroup
|
|
294
|
-
func fetchAll(ctx context.Context, ids []string) ([]Result, error) {
|
|
295
|
-
g, ctx := errgroup.WithContext(ctx)
|
|
296
|
-
results := make([]Result, len(ids))
|
|
297
|
-
for i, id := range ids {
|
|
298
|
-
i, id := i, id // capture loop vars
|
|
299
|
-
g.Go(func() error {
|
|
300
|
-
result, err := fetch(ctx, id)
|
|
301
|
-
if err != nil { return err }
|
|
302
|
-
results[i] = result
|
|
303
|
-
return nil
|
|
304
|
-
})
|
|
305
|
-
}
|
|
306
|
-
return results, g.Wait()
|
|
307
|
-
}
|
|
308
|
-
|
|
309
|
-
// Struct embedding for interfaces
|
|
310
|
-
type Service struct {
|
|
311
|
-
db *sql.DB
|
|
312
|
-
cache Cache // interface — easy to mock in tests
|
|
313
|
-
logger *slog.Logger // structured logging — use slog (stdlib since 1.21)
|
|
314
|
-
}
|
|
315
|
-
```
|
|
316
|
-
|
|
317
|
-
### Go Pitfalls
|
|
318
|
-
|
|
319
|
-
```
|
|
320
|
-
Goroutine leaks: Always defer cancel() after context.WithTimeout/WithCancel
|
|
321
|
-
Slice gotchas: append may or may not create new backing array — use copy() when in doubt
|
|
322
|
-
Interface nil: var err *MyError = nil; var i error = err; i != nil is TRUE (interface type != nil)
|
|
323
|
-
Map not safe: sync.Map or mutex for concurrent map access
|
|
324
|
-
String conversion: []byte(str) copies — use unsafe.Slice for zero-copy in hot paths
|
|
325
|
-
```
|
|
326
|
-
|
|
327
|
-
---
|
|
328
|
-
|
|
329
|
-
## RUST (2021 Edition)
|
|
330
|
-
|
|
331
|
-
### Core Patterns
|
|
332
|
-
|
|
333
|
-
```rust
|
|
334
|
-
// Result and Option — no null pointer exceptions, ever
|
|
335
|
-
fn parse_amount(s: &str) -> Result<f64, ParseError> {
|
|
336
|
-
s.trim().parse::<f64>().map_err(|e| ParseError::InvalidAmount(e.to_string()))
|
|
337
|
-
}
|
|
338
|
-
|
|
339
|
-
// Ownership-safe shared state
|
|
340
|
-
use std::sync::{Arc, RwLock};
|
|
341
|
-
#[derive(Clone)]
|
|
342
|
-
struct AppState { db: Arc<Pool<Postgres>>, cache: Arc<RwLock<HashMap<String, Value>>> }
|
|
343
|
-
|
|
344
|
-
// Axum web handler (async, zero-cost)
|
|
345
|
-
async fn create_transaction(
|
|
346
|
-
State(state): State<AppState>,
|
|
347
|
-
Json(payload): Json<CreateRequest>,
|
|
348
|
-
) -> Result<Json<Transaction>, AppError> {
|
|
349
|
-
let tx = sqlx::query_as::<_, Transaction>("INSERT INTO transactions ...")
|
|
350
|
-
.bind(&payload.amount)
|
|
351
|
-
.fetch_one(&*state.db)
|
|
352
|
-
.await?;
|
|
353
|
-
Ok(Json(tx))
|
|
354
|
-
}
|
|
355
|
-
|
|
356
|
-
// Traits for behavior abstraction
|
|
357
|
-
trait FraudDetector: Send + Sync {
|
|
358
|
-
async fn score(&self, tx: &Transaction) -> Result<f64, Error>;
|
|
359
|
-
}
|
|
360
|
-
```
|
|
361
|
-
|
|
362
|
-
---
|
|
363
|
-
|
|
364
|
-
## SQL — PRODUCTION PATTERNS
|
|
365
|
-
|
|
366
|
-
### Query Optimization
|
|
367
|
-
|
|
368
|
-
```sql
|
|
369
|
-
-- EXPLAIN ANALYZE every new query in production
|
|
370
|
-
EXPLAIN (ANALYZE, BUFFERS, FORMAT TEXT)
|
|
371
|
-
SELECT * FROM transactions WHERE user_id = $1 AND created_at > $2;
|
|
372
|
-
|
|
373
|
-
-- Index design rules:
|
|
374
|
-
-- 1. Index columns used in WHERE, JOIN ON, ORDER BY
|
|
375
|
-
-- 2. Composite index: put highest-selectivity column first
|
|
376
|
-
-- 3. Partial index for filtered queries:
|
|
377
|
-
CREATE INDEX idx_pending_transactions ON transactions (created_at)
|
|
378
|
-
WHERE status = 'pending'; -- Only indexes pending rows
|
|
379
|
-
|
|
380
|
-
-- 4. Index for LIKE prefix search:
|
|
381
|
-
CREATE INDEX idx_email_prefix ON users (email text_pattern_ops);
|
|
382
|
-
-- Supports: WHERE email LIKE 'user@%'
|
|
383
|
-
|
|
384
|
-
-- Avoid N+1: use JOIN or subquery instead
|
|
385
|
-
-- BAD (N+1):
|
|
386
|
-
SELECT * FROM orders; -- then for each order:
|
|
387
|
-
SELECT * FROM order_items WHERE order_id = $1;
|
|
388
|
-
|
|
389
|
-
-- GOOD (1 query):
|
|
390
|
-
SELECT o.*, json_agg(i.*) as items
|
|
391
|
-
FROM orders o
|
|
392
|
-
LEFT JOIN order_items i ON i.order_id = o.id
|
|
393
|
-
WHERE o.user_id = $1
|
|
394
|
-
GROUP BY o.id;
|
|
395
|
-
```
|
|
396
|
-
|
|
397
|
-
### PostgreSQL Power Features
|
|
398
|
-
|
|
399
|
-
```sql
|
|
400
|
-
-- Row-level security (multi-tenant isolation)
|
|
401
|
-
ALTER TABLE transactions ENABLE ROW LEVEL SECURITY;
|
|
402
|
-
CREATE POLICY tenant_isolation ON transactions
|
|
403
|
-
USING (org_id = current_setting('app.current_org_id')::uuid);
|
|
404
|
-
|
|
405
|
-
-- JSONB for flexible metadata (indexed)
|
|
406
|
-
ALTER TABLE transactions ADD COLUMN metadata JSONB DEFAULT '{}';
|
|
407
|
-
CREATE INDEX idx_tx_metadata_gin ON transactions USING gin(metadata);
|
|
408
|
-
-- Query: WHERE metadata @> '{"source": "mobile"}'
|
|
409
|
-
|
|
410
|
-
-- Window functions (analytics without GROUP BY collapse)
|
|
411
|
-
SELECT
|
|
412
|
-
user_id,
|
|
413
|
-
amount,
|
|
414
|
-
SUM(amount) OVER (PARTITION BY user_id ORDER BY created_at) as running_total,
|
|
415
|
-
ROW_NUMBER() OVER (PARTITION BY user_id ORDER BY created_at DESC) as rn
|
|
416
|
-
FROM transactions;
|
|
417
|
-
|
|
418
|
-
-- CTEs for readability (optimizer inlines them in PG 12+)
|
|
419
|
-
WITH high_risk AS (
|
|
420
|
-
SELECT user_id, COUNT(*) as flagged_count
|
|
421
|
-
FROM transactions WHERE risk_score > 0.8
|
|
422
|
-
GROUP BY user_id HAVING COUNT(*) > 3
|
|
423
|
-
)
|
|
424
|
-
SELECT u.email, h.flagged_count
|
|
425
|
-
FROM users u JOIN high_risk h USING (user_id);
|
|
426
|
-
|
|
427
|
-
-- Advisory locks for distributed mutex (no external Redis needed for simple cases)
|
|
428
|
-
SELECT pg_advisory_lock(hashtext('process-transaction-' || transaction_id));
|
|
429
|
-
-- ... do work ...
|
|
430
|
-
SELECT pg_advisory_unlock(hashtext('process-transaction-' || transaction_id));
|
|
431
|
-
```
|
|
432
|
-
|
|
433
|
-
---
|
|
434
|
-
|
|
435
|
-
## BASH — PRODUCTION SCRIPTS
|
|
436
|
-
|
|
437
|
-
```bash
|
|
438
|
-
#!/usr/bin/env bash
|
|
439
|
-
set -euo pipefail # e=exit on error, u=error on unset vars, o pipefail=pipe errors propagate
|
|
440
|
-
IFS=$'\n\t' # Safer word splitting
|
|
441
|
-
|
|
442
|
-
# Always quote variables
|
|
443
|
-
file="${1:-}"
|
|
444
|
-
if [[ -z "$file" ]]; then
|
|
445
|
-
echo "Usage: $0 <filename>" >&2
|
|
446
|
-
exit 1
|
|
447
|
-
fi
|
|
448
|
-
|
|
449
|
-
# Functions for reuse
|
|
450
|
-
log() { echo "[$(date -u +%Y-%m-%dT%H:%M:%SZ)] $*" >&2; }
|
|
451
|
-
die() { log "ERROR: $*"; exit 1; }
|
|
452
|
-
|
|
453
|
-
# Trap for cleanup
|
|
454
|
-
tmp_dir=$(mktemp -d)
|
|
455
|
-
trap 'rm -rf "$tmp_dir"' EXIT
|
|
456
|
-
|
|
457
|
-
# Check dependencies
|
|
458
|
-
command -v jq >/dev/null || die "jq is required but not installed"
|
|
459
|
-
command -v gcloud >/dev/null || die "gcloud is required but not installed"
|
|
460
|
-
|
|
461
|
-
# Process with error handling
|
|
462
|
-
if ! result=$(some_command 2>&1); then
|
|
463
|
-
die "Command failed: $result"
|
|
464
|
-
fi
|
|
465
|
-
|
|
466
|
-
log "Completed successfully"
|
|
467
|
-
```
|
|
468
|
-
|
|
469
|
-
---
|
|
470
|
-
|
|
471
|
-
## ELIXIR / ERLANG (Real-Time Systems)
|
|
472
|
-
|
|
473
|
-
```elixir
|
|
474
|
-
# Phoenix LiveView — real-time UI without JS complexity
|
|
475
|
-
defmodule FraudDashboardLive do
|
|
476
|
-
use Phoenix.LiveView
|
|
477
|
-
|
|
478
|
-
def mount(_params, _session, socket) do
|
|
479
|
-
if connected?(socket), do: Phoenix.PubSub.subscribe(App.PubSub, "fraud_alerts")
|
|
480
|
-
{:ok, assign(socket, alerts: load_recent_alerts())}
|
|
481
|
-
end
|
|
482
|
-
|
|
483
|
-
# Handles real-time messages from PubSub
|
|
484
|
-
def handle_info({:new_alert, alert}, socket) do
|
|
485
|
-
{:noreply, update(socket, :alerts, &[alert | &1])}
|
|
486
|
-
end
|
|
487
|
-
end
|
|
488
|
-
```
|
|
489
|
-
|
|
490
|
-
Use Elixir when: real-time features (chat, live dashboards, presence), high-concurrency (millions of connections), fault-tolerant distributed systems, IoT backends.
|
|
491
|
-
|
|
492
|
-
---
|
|
493
|
-
|
|
494
|
-
## WEBASSEMBLY (WASM)
|
|
495
|
-
|
|
496
|
-
Modern use cases:
|
|
497
|
-
|
|
498
|
-
- Run CPU-intensive code in the browser (image processing, crypto, compression)
|
|
499
|
-
- Compile Rust/C/C++ to WASM for near-native browser performance
|
|
500
|
-
- WASI for server-side sandboxed plugins
|
|
501
|
-
|
|
502
|
-
```rust
|
|
503
|
-
// Rust → WASM via wasm-pack
|
|
504
|
-
use wasm_bindgen::prelude::*;
|
|
505
|
-
|
|
506
|
-
#[wasm_bindgen]
|
|
507
|
-
pub fn process_transactions(data: &[u8]) -> Vec<u8> {
|
|
508
|
-
// CPU-intensive processing — runs in browser at near-native speed
|
|
509
|
-
let transactions: Vec<Transaction> = serde_json::from_slice(data).unwrap();
|
|
510
|
-
let results = transactions.iter().map(score_transaction).collect::<Vec<_>>();
|
|
511
|
-
serde_json::to_vec(&results).unwrap()
|
|
512
|
-
}
|
|
513
|
-
```
|
|
514
|
-
|
|
515
|
-
---
|
|
516
|
-
|
|
517
|
-
## DART (Flutter)
|
|
518
|
-
|
|
519
|
-
```dart
|
|
520
|
-
// Null safety — always enabled (Dart 3+)
|
|
521
|
-
String? maybeNull = null;
|
|
522
|
-
String definitelyNotNull = maybeNull ?? 'default';
|
|
523
|
-
String guaranteed = maybeNull!; // throws if null — use sparingly
|
|
524
|
-
|
|
525
|
-
// Records (Dart 3) — lightweight data structures
|
|
526
|
-
(String name, int age) person = ('<user>', 40);
|
|
527
|
-
print(person.$1); // '<user>'
|
|
528
|
-
|
|
529
|
-
// Sealed classes — exhaustive pattern matching
|
|
530
|
-
sealed class PaymentResult {}
|
|
531
|
-
class Success extends PaymentResult { final String txId; Success(this.txId); }
|
|
532
|
-
class Failure extends PaymentResult { final String error; Failure(this.error); }
|
|
533
|
-
|
|
534
|
-
String describe(PaymentResult r) => switch(r) {
|
|
535
|
-
Success s => 'OK: ${s.txId}',
|
|
536
|
-
Failure f => 'Error: ${f.error}',
|
|
537
|
-
}; // Compiler error if not exhaustive
|
|
538
|
-
|
|
539
|
-
// Async/await — same as JS/TS
|
|
540
|
-
Future<List<Transaction>> fetchTransactions(String userId) async {
|
|
541
|
-
final response = await http.get(Uri.parse('$baseUrl/transactions?userId=$userId'));
|
|
542
|
-
if (response.statusCode != 200) throw ApiException(response.statusCode);
|
|
543
|
-
return (jsonDecode(response.body) as List)
|
|
544
|
-
.map((e) => Transaction.fromJson(e))
|
|
545
|
-
.toList();
|
|
546
|
-
}
|
|
547
|
-
|
|
548
|
-
// Streams — reactive data
|
|
549
|
-
Stream<int> countUp(int max) async* {
|
|
550
|
-
for (var i = 0; i < max; i++) {
|
|
551
|
-
await Future.delayed(const Duration(seconds: 1));
|
|
552
|
-
yield i;
|
|
553
|
-
}
|
|
554
|
-
}
|
|
555
|
-
```
|
|
556
|
-
|
|
557
|
-
---
|
|
558
|
-
|
|
559
|
-
## SOLIDITY (Smart Contracts / Web3)
|
|
560
|
-
|
|
561
|
-
```solidity
|
|
562
|
-
// SPDX-License-Identifier: MIT
|
|
563
|
-
pragma solidity ^0.8.24;
|
|
564
|
-
|
|
565
|
-
import "@openzeppelin/contracts/token/ERC20/ERC20.sol";
|
|
566
|
-
import "@openzeppelin/contracts/access/Ownable.sol";
|
|
567
|
-
import "@openzeppelin/contracts/utils/ReentrancyGuard.sol";
|
|
568
|
-
|
|
569
|
-
// Security patterns — ALWAYS use these in production contracts
|
|
570
|
-
contract SecureToken is ERC20, Ownable, ReentrancyGuard {
|
|
571
|
-
uint256 public constant MAX_SUPPLY = 1_000_000 * 10**18;
|
|
572
|
-
mapping(address => bool) public blacklisted;
|
|
573
|
-
|
|
574
|
-
event Blacklisted(address indexed account);
|
|
575
|
-
|
|
576
|
-
constructor() ERC20("MyToken", "MTK") Ownable(msg.sender) {}
|
|
577
|
-
|
|
578
|
-
// Checks-Effects-Interactions pattern (prevent reentrancy)
|
|
579
|
-
function mint(address to, uint256 amount) external onlyOwner nonReentrant {
|
|
580
|
-
require(!blacklisted[to], "Blacklisted address"); // CHECK
|
|
581
|
-
require(totalSupply() + amount <= MAX_SUPPLY, "Exceeds max supply"); // CHECK
|
|
582
|
-
_mint(to, amount); // EFFECT (state change)
|
|
583
|
-
// No external calls after state changes (prevent reentrancy)
|
|
584
|
-
}
|
|
585
|
-
|
|
586
|
-
// Custom errors (cheaper than strings — Solidity 0.8+)
|
|
587
|
-
error Unauthorized(address caller);
|
|
588
|
-
error InsufficientBalance(uint256 available, uint256 required);
|
|
589
|
-
|
|
590
|
-
function _update(address from, address to, uint256 value)
|
|
591
|
-
internal override
|
|
592
|
-
{
|
|
593
|
-
if (blacklisted[from] || blacklisted[to]) revert Unauthorized(from);
|
|
594
|
-
super._update(from, to, value);
|
|
595
|
-
}
|
|
596
|
-
}
|
|
597
|
-
```
|
|
598
|
-
|
|
599
|
-
**Solidity Security Checklist:**
|
|
600
|
-
|
|
601
|
-
```
|
|
602
|
-
□ Reentrancy: ReentrancyGuard on all state-changing external calls
|
|
603
|
-
□ Integer overflow: Solidity 0.8+ has built-in. Use SafeMath only for older.
|
|
604
|
-
□ Access control: OpenZeppelin Ownable/AccessControl. Never trust msg.sender without check.
|
|
605
|
-
□ Oracle manipulation: Never use single oracle (Chainlink preferred, time-weighted for DEX)
|
|
606
|
-
□ Front-running: Commit-reveal scheme for sensitive operations
|
|
607
|
-
□ Audit: ALWAYS audit before mainnet. CertiK, Trail of Bits, OpenZeppelin audits.
|
|
608
|
-
□ Testing: Hardhat + Foundry. 100% branch coverage. Fuzzing required.
|
|
609
|
-
□ Upgrades: Proxy pattern (OpenZeppelin UUPS/Transparent) with timelocks
|
|
610
|
-
```
|
|
611
|
-
|
|
612
|
-
---
|
|
613
|
-
|
|
614
|
-
## GRAPHQL — PRODUCTION PATTERNS
|
|
615
|
-
|
|
616
|
-
```typescript
|
|
617
|
-
// Schema-first design (use SDL, not code-first for large schemas)
|
|
618
|
-
// schema.graphql
|
|
619
|
-
type Transaction {
|
|
620
|
-
id: ID!
|
|
621
|
-
amount: Float!
|
|
622
|
-
currency: String!
|
|
623
|
-
status: TransactionStatus!
|
|
624
|
-
user: User!
|
|
625
|
-
riskScore: Float
|
|
626
|
-
createdAt: DateTime!
|
|
627
|
-
}
|
|
628
|
-
|
|
629
|
-
enum TransactionStatus { PENDING COMPLETED FAILED REFUNDED }
|
|
630
|
-
|
|
631
|
-
type Query {
|
|
632
|
-
transaction(id: ID!): Transaction
|
|
633
|
-
transactions(
|
|
634
|
-
filter: TransactionFilter
|
|
635
|
-
first: Int = 20
|
|
636
|
-
after: String # Cursor-based pagination
|
|
637
|
-
): TransactionConnection!
|
|
638
|
-
}
|
|
639
|
-
|
|
640
|
-
type Mutation {
|
|
641
|
-
createTransaction(input: CreateTransactionInput!): TransactionResult!
|
|
642
|
-
}
|
|
643
|
-
|
|
644
|
-
type Subscription {
|
|
645
|
-
transactionUpdated(orgId: ID!): Transaction! # Real-time updates
|
|
646
|
-
}
|
|
647
|
-
|
|
648
|
-
# --- Resolver (TypeScript with DataLoader) ---
|
|
649
|
-
import DataLoader from 'dataloader'
|
|
650
|
-
|
|
651
|
-
// N+1 problem solution — batch all user lookups into one query
|
|
652
|
-
const userLoader = new DataLoader<string, User>(async (userIds) => {
|
|
653
|
-
const users = await db.user.findMany({ where: { id: { in: [...userIds] }}})
|
|
654
|
-
return userIds.map(id => users.find(u => u.id === id) ?? new Error(`User ${id} not found`))
|
|
655
|
-
})
|
|
656
|
-
|
|
657
|
-
const resolvers = {
|
|
658
|
-
Transaction: {
|
|
659
|
-
user: (tx: Transaction) => userLoader.load(tx.userId), // Batched automatically
|
|
660
|
-
riskScore: async (tx: Transaction, _, { user }) => {
|
|
661
|
-
// Field-level auth — only admins see risk scores
|
|
662
|
-
if (!user.isAdmin) return null
|
|
663
|
-
return fraudService.getScore(tx.id)
|
|
664
|
-
}
|
|
665
|
-
}
|
|
666
|
-
}
|
|
667
|
-
|
|
668
|
-
// Persisted queries — prevent arbitrary query abuse in production
|
|
669
|
-
// Client sends query hash, not query string → server looks up allowed query
|
|
670
|
-
```
|
|
671
|
-
|
|
672
|
-
### GraphQL Security
|
|
673
|
-
|
|
674
|
-
```
|
|
675
|
-
Depth limiting: Max query depth = 10 (prevent deeply nested abuse queries)
|
|
676
|
-
Complexity limits: Assign cost to fields, reject queries over budget
|
|
677
|
-
Introspection: DISABLE in production (hides schema from attackers)
|
|
678
|
-
Rate limiting: Per-field and per-operation, not just per-request
|
|
679
|
-
Auth: Resolve auth in context (not in each resolver) — consistent
|
|
680
|
-
Field-level auth: Use @auth directive or resolver-level checks per field
|
|
681
|
-
Query allowlisting: Production uses persisted queries only
|
|
682
|
-
```
|
|
683
|
-
|
|
684
|
-
---
|
|
685
|
-
|
|
686
|
-
## gRPC — SERVICE-TO-SERVICE
|
|
687
|
-
|
|
688
|
-
```protobuf
|
|
689
|
-
// fraud.proto
|
|
690
|
-
syntax = "proto3";
|
|
691
|
-
package fraud.v1;
|
|
692
|
-
|
|
693
|
-
import "google/protobuf/timestamp.proto";
|
|
694
|
-
|
|
695
|
-
service FraudDetector {
|
|
696
|
-
rpc ScoreTransaction(ScoreRequest) returns (ScoreResponse);
|
|
697
|
-
rpc StreamAlerts(AlertStreamRequest) returns (stream FraudAlert); // Server streaming
|
|
698
|
-
rpc BatchScore(stream ScoreRequest) returns (stream ScoreResponse); // Bidirectional
|
|
699
|
-
}
|
|
700
|
-
|
|
701
|
-
message ScoreRequest {
|
|
702
|
-
string transaction_id = 1;
|
|
703
|
-
double amount = 2;
|
|
704
|
-
string currency = 3;
|
|
705
|
-
string user_id = 4;
|
|
706
|
-
google.protobuf.Timestamp created_at = 5;
|
|
707
|
-
map<string, string> metadata = 6;
|
|
708
|
-
}
|
|
709
|
-
|
|
710
|
-
message ScoreResponse {
|
|
711
|
-
string transaction_id = 1;
|
|
712
|
-
double risk_score = 2;
|
|
713
|
-
repeated string risk_factors = 3;
|
|
714
|
-
bool should_block = 4;
|
|
715
|
-
}
|
|
716
|
-
```
|
|
717
|
-
|
|
718
|
-
```typescript
|
|
719
|
-
// TypeScript gRPC server
|
|
720
|
-
import * as grpc from "@grpc/grpc-js";
|
|
721
|
-
import * as protoLoader from "@grpc/proto-loader";
|
|
722
|
-
|
|
723
|
-
const packageDef = protoLoader.loadSync("fraud.proto", { keepCase: true });
|
|
724
|
-
const fraudProto = grpc.loadPackageDefinition(packageDef).fraud.v1 as any;
|
|
725
|
-
|
|
726
|
-
const server = new grpc.Server();
|
|
727
|
-
server.addService(fraudProto.FraudDetector.service, {
|
|
728
|
-
async scoreTransaction(call: any, callback: any) {
|
|
729
|
-
const { transaction_id, amount, user_id } = call.request;
|
|
730
|
-
try {
|
|
731
|
-
const score = await fraudEngine.score({
|
|
732
|
-
transactionId: transaction_id,
|
|
733
|
-
amount,
|
|
734
|
-
userId: user_id,
|
|
735
|
-
});
|
|
736
|
-
callback(null, { transaction_id, risk_score: score.value, should_block: score.value > 0.9 });
|
|
737
|
-
} catch (err) {
|
|
738
|
-
callback({ code: grpc.status.INTERNAL, message: err.message });
|
|
739
|
-
}
|
|
740
|
-
},
|
|
741
|
-
});
|
|
742
|
-
|
|
743
|
-
// Interceptor for auth + logging (gRPC middleware equivalent)
|
|
744
|
-
server.addService(
|
|
745
|
-
fraudProto.FraudDetector.service,
|
|
746
|
-
withInterceptors([authInterceptor, loggingInterceptor, tracingInterceptor], handlers),
|
|
747
|
-
);
|
|
748
|
-
```
|
|
1
|
+
# Language Reference — Deep Patterns & Best Practices
|
|
2
|
+
|
|
3
|
+
## JAVA 21 (Current LTS)
|
|
4
|
+
|
|
5
|
+
### Modern Java Patterns
|
|
6
|
+
|
|
7
|
+
```java
|
|
8
|
+
// Records (replace Lombok @Data)
|
|
9
|
+
record TransactionDto(String id, BigDecimal amount, String currency, Instant createdAt) {}
|
|
10
|
+
|
|
11
|
+
// Sealed classes (exhaustive type hierarchies)
|
|
12
|
+
sealed interface PaymentResult permits PaymentSuccess, PaymentFailure, PaymentPending {}
|
|
13
|
+
record PaymentSuccess(String transactionId) implements PaymentResult {}
|
|
14
|
+
record PaymentFailure(String errorCode, String message) implements PaymentResult {}
|
|
15
|
+
|
|
16
|
+
// Pattern matching switch (exhaustive, compiler-checked)
|
|
17
|
+
String describe(PaymentResult result) {
|
|
18
|
+
return switch (result) {
|
|
19
|
+
case PaymentSuccess s -> "Approved: " + s.transactionId();
|
|
20
|
+
case PaymentFailure f -> "Declined: " + f.message();
|
|
21
|
+
case PaymentPending p -> "Processing";
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
// Virtual threads (Project Loom) — handle 1M+ concurrent connections
|
|
26
|
+
try (var executor = Executors.newVirtualThreadPerTaskExecutor()) {
|
|
27
|
+
IntStream.range(0, 100_000).forEach(i ->
|
|
28
|
+
executor.submit(() -> handleRequest(i))
|
|
29
|
+
);
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
// Text blocks
|
|
33
|
+
String json = """
|
|
34
|
+
{
|
|
35
|
+
"type": "fraud_detected",
|
|
36
|
+
"transactionId": "%s"
|
|
37
|
+
}
|
|
38
|
+
""".formatted(txId);
|
|
39
|
+
```
|
|
40
|
+
|
|
41
|
+
### Spring Boot 3.x Essentials
|
|
42
|
+
|
|
43
|
+
```java
|
|
44
|
+
// Minimal REST controller
|
|
45
|
+
@RestController @RequestMapping("/api/v1/transactions")
|
|
46
|
+
@RequiredArgsConstructor
|
|
47
|
+
public class TransactionController {
|
|
48
|
+
private final TransactionService service;
|
|
49
|
+
|
|
50
|
+
@GetMapping
|
|
51
|
+
public Page<TransactionDto> list(
|
|
52
|
+
@AuthenticationPrincipal UserDetails user,
|
|
53
|
+
@RequestParam(defaultValue = "0") int page,
|
|
54
|
+
@RequestParam(defaultValue = "20") int size
|
|
55
|
+
) {
|
|
56
|
+
return service.findByUser(user.getUsername(), PageRequest.of(page, size));
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
@PostMapping
|
|
60
|
+
@ResponseStatus(HttpStatus.CREATED)
|
|
61
|
+
public TransactionDto create(@Valid @RequestBody CreateTransactionRequest req,
|
|
62
|
+
@AuthenticationPrincipal UserDetails user) {
|
|
63
|
+
return service.create(req, user.getUsername());
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
// Global exception handler
|
|
68
|
+
@RestControllerAdvice
|
|
69
|
+
public class GlobalExceptionHandler {
|
|
70
|
+
@ExceptionHandler(NotFoundException.class)
|
|
71
|
+
@ResponseStatus(HttpStatus.NOT_FOUND)
|
|
72
|
+
public ProblemDetail handleNotFound(NotFoundException ex) {
|
|
73
|
+
return ProblemDetail.forStatusAndDetail(HttpStatus.NOT_FOUND, ex.getMessage());
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
```
|
|
77
|
+
|
|
78
|
+
### Java Pitfalls
|
|
79
|
+
|
|
80
|
+
```
|
|
81
|
+
BigDecimal for money: NEVER double/float. new BigDecimal("19.99") not new BigDecimal(19.99)
|
|
82
|
+
Optional correctly: Never as method param. Never .get() without .isPresent(). Use .orElseThrow()
|
|
83
|
+
String concatenation: StringBuilder in loops. Never "str" + var in loop body.
|
|
84
|
+
equals/hashCode: Always override together. Records do this automatically.
|
|
85
|
+
Static analysis: SpotBugs + CheckStyle + SonarQube — run in CI.
|
|
86
|
+
```
|
|
87
|
+
|
|
88
|
+
---
|
|
89
|
+
|
|
90
|
+
## PYTHON 3.12+
|
|
91
|
+
|
|
92
|
+
### Modern Python Patterns
|
|
93
|
+
|
|
94
|
+
```python
|
|
95
|
+
from __future__ import annotations
|
|
96
|
+
from typing import TypeVar, Generic
|
|
97
|
+
from dataclasses import dataclass, field
|
|
98
|
+
from datetime import datetime
|
|
99
|
+
import asyncio
|
|
100
|
+
|
|
101
|
+
# Dataclasses (not dicts for structured data)
|
|
102
|
+
@dataclass(frozen=True, slots=True) # frozen=immutable, slots=memory-efficient
|
|
103
|
+
class Transaction:
|
|
104
|
+
id: str
|
|
105
|
+
amount: Decimal
|
|
106
|
+
currency: str
|
|
107
|
+
created_at: datetime = field(default_factory=datetime.utcnow)
|
|
108
|
+
|
|
109
|
+
# Type aliases and generics
|
|
110
|
+
type UserId = str
|
|
111
|
+
type TransactionId = str
|
|
112
|
+
|
|
113
|
+
# Structural pattern matching (3.10+)
|
|
114
|
+
match result:
|
|
115
|
+
case {"status": "success", "data": data}:
|
|
116
|
+
process(data)
|
|
117
|
+
case {"status": "error", "code": code} if code >= 500:
|
|
118
|
+
alert_team(code)
|
|
119
|
+
case _:
|
|
120
|
+
log_unknown(result)
|
|
121
|
+
|
|
122
|
+
# Async patterns (always use async for I/O)
|
|
123
|
+
async def fetch_fraud_signals(tx_ids: list[str]) -> dict[str, float]:
|
|
124
|
+
async with aiohttp.ClientSession() as session:
|
|
125
|
+
tasks = [fetch_signal(session, tx_id) for tx_id in tx_ids]
|
|
126
|
+
results = await asyncio.gather(*tasks, return_exceptions=True)
|
|
127
|
+
return {
|
|
128
|
+
tx_id: score
|
|
129
|
+
for tx_id, score in zip(tx_ids, results)
|
|
130
|
+
if not isinstance(score, Exception)
|
|
131
|
+
}
|
|
132
|
+
```
|
|
133
|
+
|
|
134
|
+
### FastAPI (Production Patterns)
|
|
135
|
+
|
|
136
|
+
```python
|
|
137
|
+
from fastapi import FastAPI, Depends, HTTPException, status
|
|
138
|
+
from fastapi.middleware.cors import CORSMiddleware
|
|
139
|
+
from contextlib import asynccontextmanager
|
|
140
|
+
|
|
141
|
+
@asynccontextmanager
|
|
142
|
+
async def lifespan(app: FastAPI):
|
|
143
|
+
# Startup
|
|
144
|
+
await db.connect()
|
|
145
|
+
await redis.ping()
|
|
146
|
+
yield
|
|
147
|
+
# Shutdown
|
|
148
|
+
await db.disconnect()
|
|
149
|
+
await redis.aclose()
|
|
150
|
+
|
|
151
|
+
app = FastAPI(lifespan=lifespan)
|
|
152
|
+
|
|
153
|
+
# Dependency injection
|
|
154
|
+
async def get_current_user(token: str = Depends(oauth2_scheme), db = Depends(get_db)):
|
|
155
|
+
payload = verify_jwt(token)
|
|
156
|
+
user = await db.users.get(payload["sub"])
|
|
157
|
+
if not user:
|
|
158
|
+
raise HTTPException(status.HTTP_401_UNAUTHORIZED)
|
|
159
|
+
return user
|
|
160
|
+
|
|
161
|
+
@app.get("/transactions", response_model=Page[TransactionResponse])
|
|
162
|
+
async def list_transactions(
|
|
163
|
+
page: int = Query(1, ge=1),
|
|
164
|
+
limit: int = Query(20, le=100),
|
|
165
|
+
current_user: User = Depends(get_current_user),
|
|
166
|
+
db: AsyncSession = Depends(get_db)
|
|
167
|
+
):
|
|
168
|
+
return await transaction_service.paginate(db, current_user.id, page, limit)
|
|
169
|
+
```
|
|
170
|
+
|
|
171
|
+
### Python Pitfalls
|
|
172
|
+
|
|
173
|
+
```python
|
|
174
|
+
# Mutable default args — classic bug
|
|
175
|
+
def bad(items=[]): items.append(1); return items # SAME list across calls
|
|
176
|
+
def good(items=None): items = items or []; items.append(1); return items
|
|
177
|
+
|
|
178
|
+
# Late binding closures
|
|
179
|
+
# bad: all lambdas capture same i
|
|
180
|
+
funcs = [lambda: i for i in range(3)] # all return 2
|
|
181
|
+
# good: capture by value
|
|
182
|
+
funcs = [lambda i=i: i for i in range(3)] # 0, 1, 2
|
|
183
|
+
|
|
184
|
+
# Blocking in async — kills performance
|
|
185
|
+
async def bad(): time.sleep(1) # blocks entire event loop
|
|
186
|
+
async def good(): await asyncio.sleep(1) # yields to other coroutines
|
|
187
|
+
|
|
188
|
+
# String formatting — always f-strings (fastest)
|
|
189
|
+
name = "World"
|
|
190
|
+
bad = "Hello, " + name # concatenation
|
|
191
|
+
bad = "Hello, %s" % name # old style
|
|
192
|
+
good = f"Hello, {name}" # f-strings — fastest, most readable
|
|
193
|
+
```
|
|
194
|
+
|
|
195
|
+
---
|
|
196
|
+
|
|
197
|
+
## TYPESCRIPT (Strict Mode Always)
|
|
198
|
+
|
|
199
|
+
### Type System Mastery
|
|
200
|
+
|
|
201
|
+
```typescript
|
|
202
|
+
// Discriminated unions — exhaustive pattern matching
|
|
203
|
+
type Result<T, E = Error> = { ok: true; value: T } | { ok: false; error: E };
|
|
204
|
+
|
|
205
|
+
function divide(a: number, b: number): Result<number> {
|
|
206
|
+
if (b === 0) return { ok: false, error: new Error("Division by zero") };
|
|
207
|
+
return { ok: true, value: a / b };
|
|
208
|
+
}
|
|
209
|
+
|
|
210
|
+
// Template literal types — type-safe event names
|
|
211
|
+
type EventName = `${string}.created` | `${string}.updated` | `${string}.deleted`;
|
|
212
|
+
type UserEvent = `user.${"created" | "updated" | "deleted"}`;
|
|
213
|
+
|
|
214
|
+
// Conditional types — advanced type transformations
|
|
215
|
+
type NonNullable<T> = T extends null | undefined ? never : T;
|
|
216
|
+
type ReturnType<T> = T extends (...args: any[]) => infer R ? R : never;
|
|
217
|
+
type Awaited<T> = T extends Promise<infer U> ? Awaited<U> : T;
|
|
218
|
+
|
|
219
|
+
// Branded types — prevent primitive obsession
|
|
220
|
+
type UserId = string & { readonly _brand: "UserId" };
|
|
221
|
+
type Amount = number & { readonly _brand: "Amount" };
|
|
222
|
+
const userId = "abc-123" as UserId; // explicit cast required
|
|
223
|
+
function getUser(id: UserId) {} // compiler prevents passing arbitrary string
|
|
224
|
+
|
|
225
|
+
// Satisfies operator (4.9+) — check type without widening
|
|
226
|
+
const config = {
|
|
227
|
+
db: { host: "localhost", port: 5432 },
|
|
228
|
+
redis: { host: "localhost", port: 6379 },
|
|
229
|
+
} satisfies Record<string, { host: string; port: number }>;
|
|
230
|
+
// config.db.host is still string literal type (not widened to string)
|
|
231
|
+
```
|
|
232
|
+
|
|
233
|
+
### Next.js 14 App Router Patterns
|
|
234
|
+
|
|
235
|
+
```typescript
|
|
236
|
+
// Server component (default — zero JS sent to client)
|
|
237
|
+
async function TransactionList({ userId }: { userId: string }) {
|
|
238
|
+
const transactions = await db.transaction.findMany({ where: { userId } })
|
|
239
|
+
return <ul>{transactions.map(tx => <TransactionItem key={tx.id} tx={tx} />)}</ul>
|
|
240
|
+
}
|
|
241
|
+
|
|
242
|
+
// Server action (form mutation without API route)
|
|
243
|
+
async function createTransaction(formData: FormData) {
|
|
244
|
+
'use server'
|
|
245
|
+
const amount = formData.get('amount') as string
|
|
246
|
+
await db.transaction.create({ data: { amount: parseFloat(amount), userId: await getUserId() }})
|
|
247
|
+
revalidatePath('/dashboard')
|
|
248
|
+
}
|
|
249
|
+
|
|
250
|
+
// Route handler with proper error handling
|
|
251
|
+
export async function POST(request: Request) {
|
|
252
|
+
try {
|
|
253
|
+
const body = await request.json()
|
|
254
|
+
const validated = schema.parse(body) // Zod validation
|
|
255
|
+
const result = await service.create(validated)
|
|
256
|
+
return Response.json(result, { status: 201 })
|
|
257
|
+
} catch (err) {
|
|
258
|
+
if (err instanceof ZodError) {
|
|
259
|
+
return Response.json({ error: err.errors }, { status: 400 })
|
|
260
|
+
}
|
|
261
|
+
return Response.json({ error: 'Internal error' }, { status: 500 })
|
|
262
|
+
}
|
|
263
|
+
}
|
|
264
|
+
```
|
|
265
|
+
|
|
266
|
+
---
|
|
267
|
+
|
|
268
|
+
## GO 1.22+
|
|
269
|
+
|
|
270
|
+
### Production Patterns
|
|
271
|
+
|
|
272
|
+
```go
|
|
273
|
+
// Error handling — always explicit, never ignore
|
|
274
|
+
func getUser(ctx context.Context, id string) (*User, error) {
|
|
275
|
+
user, err := db.QueryRowContext(ctx, "SELECT * FROM users WHERE id = $1", id).Scan(&user)
|
|
276
|
+
if err != nil {
|
|
277
|
+
if errors.Is(err, sql.ErrNoRows) {
|
|
278
|
+
return nil, fmt.Errorf("user %s: %w", id, ErrNotFound) // wrap for context
|
|
279
|
+
}
|
|
280
|
+
return nil, fmt.Errorf("query user %s: %w", id, err)
|
|
281
|
+
}
|
|
282
|
+
return user, nil
|
|
283
|
+
}
|
|
284
|
+
|
|
285
|
+
// Context propagation — always pass ctx as first param
|
|
286
|
+
func (s *Service) ProcessTransaction(ctx context.Context, req Request) (*Response, error) {
|
|
287
|
+
ctx, cancel := context.WithTimeout(ctx, 5*time.Second)
|
|
288
|
+
defer cancel()
|
|
289
|
+
// All downstream calls use this ctx — cancellation propagates automatically
|
|
290
|
+
return s.repo.Create(ctx, req)
|
|
291
|
+
}
|
|
292
|
+
|
|
293
|
+
// Goroutine leak prevention — always use errgroup or WaitGroup
|
|
294
|
+
func fetchAll(ctx context.Context, ids []string) ([]Result, error) {
|
|
295
|
+
g, ctx := errgroup.WithContext(ctx)
|
|
296
|
+
results := make([]Result, len(ids))
|
|
297
|
+
for i, id := range ids {
|
|
298
|
+
i, id := i, id // capture loop vars
|
|
299
|
+
g.Go(func() error {
|
|
300
|
+
result, err := fetch(ctx, id)
|
|
301
|
+
if err != nil { return err }
|
|
302
|
+
results[i] = result
|
|
303
|
+
return nil
|
|
304
|
+
})
|
|
305
|
+
}
|
|
306
|
+
return results, g.Wait()
|
|
307
|
+
}
|
|
308
|
+
|
|
309
|
+
// Struct embedding for interfaces
|
|
310
|
+
type Service struct {
|
|
311
|
+
db *sql.DB
|
|
312
|
+
cache Cache // interface — easy to mock in tests
|
|
313
|
+
logger *slog.Logger // structured logging — use slog (stdlib since 1.21)
|
|
314
|
+
}
|
|
315
|
+
```
|
|
316
|
+
|
|
317
|
+
### Go Pitfalls
|
|
318
|
+
|
|
319
|
+
```
|
|
320
|
+
Goroutine leaks: Always defer cancel() after context.WithTimeout/WithCancel
|
|
321
|
+
Slice gotchas: append may or may not create new backing array — use copy() when in doubt
|
|
322
|
+
Interface nil: var err *MyError = nil; var i error = err; i != nil is TRUE (interface type != nil)
|
|
323
|
+
Map not safe: sync.Map or mutex for concurrent map access
|
|
324
|
+
String conversion: []byte(str) copies — use unsafe.Slice for zero-copy in hot paths
|
|
325
|
+
```
|
|
326
|
+
|
|
327
|
+
---
|
|
328
|
+
|
|
329
|
+
## RUST (2021 Edition)
|
|
330
|
+
|
|
331
|
+
### Core Patterns
|
|
332
|
+
|
|
333
|
+
```rust
|
|
334
|
+
// Result and Option — no null pointer exceptions, ever
|
|
335
|
+
fn parse_amount(s: &str) -> Result<f64, ParseError> {
|
|
336
|
+
s.trim().parse::<f64>().map_err(|e| ParseError::InvalidAmount(e.to_string()))
|
|
337
|
+
}
|
|
338
|
+
|
|
339
|
+
// Ownership-safe shared state
|
|
340
|
+
use std::sync::{Arc, RwLock};
|
|
341
|
+
#[derive(Clone)]
|
|
342
|
+
struct AppState { db: Arc<Pool<Postgres>>, cache: Arc<RwLock<HashMap<String, Value>>> }
|
|
343
|
+
|
|
344
|
+
// Axum web handler (async, zero-cost)
|
|
345
|
+
async fn create_transaction(
|
|
346
|
+
State(state): State<AppState>,
|
|
347
|
+
Json(payload): Json<CreateRequest>,
|
|
348
|
+
) -> Result<Json<Transaction>, AppError> {
|
|
349
|
+
let tx = sqlx::query_as::<_, Transaction>("INSERT INTO transactions ...")
|
|
350
|
+
.bind(&payload.amount)
|
|
351
|
+
.fetch_one(&*state.db)
|
|
352
|
+
.await?;
|
|
353
|
+
Ok(Json(tx))
|
|
354
|
+
}
|
|
355
|
+
|
|
356
|
+
// Traits for behavior abstraction
|
|
357
|
+
trait FraudDetector: Send + Sync {
|
|
358
|
+
async fn score(&self, tx: &Transaction) -> Result<f64, Error>;
|
|
359
|
+
}
|
|
360
|
+
```
|
|
361
|
+
|
|
362
|
+
---
|
|
363
|
+
|
|
364
|
+
## SQL — PRODUCTION PATTERNS
|
|
365
|
+
|
|
366
|
+
### Query Optimization
|
|
367
|
+
|
|
368
|
+
```sql
|
|
369
|
+
-- EXPLAIN ANALYZE every new query in production
|
|
370
|
+
EXPLAIN (ANALYZE, BUFFERS, FORMAT TEXT)
|
|
371
|
+
SELECT * FROM transactions WHERE user_id = $1 AND created_at > $2;
|
|
372
|
+
|
|
373
|
+
-- Index design rules:
|
|
374
|
+
-- 1. Index columns used in WHERE, JOIN ON, ORDER BY
|
|
375
|
+
-- 2. Composite index: put highest-selectivity column first
|
|
376
|
+
-- 3. Partial index for filtered queries:
|
|
377
|
+
CREATE INDEX idx_pending_transactions ON transactions (created_at)
|
|
378
|
+
WHERE status = 'pending'; -- Only indexes pending rows
|
|
379
|
+
|
|
380
|
+
-- 4. Index for LIKE prefix search:
|
|
381
|
+
CREATE INDEX idx_email_prefix ON users (email text_pattern_ops);
|
|
382
|
+
-- Supports: WHERE email LIKE 'user@%'
|
|
383
|
+
|
|
384
|
+
-- Avoid N+1: use JOIN or subquery instead
|
|
385
|
+
-- BAD (N+1):
|
|
386
|
+
SELECT * FROM orders; -- then for each order:
|
|
387
|
+
SELECT * FROM order_items WHERE order_id = $1;
|
|
388
|
+
|
|
389
|
+
-- GOOD (1 query):
|
|
390
|
+
SELECT o.*, json_agg(i.*) as items
|
|
391
|
+
FROM orders o
|
|
392
|
+
LEFT JOIN order_items i ON i.order_id = o.id
|
|
393
|
+
WHERE o.user_id = $1
|
|
394
|
+
GROUP BY o.id;
|
|
395
|
+
```
|
|
396
|
+
|
|
397
|
+
### PostgreSQL Power Features
|
|
398
|
+
|
|
399
|
+
```sql
|
|
400
|
+
-- Row-level security (multi-tenant isolation)
|
|
401
|
+
ALTER TABLE transactions ENABLE ROW LEVEL SECURITY;
|
|
402
|
+
CREATE POLICY tenant_isolation ON transactions
|
|
403
|
+
USING (org_id = current_setting('app.current_org_id')::uuid);
|
|
404
|
+
|
|
405
|
+
-- JSONB for flexible metadata (indexed)
|
|
406
|
+
ALTER TABLE transactions ADD COLUMN metadata JSONB DEFAULT '{}';
|
|
407
|
+
CREATE INDEX idx_tx_metadata_gin ON transactions USING gin(metadata);
|
|
408
|
+
-- Query: WHERE metadata @> '{"source": "mobile"}'
|
|
409
|
+
|
|
410
|
+
-- Window functions (analytics without GROUP BY collapse)
|
|
411
|
+
SELECT
|
|
412
|
+
user_id,
|
|
413
|
+
amount,
|
|
414
|
+
SUM(amount) OVER (PARTITION BY user_id ORDER BY created_at) as running_total,
|
|
415
|
+
ROW_NUMBER() OVER (PARTITION BY user_id ORDER BY created_at DESC) as rn
|
|
416
|
+
FROM transactions;
|
|
417
|
+
|
|
418
|
+
-- CTEs for readability (optimizer inlines them in PG 12+)
|
|
419
|
+
WITH high_risk AS (
|
|
420
|
+
SELECT user_id, COUNT(*) as flagged_count
|
|
421
|
+
FROM transactions WHERE risk_score > 0.8
|
|
422
|
+
GROUP BY user_id HAVING COUNT(*) > 3
|
|
423
|
+
)
|
|
424
|
+
SELECT u.email, h.flagged_count
|
|
425
|
+
FROM users u JOIN high_risk h USING (user_id);
|
|
426
|
+
|
|
427
|
+
-- Advisory locks for distributed mutex (no external Redis needed for simple cases)
|
|
428
|
+
SELECT pg_advisory_lock(hashtext('process-transaction-' || transaction_id));
|
|
429
|
+
-- ... do work ...
|
|
430
|
+
SELECT pg_advisory_unlock(hashtext('process-transaction-' || transaction_id));
|
|
431
|
+
```
|
|
432
|
+
|
|
433
|
+
---
|
|
434
|
+
|
|
435
|
+
## BASH — PRODUCTION SCRIPTS
|
|
436
|
+
|
|
437
|
+
```bash
|
|
438
|
+
#!/usr/bin/env bash
|
|
439
|
+
set -euo pipefail # e=exit on error, u=error on unset vars, o pipefail=pipe errors propagate
|
|
440
|
+
IFS=$'\n\t' # Safer word splitting
|
|
441
|
+
|
|
442
|
+
# Always quote variables
|
|
443
|
+
file="${1:-}"
|
|
444
|
+
if [[ -z "$file" ]]; then
|
|
445
|
+
echo "Usage: $0 <filename>" >&2
|
|
446
|
+
exit 1
|
|
447
|
+
fi
|
|
448
|
+
|
|
449
|
+
# Functions for reuse
|
|
450
|
+
log() { echo "[$(date -u +%Y-%m-%dT%H:%M:%SZ)] $*" >&2; }
|
|
451
|
+
die() { log "ERROR: $*"; exit 1; }
|
|
452
|
+
|
|
453
|
+
# Trap for cleanup
|
|
454
|
+
tmp_dir=$(mktemp -d)
|
|
455
|
+
trap 'rm -rf "$tmp_dir"' EXIT
|
|
456
|
+
|
|
457
|
+
# Check dependencies
|
|
458
|
+
command -v jq >/dev/null || die "jq is required but not installed"
|
|
459
|
+
command -v gcloud >/dev/null || die "gcloud is required but not installed"
|
|
460
|
+
|
|
461
|
+
# Process with error handling
|
|
462
|
+
if ! result=$(some_command 2>&1); then
|
|
463
|
+
die "Command failed: $result"
|
|
464
|
+
fi
|
|
465
|
+
|
|
466
|
+
log "Completed successfully"
|
|
467
|
+
```
|
|
468
|
+
|
|
469
|
+
---
|
|
470
|
+
|
|
471
|
+
## ELIXIR / ERLANG (Real-Time Systems)
|
|
472
|
+
|
|
473
|
+
```elixir
|
|
474
|
+
# Phoenix LiveView — real-time UI without JS complexity
|
|
475
|
+
defmodule FraudDashboardLive do
|
|
476
|
+
use Phoenix.LiveView
|
|
477
|
+
|
|
478
|
+
def mount(_params, _session, socket) do
|
|
479
|
+
if connected?(socket), do: Phoenix.PubSub.subscribe(App.PubSub, "fraud_alerts")
|
|
480
|
+
{:ok, assign(socket, alerts: load_recent_alerts())}
|
|
481
|
+
end
|
|
482
|
+
|
|
483
|
+
# Handles real-time messages from PubSub
|
|
484
|
+
def handle_info({:new_alert, alert}, socket) do
|
|
485
|
+
{:noreply, update(socket, :alerts, &[alert | &1])}
|
|
486
|
+
end
|
|
487
|
+
end
|
|
488
|
+
```
|
|
489
|
+
|
|
490
|
+
Use Elixir when: real-time features (chat, live dashboards, presence), high-concurrency (millions of connections), fault-tolerant distributed systems, IoT backends.
|
|
491
|
+
|
|
492
|
+
---
|
|
493
|
+
|
|
494
|
+
## WEBASSEMBLY (WASM)
|
|
495
|
+
|
|
496
|
+
Modern use cases:
|
|
497
|
+
|
|
498
|
+
- Run CPU-intensive code in the browser (image processing, crypto, compression)
|
|
499
|
+
- Compile Rust/C/C++ to WASM for near-native browser performance
|
|
500
|
+
- WASI for server-side sandboxed plugins
|
|
501
|
+
|
|
502
|
+
```rust
|
|
503
|
+
// Rust → WASM via wasm-pack
|
|
504
|
+
use wasm_bindgen::prelude::*;
|
|
505
|
+
|
|
506
|
+
#[wasm_bindgen]
|
|
507
|
+
pub fn process_transactions(data: &[u8]) -> Vec<u8> {
|
|
508
|
+
// CPU-intensive processing — runs in browser at near-native speed
|
|
509
|
+
let transactions: Vec<Transaction> = serde_json::from_slice(data).unwrap();
|
|
510
|
+
let results = transactions.iter().map(score_transaction).collect::<Vec<_>>();
|
|
511
|
+
serde_json::to_vec(&results).unwrap()
|
|
512
|
+
}
|
|
513
|
+
```
|
|
514
|
+
|
|
515
|
+
---
|
|
516
|
+
|
|
517
|
+
## DART (Flutter)
|
|
518
|
+
|
|
519
|
+
```dart
|
|
520
|
+
// Null safety — always enabled (Dart 3+)
|
|
521
|
+
String? maybeNull = null;
|
|
522
|
+
String definitelyNotNull = maybeNull ?? 'default';
|
|
523
|
+
String guaranteed = maybeNull!; // throws if null — use sparingly
|
|
524
|
+
|
|
525
|
+
// Records (Dart 3) — lightweight data structures
|
|
526
|
+
(String name, int age) person = ('<user>', 40);
|
|
527
|
+
print(person.$1); // '<user>'
|
|
528
|
+
|
|
529
|
+
// Sealed classes — exhaustive pattern matching
|
|
530
|
+
sealed class PaymentResult {}
|
|
531
|
+
class Success extends PaymentResult { final String txId; Success(this.txId); }
|
|
532
|
+
class Failure extends PaymentResult { final String error; Failure(this.error); }
|
|
533
|
+
|
|
534
|
+
String describe(PaymentResult r) => switch(r) {
|
|
535
|
+
Success s => 'OK: ${s.txId}',
|
|
536
|
+
Failure f => 'Error: ${f.error}',
|
|
537
|
+
}; // Compiler error if not exhaustive
|
|
538
|
+
|
|
539
|
+
// Async/await — same as JS/TS
|
|
540
|
+
Future<List<Transaction>> fetchTransactions(String userId) async {
|
|
541
|
+
final response = await http.get(Uri.parse('$baseUrl/transactions?userId=$userId'));
|
|
542
|
+
if (response.statusCode != 200) throw ApiException(response.statusCode);
|
|
543
|
+
return (jsonDecode(response.body) as List)
|
|
544
|
+
.map((e) => Transaction.fromJson(e))
|
|
545
|
+
.toList();
|
|
546
|
+
}
|
|
547
|
+
|
|
548
|
+
// Streams — reactive data
|
|
549
|
+
Stream<int> countUp(int max) async* {
|
|
550
|
+
for (var i = 0; i < max; i++) {
|
|
551
|
+
await Future.delayed(const Duration(seconds: 1));
|
|
552
|
+
yield i;
|
|
553
|
+
}
|
|
554
|
+
}
|
|
555
|
+
```
|
|
556
|
+
|
|
557
|
+
---
|
|
558
|
+
|
|
559
|
+
## SOLIDITY (Smart Contracts / Web3)
|
|
560
|
+
|
|
561
|
+
```solidity
|
|
562
|
+
// SPDX-License-Identifier: MIT
|
|
563
|
+
pragma solidity ^0.8.24;
|
|
564
|
+
|
|
565
|
+
import "@openzeppelin/contracts/token/ERC20/ERC20.sol";
|
|
566
|
+
import "@openzeppelin/contracts/access/Ownable.sol";
|
|
567
|
+
import "@openzeppelin/contracts/utils/ReentrancyGuard.sol";
|
|
568
|
+
|
|
569
|
+
// Security patterns — ALWAYS use these in production contracts
|
|
570
|
+
contract SecureToken is ERC20, Ownable, ReentrancyGuard {
|
|
571
|
+
uint256 public constant MAX_SUPPLY = 1_000_000 * 10**18;
|
|
572
|
+
mapping(address => bool) public blacklisted;
|
|
573
|
+
|
|
574
|
+
event Blacklisted(address indexed account);
|
|
575
|
+
|
|
576
|
+
constructor() ERC20("MyToken", "MTK") Ownable(msg.sender) {}
|
|
577
|
+
|
|
578
|
+
// Checks-Effects-Interactions pattern (prevent reentrancy)
|
|
579
|
+
function mint(address to, uint256 amount) external onlyOwner nonReentrant {
|
|
580
|
+
require(!blacklisted[to], "Blacklisted address"); // CHECK
|
|
581
|
+
require(totalSupply() + amount <= MAX_SUPPLY, "Exceeds max supply"); // CHECK
|
|
582
|
+
_mint(to, amount); // EFFECT (state change)
|
|
583
|
+
// No external calls after state changes (prevent reentrancy)
|
|
584
|
+
}
|
|
585
|
+
|
|
586
|
+
// Custom errors (cheaper than strings — Solidity 0.8+)
|
|
587
|
+
error Unauthorized(address caller);
|
|
588
|
+
error InsufficientBalance(uint256 available, uint256 required);
|
|
589
|
+
|
|
590
|
+
function _update(address from, address to, uint256 value)
|
|
591
|
+
internal override
|
|
592
|
+
{
|
|
593
|
+
if (blacklisted[from] || blacklisted[to]) revert Unauthorized(from);
|
|
594
|
+
super._update(from, to, value);
|
|
595
|
+
}
|
|
596
|
+
}
|
|
597
|
+
```
|
|
598
|
+
|
|
599
|
+
**Solidity Security Checklist:**
|
|
600
|
+
|
|
601
|
+
```
|
|
602
|
+
□ Reentrancy: ReentrancyGuard on all state-changing external calls
|
|
603
|
+
□ Integer overflow: Solidity 0.8+ has built-in. Use SafeMath only for older.
|
|
604
|
+
□ Access control: OpenZeppelin Ownable/AccessControl. Never trust msg.sender without check.
|
|
605
|
+
□ Oracle manipulation: Never use single oracle (Chainlink preferred, time-weighted for DEX)
|
|
606
|
+
□ Front-running: Commit-reveal scheme for sensitive operations
|
|
607
|
+
□ Audit: ALWAYS audit before mainnet. CertiK, Trail of Bits, OpenZeppelin audits.
|
|
608
|
+
□ Testing: Hardhat + Foundry. 100% branch coverage. Fuzzing required.
|
|
609
|
+
□ Upgrades: Proxy pattern (OpenZeppelin UUPS/Transparent) with timelocks
|
|
610
|
+
```
|
|
611
|
+
|
|
612
|
+
---
|
|
613
|
+
|
|
614
|
+
## GRAPHQL — PRODUCTION PATTERNS
|
|
615
|
+
|
|
616
|
+
```typescript
|
|
617
|
+
// Schema-first design (use SDL, not code-first for large schemas)
|
|
618
|
+
// schema.graphql
|
|
619
|
+
type Transaction {
|
|
620
|
+
id: ID!
|
|
621
|
+
amount: Float!
|
|
622
|
+
currency: String!
|
|
623
|
+
status: TransactionStatus!
|
|
624
|
+
user: User!
|
|
625
|
+
riskScore: Float
|
|
626
|
+
createdAt: DateTime!
|
|
627
|
+
}
|
|
628
|
+
|
|
629
|
+
enum TransactionStatus { PENDING COMPLETED FAILED REFUNDED }
|
|
630
|
+
|
|
631
|
+
type Query {
|
|
632
|
+
transaction(id: ID!): Transaction
|
|
633
|
+
transactions(
|
|
634
|
+
filter: TransactionFilter
|
|
635
|
+
first: Int = 20
|
|
636
|
+
after: String # Cursor-based pagination
|
|
637
|
+
): TransactionConnection!
|
|
638
|
+
}
|
|
639
|
+
|
|
640
|
+
type Mutation {
|
|
641
|
+
createTransaction(input: CreateTransactionInput!): TransactionResult!
|
|
642
|
+
}
|
|
643
|
+
|
|
644
|
+
type Subscription {
|
|
645
|
+
transactionUpdated(orgId: ID!): Transaction! # Real-time updates
|
|
646
|
+
}
|
|
647
|
+
|
|
648
|
+
# --- Resolver (TypeScript with DataLoader) ---
|
|
649
|
+
import DataLoader from 'dataloader'
|
|
650
|
+
|
|
651
|
+
// N+1 problem solution — batch all user lookups into one query
|
|
652
|
+
const userLoader = new DataLoader<string, User>(async (userIds) => {
|
|
653
|
+
const users = await db.user.findMany({ where: { id: { in: [...userIds] }}})
|
|
654
|
+
return userIds.map(id => users.find(u => u.id === id) ?? new Error(`User ${id} not found`))
|
|
655
|
+
})
|
|
656
|
+
|
|
657
|
+
const resolvers = {
|
|
658
|
+
Transaction: {
|
|
659
|
+
user: (tx: Transaction) => userLoader.load(tx.userId), // Batched automatically
|
|
660
|
+
riskScore: async (tx: Transaction, _, { user }) => {
|
|
661
|
+
// Field-level auth — only admins see risk scores
|
|
662
|
+
if (!user.isAdmin) return null
|
|
663
|
+
return fraudService.getScore(tx.id)
|
|
664
|
+
}
|
|
665
|
+
}
|
|
666
|
+
}
|
|
667
|
+
|
|
668
|
+
// Persisted queries — prevent arbitrary query abuse in production
|
|
669
|
+
// Client sends query hash, not query string → server looks up allowed query
|
|
670
|
+
```
|
|
671
|
+
|
|
672
|
+
### GraphQL Security
|
|
673
|
+
|
|
674
|
+
```
|
|
675
|
+
Depth limiting: Max query depth = 10 (prevent deeply nested abuse queries)
|
|
676
|
+
Complexity limits: Assign cost to fields, reject queries over budget
|
|
677
|
+
Introspection: DISABLE in production (hides schema from attackers)
|
|
678
|
+
Rate limiting: Per-field and per-operation, not just per-request
|
|
679
|
+
Auth: Resolve auth in context (not in each resolver) — consistent
|
|
680
|
+
Field-level auth: Use @auth directive or resolver-level checks per field
|
|
681
|
+
Query allowlisting: Production uses persisted queries only
|
|
682
|
+
```
|
|
683
|
+
|
|
684
|
+
---
|
|
685
|
+
|
|
686
|
+
## gRPC — SERVICE-TO-SERVICE
|
|
687
|
+
|
|
688
|
+
```protobuf
|
|
689
|
+
// fraud.proto
|
|
690
|
+
syntax = "proto3";
|
|
691
|
+
package fraud.v1;
|
|
692
|
+
|
|
693
|
+
import "google/protobuf/timestamp.proto";
|
|
694
|
+
|
|
695
|
+
service FraudDetector {
|
|
696
|
+
rpc ScoreTransaction(ScoreRequest) returns (ScoreResponse);
|
|
697
|
+
rpc StreamAlerts(AlertStreamRequest) returns (stream FraudAlert); // Server streaming
|
|
698
|
+
rpc BatchScore(stream ScoreRequest) returns (stream ScoreResponse); // Bidirectional
|
|
699
|
+
}
|
|
700
|
+
|
|
701
|
+
message ScoreRequest {
|
|
702
|
+
string transaction_id = 1;
|
|
703
|
+
double amount = 2;
|
|
704
|
+
string currency = 3;
|
|
705
|
+
string user_id = 4;
|
|
706
|
+
google.protobuf.Timestamp created_at = 5;
|
|
707
|
+
map<string, string> metadata = 6;
|
|
708
|
+
}
|
|
709
|
+
|
|
710
|
+
message ScoreResponse {
|
|
711
|
+
string transaction_id = 1;
|
|
712
|
+
double risk_score = 2;
|
|
713
|
+
repeated string risk_factors = 3;
|
|
714
|
+
bool should_block = 4;
|
|
715
|
+
}
|
|
716
|
+
```
|
|
717
|
+
|
|
718
|
+
```typescript
|
|
719
|
+
// TypeScript gRPC server
|
|
720
|
+
import * as grpc from "@grpc/grpc-js";
|
|
721
|
+
import * as protoLoader from "@grpc/proto-loader";
|
|
722
|
+
|
|
723
|
+
const packageDef = protoLoader.loadSync("fraud.proto", { keepCase: true });
|
|
724
|
+
const fraudProto = grpc.loadPackageDefinition(packageDef).fraud.v1 as any;
|
|
725
|
+
|
|
726
|
+
const server = new grpc.Server();
|
|
727
|
+
server.addService(fraudProto.FraudDetector.service, {
|
|
728
|
+
async scoreTransaction(call: any, callback: any) {
|
|
729
|
+
const { transaction_id, amount, user_id } = call.request;
|
|
730
|
+
try {
|
|
731
|
+
const score = await fraudEngine.score({
|
|
732
|
+
transactionId: transaction_id,
|
|
733
|
+
amount,
|
|
734
|
+
userId: user_id,
|
|
735
|
+
});
|
|
736
|
+
callback(null, { transaction_id, risk_score: score.value, should_block: score.value > 0.9 });
|
|
737
|
+
} catch (err) {
|
|
738
|
+
callback({ code: grpc.status.INTERNAL, message: err.message });
|
|
739
|
+
}
|
|
740
|
+
},
|
|
741
|
+
});
|
|
742
|
+
|
|
743
|
+
// Interceptor for auth + logging (gRPC middleware equivalent)
|
|
744
|
+
server.addService(
|
|
745
|
+
fraudProto.FraudDetector.service,
|
|
746
|
+
withInterceptors([authInterceptor, loggingInterceptor, tracingInterceptor], handlers),
|
|
747
|
+
);
|
|
748
|
+
```
|