myfmbutler / myfmapilibrary-for-php
(Claris) FileMaker 19 API PHP wrapper
Installs: 4 167
Dependents: 0
Suggesters: 0
Security: 0
Stars: 20
Watchers: 4
Forks: 10
Open Issues: 3
Requires
- php: >=5.5.0
- ext-curl: *
- ext-mbstring: *
Requires (Dev)
- phpunit/phpunit: ^5.6
README
Presentation
Team
Lesterius is a European Claris (FileMaker) Business Alliance Platinum member that operates in Belgium, France, the Netherlands, Portugal and Spain. We are creative business consultants who co-create FileMaker Platform based solutions with our customers.
Sharing knowledge takes part of our DNA, that's why we developed this library to make the FileMaker Data API easy-to-use with PHP.
Break the limits of your application!
Description
This library is a PHP wrapper of the (Claris) FileMaker Data API 19.
You can find the PHP wrapper of the FileMaker Data API 17 on the releases <= v.1.* .
You can find the PHP wrapper of the FileMaker Data API 18 on the releases <= v.2.* .
You will be able to use every functions like it's documented in your FileMaker server Data Api documentation (accessible via https://[your server domain]/fmi/data/apidoc). General Claris document on the Data API is available here
Requirements
- PHP >= 5.5
- PHP cURL extension
- PHP mb_string extension
Installation
The recommended way to install it is through Composer.
composer require myfmbutler/myfmapilibrary-for-php
After installing, you need to require Composer's autoloader:
require_once __DIR__ . '/vendor/autoload.php';
Usage
Prepare your Claris (Filmaker) solution
- Enable the (Claris) FileMaker Data API option on your FileMaker server admin console.
- Create a specific user in your (Claris) FileMaker database with the 'fmrest' privilege
- Define records & layouts access for this user
Use the library
Login
Login with credentials:
$dataApi = new \Lesterius\FileMakerApi\DataApi('https://test.fmconnection.com/fmi/data', 'MyDatabase', null, 'filemaker api user', 'filemaker api password');
Login with oauth:
$dataApi = new \Lesterius\FileMakerApi\DataApi('https://test.fmconnection.com/fmi/data', 'MyDatabase', null, null, true, 'oAuthRequestId', 'oAuthIdentifier');
Logout
$dataApi->logout();
Validate Session
$dataApi->validateSession();
Create record
$data = [ 'FirstName' => 'John', 'LastName' => 'Doe', 'email' => 'johndoe@acme.inc', 'RepeatingField(1)' => 'Test' ]; $scripts = [ [ 'name' => 'ValidateUser', 'param' => 'johndoe@acme.inc', 'type' => Lesterius\FileMakerApi\DataApi::SCRIPT_PREREQUEST ], [ 'name' => 'SendEmail', 'param' => 'johndoe@acme.inc', 'type' => Lesterius\FileMakerApi\DataApi::SCRIPT_POSTREQUEST ] ]; $portalData = [ 'portalName or OccurenceName' => [ [ "Occurence::PortalField 1" => "Value", "Occurence::PortalField 2" => "Value", ] ] ]; try { $recordId = $dataApi->createRecord('layout name', $data, $scripts, $portalData); } catch(\Exception $e) { // handle exception }
Delete record
try { $dataApi->deleteRecord('layout name', $recordId, $script); } catch(\Exception $e) { // handle exception }
Edit record
try { $recordId = $dataApi->editRecord('layout name', $recordId, $data, $lastModificationId, $portalData, $scripts); } catch(\Exception $e) { // handle exception }
Duplicate record
try { $recordId = $dataApi->editRecord('layout name', $recordId, $scripts); } catch(\Exception $e) { // handle exception }
Get record
$portals = [ [ 'name' => 'Portal1', 'limit' => 10 ], [ 'name' => 'Portal2', 'offset' => 3 ] ]; try { $record = $dataApi->getRecord('layout name', $recordId, $portals, $scripts); } catch(\Exception $e) { // handle exception }
Get records
$sort = [ [ 'fieldName' => 'FirstName', 'sortOrder' => 'ascend' ], [ 'fieldName' => 'City', 'sortOrder' => 'descend' ] ]; try { $record = $dataApi->getRecords('layout name', $sort, $offset, $limit, $portals, $scripts); } catch(\Exception $e) { // handle exception }
Find records
$query = [ [ 'fields' => [ ['fieldname' => 'FirstName', 'fieldvalue' => '==Test'], ['fieldname' => 'LastName', 'fieldvalue' => '==Test'], ], 'options' => [ 'omit' => false ] ] ]; try { $results = $dataApi->findRecords('layout name', $query, $sort, $offset, $limit, $portals, $scripts, $responseLayout); } catch(\Exception $e) { // handle exception }
Set global fields
$data = [ 'FieldName1' => 'value', 'FieldName2' => 'value' ]; try { $dataApi->setGlobalFields('layout name', $data); } catch(\Exception $e) { // handle exception }
Execute script
try { $dataApi->executeScript('script name', $scriptsParams); } catch(\Exception $e) { // handle exception }
Upload file to container
Renaming file
$containerFieldName = 'Picture'; $containerFieldRepetition = 1; // replace 'upload' below with the name="value" of the file input element of your web form $filepath = $_FILES['upload']['tmp_name']; $filename = $_FILES['upload']['name']; try { $dataApi->uploadToContainer('layout name', $recordId, $containerFieldName, $containerFieldRepetition, $filepath, $filename); } catch(\Exception $e) { // handle exception }
Without checking filename
$containerFieldName = 'Picture'; $containerFieldRepetition = 1; $filepath = '/usr/home/acme/pictures/photo.jpg'; try { $dataApi->uploadToContainer('layout name', $recordId, $containerFieldName, $containerFieldRepetition, $filepath); } catch(\Exception $e) { // handle exception }
Metadata Info
Product Info
try { $dataApi->getProductInfo(); } catch(\Exception $e) { // handle exception }
Database Names
try { $dataApi->getDatabaseNames(); } catch(\Exception $e) { // handle exception }
Layout Names
try { $dataApi->getLayoutNames(); } catch(\Exception $e) { // handle exception }
Script Names
try { $dataApi->getScriptNames(); } catch(\Exception $e) { // handle exception }
Layout Metadata
try { $dataApi->getLayoutMetadata('layout name', $recordId); } catch(\Exception $e) { // handle exception }