diff options
| author | Ben Busby <noreply+git@benbusby.com> | 2021-10-21 17:07:43 -0600 |
|---|---|---|
| committer | Ben Busby <noreply+git@benbusby.com> | 2021-10-21 17:07:43 -0600 |
| commit | cf8dfc5a85a7d655fef36ce735472a16635d8b7a (patch) | |
| tree | 7433a9d7106afc9d91051d7c2b58cb02e27ef58e /update.exs | |
| parent | be9606094c256471e256b1d00d6b681528547d58 (diff) | |
| download | farside-cf8dfc5a85a7d655fef36ce735472a16635d8b7a.tar.gz | |
Initialize update script
My initial thought for this: create a simple redis db for storing key
value pairs of instance -> list of live instances for each privacy front
end (libreddit, bibliogram, etc). A script executed on a certain
schedule would (in the background) check each instance to make sure it
isn't down or unreasonably slow. If the instance is available, add it to
a list of available instances in the db.
When a user navigates to the revolver url (something like
<url>/<service>/<...>), the app would pick a random value from the list
returned by redis.get('<service>') and forward the user to that
instance.
As a side note, this could instead load the instances json from a remote
source (like github or something) so that changes to instances don't
need to involve a redeploy of the entire app.
Diffstat (limited to 'update.exs')
| -rw-r--r-- | update.exs | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/update.exs b/update.exs new file mode 100644 index 0000000..6e42198 --- /dev/null +++ b/update.exs @@ -0,0 +1,21 @@ +defmodule Instance do + defstruct [ + instance_type: nil, + instance_list: [] + ] +end + +defmodule Instances do + def update(filename) do + {:ok, file} = File.read(filename) + {:ok, json} = Poison.decode(file, as: [%Instance{}]) + for x <- json do + IO.puts(x.instance_type) + for y <- x.instance_list do + IO.puts(" - " <> y) + end + end + end +end + +Instances.update("instances.json") |
