Spamworldpro Mini Shell
Spamworldpro


Server : Apache/2.4.52 (Ubuntu)
System : Linux webserver 6.8.0-49-generic #49~22.04.1-Ubuntu SMP PREEMPT_DYNAMIC Wed Nov 6 17:42:15 UTC 2 x86_64
User : www-data ( 33)
PHP Version : 8.1.2-1ubuntu2.21
Disable Function : NONE
Directory :  /lib/python3/dist-packages/ufw/__pycache__/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : //lib/python3/dist-packages/ufw/__pycache__/util.cpython-310.pyc
o

MH�d%~�@sFdZddlmZddlZddlZddlZddlZddlZddlZddl	Z	ddl
Z
ddlZddlZddl
Z
ddlZddlZddlmZddlmZmZdZdZgd�Zgd�Zd	d
gZdd�Zd
d�Zdd�Zdd�Zdd�Zdhdd�Zdd�Z dd�Z!dd�Z"dd�Z#did!d"�Z$d#d$�Z%d%d&�Z&d'd(�Z'did)d*�Z(d+d,�Z)ej*d fd-d.�Z+d/d0�Z,d1d2�Z-d3d4�Z.d5d6�Z/e	�0�fd7d8�Z1e	�0�fd9d:�Z2d;d<�Z3d=d>�Z4d?d@�Z5dAdB�Z6dCdD�Z7dEdF�Z8dGdH�Z9dIdJ�Z:djdKdL�Z;dkdMdN�Z<dOdP�Z=dldQdR�Z>dSdT�Z?dUdV�Z@dWdX�ZAdYdZ�ZBd[d\�ZCd]d^�ZDd_d`�ZEdadb�ZFdmddde�ZGdfdg�ZHdS)nz"util.py: utility functions for ufw�)�print_functionN)�reduce)�mkstemp�mktempF)�tcp�udp�ipv6�esp�ah�igmp�gre)rr	r
rrrrcCs�d}zt�|�Wnty�wz
t�|d�d}Wn	ty%Ynwzt�|d�|dkr6d}W|Sd}W|StyDY|Sw)z8Get the protocol for a specified port from /etc/services�rr�any)�socket�
getservbyname�	Exception)�port�proto�r�*/usr/lib/python3/dist-packages/ufw/util.py�get_services_proto.s.�����rcCs�d}d}|�d�}t|�dkr|d}d}||fSt|�dkr9|d}|d}|tvr5td|�}t|��||fStd�}t|��)	zParse port or port and protocolr
�/�rr�zInvalid port with protocol '%s'zBad port)�split�len�portless_protocols�_�
ValueError)�p_strrr�tmp�err_msgrrr�parse_port_protoHs 

��r"cCs�tjs	td�dSt|�dkst�d|�sdS|�d�}zt�tj|d�Wn
t	y1YdSwt|�dkr:dSt|�dkrIt
|dd	�sIdSd	S)
zVerifies if valid IPv6 addressz"python does not have IPv6 support.F�+z^[a-fA-F0-9:\./]+$rrrrT)r�has_ipv6�warnr�re�matchr�	inet_pton�AF_INET6r�_valid_cidr_netmask��addr�netrrr�valid_address6\s"
�r.cCs�t|�dkst�d|�sdS|�d�}zt�tj|d�t|dd�s'WdSWn
ty2YdSwt|�dkr;dSt|�dkrJt	|dd�sJdSdS)	zVerifies if valid IPv4 address�z^[0-9\./]+$FrrrrT)
rr&r'rrr(�AF_INET�_valid_dotted_quadsr�
valid_netmaskr+rrr�valid_address4vs"
��r3cCst||�p	t||�S)z(Verifies if valid cidr or dotted netmask)r*r1)�nm�v6rrrr2�sr2rcCs<|dkrt|�S|dkrt|�S|dkrt|�pt|�St�)zValidate IP addresses�6�4r)r.r3r)r,�versionrrr�
valid_address�sr9c	Cs^g}d}d}tj}|rd}tj}d|vr7|�d�}|r%|ddkr%|d=n|s6|ddks3|ddkr6|d=n|�|�|s`t|�d	kr`t|d|�r`zt|d|�|d<Wn	ty_Ynw|d
}t�	|t�
||��}||d
krvd}t|�d	kr�|d|d7}|s�t|�}||kr�d||f}t|�|}d}t
||�s�d
|}t|�t�||fS)z�Convert address to standard form. Use no netmask for IP addresses. If
       netmask is specified and not all 1's, for IPv4 use cidr if possible,
       otherwise dotted netmask and for IPv6, use cidr.
    Fr7r6rr�128�32z255.255.255.255rrTzUsing '%s' for address '%s'zInvalid address '%s')rr0r)r�appendrr1�_dotted_netmask_to_cidrr�	inet_ntopr(�_address4_to_network�debugr9r)	�origr5r-�changedr8�s_typer,�network�dbg_msgrrr�normalize_address�sN
�
�
rFcC�
t|d�S)z"Opens the specified file read-only�r)�open)�fnrrr�open_file_read��
rKcCs>t|�}zt�\}}Wnty|���w||||d�S)z=Opens the specified file read-only and a tempfile read-write.)rA�orignamer �tmpname)rKrr�close)rJrAr rNrrr�
open_files�s�rPcCs�|dkrdS|sttjd��tr|tj��krt�|�dSd}tjddkr1t	�|t
|d��}nt	�||�}|dkrAttjd��dS)	z~Write to the file descriptor and error out of 0 bytes written. Intended
       to be used with open_files() and close_files().r
NzNot a valid file descriptor���r��asciiz"Could not write to file descriptor)�OSError�errno�ENOENT�
msg_output�sys�stdout�fileno�write�version_info�os�bytes�EIO)�fd�out�rcrrr�
write_to_file�s
�rcTcCsX|d��t�|d�|r#t�|d|d�t�|d|d�t�|d�dS)zuCloses the specified files (as returned by open_files), and update
       original file with the temporary file.
    rAr rMrNN)rOr]�shutil�copystat�copy�unlink)�fns�updaterrr�close_filessrjc
Csnt|�z
tj|tjtjdd�}Wnty)}zdt|�gWYd}~Sd}~ww|��d}|jt|�gS)z!Try to execute the given command.T)rY�stderr�universal_newlines�Nr)	r@�
subprocess�Popen�PIPE�STDOUTrT�str�communicate�
returncode)�command�sp�exrarrr�cmds

���rxc
Cspztj|tjd�}tj||jd�}Wnty*}zdt|�gWYd}~Sd}~ww|��d}|jt|�gS)z#Try to pipe command1 into command2.)rY)�stdinrmNr)rnrorprYrTrrrsrt)�command1�command2�sp1�sp2rwrarrr�cmd_pipe$s��r~cCs�z|j}Wnty|}Ynwz|�dd�}Wnty$|}Ynwtr3t�tj�r3|�|�n|�t	|��|�
�dS)zQImplement our own print statement that will output utf-8 when
       appropriate.�utf-8�ignoreN)�bufferr�encoderW�inspect�isclass�io�StringIOr[r^�flush)�output�s�writerrarrr�_print2s
��r�cCs>z
ttjd|�Wn	tyYnw|rt�d�dSdS)zPrint error message and exitz
ERROR: %s
rN)r�rXrk�IOError�exit)ra�do_exitrrr�errorGs��r�cCs,zttjd|�WdStyYdSw)zPrint warning messagez	WARN: %s
N)r�rXrkr��rarrrr%Rs
�r%cCsTtr	|tjkr	t}z|rt|d|�WdSt|d|�WdSty)YdSw)z
Print messagez%s
z%sN)rWrXrYr�r�)rar��newlinerrr�msgZs�r�cCs4trzttjd|�WdStyYdSwdS)zPrint debug messagez
DEBUG: %s
N)�	DEBUGGINGr�rXrkr�r�rrrr@hs��r@cCst|fdd�|�d��S)z�
    A word-wrap function that preserves existing line breaks
    and most spaces in the text. Expects that existing line
    breaks are posix newlines (
).
    c	Ss<d|dt|�|�d�dt|�dd�d�|k|fS)Nz%s%s%sz 
�
rr)r�rfindr)�line�word�widthrrr�<lambda>ws����zword_wrap.<locals>.<lambda>� )rr)�textr�rrr�	word_wrapqs�r�cCrG)zWord wrap to a specific width�K)r�)r�rrr�	wrap_text�rLr�cs dd��|j�fdd�d�dS)a$Sorts list of strings into numeric order, with text case-insensitive.
       Modifies list in place.

       Eg:
       [ '80', 'a222', 'a32', 'a2', 'b1', '443', 'telnet', '3', 'http', 'ZZZ']

       sorts to:
       ['3', '80', '443', 'a2', 'a32', 'a222', 'b1', 'http', 'telnet', 'ZZZ']
    cSs|��rt|�S|��S�N)�isdigit�int�lower)�trrrr��szhuman_sort.<locals>.<lambda>cs�fdd�t�d|�D�S)Ncsg|]}�|��qSrr)�.0�c��normrr�
<listcomp>�sz0human_sort.<locals>.<lambda>.<locals>.<listcomp>z([0-9]+))r&r)�kr�rrr��s)�keyN)�sort)�lstrr�r�
human_sort�s
r�cCs|zt|�}Wntytd��wtj�dt|�d�}tj�|�s(td|��t	|��
�d�dd�d��d}t|�S)zdFinds parent process id for pid based on /proc/<pid>/stat. See
       'man 5 proc' for details.
    zpid must be an integer�/proc�stat�Couldn't find '%s'r�)r)
r�rrr]�path�joinrr�isfiler�rI�	readlines�rsplitr)�mypid�pid�name�ppidrrr�get_ppid�s�$r�cCs�zt|�}Wn$tytd�}t|�YdSty*td�t|�}t|��w|dks3|dkr5dStj�	dt|�d�}tj�
|�sOtd�|}t|��zt|���d�
�d}Wntyntd	�|}t|��wtd
|�|dkr{dSt|�S)
z1Determine if current process is running under sshz%Couldn't find pid (is /proc mounted?)Fz!Couldn't find parent pid for '%s'rr�r�r�rz"Could not find executable for '%s'zunder_ssh: exe is '%s'z(sshd)T)r�r�rr%rrrrr]r�r�r�rIr�rr@�	under_ssh)r�r��warn_msgr!r��exerrrr��s4��r�cCs8d}|rd}t�d|�rt|�dkst|�|krdSdS)zVerifies cidr netmasks� ��^[0-9]+$rFT)r&r'r�)r4r5�numrrrr*�s$r*cCsd|rdSt�d|�r0t�d|�}t|�dkrdS|D]}|r*t|�dks*t|�dkr-dSqdSdS)z.Verifies dotted quad ip addresses and netmasksFz^[0-9]+\.[0-9\.]+$z\.�r�T)r&r'rrr�)r4r5�quads�qrrrr1�s��r1c
Cs�d}|rt�t||�s
t�d}ztt�dt�|��d�}Wnty4tt�dt�|��d�}Ynwd}t	d�D]}||?d@dkrHd}q;|rNd}n|d7}q;|dkra|dkrat
d|�}t||�sht�|S)	z@Convert netmask to cidr. IPv6 dotted netmasks are not supported.r
r�>LFr�rTrQ)rr1�long�struct�unpackr�	inet_aton�	NameErrorr��rangerrr*)r4r5�cidr�mbits�bits�	found_one�nrrrr=�s0
�

r=cCs�d}|rt�t||�s
t�ztd�}Wntyd}Ynwtd�D]}|t|�kr3|dd|>O}q#t�t�	d|��}t
||�sDt�|S)z<Convert cidr to netmask. IPv6 dotted netmasks not supported.r
rr�rr/r�)rr*r�r�r�r�r�	inet_ntoar��packr1)r�r5r4r�r�rrr�_cidr_to_dotted_netmask$s$
��
r�c	
Cs
d|vr
td�|S|�d�}t|�dkst|dd�st�|d}|d}|}t|d�r2t|d�}ztt�	dt
�|��d�}tt�	dt
�|��d�}Wn#tyqt
t�	dt
�|��d�}t
t�	dt
�|��d�}Ynw||@}t
�t�d|��}d||fS)	z8Convert an IPv4 address and netmask to a network addressrz8_address4_to_network: skipping address without a netmaskrrFrr��%s/%s)r@rrr1rr*r�r�r�r�rr�r�r�r�r�)	r,r �host�orig_nmr4�	host_bits�nm_bits�network_bitsrDrrrr?As*


�r?cCs�dd�}d|vrtd�|S|�d�}t|�dks t|dd�s"t�|d}|d}t�d	t�tj	|��}zt
d�}WntyFd}Ynwtd
�D]"}|||d�}td�D]}	|dt
||	�@d|	|d>O}qXqKzt
d�}
Wntyd}
Ynwtd
�D]}|t
|�kr�|
dd|>O}
q�||
@}g}td
�D]}|�t
||d
�|d|dd�d��q�t�tj	t�d	|d|d|d|d|d|d|d|d�	�}
d|
|fS)z8Convert an IPv6 address and netmask to a network addresscs$d��fdd�t|ddd�D��S)zDecimal to binaryr
csg|]
}t�|?d@��qS)r)rr)r��y�r�rrr�h�z9_address6_to_network.<locals>.dec2bin.<locals>.<listcomp>rrQ)r�r�)r��countrr�r�dec2binfs$z%_address6_to_network.<locals>.dec2binrz8_address6_to_network: skipping address without a netmaskrrTrz>8H��rmr�rRr����r�)r@rrr2rr�r�rr(r)r�r�r�r�r<r>r�)r,r�r �	orig_host�netmask�unpackedr��ir��jr�r-r�rDrrr�_address6_to_networkdsT
��&���,��r�c	Cs^|�d�}t|�dkst|d|�st�|d}|d}|dks$|dkr&dS|}d|vrD|�d�}t|�dks>t|d|�s@t�|d}|dksL|dkrNdS|r[t|�rXt|�sZt�n
t|�rct|�set�t||�rq|sqt||�}|r�td||f��d�d}td||f��d�d}||kSt	d||f��d�d}t	d||f��d�d}||kS)	z&Determine if address x is in network yrrrrz0.0.0.0z::Tr�)
rrr2rr.r3r*r�r�r?)	�
tested_add�
tested_netr5r r�r��address�orig_networkrDrrr�
in_network�s\

�
���������r�cCsHd}dD]}tj�|d�}tj�|�rnd}q|dkr"ttjd��|S)Nr
)z/sbinz/binz	/usr/sbinz/usr/binz/usr/local/sbinz/usr/local/bin�iptableszCould not find iptables)r]r�r��existsrTrUrV)r��drrr�_find_system_iptables�sr�cCsT|durt�}t|dg�\}}|dkrttjd|��t�d|�}t�dd|d�S)	zReturn iptables versionNz-VrzError running '%s'z\sz^vr
r)r�rxrTrUrVr&r�sub)r�rbrar rrr�get_iptables_version�sr�cCs�dd�}|rt��dkrttjd��|durt�}g}d}|�d�r$d}|td	d	d
�7}t|d|g�\}}|dkr?ttj	|��|||gd��rL|�
d
�|||gd��rY|�
d�t|d|g�t|d|g�\}}|dkrsttj	|��|S)z[Return capabilities set for netfilter to support new features. Callers
       must be root.cSs*|d|g}t||�\}}|dkrdSdS)Nz-ArTF)rx)r��chain�rule�argsrbrarrr�test_cap�s

z,get_netfilter_capabilities.<locals>.test_caprzMust be rootNz
ufw-caps-test�	ip6tableszufw6-caps-testr
)�prefix�dirz-N)�-m�	conntrack�	--ctstate�NEWr��recentz--setz
recent-set)r�r�rrr�rz--updatez	--seconds�30z
--hitcountr6z
recent-updatez-Fz-X)r]�getuidrTrU�EPERMr��endswithrrxrVr<)r��	do_checksr��capsr�rbrarrr�get_netfilter_capabilities�s,


r	cCst|�}t�}|��D]}|�d�s|�d�sq|��}|d}|d�d�d}t�}d�|d�d�dd��|d<|d	|d
<|d�d�d|d
<|d
dkrZ|d
|d<n|d�d�d|d<||vrut�||<g|||<n|||vr�g|||<|||�|�q|S)z:Get and parse netstat the output from get_netstat_output()rrrr�:rQN�laddrrR�uidr�rr��-r�)�get_netstat_output�dict�
splitlines�
startswithrr�r<)r5�netstat_outputr�r�r rr�itemrrr�parse_netstat_output's, 
rcs$d}|r[d}tj�|�sttjd|��t|���D]5}|���|�dkrOd�	�fdd�t
dt�d�d	�D��}�d
��dkrOd|t
�d
��d
�f}q|dkrZttjd��n0t�tjtj�}zt�t�|��dt�d|dd���dd��}Wn
ty�ttjd��wt||�dS)zGet IP address for interfacer
�/proc/net/if_inet6�'%s' does not existr�r
c� g|]}�d||d��qS�rr�r�r�r��r rrr�[� z"get_ip_from_if.<locals>.<listcomp>rr�r�80r�r��No such devicei��256sN���)r]r�r�rTrUrVrIr�rr�r�rr�r�r��ENODEVrr0�
SOCK_DGRAMr��fcntl�ioctlrZr�r�rrF)�ifnamer5r,�procr�r�rrr�get_ip_from_ifMs8 ����
��r(c	sZd}d}t|�r
d}d}n
t|�sttjd��tj�|�s%ttj	d|��d}|rzt
|���D]H}|����d�
�}d	��fd
d�tdt�d�d
�D��}�d��dkrdd|t�d��d�f}||ksrd|vrwt||d�rw|}|Sq/|St
|���D]*}d	|vr�q�|�d	�d�
�}zt|d�}Wn	ty�Yq�w||kr�|}|Sq�|S)zGet interface for IP addressFz
/proc/net/devTrrrr
r�r
crrrrrrrr��rz"get_if_from_ip.<locals>.<listcomp>rr�rrr�r�r)r.r3r�rUr"r]r�r�rTrVrIr�r�stripr�r�rr�r�r�r()r,r5r'�matchedr�r&�tmp_addr�iprrr�get_if_from_ipmsR �����r-c	
Cst�d�}|��t�d�}t�}|D]n}|�|�sqtj�d|d�}t�	|tj
tjB�s.qd}z
t�tj�d|d��}Wn	t
yFYnwzt�|�}Wn	t
yWYqw|D]&}zt�tj�||��d}Wn	t
ysYqZwd|tj�|�f||<qZq|S)zGet inodes of files in /procr�r�r`r
r�rr�)r]�listdirr�r&�compilerr'r�r��access�F_OK�R_OK�readlinkrr��basename)	�
proc_files�pat�inodesr��fd_path�exe_path�dirsr��inoderrr�_get_proc_inodes�s<


����r<cCsddddddddd	d
dd�}d
dddd�}tj�d|�}t�|tjtjB�s(t�g}d}t|���}|D]L}|�	�}|s?d}q4|t
||dd�}	|�d�rRd}	n
|�d�r\|	d
kr\q4||d�	d�\}
}||d}||d}
|�|
t
|d�||
|	f�q4|S)z=Read /proc/net/(tcp|udp)[6] file and return a list of tuples �ESTABLISHED�SYN_SENT�SYN_RECV�	FIN_WAIT1�	FIN_WAIT2�	TIME_WAIT�CLOSE�
CLOSE_WAIT�LAST_ACK�LISTEN�CLOSING)rrrRr�r�r�r�r��	�
�rrRr�rH)�
local_addr�staterr;z	/proc/netFTrLr�r�NArrKr
rr;)
r]r�r�r0r1r2rrIr�rr�rr<)�protocol�
tcp_states�proc_net_fieldsrJr��
skipped_first�linesr��fieldsrLrrrr;rrr�_read_proc_net_protocol�sL�
�
rTc	s�d}t��dkr@d�tddd�D]}�d��fdd�t|d|d�D��7�qtd��fd	d�tdt��d
�D��d�d}|Sg��fdd�tddd�D�D]}��tt|d
���qOtd���d�d}|S)zDConvert an address from /proc/net/(tcp|udp)* to a normalized addressr
r�rr�c�g|]
}�|d|��qS�rr�r�r���paddrrrr��r�z(convert_proc_address.<locals>.<listcomp>���r
cs g|]}�||d����qS)r�)r�rWrrrr��rr�TcrUrVrrWrXrrr��r�r��.F)rr�r�rFr<rrr�)rY�	convertedr�r)rYr r�convert_proc_address�s$*���	�r]c
Cs�t�}ddg}|r|ddg7}|D]}zt|�||<Wqty.td|�}t|�Yqwt�}t|���}|��d}|D]0}||D])\}}	}
}}t	|�}
d}t
|�|vr_|t
|�}|d|d	|
|	f||
||f7}qFq@|S)
z5netstat-style output, without IPv6 address truncationrr�tcp6�udp6z!Could not get statistics for '%s'r
r
z%-5s %-46s %-11s %-5s %-11s %s
z%s:%s)rrTrrr%r<�list�keysr�r]r�)r5�
proc_net_datar�pr�r7�	protocolsr�rrrr;rLr,r�rrrrs8�

��rcCsV|dur|S|�d�r"t|�dkr|}|Stj�||dd��}|Stj�||�}|S)zAdd prefix to dirNrrr)rrr]r�r�)r�r��newdirrrr�	_findpath&s
��rfcCs4tjddkr
t�|d�St�|jddd���d�S)z,Take a string and convert it to a hex stringrrR�hexrr�)�errorsrS)rXr\�codecsr��binascii�hexlify�decode)r�rrr�
hex_encode4srmcCs0tjddkr|jdd��d�St�|��d�S)z,Take a hex string and convert it to a stringrrRrg)�encodingr)rXr\rlrj�	unhexlify)�hrrr�
hex_decode=srq�
/run/ufw.lockcCs$d}|st|d�}t�|tj�|S)zCreate a blocking lockfileN�w)rIr$�lockf�LOCK_EX)�lockfile�dryrun�lockrrr�create_lockDs

rycCs>|durdSzt�|tj�|��WdStyYdSw)z(Free lockfile created with create_lock()N)r$rt�LOCK_UNrOr)rxrrr�release_lockMs�r{)r)Tr�)NT)F)rrF)I�__doc__�
__future__rrjrirUr$r�r�r]r&rdrr�rnrX�	functoolsr�tempfilerrr�rW�supported_protocolsr�ipv4_only_protocolsrr"r.r3r2r9rFrKrPrcrjrxr~r�r�r%rYr�r@r�r�r��getpidr�r�r*r1r=r�r?r�r�r�r�r	rr(r-r<rTr]rrfrmrqryr{rrrr�<module>s�
7

	'.#:4


9
& /%/#	
	

Spamworldpro Mini