free-climb-api / php-sdk
FreeClimb is a cloud-based application programming interface (API) that puts the power of the Vail platform in your hands. FreeClimb simplifies the process of creating applications that can use a full range of telephony features without requiring specialized or on-site telephony equipment. Using the
Requires
- php: ^8.2
- ext-curl: *
- ext-json: *
- ext-mbstring: *
- guzzlehttp/guzzle: ^7.3
- guzzlehttp/psr7: ^1.7 || ^2.0
Requires (Dev)
- friendsofphp/php-cs-fixer: ^3.65
- phpunit/phpunit: ^8.0 || ^9.0
- dev-master
- 5.1.1
- 5.1.0
- 5.0.0
- 4.6.0
- 4.5.0
- 4.4.2
- 4.4.1
- 4.4.0
- 4.3.4
- 4.3.3
- 4.3.2
- 4.3.1
- 4.3.0
- 4.2.1
- 4.2.0
- 4.1.0
- 4.0.0
- 3.2.0
- 3.1.3
- 3.1.2
- 3.1.1
- 3.1.0
- 3.0.4
- 3.0.3
- 3.0.2
- 3.0.1
- 3.0.0
- 1.1.3
- 1.1.2
- 1.0.1
- dev-VCSWP-23469
- dev-VCSWP-23775
- dev-VCSWP-22240
- dev-VCSWP-23618
- dev-VCSWP-23198
- dev-VCSWP-19122
- dev-VCSWP-22702-regen
- dev-VCSWP-22703
- dev-VCSWP-22718
- dev-VCSWP-22535
- dev-VCSWP-21889
- dev-VCSWP-19764
- dev-VCSWP-20372
- dev-VCSWP-20273
- dev-VCSWP-20150
- dev-VCSWP-19961
- dev-VCSWP-18414
- dev-VCSWP-19571
- dev-VCSWP-19258-feature
- dev-VCSWP-19521
- dev-VCSWP-19101
- dev-VCSWP-19258
- dev-VCSWP-19213-changelog-update
- dev-VCSWP-19213
- dev-VCSWP-18905
- dev-VCSWP-18939
- dev-VCSWP-18112
- dev-VCSWP-17763
- dev-ngarg-vail-patch-1
- dev-VCSWP-16885
- dev-VCSWP-16072
- dev-VCSWP-15725
- dev-VCSWP-14055-signing-secrets
This package is auto-updated.
Last update: 2025-06-07 20:58:21 UTC
README
FreeClimb is a cloud-based application programming interface (API) that puts the power of the Vail platform in your hands. FreeClimb simplifies the process of creating applications that can use a full range of telephony features without requiring specialized or on-site telephony equipment. Using the FreeClimb REST API to write applications is easy! You have the option to use the language of your choice or hit the API directly. Your application can execute a command by issuing a RESTful request to the FreeClimb API. The base URL to send HTTP requests to the FreeClimb REST API is: /apiserver. FreeClimb authenticates and processes your request.
For more information, please visit https://www.freeclimb.com/support/.
Installation & Usage
Requirements
PHP 7.4 and later. Should also work with PHP 8.0.
Composer
To install the bindings via Composer, add the following to composer.json
:
{ "repositories": [ { "type": "vcs", "url": "https://https://github.com/freeclimbapi/php-sdk.git" } ], "require": { "freeclimbapi/php-sdk": "*@dev" } }
Then run composer install
Manual Installation
Download the files and include autoload.php
:
<?php require_once('/path/to/FreeClimbAPI/vendor/autoload.php');
Getting Started
Please follow the installation procedure and then run the following:
<?php require_once(__DIR__ . '/vendor/autoload.php'); // Configure HTTP basic authorization: fc $config = FreeClimb\Api\Configuration::getDefaultConfiguration() ->setUsername('YOUR_ACCOUNT_ID') ->setPassword('YOUR_API_KEY'); $apiInstance = new FreeClimb\Api\Api\DefaultApi( // If you want use custom http client, pass your client which implements `GuzzleHttp\ClientInterface`. // This is optional, `GuzzleHttp\Client` will be used as default. new GuzzleHttp\Client(), $config ); $buy_incoming_number_request = new \FreeClimb\Api\Model\BuyIncomingNumberRequest(); // \FreeClimb\Api\Model\BuyIncomingNumberRequest | Incoming Number transaction details try { $result = $apiInstance->buyAPhoneNumber($buy_incoming_number_request); print_r($result); } catch (Exception $e) { echo 'Exception when calling DefaultApi->buyAPhoneNumber: ', $e->getMessage(), PHP_EOL; }
Using PerCL
The PerclScript class provides a convenient wrapper to handle PerCL generation in your responses. Simply execute json_encode
with an instance of the PerclScript
class and you will have PerclCommands
serialized and formatted the way you need.
<?php require_once(__DIR__ . '/vendor/autoload.php'); $say = new \FreeClimb\Api\Model\Say(); $sms = new \FreeClimb\Api\Model\Sms(); $script = new \FreeClimb\Api\Model\PerclScript(); $say->setText("hello world"); $sms->setFrom("from number"); $sms->setTo("to number"); $sms->setText("hello world SMS"); $script->setCommands(array($say, $sms)); json_encode($script); /** * [ * { * "Say": { * "text": "hello world" * } * }, * { * "Sms": { * "from": "from number", * "to": "to number", * "text": "hello world SMS" * } * } * ] */ ?>
API Endpoints
All URIs are relative to https://www.freeclimb.com/apiserver
Class | Method | HTTP request | Description |
---|---|---|---|
DefaultApi | buyAPhoneNumber | POST /Accounts/{accountId}/IncomingPhoneNumbers | Buy a Phone Number |
DefaultApi | createAConference | POST /Accounts/{accountId}/Conferences | Create a Conference |
DefaultApi | createAQueue | POST /Accounts/{accountId}/Queues | Create a Queue |
DefaultApi | createAnApplication | POST /Accounts/{accountId}/Applications | Create an application |
DefaultApi | createKnowledgeBaseCompletion | POST /Accounts/{accountId}/KnowledgeBases/{knowledgeBaseId}/Completion | Query the knowledge base |
DefaultApi | deleteARecording | DELETE /Accounts/{accountId}/Recordings/{recordingId} | Delete a Recording |
DefaultApi | deleteAnApplication | DELETE /Accounts/{accountId}/Applications/{applicationId} | Delete an application |
DefaultApi | deleteAnIncomingNumber | DELETE /Accounts/{accountId}/IncomingPhoneNumbers/{phoneNumberId} | Delete an Incoming Number |
DefaultApi | dequeueAMember | POST /Accounts/{accountId}/Queues/{queueId}/Members/{callId} | Dequeue a Member |
DefaultApi | dequeueHeadMember | POST /Accounts/{accountId}/Queues/{queueId}/Members/Front | Dequeue Head Member |
DefaultApi | downloadARecordingFile | GET /Accounts/{accountId}/Recordings/{recordingId}/Download | Download a Recording File |
DefaultApi | filterLogs | POST /Accounts/{accountId}/Logs | Filter Logs |
DefaultApi | getACall | GET /Accounts/{accountId}/Calls/{callId} | Get a Call |
DefaultApi | getAConference | GET /Accounts/{accountId}/Conferences/{conferenceId} | Get a Conference |
DefaultApi | getAMember | GET /Accounts/{accountId}/Queues/{queueId}/Members/{callId} | Get a Member |
DefaultApi | getAParticipant | GET /Accounts/{accountId}/Conferences/{conferenceId}/Participants/{callId} | Get a Participant |
DefaultApi | getAQueue | GET /Accounts/{accountId}/Queues/{queueId} | Get a Queue |
DefaultApi | getARecording | GET /Accounts/{accountId}/Recordings/{recordingId} | Get a Recording |
DefaultApi | getAnAccount | GET /Accounts/{accountId} | Get an Account |
DefaultApi | getAnApplication | GET /Accounts/{accountId}/Applications/{applicationId} | Get an Application |
DefaultApi | getAnIncomingNumber | GET /Accounts/{accountId}/IncomingPhoneNumbers/{phoneNumberId} | Get an Incoming Number |
DefaultApi | getAnSmsMessage | GET /Accounts/{accountId}/Messages/{messageId} | Get an SMS Message |
DefaultApi | getHeadMember | GET /Accounts/{accountId}/Queues/{queueId}/Members/Front | Get Head Member |
DefaultApi | getTenDLCSmsBrand | GET /Accounts/{accountId}/Messages/10DLC/Brands/{brandId} | Get a 10DLC SMS Brand |
DefaultApi | getTenDLCSmsBrands | GET /Accounts/{accountId}/Messages/10DLC/Brands | Get list of SMS 10DLC Brands |
DefaultApi | getTenDLCSmsCampaign | GET /Accounts/{accountId}/Messages/10DLC/Campaigns/{campaignId} | Get a 10DLC SMS Campaign |
DefaultApi | getTenDLCSmsCampaigns | GET /Accounts/{accountId}/Messages/10DLC/Campaigns | Get list of SMS 10DLC Campaigns |
DefaultApi | getTenDLCSmsPartnerCampaign | GET /Accounts/{accountId}/Messages/10DLC/PartnerCampaigns/{campaignId} | Get a 10DLC SMS Partner Campaign |
DefaultApi | getTenDLCSmsPartnerCampaigns | GET /Accounts/{accountId}/Messages/10DLC/PartnerCampaigns | Get list of SMS 10DLC Partner Campaigns |
DefaultApi | getTollFreeSmsCampaign | GET /Accounts/{accountId}/Messages/TollFree/Campaigns/{campaignId} | Get a TollFree SMS Campaign |
DefaultApi | getTollFreeSmsCampaigns | GET /Accounts/{accountId}/Messages/TollFree/Campaigns | Get list of TollFree Campaigns |
DefaultApi | listActiveQueues | GET /Accounts/{accountId}/Queues | List Active Queues |
DefaultApi | listAllAccountLogs | GET /Accounts/{accountId}/Logs | List All Account Logs |
DefaultApi | listApplications | GET /Accounts/{accountId}/Applications | List applications |
DefaultApi | listAvailableNumbers | GET /AvailablePhoneNumbers | List available numbers |
DefaultApi | listCallLogs | GET /Accounts/{accountId}/Calls/{callId}/Logs | List Call Logs |
DefaultApi | listCallRecordings | GET /Accounts/{accountId}/Calls/{callId}/Recordings | List Call Recordings |
DefaultApi | listCalls | GET /Accounts/{accountId}/Calls | List Calls |
DefaultApi | listConferenceRecordings | GET /Accounts/{accountId}/Conferences/{conferenceId}/Recordings | List Conference Recordings |
DefaultApi | listConferences | GET /Accounts/{accountId}/Conferences | List Conferences |
DefaultApi | listIncomingNumbers | GET /Accounts/{accountId}/IncomingPhoneNumbers | List Incoming Numbers |
DefaultApi | listMembers | GET /Accounts/{accountId}/Queues/{queueId}/Members | List Members |
DefaultApi | listParticipants | GET /Accounts/{accountId}/Conferences/{conferenceId}/Participants | List Participants |
DefaultApi | listRecordings | GET /Accounts/{accountId}/Recordings | List Recordings |
DefaultApi | listSmsMessages | GET /Accounts/{accountId}/Messages | List SMS Messages |
DefaultApi | makeACall | POST /Accounts/{accountId}/Calls | Make a Call |
DefaultApi | makeAWebrtcJwt | POST /Accounts/{accountId}/Calls/WebRTC/Token | Make a JWT for WebRTC calling |
DefaultApi | removeAParticipant | DELETE /Accounts/{accountId}/Conferences/{conferenceId}/Participants/{callId} | Remove a Participant |
DefaultApi | sendAnSmsMessage | POST /Accounts/{accountId}/Messages | Send an SMS Message |
DefaultApi | streamARecordingFile | GET /Accounts/{accountId}/Recordings/{recordingId}/Stream | Stream a Recording File |
DefaultApi | updateAConference | POST /Accounts/{accountId}/Conferences/{conferenceId} | Update a Conference |
DefaultApi | updateALiveCall | POST /Accounts/{accountId}/Calls/{callId} | Update a Live Call |
DefaultApi | updateAParticipant | POST /Accounts/{accountId}/Conferences/{conferenceId}/Participants/{callId} | Update a Participant |
DefaultApi | updateAQueue | POST /Accounts/{accountId}/Queues/{queueId} | Update a Queue |
DefaultApi | updateAnAccount | POST /Accounts/{accountId} | Manage an account |
DefaultApi | updateAnApplication | POST /Accounts/{accountId}/Applications/{applicationId} | Update an application |
DefaultApi | updateAnIncomingNumber | POST /Accounts/{accountId}/IncomingPhoneNumbers/{phoneNumberId} | Update an Incoming Number |
Models
- AccountRequest
- AccountResult
- AccountStatus
- AccountType
- AddToConference
- AddToConferenceNotificationWebhook
- AddToQueueNotificationWebhook
- AnsweredBy
- ApplicationList
- ApplicationRequest
- ApplicationResult
- AvailableNumber
- AvailableNumberList
- BargeInReason
- BuyIncomingNumberRequest
- CallControlWebhook
- CallDirection
- CallEndedReason
- CallList
- CallResult
- CallStatus
- CallStatusWebhook
- Capabilities
- CompletionRequest
- CompletionResult
- CompletionResultStatus
- ConferenceList
- ConferenceParticipantList
- ConferenceParticipantResult
- ConferenceRecordingStatusWebhook
- ConferenceResult
- ConferenceStatus
- ConferenceStatusWebhook
- CreateConference
- CreateConferenceRequest
- CreateConferenceWebhook
- CreateWebRTCToken
- Dequeue
- DequeueWebhook
- Enqueue
- FilterLogsRequest
- GetDigits
- GetDigitsReason
- GetDigitsWebhook
- GetSpeech
- GetSpeechReason
- GetSpeechWebhook
- GrammarFileBuiltIn
- GrammarType
- Hangup
- IfMachine
- InboundCallWebhook
- IncomingNumberList
- IncomingNumberRequest
- IncomingNumberResult
- Language
- LeaveConferenceWebhook
- LogLevel
- LogList
- LogResult
- MachineDetectedWebhook
- MachineType
- MakeCallRequest
- MessageDeliveryWebhook
- MessageDirection
- MessageRequest
- MessageResult
- MessageStatus
- MessageStatusWebhook
- MessagesList
- MutableResourceModel
- OutDial
- OutDialApiConnectWebhook
- OutDialConnectWebhook
- OutDialStartWebhook
- PaginationModel
- Park
- Pause
- PerclCommand
- PerclScript
- Play
- PlayBeep
- PlayEarlyMedia
- QueueList
- QueueMember
- QueueMemberList
- QueueRequest
- QueueResult
- QueueResultStatus
- QueueWaitWebhook
- RecordUtterance
- RecordUtteranceTermReason
- RecordWebhook
- RecordingList
- RecordingResult
- Redirect
- RedirectWebhook
- Reject
- RemoveFromConference
- RemoveFromQueueNotificationWebhook
- RequestType
- SMSTenDLCBrand
- SMSTenDLCBrandAltBusinessIdType
- SMSTenDLCBrandEntityType
- SMSTenDLCBrandIdentityStatus
- SMSTenDLCBrandRelationship
- SMSTenDLCBrandStockExchange
- SMSTenDLCBrandsListResult
- SMSTenDLCCampaign
- SMSTenDLCCampaignStatus
- SMSTenDLCCampaignsListResult
- SMSTenDLCPartnerCampaign
- SMSTenDLCPartnerCampaignBrand
- SMSTenDLCPartnerCampaignStatus
- SMSTenDLCPartnerCampaignsListResult
- SMSTollFreeCampaign
- SMSTollFreeCampaignRegistrationStatus
- SMSTollFreeCampaignsListResult
- Say
- SendDigits
- SetDTMFPassThrough
- SetListen
- SetTalk
- Sms
- StartRecordCall
- TFN
- TFNCampaign
- TerminateConference
- TranscribeReason
- TranscribeTermReason
- TranscribeUtterance
- TranscribeUtteranceRecord
- TranscribeWebhook
- Unpark
- UpdateCallRequest
- UpdateCallRequestStatus
- UpdateConferenceParticipantRequest
- UpdateConferenceRequest
- UpdateConferenceRequestStatus
- Webhook
Authorization
Authentication schemes defined for the API:
fc
- Type: HTTP basic authentication
Tests
To run the tests, use:
composer install vendor/bin/phpunit
Author
About this package
This PHP package is automatically generated by the OpenAPI Generator project:
- API version:
1.0.0
- Package version:
5.1.1
- Generator version:
7.9.0
- Package version:
- Build package:
org.openapitools.codegen.languages.PhpClientCodegen