Skip to content

Commit

Permalink
Remove JaResource/Canary from RoleSkillController
Browse files Browse the repository at this point in the history
  • Loading branch information
landongrindheim authored and joshsmith committed Sep 27, 2017
1 parent 61485ab commit ad25293
Show file tree
Hide file tree
Showing 5 changed files with 63 additions and 31 deletions.
23 changes: 14 additions & 9 deletions lib/code_corps/model/role_skill.ex
Original file line number Diff line number Diff line change
Expand Up @@ -15,27 +15,32 @@ defmodule CodeCorps.RoleSkill do
@doc """
Builds a changeset based on the `struct` and `params`.
"""
@spec changeset(CodeCorps.RoleSkill.t, map) :: Ecto.Changeset.t
def changeset(struct, params \\ %{}) do
struct
|> cast(params, [:role_id, :skill_id])
|> validate_required([:role_id, :skill_id])
|> assoc_constraint(:role)
|> assoc_constraint(:skill)
|> unique_constraint(:role_id, name: :index_projects_on_role_id_skill_id)
@spec create_changeset(CodeCorps.RoleSkill.t, map) :: Ecto.Changeset.t
def create_changeset(struct, params \\ %{}) do
changeset(struct, params)
end

@doc """
Builds a changeset for importing a category.
"""
@spec import_changeset(CodeCorps.RoleSkill.t, map) :: Ecto.Changeset.t
def import_changeset(struct, params) do
def import_changeset(struct, params \\ %{}) do
struct
|> changeset(params)
|> cast(params, [:cat])
|> validate_inclusion(:cat, cats())
end

@spec changeset(CodeCorps.RoleSkill.t, map) :: Ecto.Changeset.t
defp changeset(struct, params) do
struct
|> cast(params, [:role_id, :skill_id])
|> validate_required([:role_id, :skill_id])
|> assoc_constraint(:role)
|> assoc_constraint(:skill)
|> unique_constraint(:role_id, name: :index_projects_on_role_id_skill_id)
end

defp cats do
[1, 2, 3, 4, 5, 6]
end
Expand Down
5 changes: 2 additions & 3 deletions lib/code_corps/policy/policy.ex
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,8 @@ defmodule CodeCorps.Policy do
%OrganizationGithubAppInstallation{} = organization_github_app_installation, %{}),
do: Policy.OrganizationGithubAppInstallation.delete?(user, organization_github_app_installation)
defp can?(%User{} = user, :create, %OrganizationGithubAppInstallation{}, %{} = params), do: Policy.OrganizationGithubAppInstallation.create?(user, params)
defp can?(%User{} = current_user, :create, %RoleSkill{}, %{}), do: Policy.RoleSkill.create?(current_user)
defp can?(%User{} = current_user, :delete, %RoleSkill{}, %{}), do: Policy.RoleSkill.delete?(current_user)
defp can?(%User{} = current_user, :create, %TaskSkill{}, %{} = params), do: Policy.TaskSkill.create?(current_user, params)
defp can?(%User{} = current_user, :delete, %TaskSkill{} = task_skill, %{}), do: Policy.TaskSkill.delete?(current_user, task_skill)
defp can?(%User{} = current_user, :create, %UserCategory{} = user_category, %{}), do: Policy.UserCategory.create?(current_user, user_category)
Expand Down Expand Up @@ -90,9 +92,6 @@ defmodule CodeCorps.Policy do

def can?(%User{} = user, :create, Role), do: Policy.Role.create?(user)

def can?(%User{} = user, :create, RoleSkill), do: Policy.RoleSkill.create?(user)
def can?(%User{} = user, :delete, %RoleSkill{}), do: Policy.RoleSkill.delete?(user)

def can?(%User{} = user, :create, Skill), do: Policy.Skill.create?(user)

def can?(%User{} = user, :show, %StripeConnectPlan{} = stripe_connect_plan), do: Policy.StripeConnectPlan.show?(user, stripe_connect_plan)
Expand Down
2 changes: 2 additions & 0 deletions lib/code_corps/policy/role_skill.ex
Original file line number Diff line number Diff line change
@@ -1,9 +1,11 @@
defmodule CodeCorps.Policy.RoleSkill do
alias CodeCorps.User

@spec create?(User.t) :: boolean
def create?(%User{admin: true}), do: true
def create?(%User{admin: false}), do: false

@spec delete?(User.t) :: boolean
def delete?(%User{admin: true}), do: true
def delete?(%User{admin: false}), do: false
end
44 changes: 35 additions & 9 deletions lib/code_corps_web/controllers/role_skill_controller.ex
Original file line number Diff line number Diff line change
@@ -1,18 +1,44 @@
defmodule CodeCorpsWeb.RoleSkillController do
use CodeCorpsWeb, :controller
use JaResource

import CodeCorps.Helpers.Query, only: [id_filter: 2]
alias CodeCorps.{RoleSkill, User, Helpers.Query}

alias CodeCorps.RoleSkill
action_fallback CodeCorpsWeb.FallbackController
plug CodeCorpsWeb.Plug.DataToAttributes
plug CodeCorpsWeb.Plug.IdsToIntegers

plug :load_and_authorize_resource, model: RoleSkill, only: [:create, :delete]
plug JaResource
@spec index(Conn.t, map) :: Conn.t
def index(%Conn{} = conn, %{} = params) do
with role_skills <- RoleSkill |> Query.id_filter(params) |> Repo.all do
conn |> render("index.json-api", data: role_skills)
end
end

@spec show(Conn.t, map) :: Conn.t
def show(%Conn{} = conn, %{"id" => id}) do
with %RoleSkill{} = role_skill <- RoleSkill |> Repo.get(id) do
conn |> render("show.json-api", data: role_skill)
end
end

@spec model :: module
def model, do: CodeCorps.RoleSkill
@spec create(Conn.t, map) :: Conn.t
def create(%Conn{} = conn, %{} = params) do
with %User{} = current_user <- conn |> Guardian.Plug.current_resource,
{:ok, :authorized} <- current_user |> Policy.authorize(:create, %RoleSkill{}, params),
{:ok, %RoleSkill{} = role_skill} <- %RoleSkill{} |> RoleSkill.create_changeset(params) |> Repo.insert
do
conn |> put_status(:created) |> render("show.json-api", data: role_skill)
end
end

def filter(_conn, query, "id", id_list) do
query |> id_filter(id_list)
@spec delete(Conn.t, map) :: Conn.t
def delete(%Conn{} = conn, %{"id" => id} = _params) do
with %RoleSkill{} = role_skill <- RoleSkill |> Repo.get(id),
%User{} = current_user <- conn |> Guardian.Plug.current_resource,
{:ok, :authorized} <- current_user |> Policy.authorize(:delete, role_skill),
{:ok, %RoleSkill{} = _role_skill} <- role_skill |> Repo.delete
do
conn |> Conn.assign(:role_skill, role_skill) |> send_resp(:no_content, "")
end
end
end
20 changes: 10 additions & 10 deletions test/lib/code_corps/model/role_skill_test.exs
Original file line number Diff line number Diff line change
Expand Up @@ -3,51 +3,51 @@ defmodule CodeCorps.RoleSkillTest do

alias CodeCorps.RoleSkill

test "changeset with valid attributes" do
test "create_changeset with valid attributes" do
role_id = insert(:role).id
skill_id = insert(:skill).id

changeset = RoleSkill.changeset(%RoleSkill{}, %{role_id: role_id, skill_id: skill_id})
changeset = RoleSkill.create_changeset(%RoleSkill{}, %{role_id: role_id, skill_id: skill_id})
assert changeset.valid?
end

test "changeset requires role_id" do
test "create_changeset requires role_id" do
skill_id = insert(:skill).id

changeset = RoleSkill.changeset(%RoleSkill{}, %{skill_id: skill_id})
changeset = RoleSkill.create_changeset(%RoleSkill{}, %{skill_id: skill_id})

refute changeset.valid?
assert_error_message(changeset, :role_id, "can't be blank")
end

test "changeset requires skill_id" do
test "create_changeset requires skill_id" do
role_id = insert(:role).id

changeset = RoleSkill.changeset(%RoleSkill{}, %{role_id: role_id})
changeset = RoleSkill.create_changeset(%RoleSkill{}, %{role_id: role_id})

refute changeset.valid?
assert_error_message(changeset, :skill_id, "can't be blank")
end

test "changeset requires id of actual role" do
test "create_changeset requires id of actual role" do
role_id = -1
skill_id = insert(:skill).id

{result, changeset} =
RoleSkill.changeset(%RoleSkill{}, %{role_id: role_id, skill_id: skill_id})
RoleSkill.create_changeset(%RoleSkill{}, %{role_id: role_id, skill_id: skill_id})
|> Repo.insert

assert result == :error
refute changeset.valid?
assert_error_message(changeset, :role, "does not exist")
end

test "changeset requires id of actual skill" do
test "create_changeset requires id of actual skill" do
role_id = insert(:role).id
skill_id = -1

{result, changeset} =
RoleSkill.changeset(%RoleSkill{}, %{role_id: role_id, skill_id: skill_id})
RoleSkill.create_changeset(%RoleSkill{}, %{role_id: role_id, skill_id: skill_id})
|> Repo.insert

assert result == :error
Expand Down

0 comments on commit ad25293

Please sign in to comment.