Public Access
4009d68a7a
Universal: PR Check / Branch Policy (pull_request) Failing after 2s
Generic: Repo Health / Site Health (pull_request) Has been skipped
Generic: Repo Health / Access control (pull_request) Successful in 3s
Universal: PR Check / Validate PR (pull_request) Failing after 14s
Universal: PR Check / Secret Scan (pull_request) Successful in 15s
Generic: Project CI / Lint & Validate (pull_request) Successful in 57s
Platform: mokocli CI / Gate 1: Code Quality (pull_request) Successful in 2m4s
Universal: Build & Release / Promote to RC (pull_request) Has been skipped
RC Revert / Rename rc/ back to dev/ (pull_request) Has been skipped
Branch Cleanup / Delete merged branch (pull_request) Successful in 2s
Universal: Build & Release / Build & Release Pipeline (pull_request) Successful in 35s
Universal: Workflow Sync Trigger / Sync workflows to live repos (pull_request) Failing after 28m16s
Generic: Project CI / Tests (pull_request) Has been cancelled
Platform: mokocli CI / Gate 2: Unit Tests (8.1) (pull_request) Has been cancelled
Platform: mokocli CI / Gate 2: Unit Tests (8.2) (pull_request) Has been cancelled
Platform: mokocli CI / Gate 2: Unit Tests (8.3) (pull_request) Has been cancelled
Platform: mokocli CI / Gate 3: Self-Health Check (pull_request) Has been cancelled
Platform: mokocli CI / Gate 4: Governance (pull_request) Has been cancelled
Platform: mokocli CI / Gate 5: Template Integrity (pull_request) Has been cancelled
Platform: mokocli CI / CI Summary (pull_request) Has been cancelled
Universal: PR Check / Build RC Package (pull_request) Has been cancelled
Universal: PR Check / Report Issues (pull_request) Has been cancelled
Generic: Repo Health / Scripts governance (pull_request) Has been cancelled
Generic: Repo Health / Repository health (pull_request) Has been cancelled
Generic: Repo Health / Report: Scripts Governance (pull_request) Has been cancelled
Generic: Repo Health / Report: Repository Health (pull_request) Has been cancelled
The repo was renamed mokoplatform -> mokocli; this rewrites every stale
reference across the tree (case-sensitive):
MokoPlatform -> MokoCLI (DEFGROUP/INGROUP doc tags)
mokoplatform -> mokocli (repo URLs, /opt & /tmp paths, clone URLs,
EXCLUDE lists, XML xmlns + <root> namespace)
moko-platform -> moko-cli (marker files)
XML namespace URIs and ManifestParser::NAMESPACE_URI are changed in
lockstep so local manifest-vs-parser validation stays consistent. The
external standards.mokoconsulting.tech namespace endpoint must be updated
to match separately (tracked in #336).
Refs #336
Claude-Session: https://claude.ai/code/session_01WbGBN9VyRK61zczYWcCQ2i
100 lines
2.8 KiB
PHP
100 lines
2.8 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: MokoCLI.Scripts.Validate
|
|
* INGROUP: MokoCLI
|
|
* REPO: https://git.mokoconsulting.tech/MokoConsulting/mokocli
|
|
* PATH: /validate/check_dolibarr_module.php
|
|
* BRIEF: Validates Dolibarr module directory structure
|
|
*/
|
|
|
|
declare(strict_types=1);
|
|
|
|
require_once __DIR__ . '/../vendor/autoload.php';
|
|
|
|
use MokoCli\{CliFramework, SourceResolver};
|
|
|
|
/**
|
|
* Validates the required directory structure of a Dolibarr module repository.
|
|
*/
|
|
class CheckDolibarrModule extends CliFramework
|
|
{
|
|
/**
|
|
* Configure available arguments.
|
|
*/
|
|
protected function configure(): void
|
|
{
|
|
$this->setDescription('Validates Dolibarr module directory structure');
|
|
$this->addArgument('--path', 'Repository path to check', '.');
|
|
}
|
|
|
|
/**
|
|
* Run the Dolibarr module validation.
|
|
*
|
|
* @return int Exit code: 0 on pass, 1 on failure.
|
|
*/
|
|
protected function run(): int
|
|
{
|
|
$path = $this->getArgument('--path');
|
|
$passed = 0;
|
|
$failed = 0;
|
|
|
|
$this->section('Checking directory structure');
|
|
$srcName = SourceResolver::resolve($path);
|
|
SourceResolver::warnIfLegacy($path);
|
|
|
|
$srcDir = SourceResolver::resolveAbsolute($path);
|
|
if ($srcDir === null) {
|
|
$this->status(false, 'source/ or src/ directory exists');
|
|
$failed++;
|
|
} else {
|
|
$this->status(true, "{$srcName}/ directory exists");
|
|
$passed++;
|
|
}
|
|
|
|
if (!is_dir($path . "/{$srcName}/core/modules")) {
|
|
$this->status(false, "{$srcName}/core/modules/ directory exists");
|
|
$failed++;
|
|
} else {
|
|
$this->status(true, "{$srcName}/core/modules/ directory exists");
|
|
$passed++;
|
|
}
|
|
|
|
if (!is_dir($path . "/{$srcName}/langs")) {
|
|
$this->warning("Missing suggested directory: {$srcName}/langs/");
|
|
} else {
|
|
$this->status(true, "{$srcName}/langs/ directory exists");
|
|
$passed++;
|
|
}
|
|
|
|
$this->section('Checking module descriptor');
|
|
|
|
$descriptors = glob($path . "/{$srcName}/core/modules/mod*.class.php") ?: [];
|
|
if (empty($descriptors)) {
|
|
$this->status(false, 'Module descriptor found (mod*.class.php)');
|
|
$failed++;
|
|
} else {
|
|
$this->status(true, 'Module descriptor found', basename($descriptors[0]));
|
|
$passed++;
|
|
}
|
|
|
|
$this->printSummary($passed, $failed, $this->elapsed());
|
|
|
|
if ($failed > 0) {
|
|
return 1;
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
$script = new CheckDolibarrModule('check_dolibarr_module', 'Validates Dolibarr module directory structure');
|
|
exit($script->execute());
|