Snap Places API
Snap Places API for Lenses, which powers how different places interact in the Snapchat Map, offers Lens Developers a way to bringing the Snapchat map into a Lens. This will allow for developers to pull in data on places that are nearby them within a Lens.
Endpoints
This section documents the API endpoints of the Snap Places API for use with the Remote Service Module
. This API can be used to get information from the Snapchat Map that users can interact with.
get_nearby_places
List Nearby Places given a location.
This will give you the place_id
which you can use with other APIs to get more information.
lat
and lng
will automatically be filled in by the Lens to allow you to get nearby places from a user. Thus, you can get a list of nearby places like so:
Parameters
Name | Type | Description |
---|---|---|
lat | Double | Latitude of the device. The default value is based on the user's location. |
lng | Double | Longitude of the device. The default value is based on the user's location. |
gps_accuracy_m | Double | Horizontal GPS accuracy of the device. The default is set to 65. |
places_limit | int32 | Maximum number of nearby place results to return. Default is 10. |
If you set gps_accuracy to a value greater than 3000, then you may not return any venues. If you set value less than 3000, we will calculate the search radius by min(100m, req.radius + buffer), the buffer is 50 meters. If you don't set gps accuracy at all, we will use default radius of 65m.
Response
Name | Type | Description |
---|---|---|
nearby_places | NearbyPlace | Message that stores relevant information for the place. |
NearbyPlace
provides the following information:
Name | Type | Description |
---|---|---|
place_id | string | The unique identifier for the place. |
name | string | Localized name of the place. |
rank | int32 | Rank order of the place returned. |
subtitle | string | Additional descriptive text for the place. |
is_reportable | bool | Indicates if this place can be reported by users. |
placeTypeEnum | string | The type of place it is (e.g. VENUE). |
categoryId | uuid | The ID of the category this place is under. |
categoryName | string | The name of the category this place is under. |
Example
function onReceiveNearbyPlaces(isError, places) {
// Get the names and id of nearby places
places.nearbyPlaces.map((place) => {
print(place.name + ' ' + place.placeId);
});
}
ApiModule.get_nearby_places(null, null, null, null, onReceiveNearbyPlaces);
get_places_profile
Renders the metadata needed to build Place Listings.
This will give you some of the basic data of a multiple places simultaneously, such as its opening hours, address, and phone numbers.
Parameters
Name | Type | Description |
---|---|---|
place_ids | String | List of place_ids for which to retrieve place listings data. |
locale | String | Optional: Locale set in the request; if not in the header, defaults to acceptHeader . |
Response
Name | Type | Description |
---|---|---|
place_profiles | PlaceProfile | List of PlaceProfile metadata respective to the IDs passed. Order is not maintained. Limit of 100 place_ids per call. |
Example
You can get the opening hours of nearby places using the place_profile
.
function onReceiveNearbyPlaces(isError, places) {
const listOfPlaceIds = JSON.stringify(
places.nearbyPlaces.map((p) => p.placeId)
);
ApiModule.get_places_profile(
listOfPlaceIds,
null,
function (isError, placeProfiles) {
print(JSON.stringify(placeProfiles));
}
);
}
ApiModule.get_nearby_places(null, null, null, null, onReceiveNearbyPlaces);
get_place
Renders the complete metadata associated with the place.
You can use this API to get as much information as possible on a single place.
Parameters
Name | Type | Description |
---|---|---|
place_id | String | place_id for which to retrieve place listings data. |
Response
Name | Type | Description |
---|---|---|
place | Place | Place metadata. |
Example
You can get detailed information on the highest ranked nearby place like so:
function onReceiveNearbyPlaces(isError, places) {
ApiModule.get_place(
places.nearbyPlaces[0].placeId,
function (isError, placeMetadata) {
print(JSON.stringify(placeMetadata));
}
);
}
ApiModule.get_nearby_places(null, null, null, null, onReceiveNearbyPlaces);