bigins/imanager 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

bigins/imanager

最新稳定版本:2.0.0

Composer 安装命令:

composer require bigins/imanager

包简介

iManager — embeddable SQLite-backed CMF (Content Management Framework) for PHP.

README 文档

README

Embeddable, SQLite-backed Content Management Framework for PHP.

CI

iManager is a small CMS framework, not a CMS application: you embed it inside your own PHP app and get a typed domain model, a Repository layer over SQLite (JSON columns + FTS5), a Field-Type plugin system, file storage with on-demand thumbnails, and a CLI for schema and migration ops. Use it under any PHP front-end you like — a hand-rolled admin tool, a flat-file CMS, an internal API, a static-site generator that needs a typed content store. iManager has no opinion about how your application is shaped.

Status

Stable — 2.0.0 released 2026-05-13.

iManager 2.0 is a ground-up rewrite of the 1.x library. The 2.0 line replaces the flat var_export-based persistence with SQLite (JSON items.data column + generated columns + FTS5), introduces typed domain models, a Repository / Query layer, a CLI tool, and a clean field-type plugin system. The 1.x line remains available for hosts still on the embedded library.

Quickstart

Install via Composer:

composer require bigins/imanager:^2.0

Boot the full standard service graph with DefaultBootstrap::boot() and start using the repositories:

require __DIR__ . '/vendor/autoload.php';

use Imanager\DefaultBootstrap;
use Imanager\Domain\Category;
use Imanager\Domain\Field;
use Imanager\Domain\Item;
use Imanager\Enum\FieldType;
use Imanager\Storage\CategoryRepository;
use Imanager\Storage\FieldRepository;
use Imanager\Storage\ItemRepository;

$container = DefaultBootstrap::boot(
    databasePath: __DIR__ . '/data/imanager.db',
    uploadsPath:  __DIR__ . '/data/uploads',
    uploadsUrl:   '/uploads',
    cachePath:    __DIR__ . '/data/cache',
);

$categories = $container->get(CategoryRepository::class);
$fields     = $container->get(FieldRepository::class);
$items      = $container->get(ItemRepository::class);

// One-time setup: declare a category and its fields.
$blog = $categories->save(new Category(null, 'Blog', 'blog'));
$fields->save(new Field(null, $blog->id, 'title', 'Title', FieldType::Text));
$fields->save(new Field(null, $blog->id, 'body',  'Body',  FieldType::LongText));

// Persist an item.
$items->save(new Item(
    null,
    $blog->id,
    'hello-world',
    'Hello, world',
    data: ['title' => 'Hello, world', 'body' => 'First post.'],
));

// Read back.
foreach ($items->findByCategory($blog->id) as $item) {
    echo $item->name . "\n";
}

DefaultBootstrap runs the SQLite schema migrations on first use, so the database file is created and populated automatically. Subsequent composer update runs pick up new migrations the same way.

Need a leaner container or want to swap PDO / FileStorage / the event dispatcher? Use Imanager\Bootstrap::boot() instead and wire the parts you want — DefaultBootstrap is just a copy-paste-saver on top of it.

Concepts

iManager models content as four primitives:

  • Category — a kind of thing (e.g. Blog, Page, User). Each category has its own field schema and its own slug.
  • Field — a typed column on a category. The built-in field types are: text, longtext, editor, slug, password, integer, decimal, money, checkbox, dropdown, datepicker, hidden, array, fileupload, imageupload, filepicker. Custom types register via the FieldTypePlugin interface.
  • Item — an instance of a category. Field values live in a typed FieldValueBag exposed as $item->data; hot fields are also promoted to SQLite generated columns for indexable queries.
  • File — a binary asset (upload). Files are stored under data/uploads-2.0/<itemId>/<fieldId>/, with on-demand thumbnails for image uploads under thumbnail/<W>x<H>_<file>.

Domain mutations (*Created / *Updated / *Deleted events) are published through a PSR-14 dispatcher so host applications can hook into them (cache invalidation, file cleanup, etc.) without monkey- patching the storage layer.

CLI

iManager ships a Symfony-Console CLI at vendor/bin/imanager for operational tasks. The same commands run inside the Docker dev container (docker compose run --rm imanager vendor/bin/imanager …).

Command What it does
schema:status Show applied + pending schema migrations.
schema:migrate Apply pending migrations.
migrate:from-v1 One-shot import of a 1.x data/datasets/buffers/ tree. Supports --dry-run.
fts:rebuild Drop & rebuild the FTS5 index from items.
optimize PRAGMA optimize + VACUUM.
repair Integrity checks (orphan items, broken FKs, FTS sync).
dump Portable SQL dump.

Requirements

  • PHP 8.2+
  • Extensions: pdo_sqlite, mbstring, gd, dom, json
  • Composer 2

Development

The repo ships with a Docker-based dev environment (PHP 8.3 CLI + SQLite + Composer). You don't need anything else on your host machine.

docker compose build
docker compose run --rm imanager composer install
docker compose run --rm imanager composer ci

Available composer scripts:

Script Description
composer test Run PHPUnit.
composer lint Run PHP-CS-Fixer in dry-run.
composer format Auto-format with PHP-CS-Fixer.
composer stan Static analysis (PHPStan, level 8).
composer psalm Static analysis (Psalm, level 3).
composer ci Full pipeline (lint + stan + psalm + test).

Roadmap & docs

  • Master plan (multi-phase rewrite, phase status): docs/imanager-2.0-plan.md.
  • Changelog: CHANGELOG.md.
  • API reference: docs/api/ — index plus core detail pages for Domain, Storage, Query, and Field types.
  • Field-types cookbook: docs/field-types.md — how-to companion to the Field-types reference.
  • Query cookbook: docs/query-cookbook.md — predicate recipes, pagination, selector strings, full-text-search hand-off, performance.
  • Deployment guide: docs/deployment.md — host requirements, webserver + PHP-FPM configs, a production Dockerfile, SQLite at runtime, backups, scheduled maintenance.
  • Migration guide (1.x → 2.0): docs/migration-guide.md.

License

MIT — © bigin / Juri Ehret

统计信息

  • 总下载量: 0
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 10
  • 依赖项目数: 1
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-05-13

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固