All checks were successful
continuous-integration/drone/push Build is passing
Complete refactoring of resources, database tables, code references, tests, and documentation for improved naming consistency.
197 lines
5.7 KiB
Elixir
197 lines
5.7 KiB
Elixir
# Script for populating the database. You can run it as:
|
|
#
|
|
# mix run priv/repo/seeds.exs
|
|
#
|
|
|
|
alias Mv.Membership
|
|
alias Mv.Accounts
|
|
|
|
for attrs <- [
|
|
%{
|
|
name: "String Field",
|
|
value_type: :string,
|
|
description: "Example for a field of type string",
|
|
immutable: true,
|
|
required: true
|
|
},
|
|
%{
|
|
name: "Date Field",
|
|
value_type: :date,
|
|
description: "Example for a field of type date",
|
|
immutable: true,
|
|
required: true
|
|
},
|
|
%{
|
|
name: "Boolean Field",
|
|
value_type: :boolean,
|
|
description: "Example for a field of type boolean",
|
|
immutable: true,
|
|
required: true
|
|
},
|
|
%{
|
|
name: "Email Field",
|
|
value_type: :email,
|
|
description: "Example for a field of type email",
|
|
immutable: true,
|
|
required: true
|
|
}
|
|
] do
|
|
Membership.create_custom_field!(
|
|
attrs,
|
|
upsert?: true,
|
|
upsert_identity: :unique_name
|
|
)
|
|
end
|
|
|
|
# Create admin user for testing
|
|
Accounts.create_user!(%{email: "admin@mv.local"}, upsert?: true, upsert_identity: :unique_email)
|
|
|> Ash.Changeset.for_update(:admin_set_password, %{password: "testpassword"})
|
|
|> Ash.update!()
|
|
|
|
# Create sample members for testing - use upsert to prevent duplicates
|
|
for member_attrs <- [
|
|
%{
|
|
first_name: "Hans",
|
|
last_name: "Müller",
|
|
email: "hans.mueller@example.de",
|
|
birth_date: ~D[1985-06-15],
|
|
join_date: ~D[2023-01-15],
|
|
paid: true,
|
|
phone_number: "+49301234567",
|
|
city: "München",
|
|
street: "Hauptstraße",
|
|
house_number: "42",
|
|
postal_code: "80331"
|
|
},
|
|
%{
|
|
first_name: "Greta",
|
|
last_name: "Schmidt",
|
|
email: "greta.schmidt@example.de",
|
|
birth_date: ~D[1990-03-22],
|
|
join_date: ~D[2023-02-01],
|
|
paid: false,
|
|
phone_number: "+49309876543",
|
|
city: "Hamburg",
|
|
street: "Lindenstraße",
|
|
house_number: "17",
|
|
postal_code: "20095",
|
|
notes: "Interessiert an Fortgeschrittenen-Kursen"
|
|
},
|
|
%{
|
|
first_name: "Friedrich",
|
|
last_name: "Wagner",
|
|
email: "friedrich.wagner@example.de",
|
|
birth_date: ~D[1978-11-08],
|
|
join_date: ~D[2022-11-10],
|
|
paid: true,
|
|
phone_number: "+49301122334",
|
|
city: "Berlin",
|
|
street: "Kastanienallee",
|
|
house_number: "8"
|
|
},
|
|
%{
|
|
first_name: "Marianne",
|
|
last_name: "Wagner",
|
|
email: "marianne.wagner@example.de",
|
|
birth_date: ~D[1978-11-08],
|
|
join_date: ~D[2022-11-10],
|
|
paid: true,
|
|
phone_number: "+49301122334",
|
|
city: "Berlin",
|
|
street: "Kastanienallee",
|
|
house_number: "8"
|
|
}
|
|
] do
|
|
# Use upsert to prevent duplicates based on email
|
|
Membership.create_member!(member_attrs, upsert?: true, upsert_identity: :unique_email)
|
|
end
|
|
|
|
# Create additional users for user-member linking examples
|
|
additional_users = [
|
|
%{email: "hans.mueller@example.de"},
|
|
%{email: "greta.schmidt@example.de"},
|
|
%{email: "maria.weber@example.de"},
|
|
%{email: "thomas.klein@example.de"}
|
|
]
|
|
|
|
created_users =
|
|
Enum.map(additional_users, fn user_attrs ->
|
|
Accounts.create_user!(user_attrs, upsert?: true, upsert_identity: :unique_email)
|
|
|> Ash.Changeset.for_update(:admin_set_password, %{password: "testpassword"})
|
|
|> Ash.update!()
|
|
end)
|
|
|
|
# Create members with linked users to demonstrate the 1:1 relationship
|
|
# Only create if users don't already have members
|
|
linked_members = [
|
|
%{
|
|
first_name: "Maria",
|
|
last_name: "Weber",
|
|
email: "maria.weber@example.de",
|
|
birth_date: ~D[1992-07-14],
|
|
join_date: ~D[2023-03-15],
|
|
paid: true,
|
|
phone_number: "+49301357924",
|
|
city: "Frankfurt",
|
|
street: "Goetheplatz",
|
|
house_number: "5",
|
|
postal_code: "60313",
|
|
notes: "Linked to user account",
|
|
# Link to the third user (maria.weber@example.de)
|
|
user: Enum.at(created_users, 2)
|
|
},
|
|
%{
|
|
first_name: "Thomas",
|
|
last_name: "Klein",
|
|
email: "thomas.klein@example.de",
|
|
birth_date: ~D[1988-12-03],
|
|
join_date: ~D[2023-04-01],
|
|
paid: false,
|
|
phone_number: "+49302468135",
|
|
city: "Köln",
|
|
street: "Rheinstraße",
|
|
house_number: "23",
|
|
postal_code: "50667",
|
|
notes: "Linked to user account - needs payment follow-up",
|
|
# Link to the fourth user (thomas.klein@example.de)
|
|
user: Enum.at(created_users, 3)
|
|
}
|
|
]
|
|
|
|
# Create the linked members - use upsert to prevent duplicates
|
|
Enum.each(linked_members, fn member_attrs ->
|
|
user = member_attrs.user
|
|
member_attrs_without_user = Map.delete(member_attrs, :user)
|
|
|
|
# Check if user already has a member
|
|
if user.member_id == nil do
|
|
# User is free, create member and link - use upsert to prevent duplicates
|
|
Membership.create_member!(
|
|
Map.put(member_attrs_without_user, :user, %{id: user.id}),
|
|
upsert?: true,
|
|
upsert_identity: :unique_email
|
|
)
|
|
else
|
|
# User already has a member, just create the member without linking - use upsert to prevent duplicates
|
|
Membership.create_member!(member_attrs_without_user,
|
|
upsert?: true,
|
|
upsert_identity: :unique_email
|
|
)
|
|
end
|
|
end)
|
|
|
|
IO.puts("✅ Seeds completed successfully!")
|
|
IO.puts("📝 Created sample data:")
|
|
IO.puts(" - Custom fields: String, Date, Boolean, Email")
|
|
IO.puts(" - Admin user: admin@mv.local (password: testpassword)")
|
|
IO.puts(" - Sample members: Hans, Greta, Friedrich")
|
|
|
|
IO.puts(
|
|
" - Additional users: hans.mueller@example.de, greta.schmidt@example.de, maria.weber@example.de, thomas.klein@example.de"
|
|
)
|
|
|
|
IO.puts(
|
|
" - Linked members: Maria Weber ↔ maria.weber@example.de, Thomas Klein ↔ thomas.klein@example.de"
|
|
)
|
|
|
|
IO.puts("🔗 Visit the application to see user-member relationships in action!")
|