germanazo / laravel-ckan-api
Laravel 5 client for CKAN Api
Requires
- php: >=5.5.9
- guzzlehttp/guzzle: ^6.2.0
Requires (Dev)
- laravel/laravel: 5.4.*
- mockery/mockery: ^0.9.4
- phpunit/phpunit: ^5.1
This package is not auto-updated.
Last update: 2024-11-09 20:50:38 UTC
README
TODO:
- Implement unit tests.
- Package documentation.
Installation
Add to composer
composer require germanazo/laravel-ckan-api
Load service provider
Register the service provider in config/app.php
'provider' => [ ... Germanazo\CkanApi\CkanServiceProvider::class, ... ]
And register facade alias in the same config file.
'aliases' => [ ... 'CkanApi' => Germanazo\CkanApi\Facades\CkanApi::class, ... ]
Publish vendor
php artisan vendor:publish --provider="Germanazo\CkanApi\CkanServiceProvider"
Configure Ckan API
Configure the file located into config/ckan_api.php
or if you prefer use env variables:
CKAN_API_URL=https://data.myckan.com CKAN_API_KEY={{MY SUPER SECRET API KEY}
And if you know what are you doing, then it is possible to configure the api version too:
CKAN_API_VERSION=2
CKAN_API_KEY can be found inside your ckan user profile.
Use it:
use CkanApi // Get paginated results CkanApi::dataset()->all(['start' => $start]); // Start variable works only for datasets for now // Second argument is to define extra params from *_show CkanApi::dataset()->show('ref-id', ['include_tracking' => true]); CkanApi::dataset()->create(['owner_org' => 'my-org', 'name' => 'super-title','title' => 'SUPER API TITLE']); CkanApi::dataset()->update(['id' => 'ref-id', ...]); CkanApi::dataset()->delete('ref-id'); //Only for dataset CkanApi::dataset()->revision_list('ref-id');
Example to create a resource into a package
$data = [ 'url' => 'https://recursos-data.buenosaires.gob.ar/ckan2/distritos-escolares/distritos-escolares.csv', 'clear_upload' => true, 'package_id' => 'ckan-api-test-338', 'name' => 'Buenos Aires - Distritos Escolares', 'format' => 'CSV', 'description' => 'Límites y ubicación geográfica de los distritos escolares de la Ciudad que surgieron a partir de la Ley de Educación Común (Ley N° 1.420/1884). Actualmente rige la división establecida por el Decreto Nº 7.475/80.', ]; CkanApi::resource()->create($data);
Example to create a resource uploading a file
$data = [ 'upload' => fopen(storage_path('app/catalogo-bibliotecas.csv'), 'r'), // 'mimetype' => 'text/csv', 'package_id' => 'ckan-api-test-338', 'name' => 'Buenos Aires - Bibliotecas', 'format' => 'CSV', 'description' => 'Listado con ubicación geográfica de las bibliotecas de la Red del gobierno de la Ciudad Autónoma de Buenos Aires.', ]; CkanApi::resource()->create($data);
All possibles resources are:
CkanApi::dataset() CkanApi::resource() CkanApi::group() CkanApi::tag() CkanApi::revision() CkanApi::license() CkanApi::organization() CkanApi::user()
All resources has the following methods enabled, all, show, create, update, delete
, but some endpoints has only a few of those methods enabled.
See more examples at docs/simple_routing.md
For more information read http://docs.ckan.org/en/latest/api/