shiros/luna-system

Luna Module - System

Installs: 103

Dependents: 1

Suggesters: 0

Security: 0

Stars: 0

Forks: 0

pkg:composer/shiros/luna-system

v2.0.0 2025-12-11 19:22 UTC

README

pipeline status coverage report

# Luna Module - System A PHP **System Module** designed for handling OS abstraction, filesystem operations, package management, and system bridges in the **Luna Framework**. **Robust**, **Portable**, and **Developer-Friendly** – Simplifying interaction with the underlying operating system in your PHP projects.

[[TOC]]

ℹ️ About the Project

This project is developed in PHP 8.2 and is part of the Luna Framework ecosystem.

The Luna System Module provides a structured way to interact with the operating system, manage files and directories, execute system commands, and handle package resources in a consistent and framework‑oriented way.

Detailed documentation is available in the Wiki: Luna Wiki.

Key Features

  • OS Abstraction Layer: Unified API for OS‑level features (Linux, Windows, etc.).
  • Filesystem Operations: High‑level helpers for reading, writing, copying, syncing, and removing files/directories.
  • Bridge‑Based Resolution: Smart bridge system to resolve the concrete OS implementation based on the runtime environment.
  • Package Management Utilities: Helpers for copying package files/directories, including template‑aware operations.
  • Command Execution: Integration with system executors for running shell commands safely.
  • Dependency Injection Integration: Seamless usage with Luna’s DI and container components.
  • PSR‑4 Autoloading: Clean and autoloaded code structure.
  • PHP 8.2 Features: Implements modern PHP features for clean, predictable code.

🔧 Dependencies

It uses PHP 8.2+, ensuring compatibility with modern features.

This module depends on the following:

Refer to the composer.json file for additional details.

⚙️ Setup and Installation

To use the Luna System module, follow the steps below:

Step 1: Install via Composer

Ensure Composer is installed, then execute the following in your root project folder:

composer require shiros/luna-system

Autoloading is handled by Composer (PSR‑4). When used within a Luna application, the module is auto‑discovered via composer.jsonluna.module:

{
    "luna": {
        "module": "Luna\\System\\Module"
    }
}

Step 2: Autoload the Module

The module supports PSR-4 autoloading. If you're using the Luna Framework, it’s automatically available via the Luna module declaration. Otherwise, make sure to include Composer’s autoloader:

require 'vendor/autoload.php';

🚀 Usage Example

Refer to the official documentation for advanced examples and further details about system bridges, OS utilities, filesystem helpers, and package operations.

📄 Testing

This project uses PHPUnit for testing, you can run the test suite as follows.

Step 1: Install development dependencies

Before running the test suite, ensure all project dependencies, including development dependencies, are installed. Use Composer to handle this:

composer install

This command will fetch all the required libraries and ensure your project setup is complete.

Step 2: Execute the Test Suite

Once dependencies are installed, you can execute the test suite using PHPUnit.
This ensures all the functionality of the framework is working as expected:

vendor/bin/phpunit --configuration phpunit.xml --colors=always

The test results will be displayed in your console. Colored output simplifies understanding the testing status:

  • Green: Tests passed successfully.
  • Red: Tests failed.
  • Yellow: Warnings or skipped tests.

For more details on the tests, explore the /tests directory. It contains comprehensive unit tests covering various parts of the framework.

📃 License

This project is licensed under the MIT License, allowing you to use and modify this project freely.
See the LICENSE file for more details.

👨‍💻 Authors and Contributors

This project was created and is maintained by Alexandre Caillot (Shiroe_sama), with contributions from the community.

Authors

Contributors

We thank the following contributors for making this project better: