resolv.ex (1963B)
1 # Zenflows is designed to implement the Valueflows vocabulary, 2 # written and maintained by srfsh <info@dyne.org>. 3 # Copyright (C) 2021-2023 Dyne.org foundation <foundation@dyne.org>. 4 # 5 # This program is free software: you can redistribute it and/or modify 6 # it under the terms of the GNU Affero General Public License as published by 7 # the Free Software Foundation, either version 3 of the License, or 8 # (at your option) any later version. 9 # 10 # This program is distributed in the hope that it will be useful, 11 # but WITHOUT ANY WARRANTY; without even the implied warranty of 12 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 13 # GNU Affero General Public License for more details. 14 # 15 # You should have received a copy of the GNU Affero General Public License 16 # along with this program. If not, see <https://www.gnu.org/licenses/>. 17 18 defmodule Zenflows.VF.Process.Resolv do 19 @moduledoc false 20 21 use Absinthe.Schema.Notation 22 23 alias Zenflows.GQL.Connection 24 alias Zenflows.VF.Process.Domain 25 26 def process(params, _) do 27 Domain.one(params) 28 end 29 30 def processes(params, _) do 31 with {:ok, page} <- Connection.parse(params), 32 {:ok, schemas} <- Domain.all(page) do 33 {:ok, Connection.from_list(schemas, page)} 34 end 35 end 36 37 def create_process(%{process: params}, _) do 38 with {:ok, process} <- Domain.create(params) do 39 {:ok, %{process: process}} 40 end 41 end 42 43 def update_process(%{process: %{id: id} = params}, _) do 44 with {:ok, proc} <- Domain.update(id, params) do 45 {:ok, %{process: proc}} 46 end 47 end 48 49 def delete_process(%{id: id}, _) do 50 with {:ok, _} <- Domain.delete(id) do 51 {:ok, true} 52 end 53 end 54 55 def based_on(proc, _, _) do 56 proc = Domain.preload(proc, :based_on) 57 {:ok, proc.based_on} 58 end 59 60 def planned_within(proc, _, _) do 61 proc = Domain.preload(proc, :planned_within) 62 {:ok, proc.planned_within} 63 end 64 65 def nested_in(proc, _, _) do 66 proc = Domain.preload(proc, :nested_in) 67 {:ok, proc.nested_in} 68 end 69 70 def previous(proc, _, _) do 71 {:ok, Domain.previous(proc)} 72 end 73 end