Drop remaining OStatus and PuSH code, as well as related database items.
parent
cb311a274c
commit
0782dc3905
|
@ -1,20 +0,0 @@
|
||||||
# frozen_string_literal: true
|
|
||||||
|
|
||||||
module Admin
|
|
||||||
class SubscriptionsController < BaseController
|
|
||||||
def index
|
|
||||||
authorize :subscription, :index?
|
|
||||||
@subscriptions = ordered_subscriptions.page(requested_page)
|
|
||||||
end
|
|
||||||
|
|
||||||
private
|
|
||||||
|
|
||||||
def ordered_subscriptions
|
|
||||||
Subscription.order(id: :desc).includes(:account)
|
|
||||||
end
|
|
||||||
|
|
||||||
def requested_page
|
|
||||||
params[:page].to_i
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
|
@ -10,8 +10,6 @@
|
||||||
# private_key :text
|
# private_key :text
|
||||||
# public_key :text default(""), not null
|
# public_key :text default(""), not null
|
||||||
# remote_url :string default(""), not null
|
# remote_url :string default(""), not null
|
||||||
# salmon_url :string default(""), not null
|
|
||||||
# hub_url :string default(""), not null
|
|
||||||
# created_at :datetime not null
|
# created_at :datetime not null
|
||||||
# updated_at :datetime not null
|
# updated_at :datetime not null
|
||||||
# note :text default(""), not null
|
# note :text default(""), not null
|
||||||
|
@ -27,7 +25,8 @@
|
||||||
# header_file_size :integer
|
# header_file_size :integer
|
||||||
# header_updated_at :datetime
|
# header_updated_at :datetime
|
||||||
# avatar_remote_url :string
|
# avatar_remote_url :string
|
||||||
# subscription_expires_at :datetime
|
# silenced :boolean default(FALSE), not null
|
||||||
|
# suspended :boolean default(FALSE), not null
|
||||||
# locked :boolean default(FALSE), not null
|
# locked :boolean default(FALSE), not null
|
||||||
# header_remote_url :string default(""), not null
|
# header_remote_url :string default(""), not null
|
||||||
# last_webfingered_at :datetime
|
# last_webfingered_at :datetime
|
||||||
|
@ -90,7 +89,6 @@ class Account < ApplicationRecord
|
||||||
|
|
||||||
scope :remote, -> { where.not(domain: nil) }
|
scope :remote, -> { where.not(domain: nil) }
|
||||||
scope :local, -> { where(domain: nil) }
|
scope :local, -> { where(domain: nil) }
|
||||||
scope :expiring, ->(time) { remote.where.not(subscription_expires_at: nil).where('subscription_expires_at < ?', time) }
|
|
||||||
scope :partitioned, -> { order(Arel.sql('row_number() over (partition by domain)')) }
|
scope :partitioned, -> { order(Arel.sql('row_number() over (partition by domain)')) }
|
||||||
scope :silenced, -> { where.not(silenced_at: nil) }
|
scope :silenced, -> { where.not(silenced_at: nil) }
|
||||||
scope :suspended, -> { where.not(suspended_at: nil) }
|
scope :suspended, -> { where.not(suspended_at: nil) }
|
||||||
|
@ -171,10 +169,6 @@ class Account < ApplicationRecord
|
||||||
"acct:#{local_username_and_domain}"
|
"acct:#{local_username_and_domain}"
|
||||||
end
|
end
|
||||||
|
|
||||||
def subscribed?
|
|
||||||
subscription_expires_at.present?
|
|
||||||
end
|
|
||||||
|
|
||||||
def possibly_stale?
|
def possibly_stale?
|
||||||
last_webfingered_at.nil? || last_webfingered_at <= 1.day.ago
|
last_webfingered_at.nil? || last_webfingered_at <= 1.day.ago
|
||||||
end
|
end
|
||||||
|
|
|
@ -32,9 +32,6 @@ module AccountAssociations
|
||||||
has_many :media_attachments, dependent: :destroy
|
has_many :media_attachments, dependent: :destroy
|
||||||
has_many :polls, dependent: :destroy
|
has_many :polls, dependent: :destroy
|
||||||
|
|
||||||
# PuSH subscriptions
|
|
||||||
has_many :subscriptions, dependent: :destroy
|
|
||||||
|
|
||||||
# Report relationships
|
# Report relationships
|
||||||
has_many :reports, dependent: :destroy, inverse_of: :account
|
has_many :reports, dependent: :destroy, inverse_of: :account
|
||||||
has_many :targeted_reports, class_name: 'Report', foreign_key: :target_account_id, dependent: :destroy, inverse_of: :target_account
|
has_many :targeted_reports, class_name: 'Report', foreign_key: :target_account_id, dependent: :destroy, inverse_of: :target_account
|
||||||
|
|
|
@ -1,62 +0,0 @@
|
||||||
# frozen_string_literal: true
|
|
||||||
# == Schema Information
|
|
||||||
#
|
|
||||||
# Table name: subscriptions
|
|
||||||
#
|
|
||||||
# id :bigint(8) not null, primary key
|
|
||||||
# callback_url :string default(""), not null
|
|
||||||
# secret :string
|
|
||||||
# expires_at :datetime
|
|
||||||
# confirmed :boolean default(FALSE), not null
|
|
||||||
# created_at :datetime not null
|
|
||||||
# updated_at :datetime not null
|
|
||||||
# last_successful_delivery_at :datetime
|
|
||||||
# domain :string
|
|
||||||
# account_id :bigint(8) not null
|
|
||||||
#
|
|
||||||
|
|
||||||
class Subscription < ApplicationRecord
|
|
||||||
MIN_EXPIRATION = 1.day.to_i
|
|
||||||
MAX_EXPIRATION = 30.days.to_i
|
|
||||||
|
|
||||||
belongs_to :account
|
|
||||||
|
|
||||||
validates :callback_url, presence: true
|
|
||||||
validates :callback_url, uniqueness: { scope: :account_id }
|
|
||||||
|
|
||||||
scope :confirmed, -> { where(confirmed: true) }
|
|
||||||
scope :future_expiration, -> { where(arel_table[:expires_at].gt(Time.now.utc)) }
|
|
||||||
scope :expired, -> { where(arel_table[:expires_at].lt(Time.now.utc)) }
|
|
||||||
scope :active, -> { confirmed.future_expiration }
|
|
||||||
|
|
||||||
def lease_seconds=(value)
|
|
||||||
self.expires_at = future_expiration(value)
|
|
||||||
end
|
|
||||||
|
|
||||||
def lease_seconds
|
|
||||||
(expires_at - Time.now.utc).to_i
|
|
||||||
end
|
|
||||||
|
|
||||||
def expired?
|
|
||||||
Time.now.utc > expires_at
|
|
||||||
end
|
|
||||||
|
|
||||||
before_validation :set_min_expiration
|
|
||||||
|
|
||||||
private
|
|
||||||
|
|
||||||
def future_expiration(value)
|
|
||||||
Time.now.utc + future_offset(value).seconds
|
|
||||||
end
|
|
||||||
|
|
||||||
def future_offset(seconds)
|
|
||||||
[
|
|
||||||
[MIN_EXPIRATION, seconds.to_i].max,
|
|
||||||
MAX_EXPIRATION,
|
|
||||||
].min
|
|
||||||
end
|
|
||||||
|
|
||||||
def set_min_expiration
|
|
||||||
self.lease_seconds = 0 unless expires_at
|
|
||||||
end
|
|
||||||
end
|
|
|
@ -1,7 +0,0 @@
|
||||||
# frozen_string_literal: true
|
|
||||||
|
|
||||||
class SubscriptionPolicy < ApplicationPolicy
|
|
||||||
def index?
|
|
||||||
admin?
|
|
||||||
end
|
|
||||||
end
|
|
|
@ -23,7 +23,6 @@ class SuspendAccountService < BaseService
|
||||||
scheduled_statuses
|
scheduled_statuses
|
||||||
status_pins
|
status_pins
|
||||||
stream_entries
|
stream_entries
|
||||||
subscriptions
|
|
||||||
).freeze
|
).freeze
|
||||||
|
|
||||||
ASSOCIATIONS_ON_DESTROY = %w(
|
ASSOCIATIONS_ON_DESTROY = %w(
|
||||||
|
|
|
@ -1,18 +0,0 @@
|
||||||
%tr
|
|
||||||
%td
|
|
||||||
%samp= subscription.account.acct
|
|
||||||
%td
|
|
||||||
%samp= subscription.callback_url
|
|
||||||
%td
|
|
||||||
- if subscription.confirmed?
|
|
||||||
%i.fa.fa-check
|
|
||||||
%td{ style: "color: #{subscription.expired? ? 'red' : 'inherit'};" }
|
|
||||||
%time.time-ago{ datetime: subscription.expires_at.iso8601, title: l(subscription.expires_at) }
|
|
||||||
= precede subscription.expired? ? '-' : '' do
|
|
||||||
= time_ago_in_words(subscription.expires_at)
|
|
||||||
%td
|
|
||||||
- if subscription.last_successful_delivery_at?
|
|
||||||
%time.formatted{ datetime: subscription.last_successful_delivery_at.iso8601, title: l(subscription.last_successful_delivery_at) }
|
|
||||||
= l subscription.last_successful_delivery_at
|
|
||||||
- else
|
|
||||||
%i.fa.fa-times
|
|
|
@ -1,16 +0,0 @@
|
||||||
- content_for :page_title do
|
|
||||||
= t('admin.subscriptions.title')
|
|
||||||
|
|
||||||
.table-wrapper
|
|
||||||
%table.table
|
|
||||||
%thead
|
|
||||||
%tr
|
|
||||||
%th= t('admin.subscriptions.topic')
|
|
||||||
%th= t('admin.subscriptions.callback_url')
|
|
||||||
%th= t('admin.subscriptions.confirmed')
|
|
||||||
%th= t('admin.subscriptions.expires_in')
|
|
||||||
%th= t('admin.subscriptions.last_delivery')
|
|
||||||
%tbody
|
|
||||||
= render @subscriptions
|
|
||||||
|
|
||||||
= paginate @subscriptions
|
|
|
@ -1,11 +0,0 @@
|
||||||
# frozen_string_literal: true
|
|
||||||
|
|
||||||
class Scheduler::SubscriptionsCleanupScheduler
|
|
||||||
include Sidekiq::Worker
|
|
||||||
|
|
||||||
sidekiq_options unique: :until_executed, retry: 0
|
|
||||||
|
|
||||||
def perform
|
|
||||||
Subscription.expired.in_batches.delete_all
|
|
||||||
end
|
|
||||||
end
|
|
|
@ -51,7 +51,6 @@ SimpleNavigation::Configuration.run do |navigation|
|
||||||
s.item :dashboard, safe_join([fa_icon('tachometer fw'), t('admin.dashboard.title')]), admin_dashboard_url
|
s.item :dashboard, safe_join([fa_icon('tachometer fw'), t('admin.dashboard.title')]), admin_dashboard_url
|
||||||
s.item :settings, safe_join([fa_icon('cogs fw'), t('admin.settings.title')]), edit_admin_settings_url, if: -> { current_user.admin? }, highlights_on: %r{/admin/settings}
|
s.item :settings, safe_join([fa_icon('cogs fw'), t('admin.settings.title')]), edit_admin_settings_url, if: -> { current_user.admin? }, highlights_on: %r{/admin/settings}
|
||||||
s.item :relays, safe_join([fa_icon('exchange fw'), t('admin.relays.title')]), admin_relays_url, if: -> { current_user.admin? }, highlights_on: %r{/admin/relays}
|
s.item :relays, safe_join([fa_icon('exchange fw'), t('admin.relays.title')]), admin_relays_url, if: -> { current_user.admin? }, highlights_on: %r{/admin/relays}
|
||||||
s.item :subscriptions, safe_join([fa_icon('paper-plane-o fw'), t('admin.subscriptions.title')]), admin_subscriptions_url, if: -> { current_user.admin? }
|
|
||||||
s.item :sidekiq, safe_join([fa_icon('diamond fw'), 'Sidekiq']), sidekiq_url, link_html: { target: 'sidekiq' }, if: -> { current_user.admin? }
|
s.item :sidekiq, safe_join([fa_icon('diamond fw'), 'Sidekiq']), sidekiq_url, link_html: { target: 'sidekiq' }, if: -> { current_user.admin? }
|
||||||
s.item :pghero, safe_join([fa_icon('database fw'), 'PgHero']), pghero_url, link_html: { target: 'pghero' }, if: -> { current_user.admin? }
|
s.item :pghero, safe_join([fa_icon('database fw'), 'PgHero']), pghero_url, link_html: { target: 'pghero' }, if: -> { current_user.admin? }
|
||||||
end
|
end
|
||||||
|
|
|
@ -0,0 +1,9 @@
|
||||||
|
class DropOStatus < ActiveRecord::Migration[5.2]
|
||||||
|
def change
|
||||||
|
safety_assured {
|
||||||
|
remove_column :accounts, :salmon_url
|
||||||
|
remove_column :accounts, :hub_url
|
||||||
|
remove_column :accounts, :subscription_expires_at
|
||||||
|
}
|
||||||
|
end
|
||||||
|
end
|
|
@ -0,0 +1,7 @@
|
||||||
|
class DropSubscriptions < ActiveRecord::Migration[5.2]
|
||||||
|
def change
|
||||||
|
safety_assured {
|
||||||
|
drop_table :subscriptions
|
||||||
|
}
|
||||||
|
end
|
||||||
|
end
|
19
db/schema.rb
19
db/schema.rb
|
@ -113,8 +113,6 @@ ActiveRecord::Schema.define(version: 2019_05_19_130537) do
|
||||||
t.text "private_key"
|
t.text "private_key"
|
||||||
t.text "public_key", default: "", null: false
|
t.text "public_key", default: "", null: false
|
||||||
t.string "remote_url", default: "", null: false
|
t.string "remote_url", default: "", null: false
|
||||||
t.string "salmon_url", default: "", null: false
|
|
||||||
t.string "hub_url", default: "", null: false
|
|
||||||
t.datetime "created_at", null: false
|
t.datetime "created_at", null: false
|
||||||
t.datetime "updated_at", null: false
|
t.datetime "updated_at", null: false
|
||||||
t.text "note", default: "", null: false
|
t.text "note", default: "", null: false
|
||||||
|
@ -130,7 +128,8 @@ ActiveRecord::Schema.define(version: 2019_05_19_130537) do
|
||||||
t.integer "header_file_size"
|
t.integer "header_file_size"
|
||||||
t.datetime "header_updated_at"
|
t.datetime "header_updated_at"
|
||||||
t.string "avatar_remote_url"
|
t.string "avatar_remote_url"
|
||||||
t.datetime "subscription_expires_at"
|
t.boolean "silenced", default: false, null: false
|
||||||
|
t.boolean "suspended", default: false, null: false
|
||||||
t.boolean "locked", default: false, null: false
|
t.boolean "locked", default: false, null: false
|
||||||
t.string "header_remote_url", default: "", null: false
|
t.string "header_remote_url", default: "", null: false
|
||||||
t.datetime "last_webfingered_at"
|
t.datetime "last_webfingered_at"
|
||||||
|
@ -675,19 +674,6 @@ ActiveRecord::Schema.define(version: 2019_05_19_130537) do
|
||||||
t.index ["activity_id", "activity_type"], name: "index_stream_entries_on_activity_id_and_activity_type"
|
t.index ["activity_id", "activity_type"], name: "index_stream_entries_on_activity_id_and_activity_type"
|
||||||
end
|
end
|
||||||
|
|
||||||
create_table "subscriptions", force: :cascade do |t|
|
|
||||||
t.string "callback_url", default: "", null: false
|
|
||||||
t.string "secret"
|
|
||||||
t.datetime "expires_at"
|
|
||||||
t.boolean "confirmed", default: false, null: false
|
|
||||||
t.datetime "created_at", null: false
|
|
||||||
t.datetime "updated_at", null: false
|
|
||||||
t.datetime "last_successful_delivery_at"
|
|
||||||
t.string "domain"
|
|
||||||
t.bigint "account_id", null: false
|
|
||||||
t.index ["account_id", "callback_url"], name: "index_subscriptions_on_account_id_and_callback_url", unique: true
|
|
||||||
end
|
|
||||||
|
|
||||||
create_table "tags", force: :cascade do |t|
|
create_table "tags", force: :cascade do |t|
|
||||||
t.string "name", default: "", null: false
|
t.string "name", default: "", null: false
|
||||||
t.datetime "created_at", null: false
|
t.datetime "created_at", null: false
|
||||||
|
@ -853,7 +839,6 @@ ActiveRecord::Schema.define(version: 2019_05_19_130537) do
|
||||||
add_foreign_key "statuses_tags", "statuses", on_delete: :cascade
|
add_foreign_key "statuses_tags", "statuses", on_delete: :cascade
|
||||||
add_foreign_key "statuses_tags", "tags", name: "fk_3081861e21", on_delete: :cascade
|
add_foreign_key "statuses_tags", "tags", name: "fk_3081861e21", on_delete: :cascade
|
||||||
add_foreign_key "stream_entries", "accounts", name: "fk_5659b17554", on_delete: :cascade
|
add_foreign_key "stream_entries", "accounts", name: "fk_5659b17554", on_delete: :cascade
|
||||||
add_foreign_key "subscriptions", "accounts", name: "fk_9847d1cbb5", on_delete: :cascade
|
|
||||||
add_foreign_key "tombstones", "accounts", on_delete: :cascade
|
add_foreign_key "tombstones", "accounts", on_delete: :cascade
|
||||||
add_foreign_key "user_invite_requests", "users", on_delete: :cascade
|
add_foreign_key "user_invite_requests", "users", on_delete: :cascade
|
||||||
add_foreign_key "users", "accounts", name: "fk_50500f500d", on_delete: :cascade
|
add_foreign_key "users", "accounts", name: "fk_50500f500d", on_delete: :cascade
|
||||||
|
|
|
@ -1,32 +0,0 @@
|
||||||
# frozen_string_literal: true
|
|
||||||
require 'rails_helper'
|
|
||||||
|
|
||||||
RSpec.describe Admin::SubscriptionsController, type: :controller do
|
|
||||||
render_views
|
|
||||||
|
|
||||||
describe 'GET #index' do
|
|
||||||
around do |example|
|
|
||||||
default_per_page = Subscription.default_per_page
|
|
||||||
Subscription.paginates_per 1
|
|
||||||
example.run
|
|
||||||
Subscription.paginates_per default_per_page
|
|
||||||
end
|
|
||||||
|
|
||||||
before do
|
|
||||||
sign_in Fabricate(:user, admin: true), scope: :user
|
|
||||||
end
|
|
||||||
|
|
||||||
it 'renders subscriptions' do
|
|
||||||
Fabricate(:subscription)
|
|
||||||
specified = Fabricate(:subscription)
|
|
||||||
|
|
||||||
get :index
|
|
||||||
|
|
||||||
subscriptions = assigns(:subscriptions)
|
|
||||||
expect(subscriptions.count).to eq 1
|
|
||||||
expect(subscriptions[0]).to eq specified
|
|
||||||
|
|
||||||
expect(response).to have_http_status(200)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
|
@ -134,18 +134,6 @@ RSpec.describe Account, type: :model do
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
describe '#subscribed?' do
|
|
||||||
it 'returns false when no subscription expiration information is present' do
|
|
||||||
account = Fabricate(:account, subscription_expires_at: nil)
|
|
||||||
expect(account.subscribed?).to be false
|
|
||||||
end
|
|
||||||
|
|
||||||
it 'returns true when subscription expiration has been set' do
|
|
||||||
account = Fabricate(:account, subscription_expires_at: 30.days.from_now)
|
|
||||||
expect(account.subscribed?).to be true
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
describe '#possibly_stale?' do
|
describe '#possibly_stale?' do
|
||||||
let(:account) { Fabricate(:account, last_webfingered_at: last_webfingered_at) }
|
let(:account) { Fabricate(:account, last_webfingered_at: last_webfingered_at) }
|
||||||
|
|
||||||
|
@ -680,21 +668,6 @@ RSpec.describe Account, type: :model do
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
describe 'expiring' do
|
|
||||||
it 'returns remote accounts with followers whose subscription expiration date is past or not given' do
|
|
||||||
local = Fabricate(:account, domain: nil)
|
|
||||||
matches = [
|
|
||||||
{ domain: 'remote', subscription_expires_at: '2000-01-01T00:00:00Z' },
|
|
||||||
].map(&method(:Fabricate).curry(2).call(:account))
|
|
||||||
matches.each(&local.method(:follow!))
|
|
||||||
Fabricate(:account, domain: 'remote', subscription_expires_at: nil)
|
|
||||||
local.follow!(Fabricate(:account, domain: 'remote', subscription_expires_at: '2000-01-03T00:00:00Z'))
|
|
||||||
local.follow!(Fabricate(:account, domain: nil, subscription_expires_at: nil))
|
|
||||||
|
|
||||||
expect(Account.expiring('2000-01-02T00:00:00Z').recent).to eq matches.reverse
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
describe 'remote' do
|
describe 'remote' do
|
||||||
it 'returns an array of accounts who have a domain' do
|
it 'returns an array of accounts who have a domain' do
|
||||||
account_1 = Fabricate(:account, domain: nil)
|
account_1 = Fabricate(:account, domain: nil)
|
||||||
|
|
|
@ -1,67 +0,0 @@
|
||||||
require 'rails_helper'
|
|
||||||
|
|
||||||
RSpec.describe Subscription, type: :model do
|
|
||||||
let(:alice) { Fabricate(:account, username: 'alice') }
|
|
||||||
|
|
||||||
subject { Fabricate(:subscription, account: alice) }
|
|
||||||
|
|
||||||
describe '#expired?' do
|
|
||||||
it 'return true when expires_at is past' do
|
|
||||||
subject.expires_at = 2.days.ago
|
|
||||||
expect(subject.expired?).to be true
|
|
||||||
end
|
|
||||||
|
|
||||||
it 'return false when expires_at is future' do
|
|
||||||
subject.expires_at = 2.days.from_now
|
|
||||||
expect(subject.expired?).to be false
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
describe 'lease_seconds' do
|
|
||||||
it 'returns the time remaining until expiration' do
|
|
||||||
datetime = 1.day.from_now
|
|
||||||
subscription = Subscription.new(expires_at: datetime)
|
|
||||||
travel_to(datetime - 12.hours) do
|
|
||||||
expect(subscription.lease_seconds).to eq(12.hours)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
describe 'lease_seconds=' do
|
|
||||||
it 'sets expires_at to min expiration when small value is provided' do
|
|
||||||
subscription = Subscription.new
|
|
||||||
datetime = 1.day.from_now
|
|
||||||
too_low = Subscription::MIN_EXPIRATION - 1000
|
|
||||||
travel_to(datetime) do
|
|
||||||
subscription.lease_seconds = too_low
|
|
||||||
end
|
|
||||||
|
|
||||||
expected = datetime + Subscription::MIN_EXPIRATION.seconds
|
|
||||||
expect(subscription.expires_at).to be_within(1.0).of(expected)
|
|
||||||
end
|
|
||||||
|
|
||||||
it 'sets expires_at to value when valid value is provided' do
|
|
||||||
subscription = Subscription.new
|
|
||||||
datetime = 1.day.from_now
|
|
||||||
valid = Subscription::MIN_EXPIRATION + 1000
|
|
||||||
travel_to(datetime) do
|
|
||||||
subscription.lease_seconds = valid
|
|
||||||
end
|
|
||||||
|
|
||||||
expected = datetime + valid.seconds
|
|
||||||
expect(subscription.expires_at).to be_within(1.0).of(expected)
|
|
||||||
end
|
|
||||||
|
|
||||||
it 'sets expires_at to max expiration when large value is provided' do
|
|
||||||
subscription = Subscription.new
|
|
||||||
datetime = 1.day.from_now
|
|
||||||
too_high = Subscription::MAX_EXPIRATION + 1000
|
|
||||||
travel_to(datetime) do
|
|
||||||
subscription.lease_seconds = too_high
|
|
||||||
end
|
|
||||||
|
|
||||||
expected = datetime + Subscription::MAX_EXPIRATION.seconds
|
|
||||||
expect(subscription.expires_at).to be_within(1.0).of(expected)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
|
@ -1,24 +0,0 @@
|
||||||
# frozen_string_literal: true
|
|
||||||
|
|
||||||
require 'rails_helper'
|
|
||||||
require 'pundit/rspec'
|
|
||||||
|
|
||||||
RSpec.describe SubscriptionPolicy do
|
|
||||||
let(:subject) { described_class }
|
|
||||||
let(:admin) { Fabricate(:user, admin: true).account }
|
|
||||||
let(:john) { Fabricate(:user).account }
|
|
||||||
|
|
||||||
permissions :index? do
|
|
||||||
context 'admin?' do
|
|
||||||
it 'permits' do
|
|
||||||
expect(subject).to permit(admin, Subscription)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
context '!admin?' do
|
|
||||||
it 'denies' do
|
|
||||||
expect(subject).to_not permit(john, Subscription)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
|
@ -4,7 +4,6 @@ RSpec.describe RemoveStatusService, type: :service do
|
||||||
subject { RemoveStatusService.new }
|
subject { RemoveStatusService.new }
|
||||||
|
|
||||||
let!(:alice) { Fabricate(:account) }
|
let!(:alice) { Fabricate(:account) }
|
||||||
let!(:bob) { Fabricate(:account, username: 'bob', domain: 'example.com', salmon_url: 'http://example.com/salmon') }
|
|
||||||
let!(:jeff) { Fabricate(:account) }
|
let!(:jeff) { Fabricate(:account) }
|
||||||
let!(:hank) { Fabricate(:account, username: 'hank', domain: 'example.com', inbox_url: 'http://example.com/inbox') }
|
let!(:hank) { Fabricate(:account, username: 'hank', domain: 'example.com', inbox_url: 'http://example.com/inbox') }
|
||||||
let!(:bill) { Fabricate(:account, username: 'bill', domain: 'example2.com', inbox_url: 'http://example2.com/inbox') }
|
let!(:bill) { Fabricate(:account, username: 'bill', domain: 'example2.com', inbox_url: 'http://example2.com/inbox') }
|
||||||
|
@ -16,7 +15,7 @@ RSpec.describe RemoveStatusService, type: :service do
|
||||||
jeff.follow!(alice)
|
jeff.follow!(alice)
|
||||||
hank.follow!(alice)
|
hank.follow!(alice)
|
||||||
|
|
||||||
@status = PostStatusService.new.call(alice, text: 'Hello @bob@example.com')
|
@status = PostStatusService.new.call(alice, text: 'Hello!')
|
||||||
Fabricate(:status, account: bill, reblog: @status, uri: 'hoge')
|
Fabricate(:status, account: bill, reblog: @status, uri: 'hoge')
|
||||||
subject.call(@status)
|
subject.call(@status)
|
||||||
end
|
end
|
||||||
|
|
|
@ -18,7 +18,6 @@ RSpec.describe SuspendAccountService, type: :service do
|
||||||
let!(:favourite) { Fabricate(:favourite, account: account) }
|
let!(:favourite) { Fabricate(:favourite, account: account) }
|
||||||
let!(:active_relationship) { Fabricate(:follow, account: account) }
|
let!(:active_relationship) { Fabricate(:follow, account: account) }
|
||||||
let!(:passive_relationship) { Fabricate(:follow, target_account: account) }
|
let!(:passive_relationship) { Fabricate(:follow, target_account: account) }
|
||||||
let!(:subscription) { Fabricate(:subscription, account: account) }
|
|
||||||
let!(:remote_alice) { Fabricate(:account, inbox_url: 'https://alice.com/inbox') }
|
let!(:remote_alice) { Fabricate(:account, inbox_url: 'https://alice.com/inbox') }
|
||||||
let!(:remote_bob) { Fabricate(:account, inbox_url: 'https://bob.com/inbox') }
|
let!(:remote_bob) { Fabricate(:account, inbox_url: 'https://bob.com/inbox') }
|
||||||
|
|
||||||
|
@ -32,9 +31,8 @@ RSpec.describe SuspendAccountService, type: :service do
|
||||||
account.favourites,
|
account.favourites,
|
||||||
account.active_relationships,
|
account.active_relationships,
|
||||||
account.passive_relationships,
|
account.passive_relationships,
|
||||||
account.subscriptions
|
|
||||||
].map(&:count)
|
].map(&:count)
|
||||||
}.from([1, 1, 1, 1, 1, 1, 1, 1]).to([0, 0, 0, 0, 0, 0, 0, 0])
|
}.from([1, 1, 1, 1, 1, 1, 1]).to([0, 0, 0, 0, 0, 0, 0])
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'sends a delete actor activity to all known inboxes' do
|
it 'sends a delete actor activity to all known inboxes' do
|
||||||
|
@ -63,7 +61,6 @@ RSpec.describe SuspendAccountService, type: :service do
|
||||||
let!(:favourite) { Fabricate(:favourite, account: remote_bob) }
|
let!(:favourite) { Fabricate(:favourite, account: remote_bob) }
|
||||||
let!(:active_relationship) { Fabricate(:follow, account: remote_bob, target_account: account) }
|
let!(:active_relationship) { Fabricate(:follow, account: remote_bob, target_account: account) }
|
||||||
let!(:passive_relationship) { Fabricate(:follow, target_account: remote_bob) }
|
let!(:passive_relationship) { Fabricate(:follow, target_account: remote_bob) }
|
||||||
let!(:subscription) { Fabricate(:subscription, account: remote_bob) }
|
|
||||||
|
|
||||||
it 'deletes associated records' do
|
it 'deletes associated records' do
|
||||||
is_expected.to change {
|
is_expected.to change {
|
||||||
|
@ -75,9 +72,8 @@ RSpec.describe SuspendAccountService, type: :service do
|
||||||
remote_bob.favourites,
|
remote_bob.favourites,
|
||||||
remote_bob.active_relationships,
|
remote_bob.active_relationships,
|
||||||
remote_bob.passive_relationships,
|
remote_bob.passive_relationships,
|
||||||
remote_bob.subscriptions
|
|
||||||
].map(&:count)
|
].map(&:count)
|
||||||
}.from([1, 1, 0, 1, 1, 1, 1, 1]).to([0, 0, 0, 0, 0, 0, 0, 0])
|
}.from([1, 1, 0, 1, 1, 1, 1]).to([0, 0, 0, 0, 0, 0, 0])
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'sends a reject follow to follwer inboxes' do
|
it 'sends a reject follow to follwer inboxes' do
|
||||||
|
|
Loading…
Reference in New Issue