2020-11-10 10:25:21 +00:00
|
|
|
__filename__ = "webapp_moderation.py"
|
|
|
|
__author__ = "Bob Mottram"
|
|
|
|
__license__ = "AGPL3+"
|
|
|
|
__version__ = "1.1.0"
|
|
|
|
__maintainer__ = "Bob Mottram"
|
|
|
|
__email__ = "bob@freedombone.net"
|
|
|
|
__status__ = "Production"
|
|
|
|
|
|
|
|
import os
|
2020-12-09 22:55:15 +00:00
|
|
|
from utils import getNicknameFromActor
|
|
|
|
from utils import getDomainFromActor
|
|
|
|
from posts import getPublicPostDomains
|
2020-11-10 10:25:21 +00:00
|
|
|
from webapp_timeline import htmlTimeline
|
2020-11-12 17:05:38 +00:00
|
|
|
from webapp_utils import htmlHeaderWithExternalStyle
|
2020-11-10 10:25:21 +00:00
|
|
|
from webapp_utils import htmlFooter
|
2020-12-09 22:55:15 +00:00
|
|
|
from blocking import isBlockedDomain
|
2020-11-10 10:25:21 +00:00
|
|
|
|
|
|
|
|
|
|
|
def htmlModeration(cssCache: {}, defaultTimeline: str,
|
|
|
|
recentPostsCache: {}, maxRecentPosts: int,
|
|
|
|
translate: {}, pageNumber: int, itemsPerPage: int,
|
|
|
|
session, baseDir: str, wfRequest: {}, personCache: {},
|
|
|
|
nickname: str, domain: str, port: int, inboxJson: {},
|
|
|
|
allowDeletion: bool,
|
|
|
|
httpPrefix: str, projectVersion: str,
|
|
|
|
YTReplacementDomain: str,
|
|
|
|
showPublishedDateOnly: bool,
|
|
|
|
newswire: {}, positiveVoting: bool,
|
|
|
|
showPublishAsIcon: bool,
|
|
|
|
fullWidthTimelineButtonHeader: bool,
|
|
|
|
iconsAsButtons: bool,
|
|
|
|
rssIconAtTop: bool,
|
|
|
|
publishButtonAtTop: bool,
|
2020-12-09 23:30:15 +00:00
|
|
|
authorized: bool, moderationActionStr: str) -> str:
|
2020-11-10 10:25:21 +00:00
|
|
|
"""Show the moderation feed as html
|
|
|
|
This is what you see when selecting the "mod" timeline
|
|
|
|
"""
|
|
|
|
return htmlTimeline(cssCache, defaultTimeline,
|
|
|
|
recentPostsCache, maxRecentPosts,
|
|
|
|
translate, pageNumber,
|
|
|
|
itemsPerPage, session, baseDir, wfRequest, personCache,
|
|
|
|
nickname, domain, port, inboxJson, 'moderation',
|
|
|
|
allowDeletion, httpPrefix, projectVersion, True, False,
|
|
|
|
YTReplacementDomain, showPublishedDateOnly,
|
|
|
|
newswire, False, False, positiveVoting,
|
|
|
|
showPublishAsIcon, fullWidthTimelineButtonHeader,
|
|
|
|
iconsAsButtons, rssIconAtTop, publishButtonAtTop,
|
2020-12-09 23:30:15 +00:00
|
|
|
authorized, moderationActionStr)
|
2020-11-10 10:25:21 +00:00
|
|
|
|
|
|
|
|
2020-12-09 22:55:15 +00:00
|
|
|
def htmlAccountInfo(cssCache: {}, translate: {},
|
|
|
|
baseDir: str, httpPrefix: str,
|
|
|
|
nickname: str, domain: str, port: int,
|
|
|
|
searchHandle: str, debug: bool) -> str:
|
|
|
|
"""Shows which domains a search handle interacts with.
|
|
|
|
This screen is shown if a moderator enters a handle and selects info
|
|
|
|
on the moderation screen
|
|
|
|
"""
|
|
|
|
msgStr1 = 'This account interacts with the following instances'
|
|
|
|
|
|
|
|
infoForm = ''
|
|
|
|
cssFilename = baseDir + '/epicyon-profile.css'
|
|
|
|
if os.path.isfile(baseDir + '/epicyon.css'):
|
|
|
|
cssFilename = baseDir + '/epicyon.css'
|
|
|
|
|
|
|
|
infoForm = htmlHeaderWithExternalStyle(cssFilename)
|
|
|
|
|
|
|
|
searchNickname = getNicknameFromActor(searchHandle)
|
|
|
|
searchDomain, searchPort = getDomainFromActor(searchHandle)
|
|
|
|
|
|
|
|
infoForm += \
|
2020-12-09 23:44:41 +00:00
|
|
|
'<center><h1><a href="/users/' + nickname + '/moderation' + \
|
|
|
|
'?modaction=' + searchHandle + '">' + \
|
2020-12-09 22:55:15 +00:00
|
|
|
translate['Account Information'] + \
|
|
|
|
': ' + searchNickname + '@' + searchDomain + \
|
|
|
|
'</a></h1><br><br>'
|
|
|
|
|
|
|
|
infoForm += translate[msgStr1] + '</center><br><br>'
|
|
|
|
|
|
|
|
proxyType = 'tor'
|
|
|
|
domainList = []
|
|
|
|
domainList = getPublicPostDomains(None,
|
|
|
|
baseDir, searchNickname, searchDomain,
|
|
|
|
proxyType, searchPort,
|
|
|
|
httpPrefix, debug,
|
|
|
|
__version__, domainList)
|
|
|
|
infoForm += '<div class="accountInfoDomains">'
|
|
|
|
usersPath = '/users/' + nickname + '/accountinfo'
|
|
|
|
for postDomain in domainList:
|
|
|
|
infoForm += '<a href="' + \
|
|
|
|
httpPrefix + '://' + postDomain + '">' + postDomain + '</a> '
|
2020-12-09 23:08:00 +00:00
|
|
|
if isBlockedDomain(baseDir, postDomain):
|
2020-12-09 22:55:15 +00:00
|
|
|
infoForm += \
|
|
|
|
'<a href="' + usersPath + '?unblockdomain=' + postDomain + '">'
|
|
|
|
infoForm += '<button class="buttonhighlighted"><span>' + \
|
|
|
|
translate['Unblock'] + '</span></button></a>'
|
|
|
|
else:
|
|
|
|
infoForm += \
|
|
|
|
'<a href="' + usersPath + '?blockdomain=' + postDomain + '">'
|
|
|
|
infoForm += '<button class="button"><span>' + \
|
|
|
|
translate['Block'] + '</span></button></a>'
|
|
|
|
infoForm += '<br>'
|
|
|
|
|
|
|
|
infoForm += '</div>'
|
|
|
|
infoForm += htmlFooter()
|
|
|
|
return infoForm
|
|
|
|
|
|
|
|
|
2020-11-10 10:25:21 +00:00
|
|
|
def htmlModerationInfo(cssCache: {}, translate: {},
|
2020-12-09 19:17:42 +00:00
|
|
|
baseDir: str, httpPrefix: str,
|
|
|
|
nickname: str) -> str:
|
2020-11-10 10:25:21 +00:00
|
|
|
msgStr1 = \
|
|
|
|
'These are globally blocked for all accounts on this instance'
|
|
|
|
msgStr2 = \
|
|
|
|
'Any blocks or suspensions made by moderators will be shown here.'
|
2020-12-09 22:55:15 +00:00
|
|
|
|
2020-11-10 10:25:21 +00:00
|
|
|
infoForm = ''
|
|
|
|
cssFilename = baseDir + '/epicyon-profile.css'
|
|
|
|
if os.path.isfile(baseDir + '/epicyon.css'):
|
|
|
|
cssFilename = baseDir + '/epicyon.css'
|
|
|
|
|
2020-11-12 17:05:38 +00:00
|
|
|
infoForm = htmlHeaderWithExternalStyle(cssFilename)
|
2020-11-10 10:25:21 +00:00
|
|
|
|
2020-11-12 17:05:38 +00:00
|
|
|
infoForm += \
|
2020-12-09 19:17:42 +00:00
|
|
|
'<center><h1><a href="/users/' + nickname + '/moderation">' + \
|
2020-11-12 17:05:38 +00:00
|
|
|
translate['Moderation Information'] + \
|
2020-12-09 22:55:15 +00:00
|
|
|
'</a></h1></center><br>'
|
2020-11-10 10:25:21 +00:00
|
|
|
|
2020-11-12 17:05:38 +00:00
|
|
|
infoShown = False
|
|
|
|
suspendedFilename = baseDir + '/accounts/suspended.txt'
|
|
|
|
if os.path.isfile(suspendedFilename):
|
|
|
|
with open(suspendedFilename, "r") as f:
|
|
|
|
suspendedStr = f.read()
|
|
|
|
infoForm += '<div class="container">'
|
|
|
|
infoForm += ' <br><b>' + \
|
|
|
|
translate['Suspended accounts'] + '</b>'
|
|
|
|
infoForm += ' <br>' + \
|
|
|
|
translate['These are currently suspended']
|
|
|
|
infoForm += \
|
|
|
|
' <textarea id="message" ' + \
|
|
|
|
'name="suspended" style="height:200px">' + \
|
|
|
|
suspendedStr + '</textarea>'
|
|
|
|
infoForm += '</div>'
|
|
|
|
infoShown = True
|
2020-11-10 10:25:21 +00:00
|
|
|
|
2020-11-12 17:05:38 +00:00
|
|
|
blockingFilename = baseDir + '/accounts/blocking.txt'
|
|
|
|
if os.path.isfile(blockingFilename):
|
|
|
|
with open(blockingFilename, "r") as f:
|
|
|
|
blockedStr = f.read()
|
|
|
|
infoForm += '<div class="container">'
|
|
|
|
infoForm += \
|
|
|
|
' <br><b>' + \
|
|
|
|
translate['Blocked accounts and hashtags'] + '</b>'
|
2020-11-10 10:25:21 +00:00
|
|
|
infoForm += \
|
2020-11-12 17:05:38 +00:00
|
|
|
' <br>' + \
|
|
|
|
translate[msgStr1]
|
|
|
|
infoForm += \
|
|
|
|
' <textarea id="message" ' + \
|
|
|
|
'name="blocked" style="height:700px">' + \
|
|
|
|
blockedStr + '</textarea>'
|
|
|
|
infoForm += '</div>'
|
|
|
|
infoShown = True
|
|
|
|
if not infoShown:
|
|
|
|
infoForm += \
|
|
|
|
'<center><p>' + \
|
|
|
|
translate[msgStr2] + \
|
|
|
|
'</p></center>'
|
|
|
|
infoForm += htmlFooter()
|
2020-11-10 10:25:21 +00:00
|
|
|
return infoForm
|