sioweb / hrworks
Installs: 42
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
pkg:composer/sioweb/hrworks
Requires
README
This client can be used to connect with HRWorks API https://www.hrworks.de/produkt/api/
Installation
composer req sioweb/hrworks
Credentials
First create, or update, .env-File in root directory:
HRWORKS_ACCESS_KEY="your_access_key"
HRWORKS_SECRET_KEY="your_secret_key"
Example
Make sure your admin gave you the correct permissions for the actions you want to use.
After installation you can create a PHP-File in /web directory. Its recommendet to use a subdirectory, so users cannot access sensitive directories like /vendor, or /var/logs if you use it.
<?php // /web/index.php use Sioweb\Hrworks\Core\Client; include '../vendor/autoload.php'; $Client = new Client(); // $Client->setRootDir('/var/www/folder'); $Client->init(); $Organisations = $Client->load('GetAllOrganizationUnits'); foreach ($Organisations['organizationUnits'] as $Organisation) { echo '<h3>' . $Organisation['organizationUnitName'] . ' (Unit id: ' . $Organisation['organizationUnitNumber'] . ')</h3>'; echo '<pre>' . print_r($Client->load('GetPresentPersonsOfOrganizationUnit', [ 'organizationUnitNumber' => $Organisation['organizationUnitNumber'] ]), true) . '</pre>'; }
Client
Client::load(String $Target, Array Payload = NULL)
Load requires minimum a target. For some actions like GetPresentPersonsOfOrganizationUnit you need to add payload as array:
// Client::load(String $Target, Array Payload = NULL) $Client->load('GetPresentPersonsOfOrganizationUnit', [ 'organizationUnitNumber' => 1 ])
Client::setRootDir(String $RootPath)
The client loads .env from root dir, which is by default $_SERVER['DOCUMENT_ROOT'] . '/../. If you install script in / instead of /web, you need to run something like $Client->setRootDir($_SERVER['DOCUMENT_ROOT']);, befor $Client->init().
$_SERVER['DOCUMENT_ROOT'] . '/../' could output for example: /var/www/html/yourdomain/web/../
Postman
You can also create a Postman import with this package. You simply have to use Postman::load instead of Client::load.
Attention: Postman will not send correct signature for now. Maybe this will work in some future.
{"type":"InvalidSignatureError","errorCode":403,"errorMessage":"The signature included in your request does not match the signature we calculated."}
Keep in mind, that you have to update the date and the x-hrworks-date all 15 minutes.