2018-05-06 12:19:08 +02:00
|
|
|
{
|
|
|
|
"get": {
|
2018-09-20 20:52:27 +02:00
|
|
|
"operationId": "shortenUrl",
|
2018-05-06 12:19:08 +02:00
|
|
|
"tags": [
|
2018-09-20 20:52:27 +02:00
|
|
|
"Short URLs"
|
2018-05-06 12:19:08 +02:00
|
|
|
],
|
|
|
|
"summary": "Create a short URL",
|
2019-12-31 16:05:02 +01:00
|
|
|
"description": "Creates a short URL in a single API call. Useful for third party integrations.",
|
2018-05-06 12:19:08 +02:00
|
|
|
"parameters": [
|
2019-11-29 19:09:03 +01:00
|
|
|
{
|
|
|
|
"$ref": "../parameters/version.json"
|
|
|
|
},
|
2018-05-06 12:19:08 +02:00
|
|
|
{
|
|
|
|
"name": "apiKey",
|
|
|
|
"in": "query",
|
|
|
|
"description": "The API key used to authenticate the request",
|
|
|
|
"required": true,
|
|
|
|
"schema": {
|
|
|
|
"type": "string"
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"name": "longUrl",
|
|
|
|
"in": "query",
|
|
|
|
"description": "The URL to be shortened",
|
|
|
|
"required": true,
|
|
|
|
"schema": {
|
|
|
|
"type": "string"
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"name": "format",
|
|
|
|
"in": "query",
|
|
|
|
"description": "The format in which you want the response to be returned. You can also use the \"Accept\" header instead of this",
|
|
|
|
"required": false,
|
|
|
|
"schema": {
|
|
|
|
"type": "string",
|
|
|
|
"enum": [
|
|
|
|
"txt",
|
|
|
|
"json"
|
|
|
|
]
|
|
|
|
}
|
|
|
|
}
|
|
|
|
],
|
|
|
|
"responses": {
|
|
|
|
"200": {
|
|
|
|
"description": "The list of short URLs",
|
|
|
|
"content": {
|
|
|
|
"application/json": {
|
|
|
|
"schema": {
|
2018-11-16 16:57:18 +01:00
|
|
|
"$ref": "../definitions/ShortUrl.json"
|
2018-05-06 12:19:08 +02:00
|
|
|
}
|
|
|
|
},
|
|
|
|
"text/plain": {
|
|
|
|
"schema": {
|
|
|
|
"type": "string"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
"examples": {
|
|
|
|
"application/json": {
|
|
|
|
"longUrl": "https://github.com/shlinkio/shlink",
|
2018-11-16 16:57:18 +01:00
|
|
|
"shortUrl": "https://doma.in/abc123",
|
|
|
|
"shortCode": "abc123",
|
|
|
|
"dateCreated": "2016-08-21T20:34:16+02:00",
|
|
|
|
"visitsCount": 0,
|
|
|
|
"tags": [
|
|
|
|
"games",
|
|
|
|
"tech"
|
2019-07-08 18:42:53 +02:00
|
|
|
],
|
|
|
|
"meta": {
|
|
|
|
"validSince": "2017-01-21T00:00:00+02:00",
|
|
|
|
"validUntil": null,
|
|
|
|
"maxVisits": 100
|
2020-02-02 08:57:04 +01:00
|
|
|
},
|
2021-02-02 20:51:28 +01:00
|
|
|
"domain": null,
|
2021-05-22 07:32:47 +02:00
|
|
|
"title": null,
|
|
|
|
"crawlable": false
|
2018-05-06 12:19:08 +02:00
|
|
|
},
|
2018-11-16 16:57:18 +01:00
|
|
|
"text/plain": "https://doma.in/abc123"
|
2018-05-06 12:19:08 +02:00
|
|
|
}
|
|
|
|
},
|
|
|
|
"400": {
|
|
|
|
"description": "The long URL was not provided or is invalid.",
|
|
|
|
"content": {
|
2019-11-28 19:37:22 +01:00
|
|
|
"application/problem+json": {
|
2018-05-06 12:19:08 +02:00
|
|
|
"schema": {
|
|
|
|
"$ref": "../definitions/Error.json"
|
|
|
|
}
|
|
|
|
},
|
|
|
|
"text/plain": {
|
|
|
|
"schema": {
|
|
|
|
"type": "string"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
"examples": {
|
2019-11-28 19:37:22 +01:00
|
|
|
"application/problem+json": {
|
|
|
|
"title": "Invalid URL",
|
|
|
|
"type": "INVALID_URL",
|
|
|
|
"detail": "Provided URL foo is invalid. Try with a different one.",
|
|
|
|
"status": 400,
|
|
|
|
"url": "https://invalid-url.com"
|
2018-05-06 12:19:08 +02:00
|
|
|
},
|
|
|
|
"text/plain": "INVALID_URL"
|
|
|
|
}
|
|
|
|
},
|
|
|
|
"500": {
|
|
|
|
"description": "Unexpected error.",
|
|
|
|
"content": {
|
2019-11-28 19:37:22 +01:00
|
|
|
"application/problem+json": {
|
2018-05-06 12:19:08 +02:00
|
|
|
"schema": {
|
|
|
|
"$ref": "../definitions/Error.json"
|
|
|
|
}
|
|
|
|
},
|
|
|
|
"text/plain": {
|
|
|
|
"schema": {
|
|
|
|
"type": "string"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
"examples": {
|
2019-11-28 19:37:22 +01:00
|
|
|
"application/problem+json": {
|
2019-11-25 19:15:46 +01:00
|
|
|
"error": "INTERNAL_SERVER_ERROR",
|
2018-05-06 12:19:08 +02:00
|
|
|
"message": "Unexpected error occurred"
|
|
|
|
},
|
2019-11-25 19:15:46 +01:00
|
|
|
"text/plain": "INTERNAL_SERVER_ERROR"
|
2018-05-06 12:19:08 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|