Use existing Amazon Location resources
You can also use Amplify Geo with your existing Amazon Location Service resources if you'd like, there are some manual setup that you need to do.
Authorization permissions
To use your existing Amazon Location Service resources, i.e. maps and place indices, with Amplify Geo, you need to ensure your role has the right authorization permissions through Cognito. If you set up your Cognito resources in any way other than the Amplify CLI or Amplify Studio, the roles will need to be given permission to access the map and place indices.
Note: Here is a guide on Creating an Amazon Cognito identity pool for use with Amazon Location Service
There are two roles created by Cognito: an Auth_Role
that grants signed-in-user-level access and an Unauth_Role
that allows unauthenticated access to resources. Attach the following policies for the appropriate resources and roles (Auth and/or Unauth). Replace {region}
, {account-id}
, and {enter Map/PlaceIndex name}
with the correct items. Note that certain actions cannot be performed with unauthenticated access. The list of actions allowed for the Unauth role is in the Granting access to Amazon Location Service guide.
{ "Version": "2012-10-17", "Statement": [ { "Sid": "GetTiles", "Effect": "Allow", "Action": [ "geo:GetMapTile", "geo:GetMapSprites", "geo:GetMapGlyphs", "geo:GetMapStyleDescriptor" ], "Resource": "arn:aws:geo:{region}:{account-id}:map/{enter Map name}" }, { "Sid": "Search", "Effect": "Allow", "Action": [ "geo:SearchPlaceIndexForPosition", "geo:SearchPlaceIndexForText" ], "Resource": "arn:aws:geo:{region}:{account-id}:place-index/{enter PlaceIndex name}" } ]}
In your application
You can first import and configure the CLI generated amplifyconfiguration.json
. You can then manually configure Amplify Geo like this:
import { Amplify } from 'aws-amplify';import amplifyconfig from './amplifyconfiguration.json';
Amplify.configure(amplifyconfig);Amplify.configure({ ...Amplify.getConfig(), Geo: { LocationService: { maps: { items: { XXXXXXXXXXX: { // REQUIRED - Amazon Location Service Map resource name style: 'VectorEsriStreets' // REQUIRED - String representing the style of map resource } }, default: 'XXXXXXXXXXX' // REQUIRED - Amazon Location Service Map resource name to set as default }, search_indices: { items: ['XXXXXXXXX', 'XXXXXXXXX'], // REQUIRED - Amazon Location Service Place Index name default: 'XXXXXXXXX' // REQUIRED - Amazon Location Service Place Index name to set as default }, geofenceCollections: { items: ['XXXXXXXXX', 'XXXXXXXXX'], // REQUIRED - Amazon Location Service Geofence Collection name default: 'XXXXXXXXX' // REQUIRED - Amazon Location Service Geofence Collection name to set as default }, region: 'XX-XXXX-X' // REQUIRED - Amazon Location Service Region } }});
Now you can proceed to displaying a map or adding location search to your app.