CKAN 데이터 API

강력한 질의 지원을 하는 웹 API를 통해 리소스 데이터 접근. Further information in the main CKAN Data API and DataStore documentation.

Code examples:

Get 5 results containing "jones" in any field:
curl https://data.kaltimprov.go.id/ko_KR/api/action/datastore_search \
  -H"Authorization:$API_TOKEN" -d '
{
  "resource_id": "7d2bb7ac-b982-4cae-b602-c3c60fa27c9e",
  "limit": 5,
  "q": "jones"
}'
const resp = await fetch(`https://data.kaltimprov.go.id/ko_KR/api/action/datastore_search`, {
    method: 'POST',
    headers: {
        'content-type': 'application/json',
        authorization: API_TOKEN
    },
    body: JSON.stringify({
        resource_id: '7d2bb7ac-b982-4cae-b602-c3c60fa27c9e',
        limit: 5,
        q: 'jones'
    })
})
await resp.json()
$json = @'
{
  "resource_id": "7d2bb7ac-b982-4cae-b602-c3c60fa27c9e",
  "limit": 5,
  "q": "jones"
}
'@
$response = Invoke-RestMethod https://data.kaltimprov.go.id/ko_KR/api/action/datastore_search`
  -Method Post -Body $json -Headers @{"Authorization"="$API_TOKEN"}
$response.result.records

(using the ckanapi client library)

from ckanapi import RemoteCKAN

rc = RemoteCKAN('https://data.kaltimprov.go.id/ko_KR/', apikey=API_TOKEN)
result = rc.action.datastore_search(
    resource_id="7d2bb7ac-b982-4cae-b602-c3c60fa27c9e",
    limit=5,
    q="jones",
)
print(result['records'])
library(httr2)

req <- request("https://data.kaltimprov.go.id/ko_KR/api/action/datastore_search")
result <- req %>% 
    req_headers(Authorization = API_TOKEN) %>% 
    req_body_json(list(
        resource_id = '7d2bb7ac-b982-4cae-b602-c3c60fa27c9e',
        limit = 5,
        q = 'jones'))
    req_perform %>% 
    resp_body_json
Get results with either "watershed" or "survey" as subject and "active" as its stage:
curl https://data.kaltimprov.go.id/ko_KR/api/action/datastore_search \
-H"Authorization:$API_TOKEN" -d '
{
"resource_id": "7d2bb7ac-b982-4cae-b602-c3c60fa27c9e",
  "filters": {
    "subject": ["watershed", "survey"],
    "stage": "active"
  }
}'
const resp = await fetch(`https://data.kaltimprov.go.id/ko_KR/api/action/datastore_search`, {
    method: 'POST',
    headers: {
        'content-type': 'application/json',
        authorization: API_TOKEN
    },
    body: JSON.stringify({resource_id: '7d2bb7ac-b982-4cae-b602-c3c60fa27c9e', filters: {
        subject: ['watershed', 'survey'],
        stage: 'active'
    }})})
await resp.json()
$json = @'
{
  "resource_id": "7d2bb7ac-b982-4cae-b602-c3c60fa27c9e",
  "filters": {
    "subject": ["watershed", "survey"],
    "stage": "active"
  }
}
'@
$response = Invoke-RestMethod https://data.kaltimprov.go.id/ko_KR/api/action/datastore_search`
  -Method Post -Body $json -Headers @{"Authorization"="$API_TOKEN"}
$response.result.records
from ckanapi import RemoteCKAN

rc = RemoteCKAN('https://data.kaltimprov.go.id/ko_KR/', apikey=API_TOKEN)
result = rc.action.datastore_search(
    resource_id="7d2bb7ac-b982-4cae-b602-c3c60fa27c9e",
    filters={
      "subject": ["watershed", "survey"],
      "stage": "active",
    },
)
print(result['records'])
library(httr2)

req <- request("https://data.kaltimprov.go.id/ko_KR/api/action/datastore_search")
result <- req %>% 
    req_headers(Authorization = API_TOKEN) %>% 
    req_body_json(list(
        resource_id='7d2bb7ac-b982-4cae-b602-c3c60fa27c9e', 
        filters = list(
            subject = list("watershed", "survey"), 
            stage = "active")))
    req_perform %>% 
    resp_body_json

Some API endpoints may be accessed using a GET query string.

질의 예제 (첫 5개 결과)

https://data.kaltimprov.go.id/ko_KR/api/action/datastore_search?resource_id=7d2bb7ac-b982-4cae-b602-c3c60fa27c9e&limit=5

질의 예제 ('jones'을 포함하는 결과)

https://data.kaltimprov.go.id/ko_KR/api/action/datastore_search?resource_id=7d2bb7ac-b982-4cae-b602-c3c60fa27c9e&q=jones