allow filtering on censures
parent
9c9b7ec2ed
commit
e8252f38b2
|
@ -41,6 +41,15 @@ class Models:
|
||||||
'domains': fields.List(fields.String(description="The instance domains as a list.")),
|
'domains': fields.List(fields.String(description="The instance domains as a list.")),
|
||||||
'csv': fields.String(description="The instance domains as a csv."),
|
'csv': fields.String(description="The instance domains as a csv."),
|
||||||
})
|
})
|
||||||
|
self.response_model_instances_censured = api.inherit('CensuredInstanceDetails', self.response_model_instances, {
|
||||||
|
'censure_reasons': fields.List(fields.String(description="The reasons instances have given for censuring this instance")),
|
||||||
|
'censure_count': fields.Integer(description="The amount of censures this instance has received from the reference instances"),
|
||||||
|
})
|
||||||
|
self.response_model_model_Censures_get = api.model('CensuredInstances', {
|
||||||
|
'instances': fields.List(fields.Nested(self.response_model_instances_censured)),
|
||||||
|
'domains': fields.List(fields.String(description="The instance domains as a list.")),
|
||||||
|
'csv': fields.String(description="The instance domains as a csv."),
|
||||||
|
})
|
||||||
self.input_censures_modify = api.model('ModifyCensure', {
|
self.input_censures_modify = api.model('ModifyCensure', {
|
||||||
'reason': fields.String(required=False, description="The reason for this censure. No profanity or hate speech allowed!", example="csam"),
|
'reason': fields.String(required=False, description="The reason for this censure. No profanity or hate speech allowed!", example="csam"),
|
||||||
})
|
})
|
||||||
|
|
|
@ -7,10 +7,12 @@ class CensuresGiven(Resource):
|
||||||
get_parser.add_argument("Client-Agent", default="unknown:0:unknown", type=str, required=False, help="The client name and version.", location="headers")
|
get_parser.add_argument("Client-Agent", default="unknown:0:unknown", type=str, required=False, help="The client name and version.", location="headers")
|
||||||
get_parser.add_argument("csv", required=False, type=bool, help="Set to true to return just the domains as a csv. Mutually exclusive with domains", location="args")
|
get_parser.add_argument("csv", required=False, type=bool, help="Set to true to return just the domains as a csv. Mutually exclusive with domains", location="args")
|
||||||
get_parser.add_argument("domains", required=False, type=bool, help="Set to true to return just the domains as a list. Mutually exclusive with csv", location="args")
|
get_parser.add_argument("domains", required=False, type=bool, help="Set to true to return just the domains as a list. Mutually exclusive with csv", location="args")
|
||||||
|
get_parser.add_argument("min_censures", required=False, default=1, type=int, help="Limit to this amount of censures of more", location="args")
|
||||||
|
get_parser.add_argument("reasons_csv", required=False, type=str, help="Only retrieve censures where their reasons include any of the text in this csv", location="args")
|
||||||
|
|
||||||
@api.expect(get_parser)
|
@api.expect(get_parser)
|
||||||
@cache.cached(timeout=10, query_string=True)
|
@cache.cached(timeout=10, query_string=True)
|
||||||
@api.marshal_with(models.response_model_model_Whitelist_get, code=200, description='Instances', skip_none=True)
|
@api.marshal_with(models.response_model_model_Censures_get, code=200, description='Instances', skip_none=True)
|
||||||
@api.response(404, 'Instance not registered', models.response_model_error)
|
@api.response(404, 'Instance not registered', models.response_model_error)
|
||||||
def get(self, domains_csv):
|
def get(self, domains_csv):
|
||||||
'''Display all censures given out by one or more domains
|
'''Display all censures given out by one or more domains
|
||||||
|
@ -26,8 +28,23 @@ class CensuresGiven(Resource):
|
||||||
for c_instance in database.get_all_censured_instances_by_censuring_id([instance.id for instance in instances]):
|
for c_instance in database.get_all_censured_instances_by_censuring_id([instance.id for instance in instances]):
|
||||||
censures = database.get_all_censure_reasons_for_censured_id(c_instance.id, [instance.id for instance in instances])
|
censures = database.get_all_censure_reasons_for_censured_id(c_instance.id, [instance.id for instance in instances])
|
||||||
c_instance_details = c_instance.get_details()
|
c_instance_details = c_instance.get_details()
|
||||||
if len(censures) > 0:
|
censure_count = len(censures)
|
||||||
c_instance_details["censure_reasons"] = [censure.reason for censure in censures]
|
skip_instance = False
|
||||||
|
if self.args.reasons_csv:
|
||||||
|
reasons_filter = [r.strip().lower() for r in self.args.reasons_csv.split(',')]
|
||||||
|
for r in reasons_filter:
|
||||||
|
reason_filter_counter = 0
|
||||||
|
for censure_reason in censures:
|
||||||
|
if r in censure_reason.reason.lower():
|
||||||
|
reason_filter_counter += 1
|
||||||
|
if reason_filter_counter < self.args.min_censures:
|
||||||
|
skip_instance = True
|
||||||
|
elif censure_count < self.args.min_censures:
|
||||||
|
skip_instance = True
|
||||||
|
if skip_instance:
|
||||||
|
continue
|
||||||
|
c_instance_details["censure_reasons"] = [censure.reason for censure in censures]
|
||||||
|
c_instance_details["censure_count"] = censure_count
|
||||||
instance_details.append(c_instance_details)
|
instance_details.append(c_instance_details)
|
||||||
if self.args.csv:
|
if self.args.csv:
|
||||||
return {"csv": ",".join([instance["domain"] for instance in instance_details])},200
|
return {"csv": ",".join([instance["domain"] for instance in instance_details])},200
|
||||||
|
@ -44,7 +61,7 @@ class Censures(Resource):
|
||||||
|
|
||||||
@api.expect(get_parser)
|
@api.expect(get_parser)
|
||||||
@cache.cached(timeout=10, query_string=True)
|
@cache.cached(timeout=10, query_string=True)
|
||||||
@api.marshal_with(models.response_model_model_Whitelist_get, code=200, description='Instances', skip_none=True)
|
@api.marshal_with(models.response_model_model_Censures_get, code=200, description='Instances', skip_none=True)
|
||||||
@api.response(404, 'Instance not registered', models.response_model_error)
|
@api.response(404, 'Instance not registered', models.response_model_error)
|
||||||
def get(self, domain):
|
def get(self, domain):
|
||||||
'''Display all censures received by a specific domain
|
'''Display all censures received by a specific domain
|
||||||
|
|
|
@ -57,7 +57,7 @@ def generate_client_id():
|
||||||
return secrets.token_urlsafe(16)
|
return secrets.token_urlsafe(16)
|
||||||
|
|
||||||
def sanitize_string(text):
|
def sanitize_string(text):
|
||||||
santxt = bleach.clean(text).lstrip().rstrip()
|
santxt = bleach.clean(text).strip()
|
||||||
return santxt
|
return santxt
|
||||||
|
|
||||||
def hash_api_key(unhashed_api_key):
|
def hash_api_key(unhashed_api_key):
|
||||||
|
|
Loading…
Reference in New Issue