Exemple #1
0
def sign(request):
	#to do
	print 'LOG:sign -------------- from ' +  getClientIp(request)


	#the user HaiChiang is fixed in the database
	user = User.objects.get(userName='******')
	
	#create the signrequest
	signRequest = {}
	
	key_handle = user.key_handle
	Rand.rand_seed(os.urandom(1024))
	challenge = urlsafe_b64encode(Rand.rand_bytes(32))
	signRequest['signRequests'] = [{'challenge': challenge, 
				'version': 'U2F_V2', 'appId': 'http://localhost:8000', 'keyHandle': key_handle, "sessionId":"123456"}]			
	#signRequest['registerRequests'] = []
	
	strong_signRequest = {}
	strong_signRequest['Challenge'] = signRequest
	strong_signRequest['Message'] = ''
	strong_signRequest['Error'] = ''

	user.challenge = challenge
	return JsonResponse(strong_signRequest)
Exemple #2
0
def com_auth(request):
	#the user HaiChiang is fixed in the database
	user = User.objects.get(userName='******')
	print 'LOG:Chanllenge --------------' +  user.challenge
	
	#to do 
	print 'LOG:com_auth -------------- from ' +  getClientIp(request)
	
	result = 0
	if request.method == 'POST':
		data = json.loads(request.body)
		
		#
		#processing keyhandle
		#
		keyhandle = urlsafe_b64decode(data['keyhandle'].encode('utf-8'))
 		print 'LOG:key_handle ------------- ' + keyhandle
		 
		
		#
		#processing clientdata
		#
		
		#convert the clientdata to a dict structure
		clientdata = urlsafe_b64decode(data['clientData'].encode('utf-8'))
		#clientdata_dict = eval(clientdata)
 		print 'LOG:clientData ------------- ' + clientdata
		
		#
		#processing signature
		#
		signature = urlsafe_b64decode(data['signature'].encode('utf-8'))
		print 'LOG:signature ------------- ' + signature
		
		
		#public key 
		prefix = "3059301306072a8648ce3d020106082a8648ce3d030107034200".decode('hex')
		tail_key = '04EC4FDC9FBDECFE8F21B178693703733C0E3A96BE41590CCF98DCFB2DA8A19BA8A3854E8B5E57D1E01AEDCA8F28B0B643BC890174A08018C34F91D0A79D064548'.decode('hex')
		ec = EC.pub_key_from_der(prefix + tail_key)
		
		#msg
		app_para = ''
		user_presence = ''
		counter = ''
		challen_para = ''
		#msg = app_para + user_presence + counter + challen_para
		msg = '002122232425262728292A2B2C2D2E2F303132333435363738393A3B3C3D3E3F400102030405060708090A0B0C0D0E0F101112131415161718191A1B1C1D1E1F200000000004EC4FDC9FBDECFE8F21B178693703733C0E3A96BE41590CCF98DCFB2DA8A19BA8A3854E8B5E57D1E01AEDCA8F28B0B643BC890174A08018C34F91D0A79D064548'.decode('hex')
		h = sha256()
		h.update(msg)
		
		#signature
		sig = '304402206613ECA917F891ABADEAB63054CE7DFE3F32268FCE7D0AF4B37C6000C9D13B2B022067E717B413597268EF28EC72EE79135EB87026DB14E64776C15CD7335D95402A'.decode('hex')
		
		#verify
		result =  ec.verify_dsa_asn1(h.digest(), sig)
		
	
	return HttpResponse(result)
Exemple #3
0
def enroll(request):
	print 'LOG:enroll -------------- from ' +  getClientIp(request)
	
	enrollRequest, challenge = gen_enroll_challenge()
	
	#create a new user
	User.objects.filter(userName='******').delete()
	user = User.objects.create(userName='******', challenge=challenge)
	user.save()
	
	return JsonResponse(enrollRequest)
Exemple #4
0
def com_register(request):
	print 'LOG:com_register -------------- from ' +  getClientIp(request)
	
	#the user HaiChiang is fixed in the database
	user = User.objects.get(userName='******')
	print 'LOG:Chanllenge --------------' +  user.challenge
	
	result = 0
	##check the client response
	if request.method == 'POST':
		data = json.loads(request.body)
		#print data
		
		
		#
		#processing clientdata
		#
		
		#convert the clientdata to a dict structure
		clientdata = urlsafe_b64decode(data['clientData'].encode('utf-8'))
		clientdata_dict = eval(clientdata)
 		print 'LOG:clientData ------------- ' + clientdata
	
		
		#check the challenge
		#to do 
		if clientdata_dict['challenge'] != user.challenge.encode('utf-8'):
			#print 'LOG:challenge ------------- ' + clientdata_dict['challenge']
			#print type(clientdata_dict['challenge']), type(user.challenge.encode('utf-8'))
			pass
			
			#return HttpResponse(result)
		else:
			print 'LOG:challenge Check ------------- ' + clientdata_dict['challenge']
		
		#check the origin
		#to do 
		if clientdata_dict['origin'] != 'http://xxxx':
			print 'LOG:origin ------------- ' + clientdata_dict['origin']
			pass
			
			#return HttpResponse(result)
		else:
			pass
		
		#check the types
		if clientdata_dict['typ'] != 'navigator.id.finishEnrollment':
			return HttpResponse(result)		
		else:
			print 'LOG:typ checked ------------- ' 	
			
		
		#	
		#check the registrationdata
		#
		registrationdata =  urlsafe_b64decode(data['registrationData'].encode('utf-8'))
		
		
		#check the reserved byte 0x05
		if registrationdata[0:1].encode('hex') == '05':
			print 'LOG: ------------- 0x05 reserved byte checked'
		
			
		registrationdata = registrationdata[1:]
		#get the public key
		public_key = registrationdata[:65]
		print 'LOG:public key ------------- ' + public_key.encode('hex')
		#store
		user.public_key = public_key.encode('hex')
		
		
		#get the key_handle
		registrationdata = registrationdata[65:]
		key_handle_len = registrationdata[:1]
		print 'LOG:key handle len ---------' + key_handle_len.encode('hex')
		key_handle = registrationdata[1:65]
		print 'LOG:key handle ----------' + key_handle.encode('hex')
		#store
		user.key_handle = key_handle.encode('hex')
		
		
		#get the attestation cert
		registrationdata = registrationdata[65:]
		cert = X509.load_cert_der_string(registrationdata)
		print 'LOG:attestation cert ----------' + registrationdata[:len(cert.as_der())].encode('hex')

		
		#get the signature & verify it
		registrationdata = registrationdata[len(cert.as_der()):]
		sig = registrationdata
		print 'LOG:signature ----------' + sig.encode('hex')
		
		h0 = sha256()
		h0.update('http://localhost:8000')
		app_para = h0.digest()
		print 'LOG:app_para --------' + app_para.encode('hex')
		 
		h1 = sha256()
		h1.update(str(clientdata))
		print type(str(clientdata)), str(clientdata)
		challen_para = h1.digest()
		print 'LOG:cha_para --------' + challen_para.encode('hex')
		
		
		msg = chr(0x00) + app_para + challen_para + key_handle + public_key


		# print len(app_para), len(challen_para), len(key_handle), len(public_key)

		
		puk = cert.get_pubkey()
		puk.reset_context('sha256')
		puk.verify_init()
		puk.verify_update(msg)
		result = puk.verify_final(sig)
		if result == 1:
			user.save()
		print result		
		
		
	#User.objects.filter(userName='******').delete()
	return HttpResponse(result)