Observable FAQ
Privacy & Personal Information
Q: What personal data do you collect from users?
We collect your information only with your consent in accordance with our Terms of Service. We only collect personal information that is necessary to fulfill the purpose of your interaction with us. Please see our Privacy Policy for more details about what personal data we collect from users.
Q: Are you GDPR or CCPA compliant?
We're in the process of getting GDPR and CCPA certified.
Authentication
Q: Do you enforce multi-factor authentication?
Observable uses 3rd party authentication providers (Microsoft, GitHub, Google or Twitter) as well as email login through a one-time-password. Users may have multi-factor authentication configured with their authentication providers.
Q: Do you support SSO/SAML?
We support OpenID Connect with Microsoft and Google. OpenID Connect is a simple identity layer on top of OAuth 2.0. Custom SSO is available for Observable Enterprise customers (learn more). The SAML protocol is not supported at this time.
Network Security
Q: Is your network traffic handled through HTTPS?
Observable is only accessible over HTTPS and only encrypted HTTPS and websockets (WSS) are used for data transmission. Our commercial certificate is signed by Cloudflare, and we only allow TLS 1.2 and higher for HTTPS connections.
Q: How do you monitor threats and vulnerabilities?
Our production infrastructure is hosted by Heroku, and is contained within Heroku’s secure network. Heroku regularly undergoes penetration tests and vulnerability assessments to ensure that the network remains secure. See: https://www.heroku.com/policy/security.
We also rely on GitHub Enterprise’s advanced vulnerability scanning and security alerts. They monitor our codebase and dependencies for vulnerabilities, and issue automated alerts when problems are found. See: https://github.com/features/security.
Data Security
Q: How do you protect user data?
Observable protects user data by minimizing our data collection requirements and allowing users discretion over how to load data. For example in notebooks, when users access data from external data sources, it does not exist on our servers. The data flows from the data source directly to the user's browser.
Please refer to this overview for more information about how our notebook architecture protects our users' data, as well as this summary about the options for connecting to data. Data apps have a different security structure given they are created by Observable Framework, a static-site generator. Many security concerns are therefore addressed as Framework data apps connect to sensitive data sources, such as databases, on build rather than run-time, preventing any security leaks.
Q: Are stored secrets, data connectors, and cloud file attachments secure?
All user data, including cached data from data apps, stored notebook secrets, data connectors, and authentication tokens for Cloud File Attachments, are encrypted at rest and entirely stored on our production systems. Our database is hosted by Heroku, and once an authentication token is set up into Observable, it cannot be re-downloaded or exported. Authentication tokens can be deleted at any time. Data accessed from a user's cloud files or databases are not stored on the Observable platform. Only access tokens required to authenticate with the sources are stored, encrypted, on Observable's servers.
Q: Does your application enable granular permissions and roles to be created?
In Observable Pro workspaces, owners can assign roles of 'owner', 'editor', or 'viewer' to team members. At the notebook level, team members can then control who within the team can view and edit the notebook. They can also share the notebook with the whole team as viewers or editors. Our Enterprise tier provides additional security and access controls. Enterprise workspace owners can configure limitations on who in the team can publish content and can require all team members to be authenticated against their domain(s), which protects their workspaces when members leave their organizations.
Q: Do you offer an on-prem solution?
Observable does not currently offer an on-prem solution. However, it is still possible to securely connect to data that cannot leave your private network, by installing a database proxy on your network. In this configuration, data travels from the source, through the proxy, and to the user's browser without ever having to leave the private network. We provide an open source Node.js database proxy for self-hosting. You can learn more about installing and using this proxy in this notebook.
Q: Do you use any sub-processors for data processing purposes?
No.
Operational Security
Q: Do all employees have access to user data?
No. It is our company policy to respect the principle of least privilege when designing access controls and administrative tools. For example: all employees have access to notebook metadata, but only support personnel have access to the content of the notebooks. In addition, all personnel are required to sign Confidentiality Agreements to protect customer information.
Q: Describe your security awareness program for personnel
Our employees are currently required to train on our company policies, which include:
- Work Computer Policy: to properly secure employee endpoints
- Secure Software Development Process: which describes how we design, build and deploy our software with security taken into consideration on every level
- Security Incident Management Process: describing the steps and procedures that should be taken if an incident were to occur
Security Assessments and Compliance
Q: Do you scan for security vulnerabilities?
Our production infrastructure is hosted by Heroku, and is contained within Heroku’s secure network. Heroku regularly undergoes penetration tests and vulnerability assessments to ensure that the network remains secure. See: https://www.heroku.com/policy/security
Our software development process involves code vulnerability reviews by our developers in addition to resolution of issues flagged via automated vulnerability scanning. We monitor our codebase and dependencies for vulnerabilities using GitHub Enterprise’s advanced vulnerability scanning and are issued automated alerts when problems are found. See: https://github.com/features/security
Q: Do you conduct external (third-party) audits of the service? Are you SOC2 certified?
Not yet.
How are Observable data apps different from notebooks?
Observable data apps are primarily focused on the presentation of data in dashboards, while notebooks are great for ephemeral, ad hoc data exploration. Projects are file-based while notebooks exist entirely on the Observable website.
Observable data apps consist of source files (Markdown, JavaScript, etc.) that go through a compilation step before being deployed to the server. This lets them perform time-consuming tasks like querying data or pre-computing models offline, so the experience for the final user is much snappier.
While the underlying code in Observable notebooks can always be inspected by the user, data apps give the author more control over what gets exposed and what is hidden. Authors have more control over the layout of their pages as well, which makes them more suitable for dashboards.
A few more differences:
- Notebooks use Observable JavaScript, while data apps use vanilla JavaScript
- Projects can also use other languages in data loaders, such as Python, R, Rust, etc., together with the rich libraries available in these languages
- Notebooks are created and edited in the browser, while data apps are created in your favorite programming environment using the open-source Observable Framework
- Notebooks have collaboration built in, while data apps can use git or other methods to collaborate
- Notebooks live on Observable, while data apps can be deployed anywhere–including on Observable, which was purpose-built for displays of data and includes SSO, workspace management, etc.
We see notebooks as a separate approach to analyzing and visualizing data, but also as a way of exploring data before building a data app.
What is the difference between data apps and Observable Framework? How are they related?
Observable Framework is the collection of tools that process your source files written in Markdown, JavaScript, Python, R, etc., into compressed and optimized HTML and JavaScript to be served to your users quickly and efficiently.
A project is a collection of such files, which can then be built into a data app, which can be deployed to a hosting service.
The Observable platform is our hosting service for data apps, which also provides access control, collaboration features, etc.
How is Observable related to D3?
D3 is an open-source JavaScript library for data visualization. Observable is an online platform for writing and publishing data work—including D3 data visualizations built with D3. You can also work with any JavaScript library that runs in the browser in an Observable notebooks.
User support and feedback
Where can I ask questions and find answers from other users?
The Observable Community Forum and Community Slack workspace are great places to ask questions and find answers from members of the Observable community.
How can I report a bug or request a feature?
We welcome you to share bug reports, feature requests, and feedback as issues in our public feedback repository on GitHub.
I need to delete my account. Can you help?
See our Deleting your account for information on deleting your account (and what gets removed along with it). If you need help, please send an email to support@observablehq.com.