ci4-cms-erp / ci4ms
Modular CodeIgniter 4 CMS featuring RBAC admin, theming, blog/page management, elFinder media integration, and CLI tooling for rapid customization.
Package info
Language:JavaScript
Type:project
pkg:composer/ci4-cms-erp/ci4ms
Fund package maintenance!
Requires
- php: ^8.2
- bertugfahriozer/ci4commonmodel: ^1.2
- bertugfahriozer/ci4seopro: ^v1.0.0
- bertugfahriozer/sql2migration: ^1.0
- ci4-cms-erp/ext_module_generator: ^1.1
- claviska/simpleimage: 4.4.0
- codeigniter4/framework: 4.7.1
- codeigniter4/settings: 2.2
- codeigniter4/shield: 1.3.0
- codeigniter4/translations: 4.7.0
- ezyang/htmlpurifier: 4.19
- gregwar/captcha: 1.3.0
- studio-42/elfinder: 2.1.66
Requires (Dev)
- fakerphp/faker: ^1.9
- mikey179/vfsstream: ^1.6
- phpunit/phpunit: ^10.5.16
- dev-master
- 0.31.4.0
- 0.31.3.0
- 0.31.2.0
- 0.31.1.0
- 0.31.0.0
- 0.28.6.0
- 0.28.5.0
- 0.28.4.0
- 0.28.3.0
- 0.28.0.0
- 0.27.0.0
- 0.26.3.4
- 0.26.3.3
- 0.26.3.2
- 0.26.3.1
- 0.26.3.0
- 0.26.2.0
- 0.26.1.0
- 0.26.0.0
- 0.25.3.0
- 0.25.2.0
- 0.25.1.0
- 0.25.0.43
- 0.25.0.39
- 0.25.0.30
- 0.25.0.2
- 0.25.0.1
- 0.25.0.0
- 0.24.0.60
- 0.24.0.45
- 0.24.0.42
- 0.24.0.27
- 0.24.0.20
- 0.24.0.19
- 0.24.0.18
- 0.24.0.16
- 0.24.0.0
- 0.23.1.0
- 0.23.0.2
- 0.23.0.1
- 0.23.0.0
- 0.21.3.7
- 0.21.3.6
- 0.21.3.5
- 0.21.3.4
- 0.21.3.3
- 0.21.3.2
- 0.21.3.1
- 0.21.3
- 0.21.2
- 0.21.1
- 0.21.0
- dev-new-modules
This package is auto-updated.
Last update: 2026-04-06 21:27:22 UTC
README
CI4MS is a CodeIgniter 4-based CMS skeleton that delivers a production-ready, modular architecture with RBAC authorization and theme support. It combines CMS workflows, developer-focused CLI commands, an extensible module system, and customizable front-end themes in a single package.
Key Features
- Authentication & RBAC:
Modules\Authhandles user login, lockouts, and password resets via CodeIgniter Shield. Permissions map toauth_permissions_pagesrecords. - Modular backend: Each feature ships as an independent module (Blog, Pages, Menu, Media, Users, Settings, Theme, etc.) under
modules/*. - Flexible content management: Page and blog entries include SEO metadata, categories, tags, and full comment workflows.
- Media & files: Includes elFinder-powered media management, a built-in file editor, and an in-panel log viewer.
- Theme system: The
public/templates/*structure and theModules\Thememodule enable installing or upgrading themes from ZIP packages. - Setup & automation: Offers a web-based installer (
/install) plus a single CLI command (php spark ci4ms:setup) for automated installation, default data seeding, and route generation. Module scaffolding is available viaphp spark make:module. - Docker support: Ships with a production-ready
Dockerfile,docker-compose.yml, and a GitHub Actions CI workflow out of the box. - SEO helpers:
ci4seoprobuilds meta tags and JSON-LD, whileCommonLibrarycentralizes email, breadcrumbs, and inline shortcode utilities.
Requirements
- PHP 8.2 or newer (
intl,json,mbstring,gd,curl,opensslextensions required) - Composer 2.5+
- MySQL / MariaDB (or any CodeIgniter 4-supported driver)
- Writable directories:
writable/,public/uploads/, optionallypublic/templates/
See composer.json for the full dependency list (e.g. bertugfahriozer/ci4commonmodel, bertugfahriozer/sql2migration, ci4-cms-erp/ext_module_generator, claviska/simpleimage, gregwar/captcha, studio-42/elfinder).
ðŠī Project Activity
Installation
Fresh Project (recommended)
composer create-project ci4-cms-erp/ci4ms myproject
cd myproject
Clone Existing Repository
git clone <repo-url> ci4ms cd ci4ms composer install
Docker (recommended for development & CI)
cp env .env # configure database, baseURL, etc. cp app/Config/DefaultRoutes.php app/Config/Routes.php docker compose up -d --build docker exec ci4ms_app composer install docker exec ci4ms_app php spark ci4ms:setup
Refer to DOCKER_SETUP.md for full Docker configuration details.
Environment & Configuration
- Create your
.envfrom the template:
cp env .env
-
Update these core settings in
.env:app.baseURLdatabase.default.*- Optional:
cookie.*,honeypot.*,security.*
-
Prepare the routes file:
cp app/Config/DefaultRoutes.php app/Config/Routes.php
- If you prefer the web installer, open
/installin the browser and follow the wizard. Use the CLI step below to skip the wizard.
One-Command Setup (CLI)
php spark ci4ms:setup
This single command runs all migrations, seeds default data (modules, permissions, sample content), and creates the initial administrator account. No separate migrate or seed commands are needed.
Run the Dev Server
php spark serve
Access the backend via: https://<domain>/backend
Directory Layout
app/ Application code (controllers, config, libraries, filters)
modules/ Feature modules (Auth, Backend, Blog, etc.)
public/
index.php Front controller
be-assets/ Admin UI build artifacts (CSS/JS)
templates/ Front-end themes
media/ Media storage (must be writable)
writable/ Cache, logs, temporary files (must be writable)
vendor/ Composer packages
.docker/ Dockerfile, Apache, and PHP configuration
docs/ Developer documentation
Key files:
app/Commands/â CLI tooling (make:a*,create:route,ci4ms:setup).app/Filters/Ci4ms.phpâ Install guard, maintenance mode redirect, menu cache.app/Config/DefaultRoutes.phpâ Routes template; copy toRoutes.phpon setup.modules/*â Each module includes its ownConfig/Routes.php,Controllers,Models,Views,Language,Libraries,Filters.public/templates/â Theme assets; each theme requiresinfo.xmlandscreenshot.png.writable/â Cache, logs, temporary files.
Modules
| Module | Purpose | Highlights |
|---|---|---|
| Auth | Authentication lifecycle | Shield-based, CAPTCHA, email activation, reset tokens |
| Backend | Admin shell | Dashboard stats, shared base controller |
| Blog | Blog CRUD | Categories, tags, comments, bad-word filters |
| Pages | Static page management | SEO fields, inline shortcode parsing |
| Menu | Menu builder | Drag-and-drop ordering, slug helpers |
| Media | Media manager | elFinder integration, optional WebP conversion |
| Fileeditor | Project file editor | Safe read/write/rename/move/delete |
| Settings | System configuration | Company/social/mail settings, encrypted SMTP password |
| Users | User & role management | Shield groups, reset tracking |
| Methods | Route â permission mapping | Module toggling, router scan |
| Logs | Log viewer | Browses CodeIgniter log files inside the backend |
| ModulesInstaller | Module ZIP installer | Upload + cache invalidation |
| Theme | Theme manager | ZIP upload, DB migration support, duplicate checks |
| Install | Web installer | Creates .env, triggers migrations |
| Backup | Database backup manager | Create, download, and restore backups |
| DashboardWidgets | Dashboard statistics | Modular widget system for admin overview |
| LanguageManager | Language file manager | Edit and manage translation files from the backend |
See docs/architecture.md for deeper architectural notes.
CLI Commands
| Command | Description |
|---|---|
php spark ci4ms:setup |
Full automated installation: migrations, seeding, default data |
php spark make:module Blog |
Scaffold a new module (Config, Controllers, Views, language files) |
php spark make:abview dashboard |
Generate a backend view from the AdminLTE template |
php spark create:route |
Rebuild app/Config/Routes.php from the template |
php spark migrate --all |
Run all pending migrations across modules |
php spark cache:clear |
Clear all application caches |
Standard CodeIgniter commands (php spark db:seed, php spark key:generate, etc.) are also available.
Developer Notes
- Cache keys:
settings(24h),menus(24h),{userId}_permissions. Clear withphp spark cache:clearorcache()->delete(). - Base controller: Extend
Modules\Backend\Controllers\BaseControllerfor new backend controllers; it prepares session user, navigation, mail settings, and shared data. - Permissions: Register new secured routes in
Modules\Methods(or via the database) so the permission filter recognizes them. - Slug generation:
seflink()handles transliteration (including Turkish characters). - Form security: Global CSRF is enabled; backend AJAX endpoints opt out via
BackendConfig::$csrfExcept. - Comment moderation:
CommonLibrary::commentBadwordFilteringhandles bad word filtering and moderation rules. - Theme uploads: Each theme must include
info.xmlandscreenshot.png; missing files trigger a backend warning.
Testing & Maintenance
composer testâ runs PHPUnit.- The GitHub Actions workflow (
.github/workflows/docker-test.yaml) automatically builds the Docker image and runs migrations on every push tomaster. - Maintenance mode: When
settings.maintenanceMode.scalar == 1, theCi4msfilter redirects visitors tomaintenance-mode. - Security:
FileeditorandMediaenforcerealpathguards. Limit access in production environments.
Additional Docs
docs/architecture.mdâ Architecture, flow, permissions, and extension guidance.docs/developer-handbook.mdâ Environment setup, coding standards, deployment checklist.docs/theme_development.mdâ Theme folder structure, routing, andbase.phpvariables.DOCKER_SETUP.mdâ Docker environment configuration and usage.CHANGELOG.mdâ Full release history.
Questions or contributions? Open an issue or pull request.
ð Security Hall of Fame
A huge thank you to the security researchers who have helped make ci4ms more secure by finding and reporting vulnerabilities.
| Contributor | Contribution | Date |
|---|---|---|
| Lars van Mil | Identified Critical RCE and Information Disclosure vulnerabilities. | Jan 2026 |
| 0xAlchemist | Bugmith [BUGX] | Identified Critical Stored DOM XSS vulnerabilities across Company Info, Social Media, and Mail Settings modules, and a Session Invalidation flaw, leading to Account Takeover, Privilege Escalation, and potential Platform Compromise. | Feb 2026 |
| peeefour | Identified Stored DOM XSS vulnerabilities leading to Account Takeover. | Feb 2026 |
| Hunter. | Identified Critical Stored XSS in Backend & Blog modules allowing Session Hijacking. | Feb 2026 |
| m1scher | Assisted with vulnerability triaging and security testing. | Feb 2026 |
| alpernae | Assisted with vulnerability triaging and security testing. | Feb 2026 |
| offset | Identified Critical vulnerabilities including multiple Stored XSS, Authorization Bypass in Fileeditor, Install Guard Bypass, and CRLF Injection. | Apr 2026 |
If you find a security vulnerability, please report it via Security Policy.