cammanderson / mmb
Minimalist markdown blogging tool
Requires
- php: >=5.4.0
- deralex/yaml-config-service-provider: ~1
- erusev/parsedown: dev-master
- silex/silex: ~1.2
- symfony/finder: ~2.5
- symfony/process: dev-master
- symfony/yaml: ~2.4
Requires (Dev)
- phpunit/phpunit: ~4.1
Suggests
- erusev/parsedown-extra: dev-master
This package is not auto-updated.
Last update: 2024-12-31 04:17:54 UTC
README
Focus on writing clean blog articles using simple markdown. Include beautiful colourful fenced code blocks that people will love.
Minimalistic approach, based on silex. Chose where to store and retrieve your markdown, I'm using a separate git repository. Articles are pushed here and mapped by the FileArticleService.
Usage
For your application:
- Add to your composer
- Add to your Silex application
- Install Pygments
- Specify the pygmentize bin
- Specify the path to the articles (default file provider)
Composer
{ "require": { "cammanderson/mmb" : "dev-master" } }
Silex Service Provider and Route
You can add the article service and then use it in your application as needed.
... $app->register(new MMB\ArticleServiceProvider()); ... // Controller $articleController = function (Silex\Application $app, MMB\Article $article) { return $app['twig']->render('article.html.twig', array( 'article' => $article, 'highlighter' => $app['markdown_parser_highlighter'] )); }; // Add the article route $app->get('/article/{article}', function (MMB\Article $article) use ($app, $articleController) { return $articleController($app, $article); })->assert('article', '.+') ->convert('article', 'article_service:getArticle'); ...
Default Configuration
Currently needs a couple of elements set to app['config']['parameters']
parameters: mmb_file_path: ../content pygments_bin: /opt/local/bin/pygmentize-2.7
Consider using a YAML config provider for silex deralex/yaml-config-service-provider
Writing Articles
Using the FileArticleService, it will take a configuration path to look for files. Articles are mapped by key, where the key matches the filename.
2014-08-10_my-article.md
2014-08-12_my-other-article.md
Hosting articles on github
It is easily possible to place the articles in your github repository and connect to it using GithubService for mmd.
Extending
Alternative location for Articles
You can always implement your own ArticleService to source the articles from another location.
class MyArticleService extends AbstractArticleService { public function getArticle($key) { // TODO: Implement your own method to locate the article $articleContents = '...'; // Create the article $article = $this->provider->provide($key, $articleContents); // ... Apply further properties your Service supports // Return return $article; } }
Now register to the dependency injector (remember to provider the article provider).
$app['article_service'] = $app->share(function ($app) { $service = new MyArticleService(); $service->setProvider($app['article_provider']); return $service; });
TODO
Eventually to be moved to MCB (Minimalist Coders Blog) for more broader use. Developers can then implement their own article providers (file, git, cmf etc), formating and highlighters (e.g. pygments, geshi etc).
- Add various traits to article to support dates, author, version, changelog etc
- Implement a GitArticleService/GitHubArticleService that interrogates git for author, versions, etc
- Implement a better configuration layout
- Implement ArticleService list commands, allowing listings of blog history
- Possible Symfony2 support via DI/Service container config
- Implement geshi/sundown/restructedtext etc.