add owner column, apply censor

This commit is contained in:
Victor Shyba 2020-11-05 18:16:21 -03:00 committed by Lex Berezhny
parent 6bb8a69efc
commit f83289f876
5 changed files with 22 additions and 18 deletions

View file

@ -287,11 +287,13 @@ def update_channel_stats(blocks: Tuple[int, int], initial_sync: int, p: Progress
def update_claim_filters(blocking_channel_hashes, filtering_channel_hashes, p: ProgressContext): def update_claim_filters(blocking_channel_hashes, filtering_channel_hashes, p: ProgressContext):
def select_reposts(channel_hashes, filter_type=0): def select_reposts(channel_hashes, filter_type=0):
return select( return select(
Claim.c.reposted_claim_hash, filter_type).where( Claim.c.reposted_claim_hash, filter_type, Claim.c.channel_hash).where(
(Claim.c.channel_hash.in_(filtering_channel_hashes)) & (Claim.c.reposted_claim_hash.isnot(None))) (Claim.c.channel_hash.in_(filtering_channel_hashes)) & (Claim.c.reposted_claim_hash.isnot(None)))
p.ctx.execute(ClaimFilter.delete()) p.ctx.execute(ClaimFilter.delete())
# order matters: first we insert the blocked ones. Then the filtered ones.
# If there is already a block in place, that takes priority because a block is just a harder filter
p.ctx.execute(ClaimFilter.insert().from_select( p.ctx.execute(ClaimFilter.insert().from_select(
['claim_hash', 'filter_type'], select_reposts(blocking_channel_hashes, 1))) ['claim_hash', 'filter_type', 'owner_channel_hash'], select_reposts(blocking_channel_hashes, 2)))
p.ctx.execute(p.ctx.insert_or_ignore(ClaimFilter).from_select( p.ctx.execute(p.ctx.insert_or_ignore(ClaimFilter).from_select(
['claim_hash', 'filter_type'], select_reposts(filtering_channel_hashes, 0))) ['claim_hash', 'filter_type', 'owner_channel_hash'], select_reposts(filtering_channel_hashes, 1)))

View file

@ -14,7 +14,7 @@ from lbry.blockchain.transaction import Output
from ..utils import query from ..utils import query
from ..query_context import context from ..query_context import context
from ..tables import TX, TXO, Claim, Support, Trending from ..tables import TX, TXO, Claim, Support, Trending, ClaimFilter
from ..constants import ( from ..constants import (
TXO_TYPES, STREAM_TYPES, ATTRIBUTE_ARRAY_MAX_LENGTH, TXO_TYPES, STREAM_TYPES, ATTRIBUTE_ARRAY_MAX_LENGTH,
SEARCH_INTEGER_PARAMS, SEARCH_ORDER_FIELDS SEARCH_INTEGER_PARAMS, SEARCH_ORDER_FIELDS
@ -126,7 +126,9 @@ BASE_SELECT_CLAIM_COLUMNS = BASE_SELECT_TXO_COLUMNS + [
func.coalesce(Trending.c.trending_local, 0).label('trending_local'), func.coalesce(Trending.c.trending_local, 0).label('trending_local'),
func.coalesce(Trending.c.trending_mixed, 0).label('trending_mixed'), func.coalesce(Trending.c.trending_mixed, 0).label('trending_mixed'),
func.coalesce(Trending.c.trending_global, 0).label('trending_global'), func.coalesce(Trending.c.trending_global, 0).label('trending_global'),
func.coalesce(Trending.c.trending_group, 0).label('trending_group') func.coalesce(Trending.c.trending_group, 0).label('trending_group'),
func.coalesce(ClaimFilter.c.filter_type, 0).label('censor_type'),
ClaimFilter.c.owner_channel_hash.label('censor_owner_hash')
] ]
@ -276,6 +278,7 @@ def select_claims(cols: List = None, for_count=False, **constraints) -> Select:
.select_from( .select_from(
Claim.join(TXO).join(TX).join(Trending, Trending.c.claim_hash == Claim.c.claim_hash, isouter=True) Claim.join(TXO).join(TX).join(Trending, Trending.c.claim_hash == Claim.c.claim_hash, isouter=True)
.join(channel_claim, Claim.c.channel_hash == channel_claim.c.claim_hash, isouter=True) .join(channel_claim, Claim.c.channel_hash == channel_claim.c.claim_hash, isouter=True)
.join(ClaimFilter, ClaimFilter.c.claim_hash == Claim.c.claim_hash, isouter=True)
), **constraints ), **constraints
) )
@ -306,6 +309,7 @@ def search_claims(**constraints) -> Tuple[List[Output], Optional[int], Optional[
return [], total, search_censor return [], total, search_censor
rows = ctx.fetchall(select_claims(**constraints)) rows = ctx.fetchall(select_claims(**constraints))
rows = search_censor.apply(rows)
txos = rows_to_txos(rows, include_tx=False) txos = rows_to_txos(rows, include_tx=False)
annotate_with_channels(txos) annotate_with_channels(txos)
return txos, total, search_censor return txos, total, search_censor

View file

@ -338,5 +338,6 @@ Trending = Table(
ClaimFilter = Table( ClaimFilter = Table(
'claim_filter', metadata, 'claim_filter', metadata,
Column('claim_hash', LargeBinary, primary_key=True), Column('claim_hash', LargeBinary, primary_key=True),
Column('owner_channel_hash', LargeBinary),
Column('filter_type', SmallInteger), Column('filter_type', SmallInteger),
) )

View file

@ -32,21 +32,15 @@ class Censor:
self.censored = {} self.censored = {}
self.total = 0 self.total = 0
def apply(self, rows):
return [row for row in rows if not self.censor(row)]
def censor(self, row) -> bool: def censor(self, row) -> bool:
was_censored = False was_censored = row['censor_type'] > 0
for claim_hash, lookup in (
(row['claim_hash'], self.streams),
(row['claim_hash'], self.channels),
(row['channel_hash'], self.channels),
(row['reposted_claim_hash'], self.streams),
(row['reposted_claim_hash'], self.channels)):
censoring_channel_hash = lookup.get(claim_hash)
if censoring_channel_hash:
was_censored = True
self.censored.setdefault(censoring_channel_hash, 0)
self.censored[censoring_channel_hash] += 1
break
if was_censored: if was_censored:
censoring_channel_hash = row['censor_owner_hash']
self.censored.setdefault(censoring_channel_hash, 0)
self.censored[censoring_channel_hash] += 1
self.total += 1 self.total += 1
return was_censored return was_censored

View file

@ -1392,6 +1392,9 @@ class TestClaimtrieSync(SyncingBlockchainTestCase):
await self.create_claim(sign=moderator_chan, name="blocking_bad", repost=bad_content.claim_id) await self.create_claim(sign=moderator_chan, name="blocking_bad", repost=bad_content.claim_id)
self.sync.filtering_channel_hashes.add(moderator_chan.claim_hash) self.sync.filtering_channel_hashes.add(moderator_chan.claim_hash)
await self.generate(1) await self.generate(1)
results = await self.db.search_claims(channel="@some_channel")
self.assertEqual(len(results.rows), 1)
self.assertEqual(results.censor.censored.get(moderator_chan.claim_hash), 1)
@skip @skip