|
1 | 1 | defmodule CodeCorpsWeb.StripeConnectSubscriptionController do |
2 | 2 | use CodeCorpsWeb, :controller |
3 | | - use JaResource |
4 | 3 |
|
5 | | - alias CodeCorps.StripeConnectSubscription |
| 4 | + alias CodeCorps.{StripeConnectSubscription, User} |
6 | 5 | alias CodeCorps.StripeService.StripeConnectSubscriptionService |
7 | 6 |
|
8 | | - plug :load_and_authorize_resource, model: StripeConnectSubscription, only: [:show], preload: [:user] |
9 | | - plug :load_and_authorize_changeset, model: StripeConnectSubscription, only: [:create] |
| 7 | + action_fallback CodeCorpsWeb.FallbackController |
| 8 | + plug CodeCorpsWeb.Plug.DataToAttributes |
| 9 | + plug CodeCorpsWeb.Plug.IdsToIntegers |
10 | 10 |
|
11 | | - plug JaResource |
12 | | - |
13 | | - @spec model :: module |
14 | | - def model, do: CodeCorps.StripeConnectSubscription |
| 11 | + @spec show(Conn.t, map) :: Conn.t |
| 12 | + def show(%Conn{} = conn, %{"id" => id} = params) do |
| 13 | + with %User{} = current_user <- conn |> Guardian.Plug.current_resource, |
| 14 | + %StripeConnectSubscription{} = subscription <- StripeConnectSubscription |> Repo.get(id), |
| 15 | + {:ok, :authorized} <- current_user |> Policy.authorize(:show, subscription, params) do |
| 16 | + conn |> render("show.json-api", data: subscription) |
| 17 | + end |
| 18 | + end |
15 | 19 |
|
16 | | - def handle_create(_conn, attributes) do |
17 | | - attributes |> StripeConnectSubscriptionService.find_or_create |
| 20 | + @spec create(Plug.Conn.t, map) :: Conn.t |
| 21 | + def create(%Conn{} = conn, %{} = params) do |
| 22 | + with %User{} = current_user <- conn |> Guardian.Plug.current_resource, |
| 23 | + {:ok, :authorized} <- current_user |> Policy.authorize(:create, %StripeConnectSubscription{}, params), |
| 24 | + {:ok, %StripeConnectSubscription{} = subscription} <- StripeConnectSubscriptionService.find_or_create(params) do |
| 25 | + conn |> put_status(:created) |> render("show.json-api", data: subscription) |
| 26 | + end |
18 | 27 | end |
19 | 28 | end |
0 commit comments