bapp_api_client 0.5.0 copy "bapp_api_client: ^0.5.0" to clipboard
bapp_api_client: ^0.5.0 copied to clipboard

A Dart client for the BAPP platform API. Supports CRUD, pagination, tasks, file uploads, and long-running async operations.

BAPP Auto API Client — Dart #

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

Getting Started #

1. Install #

dependencies:
  bapp_api_client: ^0.5.0

2. Create a client #

import 'package:bapp_api_client/bapp_api_client.dart';

final client = BappApiClient(token: 'your-api-key');

3. Make your first request #

// List with filters
final countries = await client.list('core.country', {'page': '1', 'search': 'Romania'});

// Get by ID
final country = await client.get('core.country', '42');

// Create
final created = await client.create('core.country', {'name': 'Romania', 'code': 'RO'});

// Patch (partial update)
await client.patch('core.country', '42', {'code': 'RO'});

// Delete
await 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)
final client = BappApiClient(token: 'your-api-key');

// Bearer (JWT / OAuth)
final client = 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"
timeout HTTP request timeout (seconds) 30
max_retries Max retries on transient errors (5xx, 429, connection) 3

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)
download_document(record, dest, output?, label?, variation?) Stream document to file (memory-efficient)
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:

import 'dart:io';

// File objects are auto-detected — switches to multipart/form-data
await client.create('myapp.document', {
  'name': 'Report',
  'file': File('report.pdf'),
});

// Or use http.MultipartFile for more control
import 'package:http/http.dart' as http;
await client.create('myapp.document', {
  'name': 'Report',
  'file': await http.MultipartFile.fromPath('file', '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:

final order = await client.get('company_order.order', '42');

// Get a PDF download URL (auto-detects public_view vs view_token)
final url = client.getDocumentUrl(order, output: 'pdf');

// Pick a specific view by label
final url2 = client.getDocumentUrl(order, output: 'html', label: 'Comanda interna');

// Use a variation
final url3 = client.getDocumentUrl(order, output: 'pdf', variation: 'v4');

// Fetch the actual content as bytes
final pdfBytes = await client.getDocumentContent(order, output: 'pdf');
if (pdfBytes != null) File('order.pdf').writeAsBytesSync(pdfBytes);

// Enumerate all available views
final views = client.getDocumentViews(order);
for (final v in views) {
  print('${v['label']} ${v['type']} ${v['variations']}');
}

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).

final tasks = await client.listTasks();

final cfg = await client.detailTask('myapp.export_report');

// Run without payload (GET)
final result = await client.runTask('myapp.export_report');

// Run with payload (POST)
final result = await 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

0
likes
160
points
325
downloads

Documentation

API reference

Publisher

unverified uploader

Weekly Downloads

A Dart client for the BAPP platform API. Supports CRUD, pagination, tasks, file uploads, and long-running async operations.

Homepage
Repository (GitHub)
View/report issues

Topics

#api #client

License

MIT (license)

Dependencies

http

More

Packages that depend on bapp_api_client