Files
MokoCLI/validate/check_xml_wellformed.php
T
Jonathan Miller ab9f2d5674
Generic: Repo Health / Scripts governance (push) Blocked by required conditions
Generic: Repo Health / Repository health (push) Blocked by required conditions
Generic: Repo Health / Report Issues (push) Blocked by required conditions
Generic: Repo Health / Access control (push) Successful in 1s
Generic: Repo Health / Site Health (push) Has been skipped
Universal: Auto Version Bump / Version Bump (push) Successful in 8s
feat: security advisory aggregator, manifest API rewrite, namespace rename (#150, #283)
- Add `security:advisories` command — cross-repo CVE scanner via composer audit
  with checkpoint resumability, severity filtering, and auto-issue creation
- Rewrite `manifest:read` to use Gitea manifest API as primary source with
  auto-detection fallback from source tree (no more manifest.xml dependency)
- Rename MokoStandards namespace → MokoCli across all files
- Rename MokoEnterprise namespace → MokoCli across all files
- Rename MokoStandardsParser class → ManifestParser
- Fix composer.json autoload paths: src/ → source/
2026-06-20 20:21:26 -05:00

87 lines
2.6 KiB
PHP

#!/usr/bin/env php
<?php
/* Copyright (C) 2026 Moko Consulting <hello@mokoconsulting.tech>
*
* This file is part of a Moko Consulting project.
*
* SPDX-License-Identifier: GPL-3.0-or-later
*
* FILE INFORMATION
* DEFGROUP: MokoPlatform.Scripts.Validate
* INGROUP: MokoPlatform
* REPO: https://git.mokoconsulting.tech/MokoConsulting/mokoplatform
* PATH: /validate/check_xml_wellformed.php
* BRIEF: Validates that all tracked XML files are well-formed
*/
declare(strict_types=1);
require_once __DIR__ . '/../vendor/autoload.php';
use MokoCli\CliFramework;
/**
* Runs `xmllint --noout` against all tracked *.xml files and reports errors.
*/
class CheckXmlWellformed extends CliFramework
{
/**
* Configure available arguments.
*/
protected function configure(): void
{
$this->setDescription('Validates that all tracked XML files are well-formed');
$this->addArgument('--path', 'Repository path to check', '.');
}
/**
* Validate XML well-formedness for all tracked XML files.
*
* @return int Exit code: 0 if all files pass, 1 if any are malformed.
*/
protected function run(): int
{
$path = $this->getArgument('--path');
$output = shell_exec('git -C ' . escapeshellarg($path) . " ls-files '*.xml' 2>/dev/null") ?? '';
$files = array_values(array_filter(explode("\n", $output)));
$total = count($files);
$passed = 0;
$errors = 0;
$this->section('Validating XML well-formedness');
if ($total === 0) {
$this->log('INFO', 'No tracked XML files found');
$this->printSummary(0, 0, $this->elapsed());
return 0;
}
foreach ($files as $i => $file) {
$this->progress($i + 1, $total, $file);
$fullPath = $path . '/' . $file;
if (!is_file($fullPath)) {
continue;
}
$out = [];
$code = 0;
exec('xmllint --noout ' . escapeshellarg($fullPath) . ' 2>&1', $out, $code);
if ($code !== 0) {
$this->progress($i + 1, $total, '', true);
$this->status(false, $file, implode('; ', array_slice($out, 0, 2)));
} else {
$passed++;
}
$errors += ($code !== 0) ? 1 : 0;
}
$this->progress($total, $total, '', true);
$this->printSummary($passed, $errors, $this->elapsed());
return $errors === 0 ? 0 : 1;
}
}
$script = new CheckXmlWellformed('check_xml_wellformed', 'Validates that all tracked XML files are well-formed');
exit($script->execute());