cassarco / markdown-tools
A package for Laravel that lets you run Laravel Validation and/or a handler function over markdown files in your application.
Installs: 4
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 3
pkg:composer/cassarco/markdown-tools
Requires
- php: ^8.3
- cassarco/league-commonmark-wikilinks: ^1.0.2
- spatie/laravel-package-tools: ^1.14.0
- symfony/dom-crawler: ^7.0
Requires (Dev)
- larastan/larastan: ^2.0.1
- laravel/pint: ^1.14
- nunomaduro/collision: ^7.8
- orchestra/testbench: ^8.8
- pestphp/pest: ^2.0
- pestphp/pest-plugin-arch: ^2.0
- pestphp/pest-plugin-laravel: ^2.0
- phpstan/extension-installer: ^1.1
- phpstan/phpstan: ^1.10
- phpstan/phpstan-deprecation-rules: ^1.0
- phpstan/phpstan-phpunit: ^1.0
- dev-main
- v1.0.0
- dev-dependabot/github_actions/stefanzweifel/git-auto-commit-action-7
- dev-dependabot/github_actions/actions/checkout-5
- dev-dependabot/github_actions/aglipanci/laravel-pint-action-2.6
- dev-dependabot/github_actions/stefanzweifel/git-auto-commit-action-6
- dev-dependabot/github_actions/dependabot/fetch-metadata-2.4.0
- dev-dependabot/github_actions/aglipanci/laravel-pint-action-2.5
- dev-dependabot/github_actions/dependabot/fetch-metadata-2.2.0
This package is auto-updated.
Last update: 2025-10-13 12:32:16 UTC
README
This is a package for Laravel that lets you run Laravel Validation and/or a handler function over markdown files in your application.
First, define one or more schemes in your configuration file. Then run the bundled command to process those schemes. Read on for more detailed instructions.
Installation
You can install the package via composer:
composer require cassarco/markdown-tools
You can publish the config file with:
php artisan vendor:publish --tag="markdown-tools-config"
This is the contents of the published config file:
return [ /* |-------------------------------------------------------------------------- | Schemes |-------------------------------------------------------------------------- | | Configure as many "schemes" as you like. Each scheme should contain a | path to a single markdown file or a folder containing markdown files. | */ 'schemes' => [ // Give each scheme a name for your own organisation. 'markdown' => [ // Give the path to a folder of markdown files or a single markdown file. 'path' => resource_path('markdown'), // Specify the validation rules for front-matter properties. 'rules' => [ // 'title' => 'required', ], // Define a handler for each markdown file. You will have access to file: // - front-matter values // - markdown // - html // - htmlWithToc // - toc 'handler' => function (MarkdownFile $file) { // Do Something with each Markdown File. }, ], ], /* |-------------------------------------------------------------------------- | League/Commonmark Settings |-------------------------------------------------------------------------- | | Configure settings for League Commonmark and its extensions. | */ 'common-mark' => [ 'heading_permalink' => [ 'symbol' => '#', 'html_class' => '', 'aria_hidden' => false, 'id_prefix' => '', 'fragment_prefix' => '', ], 'table_of_contents' => [ 'html_class' => 'table-of-contents', 'position' => 'top', 'style' => 'bullet', 'min_heading_level' => 1, 'max_heading_level' => 6, 'normalize' => 'relative', 'placeholder' => null, ], 'wikilinks' => [], 'front-matter' => [ 'yaml-parse-flags' => Yaml::PARSE_DATETIME ] ], ];
Usage
First define one or more schemes:
use function Laravel\Prompts\info; return [ 'schemes' => [ 'markdown' => [ 'path' => resource_path('markdown'), 'rules' => [ 'title' => 'required', ], 'handler' => function (MarkdownFile $file) { info("Processing {$file->frontMatter()['title']}"); }, ], ], ]
If you are following this example exactly, don't forget to import the info function:
use function Laravel\Prompts\info;
Now run the bundled command to process these schemes:
php artisan markdown-tools:process
In this example you will see a list of titles for every markdown file in the folder resources/markdown, provided that
they have a title property in the markdown's front matter.
If one or more files do not pass validation, then you will see a Laravel Validation error.
You should be able to use any of the Laravel Validation Rules that make sense in this context.
Notice that the handler makes a Markdown File $file available to you on which you will find the following methods:
// Get the markdown for the markdown file. $file->markdown() // Get the front matter as a php array $file->frontMatter() // Get the html for the markdown file without a table of contents. $file->html() // Get the html table of contents. $file->toc() // Get the markdown file as html with the table of contents embedded. $file->htmlWithToc() // Get the pathname for the markdown file $file->pathname()
In my case, I use this package to import the markdown files into my database for https://www.carlcassar.com:
Article::updateOrCreate([ 'slug' => $file->frontMatter()['slug'] ?? Str::slug($file->frontMatter()['title']), ], [ 'title' => $file->frontMatter()['title'], 'slug' => $file->frontMatter()['slug'] ?? Str::slug($file->frontMatter()['title']), 'description' => $file->frontMatter()['description'], 'table_of_contents' => $file->toc(), 'content' => $file->html(), 'image' => $file->frontMatter()['image'], 'tags' => $file->frontMatter()['tags'], 'published_at' => Carbon::make($file->frontMatter()['published_at']), 'deleted_at' => Carbon::make($file->frontMatter()['deleted_at']), 'created_at' => Carbon::make($file->frontMatter()['created_at']), 'updated_at' => Carbon::make($file->frontMatter()['updated_at']), ]);
Testing
composer test
Changelog
Please see CHANGELOG for more information on what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Security Vulnerabilities
If you find a bug that impacts the security of this package please send an email to security@cassar.co instead of using the issue tracker.
Credits
License
The MIT License (MIT). Please see License File for more information.

