// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. // SPDX-License-Identifier: Apache-2.0 import { UpdateEndpointException } from '@aws-amplify/core/internals/providers/pinpoint'; import { PlatformNotSupportedError } from '@aws-amplify/core/internals/utils'; import { PushNotificationValidationErrorCode } from '../../../errors'; import { IdentifyUser, IdentifyUserInput } from '../types'; /** * Sends information about a user to Pinpoint. Sending user information allows you to associate a user to their user * profile and activities or actions in your application. Activity can be tracked across devices & platforms by using * the same `userId`. * * @deprecated AWS will end support for Amazon Pinpoint on October 30, 2026. * * @param {IdentifyUserInput} input The input object used to construct requests sent to Pinpoint's UpdateEndpoint * API. * @throws service: {@link UpdateEndpointException} - Thrown when the underlying Pinpoint service returns an error. * @throws validation: {@link PushNotificationValidationErrorCode} - Thrown when the provided parameters or library * configuration is incorrect. * @throws platform: {@link PlatformNotSupportedError} - Thrown if called against an unsupported platform. Currently, * only React Native is supported by this API. * @returns A promise that will resolve when the operation is complete. * @example * ```ts * // Identify a user with Pinpoint * await identifyUser({ * userId, * userProfile: { * email: 'userEmail@example.com' * customProperties: { * phoneNumber: ['555-555-5555'], * }, * } * }); * ``` * * @example * ```ts * // Identify a user with Pinpoint specific options * await identifyUser({ * userId, * userProfile: { * email: 'userEmail@example.com' * customProperties: { * phoneNumber: ['555-555-5555'], * }, * demographic: { * platform: 'ios', * timezone: 'America/Los_Angeles' * } * }, * options: { * address: 'device-address', * optOut: 'NONE', * userAttributes: { * interests: ['food'] * }, * }, * }); */ export const identifyUser: IdentifyUser = async () => { throw new PlatformNotSupportedError(); };