A PHP client for accessing the MonkCMS API in non-website environments.
While monkcms.php
is great for building websites, it includes many features
that simply aren't necessary — and make it hard to use — in other environments:
sessions, caching, Easy Edit, etc. This library strips all of that away to
provide only what's absolutely necessary to access content through the MonkCMS
API. It's ideal for use in web apps, command line scripts, APIs, and more.
Using Composer, add monkdev/monkcms
to your
composer.json
:
{
"require": {
"monkdev/monkcms": "~0.6"
}
}
$ composer update
Or:
$ composer require monkdev/monkcms:~0.6
Configuration can be done by passing an array to the constructor:
$cms = new Monk\Cms(array(
'siteId' => 12345,
'siteSecret' => 'secret'
));
Or after instantiation by calling setConfig
:
$cms->setConfig(array(
'siteId' => 12345,
'siteSecret' => 'secret'
));
When a configuration value isn't set, it falls back to a sensible default in many cases. These defaults can be changed to help alleviate repeating the same configuration in multiple places:
Monk\Cms::setDefaultConfig(array(
'siteId' => 12345,
'siteSecret' => 'secret'
));
While only the siteId
and the siteSecret
are required, the following configuration values are avaialble for use
$defaultConfig = array(
'request' => null, // Override the default Http Request library used in the package
'siteId' => null, // Required
'siteSecret' => null, // Required
'cmsCode' => 'EKK', // Override the default CMS Code
'cmsType' => 'CMS', // Override the default CMS Type (Sermon Cloud/Church Cloud vs CMS Content)
'url' => 'http://api.monkcms.com' // Override the default API Endpoint
);
Requesting content is simple:
$content = $cms->get('sermon/detail/sermon-slug');
If you're familiar with getContent
from monkcms.php
,
sermon
is the module,detail
is thedisplay
value, andsermon-slug
is thefind
value (optional).
Additional parameters can be passed in an array as the second argument:
$content = $cms->get('sermon/list', array(
'nonfeatures' => true,
'howmany' => 5
));
If you'd prefer to forgo the slash-separated string format, you can instead pass a single array argument with all of the values:
$content = $cms->get(array(
'module' => 'sermon',
'display' => 'list',
'howmany' => 5
));
get
returns JSON as described by the API docs
in associative array form. So, for example, a sermon's title can be accessed at
$content['show']['title']
.
If a failure occurs, get
throws a Monk\Cms\Exception
.
If you want to use show
key to format API output, there are 2 ways
For example:
$cms->get(array(
'module' => 'smallgroup',
'display' => 'list',
'order' => 'recent',
'emailencode' => 'no',
'howmany' => 1,
'page' => 1,
'show' => "___starttime format='g:ia'__ __endtime format='g:ia'__",
));
For example:
$cms->get(array(
'module' => 'smallgroup',
'display' => 'list',
'order' => 'recent',
'emailencode' => 'no',
'howmany' => 1,
'page' => 1,
'show' => [
"__starttime format='g:ia'__",
"__endtime format='g:ia'__"
]
));
Composer is used for dependency management and task running. Start by installing the dependencies:
$ composer install
Testing is done with PHPUnit. To run the tests:
$ composer test
Continuous integration is setup through Travis CI to run the tests against PHP v5.6, v7.0, and v7.1. (Circle CI is also setup to run the tests against PHP v5.6, but is backup for now until multiple versions can easily be specified.) The code coverage results are sent to Codecov during CI for tracking over time. Badges for both are dispayed at the top of this README.
phpDocumentor is used for code documentation. To build:
$ composer phpdoc
This creates a doc
directory (that is ignored by git).
A number of code quality tools are configured to aid in development. To run them all at once:
$ composer quality
Each tool can also be run individually:
- php -l:
$ composer phplint
- PHP_CodeSniffer:
$ composer phpcs
- PHP Copy/Paste Detector:
$ composer phpcpd
- PHPLOC:
$ composer phploc
- PHP Mess Detector:
$ composer phpmd
- SensioLabs Security Checker:
$ composer security-checker
Publishing a release to Packagist simply requires creating a git tag:
$ git tag -a vMAJOR.MINOR.PATCH -m "Version MAJOR.MINOR.PATCH"
$ git push origin vMAJOR.MINOR.PATCH
Be sure to choose the correct version by following Semantic Versioning.
After releasing a new version, the documentation must be manually built and
published to the gh-pages
branch.