33 lines
		
	
	
		
			748 B
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			33 lines
		
	
	
		
			748 B
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| declare(strict_types=1);
 | |
| 
 | |
| /*
 | |
|  * The MIT License (MIT)
 | |
|  *
 | |
|  * Copyright (c) 2014-2020 Spomky-Labs
 | |
|  *
 | |
|  * This software may be modified and distributed under the terms
 | |
|  * of the MIT license.  See the LICENSE file for details.
 | |
|  */
 | |
| 
 | |
| namespace Jose\Component\KeyManagement\Analyzer;
 | |
| 
 | |
| use Base64Url\Base64Url;
 | |
| use Jose\Component\Core\JWK;
 | |
| 
 | |
| final class OctAnalyzer implements KeyAnalyzer
 | |
| {
 | |
|     public function analyze(JWK $jwk, MessageBag $bag): void
 | |
|     {
 | |
|         if ('oct' !== $jwk->get('kty')) {
 | |
|             return;
 | |
|         }
 | |
|         $k = Base64Url::decode($jwk->get('k'));
 | |
|         $kLength = 8 * mb_strlen($k, '8bit');
 | |
|         if ($kLength < 128) {
 | |
|             $bag->add(Message::high('The key length is less than 128 bits.'));
 | |
|         }
 | |
|     }
 | |
| }
 |