tencent cloud

Feedback

Android&iOS&Windows&Mac

Last updated: 2025-01-03 10:36:20

    Feature Description

    To block a user's messages, add the user to the blocklist.

    Blocklists

    Blocking a user

    Call addToBlackList (Java / Swift / Objective-C / C++) to add a user to the blocklist, that is, block the user. If you have called addFriendListener to add a listener, blocking a user will trigger the onBlackListAdded callback.
    Note:
    1. If users A and B are friends, after either user A or user B is blocked by the other user, the two-way friend relationship will be terminated by default, and they cannot start a conversation with or send a friend request to each other.
    2. If you want to keep users' friend relationship after being blacklisted,you can log in to the Console, and edit the Block configuration, toggle path: Applications > Your App > Chat > Configuration > Friends and Relationship Chains > Block configuration.
    By default, a blocked user does not know that he/she is "blocked". After the user sends a message, the error code indicating that he/she has been blocked will not be returned. To have the "You have been blocked by the user" error message returned after a blocked user sends a message, you can log in to the Console and disable Blocklist Check. Then the SDK will report error code 20007 after a blocked user sends a message. The configuration path is: Applications > Your App > Chat > Configuration > Login and Message > Blocklist Check.
    Sample code:
    Java
    Swift
    Objective-C
    C++
    List<String> userIDList = new ArrayList<>();
    userIDList.add("user1");
    userIDList.add("user2");
    V2TIMManager.getFriendshipManager().addToBlackList(userIDList, new V2TIMValueCallback<List<V2TIMFriendOperationResult>>() {
    @Override
    public void onSuccess(List<V2TIMFriendOperationResult> v2TIMFriendOperationResults) {
    // User blocked successfully
    }
    
    @Override
    public void onError(int code, String desc) {
    // Failed to block the user
    }
    });
    
    // Listen for the notification of a user added to the blocklist
    V2TIMManager.getFriendshipManager().addFriendListener(new V2TIMFriendshipListener() {
    @Override
    public void onBlackListAdd(List<V2TIMFriendInfo> infoList) {
    // A user was added to the blocklist.
    }
    });
    V2TIMManager.shared.addToBlackList(userIDList: ["user1", "user2"]) { resultList in
    print( "addToBlackList succ")
    } fail: { code, desc in
    print( "addToBlackList fail, \\(code), \\(desc)")
    }
    V2TIMManager.shared.addFriendListener(listener: self)
    
    func onBlackListAdded(infoList: Array<V2TIMFriendInfo>) {
    print( infoList)
    }
    // Block a user
    [[V2TIMManager sharedInstance] addToBlackList:@[@"user1", @"user2"] succ:^(NSArray<V2TIMFriendOperationResult *> *resultList) {
    // User blocked successfully
    } fail:^(int code, NSString *desc) {
    // Failed to block the user
    }];
    
    // Listen for the notification of a user added to the blocklist
    [[V2TIMManager sharedInstance] addFriendListener:self];
    - (void)onBlackListAdded:(NSArray<V2TIMFriendInfo *>*)infoList {
    // A user was added to the blocklist.
    }
    template <class T>
    class ValueCallback final : public V2TIMValueCallback<T> {
    public:
    using SuccessCallback = std::function<void(const T&)>;
    using ErrorCallback = std::function<void(int, const V2TIMString&)>;
    
    ValueCallback() = default;
    ~ValueCallback() override = default;
    
    void SetCallback(SuccessCallback success_callback, ErrorCallback error_callback) {
    success_callback_ = std::move(success_callback);
    error_callback_ = std::move(error_callback);
    }
    
    void OnSuccess(const T& value) override {
    if (success_callback_) {
    success_callback_(value);
    }
    }
    void OnError(int error_code, const V2TIMString& error_message) override {
    if (error_callback_) {
    error_callback_(error_code, error_message);
    }
    }
    
    private:
    SuccessCallback success_callback_;
    ErrorCallback error_callback_;
    };
    
    V2TIMStringVector userIDList;
    userIDList.PushBack(u8"user1");
    userIDList.PushBack(u8"user2");
    
    auto callback = new ValueCallback<V2TIMFriendOperationResultVector>{};
    callback->SetCallback(
    [=](const V2TIMFriendOperationResultVector& friendOperationResultList) {
    // User blocked successfully
    delete callback;
    },
    [=](int error_code, const V2TIMString& error_message) {
    // Failed to block the user
    delete callback;
    });
    
    V2TIMManager::GetInstance()->GetFriendshipManager()->AddToBlackList(userIDList, callback);
    
    // Listen for the notification of a user added to the blocklist
    class FriendshipListener final : public V2TIMFriendshipListener {
    public:
    void OnBlackListAdded(const V2TIMFriendInfoVector& infoList) override {
    // A user was added to the blocklist.
    }
    // Other members …
    };
    // Add a relationship chain event listener. Keep `friendshipListener` valid before the listener is removed to ensure event callbacks are received.
    FriendshipListener friendshipListener;
    V2TIMManager::GetInstance()->GetFriendshipManager()->AddFriendListener(&friendshipListener);

    Unblocking a user

    Call deleteFromBlackList (Java / Swift / Objective-C / C++) to remove a user from the blocklist, that is, unblock the user, after which the user can send a friend request and start a conversation. If you have called addFriendListener to add a listener, unblocking a user will trigger the onBlackListDeleted callback.
    Sample code:
    Java
    Swift
    Objective-C
    C++
    List<String> userIDList = new ArrayList<>();
    userIDList.add("user1");
    userIDList.add("user2");
    V2TIMManager.getFriendshipManager().deleteFromBlackList(userIDList, new V2TIMValueCallback<List<V2TIMFriendOperationResult>>() {
    @Override
    public void onSuccess(List<V2TIMFriendOperationResult> v2TIMFriendOperationResults) {
    // User unblocked successfully
    }
    
    @Override
    public void onError(int code, String desc) {
    // Failed to unblock the user
    }
    });
    
    // Listen for the notification of a user removed from the blocklist
    V2TIMManager.getFriendshipManager().addFriendListener(new V2TIMFriendshipListener() {
    @Override
    public void onBlackListDeleted(List<String> userList) {
    // A user was removed from the blocklist.
    }
    });
    // Unblock a user
    V2TIMManager.shared.deleteFromBlackList(userIDList: ["user1"]) { resultList in
    print( "deleteFromBlackList succ")
    } fail: { code, desc in
    print( "deleteFromBlackList fail, \\(code), \\(desc)")
    }
    V2TIMManager.shared.addFriendListener(listener: self)
    func onBlackListDeleted(userIDList: Array<String>) {
    print( userIDList)
    }
    // Unblock a user
    [[V2TIMManager sharedInstance] deleteFromBlackList:@[@"user1", @"user2"] succ:^(NSArray<V2TIMFriendOperationResult *> *resultList) {
    // User unblocked successfully
    } fail:^(int code, NSString *desc) {
    // Failed to unblock the user
    }];
    
    // Listen for the notification of a user removed from the blocklist
    [[V2TIMManager sharedInstance] addFriendListener:self];
    - (void)onBlackListDeleted:(NSArray*)userIDList {
    // A user was removed from the blocklist.
    }
    
    template <class T>
    class ValueCallback final : public V2TIMValueCallback<T> {
    public:
    using SuccessCallback = std::function<void(const T&)>;
    using ErrorCallback = std::function<void(int, const V2TIMString&)>;
    
    ValueCallback() = default;
    ~ValueCallback() override = default;
    
    void SetCallback(SuccessCallback success_callback, ErrorCallback error_callback) {
    success_callback_ = std::move(success_callback);
    error_callback_ = std::move(error_callback);
    }
    
    void OnSuccess(const T& value) override {
    if (success_callback_) {
    success_callback_(value);
    }
    }
    void OnError(int error_code, const V2TIMString& error_message) override {
    if (error_callback_) {
    error_callback_(error_code, error_message);
    }
    }
    
    private:
    SuccessCallback success_callback_;
    ErrorCallback error_callback_;
    };
    
    V2TIMStringVector userIDList;
    userIDList.PushBack(u8"user1");
    userIDList.PushBack(u8"user2");
    
    auto callback = new ValueCallback<V2TIMFriendOperationResultVector>{};
    callback->SetCallback(
    [=](const V2TIMFriendOperationResultVector& friendOperationResultList) {
    // User unblocked successfully
    delete callback;
    },
    [=](int error_code, const V2TIMString& error_message) {
    // Failed to unblock the user
    delete callback;
    });
    
    V2TIMManager::GetInstance()->GetFriendshipManager()->DeleteFromBlackList(userIDList, callback);
    
    // Listen for the notification of a user removed from the blocklist
    class FriendshipListener final : public V2TIMFriendshipListener {
    public:
    void OnBlackListAdded(const V2TIMFriendInfoVector& infoList) override {
    // A user was removed from the blocklist.
    }
    // Other members …
    };
    // Add a relationship chain event listener. Keep `friendshipListener` valid before the listener is removed to ensure event callbacks are received.
    FriendshipListener friendshipListener;
    V2TIMManager::GetInstance()->GetFriendshipManager()->AddFriendListener(&friendshipListener);

    Getting a blocklist

    Call getBlackList (Java / Swift / Objective-C / C++) to view how many users have been blocked and manage them.
    Sample code:
    Java
    Swift
    Objective-C
    C++
    V2TIMManager.getFriendshipManager().getBlackList(new V2TIMValueCallback<List<V2TIMFriendInfo>>() {
    @Override
    public void onSuccess(List<V2TIMFriendInfo> v2TIMFriendInfos) {
    // Blocklist obtained successfully
    }
    
    @Override
    public void onError(int code, String desc) {
    // Failed to obtain the blocklist
    }
    });
    V2TIMManager.shared.getBlackList { infoList in
    infoList.forEach { item in
    // V2TIMFriendInfo
    print( item.description)
    }
    } fail: { code, desc in
    print( "getBlackList fail, \\(code), \\(desc)")
    }
    // Obtain a blocklist
    [[V2TIMManager sharedInstance] getBlackList:^(NSArray<V2TIMFriendInfo *> *infoList) {
    // Blocklist obtained successfully
    } fail:^(int code, NSString *desc) {
    // Failed to obtain the blocklist
    }];
    template <class T>
    class ValueCallback final : public V2TIMValueCallback<T> {
    public:
    using SuccessCallback = std::function<void(const T&)>;
    using ErrorCallback = std::function<void(int, const V2TIMString&)>;
    
    ValueCallback() = default;
    ~ValueCallback() override = default;
    
    void SetCallback(SuccessCallback success_callback, ErrorCallback error_callback) {
    success_callback_ = std::move(success_callback);
    error_callback_ = std::move(error_callback);
    }
    
    void OnSuccess(const T& value) override {
    if (success_callback_) {
    success_callback_(value);
    }
    }
    void OnError(int error_code, const V2TIMString& error_message) override {
    if (error_callback_) {
    error_callback_(error_code, error_message);
    }
    }
    
    private:
    SuccessCallback success_callback_;
    ErrorCallback error_callback_;
    };
    
    auto callback = new ValueCallback<V2TIMFriendInfoVector>{};
    callback->SetCallback(
    [=](const V2TIMFriendInfoVector& friendInfoList) {
    // Blocklist obtained successfully
    delete callback;
    },
    [=](int error_code, const V2TIMString& error_message) {
    // Failed to obtain the blocklist
    delete callback;
    });
    
    V2TIMManager::GetInstance()->GetFriendshipManager()->GetBlackList(callback);
    
    
    Contact Us

    Contact our sales team or business advisors to help your business.

    Technical Support

    Open a ticket if you're looking for further assistance. Our Ticket is 7x24 avaliable.

    7x24 Phone Support