WHOIS should have nick, user/host/real are required, handle NOSUCHUSER

This commit is contained in:
jesopo 2020-06-07 17:46:38 +01:00
parent aea7cf792a
commit 06afec2738
2 changed files with 17 additions and 9 deletions

View file

@ -439,7 +439,7 @@ class Server(IServer):
return None
return MaybeAwait(_assure)
def send_whois(self, target: str) -> Awaitable[Whois]:
def send_whois(self, target: str) -> Awaitable[Optional[Whois]]:
folded = self.casefold(target)
fut = self.send(build("WHOIS", [target, target]))
@ -449,6 +449,7 @@ class Server(IServer):
obj = Whois()
while True:
line = await self.wait_for(Responses([
ERR_NOSUCHUSER,
RPL_WHOISUSER,
RPL_WHOISSERVER,
RPL_WHOISOPERATOR,
@ -459,9 +460,14 @@ class Server(IServer):
RPL_WHOISSECURE,
RPL_ENDOFWHOIS
], params))
if line.command == RPL_WHOISUSER:
obj.username, obj.hostname, _, obj.realname = line.params[2:]
if line.command == ERR_NOSUCHUSER:
return None
elif line.command == RPL_WHOISUSER:
nick, user, host, _, real = line.params[1:]
obj.nickname = nick
obj.username = user
obj.hostname = host
obj.realname = real
elif line.command == RPL_WHOISIDLE:
obj.idle, signon, _ = line.params[2:]
obj.signon = int(signon)

View file

@ -11,9 +11,11 @@ class Whois(object):
signon: Optional[int] = None
idle: Optional[int] = None
username: Optional[str] = None
hostname: Optional[str] = None
realname: Optional[str] = None
account: Optional[str] = None
channels: Optional[List[str]] = None
nickname: str = ""
username: str = ""
hostname: str = ""
realname: str = ""
account: Optional[str] = None