/* * Copyright (c) 2022, Matthew Olsson * * SPDX-License-Identifier: BSD-2-Clause */ #pragma once #include #include namespace PDF { class SecurityHandler : public RefCounted { public: static PDFErrorOr> create(Document*, NonnullRefPtr encryption_dict); virtual ~SecurityHandler() = default; virtual bool try_provide_user_password(StringView password) = 0; virtual bool has_user_password() const = 0; virtual void encrypt(NonnullRefPtr, Reference reference) const = 0; virtual void decrypt(NonnullRefPtr, Reference reference) const = 0; }; class StandardSecurityHandler : public SecurityHandler { public: static PDFErrorOr> create(Document*, NonnullRefPtr encryption_dict); StandardSecurityHandler(Document*, size_t revision, String const& o_entry, String const& u_entry, u32 flags, bool encrypt_metadata, size_t length); ~StandardSecurityHandler() override = default; bool try_provide_user_password(StringView password_string) override; bool has_user_password() const override { return m_encryption_key.has_value(); } protected: void encrypt(NonnullRefPtr, Reference reference) const override; void decrypt(NonnullRefPtr, Reference reference) const override; private: template ByteBuffer compute_user_password_value(ByteBuffer password_string); ByteBuffer compute_encryption_key(ByteBuffer password_string); Document* m_document; size_t m_revision; Optional m_encryption_key; String m_o_entry; String m_u_entry; u32 m_flags; bool m_encrypt_metadata; size_t m_length; }; class RC4 { public: RC4(ReadonlyBytes key); void generate_bytes(ByteBuffer&); ByteBuffer encrypt(ReadonlyBytes bytes); private: Array m_bytes; }; }