當前位置: 首頁>>代碼示例>>Python>>正文


Python aead.AESGCM屬性代碼示例

本文整理匯總了Python中cryptography.hazmat.primitives.ciphers.aead.AESGCM屬性的典型用法代碼示例。如果您正苦於以下問題:Python aead.AESGCM屬性的具體用法?Python aead.AESGCM怎麽用?Python aead.AESGCM使用的例子?那麽, 這裏精選的屬性代碼示例或許可以為您提供幫助。您也可以進一步了解該屬性所在cryptography.hazmat.primitives.ciphers.aead的用法示例。


在下文中一共展示了aead.AESGCM屬性的10個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: finish_desktop_flow

# 需要導入模塊: from cryptography.hazmat.primitives.ciphers import aead [as 別名]
# 或者: from cryptography.hazmat.primitives.ciphers.aead import AESGCM [as 別名]
def finish_desktop_flow(request: HttpRequest, user_profile: UserProfile,
                        otp: str) -> HttpResponse:
    """
    The desktop otp flow returns to the app (through the clipboard)
    a token that allows obtaining (through log_into_subdomain) a logged in session
    for the user account we authenticated in this flow.
    The token can only be used once and within ExternalAuthResult.LOGIN_KEY_EXPIRATION_SECONDS
    of being created, as nothing more powerful is needed for the desktop flow
    and this ensures the key can only be used for completing this authentication attempt.
    """
    result = ExternalAuthResult(user_profile=user_profile)
    token = result.store_data()
    key = bytes.fromhex(otp)
    iv = os.urandom(12)
    desktop_data = (iv + AESGCM(key).encrypt(iv, token.encode(), b"")).hex()
    context = {'desktop_data': desktop_data,
               'browser_url': reverse('zerver.views.auth.login_page',
                                      kwargs = {'template_name': 'zerver/login.html'}),
               'realm_icon_url': realm_icon_url(user_profile.realm)}
    return render(request, 'zerver/desktop_redirect.html', context=context) 
開發者ID:zulip,項目名稱:zulip,代碼行數:22,代碼來源:auth.py

示例2: get_encrypted

# 需要導入模塊: from cryptography.hazmat.primitives.ciphers import aead [as 別名]
# 或者: from cryptography.hazmat.primitives.ciphers.aead import AESGCM [as 別名]
def get_encrypted(content: str, key: str) -> str:
    """
    Encrypt content using a specified key
    """
    def create_nonce() -> bytes:
        return os.urandom(12)

    def encrypt(string: str, enc_key: str) -> bytes:
        # String to bytes
        enc_key = base64.b64decode(enc_key)
        # Create key
        aes_gcm = AESGCM(enc_key)
        # Create nonce
        nonce = create_nonce()
        # Create ciphered data
        data = string.encode()
        ct = aes_gcm.encrypt(nonce, data, None)
        return base64.b64encode(nonce + ct)
    now = epoch_seconds()
    encrypted = encrypt(f'{now}:{content}', key).decode('utf-8')
    return encrypted 
開發者ID:demisto,項目名稱:content,代碼行數:23,代碼來源:AzureSecurityCenter_v2.py

示例3: enc

# 需要導入模塊: from cryptography.hazmat.primitives.ciphers import aead [as 別名]
# 或者: from cryptography.hazmat.primitives.ciphers.aead import AESGCM [as 別名]
def enc(self, byts, asscd=None):
        '''
        Encrypt the given bytes and return an envelope dict in msgpack form.

        Args:
            byts (bytes): The message to be encrypted.
            asscd (bytes): Extra data that needs to be authenticated (but not encrypted).

        Returns:
            bytes: The encrypted message. This is a msgpacked dictionary
            containing the IV, ciphertext, and associated data.
        '''
        iv = os.urandom(16)
        encryptor = AESGCM(self.ekey)
        byts = encryptor.encrypt(iv, byts, asscd)
        envl = {'iv': iv, 'data': byts, 'asscd': asscd}
        return s_msgpack.en(envl) 
開發者ID:vertexproject,項目名稱:synapse,代碼行數:19,代碼來源:tinfoil.py

示例4: dec

# 需要導入模塊: from cryptography.hazmat.primitives.ciphers import aead [as 別名]
# 或者: from cryptography.hazmat.primitives.ciphers.aead import AESGCM [as 別名]
def dec(self, byts):
        '''
        Decode an envelope dict and decrypt the given bytes.

        Args:
            byts (bytes): Bytes to decrypt.

        Returns:
            bytes: Decrypted message.
        '''
        envl = s_msgpack.un(byts)
        iv = envl.get('iv', b'')
        asscd = envl.get('asscd', b'')
        data = envl.get('data', b'')

        decryptor = AESGCM(self.ekey)

        try:
            data = decryptor.decrypt(iv, data, asscd)
        except Exception:
            logger.exception('Error decrypting data')
            return None
        return data 
開發者ID:vertexproject,項目名稱:synapse,代碼行數:25,代碼來源:tinfoil.py

示例5: encrypt

# 需要導入模塊: from cryptography.hazmat.primitives.ciphers import aead [as 別名]
# 或者: from cryptography.hazmat.primitives.ciphers.aead import AESGCM [as 別名]
def encrypt( self, plaintext ):
		aesgcm = AESGCM(self.key)
		nonce = os.urandom(16)
		ciphertext = aesgcm.encrypt(nonce, plaintext.encode('utf-8'), None)
		return base64.b64encode( nonce + ciphertext ).decode('utf-8') 
開發者ID:physics-sp,項目名稱:ikabot,代碼行數:7,代碼來源:aesCipher.py

示例6: decrypt

# 需要導入模塊: from cryptography.hazmat.primitives.ciphers import aead [as 別名]
# 或者: from cryptography.hazmat.primitives.ciphers.aead import AESGCM [as 別名]
def decrypt( self, ciphertext ):
		ciphertext = base64.b64decode(ciphertext)
		nonce      = ciphertext[:16]
		ciphertext = ciphertext[16:]
		aesgcm = AESGCM(self.key)
		plaintext  = aesgcm.decrypt(nonce, ciphertext, None)
		return plaintext.decode('utf-8') 
開發者ID:physics-sp,項目名稱:ikabot,代碼行數:9,代碼來源:aesCipher.py

示例7: encrypt_str

# 需要導入模塊: from cryptography.hazmat.primitives.ciphers import aead [as 別名]
# 或者: from cryptography.hazmat.primitives.ciphers.aead import AESGCM [as 別名]
def encrypt_str(self, content, key, salt, salt_explicit):
        # return the encrypted content prepended with salt_explicit
        aesgcm = AESGCM(key)
        ciphertext = aesgcm.encrypt(self._build_iv(salt, salt_explicit), content, None)
        return struct.pack('!q', salt_explicit) + ciphertext 
開發者ID:Tribler,項目名稱:py-ipv8,代碼行數:7,代碼來源:tunnelcrypto.py

示例8: decrypt_str

# 需要導入模塊: from cryptography.hazmat.primitives.ciphers import aead [as 別名]
# 或者: from cryptography.hazmat.primitives.ciphers.aead import AESGCM [as 別名]
def decrypt_str(self, content, key, salt):
        # content contains the gcm tag and salt_explicit in plaintext
        if len(content) < 24:
            raise CryptoException("truncated content")

        salt_explicit, = struct.unpack_from('!q', content)
        aesgcm = AESGCM(key)
        return aesgcm.decrypt(self._build_iv(salt, salt_explicit), content[8:], None) 
開發者ID:Tribler,項目名稱:py-ipv8,代碼行數:10,代碼來源:tunnelcrypto.py

示例9: decrypt

# 需要導入模塊: from cryptography.hazmat.primitives.ciphers import aead [as 別名]
# 或者: from cryptography.hazmat.primitives.ciphers.aead import AESGCM [as 別名]
def decrypt(self, jsons):
        """Import file is AES GCM encrypted, let's decrypt it.

        Based on the import script from Aegis:
        https://github.com/beemdevelopment/Aegis/blob/master/scripts/decrypt.py
        Format documentation:
        https://github.com/beemdevelopment/Aegis/blob/master/docs/vault.md
        """
        if not CRYPTOGRAPHY:
            raise ImportError(name='cryptography')

        password = getpassword(self.prefix)
        master_key = None
        for slot in jsons['header']['slots']:
            if slot['type'] != 1:
                continue

            kdf = Scrypt(salt=bytes.fromhex(slot['salt']),
                         length=32,
                         n=slot['n'],
                         r=slot['r'],
                         p=slot['p'],
                         backend=default_backend())
            key = kdf.derive(password.encode("utf-8"))

            cipher = AESGCM(key)
            param = slot['key_params']
            try:
                nonce = bytes.fromhex(param['nonce'])
                data = bytes.fromhex(slot['key']) + bytes.fromhex(param['tag'])
                master_key = cipher.decrypt(nonce=nonce,
                                            data=data,
                                            associated_data=None)
            except InvalidTag:  # pragma: no cover
                pass

        if master_key is None:  # pragma: no cover
            raise FormatError("unable to decrypt the master key.")

        cipher = AESGCM(master_key)
        param = jsons['header']['params']
        content = base64.b64decode(jsons['db']) + bytes.fromhex(param['tag'])
        plain = cipher.decrypt(nonce=bytes.fromhex(param['nonce']),
                               data=content,
                               associated_data=None)
        return plain.decode('utf-8') 
開發者ID:roddhjav,項目名稱:pass-import,代碼行數:48,代碼來源:aegis.py

示例10: get_encrypted

# 需要導入模塊: from cryptography.hazmat.primitives.ciphers import aead [as 別名]
# 或者: from cryptography.hazmat.primitives.ciphers.aead import AESGCM [as 別名]
def get_encrypted(content: str, key: str) -> str:
        """
        Encrypts content with encryption key.
        Args:
            content: Content to encrypt
            key: encryption key from oproxy

        Returns:
            timestamp: Encrypted content
        """

        def create_nonce():
            return os.urandom(12)

        def encrypt(string, enc_key):
            """
            Encrypts string input with encryption key.
            Args:
                string: String to encrypt
                enc_key: Encryption key

            Returns:
                bytes: Encrypted value
            """
            # String to bytes
            try:
                enc_key = base64.b64decode(enc_key)
            except Exception as err:
                return_error(f"Error in Microsoft authorization: {str(err)}"
                             f" Please check authentication related parameters.", error=traceback.format_exc())

            # Create key
            aes_gcm = AESGCM(enc_key)
            # Create nonce
            nonce = create_nonce()
            # Create ciphered data
            data = string.encode()
            ct = aes_gcm.encrypt(nonce, data, None)
            return base64.b64encode(nonce + ct)

        now = MicrosoftClient.epoch_seconds()
        encrypted = encrypt(f'{now}:{content}', key).decode('utf-8')
        return encrypted 
開發者ID:demisto,項目名稱:content,代碼行數:45,代碼來源:MicrosoftApiModule.py


注:本文中的cryptography.hazmat.primitives.ciphers.aead.AESGCM屬性示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。