33 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Ruby
		
	
	
	
			
		
		
	
	
			33 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Ruby
		
	
	
	
| # rubocop: disable Naming/FileName
 | |
| # frozen_string_literal: true
 | |
| 
 | |
| module Gitlab
 | |
|   class FIPS
 | |
|     # A simple utility class for FIPS-related helpers
 | |
| 
 | |
|     Technology = Gitlab::SSHPublicKey::Technology
 | |
| 
 | |
|     SSH_KEY_TECHNOLOGIES = [
 | |
|       Technology.new(:rsa, SSHData::PublicKey::RSA, [3072, 4096], %w(ssh-rsa)),
 | |
|       Technology.new(:dsa, SSHData::PublicKey::DSA, [], %w(ssh-dss)),
 | |
|       Technology.new(:ecdsa, SSHData::PublicKey::ECDSA, [256, 384, 521], %w(ecdsa-sha2-nistp256 ecdsa-sha2-nistp384 ecdsa-sha2-nistp521)),
 | |
|       Technology.new(:ed25519, SSHData::PublicKey::ED25519, [256], %w(ssh-ed25519)),
 | |
|       Technology.new(:ecdsa_sk, SSHData::PublicKey::SKECDSA, [256], %w(sk-ecdsa-sha2-nistp256@openssh.com)),
 | |
|       Technology.new(:ed25519_sk, SSHData::PublicKey::SKED25519, [256], %w(sk-ssh-ed25519@openssh.com))
 | |
|     ].freeze
 | |
| 
 | |
|     OPENSSL_DIGESTS = %i(SHA1 SHA256 SHA384 SHA512).freeze
 | |
| 
 | |
|     class << self
 | |
|       # Returns whether we should be running in FIPS mode or not
 | |
|       #
 | |
|       # @return [Boolean]
 | |
|       def enabled?
 | |
|         ::Labkit::FIPS.enabled?
 | |
|       end
 | |
|     end
 | |
|   end
 | |
| end
 | |
| 
 | |
| # rubocop: enable Naming/FileName
 |