20211115103758_fill_vf_satisfaction.exs (1584B)
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.DB.Repo.Migrations.Fill_vf_satisfaction do 19 use Ecto.Migration 20 21 @mutex """ 22 satisfied_by_event_id IS NOT NULL 23 OR 24 satisfied_by_commitment_id IS NOT NULL 25 """ 26 27 def change() do 28 alter table("vf_satisfaction") do 29 add :satisfies_id, references("vf_intent"), null: false 30 add :satisfied_by_event_id, references("vf_economic_event") 31 add :satisfied_by_commitment_id, references("vf_commitment") 32 add :resource_quantity_has_unit_id, references("vf_unit") 33 add :resource_quantity_has_numerical_value, :decimal 34 add :effort_quantity_has_unit_id, references("vf_unit") 35 add :effort_quantity_has_numerical_value, :decimal 36 add :note, :text 37 timestamps() 38 end 39 create constraint("vf_satisfaction", :mutex, check: @mutex) 40 end 41 end