> vscode-sftp-config
This skill should be used when setting up SFTP deployment for static websites to production servers, including converting projects from Docker/Express to static hosting, deploying Vue/React/Angular builds, setting up Slidev presentations, or configuring Hugo/Jekyll/Gatsby sites. Use this when the user asks to "setup SFTP deployment", "deploy static site to server", "configure Nginx for static files", "convert from Docker to static hosting", "deploy Vue build to production", "setup subdomain host
curl "https://skillshub.wtf/libukai/awesome-agent-skills/vscode-sftp-config?format=md"VSCode SFTP Configuration
Configure VSCode SFTP for deploying static websites to production servers. Provides complete workflow including production-ready Nginx configuration templates with security headers, caching strategies, and performance optimizations.
Core Workflow
Step 1: Analyze Project Structure
Identify the static files to deploy:
- Pure static projects: HTML, CSS, JS in root directory
- Build-based projects: Look for
dist/,build/, orpublic/output directories - Static generators: Check for build commands in
package.jsonor documentation
Ask the user for deployment details:
- Remote server address (IP or hostname)
- Remote path (e.g.,
/var/www/sitename) - SSH authentication method (password or SSH key path)
- Domain name(s) for Nginx configuration
- Whether this is a main domain or subdomain
Step 2: Generate SFTP Configuration
VSCode Extension: This skill uses the code-sftp extension by Satiro Marra.
Step 2A: Configure SSH Config (Recommended Best Practice)
Before creating sftp.json, set up SSH host alias in ~/.ssh/config for better management:
Host project-prod
HostName 82.157.29.215
User root
Port 22
IdentityFile ~/.ssh/id_rsa
IdentitiesOnly yes
ServerAliveInterval 60
ServerAliveCountMax 3
Benefits of SSH config:
- ✅ Eliminates SFTP extension warnings (
Section for 'IP' not found) - ✅ Use host alias in terminal:
ssh project-prod - ✅ Centralized SSH settings (connection keep-alive, compression, etc.)
- ✅ Easier to manage multiple environments (dev, staging, prod)
Check if ~/.ssh/config already has the server:
cat ~/.ssh/config | grep -A 5 "82.157.29.215"
If found, use that existing host alias. If not, add a new entry.
Step 2B: Create SFTP Configuration
Create .vscode/sftp.json using the template from assets/sftp.json.template.
Essential configuration fields:
name: Profile name for easy identificationhost: SSH host alias (e.g.,"Tencent_Pro") or IP addressprotocol: "sftp" for SFTP (secure) or "ftp" for FTPport: 22 for SFTP, 21 for FTPusername: SSH/FTP usernameprivateKeyPath: Path to SSH private key (e.g.,/Users/username/.ssh/id_rsa)remotePath: Remote directory path (e.g.,/var/www/sitename)uploadOnSave:falserecommended (manual sync is safer)
Optional advanced fields:
ignore: Array of files/folders to exclude from uploadwatcher: File watching configuration for auto-uploadsyncOption: Sync behavior (delete, update, skip existing files)useTempFile: Use temporary files during uploaddownloadOnOpen: Auto-download files when opened
Customize for the project:
- Replace
{{HOST_ALIAS}}with SSH config alias (recommended) or IP address - Replace other
{{PLACEHOLDERS}}with actual values - Add project-specific files to
ignorearray (.claude,nginx.conf, build artifacts, etc.) - For build-based projects: Keep
uploadOnSave: false, sync manually after build - For pure static projects: Optionally enable
uploadOnSave: truefor instant deployment
Step 3: Generate Nginx Configuration
Choose the appropriate template:
- Main domain: Use
assets/nginx-static.conf.templatefor primary website - Subdomain: Use
assets/nginx-subdomain.conf.templatefor subdomains likeslides.example.com
Customize the configuration:
- Replace
{{DOMAIN}}with actual domain name - Replace
{{DOCUMENT_ROOT}}with remote path (e.g.,/var/www/aiseed) - Adjust SSL certificate paths if using custom certificates
- Configure subdomain-specific settings if needed
Include essential features from references/nginx-best-practices.md:
- HTTP → HTTPS redirect
- HTTP/2 support
- Gzip compression
- Static resource caching (1 year for JS/CSS/images, 1 hour for HTML)
- Security headers (HSTS, X-Frame-Options, CSP, etc.)
- Access and error logs
Step 4: Provide Deployment Instructions
Generate a deployment checklist based on assets/deploy-checklist.md:
-
Initial setup (one-time):
- Install VSCode extension: code-sftp by Satiro Marra
- Open Command Palette (Cmd/Ctrl+Shift+P) →
SFTP: Configto create.vscode/sftp.json - Verify SSH access to server:
ssh user@host - Ensure remote directory exists:
ssh user@host "mkdir -p /var/www/sitename" - Set proper permissions:
ssh user@host "chmod 755 /var/www/sitename"
-
File deployment:
- For build projects: Run build command first (e.g.,
npm run build) - Open VSCode Command Palette →
SFTP: Sync Local → Remoteto upload all files - Or right-click folder in Explorer → "Upload Folder"
- Monitor upload progress in VSCode Output panel (View → Output → SFTP)
- Verify files uploaded:
ssh user@host "ls -la /var/www/sitename"
- For build projects: Run build command first (e.g.,
-
Nginx configuration:
- Upload generated config to
/etc/nginx/sites-available/ - Create symlink:
ln -s /etc/nginx/sites-available/site.conf /etc/nginx/sites-enabled/ - Test config:
sudo nginx -t - Reload:
sudo systemctl reload nginx
- Upload generated config to
-
SSL/TLS setup (if not configured):
- Refer to
references/ssl-security.mdfor certificate setup - Use Let's Encrypt for free certificates:
certbot --nginx -d example.com
- Refer to
-
Verification:
- Test HTTPS:
curl -I https://example.com - Check security headers: Use securityheaders.com
- Test performance: Use PageSpeed Insights
- Test HTTPS:
Step 5: Document the Setup
Update project documentation (README.md or CLAUDE.md) with:
- Deployment method (SFTP to
/var/www/path) - SFTP configuration location (
.vscode/sftp.json) - Nginx configuration reference
- Build commands (if applicable)
- Deployment workflow for future updates
Benefits of This Architecture
Explain to users why static + SFTP deployment is advantageous:
- Simplicity: Edit → Upload → Live (no build pipelines, no containers)
- Performance: Nginx serves static files faster than Node.js/Python backends
- Reliability: No backend processes to crash or hang
- Resource efficiency: Lower server memory and CPU usage
- Cost effective: Can host on minimal VPS or shared hosting
- Easy rollback: Copy previous version from backup directory
When NOT to Use This Architecture
Static + SFTP deployment is not appropriate when:
- Backend API endpoints are required
- Server-side form processing is needed (unless using external services like n8n, FormSpree)
- User authentication/sessions are required
- Database interactions are needed
- Server-side rendering (SSR) is required
Resources
references/
ssh-config.md- SSH config file setup and best practices (host aliases, jump hosts, security)nginx-best-practices.md- Comprehensive Nginx optimization guide for static sitesssl-security.md- SSL/TLS certificate setup and security configuration
assets/
sftp.json.template- VSCode SFTP configuration template (array format, uses SSH host alias)nginx-static.conf.template- Main domain Nginx configuration templatenginx-subdomain.conf.template- Subdomain Nginx configuration templatedeploy-checklist.md- Step-by-step deployment verification checklist
> related_skills --same-repo
> obsidian-to-x
发布内容和文章到 X (Twitter)。支持常规推文(文字/图片/视频)和 X Articles(长文 Markdown)。使用真实 Chrome 浏览器绕过反机器人检测。当用户说"发推"、"发到 X"、"发到 twitter"、"分享到 X"、"分享到 twitter"、"发 tweet"、"同步到 X"、"发布到 X"、提到"X Articles"、想从 Obsidian 笔记发布长文内容、或需要转换 Obsidian Markdown 到 X 格式时使用。适用于所有 X/Twitter 发布任务。
> vscode-port-monitor-config
This skill should be used when configuring VS Code Port Monitor extension for development server monitoring. Use when the user asks to "set up port monitoring for Vite", "monitor my dev server ports", "configure port monitor for Next.js", "track which ports are running", "set up multi-port monitoring", "monitor frontend and backend ports", or "check port status in VS Code". Provides ready-to-use configuration templates for Vite (5173), Next.js (3000), and microservices architectures with trouble
> vscode-httpyac-config
Configure VSCode with httpYac for API testing and automation. This skill should be used specifically when converting API documentation to executable .http files (10+ endpoints), setting up authentication flows with pre-request scripts, implementing request chaining with response data, organizing multi-file collections with environment management, or establishing Git-based API testing workflows with CI/CD integration.
> mcp-config
Configure MCP (Model Context Protocol) servers for Claude Code. Manage MCP servers at user or project scope with best practices to avoid context pollution.