2011-11-16 13:53:36 +01:00
|
|
|
/*
|
|
|
|
* Copyright 2011, Haiku, Inc.
|
|
|
|
* Distributed under the terms of the MIT License.
|
|
|
|
*/
|
|
|
|
#ifndef _KEY_STORE_H
|
|
|
|
#define _KEY_STORE_H
|
|
|
|
|
|
|
|
|
|
|
|
#include <Key.h>
|
|
|
|
|
|
|
|
|
|
|
|
class BKeyStore {
|
|
|
|
public:
|
|
|
|
BKeyStore();
|
|
|
|
virtual ~BKeyStore();
|
|
|
|
|
|
|
|
// TODO: -> GetNextPassword() - there can always be more than one key
|
|
|
|
// with the same identifier/secondaryIdentifier (ie. different username)
|
2011-12-22 14:58:19 +01:00
|
|
|
status_t GetKey(BKeyType type, BKeyPurpose purpose,
|
2011-11-16 13:53:36 +01:00
|
|
|
const char* identifier, BKey& key);
|
2011-12-22 14:58:19 +01:00
|
|
|
status_t GetKey(BKeyType type, BKeyPurpose purpose,
|
2011-11-16 13:53:36 +01:00
|
|
|
const char* identifier,
|
|
|
|
const char* secondaryIdentifier, BKey& key);
|
2011-12-22 14:58:19 +01:00
|
|
|
status_t GetKey(BKeyType type, BKeyPurpose purpose,
|
2011-11-16 13:53:36 +01:00
|
|
|
const char* identifier,
|
|
|
|
const char* secondaryIdentifier,
|
|
|
|
bool secondaryIdentifierOptional,
|
|
|
|
BKey& key);
|
|
|
|
|
2011-12-22 14:58:19 +01:00
|
|
|
status_t GetKey(const char* keyring,
|
|
|
|
BKeyType type, BKeyPurpose purpose,
|
2011-11-16 13:53:36 +01:00
|
|
|
const char* identifier, BKey& key);
|
2011-12-22 14:58:19 +01:00
|
|
|
status_t GetKey(const char* keyring,
|
|
|
|
BKeyType type, BKeyPurpose purpose,
|
2011-11-16 13:53:36 +01:00
|
|
|
const char* identifier,
|
|
|
|
const char* secondaryIdentifier, BKey& key);
|
2011-12-22 14:58:19 +01:00
|
|
|
status_t GetKey(const char* keyring,
|
|
|
|
BKeyType type, BKeyPurpose purpose,
|
2011-11-16 13:53:36 +01:00
|
|
|
const char* identifier,
|
|
|
|
const char* secondaryIdentifier,
|
|
|
|
bool secondaryIdentifierOptional,
|
|
|
|
BKey& key);
|
|
|
|
|
2011-12-22 14:58:19 +01:00
|
|
|
status_t RegisterKey(const BKey& key);
|
|
|
|
status_t RegisterKey(const char* keyring,
|
2011-11-16 13:53:36 +01:00
|
|
|
const BKey& key);
|
2011-12-22 14:58:19 +01:00
|
|
|
status_t UnregisterKey(const BKey& key);
|
|
|
|
status_t UnregisterKey(const char* keyring,
|
2011-11-16 13:53:36 +01:00
|
|
|
const BKey& key);
|
|
|
|
|
2011-12-22 14:58:19 +01:00
|
|
|
status_t GetNextKey(uint32& cookie, BKey& key);
|
|
|
|
status_t GetNextKey(BKeyType type, BKeyPurpose purpose,
|
2011-11-16 13:53:36 +01:00
|
|
|
uint32& cookie, BKey& key);
|
2011-12-22 14:58:19 +01:00
|
|
|
status_t GetNextKey(const char* keyring,
|
|
|
|
uint32& cookie, BKey& key);
|
|
|
|
status_t GetNextKey(const char* keyring,
|
|
|
|
BKeyType type, BKeyPurpose purpose,
|
2011-11-16 13:53:36 +01:00
|
|
|
uint32& cookie, BKey& key);
|
|
|
|
|
|
|
|
// Keyrings
|
|
|
|
|
|
|
|
status_t RegisterKeyring(const char* keyring,
|
|
|
|
const BKey& key);
|
|
|
|
status_t UnregisterKeyring(const char* keyring);
|
|
|
|
|
|
|
|
status_t GetNextKeyring(uint32& cookie,
|
|
|
|
BString& keyring);
|
|
|
|
|
|
|
|
// Master key
|
|
|
|
|
2011-12-22 14:58:19 +01:00
|
|
|
status_t SetMasterKey(const BKey& key);
|
|
|
|
status_t RemoveMasterKey();
|
2011-11-16 13:53:36 +01:00
|
|
|
|
|
|
|
status_t AddKeyringToMaster(const char* keyring);
|
|
|
|
status_t RemoveKeyringFromMaster(const char* keyring);
|
|
|
|
|
|
|
|
status_t GetNextMasterKeyring(uint32& cookie,
|
|
|
|
BString& keyring);
|
|
|
|
|
|
|
|
// Access
|
|
|
|
|
|
|
|
bool IsKeyringAccessible(const char* keyring);
|
|
|
|
status_t RevokeAccess(const char* keyring);
|
|
|
|
status_t RevokeMasterAccess();
|
|
|
|
|
2011-12-22 14:58:19 +01:00
|
|
|
// Applications
|
|
|
|
|
|
|
|
status_t GetNextApplication(const BKey& key,
|
|
|
|
uint32& cookie, BString& signature) const;
|
|
|
|
status_t RemoveApplication(const BKey& key,
|
|
|
|
const char* signature);
|
|
|
|
|
2011-11-16 13:53:36 +01:00
|
|
|
// Service functions
|
|
|
|
|
2011-12-22 14:58:19 +01:00
|
|
|
status_t GeneratePassword(BPasswordKey& password,
|
|
|
|
size_t length, uint32 flags);
|
|
|
|
float PasswordStrength(const char* password);
|
2011-11-16 13:53:36 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
#endif // _KEY_STORE_H
|