Skip to content

Web-based tool for correcting speech-to-text generated transcripts of oral histories.

License

Notifications You must be signed in to change notification settings

slnsw/amplify

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Amplify

This is an open-source, web-based tool for the correction of computer-generated transcripts that are delivered in pairing with their original audio file. The tool is built to integrate with speech-to-text software services such as VoiceBase, or through the manual upload of transcript files. Amplify is a customised version of the New York Public Library's Transcript Editor and without NYPL's dedication to innovation and contribution to the open-source community globally, this project would not have been possible.

This platform is designed to allow digital volunteers, members of the public and staff alike to assist in the correction of transcripts associated with collections belonging to the State Library.

TOC

  1. Setting up your own project
  2. Generating your transcripts
  3. Creating a manifest file
  4. Making collections/groups
  5. Importing existing transcripts
  6. Customizing your project
  7. Transcript Consensus
  8. Deploying your project
  9. Managing your project
  10. Retrieving your finished transcripts
  11. License
  12. Attribution

Setting up your own project

Requirements

You will need to have the following installed to run this project on your machine.

  • Git
  • FFmpeg - convert the file and process the transcript using azure cognitive service
  • Ruby - this app has been developed using 3.0.0. Older versions may not work
  • PostgreSQL

For local development:

  • Node.JS version 12 or greater
    • npm version 6 or greater
    • Recommended that you use nvm to manage your Node.JS versions
  • Gulp version 4
    • Installed using npm

If installing on, say, Ubuntu, the following system packages are required.

  • libxml2-dev
  • libcurl4-openssl-dev (or another libcurl4-*-dev package)
  • libpq-dev

If installing on macOS, try installing XCode and running the following before you do a bundle install:

xcode-select --install

Once everything is installed, clone this repository:

cd /my/projects/folder
git clone https://github.com/NYPL/transcript-editor.git
cd transcript-editor

If you forked this repository, replace the URL with your repository

Configure Your Project

  1. Create config/database.yml based on config/database.sample.yml - update this file with your own database credentials
  2. Create config/application.yml based on config/application.sample.yml - this file contains all your private config credentials such as Voicebase or Google accounts. The only required configuration to start is:
  • SECRET_KEY_BASE. You can generate this value by running rake secret
  • PROJECT_ID. A project id that will be used to identify this project (e.g. my-project). Must be alphanumeric; no spaces or periods; underscores and dashes okay
  1. Copy the folder project/sample-project and rename it to the PROJECT_ID from the previous step (e.g. project/my-project). This folder will contain all the configuration, content, and language for your project.

To speed up installation, especially on local development machines, here's a script you can run to populate your configuration files.

bundle exec bin/install-amplify

Configure Your Project Details

Your project folder has the following structure:

 my-project/
 +-- assets/
 |  +-- css/
 |  +-- img/
 |  +-- js/
 +-- data/
 +-- layouts/
 +-- pages/
 +-- transcripts/
 +-- project.json
 +-- speech-to-text.js

The primary place for project configuration the file project.json. For now, we can keep everything as defaults. We will cover the details of this folder in later steps.

Setup and run the app

  • Run bundle - this will install all the necessary gems for this app.
  • Run npm install - this will install all the necessary npm packages for this app.
  • Make sure ffmpeg is installed, or you could install it by sudo apt-get install ffmpeg.
  • Run rake db:setup to setup the database based on config/database.yml.
  • Get a database copy from staging and restore it to your local database.
    ssh ubuntu@stage.amplify.gov.au "pg_dump -U amplify amplify_staging -h localhost" \ >> latest.dump
    psql -d amplify_development < latest.dump
  • Run rake project:load['my-project'] to load your project folder (replace my-project with your project name).
  • Run rake cache:clear to clear your cache if you've used Amplify previously.
  • Run foreman start to start your server. Go to http://localhost:5000/ to view your project.

Your project should load, but since there's no transcripts, all you'll see is a header and blank screen! The next step is to seed the app with some transcripts

Local development

When developing locally, if doing any front-end changes to the transcript editor, you'll need to use Node.JS and Gulp to update any of the remaining editing app SASS and Javascript files that are managed by Gulp.

The source files can be found in gulp/js/, and branch off gulp/js/default.js. To get set up to update these files:

npm i
npm i -g gulp

To update the files:

gulp # Keeps running and watching for changes
gulp sass js # Runs once

Be sure to commit the changes to public/assets/css and public/assets/js.

Setting up with Docker

This instruction assumes that you have installed docker successfully. Visit https://docs.docker.com/engine/install/ if you haven't

Set up your environment variables and database.yml

# setup .env file
cp .env.sample .env
cp database.docker.sample.yml database.yml
place your db dump file right outside your project directory and name the directory as dump and the file as dump.sql
##### from project root
cd ../
mkdir dump
cp <path to you dump file> dump/dump.sql
Back to your project root path. Build the containers
# build the containers
docker compose -f docker-compose.dev.yml up --build -d
create and populate the database
docker compose -f docker-compose.dev.yml exec amplify rake db:create
docker compose -f docker-compose.dev.yml exec postgres psql -U postgres amplify-development < /dump/dump.sql

# make sure you are in the latest schema
docker compose -f docker-compose.dev.yml exec amplify rake db:migrate

Or, run this script (on your local dev):

./bin/import-db dump/dump.sql

setup test environment

cp .env.sample .env.test
docker compose -f docker-compose.dev.yml exec -e RAILS_ENV=test amplify rake db:create
docker compose -f docker-compose.dev.yml exec -e amplify rake db:test:load

Run rspec

docker compose -f docker-compose.dev.yml --env-file .env.test exec -e RAILS_ENV=test amplify rspec
Check the containers by running
docker ps -a

If you need to check for container logs:

docker container logs <id of the container> --follow

If everything is done and working you are able to visit http://localhost:9090

Troubleshooting

  • A server is already running. Check /app/tmp/pids/server.pid
    Shut down the Docker container, empty out the tmp/ directory, and restart.

Generating your transcripts

Amplify is integrated with Azure Cognitive Speech-to-Text service. And the process will be kicked off after user uploads an audio file. The process will be started as a background job Azure::SpeechToTextJob and it calls speech-to-text.js to use Speech-to-Text SDK to get the transcripts.

NOTE: this requires two environment variables set in config/application.yml (if you run install-amplify, it will ask you for these two variables as well):

SPEECH_TO_TEXT_KEY: Ask admin to obtain the subscription key from Azure portal -> Cognitive Services -> Keys and Endpoint
SPEECH_TO_TEXT_REGION: Ask admin to obtain the region from Azure portal -> Cognitive Services -> Keys and Endpoint

Creating a manifest file

New audio files and transcripts can be added to this app by creating manifest files in .csv format. These manifest files will contain basic information about your audio, e.g. an internal id, title, description, url to audio file, etc. These files will be used to perform a number of tasks such as uploading new audio for transcription, download processed transcripts, and updating information about your audio.

In your project folder, you should find an empty .csv file: project/my-project/data/transcripts_seeds.csv. It contains the following columns:

Column Description Required? Example
uid a unique identifier for your audio file. Must be alphanumeric; no spaces or periods; underscores and dashes okay. Case sensitive. Yes podcast-123, podcast_123, 123
title the title that will be displayed for this audio file Yes Podcast About Cats
description a description that will be displayed for this audio file No This is basically teh best podcast about cats; no dogs allowed
url a URL that will link back to where the audio is being presented on your website No http://mywebsite.com/podcast-123
audio_url a public URL to your audio file Yes, unless you already uploaded audio to Voicebase or already have transcripts http://mywebsite.com/podcast-123.mp3
image_url a public URL to an image representing your audio; square and ~400px is preferred No http://mywebsite.com/podcast-123.jpg
collection the unique identifier for the collection this audio belongs to (see below for more on this) No cat-collection
vendor the vendor that will be doing the transcription Yes, unless you already produced transcripts yourself pop_up_archive
vendor_identifier if already uploaded the audio to Voicebase, put the item id here Only if you already uploaded audio to Voicebase 41326
notes any extra notes that will only be used internally (not public) No this audio contains explicit material

Populate at least the required fields of this file. You can load them into the app with this command:

rake transcripts:load['my-project','transcripts_seeds.csv']

Replace my-project with your project id and transcripts_seeds.csv if you are using a different file. You can run this command any number of times after editing the manifest file or with new manifest files. The script will check if the transcript already exists using the uid column value.

Making Collections/Groups

Sometimes you may want to group your audio in different ways for the user. You can create collections similar to how you create transcripts--with a manifest file.

In your project folder, you should find an empty .csv file: project/my-project/data/collections_seeds.csv. It contains almost the same columns as the transcript manifest file.

Once you fill out the manifest file, you can load them into the app with this command:

rake collections:load['my-project','collections_seeds.csv']

Similarly with transcripts, you can always re-run this script with new data and manifest files.

Importing existing transcripts

If you already have a vendor that generates transcripts or you have created your own method for generating transcripts, you can import these transcripts into this app for editing. We currently support the WebVTT format, a W3C standard for displaying timed text in connection with the HTML5 <track> element. This format is extended from the popular SRT format. Most vendors will provide a .vtt file for your transcripts. However, .srt files can also be easily converted to .vtt.

  1. Place all your .vtt files in folder /project/my-project/transcripts/webvtt/
  2. Create a manifest file
    • Refer to this section to setup a manifest file
    • In the vendor column, enter webvtt for each transcript
    • In the vendor_identifier column, enter the name of the .vtt file, e.g. transcript_1234.vtt
    • If you have not already, run the rake transcripts:load['my-project','the_manifest_file.csv'] task on your manifest file to create entries for your transcripts
  3. Finally, run rake webvtt:read['my-project'] which will import all the .vtt files that have not already been processed

Customizing your project

All project customization should happen within your project directory (e.g. /project/my-project/). Changes made anywhere else may result in code conflicts when updating your app with new code.

Whenever you make a change to your project directory, you must run the following rake tasks to see it in the app:

rake project:load['my-project']
rake cache:clear

Activating user accounts

This app currently supports logging in through Google or Facebook accounts (via OAuth2). You can activate this by the following procedures.

Find out more about authentication in Amplify here.

Instructions for Google Account activation

  1. Log in to your Google account and visit https://console.developers.google.com/; complete any registration steps required
  2. Once you are logged into your Developer dashboard, create a project
  3. In your project's dashboard click enable and manage Google APIs. You must enable at least Contacts API and Google+ API
  4. Click the Credentials tab of your project dashboard, Create credentials for an OAuth client ID and select Web application
  5. You should make at least two credentials for your Development and Production environments (you can also create one for a Test environment)
  6. For development, enter http://localhost:3000 (or whatever your development URI is) for your Authorized Javascript origins and http://localhost:3000/omniauth/google_oauth2/callback for your Authorized redirect URIs
  7. For production, enter the same values, but replace http://localhost:3000 with your production URI e.g. https://myproject.com
  8. Open up your config/application.yml
  9. For each development and production, copy the values listed for Client ID and Client secret into the appropriate key-value entry, e.g.
development:
  GOOGLE_CLIENT_ID: 1234567890-abcdefghijklmnop.apps.googleusercontent.com
  GOOGLE_CLIENT_SECRET: aAbBcCdDeEfFgGhHiIjKlLmM
production:
  GOOGLE_CLIENT_ID: 0987654321-ghijklmnopabcdef.apps.googleusercontent.com
  GOOGLE_CLIENT_SECRET: gGhHiIjKlLmMaAbBcCdDeEfF
  1. Google login is now enabled in the Rails app. Now we need to enable it in the UI. Open up project/my-project/project.json. Under auth_providers enter:
"authProviders": [
  {
    "name": "google",
    "label": "Google",
    "path": "/auth/google_oauth2"
  }
],
  1. Run rake project:load['my-project'] to refresh this config in the interface
  2. Finally, restart your server and visit http://localhost:3000. Now you should see the option to # via Google.

Instructions for Facebook Account activation

  1. Log in to your Facebook account and visit this link
  2. Follow the steps to create a new app and go to the app's Dashboard. You must at least fill out Display Name and Contact Email.
  3. In your project's dashboard click Add Product on the left panel. Then click Facebook Login.
  4. Under Client OAuth Settings:
    • make sure Client OAuth Login and Web OAuth Login is on
    • enter http://localhost:3000/omniauth/facebook/callback in Valid OAuth redirect URIs. Also include your production or testing urls here too (e.g. http://myapp.com/omniauth/facebook/callback)
    • Save your changes
  5. On the left panel, select Test Apps. Click Create a Test App and go to its dashboard after you create it.
  6. Note these two values: App ID and App Secret
  7. Open up your config/application.yml
  8. For each development and production, copy the values listed for App ID and App Secret into the appropriate key-value entry, e.g.
development:
  FACEBOOK_APP_ID: "1234567890123456"
  FACEBOOK_APP_SECRET: abcdefghijklmnopqrstuvwxyz123456
production:
  FACEBOOK_APP_ID: "7890123456123456"
  FACEBOOK_APP_SECRET: nopqrstuvwxyz123456abcdefghijklm
  1. Facebook login is now enabled in the Rails app. Now we need to enable it in the UI. Open up project/my-project/project.json. Under auth_providers enter:
"authProviders": [
  {
    "name": "facebook",
    "label": "Facebook",
    "path": "/auth/facebook"
  }
],
  1. Run rake project:load['my-project'] to refresh this config in the interface
  2. Finally, restart your server and visit http://localhost:3000. Now you should see the option to # via Facebook.
  3. Once ready, go back to your Facebook App page and click App Review. Make your app live by toggling on Live mode.

Adding speakers

Sometimes your audio will contain multiple speakers. If you already know who are speaking, you can seed your transcripts with the speakers. Your users could then choose which speaker is speaking on any given line.

In your project folder, you should find an empty .csv file: project/my-project/data/speakers_seeds.csv. It contains just two columns: transcript_uid and name. Simply create one speaker per line, where transcript_uid is the transcript's uid and name is the name of the speaker.

Once you fill out the speakers this file, you can load them into the app with this command:

rake speakers:load['my-project','speakers_seeds.csv']

Custom content

Pages

This app let's you create an arbitrary number of pages that you may link from the navigation menu or within other pages. All pages are found within:

project/
+-- my-project/
|  +-- pages/
  • All pages are written in Markdown, but since Markdown supports HTML, you can use HTML syntax as well.
  • If you create a page called faq.md, you can access it via URL http://localhost:3000/page/faq
  • Subdirectories are supported, but the URL will always respond to just the filename, e.g. for the file project/my-project/pages/misc/faq.md, the URL will still be http://localhost:3000/page/faq
  • You can embed assets in your markdown. For example
    • Place an image in assets folder like project/my-project/assets/img/graphic.jpg
    • You can refer to it in a page like this: <img src="/my-project/assets/img/graphic.jpg" />
  • There are a few pages that the app comes with:
    • home.md - contains the content that shows up on the homepage
    • transcript_edit.md - contains the content that shows up on the top of all transcript editor pages
    • transcript_conventions.md - contains the transcript conventions that show up in the drop-down on all transcript editor pages

Menus

In your project/my-project/project.json file, there is an entry called menus. These will contain all the available menus that will be displayed in the app. Here are the available menus:

  • header - this is the persistent menu that shows up on the top of all pages
  • transcript_edit - this is the menu that shows up below the main header menu if you are on a transcript editor page
  • footer - this is the persistent menu that shows up on the bottom of all pages

Each menu will contain a number of entries (or no entries). It may look like this:

"header": [
  {"label": "Browse", "url": "/"},
  {"label": "About", "url": "/page/about"},
  {"label": "Main Website", "url": "http://otherwebsite.com/"}
],

The label is what will show up in the menu, and the URL is what that label links to. It can link to a page within the app or an external page.

Sometimes you only want to have a link show up on certain pages. You can accomplish this like so:

"header": [
  {"label": "Browse", "url": "/"},
  {"label": "About", "url": "/page/about"},
  {"label": "Help", "url": "/page/help", "validRoutes": ["transcripts/:id"]}
],

In the above case, the Help link will only show up on transcript editor pages. You can see a list of available routes in the app's router.js file

Modals

Sometimes you don't want to redirect a user to a different page, but want to have the content show up in a pop-up modal. You can define modals in your project.json file like this:

"modals": {
  "help_modal": {
    "title": "A Brief Guide",
    "doneLabel": "Close",
    "page": {"file": "help.md"}
  },
  "tutorial_modal": {
    "title": "A Brief Tutorial",
    "doneLabel": "Finished",
    "pages": [
      {"label": "Editing", "file": "tutorial_1.md"},
      {"label": "Conventions", "file": "tutorial_2.md"},
      {"label": "Commands", "file": "tutorial_3.md"}
    ]
  }
},

This will create two modals:

  1. help_modal which contains the content of just one page: project/my-project/pages/help.md
  2. tutorial_modal which contains tabbed content of three pages

You can invoke a modal from within a menu like so:

"menus": {
  "header": [
    {"label": "Browse", "url": "/"},
    {"label": "About", "url": "/page/about"},
    {"label": "Help", "modal": "help_modal"}
  ],
  ...
},

Custom assets, styling, and functionality

You would probably want to customize the look and feel of your app. You can accomplish this by overriding the default CSS styling with a project CSS file:

project/
+-- my-project/
|  +-- assets/
|     +-- css/
|        +-- styles.css

These styles will override any existing styles in the app. Similarly, you can add additional javascript functionality via custom js:

project/
+-- my-project/
|  +-- assets/
|     +-- js/
|        +-- custom.js

Sometimes you may want to include additional files or tags in your app such as custom external font services, analytics, or meta tags. You can simply edit this page:

project/
+-- my-project/
|  +-- layouts/
|     +-- index.html

Be careful not to edit the existing app structure within the #app element. Also, there are a few javascript and css files that the app depends on that you shouldn't delete.

Be sure to run the project rake task if you make any changes:

rake project:load['my-project']

Configuring the user interface

Some aspects of the user interface can be configured through the config/frontend.yml configuration file. An example of this can be found in config/frontend.sample.yml.

The following properties can be configured through this file:

  • Homepage
    • Default search and sort properties

Transcript Consensus

Even though this app could be used by just one individual, this app was designed to allow multiple users to correct the same transcript simultaneously. The goal is to improve quality by having many users look at each line of text. This app contains a configurable "consensus" algorithm that looks for where users agree and disagree, and makes an informed decision about which submission is best.

How does consensus work?

Consensus is essentially when a certain threshold of users agree that a certain line of a transcript contains the correct text. This is a bit more complicated than it seems. Consider the following three lines of text submitted by three separate users:

  1. "Hi, my name is Jane Doe."
  2. "hi my name is Jane Doe"
  3. "Hi, my name is Jane Do."

Let's assume we need more than 50% of users to agree on a particular line of text--in this case, we need 2 of the 3 users to agree. The first two lines essentially say the same thing, but the first line contains capitalization and punctuation. The first thing the consensus algorithm does is "normalize" the text by removing punctuation and making everything the same case (it also removes extra whitespace and removes hesitations like "uhh" and "ummm"). So then the submissions will look like this:

  1. "hi my name is jane doe"
  2. "hi my name is jane doe"
  3. "hi my name is jane do"

So based on our requirement for at least 2 of 3 users to agree, it looks like the first 2 users agree and we have reached consensus. Now we have to choose which submission is "better" out of the 2:

  1. "Hi, my name is Jane Doe."
  2. "hi my name is Jane Doe"

Even though this can get rather subjective in some cases, the algorithm favors the following:

  • line contains capitalization
  • line contains punctuation
  • line contains numbers (since the default convention is to transcribe a number and numerals, e.g. "3" not three)
  • line is submitted by a registered user
  • line contains hesitations (since the default convention is to transcribe as you hear it, e.g. uhh, umm)

Therefore, between our 2 options, the chosen text will be "Hi, my name is Jane Doe.". This line now has reached consensus and is now considered "complete."

Settling conflicts

The previous example demonstrates the ideal case where a line automatically reaches consensus. But there will be many cases where users simply don't agree and arbitration will be required. Since this app is built for large audio collections where the project creator may not have the resources to manually settle disputes, arbitration is built into the app itself.

The project creator can set a limit to how many submissions are allowed for a particular line. Let's say that number is 5 and the submissions are as follows:

  1. "Hi, my name is John Hardtospell."
  2. "hi my name is John hearttospell"
  3. "Hi, my name is John Harttospell."
  4. "Hi, my name is John Hard2spell."
  5. "hi my name is John Hardtospel"

Since this line reached 5 submissions but did not reach consensus (like in the previous example), it will go into "review mode". When this happens, users can no longer submit new transcriptions but must choose the best among the 5 existing choices/submissions.

Let's say that a 6th user chooses option 1; their "vote" counts as another submission with that options's text. So let's say more users vote as follows:

  1. "Hi, my name is John Hardtospell." (+5 votes)
  2. "hi my name is John hearttospell"
  3. "Hi, my name is John Harttospell." (+1 vote)
  4. "Hi, my name is John Hard2spell."
  5. "hi my name is John Hardtospel"

If we still have the same consensus rules as before (50% must agree), option 1 will be chosen as the correct text since it has 6 of the 11 total submissions.

The stages of consensus

There are generally 4 stages a line of text can possibly go through:

  1. Initialized: this contains the original text that the speech-to-text software created
  2. Edited: the line has received submissions, but not enough to reach consensus
  3. In Review: the line has reached enough submissions for consensus, but not enough users agree to reach consensus, so it must be reviewed by others
  4. Complete: the line has reached consensus and is no longer editable.

Similarly, an entire transcript has similar stages, but is generally just an aggregate of the lines that it is made up of. So a transcript is only Complete when all of its lines are Complete.

Configuring consensus

All of a project's consensus rules are defined in the project.json file like so:

"consensus": {
  "maxLineEdits": 5,
  "minLinesForConsensus": 3,
  "minPercentConsensus": 0.34,
  "minLinesForConsensusNoEdits": 5,
  "lineDisplayMethod": "original"
},
...

Here are what each property means:

  • maxLineEdits - This is the maximum number of submissions for a particular line. If a line did not reach consensus when it reaches this number, it will go into review mode. Since the line will be locked to new submissions after this number is reached, the number should be reasonably high enough so least one of the submissions is probably correct.
  • minLinesForConsensus - The minimum number of submissions required for a line to reach consensus. If you are expecting a lot of spam, you can increase this number. If you are using this tool internally and/or you trust all users of this tool, you can set this number to 1, meaning a single user's submission is final.
  • minPercentConsensus - The threshold for determining if a line reached consensus. For example, if this number is 0.5, at least 50% of users must agree in order for a line to reach consensus.
  • minLinesForConsensusNoEdits - Sometimes users submit a line with no edits, i.e. presses enter on a line that contains the original computer text. This may be intended or not: the original text may be correct or the user may just be navigating away from the line. In order to reduce false positives, this property allows you to configure how many "no-edit" submissions are required for it to be considered for consensus. For example, if the number is 5, at least 5 people must say that the original computer text was correct before it is considered for consensus. Submissions that contain edits are always preferred over no-edit submissions.
  • lineDisplayMethod - This can either be original or guess. If this property is original, the user will see the original computer text when they are editing a line that is not locked. If this property is guess, the user will see what the app thinks is the "best guess" thus far based on the existing submissions. The advantage of showing the original is that all submissions are made independently since they do not see other users' submissions. It also ensures spam submissions are not seen by others. The advantage of guess is that consensus is more likely to be reached quicker since users are essentially looking at user submissions which would likely be more quality that the computer transcriptions.

Be sure to run the project rake task if you make any changes:

rake project:load['my-project']

If you edit the consensus rules after you have received edits, you can retroactively apply the new rules to the existing edits with the following tasks:

rake transcript_lines:recalculate
rake transcripts:recalculate

Deploying your project to production

NOTE: before that, you will need to ask Admin to add your SSH key to the server or use a pem key to do the deploy.

The State Library of New South Wales hosts Amplify on Amazon AWS EC2 instances, but you can host Amplify on more or less any webserver that runs Ruby on Rails and PostgreSQL.

Note: the original NYPL project was hosted on Heroku, so if you would like to host there, please follow the NYPL's guide.

The EC2 servers run the following:

  • Nginx
  • PostgreSQL 9.5
  • Puma
  • RVM
  • Ruby 2.3.0
  • ImageMagick
  • Nodejs
  • FFmpeg

NOTE: fstab is changed to map the releases and /tmp folders under /mnt/data01 as below config:

/mnt/data01/releases /home/deploy/nsw-state-library-amplify/releases none bind
/mnt/data01/tmp /tmp none bind

Run sudo mount -av to make this config effective.

Deployments are done via Capistrano. The configuration for this is checked into this repository, under config/deploy.rb and the per-environment definitions in the config/deploy directory.

The application sits in the home directory of the deploy user. All credentials and tokens are stored in the /home/deploy/nsw-state-library-amplify/shared/config/application.yml file. The database.yml file is in the same directory.

Assuming you have already set up your deploy user and provisioned a database, you should be able to run the following to deploy your application to production:

bundle exec cap production deploy

And to staging:

bundle exec cap staging deploy

Importing content

To load content (collections, transcripts, speakers, etc) into an empty database, set RAILS_ENV to the environment (if you're on a server) and then run the following.

Initialise the database.

bundle exec rake db:setup

Start the Rails console.

bundle exec rails console

Destroy any existing vendors (should there be any) and create VoiceBase.

Vendor.destroy_all
Vendor.create!(uid: 'voice_base', name: 'VoiceBase')

Exit the Rails console, and load the project base, collections, transcript seed data, speakers, and the transcripts themselves.

bundle exec rake project:load['nsw-state-library-amplify']
bundle exec rake collections:load['nsw-state-library-amplify','collections_seeds.csv']
bundle exec rake transcripts:load['nsw-state-library-amplify','transcripts_seeds.csv']
bundle exec rake speakers:load['nsw-state-library-amplify','speakers_seeds.csv']
bundle exec rake voice_base:import_transcripts['nsw-state-library-amplify']
bundle exec rake cache:clear

Importing transcript lines

You will notice in the above section a new rake task: voice_base:import_transcripts. That's built specifically for the .srt files that VoiceBase provides us with. Take a look at the VoiceBase::ImportSrtTranscripts class to see how it works.

If you ever need to re-import updated transcripts, then you can choose between either dropping the database and re-importing everything from scratch (preferred option, unless people have actually started to use the app for real), or run the rake task again (but read it first so you can see what is happening).

Images and audio files

These are all uploaded to the slnsw-amplify AWS S3 bucket. There is a rake task built specially for uploading files: rake aws:upload_files. Images and audio files are stored directly on the AWS S3 bucket when creating or updating a transcript from the CMS dashboard.

Only images are store for collections on the AWS S3 bucket.

Updating collection data

Individual collections can be created or updated for the nsw-state-library-amplify project from the CMS dashboard.

Updating transcript data

Simply update the transcripts_seeds.csv file and run the transcripts:load rake task again (the task is idempotent). Individual transcripts can be created or updated for a collection from the CMS dashboard.

Updating transcript lines

Unfortunately, there's no way to overwrite existing transcripts without ripping them up and starting again. The way to do this is as follows:

Enter a Rails command line session.

bundle exec rails c
ts = Transcript.where(vendor_id: Vendor.find_by(uid: 'voice_base').id)
ts.destroy_all

Then, to re-add transcript lines:

bundle exec rake transcripts:load['nsw-state-library-amplify','transcripts_seeds.csv']
bundle exec rake voice_base:import_transcripts['nsw-state-library-amplify']

Services and background tasks

Find out more about services and background tasks in Amplify here.

Managing your project

This tool has the concept of "user roles", though currently only supports three types of users:

  1. Guests - These are anonymous users that did not register. They can make contributions to transcripts, but they will not be able to track their progress between sessions. Their contributions also weigh slightly less than registered users during consensus calculations.
  2. Registered Users - These are the same as guests, but they are able to track their editing progress between any session or computer if they are signed in. They do this by signing in via Google or Facebook. Their contributions weigh slightly more than anonymous users during consensus calculations.
  3. Admins - These are users that are explicitly configured to be administrators of the tool. Their privileges/capabilities include:
  • All their edits are considered "complete" and do not have to go through the usual process of consensus.
  • They can edit lines that have status "completed"
  • They can resolve flags. If a user thinks that a line that is completed/locked still contains errors, they can flag it with a type (misspelling, repeated word, missing word, etc) and comment.
  • They have access to the admin dashboard. This gives them basic statistics about overall edits, user registrations, top users, and flags.
  • They have access to the cms dashboard. This gives them access to manage collections and their associated transcripts.

Configuring Admins

You can add admins by editing your project.json file like so:

"adminEmails": [
  "janedoe@myorg.org",
  "johndoe@myorg.org",
  ...
],
...

Make sure these email addresses correspond to the email addresses that the user signs in with (i.e. Google or Facebook.) When the user signs in using this email address, they will be able to access their dashboard by clicking the drop-down menu on the top right side of the app.

Retrieving your finished transcripts

Each transcript will be available to download in three formats: plain text, captions (WebVTT - based on SRT), and JSON. These are available at any stage of the transcription process regardless of how "complete" it is. They are available via the UI by clicking "Download this transcript." Users can choose whether they want to include speakers, timestamps, or raw edits depending on which format they choose.

Enabling/Disabling transcript downloads

You can enable/disable transcript downloads by setting allowTranscriptDownload to true or false in your project.json file like so:

"allowTranscriptDownload": true,
...

You can also enable/disable individual transcript downloads by setting can_download to 1 or 0 in the transcripts table in the database.

Downloading transcripts in bulk

The app has an endpoint that enables programmatic access to transcripts:

GET /transcript_files.json?updated_after=yyyy-mm-dd&page=1

This will get all the transcript files that were updated after a certain date. This is useful if you want to periodically update transcripts that you display on another website.

License

See LICENSE.

Attribution

Attribution is not mandatory, but should you like to credit the code source we suggest the following statement.

Powered by Amplify which was customised by the State Library of NSW and based on the New York Public Library's Transcript Editor.

About

Web-based tool for correcting speech-to-text generated transcripts of oral histories.

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • JavaScript 56.0%
  • Ruby 22.4%
  • HTML 8.2%
  • SCSS 8.0%
  • CSS 3.6%
  • EJS 1.5%
  • Other 0.3%