Download the PHP package dynamik-dev/modman without Composer
On this page you can find all versions of the php package dynamik-dev/modman. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download dynamik-dev/modman
More information about dynamik-dev/modman
Files in dynamik-dev/modman
Package modman
Short Description Headless Laravel content-moderation package with a tiered grader pipeline.
License MIT
Informations about the package modman
modman
Headless Laravel content moderation. Users flag content, a tiered grader pipeline (denylist, LLM, optional heuristics and hosted classifiers) evaluates it, and a configurable policy either auto-resolves the report or routes it to a human.
modman ships no UI. It dispatches events and exposes three HTTP endpoints; you wire the rest.
Install
Optional: publish the default denylist and LLM prompt resources.
Set queue env vars if you do not want the default modman queue:
One-page example
Make a host model reportable:
Let a user flag a post:
That creates a Report in the pending state, fires ReportCreated, and queues RunModerationPipeline. The orchestrator walks the configured pipeline (denylist then LLM by default) until the policy either auto-resolves the report or routes it to a human.
React to the outcome:
Register the listener however you prefer (Laravel event discovery, a provider, etc.).
HTTP endpoints
The package registers three routes under the prefix modman, defaulting to the api and auth middleware. Reports return moderator-only data (free-text reasons, LLM evidence, full decision history), so the routes ship behind authentication and an explicit authorization gate.
| Method | Path | Name |
|---|---|---|
| GET | /modman/reports/{report} |
modman.reports.show |
| POST | /modman/reports/{report}/resolve |
modman.reports.resolve |
| POST | /modman/reports/{report}/reopen |
modman.reports.reopen |
resolve takes { "decision": "approve" | "reject", "reason": "optional string" }. reopen takes an optional reason. Both require $request->user() to be an Eloquent Model and to pass the matching gate.
Disabling or overriding the routes
When routes.enabled is false, the package registers no HTTP routes — wire your own controllers if you need a different shape.
Authorization gates
modman defines three gates with fail-closed defaults:
modman.view— checked beforeGET /modman/reports/{report}modman.resolve— checked beforePOST /modman/reports/{report}/resolvemodman.reopen— checked beforePOST /modman/reports/{report}/reopen
All three deny by default (every request returns 403) until the host overrides them. Register replacements in any service provider that boots before ModmanServiceProvider, or simply at runtime — Gate::has() keeps the package from clobbering your definition:
The controllers respond with 401 when no user is authenticated, 403 when the authenticated identity is not an Eloquent Model or the gate denies the action.
Where to go next
docs/pipeline.md— the finite-state machine and how to reorder the pipelinedocs/graders.md— every shipped grader and its configdocs/policy.md—ConfigDrivenPolicyand how to swap itdocs/events.md— every event and a listener exampledocs/writing-a-custom-grader.mddocs/writing-a-custom-policy.mddocs/adr/— architectural decision records
Requirements
- PHP 8.4+
- Laravel 12 or 13
- spatie/laravel-model-states ^2.7
License
MIT.
All versions of modman with dependencies
ext-intl Version *
ext-mbstring Version *
illuminate/contracts Version ^12.0|^13.0
illuminate/database Version ^12.0|^13.0
illuminate/http Version ^12.0|^13.0
illuminate/queue Version ^12.0|^13.0
illuminate/support Version ^12.0|^13.0
spatie/laravel-model-states Version ^2.7