/laravel-ckan-api

API Client for Ckan - Laravel 5

Primary LanguagePHP

Laravel api client for ckan

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/