You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 

970 lines
33 KiB

/************************************************************************
Copyright (c) 2005-2011 by Juphoon System Software, Inc.
All rights reserved.
This software is confidential and proprietary to Juphoon System,
Inc. No part of this software may be reproduced, stored, transmitted,
disclosed or used in any form or by any means other than as expressly
provided by the written license agreement between Juphoon and its
licensee.
THIS SOFTWARE IS PROVIDED BY JUPHOON "AS IS" AND ANY EXPRESS OR
IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
ARE DISCLAIMED. IN NO EVENT SHALL JUPHOON BE LIABLE FOR ANY DIRECT,
INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
POSSIBILITY OF SUCH DAMAGE.
Juphoon System Software, Inc.
Email: support@juphoon.com
Web: http://www.juphoon.com
************************************************************************/
/*************************************************
File name : mtc_buddy.h
Module : multimedia talk client
Author : xiangbo.hui
Created on : 2015-03-27
Description :
Data structure and function declare required by MTC statistics
Modify History:
1. Date: Author: Modification:
*************************************************/
#ifndef _MTC_BUDDY_H__
#define _MTC_BUDDY_H__
#include "mtc_def.h"
/**
* @file mtc_buddy.h
* @brief MTC Buddy Interface Functions
*
* This file includes buddy interface function.
*/
/** @brief Failure reasons. */
typedef enum EN_MTC_BUDDY_REASON_TYPE
{
EN_MTC_BUDDY_REASON_BASE = 2000, /**< @brief Base of reason number. */
EN_MTC_BUDDY_REASON_GET_AGENT, /**< @brief Internal error get agent failed. */
EN_MTC_BUDDY_REASON_SERVER, /**< @brief Server error. */
EN_MTC_BUDDY_REASON_SERVER_UPDATE_TIME_INVALID, /**< @brief Server error update time invalid. */
EN_MTC_BUDDY_REASON_SERVER_PERMISSION_DENIED, /**< @brief Server error permission denied. */
EN_MTC_BUDDY_REASON_SERVER_UID_NOT_FOUND, /**< @brief Server error uid is not found. */
EN_MTC_BUDDY_REASON_SERVER_CHANGE_NOT_EXISTS, /**< @brief Server error change relation that not exists. */
EN_MTC_BUDDY_REASON_SERVER_ADD_ALREADY_EXISTS, /**< @brief Server error add relation that already exists. */
EN_MTC_BUDDY_REASON_SERVER_ADD_SELF, /**< @brief Server error add self. */
EN_MTC_BUDDY_REASON_SERVER_RELATION_TYPE_INVALID, /**< @brief Server error relation type invalid. */
EN_MTC_BUDDY_REASON_SERVER_REMOVE_NOT_EXIST, /**< @brief Server error remove relation that not exists. */
EN_MTC_BUDDY_REASON_SERVER_STATUS_TYPE_INVALID, /**< @brief Server error status type invalid. */
EN_MTC_BUDDY_REASON_SERVER_WRITE_OWNER_ERROR, /**< @brief Server error only one owner in group. */
EN_MTC_BUDDY_REASON_SERVER_SET_WRITE_PROP, /**< @brief Server error try to set write only prop. */
EN_MTC_BUDDY_REASON_SERVER_APPLY_TYPE_GRANTED, /**< @brief Server error apply type granted. */
EN_MTC_BUDDY_REASON_SERVER_LACK_OF_ORG_NAME, /**< @brief Server error lack of org name. */
EN_MTC_BUDDY_REASON_SERVER_UNKNOW_ORG_TYPE, /**< @brief Server error unknow org type. */
EN_MTC_BUDDY_REASON_SERVER_OWNER_NOT_INVOKER, /**< @brief Server error not assign self as owner. */
EN_MTC_BUDDY_REASON_SERVER_NOT_IN_GROUP, /**< @brief Server error not in relation list of target. */
EN_MTC_BUDDY_REASON_SERVER_BLACKLIST, /**< @brief Server error block by blacklist. */
EN_MTC_BUDDY_REASON_SERVER_CAPACITY_FULL, /**< @brief Server error capacity of the group is full. */
EN_MTC_BUDDY_REASON_SERVER_NOT_BELOG_OT_ORG, /**< @brief Server error caller not belong to the group. */
EN_MTC_BUDDY_REASON_SERVER_WRITE_EXCEED_RIGHT, /**< @brief Server error try to change the member who has higher level . */
EN_MTC_BUDDY_REASON_SERVER_DBERROR, /**< @brief Server error try to connect db server . */
EN_MTC_BUDDY_REASON_QUERY_UID, /**< @brief Query UID failed. */
EN_MTC_BUDDY_REASON_BUDDY_NOT_FOUND, /**< @brief Buddy not found. */
EN_MTC_BUDDY_REASON_NO_PROPERTY, /**< @brief Property not exist. */
EN_MTC_BUDDY_REASON_TIMEOUT, /**< @brief Request timeout. */
} EN_MTC_BUDDY_REASON_TYPE;
/** @brief Relation type. */
typedef enum EN_MTC_BUDDY_RELATION_TYPE
{
EN_MTC_BUDDY_RELATION_WITH_PERSON = 11,
EN_MTC_BUDDY_RELATION_CLOSE_FRIEND = EN_MTC_BUDDY_RELATION_WITH_PERSON, /**< @brief Close friend. */
EN_MTC_BUDDY_RELATION_FRIEND = 12, /**< @brief Friend. */
EN_MTC_BUDDY_RELATION_CONTACT = 13, /**< @brief Contact. */
EN_MTC_BUDDY_RELATION_FOLLOW = 14, /**< @brief Follow. */
EN_MTC_BUDDY_RELATION_STRANGER = 15, /**< @brief Stragner. */
EN_MTC_BUDDY_RELATION_BLACKLIST = 16, /**< @brief Blacklist. */
EN_MTC_BUDDY_RELATION_SYSTEM = 18, /**< @brief System. */
} EN_MTC_BUDDY_RELATION_TYPE;
/**
* @defgroup MtcBuddyKey MTC notification key for buddy.
* @{
*/
/**
* @brief A key whose value is a string object reflecting
* the buddy's URI.
*/
#define MtcBuddyUriKey "UserUri"
/**
* @brief A key whose value is a string object reflecting
* the buddy's UserID.
*/
#define MtcBuddyUidKey "Rid"
/**
* @brief A key whose value is a number object reflecting
* the buddy's reason key.
*/
#define MtcBuddyReasonKey "MtcBuddyReasonKey"
/**
* @brief A key whose value is a string object reflecting
* the failure details.
*/
#define MtcBuddyReasonDetailKey "ReasonDetail"
/**
* @brief A key whose value is a list of relation object reflecting
* the property(s) name and value map of user.
*/
#define MtcBuddyPropertyKey "MtcBuddyPropertyKey"
/**
* @brief A key whose value is a number reflecting the account's status,
* @ref group_def_account_status.
*/
#define MtcBuddyStatusKey "Status"
/**
* @brief A key whose value is a string object reflecting
* the status name.
*/
#define MtcBuddyStatusNameKey "MtcBuddyStatusNameKey"
/**
* @brief A key whose value is a string object reflecting
* the status value.
*/
#define MtcBuddyStatusValueKey "MtcBuddyStatusValueKey"
/**
* @brief A key whose value is a number object reflecting
* the login date time by UNIX timestamp.
*/
#define MtcBuddyPropertyDateKey "Date"
/**
* @brief A key whose value is a string object reflecting
* the brand of device.
*/
#define MtcBuddyPropertyBrandKey "Brand"
/**
* @brief A key whose value is a string object reflecting
* the model of device.
*/
#define MtcBuddyPropertyModelKey "Model"
/**
* @brief A key whose value is a string object reflecting
* the OS version of device.
*/
#define MtcBuddyPropertyVersionKey "Ver"
/**
* @brief A key whose value is a string object reflecting
* the application version.
*/
#define MtcBuddyPropertyAppVersionKey "AppVer"
/**
* @brief A key whose value is an integer object reflecting
* the update time of server change.
*/
#define MtcBuddyUpdateTimeKey "UpdateTime"
/**
* @brief A key whose value is an integer object reflecting
* the base time of server change.
*/
#define MtcBuddyBaseTimeKey "BaseTime"
/**
* @brief A key whose value is an boolean object reflecting
* the update information is full or partial.
*/
#define MtcBuddyIsPartialUpdateKey "IsPartialUpdate"
/**
* @brief A key whose value is an integer reflecting
* the relation type of a relation, @ref EN_MTC_BUDDY_RELATION_TYPE
*/
#define MtcBuddyRelationTypeKey "RelationType"
/**
* @brief A key whose value is a string object reflecting
* the display name of a relation.
*/
#define MtcBuddyDisplayNameKey "DisplayName"
/**
* @brief A key whose value is a string object reflecting
* the tag of a relation.
*/
#define MtcBuddyTagKey "Tag"
/**
* @brief A key whose value is a list of relation objects
* that representing relations.
* Each object contains several fields:
* @ref MtcBuddyRelationTypeKey,
* @ref MtcBuddyUidKey,
* @ref MtcBuddyDisplayNameKey.
* @ref MtcBuddyTagKey.
*/
#define MtcBuddyRelationListKey "RelationList"
/**
* @brief A key whose value is a array of relation objects
* that representing new added relations.
* Each object contains several fields:
* @ref MtcBuddyRelationTypeKey,
* @ref MtcBuddyUidKey,
* @ref MtcBuddyDisplayNameKey.
* @ref MtcBuddyTagKey.
*/
#define MtcBuddyAddedRelationListKey "AddedRelationList"
/**
* @brief A key whose value is a array of relation objects
* that representing changed relations.
* Each object contains several fields:
* @ref MtcBuddyRelationTypeKey,
* @ref MtcBuddyUidKey,
* @ref MtcBuddyDisplayNameKey.
* @ref MtcBuddyTagKey.
*/
#define MtcBuddyUpdatedRelationListKey "UpdatedRelationList"
/**
* @brief A key whose value is a array of string objects
* that representing removed UserIDs
*/
#define MtcBuddyRemovedRelationListKey "RemovedRelationList"
/**
* @brief A key whose value is a array of relation objects
* that representing new added relations.
* Each object contains several fields:
* @ref MtcBuddyRelationTypeKey, @ref MtcBuddyUriKey, @ref MtcBuddyDisplayNameKey, @ref MtcBuddyTagKey.
*/
#define MtcBuddyListToAddKey "ListToAdd"
/**
* @brief A key whose value is a array of relation objects
* that representing changed relations.
* Each object contains several fields:
* @ref MtcBuddyRelationTypeKey, @ref MtcBuddyUriKey, @ref MtcBuddyDisplayNameKey, @ref MtcBuddyTagKey.
*/
#define MtcBuddyListToUpdateKey "ListToUpdate"
/**
* @brief A key whose value is a array of string objects
* that representing removed URIs.
*/
#define MtcBuddyListToRemoveKey "ListToRemove"
/**
* @brief A key whose value is a list of relation objects
* that representing relations.
* Each object contains several fields:
* @ref MtcBuddyUidKey,
* and other key value set by Mtc_BuddySetMyStatus.
*/
#define MtcBuddyStatusListKey "StatusList"
/**
* @brief A key whose value is a number object reflecting
* the unique ID of a buddy apply.
*/
#define MtcBuddyApplyIdKey "ApplyId"
/**
* @brief A key whose value is a bool object reflecting
* the result of a buddy apply.
*/
#define MtcBuddyApplyResultKey "ApplyResult"
/**
* @brief A key whose value is a string object reflecting
* the description of a buddy apply.
*/
#define MtcBuddyApplyDescriptionKey "Description"
/** @} */
/**
* @defgroup MtcBuddyNotification MTC notification names for buddy.
* @{
*/
/**
* @brief Posted when query buddy property successfully.
*
* The pcInfo of this notification contains
* @ref MtcBuddyUriKey, @ref MtcBuddyPropertyKey.
*/
#define MtcBuddyQueryPropertyOkNotification "MtcBuddyQueryPropertyOkNotification"
/**
* @brief Posted when query buddy property failed.
*
* The pcInfo of this notification is contains
* @ref MtcBuddyUriKey, @ref MtcBuddyReasonKey, @ref MtcBuddyReasonDetailKey.
*/
#define MtcBuddyQueryPropertyDidFailNotification "MtcBuddyQueryPropertyDidFailNotification"
/**
* @brief Posted when query buddy login information successfully.
*
* The pcInfo of this notification contains
* @ref MtcBuddyUriKey, @ref MtcBuddyStatusKey, @ref MtcBuddyPropertyDateKey,
* @ref MtcBuddyPropertyBrandKey, @ref MtcBuddyPropertyModelKey,
* @ref MtcBuddyPropertyVersionKey, @ref MtcBuddyPropertyAppVersionKey.
*/
#define MtcBuddyQueryLoginPropertiesOkNotification "MtcBuddyQueryLoginPropertiesOkNotification"
/**
* @brief Posted when query buddy login information failed.
*
* The pcInfo of this notification is contains
* @ref MtcBuddyUriKey, @ref MtcBuddyReasonKey, @ref MtcBuddyReasonDetailKey.
*/
#define MtcBuddyQueryLoginPropertiesDidFailNotification "MtcBuddyQueryLoginPropertiesDidFailNotification"
/**
* @brief Posted when query buddy login information successfully.
*
* The pcInfo of this notification contains
* @ref MtcBuddyUriKey, @ref MtcBuddyStatusKey.
*/
#define MtcBuddyQueryLoginInfoOkNotification "MtcBuddyQueryLoginInfoOkNotification"
/**
* @brief Posted when query buddy login information failed.
*
* The pcInfo of this notification is contains
* @ref MtcBuddyUriKey, @ref MtcBuddyReasonKey, @ref MtcBuddyReasonDetailKey.
*/
#define MtcBuddyQueryLoginInfoDidFailNotification "MtcBuddyQueryLoginInfoDidFailNotification"
/**
* @brief Posted when query buddys' UserId successfully.
*
* The pcInfo of this notification contains an array of UserId map item.
* Each item is an array of string, the first string is User's URI,
* the second string is corresponding UserId.
*/
#define MtcBuddyQueryUserIdOkNotification "MtcBuddyQueryUserIdOkNotification"
/**
* @brief Posted when query buddys' UserId failed.
*
* The pcInfo of this notification contains
* @ref MtcBuddyReasonKey,
* @ref MtcBuddyReasonDetailKey.
*/
#define MtcBuddyQueryUserIdDidFailNotification "MtcBuddyQueryUserIdDidFailNotification"
/**
* @brief Posted when query buddys' AccountId successfully.
*
* The pcInfo of this notification contains an array of AccountId map item.
* Each item is an array of string, the first string is User's UserId,
* following string is the AccountId associated with this user.
*/
#define MtcBuddyQueryAccountIdOkNotification "MtcBuddyQueryAccountIdOkNotification"
/**
* @brief Posted when query buddys' AccountId failed.
*
* The pcInfo is ZNULL.
*/
#define MtcBuddyQueryAccountIdDidFailNotification "MtcBuddyQueryAccountIdDidFailNotification"
/**
* @brief Posted when query users' status successfully.
*
* The pcInfo of this notification is an array, each item contains
* @ref MtcBuddyUriKey, @ref MtcBuddyStatusKey.
*/
#define MtcBuddyQueryUsersStatusOkNotification "MtcBuddyQueryUsersStatusOkNotification"
/**
* @brief Posted when query users' status failed.
*
* The pcInfo of this notification is an array of string, each item is user's URI.
*/
#define MtcBuddyQueryUsersStatusDidFailNotification "MtcBuddyQueryUsersStatusDidFailNotification"
/**
* @brief Posted when refresh successfully.
*
* The pcInfo of this notification contains
* @ref MtcBuddyUpdateTimeKey,
* @ref MtcBuddyBaseTimeKey,
* @ref MtcBuddyIsPartialUpdateKey,
* @ref MtcBuddyRelationListKey,
* @ref MtcBuddyAddedRelationListKey,
* @ref MtcBuddyUpdatedRelationListKey
* @ref MtcBuddyRemovedRelationListKey.
*/
#define MtcBuddyRefreshOkNotification "MtcBuddyRefreshOkNotification"
/**
* @brief Posted when failed to refresh.
*
* The pcInfo of this notification contains
* @ref MtcBuddyReasonKey,
* @ref MtcBuddyReasonDetailKey.
*/
#define MtcBuddyRefreshDidFailNotification "MtcBuddyRefreshDidFailNotification"
/**
* @brief Posted when buddy list changed.
*
* The pcInfo of this notification contains
* @ref MtcBuddyUpdateTimeKey,
* @ref MtcBuddyBaseTimeKey,
* @ref MtcBuddyIsPartialUpdateKey,
* @ref MtcBuddyAddedRelationListKey,
* @ref MtcBuddyUpdatedRelationListKey,
* @ref MtcBuddyRemovedRelationListKey.
*/
#define MtcBuddyChangedNotification "MtcBuddyChangedNotification"
/**
* @brief Posted when add relation successfully.
*
* The pcInfo of this notification contains
* @ref MtcBuddyUpdateTimeKey.
*/
#define MtcBuddyAddRelationOkNotification "MtcBuddyAddRelationOkNotification"
/**
* @brief Posted when failed to add relation.
*
* The pcInfo of this notification contains
* @ref MtcBuddyReasonKey,
* @ref MtcBuddyReasonDetailKey.
*/
#define MtcBuddyAddRelationDidFailNotification "MtcBuddyAddRelationDidFailNotification"
/**
* @brief Posted when update relation successfully.
*
* The pcInfo of this notification contains
* @ref MtcBuddyUpdateTimeKey.
*/
#define MtcBuddyUpdateRelationOkNotification "MtcBuddyUpdateRelationOkNotification"
/**
* @brief Posted when failed to update relation.
*
* The pcInfo of this notification contains
* @ref MtcBuddyReasonKey,
* @ref MtcBuddyReasonDetailKey.
*/
#define MtcBuddyUpdateRelationDidFailNotification "MtcBuddyUpdateRelationDidFailNotification"
/**
* @brief Posted when remove relation successfully.
*
* The pcInfo of this notification contains
* @ref MtcBuddyUpdateTimeKey.
*/
#define MtcBuddyRemoveRelationOkNotification "MtcBuddyRemoveRelationOkNotification"
/**
* @brief Posted when failed to remove relation.
*
* The pcInfo of this notification contains
* @ref MtcBuddyReasonKey,
* @ref MtcBuddyReasonDetailKey.
*/
#define MtcBuddyRemoveRelationDidFailNotification "MtcBuddyRemoveRelationDidFailNotification"
/**
* @brief Posted when set relation status successfully.
*
* The pcInfo of this notification contains
* @ref MtcBuddyUidKey,
*/
#define MtcBuddySetMyStatusOkNotification "MtcBuddySetMyStatusOkNotification"
/**
* @brief Posted when failed to set relation status.
*
* The pcInfo of this notification contains
* @ref MtcBuddyUidKey,
* @ref MtcBuddyReasonKey,
* @ref MtcBuddyReasonDetailKey.
*/
#define MtcBuddySetMyStatusDidFailNotification "MtcBuddySetMyStatusDidFailNotification"
/**
* @brief Posted when recv buddy status changed.
*
* The pcInfo of this notification contains
* @ref MtcBuddyUidKey,
* @ref MtcBuddyStatusNameKey,
* @ref MtcBuddyStatusValueKey,
* @ref MtcBuddyUpdateTimeKey.
*/
#define MtcBuddyStatusChangedNotification "MtcBuddyStatusChangedNotification"
/**
* @brief Posted when get relation status successfully.
*
* The pcInfo of this notification contains
* @ref MtcBuddyStatusListKey.
*/
#define MtcBuddyGetRelationStatusOkNotification "MtcBuddyGetRelationStatusOkNotification"
/**
* @brief Posted when failed to get relation status.
*
* The pcInfo of this notification contains
* @ref MtcBuddyReasonKey,
* @ref MtcBuddyReasonDetailKey.
*/
#define MtcBuddyGetRelationStatusDidFailNotification "MtcBuddyGetRelationStatusDidFailNotification"
/**
* @brief Posted when set relations successfully.
*
* The pcInfo of this notification contains @ref MtcBuddyUpdateTimeKey, @ref MtcBuddyBaseTimeKey.
*/
#define MtcBuddySetRelationsOkNotification "MtcBuddySetRelationsOkNotification"
/**
* @brief Posted when failed to set relations.
*
* The pcInfo of this notification contains @ref MtcBuddyReasonKey, @ref MtcBuddyReasonDetailKey.
*/
#define MtcBuddySetRelationsDidFailNotification "MtcBuddySetRelationsDidFailNotification"
/**
* @brief Posted when apply relation successfully.
*
* The pcInfo of this notification is ZNULL.
*/
#define MtcBuddyApplyRelationOkNotification "MtcBuddyApplyRelationOkNotification"
/**
* @brief Posted when failed to apply relation.
*
* The pcInfo of this notification contains
* @ref MtcBuddyReasonKey,
* @ref MtcBuddyReasonDetailKey.
*/
#define MtcBuddyApplyRelationDidFailNotification "MtcBuddyApplyRelationDidFailNotification"
/**
* @brief Posted when accept relation successfully.
*
* The pcInfo of this notification contains is ZNULL.
*/
#define MtcBuddyAcceptRelationOkNotification "MtcBuddyAcceptRelationOkNotification"
/**
* @brief Posted when failed to accept relation.
*
* The pcInfo of this notification contains
* @ref MtcBuddyReasonKey,
* @ref MtcBuddyReasonDetailKey.
*/
#define MtcBuddyAcceptRelationDidFailNotification "MtcBuddyAcceptRelationDidFailNotification"
/**
* @brief Posted when refuse relation successfully.
*
* The pcInfo of this notification is ZNULL.
*/
#define MtcBuddyRefuseRelationOkNotification "MtcBuddyRefuseRelationOkNotification"
/**
* @brief Posted when failed to refuse relation.
*
* The pcInfo of this notification contains
* @ref MtcBuddyReasonKey,
* @ref MtcBuddyReasonDetailKey.
*/
#define MtcBuddyRefuseRelationDidFailNotification "MtcBuddyRefuseRelationDidFailNotification"
/**
* @brief Posted when receive buddy apply message.
*
* The pcInfo of this notification contains
* @ref MtcBuddyApplyIdKey,
* @ref MtcBuddyUidKey,
* @ref MtcBuddyRelationTypeKey,
* @ref MtcBuddyDisplayNameKey,
* @ref MtcBuddyApplyDescriptionKey.
*/
#define MtcBuddyApplyReceivedNotification "MtcBuddyApplyReceivedNotification"
/**
* @brief Posted when receive buddy apply complete message.
*
* The pcInfo of this notification contains
* @ref MtcBuddyApplyIdKey,
* @ref MtcBuddyApplyResultKey.
* If apply success maybe also contain
* @ref MtcBuddyUpdateTimeKey,
* @ref MtcBuddyBaseTimeKey,
* @ref MtcBuddyIsPartialUpdateKey,
* @ref MtcBuddyAddedRelationListKey,
* @ref MtcBuddyUpdatedRelationListKey,
* @ref MtcBuddyRemovedRelationListKey.
*/
#define MtcBuddyApplyCompletedNotification "MtcBuddyApplyCompletedNotification"
/**
* @brief Posted when check relation ok.
*
* The pcInfo of this notification contains
* @ref MtcBuddyRelationTypeKey.
*/
#define MtcBuddyCheckRelationOkNotification "MtcBuddyCheckRelationOkNotification"
/**
* @brief Posted when check relation failed.
*
* The pcInfo of this notification contains
* @ref MtcBuddyReasonKey,
* @ref MtcBuddyReasonDetailKey.
*/
#define MtcBuddyCheckRelationDidFailNotification "MtcBuddyCheckRelationDidFailNotification"
/** @} */
/**
* @defgroup MtcBuddyReason MTC reason string.
* @{
*/
#define MTC_ERROR_BUDDY_NOT_FOUND "MtcBuddy.NotFound"
#define MTC_ERROR_BUDDY_NO_PROPERTY "MtcBuddy.NoProperty"
#define MTC_ERROR_BUDDY_TIMEOUT "MtcBuddy.Timeout"
/** @} */
#ifdef __cplusplus
EXPORT_FLAG {
#endif
/**
* @brief Query buddy's property.
*
* @param [in] zCookie The cookie which you want to set.
* @param [in] pcUri The query user's URI.
* @param [in] pcPropInfo The query property's name(s) info. For just one property, using its name directily.
* For multiple propertys, it must be a string in JSON format,
* which contains an array of string. Each string is the name of property.
*
* @retval ZOK on invoke this interface successfully. The result will notify
* to user with @ref MtcBuddyQueryPropertyOkNotification
* or @ref MtcBuddyQueryPropertyDidFailNotification.
* @retval ZFAILED failed
*/
MTCFUNC ZINT Mtc_BuddyQueryProperty(ZCOOKIE zCookie,
ZCONST ZCHAR *pcUri, ZCONST ZCHAR *pcPropInfo);
/**
* @brief Query buddy's login information.
*
* @param [in] zCookie The cookie which you want to set.
* @param [in] pcUri The query user's URI.
*
* @retval ZOK on invoke this interface successfully. The result will notify
* to user with @ref MtcBuddyQueryLoginPropertiesOkNotification
* or @ref MtcBuddyQueryLoginPropertiesDidFailNotification.
* @retval ZFAILED failed
*/
MTCFUNC ZINT Mtc_BuddyQueryLoginProperties(ZCOOKIE zCookie,
ZCONST ZCHAR *pcUri);
/**
* @brief Query buddy's login information.
*
* @param [in] zCookie The cookie which you want to set.
* @param [in] pcUri The query user's URI.
* @param [in] iExpireSeconds The expiration seconds for query.
*
* @retval ZOK on invoke this interface successfully. The result will notify
* to user with @ref MtcBuddyQueryLoginInfoOkNotification
* or @ref MtcBuddyQueryLoginInfoDidFailNotification.
* @retval ZFAILED failed
*/
MTCFUNC ZINT Mtc_BuddyQueryLoginInfo(ZCOOKIE zCookie,
ZCONST ZCHAR *pcUri, ZINT iExpireSeconds);
/**
* @brief Query buddy's UserId information.
*
* @param zCookie The cookie value.
* @param pcInfo The query information. For just one user, using its URI directily.
* For multiple users, it must be a string in JSON format,
* which contains an array of string. Each string is the user's URI
* which wants be queried.
*
* @retval ZOK on invoke this interface successfully. The result will notify
* to user with @ref MtcBuddyQueryUserIdOkNotification
* or @ref MtcBuddyQueryUserIdDidFailNotification.
* @retval ZFAILED failed
*/
MTCFUNC ZINT Mtc_BuddyQueryUserId(ZCOOKIE zCookie, ZCONST ZCHAR *pcInfo);
/**
* @brief Query buddy's AccountId information.
*
* @param zCookie The cookie value.
* @param pcInfo The query information. For just one user, using its UserId directily.
* For multiple users, it must be a string in JSON format,
* which contains an array of string. Each string is the user's UserId
* which wants be queried.
*
* @retval ZOK on invoke this interface successfully. The result will notify
* to user with @ref MtcBuddyQueryAccountIdOkNotification
* or @ref MtcBuddyQueryAccountIdDidFailNotification.
* @retval ZFAILED failed
*/
MTCFUNC ZINT Mtc_BuddyQueryAccountId(ZCOOKIE zCookie, ZCONST ZCHAR *pcInfo);
/**
* @brief Query users' login status.
*
* @param zCookie The cookie value
* @param pcInfo For just one user, using its URI directily.
* For multiple users, it is a JSON array, each item is the string of user's URI.
* @param pcTypes The query status type. ZNULL for all.
* For just one type, using its type stinrg directily.
* For multiple types, it is a JSON array, each item is the string of type.
*
* @retval ZOK on invoke this interface successfully. The result will notify
* to user with @ref MtcBuddyQueryUsersStatusOkNotification
* or @ref MtcBuddyQueryUsersStatusDidFailNotification.
* @retval ZFAILED failed
*/
MTCFUNC ZINT Mtc_BuddyQueryUsersStatus(ZCOOKIE zCookie, ZCONST ZCHAR *pcInfo,
ZCONST ZCHAR *pcTypes);
/**
* @brief Refresh all relations
*
* @param zCookie The cookie value.
* @param qwUpdateTime The start time point to refresh
*
* @retval ZOK on invoke this interface successfully. The result will notify
* to user with @ref MtcBuddyRefreshOkNotification
* or @ref MtcBuddyRefreshDidFailNotification.
* @retval ZFAILED failed
*/
MTCFUNC ZINT Mtc_BuddyRefresh(ZCOOKIE zCookie, ZINT64 qwUpdateTime);
/**
* @brief Add relation
*
* @param zCookie The cookie value.
* @param iRelationType The relation type, @ref EN_MTC_BUDDY_RELATION_TYPE
* @param pcUri The user URI.
* @param pcDisplayName The display name of the relation
* @param pcTag The tag info of the relation.
*
* @retval ZOK on invoke this interface successfully. The result will notify
* to user with @ref MtcBuddyAddRelationOkNotification
* or @ref MtcBuddyAddRelationDidFailNotification.
* @retval ZFAILED failed
*/
MTCFUNC ZINT Mtc_BuddyAddRelation(ZCOOKIE zCookie, ZINT iRelationType,
ZCONST ZCHAR *pcUri, ZCONST ZCHAR *pcDisplayName, ZCONST ZCHAR *pcTag);
/**
* @brief Update relation
*
* @param zCookie The cookie value.
* @param iRelationType The relation type, @ref EN_MTC_BUDDY_RELATION_TYPE
* @param pcUri The UserID
* @param pcDisplayName The display name of the relation
* @param pcTag The tag info of the relation.
*
* @retval ZOK on invoke this interface successfully. The result will notify
* to user with @ref MtcBuddyUpdateRelationOkNotification
* or @ref MtcBuddyUpdateRelationDidFailNotification.
* @retval ZFAILED failed
*/
MTCFUNC ZINT Mtc_BuddyUpdateRelation(ZCOOKIE zCookie, ZINT iRelationType,
ZCONST ZCHAR *pcUri, ZCONST ZCHAR *pcDisplayName, ZCONST ZCHAR *pcTag);
/**
* @brief Remove relation
*
* @param zCookie The cookie value.
* @param pcUri The UserID
*
* @retval ZOK on invoke this interface successfully. The result will notify
* to user with @ref MtcBuddyRemoveRelationOkNotification
* or @ref MtcBuddyRemoveRelationDidFailNotification.
* @retval ZFAILED failed
*/
MTCFUNC ZINT Mtc_BuddyRemoveRelation(ZCOOKIE zCookie,
ZCONST ZCHAR *pcUri);
/**
* @brief Set status of mine to one buddy.
*
* @param zCookie The cookie value.
* @param pcUid The uid of the user
* @param pcKey The status key
* @param pcValue The status value
*
* @retval ZOK on invoke this interface successfully. The result will notify
* to user with @ref MtcBuddySetMyStatusOkNotification
* or @ref MtcBuddySetMyStatusDidFailNotification.
* @retval ZFAILED failed
*/
MTCFUNC ZINT Mtc_BuddySetMyStatus(ZCOOKIE zCookie,
ZCONST ZCHAR *pcUid, ZCONST ZCHAR *pcKey, ZCONST ZCHAR *pcValue);
/**
* @brief Get status of my buddies.
*
* @param zCookie The cookie value.
* @param pcUids The uid of the user, or a string which is a JSON array, each item
* is the uid of the user.
*
* @retval ZOK on invoke this interface successfully. The result will notify
* to user with @ref MtcBuddyGetRelationStatusOkNotification
* or @ref MtcBuddyGetRelationStatusDidFailNotification.
* @retval ZFAILED failed
*/
MTCFUNC ZINT Mtc_BuddyGetRelationStatus(ZCOOKIE zCookie,
ZCONST ZCHAR *pcUids);
/**
* @brief Set batch relations
*
* @param zCookie The cookie value.
* @param pcInfo The string in JSON, which contains
@ref MtcBuddyListToAddKey, @ref MtcBuddyListToUpdateKey, @ref MtcBuddyListToRemoveKey.
*
* @retval ZOK on invoke this interface successfully. The result will notify
* to user with @ref MtcBuddySetRelationsOkNotification
* or @ref MtcBuddySetRelationsDidFailNotification.
* @retval ZFAILED failed
*/
MTCFUNC ZINT Mtc_BuddySetRelations(ZCOOKIE zCookie, ZCONST ZCHAR *pcInfo);
/**
* @brief Apply relation.
*
* @param zCookie The cookie value.
* @param pcUri The uri or uid of the user.
* @param iRelationType The relation type, @ref EN_MTC_BUDDY_RELATION_TYPE.
* @param pcDescription The description about how you find the relation.
*
* @retval ZOK on invoke this interface successfully. The result will notify
* to user with @ref MtcBuddyApplyRelationOkNotification
* or @ref MtcBuddyApplyRelationDidFailNotification.
* @retval ZFAILED failed
*/
MTCFUNC ZINT Mtc_BuddyApplyRelation(ZCOOKIE zCookie, ZCONST ZCHAR *pcUri,
ZUINT iRelationType, ZCONST ZCHAR *pcDescription);
/**
* @brief Accept relation.
*
* @param zCookie The cookie value.
* @param dwMsgId The message id of apply request.
* @param pcDisplayName The display name of the relation.
* @param pcTag The tag info of the relation that may contains
* @ref MtcGroupTagKey.
*
* @retval ZOK on invoke this interface successfully. The result will notify
* to user with @ref MtcBuddyAcceptRelationOkNotification
* or @ref MtcBuddyAcceptRelationDidFailNotification.
* @retval ZFAILED failed
*/
MTCFUNC ZINT Mtc_BuddyAcceptRelation(ZCOOKIE zCookie, ZINT64 dwMsgId,
ZCONST ZCHAR *pcDisplayName, ZCONST ZCHAR *pcTag);
/**
* @brief Refuse relation.
*
* @param zCookie The cookie value.
* @param dwMsgId The message id of apply request.
* @param pcDescription The description of refuse reason.
*
* @retval ZOK on invoke this interface successfully. The result will notify
* to user with @ref MtcBuddyRefuseRelationOkNotification
* or @ref MtcBuddyRefuseRelationDidFailNotification.
* @retval ZFAILED failed
*/
MTCFUNC ZINT Mtc_BuddyRefuseRelation(ZCOOKIE zCookie, ZINT64 dwMsgId, ZCONST ZCHAR *pcDescription);
/**
* @brief Check relation.
*
* @param zCookie The cookie value.
* @param pcTargetUid The target user uid or uri.
*
* @retval ZOK on invoke this interface successfully. The result will notify
* to user with @ref MtcBuddyCheckRelationOkNotification
* or @ref MtcBuddyCheckRelationDidFailNotification.
* @retval ZFAILED failed
*/
MTCFUNC ZINT Mtc_BuddyCheckRelation(ZCOOKIE zCookie, ZCONST ZCHAR *pcTargetUid);
/**
* @brief Set transient status of mine to one buddy.
*
* @param zCookie The cookie value.
* @param pcUid The uid of the user
* @param pcKey The status key
* @param pcValue The status value
*
* @retval ZOK on invoke this interface successfully. The result will notify
* to user with @ref MtcBuddySetMyStatusOkNotification
* or @ref MtcBuddySetMyStatusDidFailNotification.
* @retval ZFAILED failed
*/
MTCFUNC ZINT Mtc_BuddySetTransientStatus(ZCOOKIE zCookie,
ZCONST ZCHAR *pcUid, ZCONST ZCHAR *pcKey, ZCONST ZCHAR *pcValue);
/**
* @brief Set persistent status of mine to one buddy.
*
* @param zCookie The cookie value.
* @param pcUid The uid of the user
* @param pcKey The status key
* @param pcValue The status value
*
* @retval ZOK on invoke this interface successfully. The result will notify
* to user with @ref MtcBuddySetMyStatusOkNotification
* or @ref MtcBuddySetMyStatusDidFailNotification.
* @retval ZFAILED failed
*/
MTCFUNC ZINT Mtc_BuddySetPersistentStatus(ZCOOKIE zCookie,
ZCONST ZCHAR *pcUid, ZCONST ZCHAR *pcKey, ZCONST ZCHAR *pcValue);
#ifdef __cplusplus
}
#endif
#endif /* _MTC_BUDDY_H__ */