De Lijn Kern Open Data Services (Beta)
API change historyDit document beschrijft de kern operaties van de Open Data API (Beta version).
geef de lijnrichtingen van lijnen op basis van een lijst van lijn sleutels
geef de lijnrichtingen van lijnen op basis van een lijst van lijn sleutels
Try itRequest
Request URL
Request parameters
-
string
lijst van lijn sleutels (bv 1/500/1/550)
Request headers
Request body
Responses
200 OK
successful operation
Representations
{
"lijnLijnrichtingen": [
{
"lijn": {
"entiteitnummer": "3",
"lijnnummer": "335",
"lijnnummerPubliek": "335",
"omschrijving": "Leuven - Aarschot",
"vervoerRegioCode": "VR",
"publiek": true,
"vervoertype": "METRO",
"bedieningtype": "BELBUS",
"lijnGeldigVan": "2016-08-31",
"lijnGeldigTot": "2016-10-30",
"links": [
{
"rel": "string",
"url": "string"
}
]
},
"lijnrichtingen": [
{
"lijnNummerPubliek": "335",
"entiteitnummer": "3",
"lijnnummer": "335",
"richting": "HEEN",
"omschrijving": "Leuven - Aarschot",
"bestemming": "LEUVEN GASTHUISB.",
"kleurVoorGrond": "#FFFFFF",
"kleurAchterGrond": "#991199",
"kleurAchterGrondRand": "#991199",
"links": [
{
"rel": "string",
"url": "string"
}
]
}
]
}
],
"links": [
{
"rel": "string",
"url": "string"
}
]
}
{
"type": "object",
"properties": {
"lijnLijnrichtingen": {
"type": "array",
"items": {
"required": [
"lijn",
"lijnrichtingen"
],
"type": "object",
"properties": {
"lijn": {
"required": [
"bedieningtype",
"entiteitnummer",
"lijnGeldigTot",
"lijnGeldigVan",
"lijnnummer",
"lijnnummerPubliek",
"omschrijving",
"publiek",
"vervoerRegioCode",
"vervoertype"
],
"type": "object",
"properties": {
"entiteitnummer": {
"type": "string",
"description": "entiteit nummer (key waarde)",
"example": "3"
},
"lijnnummer": {
"type": "string",
"description": "intern lijn nummer (key waarde)",
"example": "335"
},
"lijnnummerPubliek": {
"type": "string",
"description": "lijn nummer zoals gekend voor de reizigerr",
"example": "335"
},
"omschrijving": {
"type": "string",
"description": "omschrijving van de lijn",
"example": "Leuven - Aarschot"
},
"vervoerRegioCode": {
"type": "string",
"description": "code van de vervoerregio waar de lijn zich bevindt",
"example": "VR"
},
"publiek": {
"type": "boolean",
"description": "is de lijn toegankelijk voor het publiek",
"example": true
},
"vervoertype": {
"enum": [
"BUS",
"TRAM",
"METRO",
"TREIN",
"ALLE"
],
"type": "string",
"description": "het vervoerstype van de lijn",
"example": "METRO"
},
"bedieningtype": {
"enum": [
"NORMAAL",
"SNELDIENST",
"SCHOOLBUS",
"FABRIEKSLIJN",
"TECHNISCHE_LIJN",
"BELBUS",
"NACHTLIJN"
],
"type": "string",
"description": "het bedieningtype van de lijn",
"example": "BELBUS"
},
"lijnGeldigVan": {
"type": "string",
"description": "de start datum van de dienstregeling zoals die momenteel geldt",
"format": "date-time",
"example": "2016-08-31T12:00:00Z"
},
"lijnGeldigTot": {
"type": "string",
"description": "de eind datum van de dienstregeling zoals die momenteel geldt",
"format": "date-time",
"example": "2016-10-30T12:00:00Z"
},
"links": {
"type": "array",
"items": {
"type": "object",
"properties": {
"rel": {
"type": "string"
},
"url": {
"type": "string"
}
}
}
}
}
},
"lijnrichtingen": {
"type": "array",
"items": {
"required": [
"entiteitnummer",
"lijnnummer",
"omschrijving",
"richting"
],
"type": "object",
"properties": {
"lijnNummerPubliek": {
"type": "string",
"description": "publiek lijnnummer",
"example": "335"
},
"entiteitnummer": {
"type": "string",
"description": "entiteit nummer",
"example": "3"
},
"lijnnummer": {
"type": "string",
"description": "lijn nummer",
"example": "335"
},
"richting": {
"enum": [
"HEEN",
"TERUG"
],
"type": "string",
"description": "richting van de lijn",
"example": "HEEN"
},
"omschrijving": {
"type": "string",
"description": "omschrijving van de lijnrichting",
"example": "Leuven - Aarschot"
},
"bestemming": {
"type": "string",
"description": "eindhalte van de lijnrichting",
"example": "LEUVEN GASTHUISB."
},
"kleurVoorGrond": {
"type": "string",
"description": "kleur van het lijnnummer op het vignet",
"example": "#FFFFFF"
},
"kleurAchterGrond": {
"type": "string",
"description": "achtergrond kleur van het lijn vignet",
"example": "#991199"
},
"kleurAchterGrondRand": {
"type": "string",
"description": "kleur van de rand van het lijn vignet",
"example": "#991199"
},
"links": {
"type": "array",
"items": {
"type": "object",
"properties": {
"rel": {
"type": "string"
},
"url": {
"type": "string"
}
}
}
}
}
},
"description": "Geeft de lijnrichting(en) van de lijn sleutel"
}
}
},
"readOnly": true
},
"links": {
"type": "array",
"items": {
"type": "object",
"properties": {
"rel": {
"type": "string"
},
"url": {
"type": "string"
}
}
}
}
}
}
Code samples
@ECHO OFF
curl -v -X GET "https://api.delijn.be/DLKernOpenData/v1/beta/lijnen/{lijnsleutels}/lijnrichtingen"
-H "Ocp-Apim-Subscription-Key: {subscription key}"
--data-ascii "{body}"
using System;
using System.Net.Http.Headers;
using System.Text;
using System.Net.Http;
using System.Web;
namespace CSHttpClientSample
{
static class Program
{
static void Main()
{
MakeRequest();
Console.WriteLine("Hit ENTER to exit...");
Console.ReadLine();
}
static async void MakeRequest()
{
var client = new HttpClient();
var queryString = HttpUtility.ParseQueryString(string.Empty);
// Request headers
client.DefaultRequestHeaders.Add("Ocp-Apim-Subscription-Key", "{subscription key}");
var uri = "https://api.delijn.be/DLKernOpenData/v1/beta/lijnen/{lijnsleutels}/lijnrichtingen?" + queryString;
var response = await client.GetAsync(uri);
}
}
}
// // This sample uses the Apache HTTP client from HTTP Components (http://hc.apache.org/httpcomponents-client-ga/)
import java.net.URI;
import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.client.HttpClient;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.client.utils.URIBuilder;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.util.EntityUtils;
public class JavaSample
{
public static void main(String[] args)
{
HttpClient httpclient = HttpClients.createDefault();
try
{
URIBuilder builder = new URIBuilder("https://api.delijn.be/DLKernOpenData/v1/beta/lijnen/{lijnsleutels}/lijnrichtingen");
URI uri = builder.build();
HttpGet request = new HttpGet(uri);
request.setHeader("Ocp-Apim-Subscription-Key", "{subscription key}");
// Request body
StringEntity reqEntity = new StringEntity("{body}");
request.setEntity(reqEntity);
HttpResponse response = httpclient.execute(request);
HttpEntity entity = response.getEntity();
if (entity != null)
{
System.out.println(EntityUtils.toString(entity));
}
}
catch (Exception e)
{
System.out.println(e.getMessage());
}
}
}
<!DOCTYPE html>
<html>
<head>
<title>JSSample</title>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.0/jquery.min.js"></script>
</head>
<body>
<script type="text/javascript">
$(function() {
var params = {
// Request parameters
};
$.ajax({
url: "https://api.delijn.be/DLKernOpenData/v1/beta/lijnen/{lijnsleutels}/lijnrichtingen?" + $.param(params),
beforeSend: function(xhrObj){
// Request headers
xhrObj.setRequestHeader("Ocp-Apim-Subscription-Key","{subscription key}");
},
type: "GET",
// Request body
data: "{body}",
})
.done(function(data) {
alert("success");
})
.fail(function() {
alert("error");
});
});
</script>
</body>
</html>
#import <Foundation/Foundation.h>
int main(int argc, const char * argv[])
{
NSAutoreleasePool * pool = [[NSAutoreleasePool alloc] init];
NSString* path = @"https://api.delijn.be/DLKernOpenData/v1/beta/lijnen/{lijnsleutels}/lijnrichtingen";
NSArray* array = @[
// Request parameters
@"entities=true",
];
NSString* string = [array componentsJoinedByString:@"&"];
path = [path stringByAppendingFormat:@"?%@", string];
NSLog(@"%@", path);
NSMutableURLRequest* _request = [NSMutableURLRequest requestWithURL:[NSURL URLWithString:path]];
[_request setHTTPMethod:@"GET"];
// Request headers
[_request setValue:@"{subscription key}" forHTTPHeaderField:@"Ocp-Apim-Subscription-Key"];
// Request body
[_request setHTTPBody:[@"{body}" dataUsingEncoding:NSUTF8StringEncoding]];
NSURLResponse *response = nil;
NSError *error = nil;
NSData* _connectionData = [NSURLConnection sendSynchronousRequest:_request returningResponse:&response error:&error];
if (nil != error)
{
NSLog(@"Error: %@", error);
}
else
{
NSError* error = nil;
NSMutableDictionary* json = nil;
NSString* dataString = [[NSString alloc] initWithData:_connectionData encoding:NSUTF8StringEncoding];
NSLog(@"%@", dataString);
if (nil != _connectionData)
{
json = [NSJSONSerialization JSONObjectWithData:_connectionData options:NSJSONReadingMutableContainers error:&error];
}
if (error || !json)
{
NSLog(@"Could not parse loaded json with error:%@", error);
}
NSLog(@"%@", json);
_connectionData = nil;
}
[pool drain];
return 0;
}
<?php
// This sample uses the Apache HTTP client from HTTP Components (http://hc.apache.org/httpcomponents-client-ga/)
require_once 'HTTP/Request2.php';
$request = new Http_Request2('https://api.delijn.be/DLKernOpenData/v1/beta/lijnen/{lijnsleutels}/lijnrichtingen');
$url = $request->getUrl();
$headers = array(
// Request headers
'Ocp-Apim-Subscription-Key' => '{subscription key}',
);
$request->setHeader($headers);
$parameters = array(
// Request parameters
);
$url->setQueryVariables($parameters);
$request->setMethod(HTTP_Request2::METHOD_GET);
// Request body
$request->setBody("{body}");
try
{
$response = $request->send();
echo $response->getBody();
}
catch (HttpException $ex)
{
echo $ex;
}
?>
########### Python 2.7 #############
import httplib, urllib, base64
headers = {
# Request headers
'Ocp-Apim-Subscription-Key': '{subscription key}',
}
params = urllib.urlencode({
})
try:
conn = httplib.HTTPSConnection('api.delijn.be')
conn.request("GET", "/DLKernOpenData/v1/beta/lijnen/{lijnsleutels}/lijnrichtingen?%s" % params, "{body}", headers)
response = conn.getresponse()
data = response.read()
print(data)
conn.close()
except Exception as e:
print("[Errno {0}] {1}".format(e.errno, e.strerror))
####################################
########### Python 3.2 #############
import http.client, urllib.request, urllib.parse, urllib.error, base64
headers = {
# Request headers
'Ocp-Apim-Subscription-Key': '{subscription key}',
}
params = urllib.parse.urlencode({
})
try:
conn = http.client.HTTPSConnection('api.delijn.be')
conn.request("GET", "/DLKernOpenData/v1/beta/lijnen/{lijnsleutels}/lijnrichtingen?%s" % params, "{body}", headers)
response = conn.getresponse()
data = response.read()
print(data)
conn.close()
except Exception as e:
print("[Errno {0}] {1}".format(e.errno, e.strerror))
####################################
require 'net/http'
uri = URI('https://api.delijn.be/DLKernOpenData/v1/beta/lijnen/{lijnsleutels}/lijnrichtingen')
request = Net::HTTP::Get.new(uri.request_uri)
# Request headers
request['Ocp-Apim-Subscription-Key'] = '{subscription key}'
# Request body
request.body = "{body}"
response = Net::HTTP.start(uri.host, uri.port, :use_ssl => uri.scheme == 'https') do |http|
http.request(request)
end
puts response.body