1.8.x.2610
This commit is contained in:
		
							parent
							
								
									78d8f54377
								
							
						
					
					
						commit
						90b50d4367
					
				
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							|  | @ -98,9 +98,12 @@ if (path == '/nevisfido/fido2/attestation/options') { | ||||||
|     } |     } | ||||||
|     post(connection, json) |     post(connection, json) | ||||||
|     def responseCode = connection.responseCode |     def responseCode = connection.responseCode | ||||||
|  |     def responseText = responseCode == 200 ? connection.inputStream.text : '{"allowCredentials":[]}' | ||||||
|  |     def jsonResponse = new JsonSlurper().parseText(responseText) | ||||||
|  |     def numOfKeys = jsonResponse.allowCredentials ? jsonResponse.allowCredentials.size() : 0 | ||||||
| 
 | 
 | ||||||
|     // non existing account, or account without FIDO2 key case |     // non existing account, account without FIDO2 key , or account with disabled FIDO2 key case | ||||||
|     if (responseCode == 404 || responseCode == 400) { |     if (responseCode == 404 || responseCode == 400 || numOfKeys == 0) { | ||||||
| 
 | 
 | ||||||
|       LOG.debug("Fido2Auth: <== Response: ${responseCode}") |       LOG.debug("Fido2Auth: <== Response: ${responseCode}") | ||||||
| 
 | 
 | ||||||
|  | @ -113,36 +116,36 @@ if (path == '/nevisfido/fido2/attestation/options') { | ||||||
|       def sourceIp = request.getLoginContext()['connection.HttpHeader.X-Real-IP'] ?: 'unknown' |       def sourceIp = request.getLoginContext()['connection.HttpHeader.X-Real-IP'] ?: 'unknown' | ||||||
|       def userAgent = request.getLoginContext()['connection.HttpHeader.user-agent'] ?: request.getLoginContext()['connection.HttpHeader.User-Agent'] ?: 'unknown' |       def userAgent = request.getLoginContext()['connection.HttpHeader.user-agent'] ?: request.getLoginContext()['connection.HttpHeader.User-Agent'] ?: 'unknown' | ||||||
|       def tAuth = System.currentTimeMillis() - (request.getSession(true).getCreationTime().getEpochSecond() * 1000) |       def tAuth = System.currentTimeMillis() - (request.getSession(true).getCreationTime().getEpochSecond() * 1000) | ||||||
|  |       def details = "no account (404)" | ||||||
|  |       if (responseCode == 400 ) { | ||||||
|  |         details = "no fido2 keys for account (400)"     | ||||||
|  |       } else if (responseCode == 200) { | ||||||
|  |         details = "no active fido2 key for account (200, empty allowCredentials array)"     | ||||||
|  |       } | ||||||
|        |        | ||||||
|       LOG.info("Event='NOACCOUNT', Requester='${requester}', RequestId='${requestId}', RequestedAq=${requestedAq}, User=${session['ch.nevis.idm.User.email']}, CredentialType='${credentialType}', tAuth=${tAuth}ms, SourceIp=${sourceIp}, UserAgent='${userAgent}'") |       LOG.info("Event='NOACCOUNT', Requester='${requester}', RequestId='${requestId}', RequestedAq=${requestedAq}, User=${session['ch.nevis.idm.User.email']}, CredentialType='${credentialType}', tAuth=${tAuth}ms, SourceIp=${sourceIp}, UserAgent='${userAgent}', Details='${details}'") | ||||||
|  | 
 | ||||||
|       // returning a fake options structure, which shouldn't leak whether the user account exists or not |       // returning a fake options structure, which shouldn't leak whether the user account exists or not | ||||||
|       // keyId is unique per environment and email, fido2SessionId and challenge are renewed each time |       // keyId is unique per environment and email, fido2SessionId and challenge are renewed each time | ||||||
|       def keyId = UUID.nameUUIDFromBytes("${parameters['rpId']}.${session['ch.nevis.idm.User.email']}".getBytes()) |       def keyId = UUID.nameUUIDFromBytes("${parameters['rpId']}.${session['ch.nevis.idm.User.email']}".getBytes()) | ||||||
|       def responseText = """{"status": "ok", |       responseText = """{"status": "ok", | ||||||
|                              "errorMessage": "", |                          "errorMessage": "", | ||||||
|                              "fido2SessionId": "${UUID.randomUUID()}", |                          "fido2SessionId": "${UUID.randomUUID()}", | ||||||
|                              "challenge": "${base64url(UUID.randomUUID())}", |                          "challenge": "${base64url(UUID.randomUUID())}", | ||||||
|                              "timeout": 300000, |                          "timeout": 300000, | ||||||
|                              "rpId": "${parameters['rpId']}", |                          "rpId": "${parameters['rpId']}", | ||||||
|                              "allowCredentials": [ |                          "allowCredentials": [ | ||||||
|                              { |                            { | ||||||
|                                 "type": "public-key", |                               "type": "public-key", | ||||||
|                                 "id": "${base64url(keyId)}", |                               "id": "${base64url(keyId)}", | ||||||
|                                 "transports": [] |                               "transports": [] | ||||||
|                              } |                            } | ||||||
|                                                  ], |                          ], | ||||||
|                              "userVerification": "required"}""" |                          "userVerification": "required"}""" | ||||||
| 
 |  | ||||||
|       response.setContent(responseText) // return response from nevisFIDO "as-is" |  | ||||||
|       response.setContentType('application/json') |  | ||||||
|       response.setHttpStatusCode(200) |  | ||||||
|       response.setIsDirectResponse(true) |  | ||||||
|       return |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     def responseText = connection.inputStream.text |  | ||||||
|     LOG.debug("Fido2Auth: <== Response: ${responseCode} : ${responseText}") |     LOG.debug("Fido2Auth: <== Response: ${responseCode} : ${responseText}") | ||||||
|     response.setContent(responseText) // return response from nevisFIDO "as-is" |     response.setContent(responseText) | ||||||
|     response.setContentType('application/json') |     response.setContentType('application/json') | ||||||
|     response.setHttpStatusCode(200) |     response.setHttpStatusCode(200) | ||||||
|     response.setIsDirectResponse(true) |     response.setIsDirectResponse(true) | ||||||
|  |  | ||||||
										
											Binary file not shown.
										
									
								
							
										
											Binary file not shown.
										
									
								
							
		Loading…
	
		Reference in New Issue