diff options
| author | Dawid Rycerz <dawid@rycerz.xyz> | 2025-03-23 17:11:39 +0100 |
|---|---|---|
| committer | Dawid Rycerz <dawid@rycerz.xyz> | 2025-04-05 21:16:51 +0200 |
| commit | 0ab2e5ba2b0631b28b5b1405559237b3913c878f (patch) | |
| tree | 791cea788b0a62bc483d0041fbd0c655d2ad49e8 /priv/repo | |
feat: initialize Phoenix application for weather alerts
This commit sets up the initial Silmataivas project structure, including: Phoenix web framework configuration, database models for users and locations, weather polling service, notification system, Docker and deployment configurations, CI/CD pipeline setup
Diffstat (limited to 'priv/repo')
| -rw-r--r-- | priv/repo/migrations/.formatter.exs | 4 | ||||
| -rw-r--r-- | priv/repo/migrations/20250323093704_create_users.exs | 13 | ||||
| -rw-r--r-- | priv/repo/migrations/20250323093713_create_locations.exs | 15 | ||||
| -rw-r--r-- | priv/repo/migrations/20250326104054_add_role_to_users.exs | 9 | ||||
| -rw-r--r-- | priv/repo/seeds.exs | 11 |
5 files changed, 52 insertions, 0 deletions
diff --git a/priv/repo/migrations/.formatter.exs b/priv/repo/migrations/.formatter.exs new file mode 100644 index 0000000..49f9151 --- /dev/null +++ b/priv/repo/migrations/.formatter.exs @@ -0,0 +1,4 @@ +[ + import_deps: [:ecto_sql], + inputs: ["*.exs"] +] diff --git a/priv/repo/migrations/20250323093704_create_users.exs b/priv/repo/migrations/20250323093704_create_users.exs new file mode 100644 index 0000000..c418326 --- /dev/null +++ b/priv/repo/migrations/20250323093704_create_users.exs @@ -0,0 +1,13 @@ +defmodule Silmataivas.Repo.Migrations.CreateUsers do + use Ecto.Migration + + def change do + create table(:users) do + add :user_id, :string + + timestamps(type: :utc_datetime) + end + + create unique_index(:users, [:user_id]) + end +end diff --git a/priv/repo/migrations/20250323093713_create_locations.exs b/priv/repo/migrations/20250323093713_create_locations.exs new file mode 100644 index 0000000..9373024 --- /dev/null +++ b/priv/repo/migrations/20250323093713_create_locations.exs @@ -0,0 +1,15 @@ +defmodule Silmataivas.Repo.Migrations.CreateLocations do + use Ecto.Migration + + def change do + create table(:locations) do + add :latitude, :float + add :longitude, :float + add :user_id, references(:users, on_delete: :nothing) + + timestamps(type: :utc_datetime) + end + + create index(:locations, [:user_id]) + end +end diff --git a/priv/repo/migrations/20250326104054_add_role_to_users.exs b/priv/repo/migrations/20250326104054_add_role_to_users.exs new file mode 100644 index 0000000..786b46f --- /dev/null +++ b/priv/repo/migrations/20250326104054_add_role_to_users.exs @@ -0,0 +1,9 @@ +defmodule Silmataivas.Repo.Migrations.AddRoleToUsers do + use Ecto.Migration + + def change do + alter table(:users) do + add :role, :string, default: "user" + end + end +end diff --git a/priv/repo/seeds.exs b/priv/repo/seeds.exs new file mode 100644 index 0000000..1a102d7 --- /dev/null +++ b/priv/repo/seeds.exs @@ -0,0 +1,11 @@ +# Script for populating the database. You can run it as: +# +# mix run priv/repo/seeds.exs +# +# Inside the script, you can read and write to any of your +# repositories directly: +# +# Silmataivas.Repo.insert!(%Silmataivas.SomeSchema{}) +# +# We recommend using the bang functions (`insert!`, `update!` +# and so on) as they will fail if something goes wrong. |
