bapp/api-client

BAPP Auto API Client for PHP

Maintainers

Package info

github.com/bapp-open/sdk-php

Homepage

pkg:composer/bapp/api-client

Statistics

Installs: 1

Dependents: 0

Suggesters: 0

Stars: 0

Open Issues: 0

0.4.2 2026-03-16 16:01 UTC

This package is auto-updated.

Last update: 2026-03-16 16:02:25 UTC


README

Official PHP client for the BAPP Auto API. Provides a simple, consistent interface for authentication, entity CRUD, and task execution.

Getting Started

1. Install

composer require bapp/api-client

2. Create a client

<?php
use Bapp\BappApiClient;

$client = new BappApiClient(['token' => 'your-api-key']);

3. Make your first request

// List with filters
$countries = $client->list('core.country', ['page' => 1, 'search' => 'Romania']);

// Get by ID
$country = $client->get('core.country', '42');

// Create
$new = $client->create('core.country', ['name' => 'Romania', 'code' => 'RO']);

// Patch (partial update)
$client->patch('core.country', '42', ['code' => 'RO']);

// Delete
$client->delete('core.country', '42');

Authentication

The client supports Token (API key) and Bearer (JWT / OAuth) authentication. Token auth already includes a tenant binding, so you don't need to specify tenant separately.

// Static API token (tenant is included in the token)
$client = new BappApiClient(['token' => 'your-api-key']);

// Bearer (JWT / OAuth)
$client = new BappApiClient(['bearer' => 'eyJhbG...', 'tenant' => '1']);

Configuration

tenant and app can be changed at any time after construction:

$client->tenant = '2';
$client->app = 'wms';

API Reference

Client options

Option Description Default
token Static API token (Token <value>) — includes tenant
bearer Bearer / JWT token
host API base URL https://panel.bapp.ro/api
tenant Tenant ID (x-tenant-id header) None
app App slug (x-app-slug header) "account"

Methods

Method Description
me() Get current user profile
get_app(app_slug) Get app configuration by slug
list(content_type, **filters) List entities (paginated)
get(content_type, id) Get a single entity
create(content_type, data) Create an entity
update(content_type, id, data) Full update (PUT)
patch(content_type, id, data) Partial update (PATCH)
delete(content_type, id) Delete an entity
list_introspect(content_type) Get list view metadata
detail_introspect(content_type) Get detail view metadata
get_document_views(record) Extract available views from a record
get_document_url(record, output?, label?, variation?) Build a render/download URL
get_document_content(record, output?, label?, variation?) Fetch document bytes (PDF, HTML, JPG)
list_tasks() List available task codes
detail_task(code) Get task configuration
run_task(code, payload?) Execute a task
run_task_async(code, payload?) Run a long-running task and poll until done

Paginated responses

list() returns the results directly as a list/array. Pagination metadata is available as extra attributes:

  • count — total number of items across all pages
  • next — URL of the next page (or null)
  • previous — URL of the previous page (or null)

File Uploads

When data contains file objects, the client automatically switches from JSON to multipart/form-data. Mix regular fields and files in the same call:

// CURLFile or SplFileInfo values trigger multipart/form-data automatically
$client->create('myapp.document', [
    'name' => 'Report',
    'file' => new \CURLFile('/path/to/report.pdf'),
]);

// Or use SplFileInfo
$client->create('myapp.document', [
    'name' => 'Report',
    'file' => new \SplFileInfo('/path/to/report.pdf'),
]);

Document Views

Records may include public_view and/or view_token fields with JWT tokens for rendering documents (invoices, orders, reports, etc.) as HTML, PDF, or images.

The SDK normalises both formats and builds the correct URL automatically:

$order = $client->get('company_order.order', '42');

// Get a PDF download URL (auto-detects public_view vs view_token)
$url = $client->getDocumentUrl($order, 'pdf');

// Pick a specific view by label
$url = $client->getDocumentUrl($order, 'html', 'Comanda interna');

// Use a variation
$url = $client->getDocumentUrl($order, 'pdf', null, 'v4');

// Fetch the actual content as bytes
$pdfBytes = $client->getDocumentContent($order, 'pdf');
file_put_contents('order.pdf', $pdfBytes);

// Enumerate all available views
$views = $client->getDocumentViews($order);
foreach ($views as $v) {
    echo $v['label'] . ' ' . $v['type'] . PHP_EOL;
}

get_document_views() returns a list of normalised view entries with label, token, type ("public_view" or "view_token"), variations, and default_variation. Use it to enumerate available views (e.g. for a dropdown).

Tasks

Tasks are server-side actions identified by a dotted code (e.g. myapp.export_report).

$tasks = $client->listTasks();

$cfg = $client->detailTask('myapp.export_report');

// Run without payload (GET)
$result = $client->runTask('myapp.export_report');

// Run with payload (POST)
$result = $client->runTask('myapp.export_report', ['format' => 'csv']);

Long-running tasks

Some tasks run asynchronously on the server. When triggered, they return an id that can be polled via bapp_framework.taskdata. Use run_task_async() to handle this automatically — it polls until finished is true and returns the final task data (which includes a file URL when the task produces a download).

License

MIT