Skip to main content

Core library for the Score portable AI knowledge format

Project description

score-core

Core library for the Score portable AI knowledge format.

Score is a human-readable, LLM-agnostic format for encoding organisational knowledge as portable skill files. score-core provides the schema, parser, serialiser, validator, library validator, Context API models, and Recording models that any Score-compatible tool needs.

Full format specification: score_spec.md Writing skills: WRITING_SKILLS.md

Install

pip install score-core

Quickstart

Validate a skill file

score validate path/to/my-skill.md
score validate path/to/skills/ --strict

Validate programmatically

from score import parse_skill_file, validate_skill

skill = parse_skill_file("path/to/my-skill.md")
payload = {
    "name": skill.name,
    "description": skill.description,
    "version": skill.version,
    "owner": skill.owner,
    "triggers": list(skill.triggers),
    "tags": list(skill.tags),
    "active": skill.active,
    "created": skill.created,
    "updated": skill.updated,
    "body": skill.body,
}

result = validate_skill(payload)
if not result["valid"]:
    for error in result["errors"]:
        print(f"error: {error['field']}{error['message']}")
for warning in result["warnings"]:
    print(f"warning: {warning['field']}{warning['message']}")

Work with the Pydantic model

from score import parse_skill_file_pydantic, validate_skill_file

skill_file = parse_skill_file_pydantic("path/to/my-skill.md")
result = validate_skill_file(skill_file)
print(result)  # ValidationResult(valid=True, errors=[], warnings=[...], ...)

Library validation

from score import validate_library

skills = [...]  # list of full skill dicts
report = validate_library(skills)
print(report["summary"]["overall_health"])  # "good" | "warning" | "critical"

Migrate existing skills to v0.1.1

score migrate path/to/skills/ --to 0.1.1           # dry run
score migrate path/to/skills/ --to 0.1.1 --apply   # write changes

CLI commands

Command Purpose
score validate <path> Validate a single file or directory
score library-check <dir> Full library report (overlaps, coverage)
score governance-init <dir> Report skills missing v0.1.1 governance fields
score verify-recording <file> Verify Recording hash chain integrity
score migrate <dir> --to 0.1.1 Add safe defaults for new spec fields

What's in the package

  • score.schema — Pydantic models (SkillFile, UITheme, ExecutionHints) and field constants
  • score.parser.mdSkill (runtime dataclass) and SkillFile (Pydantic)
  • score.serialiserSkill.md with YAML frontmatter
  • score.validator — three-tier validation (errors, warnings, hints)
  • score.library_validator — cross-skill checks and fix proposal
  • score.context_api — request/response models for the Score Context API
  • score.recording — audit log entry models and hash chain utilities
  • score.cliscore command-line interface

Relationship to Maestro

Maestro is the commercial skill management product built on the Score format. score-core is the shared library that Maestro and any other Score-compatible tool import. Maestro uses score-core internally; it is not a Maestro dependency.

Version

Current: 0.1.0 — supports Score format v0.1.1 with governance metadata fields.

Licence

MIT. See LICENCE.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

score_core-0.1.2.tar.gz (43.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

score_core-0.1.2-py3-none-any.whl (34.0 kB view details)

Uploaded Python 3

File details

Details for the file score_core-0.1.2.tar.gz.

File metadata

  • Download URL: score_core-0.1.2.tar.gz
  • Upload date:
  • Size: 43.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.6

File hashes

Hashes for score_core-0.1.2.tar.gz
Algorithm Hash digest
SHA256 c90983b4d4d2a54a9de71cd8752de992b21978087e5b214352307ac495b19ade
MD5 c4b60796e7b9bba5fbda66f611cb97b2
BLAKE2b-256 96296aa46d8027030d3ecc7247ca8247ee4226d5d251785e9569be6906418086

See more details on using hashes here.

File details

Details for the file score_core-0.1.2-py3-none-any.whl.

File metadata

  • Download URL: score_core-0.1.2-py3-none-any.whl
  • Upload date:
  • Size: 34.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.6

File hashes

Hashes for score_core-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 775c6a5ed9d49af3b0d3ca6721b6bb424f7b43df8364baf33655d8b219217843
MD5 7933c07bcd2b0415f929e500d084aea8
BLAKE2b-256 fdb15c549ec41c5ba668b55b76070e0bbdb6b7033aeb4115e1a33532ad795b15

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page