PHPackages                             buni/cms-core - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Framework](/categories/framework)
4. /
5. buni/cms-core

ActiveComposer-plugin[Framework](/categories/framework)

buni/cms-core
=============

Buni CMS - turns a Laravel app into a full CMS

v1.4.57(3mo ago)137MITPHPPHP &gt;=8.0

Since Jan 23Pushed 3mo agoCompare

[ Source](https://github.com/dfrey3820/buni)[ Packagist](https://packagist.org/packages/buni/cms-core)[ RSS](/packages/buni-cms-core/feed)WikiDiscussions main Synced 1mo ago

READMEChangelogDependencies (12)Versions (60)Used By (0)

Buni CMS
========

[](#buni-cms)

This package provides a CMS scaffold for Laravel. It includes an installer, themes and plugins scaffolding, basic models, migrations and stubs for dashboard features.

Install via composer (local path during development):

composer require buni/cms:dev-main

Updater
-------

[](#updater)

This package includes a built-in updater service (`Buni\\Cms\\Services\\Updater`) which can check a remote JSON endpoint (configured via `buni.updates.endpoint`) that must return at least:

```
{
	"version": "1.2.3",

Post-install behavior
---------------------

When this package is installed via Composer it will run migrations automatically (if possible) and then attempt to detect whether Buni CMS is already initialized.

- If no admin users are present the installer will prompt (interactive) to either open the web installer at `APP_URL/buni/install` or run the CLI installer `php artisan buni:install --yes`.
- If `APP_URL` is not set the installer will print the installer URL and instructions to set `APP_URL`.

For non-interactive environments (CI or --no-interaction) the plugin will not attempt to open a browser or run interactive prompts; it will log instructions to complete installation manually.

If you prefer to run installation yourself after require, visit:

	/buni/install

or run:

```bash
php artisan buni:install --yes

```

```
"url": "https://example.com/releases/buni-cms-1.2.3.zip",
"sha256": ""

```

}

```

- If `sha256` is present the updater verifies the downloaded ZIP matches the checksum and will abort on mismatch.
- If a release is signed the metadata can include a `signature` (base64 of the signature) or `signature_url` to fetch the signature. The updater uses the configured public key at `buni.updates.public_key` to verify the release using SHA256+RSA (OpenSSL). The updater will abort if signature verification fails.
- The updater extracts the ZIP to a temporary location and performs an atomic swap (rename) of the package directory, keeping a timestamped backup directory for rollback.
- The updater supports `dry` (preview) and `migrate` options when invoked via the `buni:update` command.

Security notes
--------------

- Provide signed releases or at minimum a checksum in the update metadata to detect tampering.
- The current implementation performs a best-effort atomic swap via filesystem renames; on some filesystems (network mounts) atomicity may not be guaranteed.
- Test updates in a safe environment before applying to production. Backups are kept under the package parent directory named `buni_update_backup_`.

Usage
-----

Via artisan:

```

php artisan buni:update --yes --migrate

```

Or call the service from code and provide a Guzzle client for testing:

```

$updater = new Buni\\Cms\\Services\\Updater(); $updater-&gt;run($command, \['migrate' =&gt; true\]);

```

```

###  Health Score

40

—

FairBetter than 88% of packages

Maintenance79

Regular maintenance activity

Popularity9

Limited adoption so far

Community8

Small or concentrated contributor base

Maturity53

Maturing project, gaining track record

 Bus Factor1

Top contributor holds 99% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

###  Release Activity

Cadence

Every ~0 days

Total

58

Last Release

112d ago

### Community

Maintainers

![](https://www.gravatar.com/avatar/e283f86a028f88cb1be7265fafe40e1a249749cdbabec6226ccae49e58adb2d2?d=identicon)[digitalstepscreatives](/maintainers/digitalstepscreatives)

---

Top Contributors

[![dfrey3820](https://avatars.githubusercontent.com/u/168394379?v=4)](https://github.com/dfrey3820 "dfrey3820 (98 commits)")[![rhoggs-bot-test-account](https://avatars.githubusercontent.com/u/22551806?v=4)](https://github.com/rhoggs-bot-test-account "rhoggs-bot-test-account (1 commits)")

###  Code Quality

TestsPHPUnit

### Embed Badge

![Health badge](/badges/buni-cms-core/health.svg)

```
[![Health](https://phpackages.com/badges/buni-cms-core/health.svg)](https://phpackages.com/packages/buni-cms-core)
```

###  Alternatives

[bagisto/bagisto

Bagisto Laravel E-Commerce

26.2k161.6k7](/packages/bagisto-bagisto)[krayin/laravel-crm

Krayin CRM

22.0k32.8k1](/packages/krayin-laravel-crm)[unopim/unopim

UnoPim Laravel PIM

9.4k1.8k](/packages/unopim-unopim)[blair2004/nexopos

The Free Modern Point Of Sale System build with Laravel, TailwindCSS and Vue.js.

1.2k2.3k](/packages/blair2004-nexopos)[laravel-enso/core

Main requirement &amp; dependency aggregator for Laravel Enso

3463.6k138](/packages/laravel-enso-core)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
