locality_social_cloud_friendlist

A Flutter package based on Locality Social Cloud that provides a pub-sub based friend list system for sending and receiving friend requests between users. This package allows you to manage friend lists securely and efficiently, using SHA-256 for topic hashing and pub-sub mechanisms for event-driven updates.

Features

  • Send and receive friend requests between users.
  • Manage friend lists via a pub-sub architecture.
  • Automatically register and track friend lists.
  • Securely generate unique friend list topics using SHA-256 hashing.
  • Check the friend status between users easily.

Setup

Configure your Locality Social Cloud and enter your appId and appSecret and connect the Cloud:

    LocalitySocialCloud.configure(appId: '..', appSecret: '...=');

    LoggedInUser loggedInUser = (await LocalitySocialCloud.auth('testuser1', 'pwd1')).loggedInUser!;
    LocalityUser user1 = loggedInUser.user;
    LocalityUser user2 = (await LocalitySocialCloud.auth('testuser2', 'pwd2')).loggedInUser!.user;

Usage

Get the FriendList of a LocalityUser:

FriendList friendList1 = FriendListFacade.getFriendListOfUser(user1);
FriendList friendList2 = FriendListFacade.getFriendListOfUser(user2);

If you want to display the FriendList in the UI, you could use this style:

friendList1.addListener(() {
      logger.info("These are all friends in the friendlist 1 after one throttled UI update: ");
      for (var friendRequest in friendList1.friendRequests) {
        ....
      }
});

The FriendList is a ThrottledProvider and can be easily be used together with the Provider package to display UI changes.

Let us say, you want to send a friend request only if you have not sent one so far. Then you can use the Timeline of the FriendList like this:

friendList1.timeline.whenSynchronized(() {
      logger.info("The timelines are now synchronized of friendlist1.");
      logger.info("Now we know whether the target user is our friend and we can send him a friend request if he is not.");
      if (!friendList1.sentFriendRequestToUser(user2)) {
        logger.info("Sending friend request ... ");
        FriendListFacade.sendFriendRequest(user1, user2);
      }
});

You can also check if they sent a friend request to each other like this:

friendList1.timeline.whenSynchronized(() {
    if ( friendList1.isFriendsWithThisUser(user2) ) {
        ....
    }
});

after initialization.

You can get a list of all the friends ( where they sent friend requests to each other ) like

friendList1.timeline.whenSynchronized(() {
    List<LocalityUser> friends = friendList1.computeFriends();
});