2022-08-26 04:24:24 +08:00
|
|
|
defmodule LivebookWeb.SessionLive.SecretsComponent do
|
|
|
|
use LivebookWeb, :live_component
|
|
|
|
|
|
|
|
@impl true
|
|
|
|
def render(assigns) do
|
|
|
|
~H"""
|
2022-09-01 05:53:23 +08:00
|
|
|
<div class="p-6 max-w-4xl flex flex-col space-y-5">
|
2022-08-26 04:24:24 +08:00
|
|
|
<h3 class="text-2xl font-semibold text-gray-800">
|
|
|
|
Add secret
|
|
|
|
</h3>
|
2022-09-01 14:09:27 +08:00
|
|
|
<p class="text-gray-700" id="import-from-url">
|
|
|
|
Enter the secret name and its value.
|
|
|
|
</p>
|
|
|
|
<.form
|
|
|
|
let={f}
|
|
|
|
for={:secret}
|
|
|
|
phx-submit="save"
|
|
|
|
phx-change="validate"
|
|
|
|
autocomplete="off"
|
|
|
|
phx-target={@myself}
|
|
|
|
>
|
|
|
|
<div class="flex flex-col space-y-4">
|
|
|
|
<div>
|
|
|
|
<div class="input-label">
|
|
|
|
Label <span class="text-xs text-gray-500">(alphanumeric and underscore)</span>
|
2022-08-26 04:24:24 +08:00
|
|
|
</div>
|
2022-09-01 14:09:27 +08:00
|
|
|
<%= text_input(f, :label,
|
|
|
|
value: @secret["label"],
|
|
|
|
class: "input",
|
|
|
|
placeholder: "secret label",
|
|
|
|
autofocus: true,
|
|
|
|
aria_labelledby: "secret-label",
|
|
|
|
spellcheck: "false"
|
|
|
|
) %>
|
|
|
|
</div>
|
|
|
|
<div>
|
|
|
|
<div class="input-label">Value</div>
|
|
|
|
<%= text_input(f, :value,
|
|
|
|
value: @secret["value"],
|
|
|
|
class: "input",
|
|
|
|
placeholder: "secret value",
|
|
|
|
aria_labelledby: "secret-value",
|
|
|
|
spellcheck: "false"
|
|
|
|
) %>
|
|
|
|
</div>
|
|
|
|
<div class="flex space-x-2">
|
|
|
|
<button class="button-base button-blue" type="submit" disabled={not valid?(@secret)}>
|
|
|
|
Save
|
|
|
|
</button>
|
|
|
|
<%= live_patch("Cancel", to: @return_to, class: "button-base button-outlined-gray") %>
|
2022-08-26 04:24:24 +08:00
|
|
|
</div>
|
2022-09-01 14:09:27 +08:00
|
|
|
</div>
|
|
|
|
</.form>
|
2022-08-26 04:24:24 +08:00
|
|
|
</div>
|
|
|
|
"""
|
|
|
|
end
|
|
|
|
|
|
|
|
@impl true
|
2022-09-01 07:45:55 +08:00
|
|
|
def handle_event("save", %{"secret" => secret}, socket) do
|
|
|
|
secret = %{label: String.upcase(secret["label"]), value: secret["value"]}
|
2022-08-26 04:24:24 +08:00
|
|
|
Livebook.Session.put_secret(socket.assigns.session.pid, secret)
|
2022-09-01 07:45:55 +08:00
|
|
|
{:noreply, assign(socket, secret: %{"label" => "", "value" => ""})}
|
2022-08-26 04:24:24 +08:00
|
|
|
end
|
|
|
|
|
2022-09-01 07:45:55 +08:00
|
|
|
def handle_event("validate", %{"secret" => secret}, socket) do
|
|
|
|
{:noreply, assign(socket, secret: secret)}
|
2022-08-26 04:24:24 +08:00
|
|
|
end
|
|
|
|
|
2022-09-01 07:45:55 +08:00
|
|
|
defp valid?(secret) do
|
|
|
|
String.match?(secret["label"], ~r/^\w+$/) and secret["value"] != ""
|
2022-08-26 04:24:24 +08:00
|
|
|
end
|
|
|
|
end
|