All the data is managed through a series of Yaml files so it may be useful to read up on the Yaml syntax.
To add a new site, go to the data/devices
files and get familiar with how it
is setup. There is a section and corresponding file for each Category. Site icons are stored in folders corresponding to each of those categories in their own folder.
Note: Please do not modify yaml files that are directly within the data
directory. Be sure you're only working on yaml files in the data/devices
sub-directory. This project is a fork of the TFA.org project and we occasionally pull upstream changes, and this setup helps us avoid unnecessary conflicts.
-
Don't break the build: We have a simple continuous integration system setup with Travis. If your pull request doesn't pass, it won't be merged.
To manually test the build, just run the following:
$ ruby verify.rb
-
Use a Nice Icon: The icon must be 32x32 in dimension. Earlier we were using 16x16 but upgraded for various high density screens.
-
Be Awesome: You need to be awesome. That is all.
It's easy to run everything locally to test it out. Either you can have plain Jekyll installed or you can use Bundler to manage everything for you.
- To install Bundler, just run
gem install bundler
. - Install dependencies in the Gemfile,
bundle install
. - Run Jekyll:
bundle exec jekyll serve --watch
. The--watch
is optional and makes Jekyll watch for file changes.
- Install Jekyll if you don't already have it:
gem install jekyll
. - Run Jekyll:
jekyll serve --watch
. The--watch
is again optional.
The following section contains rough criteria and explanations regarding what websites should be listed on DongleAuth.info. If one of the following criteria is met, it belongs on DongleAuth.info:
- Personal Info/Image: Any site that deals with personal info or a person's image. An example of a site with Personal Info would be their Amazon account and a site regarding Personal Image would be one like Twitter.
- Data: This criteria relates to data that is either important or sensitive. Websites detailed in criteria 1 also fit this criteria.
- Money: Any site that deals with money.
- Control: This criteria is more general, in that it includes sites that give access to things that may infringe upon criteria 1, 2, or 3. An example of this is a website that allows remote access to a device.
If you have any questions regarding whether or not a site matches one of the criteria, simply open an Issue and we'll take a look.
A list for excluded sites has also been created to ensure sites that have been removed are not added in the future. The list also contains the reason for its removal.
View the complete list in the EXCLUSION.md file.
To add a new section, modify the sections
value in main.yml
and follow the template below:
sections:
- id: category-id
title: Category Name
icon: icon-class
Then create a new file in the _data/devices/
directory named the same as your section's
id with the .yml
extension.
First and foremost, make sure the new site meets our definition requirements for Two Factor Auth.
If you are adding multiple sites to the DongleAuth.info list, please create a new git branch for each website, and submit a separate pull request for each branch. More information regarding how to create new git branches can be on GitHub's Help Page or DigitalOcean's Tutorial.
If a site does provide auth via USB dongle, it is strongly recommended that you add the doc:
field where public documentation is available. Other fields should be included
if the website supports them. Any services that are not supported can be excluded.
Sites supporting auth via USB dongle should not have a Twitter field.
The following is an example of a website that supports TFA:
- name: YouTube
url: https://www.youtube.com/
img: youtube.png
tfa: Yes
otp: Yes
u2f: Yes
doc: http://www.google.com/intl/en-US/landing/2step/features.html
If a site does not provide TFA, the twitter:
field should be included if the site uses
Twitter. The fields sms:
, email:
, phone:
, software:
and hardware:
can be
completely removed.
The following is an example of a website that does not supports TFA:
- name: Netflix
url: https://www.netflix.com/us/
twitter: Netflixhelps
img: netflix.png
tfa: No
If a site doesn't support authentication with a USB dongle in certain countries, you can note this on the website. There are 4 ways to customize how it is displayed:
-
A default message acknowledging restrictions will be used with the following config:
- name: Site Name url: https://www.site.com/ twitter: SiteTwitter img: site.png tfa: Yes otp: Yes exceptions: Yes doc: <link to site 2FA documentation>
-
The message can be replaced with a custom set of words:
- name: Site Name url: https://www.site.com/ twitter: SiteTwitter img: site.png tfa: Yes otp: Yes exceptions: text: "Specific text goes here." doc: <link to site 2FA documentation>
-
The icon can be made into a link in which more details can be revealed such as country specific info and anything else.
- name: Site Name url: https://www.site.com/ twitter: SiteTwitter img: site.png tfa: Yes otp: Yes exceptions: link: Yes doc: <link to site 2FA documentation>
-
2 and 3 can be combined into:
- name: Site Name url: https://www.site.com/ twitter: SiteTwitter img: site.png tfa: Yes otp: Yes exceptions: link: Yes text: "Specific text can go here as well." doc: <link to site 2FA documentation>
-
See Guideline #2 about icons. The png file should go in the corresponding
img/section
folder. -
Only the auth methods implemented by a site need a
yes
tag, the others can just be left off completely. -
For the sake of organization and readability, it is appreciated if you insert new sites alphabetically and that your site chunk follows the same order as the example above.
-
If a site supports auth via USB dongle, their Twitter handle is not needed and can be left out for cleanliness.
-
If a site does not have auth via USB dongle but there is documentation that they are adding it, then use:
tfa: No status: <url to documentation>
There are many forms of Two Factor Auth, but DongleAuth.info is only interested in listing sites that support Two Factor Authentication using USB dongles. Currently that means the site must support either One Time Passwords (HOTP / RFC 4226 or TOTP / RFC 6238) or FIDO Universal 2nd Factor (U2F).
A lot of people have different ideas of what constitutes Two Factor Auth and what doesn't, so it stands to reason that we should clarify a bit. For the purposes of this site, Two Factor Auth is defined as any service provided as a redundant layer for account authentication. Services that provide authorization redundancy are certainly appreciated, but should not be considered Two Factor Authentication.
As an example, a site that prompts you for an authentication token following user login would be considered Two Factor Auth. A site that does not prompt you for a token upon login, but prompts you for a token when you try to perform a sensitive action would not be considered Two Factor Auth.
For context, check out the discussion in #242.
Rather than split out a list USB Dongle providers on the main page, we elected to keep the main page clean and add another page dedicated to USB Dongle providers.
To add a new provider simply add to the providers.yml
files file,
marking Yes
where appropriate.
- name: Company Name
url: https://example.com
img: company.png
otp: Yes
u2f: Yes