stolt/skill-validator
Parse and validate SKILL.md files (or raw content) against the SKILL.md format specification. Validates single files, entire directories (recursively), or existing SkillMd instances, returning a SkillMd on success or detailed errors on failure.
A PHP library to parse and validate SKILL.md files or raw SKILL.md content against the
SKILL.md format specification.
composer require stolt/skill-validator
The SkillMd class from the stolt/skill-md package is the primary abstraction for a validated skill. Every valid
result exposes a SkillMd instance, and the validator also accepts SkillMd instances directly as input.
The validator can validate existing SKILL.md files, raw SKILL.md content, or the mentioned SkillMd instances.
SKILL.md fileuse Stolt\Ai\Skill\Validator;
$validator = new Validator();
$result = $validator->validateFile('/path/to/an-ai-skill/SKILL.md');
SKILL.md files in a directoryuse Stolt\Ai\Skill\Validator;
$validator = new Validator();
$results = $validator->validateFromDirectory('/path/to/skills');
foreach ($results as $filePath => $result) {
if ($result->isInvalid()) {
echo sprintf('Invalid: %s', $filePath) . PHP_EOL;
foreach ($result->errors() as $error) {
echo ' - ' . $error . PHP_EOL;
}
}
}
The method returns an array<string, ValidationResult> keyed by absolute file path, covering all SKILL.md files found
recursively under the given directory.
SKILL.md contentuse Stolt\Ai\Skill\Validator;
$validator = new Validator();
$result = $validator->validateContent('raw-skill-content');
SkillMd instanceuse Stolt\Ai\Skill\Validator;
use Stolt\Ai\SkillMd;
$skillMd = SkillMd::create(
'code-review',
'Review code changes and provide actionable feedback.',
"# Code review\n\nReview the changed files and report issues.",
['tags' => ['php', 'review'], 'version' => '1.0.0']
);
$validator = new Validator();
$result = $validator->validateSkillMd($skillMd);
[!TIP] The
validatealias method accepts a file path, directory path, raw content, or aSkillMdinstance and delegates to the appropriate method automatically.
Validation returns a Stolt\Ai\Skill\ValidationResult object. When the SKILL.md content is valid, a SkillMd
instance is available directly. The parsed metadata is also accessible as a Stolt\Ai\Skill\Metadata object.
use Stolt\Ai\Skill\Validator;
$validator = new Validator();
$result = $validator->validateContent('raw-skill-content');
if ($result->isInvalid()) {
foreach ($result->errors() as $error) {
echo $error . PHP_EOL;
}
// Raw metadata can still be inspected when parsing succeeded but validation failed.
$rawMetadata = $result->rawMetadata();
exit(1);
}
// Primary SkillMd abstraction — available on every valid result.
$skillMd = $result->skillMd(); // returns ?SkillMd (null when invalid)
// Or assert the SkillMd directly, which throws a LogicException when the result is invalid.
$skillMd = $result->toSkillMd();
// Use the SkillMd instance.
$name = $skillMd->name();
$description = $skillMd->description();
$body = $skillMd->body();
$tags = $skillMd->tags();
$version = $skillMd->version();
// Metadata object for field access with defaults.
$metadata = $result->metadata();
$allowedTools = $metadata?->get('allowed-tools', []);
$model = $metadata?->get('model');
$effort = $metadata?->get('effort');
// Markdown instructions after the YAML frontmatter.
$instructions = $result->body();
// Array representation for logging, JSON APIs, or integrations.
$arrayResult = $result->toArray();
echo sprintf('Skill "%s" is valid: %s', $name, $description) . PHP_EOL;
SkillMdBecause validateSkillMd() accepts a SkillMd instance and toSkillMd() returns one, validation results and
SkillMd objects round-trip cleanly:
use Stolt\Ai\Skill\Validator;
$validator = new Validator();
// Parse and validate raw content.
$result = $validator->validateContent($rawContent);
// Get the primary SkillMd abstraction.
$skillMd = $result->toSkillMd();
// Re-validate the SkillMd — e.g. after modifying it.
$revalidated = $validator->validateSkillMd($skillMd);
For an actual integration, the project list-skills-command can also be consolidated.
The validator checks that a SKILL.md document:
--- lines,name field,description field,tags, paths, and allowed-tools,disable-model-invocation.Supported frontmatter fields include:
namedescriptionwhen_to_useallowed-toolsdisable-model-invocationargument-hintargumentspathsmodeleffortmetadatacompatibilitylicenseauthorversiontagscomposer test
This library is licensed under the MIT license. Please see LICENSE.md for more details.
Please see CHANGELOG.md for more details.
This library idea is inspired by the work on agent-skills-validator by ronaldtebrake.
Please see CONTRIBUTING.md for more details.
How can I help you explore Laravel packages today?