Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

PA message table migration and postgres configuration #321

Merged
merged 42 commits into from
Apr 26, 2024
Merged
Show file tree
Hide file tree
Changes from 5 commits
Commits
Show all changes
42 commits
Select commit Hold shift + click to select a range
83539e8
Added modules needed to keep live alerts in memory.
cmaddox5 Apr 3, 2024
6cee1c9
Added new processes to supervision tree.
cmaddox5 Apr 3, 2024
a26e266
Added store test module.
cmaddox5 Apr 4, 2024
a672780
Made fetcher more testable.
cmaddox5 Apr 4, 2024
4d8eecc
Added Fetcher test module.
cmaddox5 Apr 5, 2024
4cfd5df
Added moduledocs.
cmaddox5 Apr 5, 2024
0d1d3b8
Credo.
cmaddox5 Apr 5, 2024
75deb87
Consolidated logic so fetching and storing happens in the same module.
cmaddox5 Apr 9, 2024
32af27e
Removed unnecessary pattern match.
cmaddox5 Apr 10, 2024
c49da34
Changed reduce to map.
cmaddox5 Apr 10, 2024
142c2d1
Fixed AuthManager so users can have more than one role.
cmaddox5 Apr 1, 2024
a726335
Changed attribute name to be more specific.
cmaddox5 Apr 1, 2024
9b8ab68
Added new role for PA Message workflow.
cmaddox5 Apr 1, 2024
33e058a
Renamed a role so it better represents how it's used.
cmaddox5 Apr 1, 2024
12d18a9
Added a plug for verifying permission.
cmaddox5 Apr 1, 2024
330bbdc
Added scope with an auth check for PA message creation.
cmaddox5 Apr 1, 2024
33e1a40
Added role to fake Keycloak config.
cmaddox5 Apr 1, 2024
9873488
Added new role to metadata.
cmaddox5 Apr 1, 2024
bcd0142
Renamed modules and files to better describe functionality.
cmaddox5 Apr 2, 2024
c226b5b
Changed references of admin to emergency admin.
cmaddox5 Apr 2, 2024
c2f686b
Simplified how roles are mapped to access levels.
cmaddox5 Apr 2, 2024
5e80d90
Removed explicit readonly permission. Can be implied.
cmaddox5 Apr 2, 2024
8842d8b
Added roles list to metadata to cut down on function calls.
cmaddox5 Apr 2, 2024
b552e83
Fixed tests now that roles are in assigns.
cmaddox5 Apr 2, 2024
1964353
Added test for new plug.
cmaddox5 Apr 2, 2024
963610c
Use Plug instead of manual adding assigns.
cmaddox5 Apr 2, 2024
ba3290b
Added a doc for the endpoint RTS will use to retrieve active messages.
cmaddox5 Apr 19, 2024
5893bef
add migration and dependencies
PaulJKim Apr 22, 2024
5ffb3e2
Add migration and database configuration
PaulJKim Apr 23, 2024
e7df84b
Merge branch 'main' into pk/pa-message-table-migration
PaulJKim Apr 23, 2024
2a830b1
Add documentation for postgres
PaulJKim Apr 23, 2024
f8163e7
Add migrations process
PaulJKim Apr 24, 2024
3b8ea39
Merge pull request #304 from mbta/cm/active-message-api-doc
cmaddox5 Apr 25, 2024
e2f93fe
Update config/test.exs
PaulJKim Apr 25, 2024
f997b2e
remove async migrations method
PaulJKim Apr 25, 2024
4086514
Add postgres service to CI
PaulJKim Apr 25, 2024
946a0c1
Merge branch 'pa-message-creation' into pk/pa-message-table-migration
PaulJKim Apr 25, 2024
70e53e4
Merge branch 'pa-message-creation' into pk/pa-message-table-migration
PaulJKim Apr 25, 2024
e8f60c6
formatting
PaulJKim Apr 25, 2024
ec0b61b
fetch cert
PaulJKim Apr 25, 2024
55a4c9a
move cert file to priv
PaulJKim Apr 25, 2024
015760f
fix typo
PaulJKim Apr 25, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 6 additions & 0 deletions .envrc.template
Original file line number Diff line number Diff line change
Expand Up @@ -15,3 +15,9 @@
# export SCREENS_URL=
# export SIGNS_UI_URL=
# export ALERTS_UI_URL=

## Postgres configuration: username, password, and hostname
## * Your local Postgres server should go here
# export DATABASE_USERNAME=
PaulJKim marked this conversation as resolved.
Show resolved Hide resolved
# export DATABASE_PASSWORD=
# export DATABASE_HOSTNAME=
4 changes: 4 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,10 @@

This tool enables PIOs to upload urgent messages to the Outfront signs in and outside stations.

## Prerequisites

Screenplay requires Postgres. If you don't already have Postgres installed, and you're on a Mac, [Postgres.app](https://postgresapp.com/downloads.html) is an easy way to get started. However, any Postgres instance to which you can connect and in which you have sufficient privileges should work.

## Development

To start your Phoenix server:
Expand Down
11 changes: 11 additions & 0 deletions config/config.exs
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,17 @@
# General application configuration
import Config

config :screenplay, Screenplay.Repo,
cmaddox5 marked this conversation as resolved.
Show resolved Hide resolved
database: "screenplay_dev",
username: System.get_env("DATABASE_USER", ""),
password: System.get_env("DATABASE_PASSWORD", ""),
hostname: System.get_env("DATABASE_HOST", "localhost"),
port: System.get_env("DATABASE_PORT", "5432") |> String.to_integer(),
show_sensitive_data_on_connection_error: true,
backoff_min: 5_000

config :screenplay, ecto_repos: [Screenplay.Repo]
cmaddox5 marked this conversation as resolved.
Show resolved Hide resolved

# Configures the endpoint
config :screenplay, ScreenplayWeb.Endpoint,
url: [host: "localhost"],
Expand Down
6 changes: 6 additions & 0 deletions config/prod.exs
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,12 @@ config :ueberauth, Ueberauth,
{Ueberauth.Strategy.Oidcc, userinfo: true, uid_field: "email", scopes: ~w(openid email)}
]

config :screenplay, Screenplay.Repo,
database: "screenplay",
ssl: true,
show_sensitive_data_on_connection_error: false,
configure: {Screenplay.Repo, :add_prod_credentials, []}

# ## SSL Support
#
# To get SSL working, you will need to add the `https` key
Expand Down
2 changes: 2 additions & 0 deletions config/runtime.exs
Original file line number Diff line number Diff line change
Expand Up @@ -64,3 +64,5 @@ scheduler_jobs =
else: []

config :screenplay, Screenplay.Scheduler, jobs: scheduler_jobs

config :screenplay, Screenplay.Repo, pool_size: 10
5 changes: 5 additions & 0 deletions config/test.exs
Original file line number Diff line number Diff line change
Expand Up @@ -28,5 +28,10 @@ config :ueberauth_oidcc,
]
]

config :screenplauy, Screenplay.Repo,
PaulJKim marked this conversation as resolved.
Show resolved Hide resolved
adapter: Ecto.Adapters.Postgres,
database: "screenplay_test",
pool: Ecto.Adapters.SQL.Sandbox

# Print only warnings and errors during test
config :logger, level: :warning
4 changes: 3 additions & 1 deletion lib/screenplay/application.ex
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,9 @@ defmodule Screenplay.Application do
# {Screenplay.Worker, arg}
Screenplay.OutfrontTakeoverTool.Alerts.State,
Screenplay.OutfrontTakeoverTool.Alerts.Reminders,
Screenplay.Scheduler
Screenplay.Scheduler,
Screenplay.Repo,
Screenplay.Migrate
]

# See https://hexdocs.pm/elixir/Supervisor.html
Expand Down
53 changes: 53 additions & 0 deletions lib/screenplay/migrate.ex
Original file line number Diff line number Diff line change
@@ -0,0 +1,53 @@
defmodule Screenplay.Migrate do
@moduledoc """
GenServer which runs on startup to run Ecto migrations. All migrations
stored in the "migrations" directory are run during init. Migrations stored
in the "async_migrations" directory will be run after the regular migrations
complete and will only log a warning on failure.
"""
use GenServer, restart: :transient
require Logger

def start_link(opts) do
GenServer.start_link(__MODULE__, opts)
end

@impl GenServer
def init(opts) do
Logger.info("#{__MODULE__} synchronous migrations starting")
Keyword.get(opts, :sync_migrate_fn, &default_migrate_fn/1).("migrations")

Logger.info("#{__MODULE__} synchronous migrations finished")
{:ok, opts, {:continue, :async_migrations}}
end

@impl GenServer
def handle_continue(:async_migrations, opts) do
PaulJKim marked this conversation as resolved.
Show resolved Hide resolved
Logger.info("#{__MODULE__} async migrations starting")

try do
Keyword.get(
opts,
:async_migrate_fn,
&default_migrate_fn/1
).("async_migrations")

Logger.info("#{__MODULE__} async migrations finished")
rescue
e ->
Logger.warning("#{__MODULE__} async migrations failed. error=#{inspect(e)}")
:ok
end

{:stop, :normal, opts}
end

defp default_migrate_fn(migration_directory) do
Ecto.Migrator.run(
Screenplay.Repo,
Ecto.Migrator.migrations_path(Screenplay.Repo, migration_directory),
:up,
all: true
)
end
end
43 changes: 43 additions & 0 deletions lib/screenplay/repo.ex
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
defmodule Screenplay.Repo do
require Logger

use Ecto.Repo,
otp_app: :screenplay,
adapter: Ecto.Adapters.Postgres

def add_prod_credentials(config, auth_token_fn \\ &ExAws.RDS.generate_db_auth_token/4) do
host = System.get_env("DATABASE_HOST")
port = String.to_integer(System.get_env("DATABASE_PORT", "5432"))
user = System.get_env("DATABASE_USER")

token =
auth_token_fn.(
host,
user,
port,
%{}
)

if is_nil(token) do
Logger.info("#{__MODULE__} add_prod_credentials token_is_nil")
else
hash_string = Base.encode16(:crypto.hash(:sha3_256, token))

Logger.info("#{__MODULE__} add_prod_credentials token_hash=#{hash_string}")
end

Keyword.merge(config,
hostname: host,
username: user,
port: port,
password: token,
ssl_opts: [
cacertfile: "priv/aws-cert-bundle.pem",
verify: :verify_peer,
server_name_indication: String.to_charlist(host),
verify_fun:
{&:ssl_verify_hostname.verify_fun/3, [check_hostname: String.to_charlist(host)]}
]
)
end
end
3 changes: 3 additions & 0 deletions mix.exs
Original file line number Diff line number Diff line change
Expand Up @@ -53,11 +53,14 @@ defmodule Screenplay.MixProject do
{:sftp_client, "~> 2.0"},
{:ex_aws, "~> 2.5"},
{:ex_aws_s3, "~> 2.5"},
{:ex_aws_rds, "~> 2.0.2"},
{:httpoison, "~> 2.2.1"},
{:lcov_ex, "~> 0.2", only: [:dev, :test], runtime: false},
{:sobelow, "~> 0.8", only: :dev},
{:sentry, "~> 10.3"},
{:stream_data, "~> 0.5", only: :test},
{:ecto_sql, "~> 3.0"},
{:postgrex, ">= 0.0.0"},
{:quantum, "~> 3.0"}
]
end
Expand Down
6 changes: 6 additions & 0 deletions mix.lock
Original file line number Diff line number Diff line change
Expand Up @@ -7,9 +7,14 @@
"cowlib": {:hex, :cowlib, "2.12.1", "a9fa9a625f1d2025fe6b462cb865881329b5caff8f1854d1cbc9f9533f00e1e1", [:make, :rebar3], [], "hexpm", "163b73f6367a7341b33c794c4e88e7dbfe6498ac42dcd69ef44c5bc5507c8db0"},
"credo": {:hex, :credo, "1.7.5", "643213503b1c766ec0496d828c90c424471ea54da77c8a168c725686377b9545", [:mix], [{:bunt, "~> 0.2.1 or ~> 1.0", [hex: :bunt, repo: "hexpm", optional: false]}, {:file_system, "~> 0.2 or ~> 1.0", [hex: :file_system, repo: "hexpm", optional: false]}, {:jason, "~> 1.0", [hex: :jason, repo: "hexpm", optional: false]}], "hexpm", "f799e9b5cd1891577d8c773d245668aa74a2fcd15eb277f51a0131690ebfb3fd"},
"crontab": {:hex, :crontab, "1.1.13", "3bad04f050b9f7f1c237809e42223999c150656a6b2afbbfef597d56df2144c5", [:mix], [{:ecto, "~> 1.0 or ~> 2.0 or ~> 3.0", [hex: :ecto, repo: "hexpm", optional: true]}], "hexpm", "d67441bec989640e3afb94e123f45a2bc42d76e02988c9613885dc3d01cf7085"},
"db_connection": {:hex, :db_connection, "2.6.0", "77d835c472b5b67fc4f29556dee74bf511bbafecdcaf98c27d27fa5918152086", [:mix], [{:telemetry, "~> 0.4 or ~> 1.0", [hex: :telemetry, repo: "hexpm", optional: false]}], "hexpm", "c2f992d15725e721ec7fbc1189d4ecdb8afef76648c746a8e1cad35e3b8a35f3"},
"decimal": {:hex, :decimal, "2.1.1", "5611dca5d4b2c3dd497dec8f68751f1f1a54755e8ed2a966c2633cf885973ad6", [:mix], [], "hexpm", "53cfe5f497ed0e7771ae1a475575603d77425099ba5faef9394932b35020ffcc"},
"dialyxir": {:hex, :dialyxir, "1.4.3", "edd0124f358f0b9e95bfe53a9fcf806d615d8f838e2202a9f430d59566b6b53b", [:mix], [{:erlex, ">= 0.2.6", [hex: :erlex, repo: "hexpm", optional: false]}], "hexpm", "bf2cfb75cd5c5006bec30141b131663299c661a864ec7fbbc72dfa557487a986"},
"ecto": {:hex, :ecto, "3.11.2", "e1d26be989db350a633667c5cda9c3d115ae779b66da567c68c80cfb26a8c9ee", [:mix], [{:decimal, "~> 2.0", [hex: :decimal, repo: "hexpm", optional: false]}, {:jason, "~> 1.0", [hex: :jason, repo: "hexpm", optional: true]}, {:telemetry, "~> 0.4 or ~> 1.0", [hex: :telemetry, repo: "hexpm", optional: false]}], "hexpm", "3c38bca2c6f8d8023f2145326cc8a80100c3ffe4dcbd9842ff867f7fc6156c65"},
"ecto_sql": {:hex, :ecto_sql, "3.11.1", "e9abf28ae27ef3916b43545f9578b4750956ccea444853606472089e7d169470", [:mix], [{:db_connection, "~> 2.4.1 or ~> 2.5", [hex: :db_connection, repo: "hexpm", optional: false]}, {:ecto, "~> 3.11.0", [hex: :ecto, repo: "hexpm", optional: false]}, {:myxql, "~> 0.6.0", [hex: :myxql, repo: "hexpm", optional: true]}, {:postgrex, "~> 0.16.0 or ~> 0.17.0 or ~> 1.0", [hex: :postgrex, repo: "hexpm", optional: true]}, {:tds, "~> 2.1.1 or ~> 2.2", [hex: :tds, repo: "hexpm", optional: true]}, {:telemetry, "~> 0.4.0 or ~> 1.0", [hex: :telemetry, repo: "hexpm", optional: false]}], "hexpm", "ce14063ab3514424276e7e360108ad6c2308f6d88164a076aac8a387e1fea634"},
"erlex": {:hex, :erlex, "0.2.6", "c7987d15e899c7a2f34f5420d2a2ea0d659682c06ac607572df55a43753aa12e", [:mix], [], "hexpm", "2ed2e25711feb44d52b17d2780eabf998452f6efda104877a3881c2f8c0c0c75"},
"ex_aws": {:hex, :ex_aws, "2.5.1", "7418917974ea42e9e84b25e88b9f3d21a861d5f953ad453e212f48e593d8d39f", [:mix], [{:configparser_ex, "~> 4.0", [hex: :configparser_ex, repo: "hexpm", optional: true]}, {:hackney, "~> 1.16", [hex: :hackney, repo: "hexpm", optional: true]}, {:jason, "~> 1.1", [hex: :jason, repo: "hexpm", optional: true]}, {:jsx, "~> 2.8 or ~> 3.0", [hex: :jsx, repo: "hexpm", optional: true]}, {:mime, "~> 1.2 or ~> 2.0", [hex: :mime, repo: "hexpm", optional: false]}, {:sweet_xml, "~> 0.7", [hex: :sweet_xml, repo: "hexpm", optional: true]}, {:telemetry, "~> 0.4.3 or ~> 1.0", [hex: :telemetry, repo: "hexpm", optional: false]}], "hexpm", "1b95431f70c446fa1871f0eb9b183043c5a625f75f9948a42d25f43ae2eff12b"},
"ex_aws_rds": {:hex, :ex_aws_rds, "2.0.2", "38dd8e83d57cf4b7286c4f6f5c978f700c40c207ffcdd6ca5d738e5eba933f9a", [:mix], [{:ex_aws, "~> 2.0", [hex: :ex_aws, repo: "hexpm", optional: false]}], "hexpm", "9e5b5cc168077874cbd0d29ba65d01caf1877e705fb5cecacf0667dd19bfa75c"},
"ex_aws_s3": {:hex, :ex_aws_s3, "2.5.3", "422468e5c3e1a4da5298e66c3468b465cfd354b842e512cb1f6fbbe4e2f5bdaf", [:mix], [{:ex_aws, "~> 2.0", [hex: :ex_aws, repo: "hexpm", optional: false]}, {:sweet_xml, ">= 0.0.0", [hex: :sweet_xml, repo: "hexpm", optional: true]}], "hexpm", "4f09dd372cc386550e484808c5ac5027766c8d0cd8271ccc578b82ee6ef4f3b8"},
"expo": {:hex, :expo, "0.5.1", "249e826a897cac48f591deba863b26c16682b43711dd15ee86b92f25eafd96d9", [:mix], [], "hexpm", "68a4233b0658a3d12ee00d27d37d856b1ba48607e7ce20fd376958d0ba6ce92b"},
"file_system": {:hex, :file_system, "0.2.10", "fb082005a9cd1711c05b5248710f8826b02d7d1784e7c3451f9c1231d4fc162d", [:mix], [], "hexpm", "41195edbfb562a593726eda3b3e8b103a309b733ad25f3d642ba49696bf715dc"},
Expand Down Expand Up @@ -40,6 +45,7 @@
"plug": {:hex, :plug, "1.15.3", "712976f504418f6dff0a3e554c40d705a9bcf89a7ccef92fc6a5ef8f16a30a97", [:mix], [{:mime, "~> 1.0 or ~> 2.0", [hex: :mime, repo: "hexpm", optional: false]}, {:plug_crypto, "~> 1.1.1 or ~> 1.2 or ~> 2.0", [hex: :plug_crypto, repo: "hexpm", optional: false]}, {:telemetry, "~> 0.4.3 or ~> 1.0", [hex: :telemetry, repo: "hexpm", optional: false]}], "hexpm", "cc4365a3c010a56af402e0809208873d113e9c38c401cabd88027ef4f5c01fd2"},
"plug_cowboy": {:hex, :plug_cowboy, "2.7.1", "87677ffe3b765bc96a89be7960f81703223fe2e21efa42c125fcd0127dd9d6b2", [:mix], [{:cowboy, "~> 2.7", [hex: :cowboy, repo: "hexpm", optional: false]}, {:cowboy_telemetry, "~> 0.3", [hex: :cowboy_telemetry, repo: "hexpm", optional: false]}, {:plug, "~> 1.14", [hex: :plug, repo: "hexpm", optional: false]}], "hexpm", "02dbd5f9ab571b864ae39418db7811618506256f6d13b4a45037e5fe78dc5de3"},
"plug_crypto": {:hex, :plug_crypto, "2.0.0", "77515cc10af06645abbfb5e6ad7a3e9714f805ae118fa1a70205f80d2d70fe73", [:mix], [], "hexpm", "53695bae57cc4e54566d993eb01074e4d894b65a3766f1c43e2c61a1b0f45ea9"},
"postgrex": {:hex, :postgrex, "0.17.5", "0483d054938a8dc069b21bdd636bf56c487404c241ce6c319c1f43588246b281", [:mix], [{:db_connection, "~> 2.1", [hex: :db_connection, repo: "hexpm", optional: false]}, {:decimal, "~> 1.5 or ~> 2.0", [hex: :decimal, repo: "hexpm", optional: false]}, {:jason, "~> 1.0", [hex: :jason, repo: "hexpm", optional: true]}, {:table, "~> 0.1.0", [hex: :table, repo: "hexpm", optional: true]}], "hexpm", "50b8b11afbb2c4095a3ba675b4f055c416d0f3d7de6633a595fc131a828a67eb"},
"quantum": {:hex, :quantum, "3.5.3", "ee38838a07761663468145f489ad93e16a79440bebd7c0f90dc1ec9850776d99", [:mix], [{:crontab, "~> 1.1", [hex: :crontab, repo: "hexpm", optional: false]}, {:gen_stage, "~> 0.14 or ~> 1.0", [hex: :gen_stage, repo: "hexpm", optional: false]}, {:telemetry, "~> 0.4.3 or ~> 1.0", [hex: :telemetry, repo: "hexpm", optional: false]}, {:telemetry_registry, "~> 0.2", [hex: :telemetry_registry, repo: "hexpm", optional: false]}], "hexpm", "500fd3fa77dcd723ed9f766d4a175b684919ff7b6b8cfd9d7d0564d58eba8734"},
"ranch": {:hex, :ranch, "1.8.0", "8c7a100a139fd57f17327b6413e4167ac559fbc04ca7448e9be9057311597a1d", [:make, :rebar3], [], "hexpm", "49fbcfd3682fab1f5d109351b61257676da1a2fdbe295904176d5e521a2ddfe5"},
"sentry": {:hex, :sentry, "10.3.0", "4b7543dfea5e59f3be6db28a032427884d55fbc828173b23115064e75dcb1eed", [:mix], [{:hackney, "~> 1.8", [hex: :hackney, repo: "hexpm", optional: true]}, {:jason, "~> 1.1", [hex: :jason, repo: "hexpm", optional: true]}, {:nimble_options, "~> 1.0", [hex: :nimble_options, repo: "hexpm", optional: false]}, {:nimble_ownership, "~> 0.3.0", [hex: :nimble_ownership, repo: "hexpm", optional: false]}, {:plug, "~> 1.6", [hex: :plug, repo: "hexpm", optional: true]}, {:telemetry, "~> 0.4 or ~> 1.0", [hex: :telemetry, repo: "hexpm", optional: true]}], "hexpm", "c1c08ba57f0634b7fda92adb0818ea0677e043e2d28ea4464351a0e4e8e142e5"},
Expand Down
25 changes: 25 additions & 0 deletions priv/repo/migrations/20240422170503_create_pa_message_table.exs
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
defmodule Screenplay.Repo.Migrations.CreatePaMessageTable do
use Ecto.Migration

def change do
create table("pa_message") do
add :alert_id, :string
add :start_time, :utc_datetime
add :end_time, :utc_datetime
add :days_of_week, {:array, :string}
add :sign_ids, {:array, :string}, null: false
add :priority, :integer, null: false
add :interval_in_minutes, :integer, null: false
add :visual_text, :text, null: false
add :audio_text, :text, null: false
add :paused, :boolean
add :saved, :boolean
add :message_type, :string

timestamps(type: :utc_datetime)
end

create index("pa_message", [:start_time, :end_time])
create index("pa_message", ["(to_tsvector('english', visual_text))"], using: "GIN")
end
end
Loading