Files
moko-platform/lib/Enterprise/ProjectPluginInterface.php
T
Jonathan Miller 1799401db5
Branch Policy Check / Verify merge target (pull_request) Successful in 1s
feat: add standard file headers to all 57 files missing them
- Add Copyright + FILE INFORMATION headers to 11 PHP enterprise classes
- Add FILE INFORMATION blocks to 9 PHP files with incomplete headers
- Add headers to 2 test files
- Add markdown comment headers to 27 index/README files
- Add headers to 5 root markdown files
- Add FILE INFORMATION to 4 files with existing but incomplete headers

All files now conform to moko-platform file header standard.

Authored-by: Moko Consulting

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-05-11 17:10:19 -05:00

133 lines
3.8 KiB
PHP

<?php
declare(strict_types=1);
/* 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: MokoStandards.Enterprise.Plugins
* INGROUP: MokoStandards.Enterprise
* REPO: https://git.mokoconsulting.tech/MokoConsulting/moko-platform
* PATH: /lib/Enterprise/ProjectPluginInterface.php
* BRIEF: Interface for project type plugins
*/
namespace MokoEnterprise;
/**
* Interface for project type-specific enterprise plugins
*
* Each project type (Joomla, Node.js, Python, etc.) implements this interface
* to provide type-specific validation, metrics, and management capabilities.
*
* @package MokoStandards\Enterprise
* @version 1.0.0
*/
interface ProjectPluginInterface
{
/**
* Get the project type this plugin handles
*
* @return string Project type (e.g., 'joomla', 'nodejs', 'python')
*/
public function getProjectType(): string;
/**
* Get the plugin name
*
* @return string Plugin name
*/
public function getPluginName(): string;
/**
* Get the plugin version
*
* @return string Plugin version
*/
public function getPluginVersion(): string;
/**
* Validate project configuration for this type
*
* @param array $config Project configuration
* @param string $projectPath Path to project directory
* @return array Validation result with 'valid' (bool), 'errors' (array), 'warnings' (array)
*/
public function validateProject(array $config, string $projectPath): array;
/**
* Collect project-specific metrics
*
* @param string $projectPath Path to project directory
* @param array $config Project configuration
* @return array Metrics data
*/
public function collectMetrics(string $projectPath, array $config): array;
/**
* Perform project health check
*
* @param string $projectPath Path to project directory
* @param array $config Project configuration
* @return array Health check result with 'healthy' (bool), 'score' (int), 'issues' (array)
*/
public function healthCheck(string $projectPath, array $config): array;
/**
* Get required files for this project type
*
* @return array List of required file patterns
*/
public function getRequiredFiles(): array;
/**
* Get recommended files for this project type
*
* @return array List of recommended file patterns
*/
public function getRecommendedFiles(): array;
/**
* Get configuration schema for this project type
*
* @return array JSON schema for project configuration
*/
public function getConfigSchema(): array;
/**
* Get best practices checklist
*
* @return array List of best practices with descriptions
*/
public function getBestPractices(): array;
/**
* Check if project is ready for release/deployment
*
* @param string $projectPath Path to project directory
* @param array $config Project configuration
* @return array Readiness result with 'ready' (bool), 'blockers' (array), 'warnings' (array)
*/
public function checkReadiness(string $projectPath, array $config): array;
/**
* Get plugin-specific commands
*
* @return array Array of command definitions
*/
public function getCommands(): array;
/**
* Initialize project with type-specific scaffolding
*
* @param string $projectPath Path to project directory
* @param array $options Initialization options
* @return array Result with 'success' (bool), 'message' (string), 'files_created' (array)
*/
public function initializeProject(string $projectPath, array $options = []): array;
}