- exod: gRPC daemon with auto-migration, graceful shutdown (SIGINT/SIGTERM), configurable listen address and data directory via flags - exo: CLI client with import (YAML artifacts), tag add/list, cat add/list, search by tag commands; connects via EXO_ADDR env var - Add bin/ to .gitignore Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
3.5 KiB
3.5 KiB
Progress
Tracks implementation progress against the phases in PROJECT_PLAN.md.
Phase 1: Foundation — COMPLETE
Deliverables:
- Go module (
go.mod) atgit.wntrmute.dev/kyle/exo corepackage:Header,Metadata,Value,ObjectType,NewUUID,MapFromList/ListFromMap- SQLite migration framework with embedded SQL files (
db/migrations/) - Initial schema migration (
001_initial.sql): 13 tables covering shared infrastructure, bibliographic, and artifact repository - Database access layer:
Open(with WAL, foreign keys, busy timeout),StartTX/EndTX,ToDBTime/FromDBTime configpackage:Configstruct with paths for database, blob store, Minio endpoint, gRPC listen address.golangci.yaml— strict linting (errcheck, govet, gosec, staticcheck, revive, errorlint)Makefile— vet, lint, test, build targets- Full test coverage for all packages (core, db, config)
Files created:
go.mod,go.sumcore/core.go,core/core_test.godb/db.go,db/db_test.go,db/migrations/001_initial.sqlconfig/config.go,config/config_test.go.golangci.yaml,Makefile
Phase 2: Artifact Repository — COMPLETE
Deliverables:
artifactspackage:Artifact,Snapshot,BlobRef,Citation,Publishertypes withGet/StoremethodsMIMEtype alias for clarity- Tag and category management:
CreateTag/GetTag/GetAllTags,CreateCategory/GetCategory/GetAllCategories,GetArtifactIDsForTag - Metadata store/retrieve operations (
StoreMetadata/GetMetadata) blobpackage: Content-addressable blob store (SHA256 hashing, hierarchical directory layout, read/write/exists)- YAML import:
ArtifactYAML,SnapshotYAML,CitationYAMLwithToStd()conversions andLoadArtifactFromYAML - Protobuf message definitions for all artifact types (
proto/exo/v1/common.proto,proto/exo/v1/artifacts.proto) - gRPC service:
ArtifactServicewith create/get artifacts, store/retrieve blobs, manage tags/categories, search by tag serverpackage: Full gRPC service implementation with proto-domain conversion helpers- buf.yaml for proto linting, buf.gen.yaml for code generation
- Full test coverage for all packages (artifacts, blob, server)
Files created:
blob/blob.go,blob/blob_test.goartifacts/artifact.go,artifacts/citation.go,artifacts/publisher.go,artifacts/snapshot.goartifacts/metadata.go,artifacts/tagcat.go,artifacts/yaml.go,artifacts/artifacts_test.goproto/exo/v1/common.proto,proto/exo/v1/artifacts.protoproto/buf.yaml,proto/buf.gen.yamlproto/exo/v1/*.pb.go(generated)server/server.go,server/server_test.go
Phase 3: CLI Tools — COMPLETE
Deliverables:
exodserver binary: gRPC daemon with startup, graceful shutdown (SIGINT/SIGTERM), auto-migration, flag-based configuration (-listen,-base,-version)exoCLI binary:import(YAML artifacts),tag add/list,cat add/list,search tag- YAML import parser in CLI (converts to proto messages for gRPC transport)
- Environment variable support (
EXO_ADDRfor server address) - Makefile
buildtarget produces both binaries inbin/ - Version injection via
-ldflags
Files created:
cmd/exod/main.gocmd/exo/main.go,cmd/exo/yaml.go