assemblyai 1.0.0.pre.beta → 1.0.0.pre.beta.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (39) hide show
  1. checksums.yaml +4 -4
  2. data/lib/assemblyai/lemur/client.rb +16 -16
  3. data/lib/assemblyai/lemur/types/lemur_base_params.rb +5 -5
  4. data/lib/assemblyai/lemur/types/lemur_base_params_context.rb +3 -29
  5. data/lib/assemblyai/lemur/types/lemur_model.rb +7 -7
  6. data/lib/assemblyai/lemur/types/lemur_question_context.rb +3 -29
  7. data/lib/assemblyai/realtime/types/audio_encoding.rb +5 -2
  8. data/lib/assemblyai/realtime/types/configure_end_utterance_silence_threshold.rb +48 -0
  9. data/lib/assemblyai/realtime/types/force_end_utterance.rb +48 -0
  10. data/lib/assemblyai/realtime/types/message_type.rb +6 -7
  11. data/lib/assemblyai/realtime/types/realtime_base_message.rb +6 -6
  12. data/lib/assemblyai/realtime/types/realtime_message.rb +6 -35
  13. data/lib/assemblyai/realtime/types/realtime_transcript.rb +3 -29
  14. data/lib/assemblyai/realtime/types/realtime_transcript_type.rb +4 -2
  15. data/lib/assemblyai/realtime/types/terminate_session.rb +5 -14
  16. data/lib/assemblyai/transcripts/client.rb +20 -20
  17. data/lib/assemblyai/transcripts/types/audio_intelligence_model_status.rb +5 -2
  18. data/lib/assemblyai/transcripts/types/content_safety_labels_result.rb +5 -5
  19. data/lib/assemblyai/transcripts/types/entity.rb +6 -11
  20. data/lib/assemblyai/transcripts/types/entity_type.rb +32 -32
  21. data/lib/assemblyai/transcripts/types/pii_policy.rb +29 -30
  22. data/lib/assemblyai/transcripts/types/redact_pii_audio_quality.rb +5 -2
  23. data/lib/assemblyai/transcripts/types/sentiment.rb +5 -2
  24. data/lib/assemblyai/transcripts/types/sentiment_analysis_result.rb +6 -6
  25. data/lib/assemblyai/transcripts/types/speech_model.rb +4 -1
  26. data/lib/assemblyai/transcripts/types/substitution_policy.rb +5 -2
  27. data/lib/assemblyai/transcripts/types/subtitle_format.rb +5 -2
  28. data/lib/assemblyai/transcripts/types/summary_model.rb +6 -2
  29. data/lib/assemblyai/transcripts/types/summary_type.rb +8 -8
  30. data/lib/assemblyai/transcripts/types/topic_detection_model_result.rb +5 -9
  31. data/lib/assemblyai/transcripts/types/transcript.rb +26 -29
  32. data/lib/assemblyai/transcripts/types/transcript_boost_param.rb +6 -2
  33. data/lib/assemblyai/transcripts/types/transcript_language_code.rb +24 -23
  34. data/lib/assemblyai/transcripts/types/transcript_list_item.rb +5 -5
  35. data/lib/assemblyai/transcripts/types/transcript_optional_params.rb +36 -39
  36. data/lib/assemblyai/transcripts/types/transcript_status.rb +7 -2
  37. data/lib/requests.rb +28 -2
  38. data/lib/types_export.rb +7 -5
  39. metadata +54 -14
@@ -1,22 +1,18 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- require_relative "message_type"
4
3
  require "json"
5
4
 
6
5
  module AssemblyAI
7
6
  class Realtime
8
7
  class TerminateSession
9
- attr_reader :terminate_session, :message_type, :additional_properties
8
+ attr_reader :terminate_session, :additional_properties
10
9
 
11
10
  # @param terminate_session [Boolean] Set to true to end your real-time session forever
12
- # @param message_type [MESSAGE_TYPE] Describes the type of the message
13
11
  # @param additional_properties [OpenStruct] Additional properties unmapped to the current class definition
14
12
  # @return [Realtime::TerminateSession]
15
- def initialize(terminate_session:, message_type:, additional_properties: nil)
13
+ def initialize(terminate_session:, additional_properties: nil)
16
14
  # @type [Boolean] Set to true to end your real-time session forever
17
15
  @terminate_session = terminate_session
18
- # @type [MESSAGE_TYPE] Describes the type of the message
19
- @message_type = message_type
20
16
  # @type [OpenStruct] Additional properties unmapped to the current class definition
21
17
  @additional_properties = additional_properties
22
18
  end
@@ -27,20 +23,16 @@ module AssemblyAI
27
23
  # @return [Realtime::TerminateSession]
28
24
  def self.from_json(json_object:)
29
25
  struct = JSON.parse(json_object, object_class: OpenStruct)
30
- parsed_json = JSON.parse(json_object)
26
+ JSON.parse(json_object)
31
27
  terminate_session = struct.terminate_session
32
- message_type = Realtime::MESSAGE_TYPE.key(parsed_json["message_type"]) || parsed_json["message_type"]
33
- new(terminate_session: terminate_session, message_type: message_type, additional_properties: struct)
28
+ new(terminate_session: terminate_session, additional_properties: struct)
34
29
  end
35
30
 
36
31
  # Serialize an instance of TerminateSession to a JSON object
37
32
  #
38
33
  # @return [JSON]
39
34
  def to_json(*_args)
40
- {
41
- "terminate_session": @terminate_session,
42
- "message_type": Realtime::MESSAGE_TYPE[@message_type] || @message_type
43
- }.to_json
35
+ { "terminate_session": @terminate_session }.to_json
44
36
  end
45
37
 
46
38
  # Leveraged for Union-type generation, validate_raw attempts to parse the given hash and check each fields type against the current object's property definitions.
@@ -49,7 +41,6 @@ module AssemblyAI
49
41
  # @return [Void]
50
42
  def self.validate_raw(obj:)
51
43
  obj.terminate_session.is_a?(Boolean) != false || raise("Passed value for field obj.terminate_session is not the expected type, validation failed.")
52
- obj.message_type.is_a?(Realtime::MESSAGE_TYPE) != false || raise("Passed value for field obj.message_type is not the expected type, validation failed.")
53
44
  end
54
45
  end
55
46
  end
@@ -34,7 +34,7 @@ module AssemblyAI
34
34
  # Retrieve a list of transcripts you created
35
35
  #
36
36
  # @param limit [Integer] Maximum amount of transcripts to retrieve
37
- # @param status [TRANSCRIPT_STATUS] Filter by transcript status
37
+ # @param status [Transcripts::TranscriptStatus] Filter by transcript status
38
38
  # @param created_on [String] Only get transcripts created on this date
39
39
  # @param before_id [String] Get transcripts that were created before this transcript ID
40
40
  # @param after_id [String] Get transcripts that were created after this transcript ID
@@ -62,8 +62,8 @@ module AssemblyAI
62
62
 
63
63
  # Create a transcript from an audio or video file that is accessible via a URL.
64
64
  #
65
- # @param speech_model [Transcripts::SPEECH_MODEL]
66
- # @param language_code [TRANSCRIPT_LANGUAGE_CODE]
65
+ # @param speech_model [Transcripts::SpeechModel]
66
+ # @param language_code [Transcripts::TranscriptLanguageCode]
67
67
  # @param punctuate [Boolean] Enable Automatic Punctuation, can be true or false
68
68
  # @param format_text [Boolean] Enable Text Formatting, can be true or false
69
69
  # @param dual_channel [Boolean] Enable [Dual Channel](https://www.assemblyai.com/docs/models/speech-recognition#dual-channel-transcription) transcription, can be true or false.
@@ -74,13 +74,13 @@ module AssemblyAI
74
74
  # @param audio_start_from [Integer] The point in time, in milliseconds, to begin transcribing in your media file
75
75
  # @param audio_end_at [Integer] The point in time, in milliseconds, to stop transcribing in your media file
76
76
  # @param word_boost [Array<String>] The list of custom vocabulary to boost transcription probability for
77
- # @param boost_param [TRANSCRIPT_BOOST_PARAM] The word boost parameter value
77
+ # @param boost_param [Transcripts::TranscriptBoostParam] The word boost parameter value
78
78
  # @param filter_profanity [Boolean] Filter profanity from the transcribed text, can be true or false
79
79
  # @param redact_pii [Boolean] Redact PII from the transcribed text using the Redact PII model, can be true or false
80
80
  # @param redact_pii_audio [Boolean] Generate a copy of the original media file with spoken PII "beeped" out, can be true or false. See [PII redaction](https://www.assemblyai.com/docs/models/pii-redaction) for more details.
81
- # @param redact_pii_audio_quality [REDACT_PII_AUDIO_QUALITY] Controls the filetype of the audio created by redact_pii_audio. Currently supports mp3 (default) and wav. See [PII redaction](https://www.assemblyai.com/docs/models/pii-redaction) for more details.
82
- # @param redact_pii_policies [Array<Transcripts::PII_POLICY>] The list of PII Redaction policies to enable. See [PII redaction](https://www.assemblyai.com/docs/models/pii-redaction) for more details.
83
- # @param redact_pii_sub [SUBSTITUTION_POLICY]
81
+ # @param redact_pii_audio_quality [Transcripts::RedactPiiAudioQuality] Controls the filetype of the audio created by redact_pii_audio. Currently supports mp3 (default) and wav. See [PII redaction](https://www.assemblyai.com/docs/models/pii-redaction) for more details.
82
+ # @param redact_pii_policies [Array<Transcripts::PiiPolicy>] The list of PII Redaction policies to enable. See [PII redaction](https://www.assemblyai.com/docs/models/pii-redaction) for more details.
83
+ # @param redact_pii_sub [Transcripts::SubstitutionPolicy]
84
84
  # @param speaker_labels [Boolean] Enable [Speaker diarization](https://www.assemblyai.com/docs/models/speaker-diarization), can be true or false
85
85
  # @param speakers_expected [Integer] Tells the speaker label model how many speakers it should attempt to identify, up to 10. See [Speaker diarization](https://www.assemblyai.com/docs/models/speaker-diarization) for more details.
86
86
  # @param content_safety [Boolean] Enable [Content Moderation](https://www.assemblyai.com/docs/models/content-moderation), can be true or false
@@ -97,8 +97,8 @@ module AssemblyAI
97
97
  # @param speech_threshold [Float] Reject audio files that contain less than this fraction of speech.
98
98
  # Valid values are in the range [0, 1] inclusive.
99
99
  # @param summarization [Boolean] Enable [Summarization](https://www.assemblyai.com/docs/models/summarization), can be true or false
100
- # @param summary_model [SUMMARY_MODEL] The model to summarize the transcript
101
- # @param summary_type [SUMMARY_TYPE] The type of summary
100
+ # @param summary_model [Transcripts::SummaryModel] The model to summarize the transcript
101
+ # @param summary_type [Transcripts::SummaryType] The type of summary
102
102
  # @param custom_topics [Boolean] Whether custom topics is enabled, either true or false
103
103
  # @param topics [Array<String>] The list of custom topics provided, if custom topics is enabled
104
104
  # @param additional_properties [OpenStruct] Additional properties unmapped to the current class definition
@@ -187,7 +187,7 @@ module AssemblyAI
187
187
  # Export your transcript in SRT or VTT format, to be plugged into a video player for subtitles and closed captions.
188
188
  #
189
189
  # @param transcript_id [String] ID of the transcript
190
- # @param subtitle_format [SUBTITLE_FORMAT] The format of the captions
190
+ # @param subtitle_format [Transcripts::SubtitleFormat] The format of the captions
191
191
  # @param chars_per_caption [Integer] The maximum number of characters per caption
192
192
  # @param request_options [RequestOptions]
193
193
  # @return [String]
@@ -276,7 +276,7 @@ module AssemblyAI
276
276
  # Retrieve a list of transcripts you created
277
277
  #
278
278
  # @param limit [Integer] Maximum amount of transcripts to retrieve
279
- # @param status [TRANSCRIPT_STATUS] Filter by transcript status
279
+ # @param status [Transcripts::TranscriptStatus] Filter by transcript status
280
280
  # @param created_on [String] Only get transcripts created on this date
281
281
  # @param before_id [String] Get transcripts that were created before this transcript ID
282
282
  # @param after_id [String] Get transcripts that were created after this transcript ID
@@ -306,8 +306,8 @@ module AssemblyAI
306
306
 
307
307
  # Create a transcript from an audio or video file that is accessible via a URL.
308
308
  #
309
- # @param speech_model [Transcripts::SPEECH_MODEL]
310
- # @param language_code [TRANSCRIPT_LANGUAGE_CODE]
309
+ # @param speech_model [Transcripts::SpeechModel]
310
+ # @param language_code [Transcripts::TranscriptLanguageCode]
311
311
  # @param punctuate [Boolean] Enable Automatic Punctuation, can be true or false
312
312
  # @param format_text [Boolean] Enable Text Formatting, can be true or false
313
313
  # @param dual_channel [Boolean] Enable [Dual Channel](https://www.assemblyai.com/docs/models/speech-recognition#dual-channel-transcription) transcription, can be true or false.
@@ -318,13 +318,13 @@ module AssemblyAI
318
318
  # @param audio_start_from [Integer] The point in time, in milliseconds, to begin transcribing in your media file
319
319
  # @param audio_end_at [Integer] The point in time, in milliseconds, to stop transcribing in your media file
320
320
  # @param word_boost [Array<String>] The list of custom vocabulary to boost transcription probability for
321
- # @param boost_param [TRANSCRIPT_BOOST_PARAM] The word boost parameter value
321
+ # @param boost_param [Transcripts::TranscriptBoostParam] The word boost parameter value
322
322
  # @param filter_profanity [Boolean] Filter profanity from the transcribed text, can be true or false
323
323
  # @param redact_pii [Boolean] Redact PII from the transcribed text using the Redact PII model, can be true or false
324
324
  # @param redact_pii_audio [Boolean] Generate a copy of the original media file with spoken PII "beeped" out, can be true or false. See [PII redaction](https://www.assemblyai.com/docs/models/pii-redaction) for more details.
325
- # @param redact_pii_audio_quality [REDACT_PII_AUDIO_QUALITY] Controls the filetype of the audio created by redact_pii_audio. Currently supports mp3 (default) and wav. See [PII redaction](https://www.assemblyai.com/docs/models/pii-redaction) for more details.
326
- # @param redact_pii_policies [Array<Transcripts::PII_POLICY>] The list of PII Redaction policies to enable. See [PII redaction](https://www.assemblyai.com/docs/models/pii-redaction) for more details.
327
- # @param redact_pii_sub [SUBSTITUTION_POLICY]
325
+ # @param redact_pii_audio_quality [Transcripts::RedactPiiAudioQuality] Controls the filetype of the audio created by redact_pii_audio. Currently supports mp3 (default) and wav. See [PII redaction](https://www.assemblyai.com/docs/models/pii-redaction) for more details.
326
+ # @param redact_pii_policies [Array<Transcripts::PiiPolicy>] The list of PII Redaction policies to enable. See [PII redaction](https://www.assemblyai.com/docs/models/pii-redaction) for more details.
327
+ # @param redact_pii_sub [Transcripts::SubstitutionPolicy]
328
328
  # @param speaker_labels [Boolean] Enable [Speaker diarization](https://www.assemblyai.com/docs/models/speaker-diarization), can be true or false
329
329
  # @param speakers_expected [Integer] Tells the speaker label model how many speakers it should attempt to identify, up to 10. See [Speaker diarization](https://www.assemblyai.com/docs/models/speaker-diarization) for more details.
330
330
  # @param content_safety [Boolean] Enable [Content Moderation](https://www.assemblyai.com/docs/models/content-moderation), can be true or false
@@ -341,8 +341,8 @@ module AssemblyAI
341
341
  # @param speech_threshold [Float] Reject audio files that contain less than this fraction of speech.
342
342
  # Valid values are in the range [0, 1] inclusive.
343
343
  # @param summarization [Boolean] Enable [Summarization](https://www.assemblyai.com/docs/models/summarization), can be true or false
344
- # @param summary_model [SUMMARY_MODEL] The model to summarize the transcript
345
- # @param summary_type [SUMMARY_TYPE] The type of summary
344
+ # @param summary_model [Transcripts::SummaryModel] The model to summarize the transcript
345
+ # @param summary_type [Transcripts::SummaryType] The type of summary
346
346
  # @param custom_topics [Boolean] Whether custom topics is enabled, either true or false
347
347
  # @param topics [Array<String>] The list of custom topics provided, if custom topics is enabled
348
348
  # @param additional_properties [OpenStruct] Additional properties unmapped to the current class definition
@@ -437,7 +437,7 @@ module AssemblyAI
437
437
  # Export your transcript in SRT or VTT format, to be plugged into a video player for subtitles and closed captions.
438
438
  #
439
439
  # @param transcript_id [String] ID of the transcript
440
- # @param subtitle_format [SUBTITLE_FORMAT] The format of the captions
440
+ # @param subtitle_format [Transcripts::SubtitleFormat] The format of the captions
441
441
  # @param chars_per_caption [Integer] The maximum number of characters per caption
442
442
  # @param request_options [RequestOptions]
443
443
  # @return [String]
@@ -2,7 +2,10 @@
2
2
 
3
3
  module AssemblyAI
4
4
  class Transcripts
5
- # @type [AUDIO_INTELLIGENCE_MODEL_STATUS]
6
- AUDIO_INTELLIGENCE_MODEL_STATUS = { success: "success", unavailable: "unavailable" }.freeze
5
+ # Either success, or unavailable in the rare case that the model failed
6
+ class AudioIntelligenceModelStatus
7
+ SUCCESS = "success"
8
+ UNAVAILABLE = "unavailable"
9
+ end
7
10
  end
8
11
  end
@@ -11,14 +11,14 @@ module AssemblyAI
11
11
  class ContentSafetyLabelsResult
12
12
  attr_reader :status, :results, :summary, :severity_score_summary, :additional_properties
13
13
 
14
- # @param status [AUDIO_INTELLIGENCE_MODEL_STATUS] The status of the Content Moderation model. Either success, or unavailable in the rare case that the model failed.
14
+ # @param status [Transcripts::AudioIntelligenceModelStatus] The status of the Content Moderation model. Either success, or unavailable in the rare case that the model failed.
15
15
  # @param results [Array<Transcripts::ContentSafetyLabelResult>]
16
16
  # @param summary [Hash{String => String}] A summary of the Content Moderation confidence results for the entire audio file
17
17
  # @param severity_score_summary [Hash{String => String}] A summary of the Content Moderation severity results for the entire audio file
18
18
  # @param additional_properties [OpenStruct] Additional properties unmapped to the current class definition
19
19
  # @return [Transcripts::ContentSafetyLabelsResult]
20
20
  def initialize(status:, results:, summary:, severity_score_summary:, additional_properties: nil)
21
- # @type [AUDIO_INTELLIGENCE_MODEL_STATUS] The status of the Content Moderation model. Either success, or unavailable in the rare case that the model failed.
21
+ # @type [Transcripts::AudioIntelligenceModelStatus] The status of the Content Moderation model. Either success, or unavailable in the rare case that the model failed.
22
22
  @status = status
23
23
  # @type [Array<Transcripts::ContentSafetyLabelResult>]
24
24
  @results = results
@@ -37,7 +37,7 @@ module AssemblyAI
37
37
  def self.from_json(json_object:)
38
38
  struct = JSON.parse(json_object, object_class: OpenStruct)
39
39
  parsed_json = JSON.parse(json_object)
40
- status = Transcripts::AUDIO_INTELLIGENCE_MODEL_STATUS.key(parsed_json["status"]) || parsed_json["status"]
40
+ status = struct.status
41
41
  results = parsed_json["results"]&.map do |v|
42
42
  v = v.to_json
43
43
  Transcripts::ContentSafetyLabelResult.from_json(json_object: v)
@@ -53,7 +53,7 @@ module AssemblyAI
53
53
  # @return [JSON]
54
54
  def to_json(*_args)
55
55
  {
56
- "status": Transcripts::AUDIO_INTELLIGENCE_MODEL_STATUS[@status] || @status,
56
+ "status": @status,
57
57
  "results": @results,
58
58
  "summary": @summary,
59
59
  "severity_score_summary": @severity_score_summary
@@ -65,7 +65,7 @@ module AssemblyAI
65
65
  # @param obj [Object]
66
66
  # @return [Void]
67
67
  def self.validate_raw(obj:)
68
- obj.status.is_a?(Transcripts::AUDIO_INTELLIGENCE_MODEL_STATUS) != false || raise("Passed value for field obj.status is not the expected type, validation failed.")
68
+ obj.status.is_a?(Transcripts::AudioIntelligenceModelStatus) != false || raise("Passed value for field obj.status is not the expected type, validation failed.")
69
69
  obj.results.is_a?(Array) != false || raise("Passed value for field obj.results is not the expected type, validation failed.")
70
70
  obj.summary.is_a?(Hash) != false || raise("Passed value for field obj.summary is not the expected type, validation failed.")
71
71
  obj.severity_score_summary.is_a?(Hash) != false || raise("Passed value for field obj.severity_score_summary is not the expected type, validation failed.")
@@ -9,14 +9,14 @@ module AssemblyAI
9
9
  class Entity
10
10
  attr_reader :entity_type, :text, :start, :end_, :additional_properties
11
11
 
12
- # @param entity_type [ENTITY_TYPE] The type of entity for the detected entity
12
+ # @param entity_type [Transcripts::EntityType] The type of entity for the detected entity
13
13
  # @param text [String] The text for the detected entity
14
14
  # @param start [Integer] The starting time, in milliseconds, at which the detected entity appears in the audio file
15
15
  # @param end_ [Integer] The ending time, in milliseconds, for the detected entity in the audio file
16
16
  # @param additional_properties [OpenStruct] Additional properties unmapped to the current class definition
17
17
  # @return [Transcripts::Entity]
18
18
  def initialize(entity_type:, text:, start:, end_:, additional_properties: nil)
19
- # @type [ENTITY_TYPE] The type of entity for the detected entity
19
+ # @type [Transcripts::EntityType] The type of entity for the detected entity
20
20
  @entity_type = entity_type
21
21
  # @type [String] The text for the detected entity
22
22
  @text = text
@@ -34,8 +34,8 @@ module AssemblyAI
34
34
  # @return [Transcripts::Entity]
35
35
  def self.from_json(json_object:)
36
36
  struct = JSON.parse(json_object, object_class: OpenStruct)
37
- parsed_json = JSON.parse(json_object)
38
- entity_type = Transcripts::ENTITY_TYPE.key(parsed_json["entity_type"]) || parsed_json["entity_type"]
37
+ JSON.parse(json_object)
38
+ entity_type = struct.entity_type
39
39
  text = struct.text
40
40
  start = struct.start
41
41
  end_ = struct.end
@@ -46,12 +46,7 @@ module AssemblyAI
46
46
  #
47
47
  # @return [JSON]
48
48
  def to_json(*_args)
49
- {
50
- "entity_type": Transcripts::ENTITY_TYPE[@entity_type] || @entity_type,
51
- "text": @text,
52
- "start": @start,
53
- "end": @end_
54
- }.to_json
49
+ { "entity_type": @entity_type, "text": @text, "start": @start, "end": @end_ }.to_json
55
50
  end
56
51
 
57
52
  # Leveraged for Union-type generation, validate_raw attempts to parse the given hash and check each fields type against the current object's property definitions.
@@ -59,7 +54,7 @@ module AssemblyAI
59
54
  # @param obj [Object]
60
55
  # @return [Void]
61
56
  def self.validate_raw(obj:)
62
- obj.entity_type.is_a?(Transcripts::ENTITY_TYPE) != false || raise("Passed value for field obj.entity_type is not the expected type, validation failed.")
57
+ obj.entity_type.is_a?(Transcripts::EntityType) != false || raise("Passed value for field obj.entity_type is not the expected type, validation failed.")
63
58
  obj.text.is_a?(String) != false || raise("Passed value for field obj.text is not the expected type, validation failed.")
64
59
  obj.start.is_a?(Integer) != false || raise("Passed value for field obj.start is not the expected type, validation failed.")
65
60
  obj.end_.is_a?(Integer) != false || raise("Passed value for field obj.end_ is not the expected type, validation failed.")
@@ -2,37 +2,37 @@
2
2
 
3
3
  module AssemblyAI
4
4
  class Transcripts
5
- # @type [ENTITY_TYPE]
6
- ENTITY_TYPE = {
7
- banking_information: "banking_information",
8
- blood_type: "blood_type",
9
- credit_card_cvv: "credit_card_cvv",
10
- credit_card_expiration: "credit_card_expiration",
11
- credit_card_number: "credit_card_number",
12
- date: "date",
13
- date_of_birth: "date_of_birth",
14
- drivers_license: "drivers_license",
15
- drug: "drug",
16
- email_address: "email_address",
17
- event: "event",
18
- injury: "injury",
19
- language: "language",
20
- location: "location",
21
- medical_condition: "medical_condition",
22
- medical_process: "medical_process",
23
- money_amount: "money_amount",
24
- nationality: "nationality",
25
- occupation: "occupation",
26
- organization: "organization",
27
- password: "password",
28
- person_age: "person_age",
29
- person_name: "person_name",
30
- phone_number: "phone_number",
31
- political_affiliation: "political_affiliation",
32
- religion: "religion",
33
- time: "time",
34
- url: "url",
35
- us_social_security_number: "us_social_security_number"
36
- }.freeze
5
+ # The type of entity for the detected entity
6
+ class EntityType
7
+ BANKING_INFORMATION = "banking_information"
8
+ BLOOD_TYPE = "blood_type"
9
+ CREDIT_CARD_CVV = "credit_card_cvv"
10
+ CREDIT_CARD_EXPIRATION = "credit_card_expiration"
11
+ CREDIT_CARD_NUMBER = "credit_card_number"
12
+ DATE = "date"
13
+ DATE_OF_BIRTH = "date_of_birth"
14
+ DRIVERS_LICENSE = "drivers_license"
15
+ DRUG = "drug"
16
+ EMAIL_ADDRESS = "email_address"
17
+ EVENT = "event"
18
+ INJURY = "injury"
19
+ LANGUAGE = "language"
20
+ LOCATION = "location"
21
+ MEDICAL_CONDITION = "medical_condition"
22
+ MEDICAL_PROCESS = "medical_process"
23
+ MONEY_AMOUNT = "money_amount"
24
+ NATIONALITY = "nationality"
25
+ OCCUPATION = "occupation"
26
+ ORGANIZATION = "organization"
27
+ PASSWORD = "password"
28
+ PERSON_AGE = "person_age"
29
+ PERSON_NAME = "person_name"
30
+ PHONE_NUMBER = "phone_number"
31
+ POLITICAL_AFFILIATION = "political_affiliation"
32
+ RELIGION = "religion"
33
+ TIME = "time"
34
+ URL = "url"
35
+ US_SOCIAL_SECURITY_NUMBER = "us_social_security_number"
36
+ end
37
37
  end
38
38
  end
@@ -2,35 +2,34 @@
2
2
 
3
3
  module AssemblyAI
4
4
  class Transcripts
5
- # @type [PII_POLICY]
6
- PII_POLICY = {
7
- medical_process: "medical_process",
8
- medical_condition: "medical_condition",
9
- blood_type: "blood_type",
10
- drug: "drug",
11
- injury: "injury",
12
- number_sequence: "number_sequence",
13
- email_address: "email_address",
14
- date_of_birth: "date_of_birth",
15
- phone_number: "phone_number",
16
- us_social_security_number: "us_social_security_number",
17
- credit_card_number: "credit_card_number",
18
- credit_card_expiration: "credit_card_expiration",
19
- credit_card_cvv: "credit_card_cvv",
20
- date: "date",
21
- nationality: "nationality",
22
- event: "event",
23
- language: "language",
24
- location: "location",
25
- money_amount: "money_amount",
26
- person_name: "person_name",
27
- person_age: "person_age",
28
- organization: "organization",
29
- political_affiliation: "political_affiliation",
30
- occupation: "occupation",
31
- religion: "religion",
32
- drivers_license: "drivers_license",
33
- banking_information: "banking_information"
34
- }.freeze
5
+ class PiiPolicy
6
+ MEDICAL_PROCESS = "medical_process"
7
+ MEDICAL_CONDITION = "medical_condition"
8
+ BLOOD_TYPE = "blood_type"
9
+ DRUG = "drug"
10
+ INJURY = "injury"
11
+ NUMBER_SEQUENCE = "number_sequence"
12
+ EMAIL_ADDRESS = "email_address"
13
+ DATE_OF_BIRTH = "date_of_birth"
14
+ PHONE_NUMBER = "phone_number"
15
+ US_SOCIAL_SECURITY_NUMBER = "us_social_security_number"
16
+ CREDIT_CARD_NUMBER = "credit_card_number"
17
+ CREDIT_CARD_EXPIRATION = "credit_card_expiration"
18
+ CREDIT_CARD_CVV = "credit_card_cvv"
19
+ DATE = "date"
20
+ NATIONALITY = "nationality"
21
+ EVENT = "event"
22
+ LANGUAGE = "language"
23
+ LOCATION = "location"
24
+ MONEY_AMOUNT = "money_amount"
25
+ PERSON_NAME = "person_name"
26
+ PERSON_AGE = "person_age"
27
+ ORGANIZATION = "organization"
28
+ POLITICAL_AFFILIATION = "political_affiliation"
29
+ OCCUPATION = "occupation"
30
+ RELIGION = "religion"
31
+ DRIVERS_LICENSE = "drivers_license"
32
+ BANKING_INFORMATION = "banking_information"
33
+ end
35
34
  end
36
35
  end
@@ -2,7 +2,10 @@
2
2
 
3
3
  module AssemblyAI
4
4
  class Transcripts
5
- # @type [REDACT_PII_AUDIO_QUALITY]
6
- REDACT_PII_AUDIO_QUALITY = { mp3: "mp3", wav: "wav" }.freeze
5
+ # Controls the filetype of the audio created by redact_pii_audio. Currently supports mp3 (default) and wav. See [PII redaction](https://www.assemblyai.com/docs/models/pii-redaction) for more details.
6
+ class RedactPiiAudioQuality
7
+ MP3 = "mp3"
8
+ WAV = "wav"
9
+ end
7
10
  end
8
11
  end
@@ -2,7 +2,10 @@
2
2
 
3
3
  module AssemblyAI
4
4
  class Transcripts
5
- # @type [SENTIMENT]
6
- SENTIMENT = { positive: "POSITIVE", neutral: "NEUTRAL", negative: "NEGATIVE" }.freeze
5
+ class Sentiment
6
+ POSITIVE = "POSITIVE"
7
+ NEUTRAL = "NEUTRAL"
8
+ NEGATIVE = "NEGATIVE"
9
+ end
7
10
  end
8
11
  end
@@ -12,7 +12,7 @@ module AssemblyAI
12
12
  # @param text [String] The transcript of the sentence
13
13
  # @param start [Integer] The starting time, in milliseconds, of the sentence
14
14
  # @param end_ [Integer] The ending time, in milliseconds, of the sentence
15
- # @param sentiment [SENTIMENT] The detected sentiment for the sentence, one of POSITIVE, NEUTRAL, NEGATIVE
15
+ # @param sentiment [Transcripts::Sentiment] The detected sentiment for the sentence, one of POSITIVE, NEUTRAL, NEGATIVE
16
16
  # @param confidence [Float] The confidence score for the detected sentiment of the sentence, from 0 to 1
17
17
  # @param speaker [String] The speaker of the sentence if [Speaker Diarization](https://www.assemblyai.com/docs/models/speaker-diarization) is enabled, else null
18
18
  # @param additional_properties [OpenStruct] Additional properties unmapped to the current class definition
@@ -24,7 +24,7 @@ module AssemblyAI
24
24
  @start = start
25
25
  # @type [Integer] The ending time, in milliseconds, of the sentence
26
26
  @end_ = end_
27
- # @type [SENTIMENT] The detected sentiment for the sentence, one of POSITIVE, NEUTRAL, NEGATIVE
27
+ # @type [Transcripts::Sentiment] The detected sentiment for the sentence, one of POSITIVE, NEUTRAL, NEGATIVE
28
28
  @sentiment = sentiment
29
29
  # @type [Float] The confidence score for the detected sentiment of the sentence, from 0 to 1
30
30
  @confidence = confidence
@@ -40,11 +40,11 @@ module AssemblyAI
40
40
  # @return [Transcripts::SentimentAnalysisResult]
41
41
  def self.from_json(json_object:)
42
42
  struct = JSON.parse(json_object, object_class: OpenStruct)
43
- parsed_json = JSON.parse(json_object)
43
+ JSON.parse(json_object)
44
44
  text = struct.text
45
45
  start = struct.start
46
46
  end_ = struct.end
47
- sentiment = Transcripts::SENTIMENT.key(parsed_json["sentiment"]) || parsed_json["sentiment"]
47
+ sentiment = struct.sentiment
48
48
  confidence = struct.confidence
49
49
  speaker = struct.speaker
50
50
  new(text: text, start: start, end_: end_, sentiment: sentiment, confidence: confidence, speaker: speaker,
@@ -59,7 +59,7 @@ module AssemblyAI
59
59
  "text": @text,
60
60
  "start": @start,
61
61
  "end": @end_,
62
- "sentiment": Transcripts::SENTIMENT[@sentiment] || @sentiment,
62
+ "sentiment": @sentiment,
63
63
  "confidence": @confidence,
64
64
  "speaker": @speaker
65
65
  }.to_json
@@ -73,7 +73,7 @@ module AssemblyAI
73
73
  obj.text.is_a?(String) != false || raise("Passed value for field obj.text is not the expected type, validation failed.")
74
74
  obj.start.is_a?(Integer) != false || raise("Passed value for field obj.start is not the expected type, validation failed.")
75
75
  obj.end_.is_a?(Integer) != false || raise("Passed value for field obj.end_ is not the expected type, validation failed.")
76
- obj.sentiment.is_a?(Transcripts::SENTIMENT) != false || raise("Passed value for field obj.sentiment is not the expected type, validation failed.")
76
+ obj.sentiment.is_a?(Transcripts::Sentiment) != false || raise("Passed value for field obj.sentiment is not the expected type, validation failed.")
77
77
  obj.confidence.is_a?(Float) != false || raise("Passed value for field obj.confidence is not the expected type, validation failed.")
78
78
  obj.speaker&.is_a?(String) != false || raise("Passed value for field obj.speaker is not the expected type, validation failed.")
79
79
  end
@@ -2,6 +2,9 @@
2
2
 
3
3
  module AssemblyAI
4
4
  class Transcripts
5
- SPEECH_MODEL = String
5
+ # The speech model to use for the transcription.
6
+ class SpeechModel
7
+ NANO = "nano"
8
+ end
6
9
  end
7
10
  end
@@ -2,7 +2,10 @@
2
2
 
3
3
  module AssemblyAI
4
4
  class Transcripts
5
- # @type [SUBSTITUTION_POLICY]
6
- SUBSTITUTION_POLICY = { entity_type: "entity_type", hash: "hash" }.freeze
5
+ # The replacement logic for detected PII, can be "entity_type" or "hash". See [PII redaction](https://www.assemblyai.com/docs/models/pii-redaction) for more details.
6
+ class SubstitutionPolicy
7
+ ENTITY_TYPE = "entity_type"
8
+ HASH = "hash"
9
+ end
7
10
  end
8
11
  end
@@ -2,7 +2,10 @@
2
2
 
3
3
  module AssemblyAI
4
4
  class Transcripts
5
- # @type [SUBTITLE_FORMAT]
6
- SUBTITLE_FORMAT = { srt: "srt", vtt: "vtt" }.freeze
5
+ # Format of the subtitles
6
+ class SubtitleFormat
7
+ SRT = "srt"
8
+ VTT = "vtt"
9
+ end
7
10
  end
8
11
  end
@@ -2,7 +2,11 @@
2
2
 
3
3
  module AssemblyAI
4
4
  class Transcripts
5
- # @type [SUMMARY_MODEL]
6
- SUMMARY_MODEL = { informative: "informative", conversational: "conversational", catchy: "catchy" }.freeze
5
+ # The model to summarize the transcript
6
+ class SummaryModel
7
+ INFORMATIVE = "informative"
8
+ CONVERSATIONAL = "conversational"
9
+ CATCHY = "catchy"
10
+ end
7
11
  end
8
12
  end
@@ -2,13 +2,13 @@
2
2
 
3
3
  module AssemblyAI
4
4
  class Transcripts
5
- # @type [SUMMARY_TYPE]
6
- SUMMARY_TYPE = {
7
- bullets: "bullets",
8
- bullets_verbose: "bullets_verbose",
9
- gist: "gist",
10
- headline: "headline",
11
- paragraph: "paragraph"
12
- }.freeze
5
+ # The type of summary
6
+ class SummaryType
7
+ BULLETS = "bullets"
8
+ BULLETS_VERBOSE = "bullets_verbose"
9
+ GIST = "gist"
10
+ HEADLINE = "headline"
11
+ PARAGRAPH = "paragraph"
12
+ end
13
13
  end
14
14
  end
@@ -11,13 +11,13 @@ module AssemblyAI
11
11
  class TopicDetectionModelResult
12
12
  attr_reader :status, :results, :summary, :additional_properties
13
13
 
14
- # @param status [AUDIO_INTELLIGENCE_MODEL_STATUS] The status of the Topic Detection model. Either success, or unavailable in the rare case that the model failed.
14
+ # @param status [Transcripts::AudioIntelligenceModelStatus] The status of the Topic Detection model. Either success, or unavailable in the rare case that the model failed.
15
15
  # @param results [Array<Transcripts::TopicDetectionResult>] An array of results for the Topic Detection model
16
16
  # @param summary [Hash{String => String}] The overall relevance of topic to the entire audio file
17
17
  # @param additional_properties [OpenStruct] Additional properties unmapped to the current class definition
18
18
  # @return [Transcripts::TopicDetectionModelResult]
19
19
  def initialize(status:, results:, summary:, additional_properties: nil)
20
- # @type [AUDIO_INTELLIGENCE_MODEL_STATUS] The status of the Topic Detection model. Either success, or unavailable in the rare case that the model failed.
20
+ # @type [Transcripts::AudioIntelligenceModelStatus] The status of the Topic Detection model. Either success, or unavailable in the rare case that the model failed.
21
21
  @status = status
22
22
  # @type [Array<Transcripts::TopicDetectionResult>] An array of results for the Topic Detection model
23
23
  @results = results
@@ -34,7 +34,7 @@ module AssemblyAI
34
34
  def self.from_json(json_object:)
35
35
  struct = JSON.parse(json_object, object_class: OpenStruct)
36
36
  parsed_json = JSON.parse(json_object)
37
- status = Transcripts::AUDIO_INTELLIGENCE_MODEL_STATUS.key(parsed_json["status"]) || parsed_json["status"]
37
+ status = struct.status
38
38
  results = parsed_json["results"]&.map do |v|
39
39
  v = v.to_json
40
40
  Transcripts::TopicDetectionResult.from_json(json_object: v)
@@ -47,11 +47,7 @@ module AssemblyAI
47
47
  #
48
48
  # @return [JSON]
49
49
  def to_json(*_args)
50
- {
51
- "status": Transcripts::AUDIO_INTELLIGENCE_MODEL_STATUS[@status] || @status,
52
- "results": @results,
53
- "summary": @summary
54
- }.to_json
50
+ { "status": @status, "results": @results, "summary": @summary }.to_json
55
51
  end
56
52
 
57
53
  # Leveraged for Union-type generation, validate_raw attempts to parse the given hash and check each fields type against the current object's property definitions.
@@ -59,7 +55,7 @@ module AssemblyAI
59
55
  # @param obj [Object]
60
56
  # @return [Void]
61
57
  def self.validate_raw(obj:)
62
- obj.status.is_a?(Transcripts::AUDIO_INTELLIGENCE_MODEL_STATUS) != false || raise("Passed value for field obj.status is not the expected type, validation failed.")
58
+ obj.status.is_a?(Transcripts::AudioIntelligenceModelStatus) != false || raise("Passed value for field obj.status is not the expected type, validation failed.")
63
59
  obj.results.is_a?(Array) != false || raise("Passed value for field obj.results is not the expected type, validation failed.")
64
60
  obj.summary.is_a?(Hash) != false || raise("Passed value for field obj.summary is not the expected type, validation failed.")
65
61
  end