Page MenuHomePhorge

repo_streamer.ex
No OneTemporary

Size
746 B
Referenced Files
None
Subscribers
None

repo_streamer.ex

# Pleroma: A lightweight social networking server
# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>
# SPDX-License-Identifier: AGPL-3.0-only
defmodule Pleroma.RepoStreamer do
alias Pleroma.Repo
import Ecto.Query
def chunk_stream(query, chunk_size) do
Stream.unfold(0, fn
:halt ->
{[], :halt}
last_id ->
query
|> order_by(asc: :id)
|> where([r], r.id > ^last_id)
|> limit(^chunk_size)
|> Repo.all()
|> case do
[] ->
{[], :halt}
records ->
last_id = List.last(records).id
{records, last_id}
end
end)
|> Stream.take_while(fn
[] -> false
_ -> true
end)
end
end

File Metadata

Mime Type
text/x-ruby
Expires
Sat, Oct 25, 4:15 PM (5 h, 24 m)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
522882
Default Alt Text
repo_streamer.ex (746 B)

Event Timeline