socrata / soda-php
A simple library to make it easier to access SODA services from PHP
Installs: 27 345
Dependents: 0
Suggesters: 0
Security: 0
Stars: 64
Watchers: 61
Forks: 27
Open Issues: 4
pkg:composer/socrata/soda-php
Requires
- php: ~5.3
- ext-curl: *
This package is not auto-updated.
Last update: 2025-10-25 22:20:38 UTC
README
Socrata - Basic PHP Library
This library provides a simple wrapper for accessing some of the features of the Socrata Open Data API from PHP. Currently it supports HTTP GET, POST, and PUT operations.
The library is very simple. To access the Socrata API, you first instantiate a "Socrata" object, passing in the domain of the data site you wish to access. The library will also accept the full root path including the protocol (ex: http://data.medicare.gov). Then you can use its included methods to make simple API calls:
Supported PHP versions
In order to access the SODA API via HTTPS, clients must now support the Server Name Indication (SNI) extension to the TLS protocol. What does this mean? It means that if you're using soda-php, you must use PHP 5.6 or above, as that is when PHP introduced support for SNI.
Install
Via composer
composer require socrata/soda-php
Usage
$socrata = new Socrata("data.medicare.gov"); $response = $socrata->get("abcd-2345");
In your API calls, specify ether the full endpoint relative path (eg: /resource/abcd-2345.json), or the dataset ID (eg: abcd-2345).
Querying
Simple filters and SoQL Queries can be passed as a parameter to the get function:
$socrata = new Socrata("data.austintexas.gov", $app_token); $params = array("\$where" => "within_circle(location, $latitude, $longitude, $range)"); $response = $socrata->get($view_uid, $params);
Publishing
To use the library to publish data you can use the PUT (replace) or POST (upsert) methods:
$socrata = new Socrata("data.medicare.gov", $app_token, $user_name, $password); // Publish data via 'upsert' $response = $socrata->post("abcd-2345", $data_as_json); // Publish data via 'replace' $response = $socrata->put("abcd-2345", $data_as_json);
The library also includes a simple example application, which retrieves rows from a dataset and dumps them in a simple table.
License
Apache License, Version 2.0. Please see License File for more information.