ExAws.Transcribe
AWS Transcribe service module for ex_aws.
Installation
The package can be installed by adding ex_aws_transcribe
to your list of dependencies
in mix.exs
along with :ex_aws
and your preferred JSON codec / http client:
def deps do
[
{:ex_aws, "~> 2.0"},
{:ex_aws_transcribe, "~> 0.1.0"},
{:poison, "~> 3.0"},
{:hackney, "~> 1.9"},
]
end
Basic Usage
alias ExAws.Transcribe
# Submit a transcription job
Transcribe.start_transcription_job("MyJob", "s3://bucket/file.mp3", "mp3", "en-US") |> ExAws.request!
# List jobs
Transcribe.list_transaction_jobs() |> ExAws.request!
# Get a job and retrieve the transcript if complete
job = Transcribe.get_transaction_job("MyJob") |> ExAws.request!
transcript_url = get_in(job, ["TranscriptionJob", "Transcript", "TranscriptFileUri"])
{:ok, {_, _, body}} = :httpc.request(:get, {transcript_url, []}, [], [])
Full documentation can be found at https://hexdocs.pm/ex_aws_transcribe
AWS Transcribe API Reference
https://docs.aws.amazon.com/transcribe/latest/dg/API_Operations.html
All options are handled as snake_case_atoms instead of CamelCase binaries as specified
in the Transcribe API. For example, :media_format
would be MediaFormat
.