From b1516507f8cb228ac637281b396daf01c569e7bd Mon Sep 17 00:00:00 2001 From: Bob Mottram Date: Wed, 8 Jul 2020 11:30:29 +0100 Subject: [PATCH] Allow for accumulating domains --- epicyon.py | 3 ++- posts.py | 17 +++++++++-------- 2 files changed, 11 insertions(+), 9 deletions(-) diff --git a/epicyon.py b/epicyon.py index 74f02cf3..ef4d539b 100644 --- a/epicyon.py +++ b/epicyon.py @@ -448,9 +448,10 @@ if args.postDomains: args.port = 80 elif args.gnunet: proxyType = 'gnunet' + domainList = [] domainList = getPublicPostDomains(baseDir, nickname, domain, False, True, proxyType, args.port, httpPrefix, debug, - __version__) + __version__, domainList) for postDomain in domainList: print(postDomain) sys.exit() diff --git a/posts.py b/posts.py index 3754cd82..1ed3541b 100644 --- a/posts.py +++ b/posts.py @@ -447,7 +447,7 @@ def getPostDomains(session, outboxUrl: str, maxPosts: int, personCache: {}, raw: bool, simple: bool, debug: bool, projectVersion: str, httpPrefix: str, - domain: str) -> []: + domain: str, domainList=[]) -> []: """Returns a list of domains referenced within public posts """ if not outboxUrl: @@ -461,7 +461,7 @@ def getPostDomains(session, outboxUrl: str, maxPosts: int, 'Accept': 'application/ld+json; profile="' + profileStr + '"' } - postDomains = [] + postDomains = domainList i = 0 userFeed = parseUserFeed(session, outboxUrl, asHeader, @@ -2988,12 +2988,13 @@ def getPublicPostsOfPerson(baseDir: str, nickname: str, domain: str, def getPublicPostDomains(baseDir: str, nickname: str, domain: str, raw: bool, simple: bool, proxyType: str, port: int, httpPrefix: str, - debug: bool, projectVersion: str) -> []: + debug: bool, projectVersion: str, + domainList=[]) -> []: """ Returns a list of domains referenced within public posts """ session = createSession(proxyType) if not session: - return + return domainList personCache = {} cachedWebfingers = {} federationList = [] @@ -3008,11 +3009,11 @@ def getPublicPostDomains(baseDir: str, nickname: str, domain: str, webfingerHandle(session, handle, httpPrefix, cachedWebfingers, domain, projectVersion) if not wfRequest: - return [] + return domainList if not isinstance(wfRequest, dict): print('Webfinger for ' + handle + ' did not return a dict. ' + str(wfRequest)) - return [] + return domainList (personUrl, pubKeyId, pubKey, personId, shaedInbox, @@ -3025,10 +3026,10 @@ def getPublicPostDomains(baseDir: str, nickname: str, domain: str, maxEmoji = 99 maxAttachments = 5 postDomains = \ - getPostDomains(session, personUrl, 60, maxMentions, maxEmoji, + getPostDomains(session, personUrl, 64, maxMentions, maxEmoji, maxAttachments, federationList, personCache, raw, simple, debug, - projectVersion, httpPrefix, domain) + projectVersion, httpPrefix, domain, domainList) postDomains.sort() return postDomains