Community
The Community API service offers you the ability to discover, search, and retrieve communities related to recipe content that exist on Whisk.
Let's first understand the Community object and its data structure before looking at its endpoints’ description.
Community Object
A Community object is a collection of arrays and attributes that defines the data structure for any given community.
This is how the data structure of a community looks:
{
"community": {
"id": "39d539c738eb47debfb1a6319d34235a",
"name": "WAPID Community",
"image": {
...
},
"description": "Food and fun with WAPID!",
"topics": [
{
"id": "914d167bb1754adbbcd1f085cdcc4f6c",
"display_name": "Family Friendly"
}
],
"social_settings": {
"website_url": "https://wapid.com/",
"instagram_username": "wapid",
"youtube_channel_url": "https://www.youtube.com/channel/WAPID",
"tiktok_username": "wapid"
},
"permissions": {
"role": "COMMUNITY_ROLE_OWNER",
"mode": "COMMUNITY_CONTRIBUTION_PERMISSION_MODE_ANYONE",
"visibility": "COMMUNITY_VISIBILITY_PUBLIC"
},
"members": {
"count": 1
},
"recipes": {
"count": 2
},
"is_sponsored": true
}
}Core Data
The following attributes define the core of a community:
id
string
The community identifier.
name
string
The full name of the community.
image
object
The community's cover image details.
Image
The image object contains the following attributes that store details of the cover image added in the community.
"image": {
"url": "https://image-cdn.whisk.com/image/upload/v1611066523/v3/user-recipes/nfaul13bavzqyiirk0sl.jpg",
"width": 1280,
"height": 854
"selection": {
"x": 0,
"y": 88,
"width": 422,
"height": 767
}
},url
string
The cover image URL.
width
string
Image width.
height
string
Image height.
selection
object
It contains the x and y coordinates and the actual size of the cover image on display.
Optional Data
The community data structure may include extra information based on any additional parameters included in the API request.
description
string
A summary describing the community.
social_settings
object
It contains the community's account on various social platforms like Facebook, Instagram, etc. For more information, see social settings.
permissions
object
It contains the different permissions configured for the community. For more information, see permissions.
members
object
It contains the count of members in the community.
recipes
object
It contains the count of recipes added to the community.
is_sponsored
boolean
Indicates if the community is commercially sponsored or not.
Topics
Topics are categories that appear on the home page of your Whisk app or website like - Featured Communities, 30 Minutes Meals, Quick and Healthy, etc. Each community is assigned a category at the time of its creation, and later we may also add it to the Featured Communities topic if we like it. The topics array contains a list of such topics that include the community.
"topics": [
{
"id": "914d167bb1754adbbcd1f085cdcc4f6c",
"display_name": "Family Friendly"
},
{
"id": "69f7f66c4c774fcf90ba4d5762f06517",
"display_name": "Featured Communities"
}
],Each topic contains the following attributes:
id
string
The topic identifier.
display_name
string
Topic's name as it appears on the Whisk website or app.
Social Settings
This object contains details on the community's presence on different social platforms.
"social_settings": {
"website_url": "https://wapid.com/",
"instagram_username": "@wapid",
"youtube_channel_url": "https://www.youtube.com/channel/WAPID",
"tiktok_username": "@wapid"
},website_url
string
The community's website.
instagram_username
string
The community's Instagram username.
youtube_channel_url
string
The community channel on Youtube.
tiktok_username
string
The community's TikTok username.
Permissions
This object contains information on your role in the community and other details like the community's general visibility and contribution scope.
"permissions": {
"role": "COMMUNITY_ROLE_OWNER",
"mode": "COMMUNITY_CONTRIBUTION_PERMISSION_MODE_ANYONE",
"visibility": "COMMUNITY_VISIBILITY_PUBLIC"
},role
enum
Indicates your role in the community.
COMMUNITY_ROLE_INVALIDCOMMUNITY_ROLE_UNSETCOMMUNITY_ROLE_OWNERCOMMUNITY_ROLE_ADMINCOMMUNITY_ROLE_MEMBERCOMMUNITY_ROLE_BLOCKEDCOMMUNITY_ROLE_PENDING
mode
enum
Indicates the contribution mode configured for the community. By default, it is set to Anyone.
COMMUNITY_CONTRIBUTION_PERMISSION_MODE_INVALIDCOMMUNITY_CONTRIBUTION_PERMISSION_MODE_ANYONECOMMUNITY_CONTRIBUTION_PERMISSION_MODE_ADMINS
visibility
enum
Indicates the community's visibility on the Whisk's website or app. By default, it is set to Public.
COMMUNITY_VISIBILITY_INVALIDCOMMUNITY_VISIBILITY_PUBLICCOMMUNITY_VISIBILITY_PRIVATE
Endpoints
Community API includes the following endpoints that you can use to pull, discover or search communities and their details.
Get your CommunitiesGet Communities from a TopicDiscover Recommended CommunitiesSearch CommunitiesGet a CommunityGet Recipes from a CommunityAdd Recipes to a CommunityRemove a Recipe from a CommunityJoin a CommunityLeave a CommunityLast updated
Was this helpful?