mirror of
https://github.com/livebook-dev/livebook.git
synced 2025-10-24 04:15:57 +08:00
Touch ups
This commit is contained in:
parent
ee94ae1b87
commit
4d76c57530
12 changed files with 121 additions and 57 deletions
|
@ -1,10 +1,7 @@
|
|||
<h1>
|
||||
<a href="https://livebook.dev/" target="_blank">
|
||||
<img src="https://github.com/livebook-dev/livebook/raw/main/static/images/logo-with-text.png" alt="Livebook" width="400">
|
||||
</a>
|
||||
</h1>
|
||||
# Livebook
|
||||
|
||||
[](https://livebook.dev/) [](https://hex.pm/packages/livebook)
|
||||
[](https://livebook.dev/)
|
||||
[](https://hexdocs.pm/livebook)
|
||||
|
||||
Livebook is a web application for writing interactive and collaborative code notebooks. It features:
|
||||
|
||||
|
|
20
docs/authentication.md
Normal file
20
docs/authentication.md
Normal file
|
@ -0,0 +1,20 @@
|
|||
# Authentication
|
||||
|
||||
## Introduction
|
||||
|
||||
Livebook's authentication covers all pages for creating, writing, and managing notebooks.
|
||||
|
||||
Livebook's default authentication method is token authentication. A token is automatically generated at startup and printed to the logs.
|
||||
|
||||
You may optionally enable password-based authentication by setting the environment variable `LIVEBOOK_PASSWORD` on startup or deployment. It must be at least 12 characters.
|
||||
|
||||
To disable authentication altogether, you may set the environment variable `LIVEBOOK_TOKEN_ENABLED` to `false`.
|
||||
|
||||
## Securing deployed notebooks
|
||||
|
||||
When you deploy a notebook as an application, the deployed application is not covered by Livebook's token/password authentication. In such cases, you have two options:
|
||||
|
||||
* You can set a password when deploying your notebook
|
||||
|
||||
* You can enable proxy authentication when deploying inside a cloud infrastructure.
|
||||
See the "Deployment" section on the sidebar for more information
|
|
@ -1,10 +0,0 @@
|
|||
# Authentication with Cloudflare
|
||||
|
||||
To integrate your Cloudflare Zero Trust authentication with Livebook, set the
|
||||
`LIVEBOOK_IDENTITY_PROVIDER` environment variable to `cloudflare:<your-team-name>`.
|
||||
|
||||
For more details about how to find your `team-name`, see:
|
||||
https://developers.cloudflare.com/cloudflare-one/glossary/#team-name.
|
||||
|
||||
For more information about Cloudflare Zero Trust, see:
|
||||
https://developers.cloudflare.com/cloudflare-one/.
|
|
@ -1,11 +0,0 @@
|
|||
# Authentication with Google IAP
|
||||
|
||||
To integrate your Google Identity-Aware Proxy (IAP) authentication with Livebook,
|
||||
set the `LIVEBOOK_IDENTITY_PROVIDER` environment variable to `google_iap:<your-jwt-audience>`.
|
||||
|
||||
For more information about Google IAP, see https://cloud.google.com/iap/docs/concepts-overview.
|
||||
|
||||
Only access with Google accounts is supported. See https://cloud.google.com/iap/docs/authenticate-users-google-accounts.
|
||||
|
||||
For more details about how to find your JWT audience, see: https://cloud.google.com/iap/docs/signed-headers-howto
|
||||
and look for "Signed Header JWT Audience."
|
|
@ -1,8 +0,0 @@
|
|||
# Token authentication
|
||||
|
||||
Livebook's default authentication method is token authentication.
|
||||
|
||||
A token is automatically generated at startup and printed to the logs. The token can be customized
|
||||
by setting the environment variable `LIVEBOOK_PASSWORD`, and must be at least 12 characters.
|
||||
|
||||
To disable token authentication, set the environment variable `LIVEBOOK_TOKEN_ENABLED` to `false`.
|
20
docs/deployment/cloudflare.md
Normal file
20
docs/deployment/cloudflare.md
Normal file
|
@ -0,0 +1,20 @@
|
|||
# Authentication with Cloudflare
|
||||
|
||||
Setting up Cloudflare authentication will protect all routes of your notebook. It is particularly useful for adding authentication to deployed notebooks. Cloudflare authentication is provided in addition to [Livebook's authentication](../authentication.md) for authoring notebooks.
|
||||
|
||||
Once Cloudflare is enabled, we recommend leaving the "/public" route of your instances still public. This route is used for integration with the [Livebook Badge](https://livebook.dev/badge/) and other conveniences.
|
||||
|
||||
## How to
|
||||
|
||||
To integrate your Cloudflare Zero Trust authentication with Livebook, set the
|
||||
`LIVEBOOK_IDENTITY_PROVIDER` environment variable to `cloudflare:<your-team-name>`.
|
||||
|
||||
For more details about how to find your `team-name`, see:
|
||||
https://developers.cloudflare.com/cloudflare-one/glossary/#team-name.
|
||||
|
||||
For more information about Cloudflare Zero Trust, see:
|
||||
https://developers.cloudflare.com/cloudflare-one/.
|
||||
|
||||
## Livebook Teams
|
||||
|
||||
[Livebook Teams](https://livebook.dev/teams/) users have access to airgapped notebook deployment via Docker, with pre-configured Zero Trust Authentication, shared team secrets and file storages. To get started, open up Livebook, click "Add Organization" on the sidebar, and visit the "Airgapped Deployment" section of your organization.
|
27
docs/deployment/docker.md
Normal file
27
docs/deployment/docker.md
Normal file
|
@ -0,0 +1,27 @@
|
|||
# Docker
|
||||
|
||||
## Dockerfile
|
||||
|
||||
You can deploy Livebook inside your infrastructure using Docker. The Dockerfile below provides a great starting point:
|
||||
|
||||
```dockerfile
|
||||
FROM ghcr.io/livebook-dev/livebook:edge
|
||||
|
||||
# Configure your port accordingly
|
||||
ENV LIVEBOOK_PORT 7860
|
||||
EXPOSE 7860
|
||||
|
||||
# If you have a persistent volume, configure it here
|
||||
ENV LIVEBOOK_DATA_PATH "/data"
|
||||
USER root
|
||||
RUN mkdir -p /data
|
||||
RUN chmod 777 /data
|
||||
```
|
||||
|
||||
You can consult our [README](../../README.md#environment-variables) for a complete list of environment variables and configuration.
|
||||
|
||||
If you plan to limit access to your Livebook via a proxy, we recommend leaving the "/public" route of your instances still public. This route is used for integration with the [Livebook Badge](https://livebook.dev/badge/) and other conveniences.
|
||||
|
||||
## Livebook Teams
|
||||
|
||||
[Livebook Teams](https://livebook.dev/teams/) users have access to airgapped notebook deployment via Docker, with pre-configured Zero Trust Authentication, shared team secrets and file storages. To get started, open up Livebook, click "Add Organization" on the sidebar, and visit the "Airgapped Deployment" section of your organization.
|
20
docs/deployment/google_iap.md
Normal file
20
docs/deployment/google_iap.md
Normal file
|
@ -0,0 +1,20 @@
|
|||
# Authentication with Google IAP
|
||||
|
||||
Setting up Google IAP authentication will protect all routes of your notebook. It is particularly useful for adding authentication to deployed notebooks. Google IAP authentication is provided in addition to [Livebook's authentication](../authentication.md) for authoring notebooks.
|
||||
|
||||
Once Google IAP is enabled, we recommend leaving the "/public" route of your instances still public. This route is used for integration with the [Livebook Badge](https://livebook.dev/badge/) and other conveniences.
|
||||
|
||||
## How to
|
||||
|
||||
To integrate your Google Identity-Aware Proxy (IAP) authentication with Livebook,
|
||||
set the `LIVEBOOK_IDENTITY_PROVIDER` environment variable to `google_iap:<your-jwt-audience>`.
|
||||
|
||||
For more information about Google IAP, see https://cloud.google.com/iap/docs/concepts-overview.
|
||||
|
||||
Only access with Google accounts is supported. See https://cloud.google.com/iap/docs/authenticate-users-google-accounts.
|
||||
|
||||
For more details about how to find your JWT audience, see https://cloud.google.com/iap/docs/signed-headers-howto and look for "Signed Header JWT Audience."
|
||||
|
||||
## Livebook Teams
|
||||
|
||||
[Livebook Teams](https://livebook.dev/teams/) users have access to airgapped notebook deployment via Docker, with pre-configured Zero Trust Authentication, shared team secrets and file storages. To get started, open up Livebook, click "Add Organization" on the sidebar, and visit the "Airgapped Deployment" section of your organization.
|
|
@ -1,7 +1,13 @@
|
|||
# Authentication with Tailscale
|
||||
|
||||
Setting up Tailscale authentication will protect all routes of your notebook. It is particularly useful for adding authentication to deployed notebooks. Tailscale authentication is provided in addition to [Livebook's authentication](../authentication.md) for authoring notebooks.
|
||||
|
||||
Once Tailscale is enabled, we recommend leaving the "/public" route of your instances still public. This route is used for integration with the [Livebook Badge](https://livebook.dev/badge/) and other conveniences.
|
||||
|
||||
## How to
|
||||
|
||||
To integrate Tailscale authentication with Livebook,
|
||||
set the `LIVEBOOK_IDENTITY_PROVIDER` environment variable to `tailscale:tailscale-socket-path`.
|
||||
set the `LIVEBOOK_IDENTITY_PROVIDER` environment variable to `tailscale:tailscale-socket-path`, make sure the `tailscale` CLI is installed and available on your machine (or your Docker image).
|
||||
|
||||
If you want to access Livebook on the same machine as you are hosting it,
|
||||
you must also set the `LIVEBOOK_IP` variable to your Tailscale IP.
|
||||
|
@ -17,7 +23,7 @@ livebook server
|
|||
See https://tailscale.com/blog/tailscale-auth-nginx/ for more information
|
||||
on how Tailscale authentication works.
|
||||
|
||||
## macOS
|
||||
### macOS
|
||||
|
||||
On macOS, when Tailscale is installed via the Mac App Store, no unix socket is exposed.
|
||||
Instead, a TCP port is made available and protected via a password, which needs to be located.
|
||||
|
@ -32,4 +38,8 @@ pass=$(echo "$addr_info" | cut -d '-' -f 2)
|
|||
LIVEBOOK_IP=$(exec $(ps -xo comm | grep MacOS/Tailscale$) ip | head -1 | tr -d '\n') \
|
||||
LIVEBOOK_IDENTITY_PROVIDER=tailscale:http://:$pass@127.0.0.1:$port \
|
||||
livebook server
|
||||
```
|
||||
```
|
||||
|
||||
## Livebook Teams
|
||||
|
||||
[Livebook Teams](https://livebook.dev/teams/) users have access to airgapped notebook deployment via Docker, with pre-configured Zero Trust Authentication, shared team secrets and file storages. To get started, open up Livebook, click "Add Organization" on the sidebar, and visit the "Airgapped Deployment" section of your organization.
|
|
@ -11,34 +11,28 @@ defmodule Livebook.Config do
|
|||
name: "Session",
|
||||
value: "Cookie value",
|
||||
module: LivebookWeb.SessionIdentity,
|
||||
read_only: true,
|
||||
link: "https://livebook.dev/",
|
||||
commands: []
|
||||
read_only: true
|
||||
},
|
||||
%{
|
||||
type: :cloudflare,
|
||||
name: "Cloudflare",
|
||||
value: "Team name (domain)",
|
||||
module: Livebook.ZTA.Cloudflare,
|
||||
read_only: false,
|
||||
link: "https://developers.cloudflare.com/cloudflare-one/",
|
||||
commands: []
|
||||
read_only: false
|
||||
},
|
||||
%{
|
||||
type: :google_iap,
|
||||
name: "Google IAP",
|
||||
value: "Audience (aud)",
|
||||
module: Livebook.ZTA.GoogleIAP,
|
||||
read_only: false,
|
||||
link: "https://cloud.google.com/iap/docs/concepts-overview"
|
||||
read_only: false
|
||||
},
|
||||
%{
|
||||
type: :tailscale,
|
||||
name: "Tailscale",
|
||||
value: "Tailscale CLI socket path",
|
||||
module: Livebook.ZTA.Tailscale,
|
||||
read_only: false,
|
||||
link: "https://hexdocs.pm/livebook/Livebook.ZTA.Tailscale.html"
|
||||
read_only: false
|
||||
}
|
||||
]
|
||||
|
||||
|
|
|
@ -194,9 +194,12 @@ defmodule LivebookWeb.Hub.Edit.TeamComponent do
|
|||
|
||||
<div class="text-sm mt-2">
|
||||
<span :if={@zta_metadata}>
|
||||
See
|
||||
<a class="text-blue-800 hover:text-blue-600" href={@zta_metadata.link}>
|
||||
<%= @zta_metadata.name %> docs
|
||||
See the
|
||||
<a
|
||||
class="text-blue-800 hover:text-blue-600"
|
||||
href={"https://hexdocs.pm/livebook/#{@zta_metadata.type}"}
|
||||
>
|
||||
Authentication with <%= @zta_metadata.name %> docs
|
||||
</a>
|
||||
for more information.
|
||||
</span>
|
||||
|
|
14
mix.exs
14
mix.exs
|
@ -188,22 +188,24 @@ defmodule Livebook.MixProject do
|
|||
defp docs() do
|
||||
[
|
||||
logo: "static/images/logo.png",
|
||||
main: "token_authentication",
|
||||
main: "readme",
|
||||
api_reference: false,
|
||||
extra_section: "Docs",
|
||||
extras: extras(),
|
||||
groups_for_extras: [
|
||||
Authentication: Path.wildcard("docs/authentication/*")
|
||||
Deployment: Path.wildcard("docs/deployment/*")
|
||||
]
|
||||
]
|
||||
end
|
||||
|
||||
defp extras() do
|
||||
[
|
||||
"docs/authentication/token_authentication.md",
|
||||
"docs/authentication/google_iap.md",
|
||||
"docs/authentication/cloudflare.md",
|
||||
"docs/authentication/tailscale.md"
|
||||
"README.md",
|
||||
"docs/authentication.md",
|
||||
"docs/deployment/docker.md",
|
||||
"docs/deployment/cloudflare.md",
|
||||
"docs/deployment/google_iap.md",
|
||||
"docs/deployment/tailscale.md"
|
||||
]
|
||||
end
|
||||
end
|
||||
|
|
Loading…
Add table
Reference in a new issue