blob: 25af417d3b486f88d0cc58d21f5b04f86dfc7801 [file] [log] [blame]
// Copyright (c) 2011 The Chromium OS Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef CHAPS_CHAPS_ADAPTOR_H
#define CHAPS_CHAPS_ADAPTOR_H
#include <base/basictypes.h>
#include "chaps/chaps_adaptor_generated.h"
namespace base {
class Lock;
}
namespace chaps {
class ChapsInterface;
class LoginEventListener;
// The ChapsAdaptor class implements the dbus-c++ generated adaptor interface
// and redirects IPC calls to a ChapsInterface instance. All dbus-c++ specific
// logic, error handling, etc. is implemented here. Specifically, the
// ChapsInterface instance need not be aware of dbus-c++ or IPC. This class
// exists because we don't want to couple dbus-c++ with the Chaps service
// implementation.
class ChapsAdaptor : public org::chromium::Chaps_adaptor,
public DBus::ObjectAdaptor {
public:
ChapsAdaptor(base::Lock* lock,
ChapsInterface* service,
LoginEventListener* login_listener);
virtual ~ChapsAdaptor();
virtual void OnLogin(const std::string& path,
const std::vector<uint8_t>& auth_data,
::DBus::Error &error);
virtual void OnLogout(const std::string& path, ::DBus::Error &error);
virtual void OnChangeAuthData(const std::string& path,
const std::vector<uint8_t>& old_auth_data,
const std::vector<uint8_t>& new_auth_data,
::DBus::Error &error);
virtual void GetSlotList(const bool& token_present,
std::vector<uint64_t>& slot_list,
uint32_t& result,
::DBus::Error& error);
virtual void GetSlotInfo(const uint64_t& slot_id,
std::vector<uint8_t>& slot_description,
std::vector<uint8_t>& manufacturer_id,
uint64_t& flags,
uint8_t& hardware_version_major,
uint8_t& hardware_version_minor,
uint8_t& firmware_version_major,
uint8_t& firmware_version_minor,
uint32_t& result,
::DBus::Error& error);
virtual void GetTokenInfo(const uint64_t& slot_id,
std::vector<uint8_t>& label,
std::vector<uint8_t>& manufacturer_id,
std::vector<uint8_t>& model,
std::vector<uint8_t>& serial_number,
uint64_t& flags,
uint64_t& max_session_count,
uint64_t& session_count,
uint64_t& max_session_count_rw,
uint64_t& session_count_rw,
uint64_t& max_pin_len,
uint64_t& min_pin_len,
uint64_t& total_public_memory,
uint64_t& free_public_memory,
uint64_t& total_private_memory,
uint64_t& free_private_memory,
uint8_t& hardware_version_major,
uint8_t& hardware_version_minor,
uint8_t& firmware_version_major,
uint8_t& firmware_version_minor,
uint32_t& result,
::DBus::Error& error);
virtual void GetMechanismList(const uint64_t& slot_id,
std::vector<uint64_t>& mechanism_list,
uint32_t& result,
::DBus::Error& error);
virtual void GetMechanismInfo(const uint64_t& slot_id,
const uint64_t& mechanism_type,
uint64_t& min_key_size,
uint64_t& max_key_size,
uint64_t& flags,
uint32_t& result,
::DBus::Error& error);
virtual uint32_t InitToken(const uint64_t& slot_id,
const bool& use_null_pin,
const std::string& optional_so_pin,
const std::vector<uint8_t>& new_token_label,
::DBus::Error& error);
virtual uint32_t InitPIN(const uint64_t& session_id,
const bool& use_null_pin,
const std::string& optional_user_pin,
::DBus::Error& error);
virtual uint32_t SetPIN(const uint64_t& session_id,
const bool& use_null_old_pin,
const std::string& optional_old_pin,
const bool& use_null_new_pin,
const std::string& optional_new_pin,
::DBus::Error& error);
virtual void OpenSession(const uint64_t& slot_id, const uint64_t& flags,
uint64_t& session_id, uint32_t& result,
::DBus::Error& error);
virtual uint32_t CloseSession(const uint64_t& session_id,
::DBus::Error& error);
virtual uint32_t CloseAllSessions(const uint64_t& slot_id,
::DBus::Error& error);
virtual void GetSessionInfo(const uint64_t& session_id,
uint64_t& slot_id,
uint64_t& state,
uint64_t& flags,
uint64_t& device_error,
uint32_t& result,
::DBus::Error& error);
virtual void GetOperationState(const uint64_t& session_id,
std::vector<uint8_t>& operation_state,
uint32_t& result,
::DBus::Error& error);
virtual uint32_t SetOperationState(
const uint64_t& session_id,
const std::vector<uint8_t>& operation_state,
const uint64_t& encryption_key_handle,
const uint64_t& authentication_key_handle,
::DBus::Error& error);
virtual uint32_t Login(const uint64_t& session_id,
const uint64_t& user_type,
const bool& use_null_pin,
const std::string& optional_pin,
::DBus::Error& error);
virtual uint32_t Logout(const uint64_t& session_id, ::DBus::Error& error);
virtual void CreateObject(
const uint64_t& session_id,
const std::vector<uint8_t>& attributes,
uint64_t& new_object_handle,
uint32_t& result,
::DBus::Error& error);
virtual void CopyObject(
const uint64_t& session_id,
const uint64_t& object_handle,
const std::vector<uint8_t>& attributes,
uint64_t& new_object_handle,
uint32_t& result,
::DBus::Error& error);
virtual uint32_t DestroyObject(const uint64_t& session_id,
const uint64_t& object_handle,
::DBus::Error& error);
virtual void GetObjectSize(const uint64_t& session_id,
const uint64_t& object_handle,
uint64_t& object_size,
uint32_t& result,
::DBus::Error& error);
virtual void GetAttributeValue(const uint64_t& session_id,
const uint64_t& object_handle,
const std::vector<uint8_t>& attributes_in,
std::vector<uint8_t>& attributes_out,
uint32_t& result,
::DBus::Error& error);
virtual uint32_t SetAttributeValue(const uint64_t& session_id,
const uint64_t& object_handle,
const std::vector<uint8_t>& attributes,
::DBus::Error& error);
virtual uint32_t FindObjectsInit(const uint64_t& session_id,
const std::vector<uint8_t>& attributes,
::DBus::Error& error);
virtual void FindObjects(const uint64_t& session_id,
const uint64_t& max_object_count,
std::vector<uint64_t>& object_list,
uint32_t& result,
::DBus::Error& error);
virtual uint32_t FindObjectsFinal(const uint64_t& session_id,
::DBus::Error& error);
virtual uint32_t EncryptInit(const uint64_t& session_id,
const uint64_t& mechanism_type,
const std::vector<uint8_t>& mechanism_parameter,
const uint64_t& key_handle,
::DBus::Error& error);
virtual void Encrypt(const uint64_t& session_id,
const std::vector<uint8_t>& data_in,
const uint64_t& max_out_length,
uint64_t& actual_out_length,
std::vector<uint8_t>& data_out,
uint32_t& result,
::DBus::Error& error);
virtual void EncryptUpdate(const uint64_t& session_id,
const std::vector<uint8_t>& data_in,
const uint64_t& max_out_length,
uint64_t& actual_out_length,
std::vector<uint8_t>& data_out,
uint32_t& result, ::DBus::Error& error);
virtual void EncryptFinal(const uint64_t& session_id,
const uint64_t& max_out_length,
uint64_t& actual_out_length,
std::vector<uint8_t>& data_out,
uint32_t& result,
::DBus::Error& error);
virtual uint32_t DecryptInit(const uint64_t& session_id,
const uint64_t& mechanism_type,
const std::vector<uint8_t>& mechanism_parameter,
const uint64_t& key_handle,
::DBus::Error& error);
virtual void Decrypt(const uint64_t& session_id,
const std::vector<uint8_t>& data_in,
const uint64_t& max_out_length,
uint64_t& actual_out_length,
std::vector<uint8_t>& data_out,
uint32_t& result,
::DBus::Error& error);
virtual void DecryptUpdate(const uint64_t& session_id,
const std::vector<uint8_t>& data_in,
const uint64_t& max_out_length,
uint64_t& actual_out_length,
std::vector<uint8_t>& data_out,
uint32_t& result,
::DBus::Error& error);
virtual void DecryptFinal(const uint64_t& session_id,
const uint64_t& max_out_length,
uint64_t& actual_out_length,
std::vector<uint8_t>& data_out,
uint32_t& result,
::DBus::Error& error);
virtual uint32_t DigestInit(const uint64_t& session_id,
const uint64_t& mechanism_type,
const std::vector<uint8_t>& mechanism_parameter,
::DBus::Error& error);
virtual void Digest(const uint64_t& session_id,
const std::vector<uint8_t>& data_in,
const uint64_t& max_out_length,
uint64_t& actual_out_length,
std::vector<uint8_t>& digest,
uint32_t& result,
::DBus::Error& error);
virtual uint32_t DigestUpdate(const uint64_t& session_id,
const std::vector<uint8_t>& data_in,
::DBus::Error& error);
virtual uint32_t DigestKey(const uint64_t& session_id,
const uint64_t& key_handle,
::DBus::Error& error);
virtual void DigestFinal(const uint64_t& session_id,
const uint64_t& max_out_length,
uint64_t& actual_out_length,
std::vector<uint8_t>& digest,
uint32_t& result,
::DBus::Error& error);
virtual uint32_t SignInit(const uint64_t& session_id,
const uint64_t& mechanism_type,
const std::vector<uint8_t>& mechanism_parameter,
const uint64_t& key_handle,
::DBus::Error& error);
virtual void Sign(const uint64_t& session_id,
const std::vector<uint8_t>& data,
const uint64_t& max_out_length,
uint64_t& actual_out_length,
std::vector<uint8_t>& signature,
uint32_t& result,
::DBus::Error& error);
virtual uint32_t SignUpdate(const uint64_t& session_id,
const std::vector<uint8_t>& data_part,
::DBus::Error& error);
virtual void SignFinal(const uint64_t& session_id,
const uint64_t& max_out_length,
uint64_t& actual_out_length,
std::vector<uint8_t>& signature,
uint32_t& result,
::DBus::Error& error);
virtual uint32_t SignRecoverInit(
const uint64_t& session_id,
const uint64_t& mechanism_type,
const std::vector<uint8_t>& mechanism_parameter,
const uint64_t& key_handle,
::DBus::Error& error);
virtual void SignRecover(const uint64_t& session_id,
const std::vector<uint8_t>& data,
const uint64_t& max_out_length,
uint64_t& actual_out_length,
std::vector<uint8_t>& signature,
uint32_t& result,
::DBus::Error& error);
virtual uint32_t VerifyInit(const uint64_t& session_id,
const uint64_t& mechanism_type,
const std::vector<uint8_t>& mechanism_parameter,
const uint64_t& key_handle,
::DBus::Error& error);
virtual uint32_t Verify(const uint64_t& session_id,
const std::vector<uint8_t>& data,
const std::vector<uint8_t>& signature,
::DBus::Error& error);
virtual uint32_t VerifyUpdate(const uint64_t& session_id,
const std::vector<uint8_t>& data_part,
::DBus::Error& error);
virtual uint32_t VerifyFinal(const uint64_t& session_id,
const std::vector<uint8_t>& signature,
::DBus::Error& error);
virtual uint32_t VerifyRecoverInit(
const uint64_t& session_id,
const uint64_t& mechanism_type,
const std::vector<uint8_t>& mechanism_parameter,
const uint64_t& key_handle,
::DBus::Error& error);
virtual void VerifyRecover(const uint64_t& session_id,
const std::vector<uint8_t>& signature,
const uint64_t& max_out_length,
uint64_t& actual_out_length,
std::vector<uint8_t>& data,
uint32_t& result,
::DBus::Error& error);
virtual void DigestEncryptUpdate(const uint64_t& session_id,
const std::vector<uint8_t>& data_in,
const uint64_t& max_out_length,
uint64_t& actual_out_length,
std::vector<uint8_t>& data_out,
uint32_t& result,
::DBus::Error& error);
virtual void DecryptDigestUpdate(const uint64_t& session_id,
const std::vector<uint8_t>& data_in,
const uint64_t& max_out_length,
uint64_t& actual_out_length,
std::vector<uint8_t>& data_out,
uint32_t& result,
::DBus::Error& error);
virtual void SignEncryptUpdate(const uint64_t& session_id,
const std::vector<uint8_t>& data_in,
const uint64_t& max_out_length,
uint64_t& actual_out_length,
std::vector<uint8_t>& data_out,
uint32_t& result,
::DBus::Error& error);
virtual void DecryptVerifyUpdate(const uint64_t& session_id,
const std::vector<uint8_t>& data_in,
const uint64_t& max_out_length,
uint64_t& actual_out_length,
std::vector<uint8_t>& data_out,
uint32_t& result,
::DBus::Error& error);
virtual void GenerateKey(const uint64_t& session_id,
const uint64_t& mechanism_type,
const std::vector<uint8_t>& mechanism_parameter,
const std::vector<uint8_t>& attributes,
uint64_t& key_handle,
uint32_t& result,
::DBus::Error& error);
virtual void GenerateKeyPair(
const uint64_t& session_id,
const uint64_t& mechanism_type,
const std::vector<uint8_t>& mechanism_parameter,
const std::vector<uint8_t>& public_attributes,
const std::vector<uint8_t>& private_attributes,
uint64_t& public_key_handle,
uint64_t& private_key_handle,
uint32_t& result,
::DBus::Error& error);
virtual void WrapKey(const uint64_t& session_id,
const uint64_t& mechanism_type,
const std::vector<uint8_t>& mechanism_parameter,
const uint64_t& wrapping_key_handle,
const uint64_t& key_handle,
const uint64_t& max_out_length,
uint64_t& actual_out_length,
std::vector<uint8_t>& wrapped_key,
uint32_t& result,
::DBus::Error& error);
virtual void UnwrapKey(const uint64_t& session_id,
const uint64_t& mechanism_type,
const std::vector<uint8_t>& mechanism_parameter,
const uint64_t& wrapping_key_handle,
const std::vector<uint8_t>& wrapped_key,
const std::vector<uint8_t>& attributes,
uint64_t& key_handle,
uint32_t& result,
::DBus::Error& error);
virtual void DeriveKey(const uint64_t& session_id,
const uint64_t& mechanism_type,
const std::vector<uint8_t>& mechanism_parameter,
const uint64_t& base_key_handle,
const std::vector<uint8_t>& attributes,
uint64_t& key_handle,
uint32_t& result,
::DBus::Error& error);
virtual uint32_t SeedRandom(const uint64_t& session_id,
const std::vector<uint8_t>& seed,
::DBus::Error& error);
virtual void GenerateRandom(const uint64_t& session_id,
const uint64_t& num_bytes,
std::vector<uint8_t>& random_data,
uint32_t& result,
::DBus::Error& error);
private:
base::Lock* lock_;
ChapsInterface* service_;
LoginEventListener* login_listener_;
DISALLOW_COPY_AND_ASSIGN(ChapsAdaptor);
};
} // namespace
#endif // CHAPS_CHAPS_ADAPTOR_H