Activity Feeds v3 is in beta — try it out!

Querying Activities

Activity Search & Queries

You can query & search activities. Here’s an example of how to query activities:

final query = ActivitiesQuery(
  filter: const Filter.equal(ActivitiesFilterField.type, 'post'),
  sort: [ActivitiesSort.desc(ActivitiesSortField.createdAt)],
  limit: 10,
);

final activityList = client.activityList(query);
final activities = await activityList.get();

The syntax emulates a MongoDB style query syntax. (It emulates it, we don’t use MongoDB, but the query syntax is nice here).

Querying activities by text

// search for activities where the text includes the word 'popularity'.
const query = ActivitiesQuery(
  filter: Filter.equal(ActivitiesFilterField.text, 'popularity'),
);

final activityList = client.activityList(query);
final activities = await activityList.get();

Querying activities by search data

Consider this example activity:

{
  "id": "activity-123",
  "type": "post",
  "text": "Check out our spring sale!",
  "search_data": {
    "campaign": {
      "id": "spring-sale-2025",
      "location": {
        "mall": "yorkdale",
        "city": "toronto",
        "country": "canada"
      }
    }
  }
  // ... other activity fields
}

You can search this activity using the search_data field in several ways:

// search for activities associated with the campaign ID 'spring-sale-2025'
final searchValue = {
  'campaign': {'id': 'spring-sale-2025'},
};

final query = ActivitiesQuery(
  filter: Filter.contains(ActivitiesFilterField.searchData, searchValue),
);

final activityList = client.activityList(query);
final activities = await activityList.get();

// search for activities where the campaign took place in a mall
const query2 = ActivitiesQuery(
  filter: Filter.pathExists(
    ActivitiesFilterField.searchData,
    'campaign.location.mall',
  ),
);

final activityList2 = client.activityList(query2);
final activities2 = await activityList2.get();

Activities Queryable Built-In Fields

nametypedescriptionsupported operationsexample
idstring or list of stringsThe ID of the activity$in, $eq{ id: { $in: [ 'abc', 'xyz' ] } }
activity_typestring or list of stringsThe type of the activity$in, $eq{ activity_type: { $in: [ 'abc', 'xyz' ] } }
user_idstring or list of stringsThe ID of the user who created the activity$in, $eq{ user_id: { $in: [ 'abc', 'xyz' ] } }
textstringThe text content of the activity$eq, $q, $autocomplete{ text: { $q: 'popularity' } }
search_dataobjectThe extra metadata for search indexing$contains, $path_exists{ search_data: { $contains: { 'category': 'sports', 'status': 'active' } } }
interest_tagslist of stringsTags for user interests$eq, $contains{ interest_tags: { $in: [ 'sports', 'music' ] } }
filter_tagslist of stringsTags for filtering$eq, $contains{ filter_tags: { $in: [ 'categoryA', 'categoryB' ] } }
created_atstring, must be formatted as an RFC3339 timestampThe time the activity was created$eq, $gt, $lt, $gte, $lte{ created_at: { $gte: '2023-12-04T09:30:20.45Z' } }
popularitynumberThe popularity score of the activity$eq, $ne, $gt, $lt, $gte, $lte{ popularity: { $gte: 70 } }
nearobjectIndicates the GEO point to search nearby activities$eq{ near: { $eq: { lat: 40.0, lng: -74.0, distance: 200 } } }
within_boundsobjectIndicates the GEO bounds to search for activities within$eq{ within_bounds: { $eq: { ne_lat: 40.0, ne_lng: -115.0, sw_lat: 32.0, sw_lng: -125.0 } } }

Be sure to reach out to support if you need additional query activity capabilities.

Activities sort options

Fields:

  • created_at
  • popularity

Direction: 1 or -1

© Getstream.io, Inc. All Rights Reserved.