|
| 1 | +# Airbyte Security |
| 2 | + |
| 3 | +Airbyte is committed to keeping your data safe by following industry-standard practices for securing physical deployments, setting access policies, and leveraging the security features of leading Cloud providers. |
| 4 | + |
| 5 | +If you have any security concerns with Airbyte or believe you have uncovered a vulnerability, contact us at [[email protected]](mailto:[email protected]) |
| 6 | + |
| 7 | +## Securing your data |
| 8 | + |
| 9 | +Airbyte connectors operate as the data pipes moving data from Point A to point B: Extracting data from data sources (APIs, files, databases) and loading it into destination platforms (warehouses, data lakes) with optional transformation performed at the data destination. As soon as data is transferred from the source to the destination, it is purged from an Airbyte deployment. |
| 10 | + |
| 11 | +An Airbyte deployment stores the following data: |
| 12 | + |
| 13 | +### Technical Logs |
| 14 | + |
| 15 | +Technical logs are stored for troubleshooting purposes and may contain sensitive data based on the connection’s `state` data. If your connection is set to an Incremental sync mode, users choose which column is the cursor for their connection. While we strongly recommend a timestamp like an `updated_at` column, users can choose any column they want to be the cursor. |
| 16 | + |
| 17 | +### Configuration Metadata |
| 18 | + |
| 19 | +Airbyte retains configuration details and data points such as table and column names for each integration. |
| 20 | + |
| 21 | +### Sensitive Data |
| 22 | + |
| 23 | +As Airbyte is not aware of the data being transferred, users are required to follow the [Terms of Services](https://airbyte.com/terms) and are ultimately responsible for ensuring their data transfer is compliant with their jurisdiction. |
| 24 | + |
| 25 | +For more information, see [Airbyte’s Privacy Policy](https://airbyte.com/privacy-policy) |
| 26 | + |
| 27 | +## Securing Airbyte Open Source |
| 28 | + |
| 29 | +:::note |
| 30 | +Our security and reliability commitments are only applicable to Airbyte Cloud. Airbyte Open Source security and reliability depend on your development and production setups. |
| 31 | +::: |
| 32 | + |
| 33 | +### Network Security |
| 34 | + |
| 35 | +Deploy Airbyte Open Source in a private network or use a firewall to filter which IP addresses are allowed to access your host. Airbyte Open Source currently does not include any user management or role-based access controls (RABC) to prevent unauthorized access to the API or UI. Controlling who has access to the hardware and network your Airbyte deployment runs on is your responsibility. |
| 36 | + |
| 37 | +You can secure access to Airbyte using the following methods: |
| 38 | + |
| 39 | +- Deploy Airbyte in a private network or use a firewall to filter which IP is allowed to access your host. |
| 40 | +- Deploy Airbyte behind a reverse proxy and handle the access control on the reverse proxy side. |
| 41 | +- If you deployed Airbyte on a cloud provider: |
| 42 | + - GCP: use the [Identity-Aware proxy](https://cloud.google.com/iap) service |
| 43 | + - AWS: use the [AWS Systems Manager Session Manager](https://docs.aws.amazon.com/systems-manager/latest/userguide/session-manager.html) service |
| 44 | + |
| 45 | +### Credential management |
| 46 | + |
| 47 | +To allow you to configure syncs and connectors, Airbyte stores the credentials (like API Keys and passwords) you provide in the Airbyte application database. Make sure you protect the [configuration management routes](https://airbyte-public-api-docs.s3.us-east-2.amazonaws.com/rapidoc-api-docs.html). |
| 48 | + |
| 49 | +If you’re deploying Airbyte Open Source on GCP, you may use Google [Secret Manager](https://cloud.google.com/secret-manager) to store credentials instead of in the database: |
| 50 | + |
| 51 | +1. Create a service account with Google Secret Manager with read/write access. Generate a JSON key. |
| 52 | +2. In the Worker and Server applications, set the `SECRET_STORE_GCP_PROJECT_ID` environment variable to the GCP project to which the credentials have access and secrets will be located. |
| 53 | +3. In the Worker and Server applications, set the `SECRET_STORE_GCP_CREDENTIALS` environment variable to the JSON key created in step 1. |
| 54 | +4. In the Worker and Server applications, set the `SECRET_PERSISTENCE` environment variable to `GOOGLE_SECRET_MANAGER`. |
| 55 | + |
| 56 | +Note that this process is not reversible. Once you have converted to a secret store, you won’t be able to reverse it. |
| 57 | + |
| 58 | +### Encryption |
| 59 | + |
| 60 | +Most Airbyte Open Source connectors support encryption-in-transit (SSL or HTTPS). We recommend configuring your connectors to use the encryption option whenever available. |
| 61 | + |
| 62 | +### Telemetry |
| 63 | +Airbyte does send anonymized data to our services to improve the product. To disable telemetry, modify the .env file and define the following environment variable: |
| 64 | + |
| 65 | +``` |
| 66 | +TRACKING_STRATEGY=logging |
| 67 | +``` |
| 68 | + |
| 69 | +## Securing Airbyte Cloud |
| 70 | + |
| 71 | +Airbyte Cloud leverages the security features of leading Cloud providers and sets least-privilege access policies to ensure data security. |
| 72 | + |
| 73 | +### Physical infrastructure |
| 74 | + |
| 75 | +Airbyte Cloud is currently deployed on GCP with all servers located in the United States. We use isolated pods to ensure your data is kept separate from other customers’ data. |
| 76 | + |
| 77 | +Only certain Airbyte staff can access Airbyte infrastructure and technical logs for deployments, upgrades, configuration changes, and troubleshooting. |
| 78 | + |
| 79 | +### Network security |
| 80 | +You may need to allowlist `34.106.109.131` to enable access to Airbyte Cloud. |
| 81 | + |
| 82 | +### Credential management |
| 83 | + |
| 84 | +Most Airbyte Cloud connectors require keys, secrets, or passwords to allow the connectors to continually sync without prompting credentials on every refresh. Airbyte Cloud fetches credentials using HTTPS and stores them in Google Cloud’s [Secret Manager](https://cloud.google.com/secret-manager). When persisting connector configurations to disk or the database, we store a version of the configuration that points to the secret in Google Secret Manager instead of the secret itself to limit the parts of the system interacting with secrets. |
| 85 | + |
| 86 | +### Encryption |
| 87 | + |
| 88 | +Since Airbyte Cloud only transfers data from source to destination and purges the data after the transfer is finished, data in transit is encrypted with TLS, and no in-store encryption is required for the data. Airbyte Cloud does store [customer metadata](https://docs.google.com/document/d/1bN5NtW57umIcsticFqdhuvSQRfMuGQlijFClFQQFqL8/edit#heading=h.t0xpm320m2ar) and encrypts it using GCP’s encryption service with AES-256-bit encryption keys. |
| 89 | + |
| 90 | +All Airbyte Cloud connectors (APIs, files, databases) pull data through encrypted channels (SSL, SSH tunnel, HTTPS), and the data transfer between our clients' infrastructure and Airbyte infrastructure is fully encrypted. |
| 91 | + |
| 92 | +### Authentication |
| 93 | + |
| 94 | +Airbyte Cloud allows you to log in to the platform using your email and password, Google account, or GitHub account. |
| 95 | + |
| 96 | +### Access Control |
| 97 | + |
| 98 | +Airbyte Cloud supports [user management](https://docs.airbyte.com/cloud/managing-airbyte-cloud#add-users-to-your-workspace) but doesn’t support role-based access control (RBAC) yet. |
| 99 | + |
| 100 | +### Compliance |
| 101 | + |
| 102 | +Our compliance efforts for Airbyte Cloud include: |
| 103 | + |
| 104 | +- SOC 2 Type II assessment: An independent third-party completed a SOC2 Type II assessment and found effective operational controls in place. Independent third-party audits will continue at a regular cadence, and the most recent report is available upon request. |
| 105 | +- ISO 27001 certification: We are currently pursuing ISO 27001 certification and will continue to align the evolution of our security program with its standards as we grow. |
| 106 | +- Assessments and penetration tests: We use tools provided by the Cloud platforms as well as third-party assessments and penetration tests. |
| 107 | + |
| 108 | +## Reporting Vulnerabilities |
| 109 | + |
| 110 | +:::warning |
| 111 | +Do not file GitHub issues or post on our community Slack or forum for security vulnerabilities since they're public avenues and may lead to additional security concerns. |
| 112 | +::: |
| 113 | + |
| 114 | +Airbyte takes security issues very seriously. If you have any concerns about Airbyte or believe you have uncovered a vulnerability, contact us at [[email protected]](mailto:[email protected]). In the message, try to describe the issue and a way to reproduce it. The security team will get back to you as soon as possible. |
| 115 | + |
| 116 | +Use this security address only for undisclosed vulnerabilities. For fixed issues or general questions on how to use the security features, use the [Discourse forum](https://discuss.airbyte.io/) or [Community Slack](https://slack.airbyte.com/). |
| 117 | + |
| 118 | +Please report any security problems to us before disclosing it publicly. |
0 commit comments