review-script-template
1
总安装量
1
周安装量
#49514
全站排名
安装命令
npx skills add https://github.com/b-open-io/bsv-skills --skill review-script-template
Agent 安装分布
replit
1
opencode
1
cursor
1
claude-code
1
antigravity
1
gemini-cli
1
Skill 文档
Review Script Template
Review and validate script template implementations in ts-templates for correctness and best practices.
When to Use
- Review a new template before merging
- Audit existing template implementations
- Validate template follows ts-templates patterns
- Check for common implementation errors
Review Checklist
Structure Validation
- File located in
src/template/appropriate subdirectory - Implements
ScriptTemplateinterface from @bsv/sdk - Exports PREFIX constant
- Exports Data interface with all protocol fields
- Default export is the template class
- Added to mod.ts exports (class + types)
Interface Requirements
-
dataproperty ispublic readonly - Constructor accepts Data interface
-
bitcomIndex?: numberfield for protocol position -
valid?: booleanfield for verification status
Required Methods
| Method | Purpose | Requirements |
|---|---|---|
decode() |
Static. Parse from BitComDecoded | Return array of instances |
lock() |
Generate LockingScript | Use BitCom for OP_RETURN protocols |
unlock() |
Generate UnlockingScript | Throw if not applicable |
verify() |
Check signature validity | Return boolean |
Code Quality
- Uses
script.chunksdirectly (no toASM().split()) - Uses @bsv/sdk Utils (no Buffer, TextEncoder)
- Proper error handling in decode()
- No hardcoded magic numbers
- Consistent with other templates in repo
Chunk Parsing Review
Correct pattern:
const script = Script.fromBinary(protocol.script)
const chunks = script.chunks
const field = Utils.toUTF8(chunks[0].data ?? [])
Incorrect patterns to flag:
// BAD: String splitting
const parts = script.toASM().split(' ')
// BAD: Buffer usage
const field = Buffer.from(chunks[0].data).toString()
// BAD: TextEncoder
new TextEncoder().encode(field)
Utils Usage Review
Verify correct Utils functions:
| Operation | Correct | Incorrect |
|---|---|---|
| String â bytes | Utils.toArray(str, 'utf8') |
Buffer.from(), TextEncoder |
| Bytes â string | Utils.toUTF8(bytes) |
Buffer.toString(), TextDecoder |
| Bytes â hex | Utils.toHex(bytes) |
Buffer.toString('hex') |
| Bytes â base64 | Utils.toBase64(bytes) |
Buffer.toString('base64') |
Signature Verification Review
For protocols with signatures:
- Uses BSM.sign() for signing
- Tries all 4 recovery factors (0-3)
- Uses Signature.fromCompact() for decoding
- Verifies address matches recovered public key
- Sets
validfield after verification
BitCom Integration Review
For OP_RETURN protocols:
- Uses BitCom class for lock()
- Creates Protocol array with correct structure
- Proper pipe delimiter handling
- decode() accepts BitComDecoded parameter
Common Issues
Issue 1: Missing Null Checks
// BAD: Can throw on missing data
const field = Utils.toUTF8(chunks[0].data)
// GOOD: Handle missing data
const field = Utils.toUTF8(chunks[0].data ?? [])
Issue 2: Wrong Chunk Index
Verify chunk indices match protocol specification:
- Check protocol documentation for field order
- Account for protocol prefix being separate
Issue 3: Incomplete Error Handling
// BAD: Crashes on parse error
static decode(bitcom: BitComDecoded): Protocol[] {
const script = Script.fromBinary(protocol.script) // Can throw!
}
// GOOD: Handle parse errors
static decode(bitcom: BitComDecoded): Protocol[] {
try {
const script = Script.fromBinary(protocol.script)
} catch {
continue // Skip invalid protocols
}
}
Issue 4: Missing mod.ts Export
Check that mod.ts includes:
export { default as Protocol, PREFIX } from './src/template/...'
export type { ProtocolData, ProtocolOptions } from './src/template/...'
Review Output Format
Provide structured feedback:
## Template Review: [TemplateName]
### Structure: â
PASS / â FAIL
- [Details]
### Methods: â
PASS / â FAIL
- [Details]
### Code Quality: â
PASS / â FAIL
- [Details]
### Issues Found
1. [Issue description and fix]
2. [Issue description and fix]
### Recommendations
- [Optional improvements]
Additional Resources
Reference Files
references/checklist-detailed.md– Extended validation criteriareferences/common-bugs.md– Known issues and fixes