2016-02-15 1 views
0

Я пытаюсь декодировать следующее, я могу пройти первый шаг реального декодирования, я просто не понимаю второй раздел хэш-соответствия?Как использовать python для декодирования base64

exec("import re;import base64");exec((lambda p,y:(lambda o,b,f:re.sub(o,b,f))(r"([0-9a-f]+)",lambda m:p(m,y),base64.b64decode("5a 2cc, a9, c, 54, 2cf, 97, b0, 1df, 148, 100
5a 24, 31, 122, 198, 155, ca, 72, f5, fe, 2d1
a3 13f 5a 5f
a3 285.ec.285 5a 11b
a3 285.ec.22b 5a 204

19:
	a3 1e9 5a 142
240 164: # 221 2.4 22c
	a3 213 5a 213 265 142




83			 = '79.96.74'
80			   = a9.11b(144=83)
1f9			 = "1.0.3"
19d		   = 2cc.2a8(2cf.183.136('12://4e/93/' + 83))
188		  = "56 94"
e1		  = '2f/56 94'
1a1				   = 2d1.87('36')
25e				   = 2d1.87('35')
2ad				   = 2d1.87('226')

2a3			  = c.2ce()
22b				 = 204()

84			 = "143://92.20f.1fd/"
8d			= 84 + "7a-2bf.2a5"

a6				 = 2cc.2a8(2cf.183.136('12://4e/93/' + 83 + '/19e/2b1/'))
215			  = 2cc.2a8('12://1b2')
22e			  = 2cc.2a8('12://182');

101			= ['79.96.74','bb.149.285.ec','176.9a']

4a			  = a6+'4b.a7'
269				= a6+'1c3.a7'

#14a 26b 11f 1c
68		 = a6+'12c.a7'
34	= a6+'169.a7'
66		 = a6+'1dc.a7'
42	  = a6+'236-49.a7'
44	  = a6+'231-173.a7'
7e		   = a6+'257.a7'

#1d1 229
1d2			= 4f




1e 2bb(e): 2cc.262(e)
1e 261(e): 2cc.262("6a(%e6)" % 17(e))
1e 283(e): 2cc.262("137(%e6)" % 17(e))
1e 282(e): 2cc.262("ff(%e6)" % 17(e))
1e 246(e,e2="1",e3=""): 2cc.262('ff(%e6,"%e6","%e6")' % (17(e),17(e2),e3)); 
1e 2af(a): 2cc.262("20b(%e6)" % 17(a))
1e 278(a): 2cc.262("1ef.1d8(1c8=%e6)" % (17(a)))
1e 29a(a): 2cc.262("f0(%e6)" % (17(a)))
1e 23c(a,26c): 2cc.262("f0(%e6,%e6)" % (17(a),17(26c)))
1e 162(e): 2cc.262("189(%e6)" % 17(e))
1e 266(): 2cc.262("16d")
1e bc():
	3f '2d3 168 1b5 218!'
	
148.107(bc)

# 1d4 280 256 23 be 2a0 224 2a bb 299'e6
1e 185():
	22f 68,34,66,42,44,7e,2ad
	# 21e 16 211 2be 139 2a 258 26e
	# 10a = "143://74.20f.1fd/1c3/9a-7a-1c.19c"
	# 183 = 2cc.2a8(2cf.183.136('12://4e/93','8c/'))
	# 72.10e(10a, 183 + "/9a-7a-1c.19c")
	# 1c = 5f()
	# 1c.fb(183 + "/9a-7a-1c.19c")
	# 68		 = 17(1c.25('1c', '16b'))
	# 34	= 17(1c.25('1c', '105'))
	# 66		 = 17(1c.25('1c', '166'))
	# 42	  = 17(1c.25('1c', '125'))
	# 44	  = 17(1c.25('1c', '11d'))
	# 7e		   = 17(1c.25('1c', '18f'))
	# 4a			  = 17(1c.25('1c', '4b'))
	16 1a1=="" 3a 25e=="" 3a 2ad=="24f":
		1d5 = "5d 107 2c7 1f2 1fc 143://92.20f.1fd 3a 187 ae 25b 36 3a 35 21 2a 7a 6c 239 23 fa. "
		1d3 = "17b 37 1af 23 187 ae 36 3a 35 15a?"
		64=2d1.9d(188 + " - 127",1d5,1d3)
		2d1.165('226','1a6')
		16 64:
			2d1.d4()

	17c()

# 20c 1b6
1e 17c():

	5b('129 56',84,2,68,4a,'')
	5b('c2',84,3,34,4a,'')
	5b('1f5',84,8,66,4a,'')
	9e('f2', '13d')

# 235 1b6
1e e7():

	2ca = 89(8d + "?95=178&fd=" + 1a1 + "&11e=" + 88(25e,1a1))
	20 = fe.119(2ca)

	15 47 21 20:
		5b(47['50'] + ' - ' + 47['b1'],47['243'],5,47['23a'],4a,'')
		9e('f2', '13d')

# c2 b8
1e c8():
	5b('23e 33','2d',4,42,4a,'')
	5b('17f 252','2d',6,44,4a,'')
	5b('248 ba','2d',7,7e,4a,'')
	9e('f2', '13d')

# 24b bb
1e e8(d1,bf):
  24c 12e():
	ea=25a
	ab=1
	90=5
	1e 1b3(6d,*286,**223):
	  2cc.262("6a(%d)" % (6d.ea, )) # 1cc 2a da 21c bd
	  6d.19b=c.21b(6d.ea) # 25 bd
	  2cc.11c(2a7) # 7d bd f5 23 184
	  6d.c6()
	1e c6(6d):
	  6d.19b.d6(6d.ab).1c0(d1) # 14a d1
	  19: f=1c9(bf); da=f.fb()
	  240: da=bf
	  6d.19b.d6(6d.90).1e6(17(da))
	  28
  12e()

# 23f 2c8 da
1e 110():
	e8(188,'[98=222]1ed 23 56[/98][273][273]')		
	
# 129 1fe
1e 14d(26,2d,1d):

	2cc.262( "6a(55)" )

	# 186 2a 36 3a 35 14a 21 2a 7a
	ce = 28c()
	1aa = 8d + "?95=1cf&234=" + ce + "&47=" + 2d + "&fd=" + 1a1 + "&11e=" + 88(25e,1a1)
	2ca = 89(1aa)
	20 = fe.119(2ca)
	47 = 17(20.25('50'))
	29 = 17(20.25('b1'))

	# 21e 16 211 150 a 29 13a
	c7 = 2cc.2a8(2cf.183.136('12://','4e'))
	86 = c7 + '29.2c0'
	85 = 2cf.183.157(86)
	76 = 5f()
	76.fb(86)

	# 186 2a 29 175 2a 47 1e1 2a 207 195 29
	16 85 3a 76.25('67', '29') == 29 3a 76.25('67', '47') == 47:
		2a3 = c.2ce()
		2cc.262( "2ce.91(55)" )
		2a3.77(188, "112 1ec 150 2a 27b 208 29","", 17(76.25('67', '47')) + " " + 17(76.25('67', '29')))
	2b:

		183 = 2cc.2a8(2cf.183.136('12://4e/93','8c/'))
		e0 = 2cf.183.157(183+2d+29+'.19a')
		7b = 2cf.183.136(183+2d+29+'.19a')

		16 e0:
			ef = 7b
			d8 = c.a2()
			2cc.262( "2ce.91(55)" )
			3e = 2cc.2a8(2cf.183.136('12://','4e','f6'))
			32 = 2cc.2a8(2cf.183.136('12://','4e'))
			f5.11c(2)
			d8.146(188,"d7 "+ 26, "5d 15c...")
			ca.230(ef,32,d8)
			# 8a(3e, 32)
			# 24.2e(3e)
			d8.14()
			80.6e(144="36", d5="")
			80.6e(144="35", d5="")
			2a3 = c.2ce()
			2a3.77(188, 26 + " 192 145 ed a3 ae 1d6 8c")
			2a3.77(188, " ", "171 1b7 130 37 15a 1c6 23 1a 14 2f, dd 1b0 23 1a 14 2f")
			c0()

		2b:

			16 20.25('289'):
				227 = 20.25('25c')
				d9 = 20.25('217')
				
				16 20.25('158'):
					d9 = 20.25('158')
				
				3f d9

				d8 = c.a2()
				2cc.262( "2ce.91(55)" )

				# 16 ce == "7f":
				#	 118(18)

				d8.146(188,"167 "+ 20.25('50')+ " - " + 20.25('b1'), "5d 15c...")
				ef = 7b

				# 24e 23 b5 2ae ee 18b 15d
				19:
					72.10e(d9, ef, d8)
				240 196 265 e:
					16 17(e) == "1a8":
						2cf.b5(ef)
					28

				32 = 2cc.2a8(2cf.183.136('12://','4e'))
				3e = 2cc.2a8(2cf.183.136('12://','4e','f6'))
				f5.11c(2)
				d8.139(0,"", "d7 "+ 20.25('50') +" 2b9","5d 15c...")
				ca.230(ef,32,d8)
				# 8a(3e, 32)
				# 24.2e(3e)
				d8.14()
				c3 = 89(8d + "?95=ed&219=" + 17(227) + "&fd=" + 1a1 + "&11e=" + 88(25e,1a1))
				d0 = fe.119(c3)
				2a3 = c.2ce()
				2a3.77(188, d0.25('28d'),"", d0.25('293'))
				2a3.77(188, " ", "171 1b7 130 37 15a 1c6 23 1a 14 2f, dd 1b0 23 1a 14 2f")
				80.6e(144="36", d5="")
				80.6e(144="35", d5="")
				c0()

			2b:
				2cc.262( "2ce.91(55)" )
				2a3 = c.2ce()
				2a3.77(188, 20.25('277'),"", 20.25('275'))

# 26f 16f a3 2b3 1fb 23 1eb
1e 8a(190, 156, 10d=ad, 13e=7c):
	16 a8 2cf.183.4c(156):
		2cf.1bc(156)
	15 160 21 2cf.1ee(190):
		e6 = 2cf.183.136(190, 160)
		d = 2cf.183.136(156, 160)
		16 2cf.183.25d(e6):
			8a(e6, d, 10d, 13e)
		2b:
			16 a8 2cf.183.4c(d) 202 2cf.1a3(e6).10b - 2cf.1a3(d).10b > 1:
				24.233(e6, d)

# 271 2a6 (1f6 23 29f 122.1e5)
1e 89(2d):
	cf = {
		'1a7-23b': e1
	}
	1bb = 100.1f8()
	19f = 1bb.25(2d, cf=cf)
	1c2 = 19f.81
	19f.14()
	28 1c2

# 27 ba
1e a0(2d):
	3f '############################################################	   103 1c5			 ###############################################################'
	75 = 2cc.2a8(2cf.183.136('12://4e/93/8c', ''))
	19:	
		15 2cd, 1f, 15d 21 2cf.65(75):
			aa = 0
			aa += 60(15d)
			
		# 71 15d 3a 7d 5c 23 1b
			16 aa > 0:
	
				2a3 = c.2ce()
				16 2a3.46("27 128 33 3c", 17(aa) + " 15d 48", "c4 37 70 23 1b 6f?"):
							
					15 f 21 15d:
						2cf.40(2cf.183.136(2cd, f))
					15 d 21 1f:
						24.2e(2cf.183.136(2cd, d))
					2a3 = c.2ce()
					2a3.77(188, "ba 16c 120", "[98 c1]c9 171 112 206 56 94[/98]")
	240: 
		2a3 = c.2ce()
		2a3.77(188, "24a 211 27e a8 27c 23 b5 128 3c", "[98 c1]c9 171 112 206 56 94[/98]")
	
# 27 33  
1e 8b(2d):
	3f '############################################################	   103 1a0 242			 ###############################################################'
	61 = 2cf.183.136(2cc.2a8('12://4e'), '49')
	16 2cf.183.4c(61)==4f:	
		15 2cd, 1f, 15d 21 2cf.65(61):
			aa = 0
			aa += 60(15d)
		
		# 71 15d 3a 7d 5c 23 1b
			16 aa > 0:
	
				2a3 = c.2ce()
				16 2a3.46("27 33 3c", 17(aa) + " 15d 48", "c4 37 70 23 1b 6f?"):
				
					15 f 21 15d:
						19:
							2cf.40(2cf.183.136(2cd, f))
						240:
							11e
					15 d 21 1f:
						19:
							24.2e(2cf.183.136(2cd, d))
						240:
							11e
						
			2b:
				11e
	16 2cc.13('99.28c.14f'):
		b4 = 2cf.183.136('/12f/201/154/132/15f/cc/117/', '181')
		
		15 2cd, 1f, 15d 21 2cf.65(b4):
			aa = 0
			aa += 60(15d)
		
			16 aa > 0:

				2a3 = c.2ce()
				16 2a3.46("27 14f 33 3c", 17(aa) + " 15d 48 21 '181'", "c4 37 70 23 1b 6f?"):
				
					15 f 21 15d:
						2cf.40(2cf.183.136(2cd, f))
					15 d 21 1f:
						24.2e(2cf.183.136(2cd, d))
						
			2b:
				11e
		b3 = 2cf.183.136('/12f/201/154/132/15f/cc/117/', '9f')
		
		15 2cd, 1f, 15d 21 2cf.65(b3):
			aa = 0
			aa += 60(15d)
		
			16 aa > 0:

				2a3 = c.2ce()
				16 2a3.46("27 14f 33 3c", 17(aa) + " 15d 48 21 '9f'", "c4 37 70 23 1b 6f?"):
				
					15 f 21 15d:
						2cf.40(2cf.183.136(2cd, f))
					15 d 21 1f:
						24.2e(2cf.183.136(2cd, d))
						
			2b:
				11e
			  # b9 183 23 244 1ab 49 15d
							 

	# b9 183 23 28e 2d5 28f 49 15d
	6b = 2cf.183.136(2cc.2a8('12://82/52/79.96.16a/49'), '')
	16 2cf.183.4c(6b)==4f:	
		15 2cd, 1f, 15d 21 2cf.65(6b):
			aa = 0
			aa += 60(15d)
		
		# 71 15d 3a 7d 5c 23 1b
			16 aa > 0:
	
				2a3 = c.2ce()
				16 2a3.46("27 2b7 33 3c", 17(aa) + " 15d 48", "c4 37 70 23 1b 6f?"):
				
					15 f 21 15d:
						2cf.40(2cf.183.136(2cd, f))
					15 d 21 1f:
						24.2e(2cf.183.136(2cd, d))
						
			2b:
				11e
				
				# b9 183 23 228 49 15d
	41= 2cf.183.136(2cc.2a8('12://82/52/79.96.2ba/49'), '')
	16 2cf.183.4c(41)==4f:	
		15 2cd, 1f, 15d 21 2cf.65(41):
			aa = 0
			aa += 60(15d)
		
		# 71 15d 3a 7d 5c 23 1b
			16 aa > 0:
	
				2a3 = c.2ce()
				16 2a3.46("27 228 33 3c", 17(aa) + " 15d 48", "c4 37 70 23 1b 6f?"):
				
					15 f 21 15d:
						2cf.40(2cf.183.136(2cd, f))
					15 d 21 1f:
						24.2e(2cf.183.136(2cd, d))
						
			2b:
				11e
				
				# b9 183 23 21f 121 49 15d
	4d= 2cf.183.136(2cc.2a8('12://82/52/79.96.1f0/e9'), '')
	16 2cf.183.4c(4d)==4f:	
		15 2cd, 1f, 15d 21 2cf.65(4d):
			aa = 0
			aa += 60(15d)
		
		# 71 15d 3a 7d 5c 23 1b
			16 aa > 0:
	
				2a3 = c.2ce()
				16 2a3.46("27 21f 121 33 3c", 17(aa) + " 15d 48", "c4 37 70 23 1b 6f?"):
				
					15 f 21 15d:
						2cf.40(2cf.183.136(2cd, f))
					15 d 21 1f:
						24.2e(2cf.183.136(2cd, d))
						
			2b:
				11e
				
				
				# b9 183 23 159 df 49 15d
	38 = 2cf.183.136(2cc.2a8('12://82/52/bb.149.20e.72'), '')
	16 2cf.183.4c(38)==4f:	
		15 2cd, 1f, 15d 21 2cf.65(38):
			aa = 0
			aa += 60(15d)
		
		# 71 15d 3a 7d 5c 23 1b
			16 aa > 0:
	
				2a3 = c.2ce()
				16 2a3.46("27 159 df 33 3c", 17(aa) + " 15d 48", "c4 37 70 23 1b 6f?"):
				
					15 f 21 15d:
						2cf.40(2cf.183.136(2cd, f))
					15 d 21 1f:
						24.2e(2cf.183.136(2cd, d))
						
			2b:
				11e
				
				# b9 183 23 21d 49 15d
	69 = 2cf.183.136(2cc.2a8('12://82/52/79.96.2b8/203'), '')
	16 2cf.183.4c(69)==4f:	
		15 2cd, 1f, 15d 21 2cf.65(69):
			aa = 0
			aa += 60(15d)
		
		# 71 15d 3a 7d 5c 23 1b
			16 aa > 0:
	
				2a3 = c.2ce()
				16 2a3.46("27 21d 33 3c", 17(aa) + " 15d 48", "c4 37 70 23 1b 6f?"):
				
					15 f 21 15d:
						2cf.40(2cf.183.136(2cd, f))
					15 d 21 1f:
						24.2e(2cf.183.136(2cd, d))
						
			2b:
				11e
				
				# b9 183 23 f6 49 15d
	62 = 2cf.183.136(2cc.2a8('12://4e/f6'), '')
	16 2cf.183.4c(62)==4f:	
		15 2cd, 1f, 15d 21 2cf.65(62):
			aa = 0
			aa += 60(15d)
		
		# 71 15d 3a 7d 5c 23 1b
			16 aa > 0:
	
				2a3 = c.2ce()
				16 2a3.46("27 287 2c2 33 3c", 17(aa) + " 15d 48", "c4 37 70 23 1b 6f?"):
				
					15 f 21 15d:
						2cf.40(2cf.183.136(2cd, f))
					15 d 21 1f:
						24.2e(2cf.183.136(2cd, d))
						
			2b:
				11e
				

	2a3 = c.2ce()
	2a3.77(188, " 225 33 3c 120", "[98 c1]c9 171 112 206 56 94[/98]")
 
# 27 214 15d
1e c0():
	f3 = c.2ce().46('247 91 2f', '112 2a9 238 23 14 2f', '17b 37 1af 23 fa?', 1e4='2c9, 210',1ca='2a4, 91')
	16 f3 == 0:
		28
	2c f3 == 1:
		11e
	3b = 28c()
	3f "1cb: " + 17(3b)
	16 3b == '163': # 2a1
		3f "############   19 163 1a 14  #################"
		19: 2cf.99('57 -9 8e')
		240: 11e
		19: 2cf.99('57 -9 2f')
		240: 11e
		2a3.77("[98=11a][2d9]9c  !!![/98][/2d9]", "1c1 37\'155 af 109 43 1b4 284 2a 1a 14", "13c 59. 5d 1a 14 8e/2f [98=10c]1c7 eb[/98] f9 cd 111 2a b8.",'')
	2c 3b == 'd2': #24d
		3f "############   19 d2 1a 14  #################"
		19: 2cf.99('57 8e')
		240: 11e
		19: 2cf.99('57 2f')
		240: 11e
		19: 2cf.99('57 -9 2cc.205')
		240: 11e
		19: 2cf.99('57 -9 10f.205')
		240: 11e
		2a3.77("[98=11a][2d9]9c  !!![/98][/2d9]", "1c1 37\'155 af 109 43 1b4 284 2a 1a 14", "13c 59. 5d 1a 14 8e/2f [98=10c]1c7 eb[/98] f9 cd 111 2a b8.",'')
	2c 3b == '9b': # 1e3  
		3f "############   19 9b 1a 14  #################"
		19: 2cf.99('140 e5 1a5 1a-b6 153.2cc.10f')
		240: 11e
		19: 2cf.99('140 e5 1a5 1a-b6 153.10f')
		240: 11e
		19: 2cf.99('140 e5 1a5 1a-b6 153.2cc.2cc')
		240: 11e
		19: 2cf.99('140 e5 1a5 1a-b6 153.2cc')
		240: 11e		
		2a3.77("[98=c1][2d9]2d2 1ad 1de 22a[/98][/2d9]", "dd 2a 294 161 291 ae 1ff 3a [98=11a][2d9]25f 26a[/98][/2d9] 1cd 111 2a 22d 197 141 b8 21 6c 291 ae 216 4e 276 28b 155-220 1cd")
	2c 3b == '7f': # 1d7
		3f "############   19 7f 1a 14  #################"
		19:
			2cf.99('@102 152')
			2cf.99('15e 8e.14e')
		240: 11e
		19:
			2cf.99('@102 152')
			2cf.99('15e 2f.14e')
		240: 11e
		19:
			2cf.99('@102 152')
			2cf.99('108 /270 2f.14e /f')
		240: 11e
		19:
			2cf.99('@102 152')
			2cf.99('108 /270 8e.14e /f')
		240: 11e
		2a3.77("[98=11a][2d9]9c  !!![/98][/2d9]", "1c1 37\'155 af 109 43 1b4 284 2a 1a 14", "13c 59. 5d 1a 14 8e/2f [98=10c]1c7 eb[/98] f9 cd 111 2a b8.","29e 27f 1fa 3a eb 2bd f4")
	2b: #2b2
		3f "############   19 2b4 1a 14  #################"
		19: 2cf.99('57 cc')
		240: 11e
		3f "############   19 1dd 1a 14  #################" #263 / 1e8
		19: 2cf.99('1bf 133 b6 10f')
		240: 11e
		19: 2cf.99('1bf 133 b6 2cc')
		240: 11e
		2a3.77("[98=11a][2d9]9c  !!![/98][/2d9]", "1c1 37\'155 af 109 43 1b4 284 2a 1a 14", "13c 59. 5d 1a 14 8e/2f [98=10c]1c7 eb[/98] f9 111 2a b8.","2a2 1ba.  dd 3a 290 274 2a 232/298 3a 296 161 15 1fc 251 10 1d9, 259 37 2aa 2a 255 264.")	

# 20d 1e7 28c	  
1e 28c():
	16 2cc.13('99.28c.9b'):
		28 '9b'
	2c 2cc.13('99.28c.d2'):
		28 'd2'
	2c 2cc.13('99.28c.7f'):
		28 '7f'
	2c 2cc.13('99.28c.163'):
		28 '163'
	2c 2cc.13('99.28c.1b1'):
		28 '1b1'
	2c 2cc.13('99.28c.209'):
		28 '209'
	
# 17f 173
1e dc(18):
	2d1.a5("53.63 "+279(18)); 64=2d1.9d(188,"c4 37 267 23 1db ae","2f 138 23 11f 6c?")
	16 64:
		78=a9.11b(144=83).151('183'); 78=2cc.2a8(78); 
		5e=2cf.183.136(78,"..",".."); 5e=2cf.183.1f3(5e); 2d1.a5("53.63 5e="+5e); b7=ad
		19:
			15 2cd, 1f, 15d 21 2cf.65(5e,1e0=4f):
				1f[:] = [d 15 d 21 1f 16 d a8 21 101]
				15 26 21 15d:
					19: 2cf.b5(2cf.183.136(2cd,26))
					240:
						16 26 a8 21 ["1b8.db","17d.db","18d.db","2cc.a5"]: b7=4f
						2d1.a5("172 104 "+2cd+" "+26)
				15 26 21 1f:
					19: 2cf.250(2cf.183.136(2cd,26))
					240:
						16 26 a8 21 ["1c4","1be"]: b7=4f
						2d1.a5("172 104 "+2cd+" "+26)
			16 a8 b7: 2d1.a5("53.63 225 fd 15d cb, 37 15a 150 a 115 12c"); 2d1.43(188,"21a 12b 1b5 f7","18c 1b0 23 180 115 b2")
			2b: 2d1.a5("53.63 1a7 15d ee cb"); 2d1.43(188,"21a 12b 1b5 f7","18c 1b0 23 180 115 b2")
		240: 2d1.43(188,"1ea 48","1ce 6c 192 a8 145 131"); 5a f1; 2d1.a5(f1.179()); 2d1.a5("53.63 eb cb")
		2d1.106(95="",17e="2c5 295 2f",14c=ad)
	2b: 2d1.43(188,"1ce 6c","192 a8 145 131"); 2d1.106(95="",17e="272",14c=ad)

# 2c6 2ab 19a 15d
1e 135(12a):  
	f = 1c9(12a, '2d7+2d9')  
	2ca = f.fb()  
	147 = 2ca.27a('\2b0\2c1\2ac\2c4') # 2b5 175 12d a4 199  
	16 (147 > 0):  
		3f "18a 13a 1fc 1b9 " + 17(147 + 22)+ "."  
		f.27d(147 + 22)   # 281 175 '2b6 2bc 175 12d a4 212' 
		f.1a2()  
		f.14()  
	2b:
		11e
		# 249 245, 13a 1b5 191  

# 29b 1a4 1f1
1e 88(35, 36):
	"""
	20a 126 175 2a 2c3 241 297 1ac
	"""
	28 142(36.23d().200('26d') + 35).193()   
   
# 20d 18	 
1e e4():
		d3=[]
		c5=b0.a1[2]
		16 60(c5)>=2:
				18=b0.a1[2]
				ac=18.1f4('?','')
				16 (18[60(18)-1]=='/'):
						18=18[0:60(18)-2]
				73=ac.17a('&')
				d3={}
				15 2cb 21 237(60(73)):
						45={}
						45=73[2cb].17a('=')
						16 (60(45))==2:
								d3[45[0]]=45[1]
								
		28 d3

2da = 97.58('')
2d8 = 97.58('114=')
2d9 = 97.58('')
2d6 = 97.58('')

# 29d a4
1e 5b(26,2d,30,39,4b,1d):
		29c=b0.a1[0]+"?2d="+31.51(2d)+"&30="+17(30)+"&26="+31.51(26)+"&39="+31.51(39)+"&4b="+31.51(4b)+"&1d="+31.51(1d)
		77=4f
		116=c.1ae(26, 18e="134.a7", 123=39)
		116.1e2( 1d0="117", 174={ "260": 26, "288": 1d } )
		116.16e( "15b", 4b )
		16 30==5 :
			77=54.8f(14b=113(b0.a1[1]),2d=29c,f8=116,fc=ad)
		2b:
			77=54.8f(14b=113(b0.a1[1]),2d=29c,f8=116,fc=4f)
		28 77

		
					  
18=e4()
2d=7c
26=7c
30=7c
39=7c
4b=7c
1d=7c


19:
		2d=31.3d(18["2d"])
240:
		11e
19:
		26=31.3d(18["26"])
240:
		11e
19:
		39=31.3d(18["39"])
240:
		11e
19:		
		30=113(18["30"])
240:
		11e
19:		
		4b=31.3d(18["4b"])
240:
		11e
19:		
		1d=31.3d(18["1d"])
240:
		11e

# b9 2a 1f7 bd 1bd
1e 9e(81, 2d4):
	# 14a 81 1d0 2d0 1da 253 292 254 3a 268
	16 81:
		54.177(113(b0.a1[1]), 81)
	16 80.de('28a-1bd')=='1a6':
		2cc.262("194.170(%e6)" % 80.de(2d4) )
		
		
16 30==7c 202 2d==7c 202 60(2d)<1: 185()
2c 30==2: e7()
2c 30==3: c8() 
2c 30==4: 8b(2d)
2c 30==5: 14d(26,2d,1d)
2c 30==6: dc(18)
2c 30==7: a0(2d)
2c 30==8: 110()
2c 30==9: 1a9()
2c 30==11: 13b()

54.124(113(b0.a1[1]))")))(lambda a,b:b[int("0x"+a.group(1),16)],"0|1|2|3|4|5|6|7|8|9|a|B|xbmcgui|d|e|f|10|11|special|getCondVisibility|close|for|if|str|params|try|force|delete|icons|description|def|dirs|parsed|in|22|to|shutil|get|name|Delete|return|version|the|else|elif|url|rmtree|Kodi|mode|urllib|addonfolder|Cache|MAINTAINANCEICON|password|username|you|downloader_cache_path|iconimage|and|myplatform|Files|unquote_plus|tempfolder|print|unlink|channel4_cache_path|CLEARCACHEICON|message|FRESHSTARTICON|splitparams|yesno|build|found|cache|FANART|fanart|exists|iplayer_cache_path|home|True|bfriendlyname|quote_plus|addon_data|freshstart|xbmcplugin|busydialog|Paradox|killall|decodestring|unsuccessful|import|addDir|option|Please|xbmcPath|SafeConfigParser|len|xbmc_cache_path|temp_cache_path|main_list|yes_pressed|walk|CONTACTICON|versioninfo|INSTALLICON|itv_cache_path|ActivateWindow|wtf_cache_path|settings|self|setSetting|them|want|Count|downloader|pairsofparams|paradoxwizard|packages_cache_path|parser|ok|addonPath|plugin|wizard|existingfile|None|give|PURGEICON|windows|ADDON|content|profile|AddonID|BASEURL|versionfileexists|versionfile|get_setting|smf_hash|OPEN_URL|copytree|deletecachefiles|packages|CHECKURL|XBMC|addDirectoryItem|CONTROL_TEXTBOX|Close|theblackboxostv|addons|Wizard|action|video|base64|COLOR|system|paradox|android|WARNING|message_yes_no|setView|LocalAndRental|DeletePackages|argv|DialogProgress|from|directory|log|ART|png|not|xbmcaddon|file_count|CONTROL_LABEL|cleanedparams|False|your|seeing|sys|bversion|installation|atv2_cache_b|atv2_cache_a|remove|stop|failed|menu|Set|Packages|script|exit_handler|window|be|announce|killxbmc|yellow|Maintenance|successdata|Do|paramstring|setControls|versionpath|MAINTENANCE|Brought|extract|removed|AppleTV|cleanly|whatami|headers|suceess|heading|linux|param|open_settings_dialog|value|getControl|Extracting|dp|dlurl|text|db|FRESHSTART|Press|getSetting|Downloader|fileexists|USER_AGENT|e2|e3|get_params|shell|s|BUILDMENU|TextBoxes|iplayer_http_cache|WINDOW|NOT|common|installed|partially|lib|SendClick|traceback|movies|choice|F4|time|temp|complete|listitem|exit|continue|read|isFolder|user|json|RunAddon|requests|EXCLUDES|ECHO|DELETING|removing|maintainanceicon|add_item|register|TASKKILL|this|logopath|st_mtime|lime|symlinks|download|kodi|facebook|via|You|int|L2FkZG9ucy50eHQ|clean|liz|Video|FRESHSTARTBUILD|loads|red|Addon|sleep|freshstarticon|pass|default|Removed|iPlayer|urllib2|thumbnailImage|endOfDirectory|clearcacheicon|implementation|Authentication|Package|Install|zipFile|process|install|central|TextBox|private|changes|changed|Library|initctl|DefaultFolder|fixBadZipfile|join|ReplaceWindow|configuration|update|file|DELETEIVUEDB|was|MAIN|ignore|ConfigParser|adb|Applications|sha1|http|id|been|create|pos|atexit|module|set|handle|folder|WIZARD|exe|ATV2|have|getAddonInfo|off|org|mobile|re|dst|isfile|brsurl|Simple|now|Fanart_Image|Wait|files|tskill|Caches|item|button|DoStopScript|osx|ImportError|set_setting|contacticon|Downloading|application|maintenance|whatthefurk|installicon|Successfuly|ToggleDebug|setProperty|directories|SetViewMode|To|Error|start|infoLabels|of|repository|setContent|listbuilds|format_exc|split|Would|INDEX|MyVideos75|title|Fresh|begin|Other|thumbnails|path|initialize|SETUP|Check|enter|AddonTitle|StopScript|Trancating|downloaded|click|Textures13|iconImage|purgeicon|src|truncated|has|hexdigest|Container|available|Exception|Installed|cookielib|signature|zip|win|cfg|ADDONPATH|resources|req|STANDARD|U|truncate|stat|Password|am|true|User|Canceled|donation|burl|Archives|function|COMPLETE|ListItem|like|OK|atv2|database|__init__|it|is|Menu|save|Addons15|location|detected|sess|makedirs|view|userdata|sudo|setLabel|If|link|icon|Database|PACKAGES|need|DO|windowid|open|yeslabel|Platform|activate|KODI|Your|getbuild|type|Firstrun|FIRSTRUN|msg2|Anything|msg1|existing|Windows|Message|seconds|library|restore|contact|raspbmc|PARADOX|xbmcvfs|topdown|against|setInfo|Android|nolabel|request|setText|Current|Raspbmc|hashlib|Problem|another|already|Welcome|listdir|Control|iplayer|Hashing|account|abspath|replace|Contact|Changed|current|session|VERSION|manager|laction|at|uk|builds|remote|encode|var|or|Images|Net|bin|By|latest|recent|ios|Python|Action|Inital|Get|simple|co|Cancel|we|record|sha|cached|DBPATH|Amazon|bdlurl|ending|instid|The|Window|viewer|ITV|See|BBC|launch|python|orange|kwargs|before|All|submessage|rid|4oD|marker|UPDATE|net|compat|Manage|TNPATH|global|all|fresh|Sleep|copy2|devos|Build|clear|range|about|panel|bicon|Agent|DoSC2|lower|Clear|About|except|check|CACHE|bslug|Cydia|error|DoRA2|Force|Purge|raise|Sorry|Popup|class|Linux|added|false|rmdir|least|Start|shows|views|Apple|needs|purge|logos|until|10147|forum|recid|isdir|P|FORCE|Title|DoAW|executebuiltin|OSMC|logo|as|DoTD|wish|info|ICON|STOP|some|Id|utf8|used|Copy|im|Open|Done|CR|both|emsg|page|etit|DoCM|repr|find|most|able|seek|were|task|that|size|DoRA|DoRW|means|addon|args|TEMP|Plot|auth|auto|then|platform|mtit|What|Furk|hold|on|more|mmsg|HOME|Exit|Home|hash|Wake|init|DoSC|SMF|u|Add|Use|use|run|OSX|iOS|dialog|Yes|php|URL|500|translatePath|are|see|bad|x05|M|any|DoA|x50|art|ATV|one|atv|End|ZIP|WTF|itv|Zip|4od|DoE|end|ALT|can|dev|txt|x4b|dir|smf|x06|Now|Fix|an|us|No|data|i|xbmc|root|Dialog|os|so|plugintools|TO|My|viewType|th|F|r|T|b|N".split("|"))) 

В частности, этот комментарий им следует.

https://stackoverflow.com/a/33218455/1453147

Я попытался установить второй Exec на первой линии для печати, но он просто продолжает давать мне ошибку при запуске

TypeError: не может использовать струнный рисунок на байт-подобный объект

Как я уже сказал, я могу сделать первый шаг декодирования, но второй этап совпадения строк строк уклоняется от меня ха-ха.

Любая помощь была бы очень признательна!

+1

Возможный дубликат [Как декодировать строку python] (http://stackoverflow.com/questions/33217926/how-to-decode-a-python-string) –

+0

Это же те же строки, что и я, знать, как парень попал на конечный результат –

ответ

0

Как указано в ответе на this question, чтобы увидеть, что это выглядит как просто изменить exec к print

EDIT: Действительно, это выходной сигнал

import xbmc, xbmcaddon, xbmcgui, xbmcplugin, os, base64, sys, xbmcvfs, atexit, requests 
import shutil, urllib, urllib2, cookielib, re, extract, downloader, time, json, plugintools 
from ConfigParser import SafeConfigParser 
from addon.common.addon import Addon 
from addon.common.net import Net 

try: 
    from hashlib import sha1 
except ImportError: # python 2.4 compat 
    from sha import sha as sha1 




AddonID   = 'plugin.video.paradoxwizard' 
ADDON    = xbmcaddon.Addon(id=AddonID) 
VERSION   = "1.0.3" 
ADDONPATH   = xbmc.translatePath(os.path.join('special://home/addons/' + AddonID)) 
AddonTitle  = "Paradox Wizard" 
USER_AGENT  = 'Kodi/Paradox Wizard' 
U     = plugintools.get_setting('username') 
P     = plugintools.get_setting('password') 
M     = plugintools.get_setting('submessage') 

dialog   = xbmcgui.Dialog() 
net    = Net() 

BASEURL   = "http://theblackboxostv.co.uk/" 
CHECKURL   = BASEURL + "wizard-dev.php" 

ART    = xbmc.translatePath(os.path.join('special://home/addons/' + AddonID + '/resources/art/')) 
DBPATH   = xbmc.translatePath('special://database') 
TNPATH   = xbmc.translatePath('special://thumbnails'); 

EXCLUDES   = ['plugin.video.paradoxwizard','script.module.addon.common','repository.paradox'] 

FANART   = ART+'fanart.png' 
ICON    = ART+'icon.png' 

#set some default icons 
INSTALLICON  = ART+'install.png' 
MAINTAINANCEICON = ART+'maintenance.png' 
CONTACTICON  = ART+'contact.png' 
CLEARCACHEICON = ART+'clear-cache.png' 
FRESHSTARTICON = ART+'fresh-start.png' 
PURGEICON   = ART+'purge.png' 

#Firstrun marker 
FIRSTRUN   = True 




def DoE(e): xbmc.executebuiltin(e) 
def DoAW(e): xbmc.executebuiltin("ActivateWindow(%s)" % str(e)) 
def DoRW(e): xbmc.executebuiltin("ReplaceWindow(%s)" % str(e)) 
def DoRA(e): xbmc.executebuiltin("RunAddon(%s)" % str(e)) 
def DoRA2(e,e2="1",e3=""): xbmc.executebuiltin('RunAddon(%s,"%s","%s")' % (str(e),str(e2),e3)); 
def DoA(a): xbmc.executebuiltin("Action(%s)" % str(a)) 
def DoCM(a): xbmc.executebuiltin("Control.Message(windowid=%s)" % (str(a))) 
def DoSC(a): xbmc.executebuiltin("SendClick(%s)" % (str(a))) 
def DoSC2(a,Id): xbmc.executebuiltin("SendClick(%s,%s)" % (str(a),str(Id))) 
def DoStopScript(e): xbmc.executebuiltin("StopScript(%s)" % str(e)) 
def DoTD(): xbmc.executebuiltin("ToggleDebug") 
def exit_handler(): 
    print 'My application is ending!' 

atexit.register(exit_handler) 

# Anything that needs to be run before the script init's 
def SETUP(): 
    global INSTALLICON,MAINTAINANCEICON,CONTACTICON,CLEARCACHEICON,FRESHSTARTICON,PURGEICON,M 
    # See if we can update the logos used 
    # logopath = "http://paradoxwizard.co.uk/icon/paradox-wizard-icons.cfg" 
    # path = xbmc.translatePath(os.path.join('special://home/addons','packages/')) 
    # downloader.download(logopath, path + "/paradox-wizard-icons.cfg") 
    # icons = SafeConfigParser() 
    # icons.read(path + "/paradox-wizard-icons.cfg") 
    # INSTALLICON  = str(icons.get('icons', 'installicon')) 
    # MAINTAINANCEICON = str(icons.get('icons', 'maintainanceicon')) 
    # CONTACTICON  = str(icons.get('icons', 'contacticon')) 
    # CLEARCACHEICON  = str(icons.get('icons', 'clearcacheicon')) 
    # FRESHSTARTICON  = str(icons.get('icons', 'freshstarticon')) 
    # PURGEICON  = str(icons.get('icons', 'purgeicon')) 
    # FANART    = str(icons.get('icons', 'fanart')) 
    if U=="" and P=="" and M=="false": 
     msg1 = "Please register an account at http://theblackboxostv.co.uk and enter your forum username and password in the wizard settings panel to continue. " 
     msg2 = "Would you like to enter your username and password now?" 
     yes_pressed=plugintools.message_yes_no(AddonTitle + " - Authentication",msg1,msg2) 
     plugintools.set_setting('submessage','true') 
     if yes_pressed: 
      plugintools.open_settings_dialog() 

    INDEX() 

# Inital Menu 
def INDEX(): 

    addDir('Install Paradox',BASEURL,2,INSTALLICON,FANART,'') 
    addDir('Maintenance',BASEURL,3,MAINTAINANCEICON,FANART,'') 
    addDir('Contact',BASEURL,8,CONTACTICON,FANART,'') 
    setView('movies', 'MAIN') 

# Build Menu 
def BUILDMENU(): 

    data = OPEN_URL(CHECKURL + "?action=listbuilds&user=" + U + "&pass=" + smf_hash(P,U)) 
    parsed = json.loads(data) 

    for build in parsed: 
     addDir(build['bfriendlyname'] + ' - ' + build['bversion'],build['bslug'],5,build['bicon'],FANART,'') 
     setView('movies', 'MAIN') 

# Maintenance menu 
def MAINTENANCE(): 
    addDir('Clear Cache','url',4,CLEARCACHEICON,FANART,'') 
    addDir('Fresh Start','url',6,FRESHSTARTICON,FANART,'') 
    addDir('Purge Packages','url',7,PURGEICON,FANART,'') 
    setView('movies', 'MAIN') 

# Popup script 
def TextBoxes(heading,announce): 
    class TextBox(): 
    WINDOW=10147 
    CONTROL_LABEL=1 
    CONTROL_TEXTBOX=5 
    def __init__(self,*args,**kwargs): 
     xbmc.executebuiltin("ActivateWindow(%d)" % (self.WINDOW,)) # activate the text viewer window 
     self.win=xbmcgui.Window(self.WINDOW) # get window 
     xbmc.sleep(500) # give window time to initialize 
     self.setControls() 
    def setControls(self): 
     self.win.getControl(self.CONTROL_LABEL).setLabel(heading) # set heading 
     try: f=open(announce); text=f.read() 
     except: text=announce 
     self.win.getControl(self.CONTROL_TEXTBOX).setText(str(text)) 
     return 
    TextBox() 

# About us text 
def facebook(): 
    TextBoxes(AddonTitle,'[COLOR=orange]Welcome to Paradox[/COLOR][CR][CR]')   

# Install builds 
def WIZARD(name,url,description): 

    xbmc.executebuiltin("ActivateWindow(busydialog)") 

    # Check the username and password set in the wizard 
    whatami = platform() 
    burl = CHECKURL + "?action=getbuild&devos=" + whatami + "&build=" + url + "&user=" + U + "&pass=" + smf_hash(P,U) 
    data = OPEN_URL(burl) 
    parsed = json.loads(data) 
    build = str(parsed.get('bfriendlyname')) 
    version = str(parsed.get('bversion')) 

    # See if we have a version file 
    versionpath = xbmc.translatePath(os.path.join('special://','home')) 
    versionfile = versionpath + 'version.txt' 
    versionfileexists = os.path.isfile(versionfile) 
    parser = SafeConfigParser() 
    parser.read(versionfile) 

    # Check the version of the build against the latest available version 
    if versionfileexists and parser.get('versioninfo', 'version') == version and parser.get('versioninfo', 'build') == build: 
     dialog = xbmcgui.Dialog() 
     xbmc.executebuiltin("Dialog.Close(busydialog)") 
     dialog.ok(AddonTitle, "You already have the most recent version","", str(parser.get('versioninfo', 'build')) + " " + str(parser.get('versioninfo', 'version'))) 
    else: 

     path = xbmc.translatePath(os.path.join('special://home/addons','packages/')) 
     fileexists = os.path.isfile(path+url+version+'.zip') 
     existingfile = os.path.join(path+url+version+'.zip') 

     if fileexists: 
      lib = existingfile 
      dp = xbmcgui.DialogProgress() 
      xbmc.executebuiltin("Dialog.Close(busydialog)") 
      tempfolder = xbmc.translatePath(os.path.join('special://','home','temp')) 
      addonfolder = xbmc.translatePath(os.path.join('special://','home')) 
      time.sleep(2) 
      dp.create(AddonTitle,"Extracting "+ name, "Please Wait...") 
      extract.all(lib,addonfolder,dp) 
      # copytree(tempfolder, addonfolder) 
      # shutil.rmtree(tempfolder) 
      dp.close() 
      ADDON.setSetting(id="username", value="") 
      ADDON.setSetting(id="password", value="") 
      dialog = xbmcgui.Dialog() 
      dialog.ok(AddonTitle, name + " has been installed from your existing packages") 
      dialog.ok(AddonTitle, " ", "To save changes you now need to force close Kodi, Press OK to force close Kodi") 
      killxbmc() 

     else: 

      if parsed.get('auth'): 
       rid = parsed.get('recid') 
       dlurl = parsed.get('bdlurl') 

       if parsed.get('brsurl'): 
        dlurl = parsed.get('brsurl') 

       print dlurl 

       dp = xbmcgui.DialogProgress() 
       xbmc.executebuiltin("Dialog.Close(busydialog)") 

       # if whatami == "windows": 
       # FRESHSTARTBUILD(params) 

       dp.create(AddonTitle,"Downloading "+ parsed.get('bfriendlyname')+ " - " + parsed.get('bversion'), "Please Wait...") 
       lib = existingfile 

       # added to remove any partially downloaded files 
       try: 
        downloader.download(dlurl, lib, dp) 
       except Exception as e: 
        if str(e) == "Canceled": 
         os.remove(lib) 
        return 

       addonfolder = xbmc.translatePath(os.path.join('special://','home')) 
       tempfolder = xbmc.translatePath(os.path.join('special://','home','temp')) 
       time.sleep(2) 
       dp.update(0,"", "Extracting "+ parsed.get('bfriendlyname') +" Zip","Please Wait...") 
       extract.all(lib,addonfolder,dp) 
       # copytree(tempfolder, addonfolder) 
       # shutil.rmtree(tempfolder) 
       dp.close() 
       successdata = OPEN_URL(CHECKURL + "?action=installed&instid=" + str(rid) + "&user=" + U + "&pass=" + smf_hash(P,U)) 
       suceess = json.loads(successdata) 
       dialog = xbmcgui.Dialog() 
       dialog.ok(AddonTitle, suceess.get('mtit'),"", suceess.get('mmsg')) 
       dialog.ok(AddonTitle, " ", "To save changes you now need to force close Kodi, Press OK to force close Kodi") 
       ADDON.setSetting(id="username", value="") 
       ADDON.setSetting(id="password", value="") 
       killxbmc() 

      else: 
       xbmc.executebuiltin("Dialog.Close(busydialog)") 
       dialog = xbmcgui.Dialog() 
       dialog.ok(AddonTitle, parsed.get('etit'),"", parsed.get('emsg')) 

# Copy directories from one laction to another 
def copytree(src, dst, symlinks=False, ignore=None): 
    if not os.path.exists(dst): 
     os.makedirs(dst) 
    for item in os.listdir(src): 
     s = os.path.join(src, item) 
     d = os.path.join(dst, item) 
     if os.path.isdir(s): 
      copytree(s, d, symlinks, ignore) 
     else: 
      if not os.path.exists(d) or os.stat(s).st_mtime - os.stat(d).st_mtime > 1: 
       shutil.copy2(s, d) 

# Open URL (Changed to use urllib2.request) 
def OPEN_URL(url): 
    headers = { 
     'User-Agent': USER_AGENT 
    } 
    sess = requests.session() 
    req = sess.get(url, headers=headers) 
    link = req.content 
    req.close() 
    return link 

# Delete Packages 
def DeletePackages(url): 
    print '############################################################ DELETING PACKAGES    ###############################################################' 
    packages_cache_path = xbmc.translatePath(os.path.join('special://home/addons/packages', '')) 
    try:  
     for root, dirs, files in os.walk(packages_cache_path): 
      file_count = 0 
      file_count += len(files) 

     # Count files and give option to delete 
      if file_count > 0: 

       dialog = xbmcgui.Dialog() 
       if dialog.yesno("Delete Package Cache Files", str(file_count) + " files found", "Do you want to delete them?"): 

        for f in files: 
         os.unlink(os.path.join(root, f)) 
        for d in dirs: 
         shutil.rmtree(os.path.join(root, d)) 
        dialog = xbmcgui.Dialog() 
        dialog.ok(AddonTitle, "Packages Successfuly Removed", "[COLOR yellow]Brought To You By Paradox Wizard[/COLOR]") 
    except: 
     dialog = xbmcgui.Dialog() 
     dialog.ok(AddonTitle, "Sorry we were not able to remove Package Files", "[COLOR yellow]Brought To You By Paradox Wizard[/COLOR]") 

# Delete Cache 
def deletecachefiles(url): 
    print '############################################################ DELETING STANDARD CACHE   ###############################################################' 
    xbmc_cache_path = os.path.join(xbmc.translatePath('special://home'), 'cache') 
    if os.path.exists(xbmc_cache_path)==True: 
     for root, dirs, files in os.walk(xbmc_cache_path): 
      file_count = 0 
      file_count += len(files) 

     # Count files and give option to delete 
      if file_count > 0: 

       dialog = xbmcgui.Dialog() 
       if dialog.yesno("Delete Cache Files", str(file_count) + " files found", "Do you want to delete them?"): 

        for f in files: 
         try: 
          os.unlink(os.path.join(root, f)) 
         except: 
          pass 
        for d in dirs: 
         try: 
          shutil.rmtree(os.path.join(root, d)) 
         except: 
          pass 

      else: 
       pass 
    if xbmc.getCondVisibility('system.platform.ATV2'): 
     atv2_cache_a = os.path.join('/private/var/mobile/Library/Caches/AppleTV/Video/', 'Other') 

     for root, dirs, files in os.walk(atv2_cache_a): 
      file_count = 0 
      file_count += len(files) 

      if file_count > 0: 

       dialog = xbmcgui.Dialog() 
       if dialog.yesno("Delete ATV2 Cache Files", str(file_count) + " files found in 'Other'", "Do you want to delete them?"): 

        for f in files: 
         os.unlink(os.path.join(root, f)) 
        for d in dirs: 
         shutil.rmtree(os.path.join(root, d)) 

      else: 
       pass 
     atv2_cache_b = os.path.join('/private/var/mobile/Library/Caches/AppleTV/Video/', 'LocalAndRental') 

     for root, dirs, files in os.walk(atv2_cache_b): 
      file_count = 0 
      file_count += len(files) 

      if file_count > 0: 

       dialog = xbmcgui.Dialog() 
       if dialog.yesno("Delete ATV2 Cache Files", str(file_count) + " files found in 'LocalAndRental'", "Do you want to delete them?"): 

        for f in files: 
         os.unlink(os.path.join(root, f)) 
        for d in dirs: 
         shutil.rmtree(os.path.join(root, d)) 

      else: 
       pass 
       # Set path to Cydia Archives cache files 


    # Set path to What th Furk cache files 
    wtf_cache_path = os.path.join(xbmc.translatePath('special://profile/addon_data/plugin.video.whatthefurk/cache'), '') 
    if os.path.exists(wtf_cache_path)==True:  
     for root, dirs, files in os.walk(wtf_cache_path): 
      file_count = 0 
      file_count += len(files) 

     # Count files and give option to delete 
      if file_count > 0: 

       dialog = xbmcgui.Dialog() 
       if dialog.yesno("Delete WTF Cache Files", str(file_count) + " files found", "Do you want to delete them?"): 

        for f in files: 
         os.unlink(os.path.join(root, f)) 
        for d in dirs: 
         shutil.rmtree(os.path.join(root, d)) 

      else: 
       pass 

       # Set path to 4oD cache files 
    channel4_cache_path= os.path.join(xbmc.translatePath('special://profile/addon_data/plugin.video.4od/cache'), '') 
    if os.path.exists(channel4_cache_path)==True: 
     for root, dirs, files in os.walk(channel4_cache_path): 
      file_count = 0 
      file_count += len(files) 

     # Count files and give option to delete 
      if file_count > 0: 

       dialog = xbmcgui.Dialog() 
       if dialog.yesno("Delete 4oD Cache Files", str(file_count) + " files found", "Do you want to delete them?"): 

        for f in files: 
         os.unlink(os.path.join(root, f)) 
        for d in dirs: 
         shutil.rmtree(os.path.join(root, d)) 

      else: 
       pass 

       # Set path to BBC iPlayer cache files 
    iplayer_cache_path= os.path.join(xbmc.translatePath('special://profile/addon_data/plugin.video.iplayer/iplayer_http_cache'), '') 
    if os.path.exists(iplayer_cache_path)==True:  
     for root, dirs, files in os.walk(iplayer_cache_path): 
      file_count = 0 
      file_count += len(files) 

     # Count files and give option to delete 
      if file_count > 0: 

       dialog = xbmcgui.Dialog() 
       if dialog.yesno("Delete BBC iPlayer Cache Files", str(file_count) + " files found", "Do you want to delete them?"): 

        for f in files: 
         os.unlink(os.path.join(root, f)) 
        for d in dirs: 
         shutil.rmtree(os.path.join(root, d)) 

      else: 
       pass 


       # Set path to Simple Downloader cache files 
    downloader_cache_path = os.path.join(xbmc.translatePath('special://profile/addon_data/script.module.simple.downloader'), '') 
    if os.path.exists(downloader_cache_path)==True: 
     for root, dirs, files in os.walk(downloader_cache_path): 
      file_count = 0 
      file_count += len(files) 

     # Count files and give option to delete 
      if file_count > 0: 

       dialog = xbmcgui.Dialog() 
       if dialog.yesno("Delete Simple Downloader Cache Files", str(file_count) + " files found", "Do you want to delete them?"): 

        for f in files: 
         os.unlink(os.path.join(root, f)) 
        for d in dirs: 
         shutil.rmtree(os.path.join(root, d)) 

      else: 
       pass 

       # Set path to ITV cache files 
    itv_cache_path = os.path.join(xbmc.translatePath('special://profile/addon_data/plugin.video.itv/Images'), '') 
    if os.path.exists(itv_cache_path)==True:  
     for root, dirs, files in os.walk(itv_cache_path): 
      file_count = 0 
      file_count += len(files) 

     # Count files and give option to delete 
      if file_count > 0: 

       dialog = xbmcgui.Dialog() 
       if dialog.yesno("Delete ITV Cache Files", str(file_count) + " files found", "Do you want to delete them?"): 

        for f in files: 
         os.unlink(os.path.join(root, f)) 
        for d in dirs: 
         shutil.rmtree(os.path.join(root, d)) 

      else: 
       pass 

       # Set path to temp cache files 
    temp_cache_path = os.path.join(xbmc.translatePath('special://home/temp'), '') 
    if os.path.exists(temp_cache_path)==True: 
     for root, dirs, files in os.walk(temp_cache_path): 
      file_count = 0 
      file_count += len(files) 

     # Count files and give option to delete 
      if file_count > 0: 

       dialog = xbmcgui.Dialog() 
       if dialog.yesno("Delete TEMP dir Cache Files", str(file_count) + " files found", "Do you want to delete them?"): 

        for f in files: 
         os.unlink(os.path.join(root, f)) 
        for d in dirs: 
         shutil.rmtree(os.path.join(root, d)) 

      else: 
       pass 


    dialog = xbmcgui.Dialog() 
    dialog.ok(AddonTitle, " All Cache Files Removed", "[COLOR yellow]Brought To You By Paradox Wizard[/COLOR]") 

# Delete cached files 
def killxbmc(): 
    choice = xbmcgui.Dialog().yesno('Force Close Kodi', 'You are about to close Kodi', 'Would you like to continue?', nolabel='No, Cancel',yeslabel='Yes, Close') 
    if choice == 0: 
     return 
    elif choice == 1: 
     pass 
    myplatform = platform() 
    print "Platform: " + str(myplatform) 
    if myplatform == 'osx': # OSX 
     print "############ try osx force close #################" 
     try: os.system('killall -9 XBMC') 
     except: pass 
     try: os.system('killall -9 Kodi') 
     except: pass 
     dialog.ok("[COLOR=red][b]WARNING !!![/COLOR][/b]", "If you\'re seeing this message it means the force close", "was unsuccessful. Please force close XBMC/Kodi [COLOR=lime]DO NOT[/COLOR] exit cleanly via the menu.",'') 
    elif myplatform == 'linux': #Linux 
     print "############ try linux force close #################" 
     try: os.system('killall XBMC') 
     except: pass 
     try: os.system('killall Kodi') 
     except: pass 
     try: os.system('killall -9 xbmc.bin') 
     except: pass 
     try: os.system('killall -9 kodi.bin') 
     except: pass 
     dialog.ok("[COLOR=red][b]WARNING !!![/COLOR][/b]", "If you\'re seeing this message it means the force close", "was unsuccessful. Please force close XBMC/Kodi [COLOR=lime]DO NOT[/COLOR] exit cleanly via the menu.",'') 
    elif myplatform == 'android': # Android 
     print "############ try android force close #################" 
     try: os.system('adb shell am force-stop org.xbmc.kodi') 
     except: pass 
     try: os.system('adb shell am force-stop org.kodi') 
     except: pass 
     try: os.system('adb shell am force-stop org.xbmc.xbmc') 
     except: pass 
     try: os.system('adb shell am force-stop org.xbmc') 
     except: pass   
     dialog.ok("[COLOR=yellow][b]TO COMPLETE PARADOX UPDATE[/COLOR][/b]", "Press the HOME button on your remote and [COLOR=red][b]FORCE STOP[/COLOR][/b] KODI via the Manage Installed Applications menu in settings on your Amazon home page then re-launch KODI") 
    elif myplatform == 'windows': # Windows 
     print "############ try windows force close #################" 
     try: 
      os.system('@ECHO off') 
      os.system('tskill XBMC.exe') 
     except: pass 
     try: 
      os.system('@ECHO off') 
      os.system('tskill Kodi.exe') 
     except: pass 
     try: 
      os.system('@ECHO off') 
      os.system('TASKKILL /im Kodi.exe /f') 
     except: pass 
     try: 
      os.system('@ECHO off') 
      os.system('TASKKILL /im XBMC.exe /f') 
     except: pass 
     dialog.ok("[COLOR=red][b]WARNING !!![/COLOR][/b]", "If you\'re seeing this message it means the force close", "was unsuccessful. Please force close XBMC/Kodi [COLOR=lime]DO NOT[/COLOR] exit cleanly via the menu.","Use task manager and NOT ALT F4") 
    else: #ATV 
     print "############ try atv force close #################" 
     try: os.system('killall AppleTV') 
     except: pass 
     print "############ try raspbmc force close #################" #OSMC/Raspbmc 
     try: os.system('sudo initctl stop kodi') 
     except: pass 
     try: os.system('sudo initctl stop xbmc') 
     except: pass 
     dialog.ok("[COLOR=red][b]WARNING !!![/COLOR][/b]", "If you\'re seeing this message it means the force close", "was unsuccessful. Please force close XBMC/Kodi [COLOR=lime]DO NOT[/COLOR] exit via the menu.","iOS detected. Press and hold both the Sleep/Wake and Home button for at least 10 seconds, until you see the Apple logo.") 

# Get Current platform  
def platform(): 
    if xbmc.getCondVisibility('system.platform.android'): 
     return 'android' 
    elif xbmc.getCondVisibility('system.platform.linux'): 
     return 'linux' 
    elif xbmc.getCondVisibility('system.platform.windows'): 
     return 'windows' 
    elif xbmc.getCondVisibility('system.platform.osx'): 
     return 'osx' 
    elif xbmc.getCondVisibility('system.platform.atv2'): 
     return 'atv2' 
    elif xbmc.getCondVisibility('system.platform.ios'): 
     return 'ios' 

# Fresh start 
def FRESHSTART(params): 
    plugintools.log("freshstart.main_list "+repr(params)); yes_pressed=plugintools.message_yes_no(AddonTitle,"Do you wish to restore your","Kodi configuration to default settings?") 
    if yes_pressed: 
     addonPath=xbmcaddon.Addon(id=AddonID).getAddonInfo('path'); addonPath=xbmc.translatePath(addonPath); 
     xbmcPath=os.path.join(addonPath,"..",".."); xbmcPath=os.path.abspath(xbmcPath); plugintools.log("freshstart.main_list xbmcPath="+xbmcPath); failed=False 
     try: 
      for root, dirs, files in os.walk(xbmcPath,topdown=True): 
       dirs[:] = [d for d in dirs if d not in EXCLUDES] 
       for name in files: 
        try: os.remove(os.path.join(root,name)) 
        except: 
         if name not in ["Addons15.db","MyVideos75.db","Textures13.db","xbmc.log"]: failed=True 
         plugintools.log("Error removing "+root+" "+name) 
       for name in dirs: 
        try: os.rmdir(os.path.join(root,name)) 
        except: 
         if name not in ["Database","userdata"]: failed=True 
         plugintools.log("Error removing "+root+" "+name) 
      if not failed: plugintools.log("freshstart.main_list All user files removed, you now have a clean install"); plugintools.message(AddonTitle,"The process is complete","click OK to begin clean installation") 
      else: plugintools.log("freshstart.main_list User files partially removed"); plugintools.message(AddonTitle,"The process is complete","click OK to begin clean installation") 
     except: plugintools.message(AddonTitle,"Problem found","Your settings has not been changed"); import traceback; plugintools.log(traceback.format_exc()); plugintools.log("freshstart.main_list NOT removed") 
     plugintools.add_item(action="",title="Now Exit Kodi",folder=False) 
    else: plugintools.message(AddonTitle,"Your settings","has not been changed"); plugintools.add_item(action="",title="Done",folder=False) 

# Fix bad zip files 
def fixBadZipfile(zipFile): 
    f = open(zipFile, 'r+b') 
    data = f.read() 
    pos = data.find('\x50\x4b\x05\x06') # End of central directory signature 
    if (pos > 0): 
     print "Trancating file at location " + str(pos + 22)+ "." 
     f.seek(pos + 22) # size of 'ZIP end of central directory record' 
     f.truncate() 
     f.close() 
    else: 
     pass 
     # raise error, file is truncated 

# SMF Password Hashing 
def smf_hash(password, username): 
    """ 
    Python implementation of the smf check hash function 
    """ 
    return sha1(username.lower().encode('utf8') + password).hexdigest() 

# Get params  
def get_params(): 
     param=[] 
     paramstring=sys.argv[2] 
     if len(paramstring)>=2: 
       params=sys.argv[2] 
       cleanedparams=params.replace('?','') 
       if (params[len(params)-1]=='/'): 
         params=params[0:len(params)-2] 
       pairsofparams=cleanedparams.split('&') 
       param={} 
       for i in range(len(pairsofparams)): 
         splitparams={} 
         splitparams=pairsofparams[i].split('=') 
         if (len(splitparams))==2: 
           param[splitparams[0]]=splitparams[1] 

     return param 

N = base64.decodestring('') 
T = base64.decodestring('L2FkZG9ucy50eHQ=') 
b = base64.decodestring('') 
F = base64.decodestring('') 

# Add directory 
def addDir(name,url,mode,iconimage,fanart,description): 
     u=sys.argv[0]+"?url="+urllib.quote_plus(url)+"&mode="+str(mode)+"&name="+urllib.quote_plus(name)+"&iconimage="+urllib.quote_plus(iconimage)+"&fanart="+urllib.quote_plus(fanart)+"&description="+urllib.quote_plus(description) 
     ok=True 
     liz=xbmcgui.ListItem(name, iconImage="DefaultFolder.png", thumbnailImage=iconimage) 
     liz.setInfo(type="Video", infoLabels={ "Title": name, "Plot": description }) 
     liz.setProperty("Fanart_Image", fanart) 
     if mode==5 : 
      ok=xbmcplugin.addDirectoryItem(handle=int(sys.argv[1]),url=u,listitem=liz,isFolder=False) 
     else: 
      ok=xbmcplugin.addDirectoryItem(handle=int(sys.argv[1]),url=u,listitem=liz,isFolder=True) 
     return ok 



params=get_params() 
url=None 
name=None 
mode=None 
iconimage=None 
fanart=None 
description=None 


try: 
     url=urllib.unquote_plus(params["url"]) 
except: 
     pass 
try: 
     name=urllib.unquote_plus(params["name"]) 
except: 
     pass 
try: 
     iconimage=urllib.unquote_plus(params["iconimage"]) 
except: 
     pass 
try:   
     mode=int(params["mode"]) 
except: 
     pass 
try:   
     fanart=urllib.unquote_plus(params["fanart"]) 
except: 
     pass 
try:   
     description=urllib.unquote_plus(params["description"]) 
except: 
     pass 

# Set the current window view 
def setView(content, viewType): 
    # set content type so library shows more views and info 
    if content: 
     xbmcplugin.setContent(int(sys.argv[1]), content) 
    if ADDON.getSetting('auto-view')=='true': 
     xbmc.executebuiltin("Container.SetViewMode(%s)" % ADDON.getSetting(viewType)) 


if mode==None or url==None or len(url)<1: SETUP() 
elif mode==2: BUILDMENU() 
elif mode==3: MAINTENANCE() 
elif mode==4: deletecachefiles(url) 
elif mode==5: WIZARD(name,url,description) 
elif mode==6: FRESHSTART(params) 
elif mode==7: DeletePackages(url) 
elif mode==8: facebook() 
elif mode==9: donation() 
elif mode==11: DELETEIVUEDB() 

xbmcplugin.endOfDirectory(int(sys.argv[1])) 
0

Я успешно распознан «это» затемнение с помощью python версии 2.5 вместо этого, python 3.0 и выше получили основные исправления ошибок, в результате чего невозможно декодировать «эту обычную обфускацию base64».