A Confluence RESTful API client in PHP
An Object Oriented wrapper for Confluence
- PHP >= 8.1.0
$ composer require cloudplaydev/confluence-php-client
use CloudPlayDev\ConfluenceClient\ConfluenceClient;
$client = new ConfluenceClient('https://url-to-conluence');
//authenticate with a private access token
//@see https://confluence.atlassian.com/enterprise/using-personal-access-tokens-1026032365.html
$client->authenticate('NjU2OTA4NDI2MTY5OkBznOUO8YjaUF7KoOruZRXhILJ9');
$client = new ConfluenceClient('https://USERNAME:PASSWORD@url-to-conluence');
or
use CloudPlayDev\ConfluenceClient\ConfluenceClient;
$client = new ConfluenceClient('https://url-to-conluence');
$client->authenticateBasicAuth('USERNAME', 'PASSWORD');
/* @var $client CloudPlayDev\ConfluenceClient\ConfluenceClient */
//Get the page we created
$searchResults = $client->content()->find([
'spaceKey' => 'testSpaceKey',
'title' => 'Test'
]);
//first page
$createdPage = $searchResults->getResultAt(0);
/* @var $client CloudPlayDev\ConfluenceClient\ConfluenceClient */
$limit = 100;
$start = 10;
//Get the search results with pagination
$searchResults = $client->content()->find([
'spaceKey' => 'testSpaceKey',
'title' => 'Test'
], $limit, $start);
//check if there are more results
while(!$searchResults->isLastPage()) {
//get the next pages
$nextPages = $client->content()->find([
'spaceKey' => 'testSpaceKey',
'title' => 'Test'
], $limit, $searchResults->getStart() + $limit);
}
/* @var $client CloudPlayDev\ConfluenceClient\ConfluenceClient */
//Get a page or comment
$resultContent = $client->content()->get(1234567890);
/* @var $client CloudPlayDev\ConfluenceClient\ConfluenceClient */
//Get a page or comment in a specific version
$resultContentInVersion2 = $client->content()->get(1234567890, 2);
use CloudPlayDev\ConfluenceClient\Api\Content;
/* @var $client CloudPlayDev\ConfluenceClient\ConfluenceClient */
/* @var $page CloudPlayDev\ConfluenceClient\Entity\ContentPage */
//get child content
$childContent = $client->content()->children($page, Content::CONTENT_TYPE_PAGE); //\CloudPlayDev\ConfluenceClient\Entity\ContentSearchResult
use CloudPlayDev\ConfluenceClient\Api\Content;
/* @var $client CloudPlayDev\ConfluenceClient\ConfluenceClient */
$pageId = 2323232323;
$historyData = $client->content()->history($pageId); // \CloudPlayDev\ConfluenceClient\Entity\ContentHistory
use CloudPlayDev\ConfluenceClient\Entity\ContentPage;
/* @var $client CloudPlayDev\ConfluenceClient\ConfluenceClient */
//Create a confluence content page
$page = new ContentPage();
//Configure your page
$page->setSpace('testSpaceKey')
->setTitle('Test')
->setContent('<p>test page</p>');
//Create the page in confluence in the test space
$client->content()->create($page);
/* @var $client CloudPlayDev\ConfluenceClient\ConfluenceClient */
//get a page by id
$page = $client->content()->get(123456789);
//attach a comment to the page
$comment = $page->createComment('my comment text');
//save the comment
$client->content()->create($comment);
/* @var $client CloudPlayDev\ConfluenceClient\ConfluenceClient */
//get a page by id
$page = $client->content()->get(123456789);
//attach a subpage to page
$subPage = $page->createSubpage('subpage title', 'subpage content');
//save the page
$client->content()->create($subPage);
/* @var $client CloudPlayDev\ConfluenceClient\ConfluenceClient */
//get content by id
$page = $client->content()->get(123456789);
//change content
$page->setContent('new content')
->setTitle('new title');
//save the changes
$client->content()->update($page);
/* @var $client CloudPlayDev\ConfluenceClient\ConfluenceClient */
//get content by id
$page = $client->content()->get(123456789);
//delete content
$client->content()->delete($page);
You have to use basic auth with your username and password. You can also use a personal access token instead of your password. See Using personal access tokens for more information.
Create a new API token here: https://id.atlassian.com/manage-profile/security/api-tokens
use CloudPlayDev\ConfluenceClient\ConfluenceClient;
$client = new ConfluenceClient('https://xxxxxxxx.atlassian.net/wiki/');
$client->authenticateBasicAuth('USERNAME', 'TOKEN');