Subscribe to events emitted by EctoWatch, and cache the changed row. Use the sync
function
to update an in-memory row or list of rows using the cached version.
Post <-> PostsTags <-> Tag
children = [
...,
{EctoSync,
repo: MyRepo,
pub_sub: MyPubSub,
watchers: EctoSync.watchers(Posts, assocs: [:tags])
},
...
]
alias MyApp.Posts.Post
alias MyApp.Posts.Tag
def mount(params, session, socket) do
posts = list_posts(preload: [:tags])
if connected?(socket) do
EctoSync.subscribe(Post, assocs: [:tags])
end
{:ok, assign(socket, posts: posts)}
end
def handle_info({EctoSync, {PostsTags, _event} = sync_args}, socket) do
{:ok, posts} = EctoSync.sync(socket.assigns.posts, sync_args)
{:noreply, assign(socket, posts: posts)}
end
- When a Tag row is updated, all posts that reference that tag will be updated.
- When a PostsTags row is inserted, the tag will automatically be added to the corresponding post.
The Tag is loaded from the database once for each event handled by EctoSync.
The result is then cached and this cached version will be used when other processes call
EctoSync.sync/2
with the args provided in handle_info
.
def mount(params, session, socket) do
tags = list_tags()
if connected?(socket) do
EctoSync.subscribe(tags)
end
{:ok, assign(socket, tags: tags)}
end
def render(assigns) do
~F"""
<.simple_form for={@form}>
<input name="name" placeholder="Post name" />
<select multiple name="tags">
<option :for={tag <- @tags} value={tag.id}>{tag.name}</option>
</select>
</.simple_form>
"""
end
def handle_info({EctoSync, {Tag, _event, _} = sync_args}, socket) do
{:ok, tags} = EctoSync.sync(socket.assigns.tags, sync_args)
{:noreply, assign(socket, tags: tags)
end
If available in Hex, the package can be installed
by adding ecto_sync
to your list of dependencies in mix.exs
:
def deps do
[
{:ecto_sync, "~> 0.1.0"}
]
end
children = [
...,
{EctoSync,
repo: MyRepo,
pub_sub: MyPubSub,
watchers:
EctoSync.watchers(Schema)
|> EctoSync.watchers(OtherSchema, assocs: [:some_assocs])
|> EctoSync.watchers(AnotherSchema, extra_columns: [:test_id])},
]
Documentation can be generated with ExDoc and published on HexDocs. Once published, the docs can be found at https://hexdocs.pm/ecto_sync.