add identities
This commit is contained in:
parent
839546e22c
commit
360e6fac2b
13 changed files with 488 additions and 0 deletions
104
lib/chiya/identities.ex
Normal file
104
lib/chiya/identities.ex
Normal file
|
@ -0,0 +1,104 @@
|
|||
defmodule Chiya.Identities do
|
||||
@moduledoc """
|
||||
The Identities context.
|
||||
"""
|
||||
|
||||
import Ecto.Query, warn: false
|
||||
alias Chiya.Repo
|
||||
|
||||
alias Chiya.Identities.Identity
|
||||
|
||||
@doc """
|
||||
Returns the list of identities.
|
||||
|
||||
## Examples
|
||||
|
||||
iex> list_identities()
|
||||
[%Identity{}, ...]
|
||||
|
||||
"""
|
||||
def list_identities do
|
||||
Repo.all(Identity)
|
||||
end
|
||||
|
||||
@doc """
|
||||
Gets a single identity.
|
||||
|
||||
Raises `Ecto.NoResultsError` if the Identity does not exist.
|
||||
|
||||
## Examples
|
||||
|
||||
iex> get_identity!(123)
|
||||
%Identity{}
|
||||
|
||||
iex> get_identity!(456)
|
||||
** (Ecto.NoResultsError)
|
||||
|
||||
"""
|
||||
def get_identity!(id), do: Repo.get!(Identity, id)
|
||||
|
||||
@doc """
|
||||
Creates a identity.
|
||||
|
||||
## Examples
|
||||
|
||||
iex> create_identity(%{field: value})
|
||||
{:ok, %Identity{}}
|
||||
|
||||
iex> create_identity(%{field: bad_value})
|
||||
{:error, %Ecto.Changeset{}}
|
||||
|
||||
"""
|
||||
def create_identity(attrs \\ %{}) do
|
||||
%Identity{}
|
||||
|> Identity.changeset(attrs)
|
||||
|> Repo.insert()
|
||||
end
|
||||
|
||||
@doc """
|
||||
Updates a identity.
|
||||
|
||||
## Examples
|
||||
|
||||
iex> update_identity(identity, %{field: new_value})
|
||||
{:ok, %Identity{}}
|
||||
|
||||
iex> update_identity(identity, %{field: bad_value})
|
||||
{:error, %Ecto.Changeset{}}
|
||||
|
||||
"""
|
||||
def update_identity(%Identity{} = identity, attrs) do
|
||||
identity
|
||||
|> Identity.changeset(attrs)
|
||||
|> Repo.update()
|
||||
end
|
||||
|
||||
@doc """
|
||||
Deletes a identity.
|
||||
|
||||
## Examples
|
||||
|
||||
iex> delete_identity(identity)
|
||||
{:ok, %Identity{}}
|
||||
|
||||
iex> delete_identity(identity)
|
||||
{:error, %Ecto.Changeset{}}
|
||||
|
||||
"""
|
||||
def delete_identity(%Identity{} = identity) do
|
||||
Repo.delete(identity)
|
||||
end
|
||||
|
||||
@doc """
|
||||
Returns an `%Ecto.Changeset{}` for tracking identity changes.
|
||||
|
||||
## Examples
|
||||
|
||||
iex> change_identity(identity)
|
||||
%Ecto.Changeset{data: %Identity{}}
|
||||
|
||||
"""
|
||||
def change_identity(%Identity{} = identity, attrs \\ %{}) do
|
||||
Identity.changeset(identity, attrs)
|
||||
end
|
||||
end
|
22
lib/chiya/identities/identity.ex
Normal file
22
lib/chiya/identities/identity.ex
Normal file
|
@ -0,0 +1,22 @@
|
|||
defmodule Chiya.Identities.Identity do
|
||||
use Ecto.Schema
|
||||
import Ecto.Changeset
|
||||
|
||||
schema "identities" do
|
||||
field :active, :boolean, default: false
|
||||
field :name, :string
|
||||
field :public, :boolean, default: false
|
||||
field :rel, :string
|
||||
field :url, :string
|
||||
field :icon, :string
|
||||
|
||||
timestamps()
|
||||
end
|
||||
|
||||
@doc false
|
||||
def changeset(identity, attrs) do
|
||||
identity
|
||||
|> cast(attrs, [:name, :rel, :url, :public, :active, :icon])
|
||||
|> validate_required([:name, :rel, :url, :public, :active, :icon])
|
||||
end
|
||||
end
|
62
lib/chiya_web/controllers/identity_controller.ex
Normal file
62
lib/chiya_web/controllers/identity_controller.ex
Normal file
|
@ -0,0 +1,62 @@
|
|||
defmodule ChiyaWeb.IdentityController do
|
||||
use ChiyaWeb, :controller
|
||||
|
||||
alias Chiya.Identities
|
||||
alias Chiya.Identities.Identity
|
||||
|
||||
def index(conn, _params) do
|
||||
identities = Identities.list_identities()
|
||||
render(conn, :index, identities: identities)
|
||||
end
|
||||
|
||||
def new(conn, _params) do
|
||||
changeset = Identities.change_identity(%Identity{})
|
||||
render(conn, :new, changeset: changeset)
|
||||
end
|
||||
|
||||
def create(conn, %{"identity" => identity_params}) do
|
||||
case Identities.create_identity(identity_params) do
|
||||
{:ok, identity} ->
|
||||
conn
|
||||
|> put_flash(:info, "Identity created successfully.")
|
||||
|> redirect(to: ~p"/admin/identities/#{identity}")
|
||||
|
||||
{:error, %Ecto.Changeset{} = changeset} ->
|
||||
render(conn, :new, changeset: changeset)
|
||||
end
|
||||
end
|
||||
|
||||
def show(conn, %{"id" => id}) do
|
||||
identity = Identities.get_identity!(id)
|
||||
render(conn, :show, identity: identity)
|
||||
end
|
||||
|
||||
def edit(conn, %{"id" => id}) do
|
||||
identity = Identities.get_identity!(id)
|
||||
changeset = Identities.change_identity(identity)
|
||||
render(conn, :edit, identity: identity, changeset: changeset)
|
||||
end
|
||||
|
||||
def update(conn, %{"id" => id, "identity" => identity_params}) do
|
||||
identity = Identities.get_identity!(id)
|
||||
|
||||
case Identities.update_identity(identity, identity_params) do
|
||||
{:ok, identity} ->
|
||||
conn
|
||||
|> put_flash(:info, "Identity updated successfully.")
|
||||
|> redirect(to: ~p"/admin/identities/#{identity}")
|
||||
|
||||
{:error, %Ecto.Changeset{} = changeset} ->
|
||||
render(conn, :edit, identity: identity, changeset: changeset)
|
||||
end
|
||||
end
|
||||
|
||||
def delete(conn, %{"id" => id}) do
|
||||
identity = Identities.get_identity!(id)
|
||||
{:ok, _identity} = Identities.delete_identity(identity)
|
||||
|
||||
conn
|
||||
|> put_flash(:info, "Identity deleted successfully.")
|
||||
|> redirect(to: ~p"/admin/identities")
|
||||
end
|
||||
end
|
13
lib/chiya_web/controllers/identity_html.ex
Normal file
13
lib/chiya_web/controllers/identity_html.ex
Normal file
|
@ -0,0 +1,13 @@
|
|||
defmodule ChiyaWeb.IdentityHTML do
|
||||
use ChiyaWeb, :html
|
||||
|
||||
embed_templates "identity_html/*"
|
||||
|
||||
@doc """
|
||||
Renders a identity form.
|
||||
"""
|
||||
attr :changeset, Ecto.Changeset, required: true
|
||||
attr :action, :string, required: true
|
||||
|
||||
def identity_form(assigns)
|
||||
end
|
8
lib/chiya_web/controllers/identity_html/edit.html.heex
Normal file
8
lib/chiya_web/controllers/identity_html/edit.html.heex
Normal file
|
@ -0,0 +1,8 @@
|
|||
<.header>
|
||||
Edit Identity <%= @identity.id %>
|
||||
<:subtitle>Use this form to manage identity records in your database.</:subtitle>
|
||||
</.header>
|
||||
|
||||
<.identity_form changeset={@changeset} action={~p"/admin/identities/#{@identity}"} />
|
||||
|
||||
<.back navigate={~p"/admin/identities"}>Back to identities</.back>
|
|
@ -0,0 +1,14 @@
|
|||
<.simple_form :let={f} for={@changeset} action={@action}>
|
||||
<.error :if={@changeset.action}>
|
||||
Oops, something went wrong! Please check the errors below.
|
||||
</.error>
|
||||
<.input field={f[:name]} type="text" label="Name" />
|
||||
<.input field={f[:rel]} type="text" label="Rel" />
|
||||
<.input field={f[:url]} type="text" label="Url" />
|
||||
<.input field={f[:public]} type="checkbox" label="Public" />
|
||||
<.input field={f[:active]} type="checkbox" label="Active" />
|
||||
<.input field={f[:icon]} type="checkbox" label="Icon" />
|
||||
<:actions>
|
||||
<.button>Save Identity</.button>
|
||||
</:actions>
|
||||
</.simple_form>
|
27
lib/chiya_web/controllers/identity_html/index.html.heex
Normal file
27
lib/chiya_web/controllers/identity_html/index.html.heex
Normal file
|
@ -0,0 +1,27 @@
|
|||
<.header>
|
||||
Listing Identities
|
||||
<:actions>
|
||||
<.link href={~p"/admin/identities/new"}>
|
||||
<.button>New Identity</.button>
|
||||
</.link>
|
||||
</:actions>
|
||||
</.header>
|
||||
|
||||
<.table id="identities" rows={@identities} row_click={&JS.navigate(~p"/admin/identities/#{&1}")}>
|
||||
<:col :let={identity} label="Name"><%= identity.name %></:col>
|
||||
<:col :let={identity} label="Rel"><%= identity.rel %></:col>
|
||||
<:col :let={identity} label="Url"><%= identity.url %></:col>
|
||||
<:col :let={identity} label="Public"><%= identity.public %></:col>
|
||||
<:col :let={identity} label="Active"><%= identity.active %></:col>
|
||||
<:action :let={identity}>
|
||||
<div class="sr-only">
|
||||
<.link navigate={~p"/admin/identities/#{identity}"}>Show</.link>
|
||||
</div>
|
||||
<.link navigate={~p"/admin/identities/#{identity}/edit"}>Edit</.link>
|
||||
</:action>
|
||||
<:action :let={identity}>
|
||||
<.link href={~p"/admin/identities/#{identity}"} method="delete" data-confirm="Are you sure?">
|
||||
Delete
|
||||
</.link>
|
||||
</:action>
|
||||
</.table>
|
8
lib/chiya_web/controllers/identity_html/new.html.heex
Normal file
8
lib/chiya_web/controllers/identity_html/new.html.heex
Normal file
|
@ -0,0 +1,8 @@
|
|||
<.header>
|
||||
New Identity
|
||||
<:subtitle>Use this form to manage identity records in your database.</:subtitle>
|
||||
</.header>
|
||||
|
||||
<.identity_form changeset={@changeset} action={~p"/admin/identities"} />
|
||||
|
||||
<.back navigate={~p"/admin/identities"}>Back to identities</.back>
|
20
lib/chiya_web/controllers/identity_html/show.html.heex
Normal file
20
lib/chiya_web/controllers/identity_html/show.html.heex
Normal file
|
@ -0,0 +1,20 @@
|
|||
<.header>
|
||||
Identity <%= @identity.id %>
|
||||
<:subtitle>This is a identity record from your database.</:subtitle>
|
||||
<:actions>
|
||||
<.link href={~p"/admin/identities/#{@identity}/edit"}>
|
||||
<.button>Edit identity</.button>
|
||||
</.link>
|
||||
</:actions>
|
||||
</.header>
|
||||
|
||||
<.list>
|
||||
<:item title="Name"><%= @identity.name %></:item>
|
||||
<:item title="Rel"><%= @identity.rel %></:item>
|
||||
<:item title="Url"><%= @identity.url %></:item>
|
||||
<:item title="Public"><%= @identity.public %></:item>
|
||||
<:item title="Active"><%= @identity.active %></:item>
|
||||
<:item title="Icon"><%= @identity.icon %></:item>
|
||||
</.list>
|
||||
|
||||
<.back navigate={~p"/admin/identities"}>Back to identities</.back>
|
16
priv/repo/migrations/20230309202012_create_identities.exs
Normal file
16
priv/repo/migrations/20230309202012_create_identities.exs
Normal file
|
@ -0,0 +1,16 @@
|
|||
defmodule Chiya.Repo.Migrations.CreateIdentities do
|
||||
use Ecto.Migration
|
||||
|
||||
def change do
|
||||
create table(:identities) do
|
||||
add :name, :string
|
||||
add :rel, :string
|
||||
add :url, :string
|
||||
add :public, :boolean, default: false, null: false
|
||||
add :active, :boolean, default: false, null: false
|
||||
add :icon, :string
|
||||
|
||||
timestamps()
|
||||
end
|
||||
end
|
||||
end
|
80
test/chiya/identities_test.exs
Normal file
80
test/chiya/identities_test.exs
Normal file
|
@ -0,0 +1,80 @@
|
|||
defmodule Chiya.IdentitiesTest do
|
||||
use Chiya.DataCase
|
||||
|
||||
alias Chiya.Identities
|
||||
|
||||
describe "identities" do
|
||||
alias Chiya.Identities.Identity
|
||||
|
||||
import Chiya.IdentitiesFixtures
|
||||
|
||||
@invalid_attrs %{active: nil, name: nil, public: nil, rel: nil, url: nil}
|
||||
|
||||
test "list_identities/0 returns all identities" do
|
||||
identity = identity_fixture()
|
||||
assert Identities.list_identities() == [identity]
|
||||
end
|
||||
|
||||
test "get_identity!/1 returns the identity with given id" do
|
||||
identity = identity_fixture()
|
||||
assert Identities.get_identity!(identity.id) == identity
|
||||
end
|
||||
|
||||
test "create_identity/1 with valid data creates a identity" do
|
||||
valid_attrs = %{
|
||||
active: true,
|
||||
name: "some name",
|
||||
public: true,
|
||||
rel: "some rel",
|
||||
url: "some url"
|
||||
}
|
||||
|
||||
assert {:ok, %Identity{} = identity} = Identities.create_identity(valid_attrs)
|
||||
assert identity.active == true
|
||||
assert identity.name == "some name"
|
||||
assert identity.public == true
|
||||
assert identity.rel == "some rel"
|
||||
assert identity.url == "some url"
|
||||
end
|
||||
|
||||
test "create_identity/1 with invalid data returns error changeset" do
|
||||
assert {:error, %Ecto.Changeset{}} = Identities.create_identity(@invalid_attrs)
|
||||
end
|
||||
|
||||
test "update_identity/2 with valid data updates the identity" do
|
||||
identity = identity_fixture()
|
||||
|
||||
update_attrs = %{
|
||||
active: false,
|
||||
name: "some updated name",
|
||||
public: false,
|
||||
rel: "some updated rel",
|
||||
url: "some updated url"
|
||||
}
|
||||
|
||||
assert {:ok, %Identity{} = identity} = Identities.update_identity(identity, update_attrs)
|
||||
assert identity.active == false
|
||||
assert identity.name == "some updated name"
|
||||
assert identity.public == false
|
||||
assert identity.rel == "some updated rel"
|
||||
assert identity.url == "some updated url"
|
||||
end
|
||||
|
||||
test "update_identity/2 with invalid data returns error changeset" do
|
||||
identity = identity_fixture()
|
||||
assert {:error, %Ecto.Changeset{}} = Identities.update_identity(identity, @invalid_attrs)
|
||||
assert identity == Identities.get_identity!(identity.id)
|
||||
end
|
||||
|
||||
test "delete_identity/1 deletes the identity" do
|
||||
identity = identity_fixture()
|
||||
assert {:ok, %Identity{}} = Identities.delete_identity(identity)
|
||||
assert_raise Ecto.NoResultsError, fn -> Identities.get_identity!(identity.id) end
|
||||
end
|
||||
|
||||
test "change_identity/1 returns a identity changeset" do
|
||||
identity = identity_fixture()
|
||||
assert %Ecto.Changeset{} = Identities.change_identity(identity)
|
||||
end
|
||||
end
|
||||
end
|
90
test/chiya_web/controllers/identity_controller_test.exs
Normal file
90
test/chiya_web/controllers/identity_controller_test.exs
Normal file
|
@ -0,0 +1,90 @@
|
|||
defmodule ChiyaWeb.IdentityControllerTest do
|
||||
use ChiyaWeb.ConnCase
|
||||
|
||||
import Chiya.IdentitiesFixtures
|
||||
|
||||
@create_attrs %{active: true, name: "some name", public: true, rel: "some rel", url: "some url"}
|
||||
@update_attrs %{
|
||||
active: false,
|
||||
name: "some updated name",
|
||||
public: false,
|
||||
rel: "some updated rel",
|
||||
url: "some updated url"
|
||||
}
|
||||
@invalid_attrs %{active: nil, name: nil, public: nil, rel: nil, url: nil}
|
||||
|
||||
describe "index" do
|
||||
test "lists all identities", %{conn: conn} do
|
||||
conn = get(conn, ~p"/admin/identities")
|
||||
assert html_response(conn, 200) =~ "Listing Identities"
|
||||
end
|
||||
end
|
||||
|
||||
describe "new identity" do
|
||||
test "renders form", %{conn: conn} do
|
||||
conn = get(conn, ~p"/admin/identities/new")
|
||||
assert html_response(conn, 200) =~ "New Identity"
|
||||
end
|
||||
end
|
||||
|
||||
describe "create identity" do
|
||||
test "redirects to show when data is valid", %{conn: conn} do
|
||||
conn = post(conn, ~p"/admin/identities", identity: @create_attrs)
|
||||
|
||||
assert %{id: id} = redirected_params(conn)
|
||||
assert redirected_to(conn) == ~p"/admin/identities/#{id}"
|
||||
|
||||
conn = get(conn, ~p"/admin/identities/#{id}")
|
||||
assert html_response(conn, 200) =~ "Identity #{id}"
|
||||
end
|
||||
|
||||
test "renders errors when data is invalid", %{conn: conn} do
|
||||
conn = post(conn, ~p"/admin/identities", identity: @invalid_attrs)
|
||||
assert html_response(conn, 200) =~ "New Identity"
|
||||
end
|
||||
end
|
||||
|
||||
describe "edit identity" do
|
||||
setup [:create_identity]
|
||||
|
||||
test "renders form for editing chosen identity", %{conn: conn, identity: identity} do
|
||||
conn = get(conn, ~p"/admin/identities/#{identity}/edit")
|
||||
assert html_response(conn, 200) =~ "Edit Identity"
|
||||
end
|
||||
end
|
||||
|
||||
describe "update identity" do
|
||||
setup [:create_identity]
|
||||
|
||||
test "redirects when data is valid", %{conn: conn, identity: identity} do
|
||||
conn = put(conn, ~p"/admin/identities/#{identity}", identity: @update_attrs)
|
||||
assert redirected_to(conn) == ~p"/admin/identities/#{identity}"
|
||||
|
||||
conn = get(conn, ~p"/admin/identities/#{identity}")
|
||||
assert html_response(conn, 200) =~ "some updated name"
|
||||
end
|
||||
|
||||
test "renders errors when data is invalid", %{conn: conn, identity: identity} do
|
||||
conn = put(conn, ~p"/admin/identities/#{identity}", identity: @invalid_attrs)
|
||||
assert html_response(conn, 200) =~ "Edit Identity"
|
||||
end
|
||||
end
|
||||
|
||||
describe "delete identity" do
|
||||
setup [:create_identity]
|
||||
|
||||
test "deletes chosen identity", %{conn: conn, identity: identity} do
|
||||
conn = delete(conn, ~p"/admin/identities/#{identity}")
|
||||
assert redirected_to(conn) == ~p"/admin/identities"
|
||||
|
||||
assert_error_sent 404, fn ->
|
||||
get(conn, ~p"/admin/identities/#{identity}")
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
defp create_identity(_) do
|
||||
identity = identity_fixture()
|
||||
%{identity: identity}
|
||||
end
|
||||
end
|
24
test/support/fixtures/identities_fixtures.ex
Normal file
24
test/support/fixtures/identities_fixtures.ex
Normal file
|
@ -0,0 +1,24 @@
|
|||
defmodule Chiya.IdentitiesFixtures do
|
||||
@moduledoc """
|
||||
This module defines test helpers for creating
|
||||
entities via the `Chiya.Identities` context.
|
||||
"""
|
||||
|
||||
@doc """
|
||||
Generate a identity.
|
||||
"""
|
||||
def identity_fixture(attrs \\ %{}) do
|
||||
{:ok, identity} =
|
||||
attrs
|
||||
|> Enum.into(%{
|
||||
active: true,
|
||||
name: "some name",
|
||||
public: true,
|
||||
rel: "some rel",
|
||||
url: "some url"
|
||||
})
|
||||
|> Chiya.Identities.create_identity()
|
||||
|
||||
identity
|
||||
end
|
||||
end
|
Loading…
Reference in a new issue