Skip to content

Commit

Permalink
Add transcript feature
Browse files Browse the repository at this point in the history
  • Loading branch information
olivierapivideo authored Oct 8, 2024
1 parent e8ce368 commit 14cd125
Show file tree
Hide file tree
Showing 24 changed files with 166 additions and 12 deletions.
2 changes: 1 addition & 1 deletion .openapi-generator/oas_apivideo.yaml-defaut-cli.sha256
Original file line number Diff line number Diff line change
@@ -1 +1 @@
49fece4f39cb92341dc77e0eb7371a152903bf6aebcfa250d289efc9018b0f72
408ded0eac343dc4e06f2885cbfff90ed5b358f8841ee006d063b93ab0fb7f9b
4 changes: 2 additions & 2 deletions ApiVideoClient.podspec
Original file line number Diff line number Diff line change
Expand Up @@ -5,8 +5,8 @@ Pod::Spec.new do |s|
s.tvos.deployment_target = '10.0'
# Add back when CocoaPods/CocoaPods#11558 is released
#s.watchos.deployment_target = '3.0'
s.version = '1.3.3'
s.source = { :git => 'https://github.com/apivideo/api.video-swift-client', :tag => 'v1.3.3' }
s.version = '1.3.4'
s.source = { :git => 'https://github.com/apivideo/api.video-swift-client', :tag => 'v1.3.4' }
s.authors = { 'Ecosystem Team' => 'ecosystem@api.video' }
s.license = { :type => 'MIT' }
s.homepage = 'https://docs.api.video'
Expand Down
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.3.4] - 2024-10-08
- Add transcript feature

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

Expand Down
4 changes: 2 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -56,14 +56,14 @@ api.video's Swift API client for iOS, macOS and tvOS streamlines the coding proc
Specify it in your `Cartfile`:

```
github "apivideo/api.video-swift-client" ~> 1.3.3
github "apivideo/api.video-swift-client" ~> 1.3.4
```

Run `carthage update`

#### CocoaPods

Add `pod 'ApiVideoClient', '1.3.3'` in your `Podfile`
Add `pod 'ApiVideoClient', '1.3.4'` in your `Podfile`

Run `pod install`

Expand Down
2 changes: 1 addition & 1 deletion Sources/APIs.swift
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ import Foundation
public class ApiVideoClient {
public static var apiKey: String? = nil
public static var basePath = "https://ws.api.video"
internal static var customHeaders:[String: String] = ["AV-Origin-Client": "swift:1.3.3"]
internal static var customHeaders:[String: String] = ["AV-Origin-Client": "swift:1.3.4"]
private static var chunkSize: Int = 50 * 1024 * 1024
internal static var requestBuilderFactory: RequestBuilderFactory = AlamofireRequestBuilderFactory()
internal static var credential = ApiVideoCredential()
Expand Down
16 changes: 15 additions & 1 deletion Sources/Models/Video.swift
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,10 @@ import AnyCodable

public struct Video: Codable, Hashable {

public enum LanguageOrigin: String, Codable, CaseIterable {
case api = "api"
case auto = "auto"
}
/** The unique identifier of the video object. */
public var videoId: String
/** When a video was created, presented in ATOM UTC format. */
Expand All @@ -30,6 +34,10 @@ public struct Video: Codable, Hashable {
public var deletesAt: Date?
/** Returns `true` for videos you discarded when you have the Video Restore feature enabled. Returns `false` for every other video. */
public var discarded: Bool?
/** Returns the language of a video in [IETF language tag](https://en.wikipedia.org/wiki/IETF_language_tag) format. You can set the language during video creation via the API, otherwise it is detected automatically. */
public var language: String?
/** Returns the origin of the last update on the video's `language` attribute. - `api` means that the last update was requested from the API. - `auto` means that the last update was done automatically by the API. */
public var languageOrigin: LanguageOrigin?
/** One array of tags (each tag is a string) in order to categorize a video. Tags may include spaces. */
public var tags: [String]?
/** Metadata you can use to categorise and filter videos. Metadata is a list of dictionaries, where each dictionary represents a key value pair for categorising a video. */
Expand All @@ -45,7 +53,7 @@ public struct Video: Codable, Hashable {
/** This lets you know whether mp4 is supported. If enabled, an mp4 URL will be provided in the response for the video. */
public var mp4Support: Bool?

public init(videoId: String, createdAt: Date? = nil, title: String? = nil, description: String? = nil, publishedAt: Date? = nil, updatedAt: Date? = nil, discardedAt: Date? = nil, deletesAt: Date? = nil, discarded: Bool? = nil, tags: [String]? = nil, metadata: [Metadata]? = nil, source: VideoSource? = nil, assets: VideoAssets? = nil, playerId: String? = nil, _public: Bool? = nil, panoramic: Bool? = nil, mp4Support: Bool? = nil) {
public init(videoId: String, createdAt: Date? = nil, title: String? = nil, description: String? = nil, publishedAt: Date? = nil, updatedAt: Date? = nil, discardedAt: Date? = nil, deletesAt: Date? = nil, discarded: Bool? = nil, language: String? = nil, languageOrigin: LanguageOrigin? = nil, tags: [String]? = nil, metadata: [Metadata]? = nil, source: VideoSource? = nil, assets: VideoAssets? = nil, playerId: String? = nil, _public: Bool? = nil, panoramic: Bool? = nil, mp4Support: Bool? = nil) {
self.videoId = videoId
self.createdAt = createdAt
self.title = title
Expand All @@ -55,6 +63,8 @@ public struct Video: Codable, Hashable {
self.discardedAt = discardedAt
self.deletesAt = deletesAt
self.discarded = discarded
self.language = language
self.languageOrigin = languageOrigin
self.tags = tags
self.metadata = metadata
self.source = source
Expand All @@ -75,6 +85,8 @@ public struct Video: Codable, Hashable {
case discardedAt
case deletesAt
case discarded
case language
case languageOrigin
case tags
case metadata
case source
Expand All @@ -98,6 +110,8 @@ public struct Video: Codable, Hashable {
try container.encodeIfPresent(discardedAt, forKey: .discardedAt)
try container.encodeIfPresent(deletesAt, forKey: .deletesAt)
try container.encodeIfPresent(discarded, forKey: .discarded)
try container.encodeIfPresent(language, forKey: .language)
try container.encodeIfPresent(languageOrigin, forKey: .languageOrigin)
try container.encodeIfPresent(tags, forKey: .tags)
try container.encodeIfPresent(metadata, forKey: .metadata)
try container.encodeIfPresent(source, forKey: .source)
Expand Down
47 changes: 46 additions & 1 deletion Sources/Models/VideoCreationPayload.swift
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,41 @@ import AnyCodable

public struct VideoCreationPayload: Codable, Hashable {

public enum Language: String, Codable, CaseIterable {
case ar = "ar"
case ca = "ca"
case cs = "cs"
case da = "da"
case de = "de"
case el = "el"
case en = "en"
case es = "es"
case fa = "fa"
case fi = "fi"
case fr = "fr"
case he = "he"
case hi = "hi"
case hr = "hr"
case hu = "hu"
case it = "it"
case ja = "ja"
case ko = "ko"
case ml = "ml"
case nl = "nl"
case nn = "nn"
case _false = "false"
case pl = "pl"
case pt = "pt"
case ru = "ru"
case sk = "sk"
case sl = "sl"
case te = "te"
case tr = "tr"
case uk = "uk"
case ur = "ur"
case vi = "vi"
case zh = "zh"
}
/** The title of your new video. */
public var title: String
/** A brief description of your video. */
Expand All @@ -32,8 +67,12 @@ public struct VideoCreationPayload: Codable, Hashable {
public var metadata: [Metadata]?
public var clip: VideoClip?
public var watermark: VideoWatermark?
/** Use this parameter to set the language of the video. When this parameter is set, the API creates a transcript of the video using the language you specify. You must use the [IETF language tag](https://en.wikipedia.org/wiki/IETF_language_tag) format. `language` is a permanent attribute of the video. You can update it to another language using the [`PATCH /videos/{videoId}`](https://docs.api.video/reference/api/Videos#update-a-video-object) operation. This triggers the API to generate a new transcript using a different language. */
public var language: Language?
/** Use this parameter to enable transcription. - When `true`, the API generates a transcript for the video. - The default value is `false`. - If you define a video language using the `language` parameter, the API uses that language to transcribe the video. If you do not define a language, the API detects it based on the video. - When the API generates a transcript, it will be available as a caption for the video. */
public var transcript: Bool?

public init(title: String, description: String? = nil, source: String? = nil, _public: Bool? = true, panoramic: Bool? = false, mp4Support: Bool? = true, playerId: String? = nil, tags: [String]? = nil, metadata: [Metadata]? = nil, clip: VideoClip? = nil, watermark: VideoWatermark? = nil) {
public init(title: String, description: String? = nil, source: String? = nil, _public: Bool? = true, panoramic: Bool? = false, mp4Support: Bool? = true, playerId: String? = nil, tags: [String]? = nil, metadata: [Metadata]? = nil, clip: VideoClip? = nil, watermark: VideoWatermark? = nil, language: Language? = nil, transcript: Bool? = nil) {
self.title = title
self.description = description
self.source = source
Expand All @@ -45,6 +84,8 @@ public struct VideoCreationPayload: Codable, Hashable {
self.metadata = metadata
self.clip = clip
self.watermark = watermark
self.language = language
self.transcript = transcript
}

public enum CodingKeys: String, CodingKey, CaseIterable {
Expand All @@ -59,6 +100,8 @@ public struct VideoCreationPayload: Codable, Hashable {
case metadata
case clip
case watermark
case language
case transcript
}

// Encodable protocol methods
Expand All @@ -76,6 +119,8 @@ public struct VideoCreationPayload: Codable, Hashable {
try container.encodeIfPresent(metadata, forKey: .metadata)
try container.encodeIfPresent(clip, forKey: .clip)
try container.encodeIfPresent(watermark, forKey: .watermark)
try container.encodeIfPresent(language, forKey: .language)
try container.encodeIfPresent(transcript, forKey: .transcript)
}
}

47 changes: 46 additions & 1 deletion Sources/Models/VideoUpdatePayload.swift
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,41 @@ import AnyCodable

public struct VideoUpdatePayload: Codable, Hashable {

public enum Language: String, Codable, CaseIterable {
case ar = "ar"
case ca = "ca"
case cs = "cs"
case da = "da"
case de = "de"
case el = "el"
case en = "en"
case es = "es"
case fa = "fa"
case fi = "fi"
case fr = "fr"
case he = "he"
case hi = "hi"
case hr = "hr"
case hu = "hu"
case it = "it"
case ja = "ja"
case ko = "ko"
case ml = "ml"
case nl = "nl"
case nn = "nn"
case _false = "false"
case pl = "pl"
case pt = "pt"
case ru = "ru"
case sk = "sk"
case sl = "sl"
case te = "te"
case tr = "tr"
case uk = "uk"
case ur = "ur"
case vi = "vi"
case zh = "zh"
}
/** The unique ID for the player you want to associate with your video. */
public var playerId: NullableString?
/** The title you want to use for your video. */
Expand All @@ -28,8 +63,12 @@ public struct VideoUpdatePayload: Codable, Hashable {
public var tags: [String]?
/** A list (array) of dictionaries where each dictionary contains a key value pair that describes the video. As with tags, you must send the complete list of metadata you want as whatever you send here will overwrite the existing metadata for the video. */
public var metadata: [Metadata]?
/** Use this parameter to set the language of the video. When this parameter is set, the API creates a transcript of the video using the language you specify. You must use the [IETF language tag](https://en.wikipedia.org/wiki/IETF_language_tag) format. `language` is a permanent attribute of the video. You can update it to another language using the [`PATCH /videos/{videoId}`](https://docs.api.video/reference/api/Videos#update-a-video-object) operation. This triggers the API to generate a new transcript using a different language. */
public var language: Language?
/** Use this parameter to enable transcription. - When `true`, the API generates a transcript for the video. - The default value is `false`. - If you define a video language using the `language` parameter, the API uses that language to transcribe the video. If you do not define a language, the API detects it based on the video. - When the API generates a transcript, it will be available as a caption for the video. */
public var transcript: Bool?

public init(playerId: NullableString? = nil, title: String? = nil, description: String? = nil, _public: Bool? = nil, panoramic: Bool? = nil, mp4Support: Bool? = nil, tags: [String]? = nil, metadata: [Metadata]? = nil) {
public init(playerId: NullableString? = nil, title: String? = nil, description: String? = nil, _public: Bool? = nil, panoramic: Bool? = nil, mp4Support: Bool? = nil, tags: [String]? = nil, metadata: [Metadata]? = nil, language: Language? = nil, transcript: Bool? = nil) {
self.playerId = playerId
self.title = title
self.description = description
Expand All @@ -38,6 +77,8 @@ public struct VideoUpdatePayload: Codable, Hashable {
self.mp4Support = mp4Support
self.tags = tags
self.metadata = metadata
self.language = language
self.transcript = transcript
}

public enum CodingKeys: String, CodingKey, CaseIterable {
Expand All @@ -49,6 +90,8 @@ public struct VideoUpdatePayload: Codable, Hashable {
case mp4Support
case tags
case metadata
case language
case transcript
}

// Encodable protocol methods
Expand All @@ -63,6 +106,8 @@ public struct VideoUpdatePayload: Codable, Hashable {
try container.encodeIfPresent(mp4Support, forKey: .mp4Support)
try container.encodeIfPresent(tags, forKey: .tags)
try container.encodeIfPresent(metadata, forKey: .metadata)
try container.encodeIfPresent(language, forKey: .language)
try container.encodeIfPresent(transcript, forKey: .transcript)
}
}

2 changes: 2 additions & 0 deletions Tests/TestResources/payloads/videos/create/responses/201.json
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,8 @@
"videoId" : "vi4blUQJFrYWbaG44NChkH27",
"title" : "Maths video",
"description" : "An amazing video explaining the string theory",
"language" : "en",
"languageOrigin" : "api",
"public" : false,
"panoramic" : false,
"mp4Support" : true,
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
{
"type" : "https://docs.api.video/reference/invalid-attribute",
"title" : "An attribute is invalid.",
"status" : 400,
"detail" : "The \"language\" attribute must contain only letters and dashes (for example \"fr\", \"fr-BE\").",
"name" : "language"
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
{
"type" : "https://docs.api.video/reference/invalid-attribute",
"title" : "An attribute is invalid.",
"status" : 400,
"detail" : "The \"language\" attribute is not valid.",
"name" : "language"
}
2 changes: 2 additions & 0 deletions Tests/TestResources/payloads/videos/get/responses/200.json
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,8 @@
"playerId" : "pl45KFKdlddgk654dspkze",
"title" : "Maths video",
"description" : "An amazing video explaining string theory",
"language" : "en",
"languageOrigin" : "api",
"public" : false,
"panoramic" : false,
"mp4Support" : true,
Expand Down
6 changes: 6 additions & 0 deletions Tests/TestResources/payloads/videos/list/responses/200.json
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,8 @@
"playerId" : "pl45KFKdlddgk654dspkze",
"title" : "Maths video",
"description" : "An amazing video explaining the string theory",
"language" : "en",
"languageOrigin" : "api",
"public" : false,
"panoramic" : false,
"mp4Support" : true,
Expand Down Expand Up @@ -32,6 +34,8 @@
"videoId" : "vi4blUQJFrYWbaG44NChkH27",
"title" : "Video Title",
"description" : "A description for your video.",
"language" : "en",
"languageOrigin" : "api",
"public" : false,
"panoramic" : false,
"mp4Support" : true,
Expand Down Expand Up @@ -64,6 +68,8 @@
"playerId" : "pl45KFKdlddgk654dspkze",
"title" : "My Video Title",
"description" : "A brief description of the video.",
"language" : "fr",
"languageOrigin" : "api",
"public" : false,
"panoramic" : false,
"mp4Support" : true,
Expand Down
2 changes: 2 additions & 0 deletions Tests/TestResources/payloads/videos/update/responses/200.json
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,8 @@
"playerId" : "pl45KFKdlddgk654dspkze",
"title" : "Maths video",
"description" : "An amazing video explaining the string theory",
"language" : "en",
"languageOrigin" : "api",
"public" : false,
"panoramic" : false,
"mp4Support" : true,
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
{
"type" : "https://docs.api.video/reference/invalid-attribute",
"title" : "An attribute is invalid.",
"status" : 400,
"detail" : "The \"language\" attribute must contain only letters and dashes (for example \"fr\", \"fr-BE\").",
"name" : "language"
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
{
"type" : "https://docs.api.video/reference/invalid-attribute",
"title" : "An attribute is invalid.",
"status" : 400,
"detail" : "The \"language\" attribute is not valid.",
"name" : "language"
}
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@
"playerId" : "pl45KFKdlddgk654dspkze",
"title" : "Maths video",
"description" : "An amazing video explaining the string theory",
"language" : "en",
"public" : false,
"panoramic" : false,
"tags" : [ "maths", "string theory", "video" ],
Expand Down
2 changes: 2 additions & 0 deletions docs/Video.md
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,8 @@ Name | Type | Description | Notes
**discardedAt** | **Date** | The date and time the video was discarded. The API populates this field only if you have the Video Restore feature enabled and discard a video. Date and time are provided using ATOM UTC format. | [optional]
**deletesAt** | **Date** | The date and time the video will be permanently deleted. The API populates this field only if you have the Video Restore feature enabled and discard a video. Discarded videos are pemanently deleted after 90 days. Date and time are provided using ATOM UTC format. | [optional]
**discarded** | **Bool** | Returns `true` for videos you discarded when you have the Video Restore feature enabled. Returns `false` for every other video. | [optional]
**language** | **String** | Returns the language of a video in [IETF language tag](https://en.wikipedia.org/wiki/IETF_language_tag) format. You can set the language during video creation via the API, otherwise it is detected automatically. | [optional]
**languageOrigin** | **String** | Returns the origin of the last update on the video's `language` attribute. - `api` means that the last update was requested from the API. - `auto` means that the last update was done automatically by the API. | [optional]
**tags** | **[String]** | One array of tags (each tag is a string) in order to categorize a video. Tags may include spaces. | [optional]
**metadata** | [Metadata] | Metadata you can use to categorise and filter videos. Metadata is a list of dictionaries, where each dictionary represents a key value pair for categorising a video. | [optional]
**source** | [**VideoSource**](VideoSource.md) | | [optional]
Expand Down
2 changes: 2 additions & 0 deletions docs/VideoCreationPayload.md
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,8 @@ Name | Type | Description | Notes
**metadata** | [Metadata] | A list of key value pairs that you use to provide metadata for your video. | [optional]
**clip** | [**VideoClip**](VideoClip.md) | | [optional]
**watermark** | [**VideoWatermark**](VideoWatermark.md) | | [optional]
**language** | **String** | Use this parameter to set the language of the video. When this parameter is set, the API creates a transcript of the video using the language you specify. You must use the [IETF language tag](https://en.wikipedia.org/wiki/IETF_language_tag) format. `language` is a permanent attribute of the video. You can update it to another language using the [`PATCH /videos/{videoId}`](https://docs.api.video/reference/api/Videos#update-a-video-object) operation. This triggers the API to generate a new transcript using a different language. | [optional]
**transcript** | **Bool** | Use this parameter to enable transcription. - When `true`, the API generates a transcript for the video. - The default value is `false`. - If you define a video language using the `language` parameter, the API uses that language to transcribe the video. If you do not define a language, the API detects it based on the video. - When the API generates a transcript, it will be available as a caption for the video. | [optional]

[[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md)

Expand Down
Loading

0 comments on commit 14cd125

Please sign in to comment.