Skip to content

Commit

Permalink
Add video tags endpoint
Browse files Browse the repository at this point in the history
  • Loading branch information
olivierapivideo authored Sep 27, 2024
1 parent 240130e commit 3ce744c
Show file tree
Hide file tree
Showing 10 changed files with 869 additions and 2 deletions.
3 changes: 3 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,6 +1,9 @@
# Changelog
All changes to this project will be documented in this file.

## [1.4.3] - 2024-09-30
- Add /tags API endpoint

## [1.4.2] - 2024-09-16
- Add discarded video endpoints

Expand Down
19 changes: 19 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@
- [Chapters](#chapters)
- [LiveStreams](#livestreams)
- [PlayerThemes](#playerthemes)
- [Tags](#tags)
- [UploadTokens](#uploadtokens)
- [Videos](#videos)
- [Watermarks](#watermarks)
Expand Down Expand Up @@ -230,6 +231,22 @@ Method | HTTP request | Description
[**DeleteLogo**](https://github.com/apivideo/api.video-go-client/blob/main/docs/PlayerThemes.md#DeleteLogo) | **Delete** `/players/{playerId}/logo` | Delete logo


#### Tags


##### Retrieve an instance of the Tags API:
```golang
client := apivideosdk.ClientBuilder("API_VIDEO_KEY").Build()
tagsApi := client.Tags
```

##### Endpoints

Method | HTTP request | Description
------------- | ------------- | -------------
[**List**](https://github.com/apivideo/api.video-go-client/blob/main/docs/Tags.md#List) | **Get** `/tags` | List all video tags


#### UploadTokens


Expand Down Expand Up @@ -345,6 +362,8 @@ Method | HTTP request | Description
- [FilterBy1](https://github.com/apivideo/api.video-go-client/blob/main/docs/FilterBy1.md)
- [FilterBy2](https://github.com/apivideo/api.video-go-client/blob/main/docs/FilterBy2.md)
- [Link](https://github.com/apivideo/api.video-go-client/blob/main/docs/Link.md)
- [ListTagsResponse](https://github.com/apivideo/api.video-go-client/blob/main/docs/ListTagsResponse.md)
- [ListTagsResponseData](https://github.com/apivideo/api.video-go-client/blob/main/docs/ListTagsResponseData.md)
- [LiveStream](https://github.com/apivideo/api.video-go-client/blob/main/docs/LiveStream.md)
- [LiveStreamAssets](https://github.com/apivideo/api.video-go-client/blob/main/docs/LiveStreamAssets.md)
- [LiveStreamCreationPayload](https://github.com/apivideo/api.video-go-client/blob/main/docs/LiveStreamCreationPayload.md)
Expand Down
204 changes: 204 additions & 0 deletions api/openapi.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -974,6 +974,163 @@ paths:
code: |
// First install the api client: https://github.com/apivideo/api.video-swift-client#getting-started
// Documentation: https://github.com/apivideo/api.video-swift-client/blob/main/docs/VideosAPI.md#create
/tags:
get:
description: This endpoint enables you to search for video tags in a project
and see how many videos are tagged with them. If you do not define any query
parameters, the endpoint lists all video tags and the numbers of times they
are used in a project.
operationId: LIST-tags
parameters:
- description: |
Use this parameter to search for specific video tags. The API filters results even on partial values, and ignores accents, uppercase, and lowercase.
explode: true
in: query
name: value
required: false
schema:
type: string
style: form
- description: |
Use this parameter to choose which field the API will use to sort the response data. The default is `value`.

These are the available fields to sort by:

- `value`: Sorts the results based on tag values in alphabetic order.
- `videoCount`: Sorts the results based on the number of times a video tag is used.
example: value
explode: true
in: query
name: sortBy
required: false
schema:
enum:
- value
- videoCount
type: string
style: form
- description: Use this parameter to sort results. `asc` is ascending and sorts
from A to Z. `desc` is descending and sorts from Z to A.
example: asc
explode: true
in: query
name: sortOrder
required: false
schema:
enum:
- asc
- desc
type: string
style: form
- description: 'Choose the number of search results to return per page. Minimum
value: 1'
example: 2
explode: true
in: query
name: currentPage
required: false
schema:
default: 1
type: integer
style: form
- description: Results per page. Allowed values 1-100, default is 25.
example: 30
explode: true
in: query
name: pageSize
required: false
schema:
default: 25
type: integer
style: form
responses:
"200":
content:
application/json:
examples:
response:
value:
data:
- value: maths
videoCount: "33"
- value: tutorials
videoCount: "10"
pagination:
currentPage: 1
pageSize: 25
pagesTotal: 1
itemsTotal: 2
currentPageItems: 2
links:
- rel: self
uri: https://ws.api.video/watermarks?currentPage=1
- rel: first
uri: https://ws.api.video/watermarks?currentPage=1
- rel: last
uri: https://ws.api.video/watermarks?currentPage=1
schema:
$ref: '#/components/schemas/list-tags-response'
description: Success
headers:
X-RateLimit-Limit:
description: The request limit per minute.
explode: false
schema:
type: integer
style: simple
X-RateLimit-Remaining:
description: The number of available requests left for the current time
window.
explode: false
schema:
type: integer
style: simple
X-RateLimit-Retry-After:
description: The number of seconds left until the current rate limit
window resets.
explode: false
schema:
type: integer
style: simple
"429":
content:
application/json:
examples:
Too many requests:
value:
type: https://docs.api.video/reference/too-many-requests
title: Too many requests.
status: 429
schema:
$ref: '#/components/schemas/too-many-requests'
description: Too Many Requests
headers:
X-RateLimit-Limit:
description: The request limit per minute.
explode: false
schema:
type: integer
style: simple
X-RateLimit-Remaining:
description: The number of available requests left for the current time
window.
explode: false
schema:
type: integer
style: simple
X-RateLimit-Retry-After:
description: The number of seconds left until the current rate limit
window resets.
explode: false
schema:
type: integer
style: simple
summary: List all video tags
tags:
- Tags
x-client-action: list
x-group-parameters: true
x-client-paginated: true
/videos/{videoId}/source:
post:
description: Ingest a video from a source or file.
Expand Down Expand Up @@ -14765,6 +14922,41 @@ components:
- videoId
title: Video
type: object
list-tags-response:
example:
pagination:
itemsTotal: 123
pagesTotal: 7
pageSize: 20
currentPage: 3
currentPageItems: 20
links:
first:
rel: first
uri: /videos/search?currentPage=1&pageSize=20
previous:
rel: previous
uri: /videos/search?currentPage=2&pageSize=20
next:
rel: next
uri: /videos/search?currentPage=4&pageSize=20
last:
rel: last
uri: /videos/search?currentPage=6&pageSize=20
data:
- videoCount: 0
value: value
- videoCount: 0
value: value
properties:
data:
items:
$ref: '#/components/schemas/list_tags_response_data'
type: array
pagination:
$ref: '#/components/schemas/pagination'
title: Tags
type: object
watermark:
example:
watermarkId: watermark_1BWr2L5MTQwxGkuxKjzh6i
Expand Down Expand Up @@ -16903,6 +17095,18 @@ components:
type: string
type: object
x-is-deep-object: true
list_tags_response_data:
example:
videoCount: 0
value: value
properties:
value:
description: Returns the value of a video tag used in your project.
type: string
videoCount:
description: Returns the number of times a video tag is used.
type: integer
type: object
player_theme_assets:
example:
link: path/to/my/logo/mylogo.jpg
Expand Down
Loading

0 comments on commit 3ce744c

Please sign in to comment.