concretecms/community_api_client

This package contains an api client that is able to connect with the community.

dev-master 2022-05-19 01:21 UTC

This package is auto-updated.

Last update: 2024-11-19 06:21:44 UTC


README

This is the official api client that is used to communicate with the community site.

Currently the functionality is very limited but it get's extended soon.

You can use the api client to assign achievements.

Requirements

  • PHP 7.1
  • Can only run within Concrete CMS context

Installation

The Community API client can be installed using Composer.

Composer To install run composer require concrete5/community_api_client

Configuration

There is no interface for configure the api client. However there are multiple options to do that.

Option 1: Programmatically

If you want to setup the credentials programmatically you can do so like this:

use Concrete\Core\Support\Facade\Application;
use PortlandLabs\CommunityApiClient\ApiClient;

/** @var ApiClient $apiClient */
$apiClient = $app->make(ApiClient::class);
$apiClient
    ->setEndpoint("your_endpoint")
    ->setClientId("your_client_id")
    ->setClientSecret("your_client_secret");

Option 2: With a configuration file

You can also take use of an configuration file.

All you need to do is creating a file located at application/config/community_api_client.php with the following content:

<?php
return [
    'endpoint' => 'your_endpoint',
    'client_id' => 'your_client_id',
    'client_secret' => 'your_client_secret'
];

Option 3: With the Concrete CMS CLI application

You can also take use of the cli application to configure the api client.

concrete/bin/concrete5 c5:config set community_api_client.endpoint your_endpoint
concrete/bin/concrete5 c5:config set community_api_client.client_id your_client_id
concrete/bin/concrete5 c5:config set community_api_client.client_secret your_client_secret

Option 4: With environment variables

You can also setup the credentials with environment variables. The following variables are used.

API_COMMUNITY_ENDPOINT
API_COMMUNITY_CLIENT_ID
API_COMMUNITY_CLIENT_SECRET

If environment variables are configured the concrete CMS configuration will be ignored.

Usage

After you have configured the endpoint you can communicate with the api interface.

The following code snippet demonstrates you how to deal with it.

use Concrete\Core\Support\Facade\Application;
use PortlandLabs\CommunityApiClient\Models\Achievements;

$app = Application::getFacadeApplication();
/** @var Achievements $achievements */
$achievements = $app->make(Achievements::class);
$success = $achievements->assign("test_handle");

Currently there is now api documentation available. So if you want to know what functionality is available you need to take a look at the models folder within this repository.