diff options
author | ThibG <thib@sitedethib.com> | 2020-11-19 17:48:13 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-11-19 17:48:13 +0100 |
commit | 96c1e7132971877fba308c51cd42306f0b1bf166 (patch) | |
tree | 958beaea2865100de42bd7d962f6c7554566e906 /app/models | |
parent | 022d2353a77edaddd6a681405521f27f5fac11b2 (diff) |
Add import/export feature for bookmarks (#14956)
* Add ability to export bookmarks * Add support for importing bookmarks * Add bookmark import tests * Add bookmarks export test
Diffstat (limited to 'app/models')
-rw-r--r-- | app/models/export.rb | 12 | ||||
-rw-r--r-- | app/models/import.rb | 2 |
2 files changed, 13 insertions, 1 deletions
diff --git a/app/models/export.rb b/app/models/export.rb index cab01f11a..5216eed5e 100644 --- a/app/models/export.rb +++ b/app/models/export.rb @@ -9,6 +9,14 @@ class Export @account = account end + def to_bookmarks_csv + CSV.generate do |csv| + account.bookmarks.includes(:status).reorder(id: :desc).each do |bookmark| + csv << [ActivityPub::TagManager.instance.uri_for(bookmark.status)] + end + end + end + def to_blocked_accounts_csv to_csv account.blocking.select(:username, :domain) end @@ -55,6 +63,10 @@ class Export account.statuses_count end + def total_bookmarks + account.bookmarks.count + end + def total_follows account.following_count end diff --git a/app/models/import.rb b/app/models/import.rb index c78a04d07..702453289 100644 --- a/app/models/import.rb +++ b/app/models/import.rb @@ -24,7 +24,7 @@ class Import < ApplicationRecord belongs_to :account - enum type: [:following, :blocking, :muting, :domain_blocking] + enum type: [:following, :blocking, :muting, :domain_blocking, :bookmarks] validates :type, presence: true |