Your IP : 216.73.216.181
��Yf}9�
@s�dZddlZddlZddlZyddlZdZWnek
rZdZYnXddgZGdd�de�Z dZ
d Zd
ZdZ
ee
ZdZGd
d�d�Zer�Gdd�de�Zejd�edkr�ddlZeejd�Zeej��ejejd�ejejd�ej�ej�\ZZxjeded�D]UZ ej!e �\Z"Z#Z$ede �xe#D]Z%ede%�q�Wed�qtWej&�dS)z@A POP3 client class.
Based on the J. Myers POP3 draft, Jan. 96
�NTF�POP3�error_protoc@seZdZdS)rN)�__name__�
__module__�__qualname__�rr�+/opt/alt/python35/lib64/python3.5/poplib.pyrs�ni�s
s
ic@s�eZdZdZdZeejdd�Zdd�Z dd�Z
d d
�Zdd�Zd
d�Z
dd�Zdd�Zdd�Zdd�Zdd�Zdd�Zdd�Zdd�Zdd d!�Zd"d#�Zd$d%�Zd&d'�Zd(d)�Zd*d+�Zd,d-�Zd.d/�Zejd0�Z d1d2�Z!d3d4�Z"dd5d6�Z#d7d8�Z$d9d:�Z%dd;d<�Z&dS)=raPThis class supports both the minimal and optional command sets.
Arguments can be strings or integers (where appropriate)
(e.g.: retr(1) and retr('1') both work equally well.
Minimal Command Set:
USER name user(name)
PASS string pass_(string)
STAT stat()
LIST [msg] list(msg = None)
RETR msg retr(msg)
DELE msg dele(msg)
NOOP noop()
RSET rset()
QUIT quit()
Optional Commands (some servers support these):
RPOP name rpop(name)
APOP name digest apop(name, digest)
TOP msg n top(msg, n)
UIDL [msg] uidl(msg = None)
CAPA capa()
STLS stls()
UTF8 utf8()
Raises one exception: 'error_proto'.
Instantiate with:
POP3(hostname, port=110)
NB: the POP protocol locks the mailbox from user
authorization until QUIT, so be sure to get in, suck
the messages, and quit, each time you access the
mailbox.
POP is a line-based protocol, which means large mail
messages consume lots of python cycles reading them
line-by-line.
If it's available on your mail server, use IMAP4
instead, it doesn't suffer from the two problems
above.
zUTF-8cCs^||_||_d|_|j|�|_|jjd�|_d|_|j�|_ dS)NF�rbr)
�host�port�_tls_established�_create_socket�sock�makefile�file�
_debugging�_getresp�welcome)�selfrr�timeoutrrr�__init__as z
POP3.__init__cCstj|j|jf|�S)N)�socketZcreate_connectionrr)rrrrrrkszPOP3._create_socketcCs:|jdkr"tdt|��|jj|t�dS)N�z*put*)r�print�reprrZsendall�CRLF)r�linerrr�_putlinensz
POP3._putlinecCs?|jrtdt|��t||j�}|j|�dS)Nz*cmd*)rrr�bytes�encodingr)rrrrr�_putcmdus zPOP3._putcmdcCs�|jjtd�}t|�tkr4td��|jdkrVtdt|��|shtd��t|�}|dd�tkr�|dd�|fS|dd�t kr�|dd�|fS|dd �|fS)
Nrz
line too longz*get*z-ERR EOF����r#���r$)
r�readline�_MAXLINE�lenrrrrr�CR)rr�octetsrrr�_getlinesz
POP3._getlinecCsS|j�\}}|jdkr4tdt|��|jd�sOt|��|S)Nrz*resp*�+)r*rrr�
startswithr)r�resp�orrrr�sz
POP3._getrespcCs�|j�}g}d}|j�\}}xb|dkr�|jd�rb|d}|dd�}||}|j|�|j�\}}q-W|||fS)Nr�.s..r)rr*r,�append)rr-�listr)rr.rrr�_getlongresp�s
zPOP3._getlongrespcCs|j|�|j�S)N)r!r)rrrrr� _shortcmd�s
zPOP3._shortcmdcCs|j|�|j�S)N)r!r2)rrrrr�_longcmd�s
z
POP3._longcmdcCs|jS)N)r)rrrr�
getwelcome�szPOP3.getwelcomecCs
||_dS)N)r)r�levelrrr�set_debuglevel�szPOP3.set_debuglevelcCs|jd|�S)zVSend user name, return response
(should indicate password required).
zUSER %s)r3)r�userrrrr8�sz POP3.usercCs|jd|�S)z�Send password, return response
(response includes message count, mailbox size).
NB: mailbox is locked by server from here to 'quit()'
zPASS %s)r3)rZpswdrrr�pass_�sz
POP3.pass_cCsa|jd�}|j�}|jr7tdt|��t|d�}t|d�}||fS)z]Get mailbox status.
Result is tuple of 2 ints (message count, mailbox size)
ZSTATz*stat*rr")r3�splitrrr�int)rZretvalZretsZnumMessagesZsizeMessagesrrr�stat�s z POP3.statNcCs*|dk r|jd|�S|jd�S)aRequest listing, return result.
Result without a message number argument is in form
['response', ['mesg_num octets', ...], octets].
Result when a message number argument is given is a
single response: the "scan listing" for that message.
NzLIST %sZLIST)r3r4)r�whichrrrr1�s z POP3.listcCs|jd|�S)zoRetrieve whole message number 'which'.
Result is in form ['response', ['line', ...], octets].
zRETR %s)r4)rr=rrr�retr�sz POP3.retrcCs|jd|�S)zFDelete message number 'which'.
Result is 'response'.
zDELE %s)r3)rr=rrr�dele�sz POP3.delecCs
|jd�S)zXDoes nothing.
One supposes the response indicates the server is alive.
ZNOOP)r3)rrrr�noopsz POP3.noopcCs
|jd�S)z(Unmark all messages marked for deletion.ZRSET)r3)rrrr�rsetsz POP3.rsetcCs|jd�}|j�|S)zDSignoff: commit changes on server, unlock mailbox, close connection.ZQUIT)r3�close)rr-rrr�quits
z POP3.quitcCs�z,|j}d|_|dk r+|j�Wd|j}d|_|dk r�zmy|jtj�WnRtk
r�}z2|jtjkr�t |dd�dkr��WYdd}~XnXWd|j�XXdS)z8Close the connection without assuming anything about it.NZwinerrorri&')
rrBrZshutdownrZ SHUT_RDWR�OSError�errnoZENOTCONN�getattr)rrr�excrrrrBs z
POP3.closecCs|jd|�S)zNot sure what this does.zRPOP %s)r3)rr8rrr�rpop2sz POP3.rpops\+OK.[^<]*(<.*>)cCs�t||j�}|jj|j�}|s9td��ddl}|jd�|}|j|�j �}|j
d||f�S)aAuthorisation
- only possible if server has supplied a timestamp in initial greeting.
Args:
user - mailbox user;
password - mailbox password.
NB: mailbox is locked by server from here to 'quit()'
z!-ERR APOP not supported by serverrNrz
APOP %s %s)rr � timestamp�matchrr�hashlib�groupZmd5Z hexdigestr3)rr8ZpasswordZsecret�mrKZdigestrrr�apop9sz POP3.apopcCs|jd||f�S)z�Retrieve message header of message number 'which'
and first 'howmuch' lines of message body.
Result is in form ['response', ['line', ...], octets].
z TOP %s %s)r4)rr=Zhowmuchrrr�topNszPOP3.topcCs*|dk r|jd|�S|jd�S)z�Return message digest (unique id) list.
If 'which', result contains unique id for that message
in the form 'response mesgnum uid', otherwise result is
the list ['response', ['mesgnum uid', ...], octets]
NzUIDL %sZUIDL)r3r4)rr=rrr�uidlWsz POP3.uidlcCs
|jd�S)zITry to enter UTF-8 mode (see RFC 6856). Returns server response.
ZUTF8)r3)rrrr�utf8csz POP3.utf8c Cs�dd�}i}yJ|jd�}|d}x*|D]"}||�\}}|||<q5WWn1tk
r�}ztd��WYdd}~XnX|S)aReturn server capabilities (RFC 2449) as a dictionary
>>> c=poplib.POP3('localhost')
>>> c.capa()
{'IMPLEMENTATION': ['Cyrus', 'POP3', 'server', 'v2.2.12'],
'TOP': [], 'LOGIN-DELAY': ['0'], 'AUTH-RESP-CODE': [],
'EXPIRE': ['NEVER'], 'USER': [], 'STLS': [], 'PIPELINING': [],
'UIDL': [], 'RESP-CODES': []}
>>>
Really, according to RFC 2449, the cyrus folks should avoid
having the implementation split into multiple arguments...
cSs-|jd�j�}|d|dd�fS)N�asciirr)�decoder:)rZlstrrr� _parsecapvszPOP3.capa.<locals>._parsecapZCAPArz!-ERR CAPA not supported by serverN)r4r) rrT�capsr-ZrawcapsZcaplineZcapnmZcapargsZ_errrrr�capais
z POP3.capacCs�tstd��|jr'td��|j�}d|krKtd��|dkrctj�}|jd�}|j|jd|j �|_|jj
d�|_d|_|S) z{Start a TLS session on the active connection as specified in RFC 2595.
context - a ssl.SSLContext
z-ERR TLS support missingz$-ERR TLS session already establishedZSTLSz!-ERR STLS not supported by serverN�server_hostnamer
T)�HAVE_SSLrr
rV�ssl�_create_stdlib_contextr3�wrap_socketrrrr)r�contextrUr-rrr�stls�s z POP3.stls)'rrr�__doc__r � POP3_PORTr�_GLOBAL_DEFAULT_TIMEOUTrrrr!r*rr2r3r4r5r7r8r9r<r1r>r?r@rArCrBrH�re�compilerIrNrOrPrQrVr]rrrrr2s@+
c@sUeZdZdZeddejddd�Zdd�Zddddd�Z dS) �POP3_SSLaPOP3 client class over SSL connection
Instantiate with: POP3_SSL(hostname, port=995, keyfile=None, certfile=None,
context=None)
hostname - the hostname of the pop3 over ssl server
port - port number
keyfile - PEM formatted file that contains your private key
certfile - PEM formatted certificate chain file
context - a ssl.SSLContext
See the methods of the parent class POP3 for more documentation.
NcCs�|dk r$|dk r$td��|dk rH|dk rHtd��||_||_|dkr~tjd|d|�}||_tj||||�dS)Nz4context and keyfile arguments are mutually exclusivez5context and certfile arguments are mutually exclusive�certfile�keyfile)�
ValueErrorrerdrYrZr\rr)rrrrerdrr\rrrr�s zPOP3_SSL.__init__cCs1tj||�}|jj|d|j�}|S)NrW)rrr\r[r)rrrrrrr�szPOP3_SSL._create_socketcCstd��dS)z�The method unconditionally raises an exception since the
STLS command doesn't make any sense on an already established
SSL/TLS session.
z$-ERR TLS session already establishedN)r)rrerdr\rrrr]�sz
POP3_SSL.stls)
rrrr^�
POP3_SSL_PORTrr`rrr]rrrrrc�s
rc�__main__rr"�zMessage %d:z z-----------------------)'r^rErarrYrX�ImportError�__all__� Exceptionrr_rgr(ZLFrr&rrcr0r�sys�argv�arr5r8r9r1r<ZnumMsgsZ totalSize�range�ir>�header�msgr)rrCrrrr�<module>sH
�k,
?>