Skip to content

Commit

Permalink
expanding list of data security measures
Browse files Browse the repository at this point in the history
  • Loading branch information
tinok authored and joshuaberetta committed Apr 6, 2022
1 parent 15a711b commit ff1d95c
Show file tree
Hide file tree
Showing 3 changed files with 43 additions and 86 deletions.
37 changes: 0 additions & 37 deletions source/data_security_measures.md

This file was deleted.

1 change: 0 additions & 1 deletion source/index.rst
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,6 @@ Search the knowledge base, browse our resources and visit our forum for more det
activation_link
reset_password
gdpr
data_security_measures
training_arabic
training_french
recently_updated
Expand Down
91 changes: 43 additions & 48 deletions source/is_my_data_safe.md
Original file line number Diff line number Diff line change
@@ -1,48 +1,43 @@
# Is My Data Safe on Your Server?
**Last updated:** <a href="https://github.com/kobotoolbox/docs/blob/511ea4cb3c698a4b45e7c2b4efd1af4e356e811f/source/is_my_data_safe.md" class="reference">15 Feb 2022</a>

Most users use one of the two server instances that we support:
[KoboToolbox by OCHA](https://kobo.humanitarianresponse.info/accounts/login/?next=/#/)
(for humanitarian workers) and
[KoboToolbox by Kobo](https://kf.kobotoolbox.org/accounts/login/?next=/#/) (for
everyone else). KoboToolbox can also be installed on local computers or your own
web servers. This article is about the security of your data on one of the two
supported servers hosted by [Kobo, Inc.](https://www.kobotoolbox.org/kobo) and
OCHA.

We take the protection of collected data very seriously. Data from both servers
is hosted by Amazon Web Services (AWS). Both servers are administered using best
practice tools and mechanisms to keep data safe from intrusion or loss.

The instance hosted by Kobo ([kf.kobotoolbox.org](https://kf.kobotoolbox.org))
is physically located in the United States of America. **The humanitarian
instance financed by OCHA, is hosted at a data center in Ireland.**

AWS security information can be found on
[this page](https://aws.amazon.com/security/). In addition, we do regular
database backups to protect against any eventuality. The privacy policy and
terms of use are both linked here.

Once your data is received on the server it is stored in accounts protected by
usernames and passwords. However, unless it was encrypted on the handset
[(see this article)](encrypting_forms.md), it will be stored 'in the clear' on
the server filesystem or within its database, which means that our server
administrators could potentially access it.

For
[kobo.humanitarianresponse.info](https://kobo.humanitarianresponse.info/accounts/login/?next=/#/)
and
[kc.humanitarianresponse.info](https://kobo.humanitarianresponse.info/accounts/login/?next=/kobocat/#/)
only the server administrator has technical access to the database, and we will
never access your data unless you have given us explicit access to it. However,
to have complete control and ownership of your data, you are also free to
install an instance of KoboToolbox on your own server.

All user passwords are only stored fully encrypted on the KoboToolbox server,
using the default open source framework provided by Django, which we use for our
backend. Django uses the
[PBKDF2 algorithm](https://en.wikipedia.org/wiki/PBKDF2) with a
[SHA256 hash](https://en.wikipedia.org/wiki/SHA-2). This approach is considered
very secure as such encrypted passwords require enormous amounts of computing
power and time to break. Read more about Django's password encryption process
[here](https://docs.djangoproject.com/en/1.8/topics/auth/passwords/).
# KoboToolbox data security measures: Keeping your data safe

We take data protection very seriously. Data security means protecting our users’ data from any threats that may exist. This article summarizes some of our administrative, physical, organizational, and technical measures for enforcing data security on the KoboToolbox servers maintained by Kobo, Inc., the [nonprofit organization behind KoboToolbox](https://www.kobotoolbox.org/kobo/ "nonprofit organization behind KoboToolbox").

We are fully compliant with the European Union’s General Data Protection Regulation (GDPR). If you are located in the European Union, [you can sign a data processing agreement (DPA) here](https://www.digisigner.com/online/showTemplate?linkId=772fa6c1-a184-41bf-8e95-9e6dbf0c866bhttp:// "you can sign a data processing agreement (DPA) here").

## Confidentiality
**Physical Access Control**
- Physical access control measures, amongst others, are implemented by Amazon Web Services (AWS), which is used to host our KoboToolbox servers. These measures include, for example, video surveillance and physical security of server and network facilities, maintaining key card access control, limiting access to only authorized personnel. For a full list of details about AWS technical and organizational measures for physical access control, [see this article](http://https://aws.amazon.com/compliance/data-center/controls/. "see this article on data center controls provided by AWS").

**Electronic Access Control**
- All KoboToolbox accounts are password-protected. Users are provided visual feedback about the complexity of their password, which encourages them to select a stronger password when applicable. Only encrypted password hashes are stored on the KoboToolbox server, utilizing the default open-source framework provided by Django, which uses the [PBKDF2](http://https://en.wikipedia.org/wiki/PBKDF2 "PBKDF2") algorithm with a SHA256 hash. Plain text passwords are never saved on the server.
- All database content is encrypted at rest (disk-level encryption).
- Data sent to the server is encrypted in transit using SHA-256 with RSA encryption.
- Users can [choose to also enable encryption of their project data (data-level encryption)](http://https://support.kobotoolbox.org/encrypting_forms.html "choose to enable encryption of their project data (data-level encryption)") which renders it inaccessible at all stages of data processing and requires a private key to decrypt it locally.

**Internal Access Control**
- Only authorized system administrators can access the KoboToolbox Server. They may only do so for the express purpose of updating installed software or maintaining the server infrastructure.
- System administrators require additional authentication, including SSH Public Key authentication, for accessing the KoboToolbox Server and two-factor authentication for accessing control panels provided by AWS.
- AWS provides a log of actions taken in the AWS Console. For SSH connections into the individual KoboToolbox Server instances, Kobo collects "system access events" by SSH key, which can then be matched to the authorized users.
- SSH is further protected against brute-force attempts and unauthorized access by limiting connections at the firewall level to only a small list of explicitly-allowed IP addresses.

**Data Protection by Design and Default**
- Only limited information is required for creating a KoboToolbox user account.
- Kobo staff are required to abide by the rules set out in Kobo’s privacy policies.
- Data processed on behalf of the user is not accessed by Kobo.
- Users are provided the option of applying advanced encryption. This ensures that data is encrypted using a public key before it is submitted to a KoboToolbox Server, and that it can only be decrypted with a private key on a local computer. KoboToolbox also offers the possibility of removing information in bulk once it has been collected, facilitating the pseudonymization of Personal Data (through the removal of identifiers).
- See above sub-section “Electronic Access Control” for details about visual feedback on password complexity.

## Integrity
**Data Transfer Control**
- All data in transit is protected using SHA-256 with RSA encryption.
**Data Entry Control**
- Users control who has the permission to enter data based on their KoboToolbox permissions. HTTP access logs stored on the server include the authenticated user for most requests.

## Availability and Resilience
- Kobo conducts daily backups of all databases to a separate, remote location. In case of a critical outage, all user data will be restored from the most recent backup as quickly as possible.
- Firewalls block all external requests except for SSH connections from a small list of explicitly allowed IP addresses. Public HTTP and HTTPS traffic cannot connect directly to the KoboToolbox Server, instead it is serviced by the AWS load balancer, which then forwards it to Kobo’s front-end servers.
- KoboToolbox Servers are configured to use multiple concurrently running server instances and are set to increase the number of such instances to avoid the impact of any localized failures. In case of any other failures that threaten continuous operation of critical aspects of the KoboToolbox software, system administrators stand by to intervene on short notice to restore service.
- Kobo’s reporting procedures include automated alerts, escalation of user-reported issues, and self-noticed problems by staff.
- Contingency plans include the availability of multiple people in multiple geographic locations who can respond to emergencies and restore service.
- KoboToolbox Servers have the demonstrated ability to continue operating in a degraded state, receiving submissions while simultaneously recovering lost projects/submissions via to-the-minute point-in-time recovery (PITR).
- Users found to abuse the use of their accounts by overburdening the KoboToolbox Server may be suspended or their account may be restricted.

0 comments on commit ff1d95c

Please sign in to comment.