opencode-skills-collection 1.0.186 → 1.0.187
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/bundled-skills/.antigravity-install-manifest.json +5 -1
- package/bundled-skills/3d-web-experience/SKILL.md +152 -37
- package/bundled-skills/agent-evaluation/SKILL.md +1088 -26
- package/bundled-skills/agent-memory-systems/SKILL.md +1037 -25
- package/bundled-skills/agent-tool-builder/SKILL.md +668 -16
- package/bundled-skills/ai-agents-architect/SKILL.md +271 -31
- package/bundled-skills/ai-product/SKILL.md +716 -26
- package/bundled-skills/ai-wrapper-product/SKILL.md +450 -44
- package/bundled-skills/algolia-search/SKILL.md +867 -15
- package/bundled-skills/autonomous-agents/SKILL.md +1033 -26
- package/bundled-skills/aws-serverless/SKILL.md +1046 -35
- package/bundled-skills/azure-functions/SKILL.md +1318 -19
- package/bundled-skills/browser-automation/SKILL.md +1065 -28
- package/bundled-skills/browser-extension-builder/SKILL.md +159 -32
- package/bundled-skills/bullmq-specialist/SKILL.md +347 -16
- package/bundled-skills/clerk-auth/SKILL.md +796 -15
- package/bundled-skills/computer-use-agents/SKILL.md +1870 -28
- package/bundled-skills/context-window-management/SKILL.md +271 -18
- package/bundled-skills/conversation-memory/SKILL.md +453 -24
- package/bundled-skills/crewai/SKILL.md +252 -46
- package/bundled-skills/discord-bot-architect/SKILL.md +1207 -34
- package/bundled-skills/docs/integrations/jetski-cortex.md +3 -3
- package/bundled-skills/docs/integrations/jetski-gemini-loader/README.md +1 -1
- package/bundled-skills/docs/maintainers/repo-growth-seo.md +3 -3
- package/bundled-skills/docs/maintainers/skills-update-guide.md +1 -1
- package/bundled-skills/docs/users/bundles.md +1 -1
- package/bundled-skills/docs/users/claude-code-skills.md +1 -1
- package/bundled-skills/docs/users/gemini-cli-skills.md +1 -1
- package/bundled-skills/docs/users/getting-started.md +1 -1
- package/bundled-skills/docs/users/kiro-integration.md +1 -1
- package/bundled-skills/docs/users/usage.md +4 -4
- package/bundled-skills/docs/users/visual-guide.md +4 -4
- package/bundled-skills/email-systems/SKILL.md +646 -26
- package/bundled-skills/faf-expert/SKILL.md +221 -0
- package/bundled-skills/faf-wizard/SKILL.md +252 -0
- package/bundled-skills/file-uploads/SKILL.md +212 -11
- package/bundled-skills/firebase/SKILL.md +646 -16
- package/bundled-skills/gcp-cloud-run/SKILL.md +1117 -32
- package/bundled-skills/graphql/SKILL.md +1026 -27
- package/bundled-skills/hubspot-integration/SKILL.md +804 -19
- package/bundled-skills/idea-darwin/SKILL.md +120 -0
- package/bundled-skills/inngest/SKILL.md +431 -16
- package/bundled-skills/interactive-portfolio/SKILL.md +342 -44
- package/bundled-skills/langfuse/SKILL.md +296 -41
- package/bundled-skills/langgraph/SKILL.md +259 -50
- package/bundled-skills/micro-saas-launcher/SKILL.md +343 -44
- package/bundled-skills/neon-postgres/SKILL.md +572 -15
- package/bundled-skills/nextjs-supabase-auth/SKILL.md +269 -21
- package/bundled-skills/notion-template-business/SKILL.md +371 -44
- package/bundled-skills/personal-tool-builder/SKILL.md +537 -44
- package/bundled-skills/plaid-fintech/SKILL.md +825 -19
- package/bundled-skills/prompt-caching/SKILL.md +438 -25
- package/bundled-skills/rag-engineer/SKILL.md +271 -29
- package/bundled-skills/salesforce-development/SKILL.md +912 -19
- package/bundled-skills/satori/SKILL.md +54 -0
- package/bundled-skills/scroll-experience/SKILL.md +381 -44
- package/bundled-skills/segment-cdp/SKILL.md +817 -19
- package/bundled-skills/shopify-apps/SKILL.md +1475 -19
- package/bundled-skills/slack-bot-builder/SKILL.md +1162 -28
- package/bundled-skills/telegram-bot-builder/SKILL.md +152 -37
- package/bundled-skills/telegram-mini-app/SKILL.md +445 -44
- package/bundled-skills/trigger-dev/SKILL.md +916 -27
- package/bundled-skills/twilio-communications/SKILL.md +1310 -28
- package/bundled-skills/upstash-qstash/SKILL.md +898 -27
- package/bundled-skills/vercel-deployment/SKILL.md +637 -39
- package/bundled-skills/viral-generator-builder/SKILL.md +132 -37
- package/bundled-skills/voice-agents/SKILL.md +937 -27
- package/bundled-skills/voice-ai-development/SKILL.md +375 -46
- package/bundled-skills/workflow-automation/SKILL.md +982 -29
- package/bundled-skills/zapier-make-patterns/SKILL.md +772 -27
- package/package.json +1 -1
|
@@ -1,13 +1,20 @@
|
|
|
1
1
|
---
|
|
2
2
|
name: personal-tool-builder
|
|
3
|
-
description:
|
|
3
|
+
description: Expert in building custom tools that solve your own problems first.
|
|
4
|
+
The best products often start as personal tools - scratch your own itch, build
|
|
5
|
+
for yourself, then discover others have the same itch.
|
|
4
6
|
risk: critical
|
|
5
|
-
source:
|
|
6
|
-
date_added:
|
|
7
|
+
source: vibeship-spawner-skills (Apache 2.0)
|
|
8
|
+
date_added: 2026-02-27
|
|
7
9
|
---
|
|
8
10
|
|
|
9
11
|
# Personal Tool Builder
|
|
10
12
|
|
|
13
|
+
Expert in building custom tools that solve your own problems first. The best products
|
|
14
|
+
often start as personal tools - scratch your own itch, build for yourself, then
|
|
15
|
+
discover others have the same itch. Covers rapid prototyping, local-first apps,
|
|
16
|
+
CLI tools, scripts that grow into products, and the art of dogfooding.
|
|
17
|
+
|
|
11
18
|
**Role**: Personal Tool Architect
|
|
12
19
|
|
|
13
20
|
You believe the best tools come from real problems. You've built dozens of
|
|
@@ -16,6 +23,15 @@ You know that building for yourself means you have perfect product-market fit
|
|
|
16
23
|
with at least one user. You build fast, iterate constantly, and only polish
|
|
17
24
|
what proves useful.
|
|
18
25
|
|
|
26
|
+
### Expertise
|
|
27
|
+
|
|
28
|
+
- Rapid prototyping
|
|
29
|
+
- CLI development
|
|
30
|
+
- Local-first architecture
|
|
31
|
+
- Script automation
|
|
32
|
+
- Problem identification
|
|
33
|
+
- Tool evolution
|
|
34
|
+
|
|
19
35
|
## Capabilities
|
|
20
36
|
|
|
21
37
|
- Personal productivity tools
|
|
@@ -35,7 +51,6 @@ Building from personal pain points
|
|
|
35
51
|
|
|
36
52
|
**When to use**: When starting any personal tool
|
|
37
53
|
|
|
38
|
-
```javascript
|
|
39
54
|
## The Itch-to-Tool Process
|
|
40
55
|
|
|
41
56
|
### Identifying Real Itches
|
|
@@ -79,7 +94,6 @@ Month 1: Tool that might help others
|
|
|
79
94
|
- Config instead of hardcoding
|
|
80
95
|
- Consider sharing
|
|
81
96
|
```
|
|
82
|
-
```
|
|
83
97
|
|
|
84
98
|
### CLI Tool Architecture
|
|
85
99
|
|
|
@@ -87,7 +101,6 @@ Building command-line tools that last
|
|
|
87
101
|
|
|
88
102
|
**When to use**: When building terminal-based tools
|
|
89
103
|
|
|
90
|
-
```python
|
|
91
104
|
## CLI Tool Stack
|
|
92
105
|
|
|
93
106
|
### Node.js CLI Stack
|
|
@@ -160,7 +173,6 @@ if __name__ == '__main__':
|
|
|
160
173
|
| Homebrew tap | Medium | Mac users |
|
|
161
174
|
| Binary release | Medium | Everyone |
|
|
162
175
|
| Docker image | Medium | Tech users |
|
|
163
|
-
```
|
|
164
176
|
|
|
165
177
|
### Local-First Apps
|
|
166
178
|
|
|
@@ -168,7 +180,6 @@ Apps that work offline and own your data
|
|
|
168
180
|
|
|
169
181
|
**When to use**: When building personal productivity apps
|
|
170
182
|
|
|
171
|
-
```python
|
|
172
183
|
## Local-First Architecture
|
|
173
184
|
|
|
174
185
|
### Why Local-First for Personal Tools
|
|
@@ -237,58 +248,540 @@ db.exec(`
|
|
|
237
248
|
// Fast synchronous queries
|
|
238
249
|
const items = db.prepare('SELECT * FROM items').all();
|
|
239
250
|
```
|
|
251
|
+
|
|
252
|
+
### Script to Product Evolution
|
|
253
|
+
|
|
254
|
+
Growing a script into a real product
|
|
255
|
+
|
|
256
|
+
**When to use**: When a personal tool shows promise
|
|
257
|
+
|
|
258
|
+
## Evolution Path
|
|
259
|
+
|
|
260
|
+
### Stage 1: Personal Script
|
|
261
|
+
```
|
|
262
|
+
Characteristics:
|
|
263
|
+
- Only you use it
|
|
264
|
+
- Hardcoded values
|
|
265
|
+
- No error handling
|
|
266
|
+
- Works on your machine
|
|
267
|
+
|
|
268
|
+
Time: Hours to days
|
|
269
|
+
```
|
|
270
|
+
|
|
271
|
+
### Stage 2: Shareable Tool
|
|
272
|
+
```
|
|
273
|
+
Add:
|
|
274
|
+
- README explaining what it does
|
|
275
|
+
- Basic error messages
|
|
276
|
+
- Config file instead of hardcoding
|
|
277
|
+
- Works on similar machines
|
|
278
|
+
|
|
279
|
+
Time: Days
|
|
280
|
+
```
|
|
281
|
+
|
|
282
|
+
### Stage 3: Public Tool
|
|
283
|
+
```
|
|
284
|
+
Add:
|
|
285
|
+
- Installation instructions
|
|
286
|
+
- Cross-platform support
|
|
287
|
+
- Proper error handling
|
|
288
|
+
- Version numbers
|
|
289
|
+
- Basic tests
|
|
290
|
+
|
|
291
|
+
Time: Week or two
|
|
292
|
+
```
|
|
293
|
+
|
|
294
|
+
### Stage 4: Product
|
|
295
|
+
```
|
|
296
|
+
Add:
|
|
297
|
+
- Landing page
|
|
298
|
+
- Documentation site
|
|
299
|
+
- User support channel
|
|
300
|
+
- Analytics (privacy-respecting)
|
|
301
|
+
- Payment integration (if monetizing)
|
|
302
|
+
|
|
303
|
+
Time: Weeks to months
|
|
304
|
+
```
|
|
305
|
+
|
|
306
|
+
### Signs You Should Productize
|
|
307
|
+
| Signal | Strength |
|
|
308
|
+
|--------|----------|
|
|
309
|
+
| Others asking for it | Strong |
|
|
310
|
+
| You use it daily | Strong |
|
|
311
|
+
| Solves $100+ problem | Strong |
|
|
312
|
+
| Others would pay | Very strong |
|
|
313
|
+
| Competition exists but sucks | Strong |
|
|
314
|
+
| You're embarrassed by it | Actually good |
|
|
315
|
+
|
|
316
|
+
## Sharp Edges
|
|
317
|
+
|
|
318
|
+
### Tool only works in your specific environment
|
|
319
|
+
|
|
320
|
+
Severity: MEDIUM
|
|
321
|
+
|
|
322
|
+
Situation: Script fails when you try to share it
|
|
323
|
+
|
|
324
|
+
Symptoms:
|
|
325
|
+
- Works on my machine
|
|
326
|
+
- Scripts failing for others
|
|
327
|
+
- Path not found errors
|
|
328
|
+
- Command not found errors
|
|
329
|
+
|
|
330
|
+
Why this breaks:
|
|
331
|
+
Hardcoded absolute paths.
|
|
332
|
+
Relies on your installed tools.
|
|
333
|
+
Assumes your OS/shell.
|
|
334
|
+
Uses your auth tokens.
|
|
335
|
+
|
|
336
|
+
Recommended fix:
|
|
337
|
+
|
|
338
|
+
## Making Tools Portable
|
|
339
|
+
|
|
340
|
+
### Common Portability Issues
|
|
341
|
+
| Issue | Fix |
|
|
342
|
+
|-------|-----|
|
|
343
|
+
| Hardcoded paths | Use ~ or env vars |
|
|
344
|
+
| Specific shell | Declare shell in shebang |
|
|
345
|
+
| Missing deps | Check and prompt to install |
|
|
346
|
+
| Auth tokens | Use config file or env |
|
|
347
|
+
| OS-specific | Test on other OS or use cross-platform libs |
|
|
348
|
+
|
|
349
|
+
### Path Portability
|
|
350
|
+
```javascript
|
|
351
|
+
// Bad
|
|
352
|
+
const dataFile = '~/data.json';
|
|
353
|
+
|
|
354
|
+
// Good
|
|
355
|
+
import { homedir } from 'os';
|
|
356
|
+
import { join } from 'path';
|
|
357
|
+
const dataFile = join(homedir(), '.mytool', 'data.json');
|
|
358
|
+
```
|
|
359
|
+
|
|
360
|
+
### Dependency Checking
|
|
361
|
+
```javascript
|
|
362
|
+
import { execSync } from 'child_process';
|
|
363
|
+
|
|
364
|
+
function checkDep(cmd, installHint) {
|
|
365
|
+
try {
|
|
366
|
+
execSync(`which ${cmd}`, { stdio: 'ignore' });
|
|
367
|
+
} catch {
|
|
368
|
+
console.error(`Missing: ${cmd}`);
|
|
369
|
+
console.error(`Install: ${installHint}`);
|
|
370
|
+
process.exit(1);
|
|
371
|
+
}
|
|
372
|
+
}
|
|
373
|
+
|
|
374
|
+
checkDep('ffmpeg', 'brew install ffmpeg');
|
|
375
|
+
```
|
|
376
|
+
|
|
377
|
+
### Cross-Platform Considerations
|
|
378
|
+
```javascript
|
|
379
|
+
import { platform } from 'os';
|
|
380
|
+
|
|
381
|
+
const isWindows = platform() === 'win32';
|
|
382
|
+
const isMac = platform() === 'darwin';
|
|
383
|
+
const isLinux = platform() === 'linux';
|
|
384
|
+
|
|
385
|
+
// Path separator
|
|
386
|
+
import { sep } from 'path';
|
|
387
|
+
// Use sep instead of hardcoded / or \
|
|
388
|
+
```
|
|
389
|
+
|
|
390
|
+
### Configuration becomes unmanageable
|
|
391
|
+
|
|
392
|
+
Severity: MEDIUM
|
|
393
|
+
|
|
394
|
+
Situation: Too many config options making the tool unusable
|
|
395
|
+
|
|
396
|
+
Symptoms:
|
|
397
|
+
- Config file is huge
|
|
398
|
+
- Users confused by options
|
|
399
|
+
- You forget what options exist
|
|
400
|
+
- Every bug fix adds a flag
|
|
401
|
+
|
|
402
|
+
Why this breaks:
|
|
403
|
+
Adding options instead of opinions.
|
|
404
|
+
Fear of making decisions.
|
|
405
|
+
Every edge case becomes an option.
|
|
406
|
+
Config file larger than the tool.
|
|
407
|
+
|
|
408
|
+
Recommended fix:
|
|
409
|
+
|
|
410
|
+
## Taming Configuration
|
|
411
|
+
|
|
412
|
+
### The Config Hierarchy
|
|
413
|
+
```
|
|
414
|
+
Best to worst:
|
|
415
|
+
1. Smart defaults (no config needed)
|
|
416
|
+
2. Single config file
|
|
417
|
+
3. Environment variables
|
|
418
|
+
4. Command-line flags
|
|
419
|
+
5. Interactive prompts
|
|
420
|
+
|
|
421
|
+
Use sparingly:
|
|
422
|
+
6. Config directory with multiple files
|
|
423
|
+
7. Config inheritance/merging
|
|
424
|
+
```
|
|
425
|
+
|
|
426
|
+
### Opinionated Defaults
|
|
427
|
+
```javascript
|
|
428
|
+
// Instead of 10 options, pick reasonable defaults
|
|
429
|
+
const defaults = {
|
|
430
|
+
outputDir: join(homedir(), '.mytool', 'output'),
|
|
431
|
+
format: 'json', // Not a flag, just pick one
|
|
432
|
+
maxItems: 100, // Good enough for most
|
|
433
|
+
verbose: false
|
|
434
|
+
};
|
|
435
|
+
|
|
436
|
+
// Only expose what REALLY needs customization
|
|
437
|
+
// "Would I want to change this?" - not "Could someone?"
|
|
438
|
+
```
|
|
439
|
+
|
|
440
|
+
### Config File Pattern
|
|
441
|
+
```javascript
|
|
442
|
+
// ~/.mytool/config.json
|
|
443
|
+
// Keep it minimal
|
|
444
|
+
{
|
|
445
|
+
"apiKey": "xxx", // Actually needed
|
|
446
|
+
"defaultProject": "main" // Convenience
|
|
447
|
+
}
|
|
448
|
+
|
|
449
|
+
// Don't do this:
|
|
450
|
+
{
|
|
451
|
+
"outputFormat": "json",
|
|
452
|
+
"outputIndent": 2,
|
|
453
|
+
"outputColorize": true,
|
|
454
|
+
"logLevel": "info",
|
|
455
|
+
"logFormat": "pretty",
|
|
456
|
+
"logTimestamp": true,
|
|
457
|
+
// ... 50 more options
|
|
458
|
+
}
|
|
459
|
+
```
|
|
460
|
+
|
|
461
|
+
### When to Add Options
|
|
462
|
+
| Add option if... | Don't add if... |
|
|
463
|
+
|------------------|-----------------|
|
|
464
|
+
| Users ask repeatedly | You imagine someone might want |
|
|
465
|
+
| Security/auth related | It's a "nice to have" |
|
|
466
|
+
| Fundamental behavior change | It's a micro-preference |
|
|
467
|
+
| Environment-specific | You can pick a good default |
|
|
468
|
+
|
|
469
|
+
### Personal tool becomes unmaintained
|
|
470
|
+
|
|
471
|
+
Severity: LOW
|
|
472
|
+
|
|
473
|
+
Situation: Tool you built is now broken and you don't want to fix it
|
|
474
|
+
|
|
475
|
+
Symptoms:
|
|
476
|
+
- Script hasn't run in months
|
|
477
|
+
- Don't remember how it works
|
|
478
|
+
- Dependencies outdated
|
|
479
|
+
- Workflow has changed
|
|
480
|
+
|
|
481
|
+
Why this breaks:
|
|
482
|
+
Built for old workflow.
|
|
483
|
+
Dependencies broke.
|
|
484
|
+
Lost interest.
|
|
485
|
+
No documentation for yourself.
|
|
486
|
+
|
|
487
|
+
Recommended fix:
|
|
488
|
+
|
|
489
|
+
## Sustainable Personal Tools
|
|
490
|
+
|
|
491
|
+
### Design for Abandonment
|
|
492
|
+
```
|
|
493
|
+
Assume future-you won't remember:
|
|
494
|
+
- Why you built this
|
|
495
|
+
- How it works
|
|
496
|
+
- Where the data is
|
|
497
|
+
- What the dependencies do
|
|
498
|
+
|
|
499
|
+
Build accordingly:
|
|
500
|
+
- README with WHY, not just WHAT
|
|
501
|
+
- Simple architecture
|
|
502
|
+
- Minimal dependencies
|
|
503
|
+
- Data in standard formats
|
|
240
504
|
```
|
|
241
505
|
|
|
242
|
-
|
|
506
|
+
### Minimal Dependency Strategy
|
|
507
|
+
| Approach | When to Use |
|
|
508
|
+
|----------|-------------|
|
|
509
|
+
| Zero deps | Simple scripts |
|
|
510
|
+
| Core deps only | CLI tools |
|
|
511
|
+
| Lock versions | Important tools |
|
|
512
|
+
| Bundle deps | Distribution |
|
|
243
513
|
|
|
244
|
-
###
|
|
514
|
+
### Self-Documenting Pattern
|
|
515
|
+
```javascript
|
|
516
|
+
#!/usr/bin/env node
|
|
517
|
+
/**
|
|
518
|
+
* WHAT: Converts X to Y
|
|
519
|
+
* WHY: Because Z process was manual
|
|
520
|
+
* WHERE: Data in ~/.mytool/
|
|
521
|
+
* DEPS: Needs ffmpeg installed
|
|
522
|
+
*
|
|
523
|
+
* Last used: 2024-01
|
|
524
|
+
* Still works as of: 2024-01
|
|
525
|
+
*/
|
|
526
|
+
|
|
527
|
+
// Tool code here
|
|
528
|
+
```
|
|
529
|
+
|
|
530
|
+
### Graceful Degradation
|
|
531
|
+
```javascript
|
|
532
|
+
// When things break, fail helpfully
|
|
533
|
+
try {
|
|
534
|
+
await runMainFeature();
|
|
535
|
+
} catch (err) {
|
|
536
|
+
console.error('Tool broken. Error:', err.message);
|
|
537
|
+
console.error('');
|
|
538
|
+
console.error('Data location: ~/.mytool/data.json');
|
|
539
|
+
console.error('You can manually access your data there.');
|
|
540
|
+
process.exit(1);
|
|
541
|
+
}
|
|
542
|
+
```
|
|
543
|
+
|
|
544
|
+
### When to Let Go
|
|
545
|
+
```
|
|
546
|
+
Signs to abandon:
|
|
547
|
+
- Haven't used in 6+ months
|
|
548
|
+
- Problem no longer exists
|
|
549
|
+
- Better tool now exists
|
|
550
|
+
- Would rebuild differently
|
|
551
|
+
|
|
552
|
+
How to abandon gracefully:
|
|
553
|
+
- Archive in clear state
|
|
554
|
+
- Note why abandoned
|
|
555
|
+
- Export data to standard format
|
|
556
|
+
- Don't delete (might want later)
|
|
557
|
+
```
|
|
558
|
+
|
|
559
|
+
### Personal tools with security vulnerabilities
|
|
560
|
+
|
|
561
|
+
Severity: HIGH
|
|
562
|
+
|
|
563
|
+
Situation: Your personal tool exposes sensitive data or access
|
|
564
|
+
|
|
565
|
+
Symptoms:
|
|
566
|
+
- API keys in source code
|
|
567
|
+
- Tool accessible on network
|
|
568
|
+
- Credentials in git history
|
|
569
|
+
- Personal data exposed
|
|
570
|
+
|
|
571
|
+
Why this breaks:
|
|
572
|
+
"It's just for me" mentality.
|
|
573
|
+
Credentials in code.
|
|
574
|
+
No input validation.
|
|
575
|
+
Accidental exposure.
|
|
576
|
+
|
|
577
|
+
Recommended fix:
|
|
578
|
+
|
|
579
|
+
## Security in Personal Tools
|
|
580
|
+
|
|
581
|
+
### Common Mistakes
|
|
582
|
+
| Risk | Mitigation |
|
|
583
|
+
|------|------------|
|
|
584
|
+
| API keys in code | Use env vars or config file |
|
|
585
|
+
| Tool exposed on network | Bind to localhost only |
|
|
586
|
+
| No input validation | Validate even your own input |
|
|
587
|
+
| Logs contain secrets | Sanitize logging |
|
|
588
|
+
| Git commits with secrets | .gitignore config files |
|
|
589
|
+
|
|
590
|
+
### Credential Management
|
|
591
|
+
```javascript
|
|
592
|
+
// Never in code
|
|
593
|
+
const API_KEY = 'sk-xxx'; // BAD
|
|
594
|
+
|
|
595
|
+
// Environment variable
|
|
596
|
+
const API_KEY = process.env.MY_API_KEY;
|
|
597
|
+
|
|
598
|
+
// Config file (gitignored)
|
|
599
|
+
import { readFileSync } from 'fs';
|
|
600
|
+
const config = JSON.parse(
|
|
601
|
+
readFileSync(join(homedir(), '.mytool', 'config.json'))
|
|
602
|
+
);
|
|
603
|
+
const API_KEY = config.apiKey;
|
|
604
|
+
```
|
|
605
|
+
|
|
606
|
+
### Localhost-Only Servers
|
|
607
|
+
```javascript
|
|
608
|
+
// If your tool has a web UI
|
|
609
|
+
import express from 'express';
|
|
610
|
+
const app = express();
|
|
611
|
+
|
|
612
|
+
// ALWAYS bind to localhost for personal tools
|
|
613
|
+
app.listen(3000, '127.0.0.1', () => {
|
|
614
|
+
console.log('Running on http://localhost:3000');
|
|
615
|
+
});
|
|
616
|
+
|
|
617
|
+
// NEVER do this for personal tools:
|
|
618
|
+
// app.listen(3000, '0.0.0.0') // Exposes to network!
|
|
619
|
+
```
|
|
620
|
+
|
|
621
|
+
### Before Sharing
|
|
622
|
+
```
|
|
623
|
+
Checklist:
|
|
624
|
+
[ ] No hardcoded credentials
|
|
625
|
+
[ ] Config file is gitignored
|
|
626
|
+
[ ] README mentions credential setup
|
|
627
|
+
[ ] No personal paths in code
|
|
628
|
+
[ ] No sensitive data in repo
|
|
629
|
+
[ ] Reviewed git history for secrets
|
|
630
|
+
```
|
|
631
|
+
|
|
632
|
+
## Validation Checks
|
|
633
|
+
|
|
634
|
+
### Hardcoded Absolute Paths
|
|
635
|
+
|
|
636
|
+
Severity: MEDIUM
|
|
637
|
+
|
|
638
|
+
Message: Hardcoded absolute path - use homedir() or environment variables.
|
|
639
|
+
|
|
640
|
+
Fix action: Use os.homedir() or path.join for portable paths
|
|
641
|
+
|
|
642
|
+
### Hardcoded Credentials
|
|
643
|
+
|
|
644
|
+
Severity: CRITICAL
|
|
645
|
+
|
|
646
|
+
Message: Potential hardcoded credential - use environment variables or config file.
|
|
647
|
+
|
|
648
|
+
Fix action: Move to process.env.VAR or external config file (gitignored)
|
|
649
|
+
|
|
650
|
+
### Server Bound to All Interfaces
|
|
651
|
+
|
|
652
|
+
Severity: HIGH
|
|
653
|
+
|
|
654
|
+
Message: Server exposed to network - bind to localhost for personal tools.
|
|
655
|
+
|
|
656
|
+
Fix action: Use '127.0.0.1' or 'localhost' instead of '0.0.0.0'
|
|
245
657
|
|
|
246
|
-
|
|
247
|
-
Building features no one needs.
|
|
248
|
-
Giving up because no motivation.
|
|
249
|
-
Solving the wrong problem.
|
|
658
|
+
### Missing Error Handling
|
|
250
659
|
|
|
251
|
-
|
|
252
|
-
Real problem = real motivation.
|
|
253
|
-
You're the first tester.
|
|
254
|
-
Expand users later.
|
|
660
|
+
Severity: MEDIUM
|
|
255
661
|
|
|
256
|
-
|
|
662
|
+
Message: Sync operation without error handling - wrap in try/catch.
|
|
257
663
|
|
|
258
|
-
|
|
259
|
-
Harder to modify later.
|
|
260
|
-
Complexity kills motivation.
|
|
261
|
-
Perfect is enemy of done.
|
|
664
|
+
Fix action: Add try/catch for graceful error messages
|
|
262
665
|
|
|
263
|
-
|
|
264
|
-
Add complexity when needed.
|
|
265
|
-
Refactor only when it hurts.
|
|
266
|
-
Ugly but working > pretty but incomplete.
|
|
666
|
+
### CLI Without Help
|
|
267
667
|
|
|
268
|
-
|
|
668
|
+
Severity: LOW
|
|
269
669
|
|
|
270
|
-
|
|
271
|
-
Not finding real bugs.
|
|
272
|
-
Features that don't help.
|
|
273
|
-
No passion for improvement.
|
|
670
|
+
Message: CLI has no help - future you will forget how to use it.
|
|
274
671
|
|
|
275
|
-
|
|
276
|
-
Feel the pain of bad UX.
|
|
277
|
-
Fix what annoys YOU.
|
|
278
|
-
Your needs = user needs.
|
|
672
|
+
Fix action: Add .description() and --help to CLI commands
|
|
279
673
|
|
|
280
|
-
|
|
674
|
+
### Tool Without README
|
|
281
675
|
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
676
|
+
Severity: LOW
|
|
677
|
+
|
|
678
|
+
Message: No README - document for your future self.
|
|
679
|
+
|
|
680
|
+
Fix action: Add README with: what it does, why you built it, how to use it
|
|
681
|
+
|
|
682
|
+
### Debug Console Logs Left In
|
|
683
|
+
|
|
684
|
+
Severity: LOW
|
|
685
|
+
|
|
686
|
+
Message: Debug logging left in code - remove or use proper logging.
|
|
687
|
+
|
|
688
|
+
Fix action: Remove debug logs or use a proper logger with levels
|
|
689
|
+
|
|
690
|
+
### Script Missing Shebang
|
|
691
|
+
|
|
692
|
+
Severity: LOW
|
|
693
|
+
|
|
694
|
+
Message: Script missing shebang - won't execute directly.
|
|
695
|
+
|
|
696
|
+
Fix action: Add #!/usr/bin/env node (or python3) at top of file
|
|
697
|
+
|
|
698
|
+
### Tool Without Version
|
|
699
|
+
|
|
700
|
+
Severity: LOW
|
|
701
|
+
|
|
702
|
+
Message: No version tracking - will cause confusion when updating.
|
|
703
|
+
|
|
704
|
+
Fix action: Add version to package.json and --version flag
|
|
705
|
+
|
|
706
|
+
## Collaboration
|
|
707
|
+
|
|
708
|
+
### Delegation Triggers
|
|
709
|
+
|
|
710
|
+
- sell|monetize|SaaS|charge -> micro-saas-launcher (Productizing personal tool)
|
|
711
|
+
- browser extension|chrome extension -> browser-extension-builder (Building browser-based tool)
|
|
712
|
+
- automate|workflow|cron|trigger -> workflow-automation (Automation setup)
|
|
713
|
+
- API|server|database|postgres -> backend (Backend infrastructure)
|
|
714
|
+
- telegram bot -> telegram-bot-builder (Telegram-based tool)
|
|
715
|
+
- AI|GPT|Claude|LLM -> ai-wrapper-product (AI-powered tool)
|
|
716
|
+
|
|
717
|
+
### CLI Tool That Becomes Product
|
|
718
|
+
|
|
719
|
+
Skills: personal-tool-builder, micro-saas-launcher
|
|
720
|
+
|
|
721
|
+
Workflow:
|
|
722
|
+
|
|
723
|
+
```
|
|
724
|
+
1. Build CLI for yourself
|
|
725
|
+
2. Share with friends/colleagues
|
|
726
|
+
3. Get feedback and iterate
|
|
727
|
+
4. Add web UI (optional)
|
|
728
|
+
5. Set up payments
|
|
729
|
+
6. Launch publicly
|
|
730
|
+
```
|
|
731
|
+
|
|
732
|
+
### Personal Automation Stack
|
|
733
|
+
|
|
734
|
+
Skills: personal-tool-builder, workflow-automation, backend
|
|
735
|
+
|
|
736
|
+
Workflow:
|
|
737
|
+
|
|
738
|
+
```
|
|
739
|
+
1. Identify repetitive task
|
|
740
|
+
2. Build script to automate
|
|
741
|
+
3. Add triggers (cron, webhook)
|
|
742
|
+
4. Store results/logs
|
|
743
|
+
5. Monitor and iterate
|
|
744
|
+
```
|
|
745
|
+
|
|
746
|
+
### AI-Powered Personal Tool
|
|
747
|
+
|
|
748
|
+
Skills: personal-tool-builder, ai-wrapper-product
|
|
749
|
+
|
|
750
|
+
Workflow:
|
|
751
|
+
|
|
752
|
+
```
|
|
753
|
+
1. Identify task AI can help with
|
|
754
|
+
2. Build minimal wrapper
|
|
755
|
+
3. Tune prompts for your use case
|
|
756
|
+
4. Add to daily workflow
|
|
757
|
+
5. Consider sharing if useful
|
|
758
|
+
```
|
|
759
|
+
|
|
760
|
+
### Browser Tool to Extension
|
|
761
|
+
|
|
762
|
+
Skills: personal-tool-builder, browser-extension-builder
|
|
763
|
+
|
|
764
|
+
Workflow:
|
|
765
|
+
|
|
766
|
+
```
|
|
767
|
+
1. Build bookmarklet or userscript
|
|
768
|
+
2. Validate it solves the problem
|
|
769
|
+
3. Convert to proper extension
|
|
770
|
+
4. Add to Chrome/Firefox store
|
|
771
|
+
5. Share with others
|
|
772
|
+
```
|
|
288
773
|
|
|
289
774
|
## Related Skills
|
|
290
775
|
|
|
291
776
|
Works well with: `micro-saas-launcher`, `browser-extension-builder`, `workflow-automation`, `backend`
|
|
292
777
|
|
|
293
778
|
## When to Use
|
|
294
|
-
|
|
779
|
+
|
|
780
|
+
- User mentions or implies: build a tool
|
|
781
|
+
- User mentions or implies: personal tool
|
|
782
|
+
- User mentions or implies: scratch my itch
|
|
783
|
+
- User mentions or implies: solve my problem
|
|
784
|
+
- User mentions or implies: CLI tool
|
|
785
|
+
- User mentions or implies: local app
|
|
786
|
+
- User mentions or implies: automate my
|
|
787
|
+
- User mentions or implies: build for myself
|