Support Removal of Friends and Ignores
This commit is contained in:
@@ -98,12 +98,18 @@ void Database::PrepareStatements()
|
||||
{ QueryID::SaveFriend,
|
||||
"INSERT OR IGNORE INTO UserFriendList ( account_id, friend_handle ) VALUES ( ?, ? );" },
|
||||
|
||||
{ QueryID::RemoveFriend,
|
||||
"DELETE FROM UserFriendList WHERE account_id = ? AND friend_handle = ?;" },
|
||||
|
||||
{ QueryID::LoadFriendList,
|
||||
"SELECT friend_handle FROM UserFriendList WHERE account_id = ?;" },
|
||||
|
||||
{ QueryID::SaveIgnore,
|
||||
"INSERT OR IGNORE INTO UserIgnoredList ( account_id, ignore_handle ) VALUES ( ?, ? );" },
|
||||
|
||||
{ QueryID::RemoveIgnore,
|
||||
"DELETE FROM UserIgnoredList WHERE account_id = ? AND ignore_handle = ?;" },
|
||||
|
||||
{ QueryID::LoadIgnoreList,
|
||||
"SELECT ignore_handle FROM UserIgnoredList WHERE account_id = ?;" }
|
||||
};
|
||||
@@ -453,6 +459,39 @@ bool Database::SaveFriend( const int64_t account_id, const std::wstring &friend_
|
||||
return false;
|
||||
}
|
||||
|
||||
bool Database::RemoveFriend( const int64_t account_id, const std::wstring &friend_handle )
|
||||
{
|
||||
if( account_id <= 0 || friend_handle.empty() )
|
||||
{
|
||||
Log::Error( "Invalid parameters for RemoveFriend" );
|
||||
return false;
|
||||
}
|
||||
|
||||
try
|
||||
{
|
||||
auto stmt = m_statements[ QueryID::RemoveFriend ];
|
||||
auto friendHandle = Util::WideToUTF8( friend_handle );
|
||||
|
||||
sqlite3_reset( stmt );
|
||||
sqlite3_clear_bindings( stmt );
|
||||
sqlite3_bind_int64( stmt, 1, account_id );
|
||||
sqlite3_bind_text( stmt, 2, friendHandle.c_str(), -1, SQLITE_TRANSIENT );
|
||||
|
||||
if( sqlite3_step( stmt ) != SQLITE_DONE )
|
||||
{
|
||||
Log::Error( "SQLite delete failed: {}", sqlite3_errmsg( m_db ) );
|
||||
return false;
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
catch( const std::exception &e )
|
||||
{
|
||||
Log::Error( "Database error: {}", std::string( e.what() ) );
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
std::vector<std::wstring> Database::LoadFriends( const int64_t account_id )
|
||||
{
|
||||
std::vector<std::wstring> friend_list;
|
||||
@@ -517,6 +556,39 @@ bool Database::SaveIgnore( const int64_t account_id, const std::wstring &ignore_
|
||||
return false;
|
||||
}
|
||||
|
||||
bool Database::RemoveIgnore( const int64_t account_id, const std::wstring &ignore_handle )
|
||||
{
|
||||
if( account_id <= 0 || ignore_handle.empty() )
|
||||
{
|
||||
Log::Error( "Invalid parameters for RemoveIgnore" );
|
||||
return false;
|
||||
}
|
||||
|
||||
try
|
||||
{
|
||||
auto stmt = m_statements[ QueryID::RemoveIgnore ];
|
||||
auto ignoreHandle = Util::WideToUTF8( ignore_handle );
|
||||
|
||||
sqlite3_reset( stmt );
|
||||
sqlite3_clear_bindings( stmt );
|
||||
sqlite3_bind_int64( stmt, 1, account_id );
|
||||
sqlite3_bind_text( stmt, 2, ignoreHandle.c_str(), -1, SQLITE_TRANSIENT );
|
||||
|
||||
if( sqlite3_step( stmt ) != SQLITE_DONE )
|
||||
{
|
||||
Log::Error( "SQLite delete failed: {}", sqlite3_errmsg( m_db ) );
|
||||
return false;
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
catch( const std::exception &e )
|
||||
{
|
||||
Log::Error( "Database error: {}", std::string( e.what() ) );
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
std::vector<std::wstring> Database::LoadIgnores( const int64_t account_id )
|
||||
{
|
||||
std::vector<std::wstring> ignore_list;
|
||||
|
||||
@@ -23,9 +23,11 @@ enum class QueryID {
|
||||
LoadCharacter,
|
||||
|
||||
SaveFriend,
|
||||
RemoveFriend,
|
||||
LoadFriendList,
|
||||
|
||||
SaveIgnore,
|
||||
RemoveIgnore,
|
||||
LoadIgnoreList,
|
||||
};
|
||||
|
||||
@@ -78,9 +80,11 @@ public:
|
||||
sptr_realm_character LoadCharacterData( const int64_t account_id, const int32_t character_id );
|
||||
|
||||
bool SaveFriend( const int64_t account_id, const std::wstring &friend_handle );
|
||||
bool RemoveFriend( const int64_t account_id, const std::wstring &friend_handle );
|
||||
std::vector< std::wstring > LoadFriends( const int64_t account_id );
|
||||
|
||||
bool SaveIgnore( const int64_t account_id, const std::wstring &ignore_handle );
|
||||
bool RemoveIgnore( const int64_t account_id, const std::wstring &ignore_handle );
|
||||
std::vector< std::wstring > LoadIgnores( const int64_t account_id );
|
||||
|
||||
private:
|
||||
|
||||
Reference in New Issue
Block a user