secure
Use this skill when the user needs to secure their SaaS app, implement authentication, protect user data, secure APIs, or check for vulnerabilities. Also use when the user says 'is my app secure,' 'security check,' 'I'm worried about hackers,' 'how do I protect user data,' or 'security before launch.' Covers OWASP Top 10, auth best practices, data protection, and security checklists for apps built with AI tools.
Best use case
secure is best used when you need a repeatable AI agent workflow instead of a one-off prompt.
Use this skill when the user needs to secure their SaaS app, implement authentication, protect user data, secure APIs, or check for vulnerabilities. Also use when the user says 'is my app secure,' 'security check,' 'I'm worried about hackers,' 'how do I protect user data,' or 'security before launch.' Covers OWASP Top 10, auth best practices, data protection, and security checklists for apps built with AI tools.
Teams using secure should expect a more consistent output, faster repeated execution, less prompt rewriting.
When to use this skill
- You want a reusable workflow that can be run more than once with consistent structure.
When not to use this skill
- You only need a quick one-off answer and do not need a reusable workflow.
- You cannot install or maintain the underlying files, dependencies, or repository context.
Installation
Claude Code / Cursor / Codex
Manual Installation
- Download SKILL.md from GitHub
- Place it in
.claude/skills/secure/SKILL.mdinside your project - Restart your AI agent — it will auto-discover the skill
How secure Compares
| Feature / Agent | secure | Standard Approach |
|---|---|---|
| Platform Support | Not specified | Limited / Varies |
| Context Awareness | High | Baseline |
| Installation Complexity | Unknown | N/A |
Frequently Asked Questions
What does this skill do?
Use this skill when the user needs to secure their SaaS app, implement authentication, protect user data, secure APIs, or check for vulnerabilities. Also use when the user says 'is my app secure,' 'security check,' 'I'm worried about hackers,' 'how do I protect user data,' or 'security before launch.' Covers OWASP Top 10, auth best practices, data protection, and security checklists for apps built with AI tools.
Where can I find the source code?
You can find the source code on GitHub using the link provided at the top of the page.
SKILL.md Source
# Security **This skill is for securing your app's code and data.** For regulatory compliance (HIPAA, SOC 2, GDPR), use **compliance**. For pre-launch readiness checks, use **go-live**. For environment variable setup during deployment, use **deploy**. For database-level security (Row Level Security), use **database**. ### Don't Do Yet - **Don't implement OAuth/SSO** until you have paying customers who need it. Email + password is fine for launch. - **Don't buy a pentest** until you have 1,000+ users or handle sensitive data (health, finance). This checklist is enough for MVP. - **Don't set up a Web Application Firewall (WAF)** — your hosting platform (Vercel, Railway) handles this. You don't need Cloudflare yet. - **Don't build your own auth system.** Use Supabase Auth, Clerk, or NextAuth. Rolling your own is how breaches happen. ## Quick Start **Claude Code:** ``` Run a security audit on my app. Check for: - API keys or secrets in code (should be in .env) - Missing auth on protected routes - SQL injection risks - XSS vulnerabilities - Missing rate limiting Fix anything you find. ``` **Lovable / Replit / Cursor** (paste into chat): ``` Review my app for security issues. Check these common problems: 1. Are any API keys or passwords hardcoded? Move them to environment variables. 2. Can someone access pages without logging in? Add auth checks. 3. Is user input validated before hitting the database? 4. Are passwords hashed (not stored as plain text)? 5. Is rate limiting set up on API endpoints? Show me what needs fixing and fix it. ``` --- ## Security Checklist ``` Security Basics: - [ ] Authentication required for protected routes - [ ] Passwords hashed (bcrypt/argon2), never stored plain text - [ ] API keys in environment variables, not code - [ ] HTTPS only in production - [ ] Input validated on server side - [ ] SQL injection prevented (use parameterized queries) - [ ] XSS prevented (sanitize user input) - [ ] CSRF tokens on forms - [ ] Rate limiting on API endpoints - [ ] User sessions expire (30min-1hr typical) ``` See [COMMON-VULNS.md](COMMON-VULNS.md) for detailed checks. --- ## Critical: Never Store These in Code **Move to environment variables:** - Database passwords - API keys (Stripe, SendGrid, etc) - JWT secrets - OAuth client secrets - Encryption keys **Tell AI:** ``` Store API keys in .env file, not in code. Add .env to .gitignore. Access via process.env.API_KEY ``` --- ## Authentication **Use a service. Don't build this yourself.** | If you use... | Auth solution | |---------------|---------------| | Supabase | Supabase Auth (built in) | | Next.js | NextAuth.js or Clerk | | Lovable | Supabase Auth (Lovable's default) | | Replit | Replit Auth or Supabase | **If you must build auth yourself** (not recommended), the minimums are: - Passwords: 8+ chars, hashed with bcrypt (12 rounds), never stored plain text - Email verification required for signups - Password reset via email token only - Sessions expire after 30-60 minutes idle **Tell AI:** ``` Set up authentication using [Supabase Auth / NextAuth / Clerk]. I need: email+password signup, email verification, password reset, and session timeout after 30 minutes of inactivity. ``` See [SECURITY-PROMPTS.md](SECURITY-PROMPTS.md) for implementation details. --- ## Data Protection **Always encrypt:** - Passwords (hashed, not encrypted) - Payment info (use Stripe, don't store cards) - Personal identifiable information (PII) **Never log:** - Passwords (even hashed) - Credit card numbers - API keys - Session tokens **Tell AI:** ``` Never log sensitive data. Replace passwords/tokens with "[REDACTED]" in logs. ``` --- ## API Security **Required for all API endpoints:** - Authentication check - Rate limiting (prevent abuse) - Input validation - Error messages don't leak info **Tell AI:** ``` Add to all API routes: - Require valid auth token - Rate limit: 100 requests/minute per IP - Validate all inputs (reject invalid) - Generic error messages (no stack traces to users) ``` --- ## Common Vulnerabilities **Most common in AI-built apps:** 1. **Exposed API keys** - In code instead of .env 2. **No rate limiting** - APIs can be spammed 3. **Missing auth checks** - Routes accessible without login 4. **SQL injection** - Raw SQL with user input 5. **XSS attacks** - Unescaped user content displayed See [COMMON-VULNS.md](COMMON-VULNS.md) for how to check. --- ## Security Prompts for AI **Adding authentication:** ``` Add authentication to this route. Require valid JWT token. Return 401 if missing/invalid. Don't expose error details. ``` **Rate limiting:** ``` Add rate limiting: - 100 requests/minute per IP - Return 429 "Too many requests" if exceeded - Use sliding window, not fixed ``` **Input validation:** ``` Validate all user inputs: - Email: valid format - Password: 8+ chars, 1 number, 1 symbol - Username: alphanumeric only, 3-20 chars Reject invalid input with clear error message ``` See [SECURITY-PROMPTS.md](SECURITY-PROMPTS.md) for more. --- ## Pre-Launch Security Review **Before deploying:** ``` Production Security: - [ ] All secrets in environment variables - [ ] HTTPS enforced (no HTTP) - [ ] Database backups configured - [ ] Rate limiting on all APIs - [ ] Error pages don't show stack traces - [ ] Admin routes protected - [ ] File uploads validated (type, size) - [ ] CORS configured (not wildcard "*") ``` --- ## When to Get Security Audit **Signs you need expert review:** - Handling payments directly (not Stripe) - Storing health/financial data - Multi-tenant with data isolation - Over 1,000 users - Processing sensitive PII **For most MVPs:** Following this checklist is sufficient. --- ## Common Founder Mistakes | Mistake | Fix | |---------|-----| | API keys in code | Move to .env | | No rate limiting | Add to all endpoints | | Plain text passwords | Use bcrypt | | HTTP in production | Force HTTPS | | Accepting all CORS | Whitelist domains | | No input validation | Validate server-side | | Detailed error messages | Generic messages only | --- ## Quick Wins **Easy security improvements:** 1. Add Helmet.js (Node) - Sets security headers 2. Use HTTPS everywhere - Force in production 3. Add rate limiting - Prevents abuse 4. Environment variables - Keep secrets safe 5. Update dependencies - Fix known vulnerabilities **Tell AI:** ``` Add helmet.js for security headers. Configure for production (HTTPS, CSP, XSS protection). ``` --- ## Testing Security **Quick checks:** **Exposed secrets:** ```bash grep -r "api_key" src/ grep -r "password" src/ # Should only find references to env vars ``` **No auth bypass:** - Try accessing protected routes without login - Should redirect to login or return 401 **Rate limiting works:** - Hit API endpoint 100 times quickly - Should get 429 error --- ## Success Looks Like ✅ No secrets in code (all in .env) ✅ Can't access protected routes without auth ✅ Passwords hashed, never stored plain text ✅ Rate limiting prevents abuse ✅ HTTPS enforced in production ✅ Input validated on server side --- ## Related Skills - **compliance** — Regulatory requirements (HIPAA, SOC 2, GDPR, CCPA) - **go-live** — Pre-launch readiness checks (security is one part of this) - **deploy** — Hosting and environment variable setup - **database** — Row Level Security, data access policies - **payments** — Stripe security and PCI compliance
Related Skills
validate
Use this skill when the user needs to validate a business idea, test demand before building, run a smoke test, create an MVP experiment, or decide whether an idea is worth pursuing. Covers demand validation, smoke tests, fake-door tests, landing page experiments, and go/no-go decision frameworks for bootstrapped founders.
ux-design
Use this skill when flows feel clunky, users are confused, navigation needs planning, onboarding needs design, or accessibility needs implementation. Covers information architecture, user flows, interaction patterns, progressive disclosure, and error handling UX.
ui-patterns
Use this skill when the user needs to build a dashboard, settings page, data table, or any page layout. Also use when choosing component libraries, implementing responsive design, dark mode, or handling UI states (loading, empty, error). Covers component selection, page composition, and responsive implementation.
translate
Use this skill when the user is a domain expert (lawyer, doctor, contractor, accountant, etc.) who wants to turn their professional knowledge into a software product. Also use when the user says 'I have an idea for my industry,' 'I know this problem exists,' 'I want to build something for [profession],' or is struggling to describe what they want the software to do. Helps identify which professional pain is worth building for, then translates it into requirements AI tools can execute.
test
Use this skill when the user needs to test features before deployment, create test scenarios, find edge cases, or verify bug fixes. Covers manual testing workflows, cross-browser testing, edge case identification, and testing checklists for non-technical founders.
technical-seo
Use this skill to implement technical SEO optimizations in code — meta tags, schema markup, Core Web Vitals, crawlability, robots.txt, sitemaps, and GEO (Generative Engine Optimization) for AI search engines. This is the implementation skill — for strategy see seo, for content writing see seo-content, for auditing see seo-audit.
support
Use this skill when the user needs to create help docs, build a knowledge base, set up self-serve support, or reduce support tickets. Covers documentation strategy, help center structure, support tone, and scaling support without hiring.
social-media
Use this skill when the user needs to grow a social media presence, create content for Twitter/X, LinkedIn, or other platforms, build a founder brand, or use social media as a distribution channel. Covers platform strategy, content frameworks, posting cadence, and audience building for bootstrapped SaaS founders.
seo
Use this skill when the user needs to plan SEO content, do keyword research, build a content calendar, map search intent to page types, or create an internal linking strategy. Also use when the user says 'how do I rank higher,' 'what should I write about for SEO,' 'SEO plan,' 'what keywords should I target,' or 'how to get organic traffic.' This is the strategy and planning skill — for writing content see seo-content, for technical implementation see technical-seo, for auditing see seo-audit.
seo-content
Use this skill when the user needs to write SEO content — blog posts, landing pages, feature pages, comparison pages, how-to guides, or any content meant to rank in search and get cited by AI. Covers content briefs, humanized writing that avoids AI detection, SERP feature targeting, entity optimization, content refresh, and quality self-checks. This is the writing skill — for strategy see seo, for technical implementation see technical-seo, for auditing see seo-audit.
seo-audit
Audit a codebase for SEO and AI-answer visibility, then produce a prioritized fix-it plan. Use this skill whenever a user says things like "audit my SEO", "check my site for search visibility", "how do I rank better", "optimize for Google", "optimize for AI answers", "SEO review", "GEO audit", "run the SEO agent", or anything about improving organic traffic or search rankings. Also trigger when someone mentions wanting visibility in AI-generated answers (ChatGPT, Gemini, Perplexity, Claude). Works on any web project — static sites, Next.js, Astro, Hugo, WordPress themes, or anything that outputs HTML.
sales
Use this skill when the user needs to find their first customers, write cold outreach, build a prospect list, or close early sales. Covers founder-led sales methodology, outreach templates, personalization, LinkedIn strategy, and landing the first 100 customers.