diff --git a/.github/workflows/push-integ-test.yml b/.github/workflows/push-integ-test.yml index a7a09f7a539..a56ca5db116 100644 --- a/.github/workflows/push-integ-test.yml +++ b/.github/workflows/push-integ-test.yml @@ -8,7 +8,7 @@ concurrency: on: push: branches: - - feat/example-integ-test-branch/main + - next/main jobs: e2e: diff --git a/packages/analytics/__tests__/providers/pinpoint/apis/record.test.ts b/packages/analytics/__tests__/providers/pinpoint/apis/record.test.ts index 7271be74ebb..62864d6f2b9 100644 --- a/packages/analytics/__tests__/providers/pinpoint/apis/record.test.ts +++ b/packages/analytics/__tests__/providers/pinpoint/apis/record.test.ts @@ -1,3 +1,4 @@ +import { Hub } from '@aws-amplify/core'; import { record as pinpointRecord } from '@aws-amplify/core/internals/providers/pinpoint'; import { ConsoleLogger as Logger } from '@aws-amplify/core/internals/utils'; import { record } from '../../../../src/providers/pinpoint'; @@ -20,35 +21,43 @@ import { config, } from './testUtils/data'; +jest.mock('@aws-amplify/core'); +jest.mock('@aws-amplify/core/internals/providers/pinpoint'); jest.mock('../../../../src/utils'); jest.mock('../../../../src/providers/pinpoint/utils'); -jest.mock('@aws-amplify/core/internals/providers/pinpoint'); describe('Pinpoint API: record', () => { + // create spies + const loggerWarnSpy = jest.spyOn(Logger.prototype, 'warn'); + // create mocks const mockPinpointRecord = pinpointRecord as jest.Mock; const mockResolveConfig = resolveConfig as jest.Mock; const mockResolveCredentials = resolveCredentials as jest.Mock; const mockIsAnalyticsEnabled = isAnalyticsEnabled as jest.Mock; const mockGetAnalyticsUserAgentString = getAnalyticsUserAgentString as jest.Mock; - const loggerWarnSpy = jest.spyOn(Logger.prototype, 'warn'); + const mockHubDispatch = Hub.dispatch as jest.Mock; beforeEach(() => { - mockPinpointRecord.mockReset(); mockPinpointRecord.mockResolvedValue(undefined); - mockResolveConfig.mockReset(); mockResolveConfig.mockReturnValue(config); - mockIsAnalyticsEnabled.mockReset(); mockIsAnalyticsEnabled.mockReturnValue(true); - mockGetAnalyticsUserAgentString.mockReset(); mockGetAnalyticsUserAgentString.mockReturnValue('mock-user-agent'); - mockResolveCredentials.mockReset(); mockResolveCredentials.mockResolvedValue({ credentials, identityId, }); }); + afterEach(() => { + mockPinpointRecord.mockReset(); + mockResolveConfig.mockReset(); + mockIsAnalyticsEnabled.mockReset(); + mockGetAnalyticsUserAgentString.mockReset(); + mockResolveCredentials.mockReset(); + mockHubDispatch.mockClear(); + }); + it('invokes the core record implementation', async () => { record(event); @@ -101,4 +110,17 @@ describe('Pinpoint API: record', () => { expect(mockPinpointRecord).not.toBeCalled(); }); + + it('should dispatch a Hub event', async () => { + record(event); + + await new Promise(process.nextTick); + + expect(mockHubDispatch).toBeCalledWith( + 'analytics', + { event: 'record', data: event, message: 'Recording Analytics event' }, + 'Analytics', + expect.anything() + ); + }); }); diff --git a/packages/analytics/src/providers/pinpoint/apis/record.ts b/packages/analytics/src/providers/pinpoint/apis/record.ts index 49c86b47438..3835148bac0 100644 --- a/packages/analytics/src/providers/pinpoint/apis/record.ts +++ b/packages/analytics/src/providers/pinpoint/apis/record.ts @@ -1,7 +1,9 @@ // Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. // SPDX-License-Identifier: Apache-2.0 +import { Hub } from '@aws-amplify/core'; import { + AMPLIFY_SYMBOL, AnalyticsAction, ConsoleLogger as Logger, } from '@aws-amplify/core/internals/utils'; @@ -59,6 +61,12 @@ export const record = (input: RecordInput): void => { resolveCredentials() .then(({ credentials, identityId }) => { + Hub.dispatch( + 'analytics', + { event: 'record', data: input, message: 'Recording Analytics event' }, + 'Analytics', + AMPLIFY_SYMBOL + ); recordCore({ appId, category: 'Analytics', diff --git a/packages/api-graphql/__tests__/v6-test.ts b/packages/api-graphql/__tests__/v6-test.ts index 9fbd2b44afc..91e86e769be 100644 --- a/packages/api-graphql/__tests__/v6-test.ts +++ b/packages/api-graphql/__tests__/v6-test.ts @@ -16,12 +16,14 @@ import { } from './utils/expects'; import { + __amplify, GraphQLResult, GraphqlSubscriptionResult, GraphqlSubscriptionMessage, GraphQLQuery, GraphQLSubscription, GraphQLReturnType, + V6Client, } from '../src/types'; import { @@ -44,7 +46,10 @@ const serverManagedFields = { describe('client', () => { // `generateClient()` is only exported from top-level API category. - const client = { graphql }; + const client = { + [__amplify]: Amplify, + graphql, + } as V6Client; beforeEach(() => { Amplify.configure({ diff --git a/packages/api-graphql/src/GraphQLAPI.ts b/packages/api-graphql/src/GraphQLAPI.ts index 2189b9c6455..f5d280e258a 100644 --- a/packages/api-graphql/src/GraphQLAPI.ts +++ b/packages/api-graphql/src/GraphQLAPI.ts @@ -1,5 +1,6 @@ // Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. // SPDX-License-Identifier: Apache-2.0 +import { AmplifyClassV6 } from '@aws-amplify/core'; import { GraphQLOptions, GraphQLResult } from './types'; import { InternalGraphQLAPIClass } from './internals'; import { Observable } from 'rxjs'; @@ -30,10 +31,11 @@ export class GraphQLAPIClass extends InternalGraphQLAPIClass { * @returns An Observable if the query is a subscription query, else a promise of the graphql result. */ graphql( + amplify: AmplifyClassV6, options: GraphQLOptions, additionalHeaders?: { [key: string]: string } ): Observable> | Promise> { - return super.graphql(options, additionalHeaders); + return super.graphql(amplify, options, additionalHeaders); } /** diff --git a/packages/api-graphql/src/internals/InternalGraphQLAPI.ts b/packages/api-graphql/src/internals/InternalGraphQLAPI.ts index 255519c9658..79d0d277ac5 100644 --- a/packages/api-graphql/src/internals/InternalGraphQLAPI.ts +++ b/packages/api-graphql/src/internals/InternalGraphQLAPI.ts @@ -9,7 +9,7 @@ import { OperationTypeNode, } from 'graphql'; import { Observable } from 'rxjs'; -import { Amplify, Cache, fetchAuthSession } from '@aws-amplify/core'; +import { AmplifyClassV6 } from '@aws-amplify/core'; import { APIAuthMode, CustomUserAgentDetails, @@ -54,7 +54,6 @@ export class InternalGraphQLAPIClass { private _options; private appSyncRealTime: AWSAppSyncRealTimeProvider | null; - Cache = Cache; private _api = { post, updateRequestToBeCancellable }; /** @@ -71,10 +70,11 @@ export class InternalGraphQLAPIClass { } private async _headerBasedAuth( + amplify: AmplifyClassV6, authMode: APIAuthMode, additionalHeaders: { [key: string]: string } = {} ) { - const config = Amplify.getConfig(); + const config = amplify.getConfig(); const { region: region, endpoint: appSyncGraphqlEndpoint, @@ -95,7 +95,7 @@ export class InternalGraphQLAPIClass { }; break; case 'iam': - const session = await fetchAuthSession(); + const session = await amplify.Auth.fetchAuthSession(); if (session.credentials === undefined) { throw new Error(GraphQLAuthError.NO_CREDENTIALS); } @@ -105,7 +105,9 @@ export class InternalGraphQLAPIClass { try { let token; - token = (await fetchAuthSession()).tokens?.accessToken.toString(); + token = ( + await amplify.Auth.fetchAuthSession() + ).tokens?.accessToken.toString(); if (!token) { throw new Error(GraphQLAuthError.NO_FEDERATED_JWT); @@ -158,6 +160,7 @@ export class InternalGraphQLAPIClass { * @returns An Observable if the query is a subscription query, else a promise of the graphql result. */ graphql( + amplify: AmplifyClassV6, { query: paramQuery, variables = {}, authMode, authToken }: GraphQLOptions, additionalHeaders?: { [key: string]: string }, customUserAgentDetails?: CustomUserAgentDetails @@ -185,6 +188,7 @@ export class InternalGraphQLAPIClass { case 'mutation': const abortController = new AbortController(); const responsePromise = this._graphql( + amplify, { query, variables, authMode }, headers, abortController, @@ -197,6 +201,7 @@ export class InternalGraphQLAPIClass { return responsePromise; case 'subscription': return this._graphqlSubscribe( + amplify, { query, variables, authMode }, headers, customUserAgentDetails @@ -207,12 +212,13 @@ export class InternalGraphQLAPIClass { } private async _graphql( + amplify: AmplifyClassV6, { query, variables, authMode }: GraphQLOptions, additionalHeaders = {}, abortController: AbortController, customUserAgentDetails?: CustomUserAgentDetails ): Promise> { - const config = Amplify.getConfig(); + const config = amplify.getConfig(); const { region: region, endpoint: appSyncGraphqlEndpoint } = config.API?.GraphQL || {}; @@ -223,10 +229,10 @@ export class InternalGraphQLAPIClass { // TODO: Figure what we need to do to remove `!`'s. const headers = { ...(!customGraphqlEndpoint && - (await this._headerBasedAuth(authMode!, additionalHeaders))), + (await this._headerBasedAuth(amplify, authMode!, additionalHeaders))), ...((customGraphqlEndpoint && (customEndpointRegion - ? await this._headerBasedAuth(authMode!, additionalHeaders) + ? await this._headerBasedAuth(amplify, authMode!, additionalHeaders) : { Authorization: null })) || {}), ...additionalHeaders, @@ -311,11 +317,12 @@ export class InternalGraphQLAPIClass { } private _graphqlSubscribe( + amplify: AmplifyClassV6, { query, variables, authMode }: GraphQLOptions, additionalHeaders = {}, customUserAgentDetails?: CustomUserAgentDetails ): Observable { - const { GraphQL } = Amplify.getConfig().API ?? {}; + const { GraphQL } = amplify.getConfig().API ?? {}; if (!this.appSyncRealTime) { this.appSyncRealTime = new AWSAppSyncRealTimeProvider(); } diff --git a/packages/api-graphql/src/internals/v6.ts b/packages/api-graphql/src/internals/v6.ts index affe62c8dd7..ca7b744176b 100644 --- a/packages/api-graphql/src/internals/v6.ts +++ b/packages/api-graphql/src/internals/v6.ts @@ -1,7 +1,12 @@ // Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. // SPDX-License-Identifier: Apache-2.0 import { GraphQLAPI } from '../GraphQLAPI'; -import { GraphQLOptionsV6, GraphQLResponseV6 } from '../types'; +import { + __amplify, + V6Client, + GraphQLOptionsV6, + GraphQLResponseV6, +} from '../types'; /** * Invokes graphql operations against a graphql service, providing correct input and @@ -91,6 +96,7 @@ export function graphql< FALLBACK_TYPES = unknown, TYPED_GQL_STRING extends string = string >( + this: V6Client, options: GraphQLOptionsV6, additionalHeaders?: { [key: string]: string } ): GraphQLResponseV6 { @@ -99,7 +105,11 @@ export function graphql< * Neither of these can actually be validated at runtime. Hence, we don't perform * any validation or type-guarding here. */ - const result = GraphQLAPI.graphql(options, additionalHeaders); + const result = GraphQLAPI.graphql( + this[__amplify], + options, + additionalHeaders + ); return result as any; } @@ -108,7 +118,11 @@ export function graphql< * @param {any} request - request to cancel * @returns - A boolean indicating if the request was cancelled */ -export function cancel(promise: Promise, message?: string): boolean { +export function cancel( + this: V6Client, + promise: Promise, + message?: string +): boolean { return GraphQLAPI.cancel(promise, message); } @@ -117,7 +131,7 @@ export function cancel(promise: Promise, message?: string): boolean { * @param {any} error - Any error * @returns - A boolean indicating if the error was from an api request cancellation */ -export function isCancelError(error: any): boolean { +export function isCancelError(this: V6Client, error: any): boolean { return GraphQLAPI.isCancelError(error); } diff --git a/packages/api-graphql/src/types/index.ts b/packages/api-graphql/src/types/index.ts index 709855e579b..bb4f8d0a5ca 100644 --- a/packages/api-graphql/src/types/index.ts +++ b/packages/api-graphql/src/types/index.ts @@ -1,5 +1,6 @@ // Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. // SPDX-License-Identifier: Apache-2.0 +import { AmplifyClassV6 } from '@aws-amplify/core'; import { Source, DocumentNode, GraphQLError } from 'graphql'; export { OperationTypeNode } from 'graphql'; import { Observable } from 'rxjs'; @@ -339,3 +340,26 @@ export type GeneratedSubscription = string & { __generatedSubscriptionInput: InputType; __generatedSubscriptionOutput: OutputType; }; + +type FilteredKeys = { + [P in keyof T]: T[P] extends never ? never : P; +}[keyof T]; +type ExcludeNeverFields = { + [K in FilteredKeys]: O[K]; +}; + +export const __amplify = Symbol('amplify'); + +export type V6Client = never> = ExcludeNeverFields<{ + [__amplify]: AmplifyClassV6; + graphql: ( + options: GraphQLOptionsV6, + additionalHeaders?: + | { + [key: string]: string; + } + | undefined + ) => GraphQLResponseV6; + cancel: (promise: Promise, message?: string) => boolean; + isCancelError: (error: any) => boolean; +}>; diff --git a/packages/api-rest/src/utils/index.native.ts b/packages/api-rest/src/utils/index.native.ts deleted file mode 100644 index 54f58b7a2ed..00000000000 --- a/packages/api-rest/src/utils/index.native.ts +++ /dev/null @@ -1,13 +0,0 @@ -// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. -// SPDX-License-Identifier: Apache-2.0 - -import { loadUrlPolyfill } from '@aws-amplify/react-native'; - -loadUrlPolyfill(); - -export { createCancellableOperation } from './createCancellableOperation'; -export { resolveCredentials } from './resolveCredentials'; -export { parseSigningInfo } from './parseSigningInfo'; -export { parseRestApiServiceError } from './serviceError'; -export { resolveApiUrl } from './resolveApiUrl'; -export { logger } from './logger'; diff --git a/packages/api-rest/src/utils/index.ts b/packages/api-rest/src/utils/index.ts index 2e72b5bf24b..2fc96b25063 100644 --- a/packages/api-rest/src/utils/index.ts +++ b/packages/api-rest/src/utils/index.ts @@ -1,6 +1,8 @@ // Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. // SPDX-License-Identifier: Apache-2.0 +import './polyfills'; + export { createCancellableOperation } from './createCancellableOperation'; export { resolveCredentials } from './resolveCredentials'; export { parseSigningInfo } from './parseSigningInfo'; diff --git a/packages/auth/src/providers/cognito/polyfill/index.native.ts b/packages/api-rest/src/utils/polyfills/index.native.ts similarity index 100% rename from packages/auth/src/providers/cognito/polyfill/index.native.ts rename to packages/api-rest/src/utils/polyfills/index.native.ts diff --git a/packages/auth/src/providers/cognito/polyfill/index.ts b/packages/api-rest/src/utils/polyfills/index.ts similarity index 70% rename from packages/auth/src/providers/cognito/polyfill/index.ts rename to packages/api-rest/src/utils/polyfills/index.ts index cbe0bdce89c..f0daa8d350d 100644 --- a/packages/auth/src/providers/cognito/polyfill/index.ts +++ b/packages/api-rest/src/utils/polyfills/index.ts @@ -1,4 +1,4 @@ // Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. // SPDX-License-Identifier: Apache-2.0 -// no op +// noop - polyfills not required on platform diff --git a/packages/api/package.json b/packages/api/package.json index d95ca5a7f22..c112d174c83 100644 --- a/packages/api/package.json +++ b/packages/api/package.json @@ -24,7 +24,6 @@ }, "scripts": { "test": "npm run lint && jest -w 1 --coverage", - "test:size": "size-limit", "build-with-test": "npm test && npm run build", "build:cjs": "node ./build es5 && webpack && webpack --config ./webpack.config.dev.js", "build:esm": "node ./build es6", @@ -63,14 +62,6 @@ "@aws-amplify/api-rest": "4.0.0", "tslib": "^2.6.1" }, - "size-limit": [ - { - "name": "API (top-level class)", - "path": "./lib-esm/index.js", - "import": "{ Amplify, API }", - "limit": "93.82 kB" - } - ], "jest": { "globals": { "ts-jest": { diff --git a/packages/api/src/API.ts b/packages/api/src/API.ts index ad13b176e02..2bb98ccd2de 100644 --- a/packages/api/src/API.ts +++ b/packages/api/src/API.ts @@ -1,81 +1,23 @@ // Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. // SPDX-License-Identifier: Apache-2.0 -import { - AWSAppSyncRealTimeProvider, - GraphQLOptions, - GraphQLResult, - GraphQLQuery, - GraphQLSubscription, -} from '@aws-amplify/api-graphql'; +import { __amplify, V6Client } from '@aws-amplify/api-graphql'; import { graphql as v6graphql, cancel as v6cancel, isCancelError as v6isCancelError, } from '@aws-amplify/api-graphql/internals'; -import { Observable } from 'rxjs'; -import { InternalAPIClass } from './internals/InternalAPI'; +import { Amplify } from '@aws-amplify/core'; /** - * @deprecated - * Use RestApi or GraphQLAPI to reduce your application bundle size - * Export Cloud Logic APIs + * Generates an API client that can work with models or raw GraphQL */ -export class APIClass extends InternalAPIClass { - public getModuleName() { - return 'API'; - } - - /** - * Executes a GraphQL operation - * - * @param options - GraphQL Options - * @param [additionalHeaders] - headers to merge in after any `graphql_headers` set in the config - * @returns An Observable if queryType is 'subscription', else a promise of the graphql result from the query. - */ - graphql( - options: GraphQLOptions, - additionalHeaders?: { [key: string]: string } - ): T extends GraphQLQuery - ? Promise> - : T extends GraphQLSubscription - ? Observable<{ - provider: AWSAppSyncRealTimeProvider; - value: GraphQLResult; - }> - : Promise> | Observable; - graphql( - options: GraphQLOptions, - additionalHeaders?: { [key: string]: string } - ): Promise> | Observable { - return super.graphql(options, additionalHeaders); - } - - /** - * Generates an API client that can work with models or raw GraphQL - */ - generateClient = never>(): V6Client { - const client: V6Client = { - graphql: v6graphql, - cancel: v6cancel, - isCancelError: v6isCancelError, - }; - - return client as V6Client; - } +export function generateClient< + T extends Record = never +>(): V6Client { + return { + [__amplify]: Amplify, + graphql: v6graphql, + cancel: v6cancel, + isCancelError: v6isCancelError, + }; } - -type FilteredKeys = { - [P in keyof T]: T[P] extends never ? never : P; -}[keyof T]; -type ExcludeNeverFields = { - [K in FilteredKeys]: O[K]; -}; - -// If no T is passed, ExcludeNeverFields removes "models" from the client -declare type V6Client = never> = ExcludeNeverFields<{ - graphql: typeof v6graphql; - cancel: typeof v6cancel; - isCancelError: typeof v6isCancelError; -}>; - -export const API = new APIClass(null); diff --git a/packages/api/src/index.ts b/packages/api/src/index.ts index b78f4a1c773..344268d3ca5 100644 --- a/packages/api/src/index.ts +++ b/packages/api/src/index.ts @@ -4,7 +4,7 @@ // TODO(v6): revisit exports export { GraphQLQuery, GraphQLSubscription } from './types'; -import { API } from './API'; +export { generateClient } from './API'; export { GraphQLAuthError } from '@aws-amplify/api-graphql'; @@ -13,10 +13,6 @@ export type { GraphQLReturnType, } from '@aws-amplify/api-graphql'; -const generateClient = API.generateClient; - -export { generateClient }; - export { get, put, diff --git a/packages/api/src/internals/InternalAPI.ts b/packages/api/src/internals/InternalAPI.ts index ea83b7eab7c..dbd8c01ba91 100644 --- a/packages/api/src/internals/InternalAPI.ts +++ b/packages/api/src/internals/InternalAPI.ts @@ -10,7 +10,7 @@ import { GraphQLSubscription, } from '@aws-amplify/api-graphql'; import { InternalGraphQLAPIClass } from '@aws-amplify/api-graphql/internals'; -import { Cache } from '@aws-amplify/core'; +import { Amplify, Cache } from '@aws-amplify/core'; import { ApiAction, Category, @@ -19,6 +19,15 @@ import { } from '@aws-amplify/core/internals/utils'; import { Observable } from 'rxjs'; +/** + * NOTE! + * + * This is used only by DataStore. + * + * This can probably be pruned and/or removed. Just leaving it as much of the same + * state as possible for V6 to reduce number of potentially impactful changes to DataStore. + */ + const logger = new Logger('API'); /** * @deprecated @@ -88,6 +97,7 @@ export class InternalAPIClass { }; return this._graphqlApi.graphql( + Amplify, options, additionalHeaders, apiUserAgentDetails diff --git a/packages/api/src/server.ts b/packages/api/src/server.ts index 681f6cfe3db..8527c88d159 100644 --- a/packages/api/src/server.ts +++ b/packages/api/src/server.ts @@ -1,6 +1,38 @@ // Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. // SPDX-License-Identifier: Apache-2.0 +export { GraphQLQuery, GraphQLSubscription } from './types'; +import { + graphql, + cancel, + isCancelError, +} from '@aws-amplify/api-graphql/internals'; +import { + AmplifyServer, + getAmplifyServerContext, +} from '@aws-amplify/core/internals/adapter-core'; + +import { __amplify, V6Client } from '@aws-amplify/api-graphql'; + +export type { + GraphQLResult, + GraphQLReturnType, +} from '@aws-amplify/api-graphql'; + +/** + * Generates an API client that can work with models or raw GraphQL + */ +export function generateClient = never>( + contextSpec: AmplifyServer.ContextSpec +): V6Client { + return { + [__amplify]: getAmplifyServerContext(contextSpec).amplify, + graphql, + cancel, + isCancelError, + }; +} + export { get, put, diff --git a/packages/auth/__tests__/providers/cognito/credentialsProvider.test.ts b/packages/auth/__tests__/providers/cognito/credentialsProvider.test.ts index 916c0e0f194..bcbfc7254ac 100644 --- a/packages/auth/__tests__/providers/cognito/credentialsProvider.test.ts +++ b/packages/auth/__tests__/providers/cognito/credentialsProvider.test.ts @@ -20,7 +20,7 @@ jest.mock('@aws-amplify/core', () => ({ getCredentialsForIdentity: jest.fn(), })); -jest.mock('@aws-amplify/core/lib/AwsClients/CognitoIdentity'); +jest.mock('@aws-amplify/core/lib/awsClients/cognitoIdentity'); jest.mock( './../../../src/providers/cognito/credentialsProvider/IdentityIdProvider', diff --git a/packages/auth/__tests__/providers/cognito/fetchMFAPreference.test.ts b/packages/auth/__tests__/providers/cognito/fetchMFAPreference.test.ts index 5b6794fa7da..bd90bbd35cb 100644 --- a/packages/auth/__tests__/providers/cognito/fetchMFAPreference.test.ts +++ b/packages/auth/__tests__/providers/cognito/fetchMFAPreference.test.ts @@ -63,7 +63,10 @@ describe('fetchMFAPreference Happy Path Cases:', () => { expect(resp).toEqual({ preferred: 'SMS', enabled: ['SMS', 'TOTP'] }); expect(getUserClientSpy).toHaveBeenCalledTimes(1); expect(getUserClientSpy).toHaveBeenCalledWith( - { region: 'us-west-2' }, + { + region: 'us-west-2', + userAgentValue: expect.any(String) + }, { AccessToken: mockedAccessToken, } diff --git a/packages/auth/__tests__/providers/cognito/fetchUserAttributes.test.ts b/packages/auth/__tests__/providers/cognito/fetchUserAttributes.test.ts index d6d5e80e0b9..a15065f1698 100644 --- a/packages/auth/__tests__/providers/cognito/fetchUserAttributes.test.ts +++ b/packages/auth/__tests__/providers/cognito/fetchUserAttributes.test.ts @@ -67,7 +67,10 @@ describe('fetchUserAttributes Happy Path Cases:', () => { }); expect(getUserClientSpy).toHaveBeenCalledTimes(1); expect(getUserClientSpy).toHaveBeenCalledWith( - { region: 'us-west-2' }, + { + region: 'us-west-2', + userAgentValue: expect.any(String) + }, { AccessToken: mockedAccessToken, } diff --git a/packages/auth/__tests__/providers/cognito/identityIdProvider.test.ts b/packages/auth/__tests__/providers/cognito/identityIdProvider.test.ts index b0914f37d8f..1f186bf7272 100644 --- a/packages/auth/__tests__/providers/cognito/identityIdProvider.test.ts +++ b/packages/auth/__tests__/providers/cognito/identityIdProvider.test.ts @@ -6,9 +6,9 @@ import { Amplify, Identity, ResourcesConfig } from '@aws-amplify/core'; import { DefaultIdentityIdStore } from '../../../src/providers/cognito/credentialsProvider/IdentityIdStore'; // TODO(V6): import these from top level core/ and not lib/ -import * as cogId from '@aws-amplify/core/lib/AwsClients/CognitoIdentity'; +import * as cogId from '@aws-amplify/core/lib/awsClients/cognitoIdentity'; import { cognitoIdentityIdProvider } from '../../../src/providers/cognito/credentialsProvider/IdentityIdProvider'; -jest.mock('@aws-amplify/core/lib/AwsClients/CognitoIdentity'); +jest.mock('@aws-amplify/core/lib/awsClients/cognitoIdentity'); jest.mock('../../../src/providers/cognito/credentialsProvider/IdentityIdStore'); type ArgumentTypes = F extends (...args: infer A) => any diff --git a/packages/auth/__tests__/providers/cognito/resendSignUpCode.test.ts b/packages/auth/__tests__/providers/cognito/resendSignUpCode.test.ts index 7437bbafc96..9414c1f6161 100644 --- a/packages/auth/__tests__/providers/cognito/resendSignUpCode.test.ts +++ b/packages/auth/__tests__/providers/cognito/resendSignUpCode.test.ts @@ -40,7 +40,10 @@ describe('ResendSignUp API Happy Path Cases:', () => { }); expect(result).toEqual(authAPITestParams.resendSignUpAPIResult); expect(resendSignUpSpy).toHaveBeenCalledWith( - { region: 'us-west-2' }, + { + region: 'us-west-2', + userAgentValue: expect.any(String) + }, { ClientMetadata: undefined, Username: user1.username, diff --git a/packages/auth/__tests__/providers/cognito/setUpTOTP.test.ts b/packages/auth/__tests__/providers/cognito/setUpTOTP.test.ts index e88cb987459..6dc61a663af 100644 --- a/packages/auth/__tests__/providers/cognito/setUpTOTP.test.ts +++ b/packages/auth/__tests__/providers/cognito/setUpTOTP.test.ts @@ -60,7 +60,10 @@ describe('setUpTOTP API happy path cases', () => { test('setUpTOTP API should call the UserPoolClient and should return a TOTPSetupDetails', async () => { const result = await setUpTOTP(); expect(associateSoftwareTokenClientSpy).toHaveBeenCalledWith( - { region: 'us-west-2' }, + { + region: 'us-west-2', + userAgentValue: expect.any(String) + }, { AccessToken: mockedAccessToken, } diff --git a/packages/auth/__tests__/providers/cognito/signUp.test.ts b/packages/auth/__tests__/providers/cognito/signUp.test.ts index c9ceaca4541..23ac5490f53 100644 --- a/packages/auth/__tests__/providers/cognito/signUp.test.ts +++ b/packages/auth/__tests__/providers/cognito/signUp.test.ts @@ -55,7 +55,10 @@ describe('SignUp API Happy Path Cases:', () => { userId: '1234567890', }); expect(signUpSpy).toHaveBeenCalledWith( - { region: 'us-west-2' }, + { + region: 'us-west-2', + userAgentValue: expect.any(String) + }, { ClientMetadata: undefined, Password: user1.password, diff --git a/packages/auth/__tests__/providers/cognito/updateMFAPreference.test.ts b/packages/auth/__tests__/providers/cognito/updateMFAPreference.test.ts index f3db0896dca..3b2058b2e18 100644 --- a/packages/auth/__tests__/providers/cognito/updateMFAPreference.test.ts +++ b/packages/auth/__tests__/providers/cognito/updateMFAPreference.test.ts @@ -78,7 +78,10 @@ describe('updateMFAPreference Happy Path Cases:', () => { const { totp, sms } = mfaChoise; await updateMFAPreference(mfaChoise); expect(setUserMFAPreferenceClientSpy).toHaveBeenCalledWith( - { region: 'us-west-2' }, + { + region: 'us-west-2', + userAgentValue: expect.any(String) + }, { AccessToken: mockedAccessToken, SMSMfaSettings: getMFASettings(sms), diff --git a/packages/auth/src/providers/cognito/apis/confirmResetPassword.ts b/packages/auth/src/providers/cognito/apis/confirmResetPassword.ts index 470de966987..ae7205189bc 100644 --- a/packages/auth/src/providers/cognito/apis/confirmResetPassword.ts +++ b/packages/auth/src/providers/cognito/apis/confirmResetPassword.ts @@ -2,13 +2,14 @@ // SPDX-License-Identifier: Apache-2.0 import { Amplify } from '@aws-amplify/core'; -import { assertTokenProviderConfig } from '@aws-amplify/core/internals/utils'; +import { assertTokenProviderConfig, AuthAction } from '@aws-amplify/core/internals/utils'; import { AuthValidationErrorCode } from '../../../errors/types/validation'; import { assertValidationError } from '../../../errors/utils/assertValidationError'; import { ConfirmResetPasswordInput } from '../types'; import { confirmForgotPassword } from '../utils/clients/CognitoIdentityProvider'; import { getRegion } from '../utils/clients/CognitoIdentityProvider/utils'; import { ConfirmForgotPasswordException } from '../../cognito/types/errors'; +import { getAuthUserAgentValue } from '../../../utils'; /** * Confirms the new password and verification code to reset the password. * @@ -43,7 +44,10 @@ export async function confirmResetPassword( const metadata = input.options?.serviceOptions?.clientMetadata; await confirmForgotPassword( - { region: getRegion(authConfig.userPoolId) }, + { + region: getRegion(authConfig.userPoolId), + userAgentValue: getAuthUserAgentValue(AuthAction.ConfirmResetPassword) + }, { Username: username, ConfirmationCode: code, diff --git a/packages/auth/src/providers/cognito/apis/confirmSignUp.ts b/packages/auth/src/providers/cognito/apis/confirmSignUp.ts index 278fdffa629..e318b127ade 100644 --- a/packages/auth/src/providers/cognito/apis/confirmSignUp.ts +++ b/packages/auth/src/providers/cognito/apis/confirmSignUp.ts @@ -2,13 +2,14 @@ // SPDX-License-Identifier: Apache-2.0 import { Amplify } from '@aws-amplify/core'; -import { assertTokenProviderConfig } from '@aws-amplify/core/internals/utils'; +import { assertTokenProviderConfig, AuthAction } from '@aws-amplify/core/internals/utils'; import { ConfirmSignUpInput, ConfirmSignUpOutput } from '../types'; import { assertValidationError } from '../../../errors/utils/assertValidationError'; import { AuthValidationErrorCode } from '../../../errors/types/validation'; import { ConfirmSignUpException } from '../types/errors'; import { confirmSignUp as confirmSignUpClient } from '../utils/clients/CognitoIdentityProvider'; import { getRegion } from '../utils/clients/CognitoIdentityProvider/utils'; +import { getAuthUserAgentValue } from '../../../utils'; /** * Confirms a new user account. @@ -39,7 +40,10 @@ export async function confirmSignUp( ); await confirmSignUpClient( - { region: getRegion(authConfig.userPoolId) }, + { + region: getRegion(authConfig.userPoolId), + userAgentValue: getAuthUserAgentValue(AuthAction.ConfirmSignUp) + }, { Username: username, ConfirmationCode: confirmationCode, diff --git a/packages/auth/src/providers/cognito/apis/confirmUserAttribute.ts b/packages/auth/src/providers/cognito/apis/confirmUserAttribute.ts index a1a3e1b6c25..c97cfade231 100644 --- a/packages/auth/src/providers/cognito/apis/confirmUserAttribute.ts +++ b/packages/auth/src/providers/cognito/apis/confirmUserAttribute.ts @@ -2,7 +2,7 @@ // SPDX-License-Identifier: Apache-2.0 import { Amplify } from '@aws-amplify/core'; -import { assertTokenProviderConfig } from '@aws-amplify/core/internals/utils'; +import { assertTokenProviderConfig, AuthAction } from '@aws-amplify/core/internals/utils'; import { AuthValidationErrorCode } from '../../../errors/types/validation'; import { assertValidationError } from '../../../errors/utils/assertValidationError'; import { verifyUserAttribute } from '../utils/clients/CognitoIdentityProvider'; @@ -11,6 +11,7 @@ import { fetchAuthSession } from '../../../'; import { getRegion } from '../utils/clients/CognitoIdentityProvider/utils'; import { assertAuthTokens } from '../utils/types'; import { ConfirmUserAttributeInput } from '../types'; +import { getAuthUserAgentValue } from '../../../utils'; /** * Confirms a user attribute with the confirmation code. @@ -36,6 +37,7 @@ export async function confirmUserAttribute( await verifyUserAttribute( { region: getRegion(authConfig.userPoolId), + userAgentValue: getAuthUserAgentValue(AuthAction.ConfirmUserAttribute) }, { AccessToken: tokens.accessToken.toString(), diff --git a/packages/auth/src/providers/cognito/apis/deleteUser.ts b/packages/auth/src/providers/cognito/apis/deleteUser.ts index f15f83dcb69..68c609e765d 100644 --- a/packages/auth/src/providers/cognito/apis/deleteUser.ts +++ b/packages/auth/src/providers/cognito/apis/deleteUser.ts @@ -2,7 +2,7 @@ // SPDX-License-Identifier: Apache-2.0 import { Amplify } from '@aws-amplify/core'; -import { assertTokenProviderConfig } from '@aws-amplify/core/internals/utils'; +import { assertTokenProviderConfig, AuthAction } from '@aws-amplify/core/internals/utils'; import { fetchAuthSession } from '../../../'; import { getRegion } from '../utils/clients/CognitoIdentityProvider/utils'; import { assertAuthTokens } from '../utils/types'; @@ -10,6 +10,7 @@ import { deleteUser as serviceDeleteUser } from '../utils/clients/CognitoIdentit import { DeleteUserException } from '../types/errors'; import { tokenOrchestrator } from '../tokenProvider'; import { signOut } from '..'; +import { getAuthUserAgentValue } from '../../../utils'; /** * Deletes a user from the user pool while authenticated. @@ -25,7 +26,10 @@ export async function deleteUser(): Promise { assertAuthTokens(tokens); await serviceDeleteUser( - { region: getRegion(authConfig.userPoolId) }, + { + region: getRegion(authConfig.userPoolId), + userAgentValue: getAuthUserAgentValue(AuthAction.DeleteUser) + }, { AccessToken: tokens.accessToken.toString(), } diff --git a/packages/auth/src/providers/cognito/apis/deleteUserAttributes.ts b/packages/auth/src/providers/cognito/apis/deleteUserAttributes.ts index f2eac26d22d..9324e3b335b 100644 --- a/packages/auth/src/providers/cognito/apis/deleteUserAttributes.ts +++ b/packages/auth/src/providers/cognito/apis/deleteUserAttributes.ts @@ -2,13 +2,14 @@ // SPDX-License-Identifier: Apache-2.0 import { Amplify } from '@aws-amplify/core'; -import { assertTokenProviderConfig } from '@aws-amplify/core/internals/utils'; +import { assertTokenProviderConfig, AuthAction } from '@aws-amplify/core/internals/utils'; import { deleteUserAttributes as deleteUserAttributesClient } from '../utils/clients/CognitoIdentityProvider'; import { fetchAuthSession } from '../../../'; import { getRegion } from '../utils/clients/CognitoIdentityProvider/utils'; import { assertAuthTokens } from '../utils/types'; import { DeleteUserAttributesInput } from '../types'; import { DeleteUserAttributesException } from '../types/errors'; +import { getAuthUserAgentValue } from '../../../utils'; /** * Deletes user attributes. @@ -28,6 +29,7 @@ export async function deleteUserAttributes( await deleteUserAttributesClient( { region: getRegion(authConfig.userPoolId), + userAgentValue: getAuthUserAgentValue(AuthAction.DeleteUserAttributes) }, { AccessToken: tokens.accessToken.toString(), diff --git a/packages/auth/src/providers/cognito/apis/fetchDevices.ts b/packages/auth/src/providers/cognito/apis/fetchDevices.ts index 4c44a6bf652..d44f4b4fd25 100644 --- a/packages/auth/src/providers/cognito/apis/fetchDevices.ts +++ b/packages/auth/src/providers/cognito/apis/fetchDevices.ts @@ -2,7 +2,7 @@ // SPDX-License-Identifier: Apache-2.0 import { Amplify } from '@aws-amplify/core'; -import { assertTokenProviderConfig } from '@aws-amplify/core/internals/utils'; +import { assertTokenProviderConfig, AuthAction } from '@aws-amplify/core/internals/utils'; import { fetchAuthSession } from '../../../'; import { FetchDevicesOutput } from '../types'; import { listDevices } from '../utils/clients/CognitoIdentityProvider'; @@ -10,7 +10,7 @@ import { DeviceType } from '../utils/clients/CognitoIdentityProvider/types'; import { assertAuthTokens } from '../utils/types'; import { getRegion } from '../utils/clients/CognitoIdentityProvider/utils'; import { rememberDevice } from '..'; -import { ListDevicesException } from '../types/errors'; +import { getAuthUserAgentValue } from '../../../utils'; // Cognito Documentation for max device // https://docs.aws.amazon.com/cognito-user-identity-pools/latest/APIReference/API_ListDevices.html#API_ListDevices_RequestSyntax @@ -32,7 +32,10 @@ export async function fetchDevices(): Promise { assertAuthTokens(tokens); const response = await listDevices( - { region: getRegion(authConfig.userPoolId) }, + { + region: getRegion(authConfig.userPoolId), + userAgentValue: getAuthUserAgentValue(AuthAction.FetchDevices) + }, { AccessToken: tokens.accessToken.toString(), Limit: MAX_DEVICES, diff --git a/packages/auth/src/providers/cognito/apis/fetchMFAPreference.ts b/packages/auth/src/providers/cognito/apis/fetchMFAPreference.ts index 34e27bb29b6..497121e39a5 100644 --- a/packages/auth/src/providers/cognito/apis/fetchMFAPreference.ts +++ b/packages/auth/src/providers/cognito/apis/fetchMFAPreference.ts @@ -6,10 +6,11 @@ import { getMFAType, getMFATypes } from '../utils/signInHelpers'; import { GetUserException } from '../types/errors'; import { getUser } from '../utils/clients/CognitoIdentityProvider'; import { Amplify } from '@aws-amplify/core'; -import { assertTokenProviderConfig } from '@aws-amplify/core/internals/utils'; +import { assertTokenProviderConfig, AuthAction } from '@aws-amplify/core/internals/utils'; import { fetchAuthSession } from '../../../'; import { getRegion } from '../utils/clients/CognitoIdentityProvider/utils'; import { assertAuthTokens } from '../utils/types'; +import { getAuthUserAgentValue } from '../../../utils'; /** * Fetches the preferred MFA setting and enabled MFA settings for the user. @@ -25,7 +26,10 @@ export async function fetchMFAPreference(): Promise { const { tokens } = await fetchAuthSession({ forceRefresh: false }); assertAuthTokens(tokens); const { PreferredMfaSetting, UserMFASettingList } = await getUser( - { region: getRegion(authConfig.userPoolId) }, + { + region: getRegion(authConfig.userPoolId), + userAgentValue: getAuthUserAgentValue(AuthAction.FetchMFAPreference) + }, { AccessToken: tokens.accessToken.toString(), } diff --git a/packages/auth/src/providers/cognito/apis/forgetDevice.ts b/packages/auth/src/providers/cognito/apis/forgetDevice.ts index 5fea13a05bf..4a050acff84 100644 --- a/packages/auth/src/providers/cognito/apis/forgetDevice.ts +++ b/packages/auth/src/providers/cognito/apis/forgetDevice.ts @@ -4,12 +4,13 @@ import { forgetDevice as serviceForgetDevice } from '../utils/clients/CognitoIdentityProvider'; import { Amplify } from '@aws-amplify/core'; import { assertAuthTokens, assertDeviceMetadata } from '../utils/types'; -import { assertTokenProviderConfig } from '@aws-amplify/core/internals/utils'; +import { assertTokenProviderConfig, AuthAction } from '@aws-amplify/core/internals/utils'; import { fetchAuthSession } from '../../../'; import { getRegion } from '../utils/clients/CognitoIdentityProvider/utils'; import { tokenOrchestrator } from '../tokenProvider'; import { ForgetDeviceInput } from '../types'; import { ForgetDeviceException } from '../../cognito/types/errors'; +import { getAuthUserAgentValue } from '../../../utils'; /** * Forget a remembered device while authenticated. @@ -32,7 +33,10 @@ export async function forgetDevice(input?: ForgetDeviceInput): Promise { if (!externalDeviceKey) assertDeviceMetadata(deviceMetadata); await serviceForgetDevice( - { region: getRegion(authConfig.userPoolId) }, + { + region: getRegion(authConfig.userPoolId), + userAgentValue: getAuthUserAgentValue(AuthAction.ForgetDevice) + }, { AccessToken: tokens.accessToken.toString(), DeviceKey: externalDeviceKey ?? currentDeviceKey, diff --git a/packages/auth/src/providers/cognito/apis/internal/fetchUserAttributes.ts b/packages/auth/src/providers/cognito/apis/internal/fetchUserAttributes.ts index 22fb636b81a..b19dcc1ecf1 100644 --- a/packages/auth/src/providers/cognito/apis/internal/fetchUserAttributes.ts +++ b/packages/auth/src/providers/cognito/apis/internal/fetchUserAttributes.ts @@ -3,6 +3,7 @@ import { AmplifyClassV6 } from '@aws-amplify/core'; import { + AuthAction, assertTokenProviderConfig, fetchAuthSession, } from '@aws-amplify/core/internals/utils'; @@ -11,6 +12,7 @@ import { getRegion } from '../../utils/clients/CognitoIdentityProvider/utils'; import { assertAuthTokens } from '../../utils/types'; import { FetchUserAttributesOutput } from '../../types'; import { toAuthUserAttribute } from '../../utils/apiHelpers'; +import { getAuthUserAgentValue } from '../../../../utils'; export const fetchUserAttributes = async ( amplify: AmplifyClassV6 @@ -23,7 +25,10 @@ export const fetchUserAttributes = async ( assertAuthTokens(tokens); const { UserAttributes } = await getUser( - { region: getRegion(authConfig.userPoolId) }, + { + region: getRegion(authConfig.userPoolId), + userAgentValue: getAuthUserAgentValue(AuthAction.FetchUserAttributes) + }, { AccessToken: tokens.accessToken.toString(), } diff --git a/packages/auth/src/providers/cognito/apis/rememberDevice.ts b/packages/auth/src/providers/cognito/apis/rememberDevice.ts index de8c46e95dc..2528cc467f5 100644 --- a/packages/auth/src/providers/cognito/apis/rememberDevice.ts +++ b/packages/auth/src/providers/cognito/apis/rememberDevice.ts @@ -4,11 +4,12 @@ import { updateDeviceStatus } from '../utils/clients/CognitoIdentityProvider'; import { Amplify } from '@aws-amplify/core'; import { assertAuthTokens, assertDeviceMetadata } from '../utils/types'; -import { assertTokenProviderConfig } from '@aws-amplify/core/internals/utils'; +import { assertTokenProviderConfig, AuthAction } from '@aws-amplify/core/internals/utils'; import { fetchAuthSession } from '../../../'; import { getRegion } from '../utils/clients/CognitoIdentityProvider/utils'; import { tokenOrchestrator } from '../tokenProvider'; import { UpdateDeviceStatusException } from '../../cognito/types/errors'; +import { getAuthUserAgentValue } from '../../../utils'; /** * Marks device as remembered while authenticated. @@ -28,7 +29,10 @@ export async function rememberDevice(): Promise { assertDeviceMetadata(deviceMetadata); await updateDeviceStatus( - { region: getRegion(authConfig.userPoolId) }, + { + region: getRegion(authConfig.userPoolId), + userAgentValue: getAuthUserAgentValue(AuthAction.RememberDevice) + }, { AccessToken: tokens.accessToken.toString(), DeviceKey: deviceMetadata.deviceKey, diff --git a/packages/auth/src/providers/cognito/apis/resendSignUpCode.ts b/packages/auth/src/providers/cognito/apis/resendSignUpCode.ts index 2385908077a..874eb9465af 100644 --- a/packages/auth/src/providers/cognito/apis/resendSignUpCode.ts +++ b/packages/auth/src/providers/cognito/apis/resendSignUpCode.ts @@ -2,13 +2,14 @@ // SPDX-License-Identifier: Apache-2.0 import { Amplify } from '@aws-amplify/core'; -import { assertTokenProviderConfig } from '@aws-amplify/core/internals/utils'; +import { assertTokenProviderConfig, AuthAction } from '@aws-amplify/core/internals/utils'; import { AuthStandardAttributeKey, AuthDeliveryMedium } from '../../../types'; import { assertValidationError } from '../../../errors/utils/assertValidationError'; import { AuthValidationErrorCode } from '../../../errors/types/validation'; import { ResendSignUpCodeInput, ResendSignUpCodeOutput } from '../types'; import { getRegion } from '../utils/clients/CognitoIdentityProvider/utils'; import { resendConfirmationCode } from '../utils/clients/CognitoIdentityProvider'; +import { getAuthUserAgentValue } from '../../../utils'; /** * Resend the confirmation code while signing up @@ -31,7 +32,10 @@ export async function resendSignUpCode( assertTokenProviderConfig(authConfig); const clientMetadata = input.options?.serviceOptions?.clientMetadata; const { CodeDeliveryDetails } = await resendConfirmationCode( - { region: getRegion(authConfig.userPoolId) }, + { + region: getRegion(authConfig.userPoolId), + userAgentValue: getAuthUserAgentValue(AuthAction.ResendSignUpCode) + }, { Username: username, ClientMetadata: clientMetadata, diff --git a/packages/auth/src/providers/cognito/apis/resetPassword.ts b/packages/auth/src/providers/cognito/apis/resetPassword.ts index a569ff9bc24..0f18fc39b0d 100644 --- a/packages/auth/src/providers/cognito/apis/resetPassword.ts +++ b/packages/auth/src/providers/cognito/apis/resetPassword.ts @@ -2,7 +2,7 @@ // SPDX-License-Identifier: Apache-2.0 import { Amplify } from '@aws-amplify/core'; -import { assertTokenProviderConfig } from '@aws-amplify/core/internals/utils'; +import { assertTokenProviderConfig, AuthAction } from '@aws-amplify/core/internals/utils'; import { AuthValidationErrorCode } from '../../../errors/types/validation'; import { assertValidationError } from '../../../errors/utils/assertValidationError'; import { AuthDeliveryMedium, AuthStandardAttributeKey } from '../../../types'; @@ -10,6 +10,7 @@ import { ResetPasswordInput, ResetPasswordOutput } from '../types'; import { forgotPassword } from '../utils/clients/CognitoIdentityProvider'; import { getRegion } from '../utils/clients/CognitoIdentityProvider/utils'; import { ForgotPasswordException } from '../../cognito/types/errors'; +import { getAuthUserAgentValue } from '../../../utils'; /** * Resets a user's password. @@ -34,7 +35,10 @@ export async function resetPassword( assertTokenProviderConfig(authConfig); const clientMetadata = input.options?.serviceOptions?.clientMetadata; const res = await forgotPassword( - { region: getRegion(authConfig.userPoolId) }, + { + region: getRegion(authConfig.userPoolId), + userAgentValue: getAuthUserAgentValue(AuthAction.ResetPassword) + }, { Username: username, ClientMetadata: clientMetadata, diff --git a/packages/auth/src/providers/cognito/apis/sendUserAttributeVerificationCode.ts b/packages/auth/src/providers/cognito/apis/sendUserAttributeVerificationCode.ts index 781d9e0595f..d3f25b01d35 100644 --- a/packages/auth/src/providers/cognito/apis/sendUserAttributeVerificationCode.ts +++ b/packages/auth/src/providers/cognito/apis/sendUserAttributeVerificationCode.ts @@ -2,7 +2,7 @@ // SPDX-License-Identifier: Apache-2.0 import { Amplify } from '@aws-amplify/core'; -import { assertTokenProviderConfig } from '@aws-amplify/core/internals/utils'; +import { assertTokenProviderConfig, AuthAction } from '@aws-amplify/core/internals/utils'; import { fetchAuthSession } from '../../..'; import { AuthDeliveryMedium } from '../../../types'; import { @@ -13,6 +13,7 @@ import { getUserAttributeVerificationCode } from '../utils/clients/CognitoIdenti import { assertAuthTokens } from '../utils/types'; import { getRegion } from '../utils/clients/CognitoIdentityProvider/utils'; import { GetUserAttributeVerificationException } from '../types/errors'; +import { getAuthUserAgentValue } from '../../../utils'; /** * Resends user's confirmation code when updating attributes while authenticated. @@ -32,7 +33,10 @@ export const sendUserAttributeVerificationCode = async ( const { tokens } = await fetchAuthSession({ forceRefresh: false }); assertAuthTokens(tokens); const { CodeDeliveryDetails } = await getUserAttributeVerificationCode( - { region: getRegion(authConfig.userPoolId) }, + { + region: getRegion(authConfig.userPoolId), + userAgentValue: getAuthUserAgentValue(AuthAction.SendUserAttributeVerificationCode) + }, { AccessToken: tokens.accessToken.toString(), ClientMetadata: clientMetadata, diff --git a/packages/auth/src/providers/cognito/apis/setUpTOTP.ts b/packages/auth/src/providers/cognito/apis/setUpTOTP.ts index 5df778e4eac..f445ba7835f 100644 --- a/packages/auth/src/providers/cognito/apis/setUpTOTP.ts +++ b/packages/auth/src/providers/cognito/apis/setUpTOTP.ts @@ -2,7 +2,7 @@ // SPDX-License-Identifier: Apache-2.0 import { Amplify } from '@aws-amplify/core'; -import { assertTokenProviderConfig } from '@aws-amplify/core/internals/utils'; +import { assertTokenProviderConfig, AuthAction } from '@aws-amplify/core/internals/utils'; import { fetchAuthSession } from '../../../'; import { AuthError } from '../../../errors/AuthError'; import { @@ -14,6 +14,7 @@ import { getTOTPSetupDetails } from '../utils/signInHelpers'; import { associateSoftwareToken } from '../utils/clients/CognitoIdentityProvider'; import { getRegion } from '../utils/clients/CognitoIdentityProvider/utils'; import { assertAuthTokens } from '../utils/types'; +import { getAuthUserAgentValue } from '../../../utils'; /** * Sets up TOTP for the user. @@ -30,7 +31,10 @@ export async function setUpTOTP(): Promise { assertAuthTokens(tokens); const username = tokens.idToken?.payload['cognito:username'] ?? ''; const { SecretCode } = await associateSoftwareToken( - { region: getRegion(authConfig.userPoolId) }, + { + region: getRegion(authConfig.userPoolId), + userAgentValue: getAuthUserAgentValue(AuthAction.SetUpTOTP) + }, { AccessToken: tokens.accessToken.toString(), } diff --git a/packages/auth/src/providers/cognito/apis/signInWithRedirect.ts b/packages/auth/src/providers/cognito/apis/signInWithRedirect.ts index d7bf6661660..8ba9d466f90 100644 --- a/packages/auth/src/providers/cognito/apis/signInWithRedirect.ts +++ b/packages/auth/src/providers/cognito/apis/signInWithRedirect.ts @@ -3,10 +3,10 @@ import { Amplify, Hub, defaultStorage, OAuthConfig } from '@aws-amplify/core'; import { + AuthAction, AMPLIFY_SYMBOL, assertOAuthConfig, assertTokenProviderConfig, - getAmplifyUserAgent, isBrowser, urlSafeEncode, USER_AGENT_HEADER, @@ -21,7 +21,7 @@ import { AuthError } from '../../../errors/AuthError'; import { AuthErrorTypes } from '../../../types/Auth'; import { AuthErrorCodes } from '../../../common/AuthErrorStrings'; import { authErrorMessages } from '../../../Errors'; -import { openAuthSession } from '../../../utils'; +import { getAuthUserAgentValue, openAuthSession } from '../../../utils'; import { assertUserNotAuthenticated } from '../utils/signInHelpers'; import { SignInWithRedirectInput } from '../types'; import { generateCodeVerifier, generateState } from '../utils/oauth'; @@ -122,7 +122,7 @@ async function oauthSignIn({ domain, redirectUri: redirectSignIn[0], responseType, - userAgentValue: getAmplifyUserAgent(), + userAgentValue: getAuthUserAgentValue(AuthAction.SignInWithRedirect), preferPrivateSession, }); } @@ -431,7 +431,7 @@ async function parseRedirectURL() { domain, redirectUri: redirectSignIn[0], responseType, - userAgentValue: getAmplifyUserAgent(), + userAgentValue: getAuthUserAgentValue(AuthAction.SignInWithRedirect), }); } catch (err) { // is ok if there is not OAuthConfig diff --git a/packages/auth/src/providers/cognito/apis/signOut.ts b/packages/auth/src/providers/cognito/apis/signOut.ts index 7808a0eff10..ed0fa321e85 100644 --- a/packages/auth/src/providers/cognito/apis/signOut.ts +++ b/packages/auth/src/providers/cognito/apis/signOut.ts @@ -8,11 +8,12 @@ import { clearCredentials, defaultStorage, } from '@aws-amplify/core'; -import { openAuthSession } from '../../../utils'; +import { getAuthUserAgentValue, openAuthSession } from '../../../utils'; import { SignOutInput, SignOutOutput } from '../types'; import { DefaultOAuthStore } from '../utils/signInWithRedirectStore'; import { tokenOrchestrator } from '../tokenProvider'; import { + AuthAction, AMPLIFY_SYMBOL, assertOAuthConfig, assertTokenProviderConfig, @@ -56,6 +57,7 @@ async function clientSignOut(cognitoConfig: CognitoUserPoolConfig) { await revokeToken( { region: getRegion(cognitoConfig.userPoolId), + userAgentValue: getAuthUserAgentValue(AuthAction.SignOut) }, { ClientId: cognitoConfig.userPoolClientId, @@ -81,6 +83,7 @@ async function globalSignOut(cognitoConfig: CognitoUserPoolConfig) { await globalSignOutClient( { region: getRegion(cognitoConfig.userPoolId), + userAgentValue: getAuthUserAgentValue(AuthAction.SignOut) }, { AccessToken: tokens.accessToken.toString(), diff --git a/packages/auth/src/providers/cognito/apis/signUp.ts b/packages/auth/src/providers/cognito/apis/signUp.ts index 2dc5340e15b..92e859e81d7 100644 --- a/packages/auth/src/providers/cognito/apis/signUp.ts +++ b/packages/auth/src/providers/cognito/apis/signUp.ts @@ -2,7 +2,7 @@ // SPDX-License-Identifier: Apache-2.0 import { Amplify } from '@aws-amplify/core'; -import { assertTokenProviderConfig } from '@aws-amplify/core/internals/utils'; +import { assertTokenProviderConfig, AuthAction } from '@aws-amplify/core/internals/utils'; import { AuthDeliveryMedium } from '../../../types'; import { UserAttributeKey, SignUpInput, SignUpOutput } from '../types'; import { signUp as signUpClient } from '../utils/clients/CognitoIdentityProvider'; @@ -12,6 +12,7 @@ import { SignUpException } from '../types/errors'; import { AttributeType } from '../utils/clients/CognitoIdentityProvider/types'; import { getRegion } from '../utils/clients/CognitoIdentityProvider/utils'; import { toAttributeType } from '../utils/apiHelpers'; +import { getAuthUserAgentValue } from '../../../utils'; /** * Creates a user @@ -48,7 +49,10 @@ export async function signUp(input: SignUpInput): Promise { } const res = await signUpClient( - { region: getRegion(authConfig.userPoolId) }, + { + region: getRegion(authConfig.userPoolId), + userAgentValue: getAuthUserAgentValue(AuthAction.SignUp) + }, { Username: username, Password: password, diff --git a/packages/auth/src/providers/cognito/apis/updateMFAPreference.ts b/packages/auth/src/providers/cognito/apis/updateMFAPreference.ts index aaefe4b372e..e5b9c79b0fd 100644 --- a/packages/auth/src/providers/cognito/apis/updateMFAPreference.ts +++ b/packages/auth/src/providers/cognito/apis/updateMFAPreference.ts @@ -2,7 +2,7 @@ // SPDX-License-Identifier: Apache-2.0 import { Amplify } from '@aws-amplify/core'; -import { assertTokenProviderConfig } from '@aws-amplify/core/internals/utils'; +import { assertTokenProviderConfig, AuthAction } from '@aws-amplify/core/internals/utils'; import { fetchAuthSession } from '../../../'; import { UpdateMFAPreferenceInput } from '../types'; import { SetUserMFAPreferenceException } from '../types/errors'; @@ -11,6 +11,7 @@ import { setUserMFAPreference } from '../utils/clients/CognitoIdentityProvider'; import { getRegion } from '../utils/clients/CognitoIdentityProvider/utils'; import { CognitoMFASettings } from '../utils/clients/CognitoIdentityProvider/types'; import { assertAuthTokens } from '../utils/types'; +import { getAuthUserAgentValue } from '../../../utils'; /** * Updates the MFA preference of the user. @@ -28,7 +29,10 @@ export async function updateMFAPreference( const { tokens } = await fetchAuthSession({ forceRefresh: false }); assertAuthTokens(tokens); await setUserMFAPreference( - { region: getRegion(authConfig.userPoolId) }, + { + region: getRegion(authConfig.userPoolId), + userAgentValue: getAuthUserAgentValue(AuthAction.UpdateMFAPreference) + }, { AccessToken: tokens.accessToken.toString(), SMSMfaSettings: getMFASettings(sms), diff --git a/packages/auth/src/providers/cognito/apis/updatePassword.ts b/packages/auth/src/providers/cognito/apis/updatePassword.ts index 32c90b40d1f..99b1a2c34ac 100644 --- a/packages/auth/src/providers/cognito/apis/updatePassword.ts +++ b/packages/auth/src/providers/cognito/apis/updatePassword.ts @@ -7,10 +7,11 @@ import { UpdatePasswordInput } from '../types'; import { changePassword } from '../utils/clients/CognitoIdentityProvider'; import { ChangePasswordException } from '../../cognito/types/errors'; import { Amplify } from '@aws-amplify/core'; -import { assertTokenProviderConfig } from '@aws-amplify/core/internals/utils'; +import { assertTokenProviderConfig, AuthAction } from '@aws-amplify/core/internals/utils'; import { fetchAuthSession } from '../../../'; import { getRegion } from '../utils/clients/CognitoIdentityProvider/utils'; import { assertAuthTokens } from '../utils/types'; +import { getAuthUserAgentValue } from '../../../utils'; /** * Updates user's password while authenticated. @@ -38,7 +39,10 @@ export async function updatePassword( const { tokens } = await fetchAuthSession({ forceRefresh: false }); assertAuthTokens(tokens); await changePassword( - { region: getRegion(authConfig.userPoolId) }, + { + region: getRegion(authConfig.userPoolId), + userAgentValue: getAuthUserAgentValue(AuthAction.UpdatePassword) + }, { AccessToken: tokens.accessToken.toString(), PreviousPassword: oldPassword, diff --git a/packages/auth/src/providers/cognito/apis/updateUserAttributes.ts b/packages/auth/src/providers/cognito/apis/updateUserAttributes.ts index b1922a955e5..b5866f9fb26 100644 --- a/packages/auth/src/providers/cognito/apis/updateUserAttributes.ts +++ b/packages/auth/src/providers/cognito/apis/updateUserAttributes.ts @@ -2,7 +2,7 @@ // SPDX-License-Identifier: Apache-2.0 import { Amplify } from '@aws-amplify/core'; -import { assertTokenProviderConfig } from '@aws-amplify/core/internals/utils'; +import { assertTokenProviderConfig, AuthAction } from '@aws-amplify/core/internals/utils'; import { fetchAuthSession } from '../../../'; import { AuthUserAttributes, @@ -19,6 +19,7 @@ import { getRegion } from '../utils/clients/CognitoIdentityProvider/utils'; import { toAttributeType } from '../utils/apiHelpers'; import { CodeDeliveryDetailsType } from '../utils/clients/CognitoIdentityProvider/types'; import { UpdateUserAttributesException } from '../types/errors'; +import { getAuthUserAgentValue } from '../../../utils'; /** * Updates user's attributes while authenticated. @@ -38,7 +39,10 @@ export const updateUserAttributes = async ( const { tokens } = await fetchAuthSession({ forceRefresh: false }); assertAuthTokens(tokens); const { CodeDeliveryDetailsList } = await updateUserAttributesClient( - { region: getRegion(authConfig.userPoolId) }, + { + region: getRegion(authConfig.userPoolId), + userAgentValue: getAuthUserAgentValue(AuthAction.UpdateUserAttributes) + }, { AccessToken: tokens.accessToken.toString(), ClientMetadata: clientMetadata, diff --git a/packages/auth/src/providers/cognito/apis/verifyTOTPSetup.ts b/packages/auth/src/providers/cognito/apis/verifyTOTPSetup.ts index fe5370cc1a0..5aa3e84e19d 100644 --- a/packages/auth/src/providers/cognito/apis/verifyTOTPSetup.ts +++ b/packages/auth/src/providers/cognito/apis/verifyTOTPSetup.ts @@ -7,10 +7,11 @@ import { VerifyTOTPSetupInput } from '../types'; import { verifySoftwareToken } from '../utils/clients/CognitoIdentityProvider'; import { VerifySoftwareTokenException } from '../types/errors'; import { Amplify } from '@aws-amplify/core'; -import { assertTokenProviderConfig } from '@aws-amplify/core/internals/utils'; +import { assertTokenProviderConfig, AuthAction } from '@aws-amplify/core/internals/utils'; import { fetchAuthSession } from '../../../'; import { getRegion } from '../utils/clients/CognitoIdentityProvider/utils'; import { assertAuthTokens } from '../utils/types'; +import { getAuthUserAgentValue } from '../../../utils'; /** * Verifies an OTP code retrieved from an associated authentication app. @@ -35,7 +36,10 @@ export async function verifyTOTPSetup( const { tokens } = await fetchAuthSession({ forceRefresh: false }); assertAuthTokens(tokens); await verifySoftwareToken( - { region: getRegion(authConfig.userPoolId) }, + { + region: getRegion(authConfig.userPoolId), + userAgentValue: getAuthUserAgentValue(AuthAction.VerifyTOTPSetup) + }, { AccessToken: tokens.accessToken.toString(), UserCode: code, diff --git a/packages/auth/src/providers/cognito/index.ts b/packages/auth/src/providers/cognito/index.ts index 82dda42a806..f4a8cf821dd 100644 --- a/packages/auth/src/providers/cognito/index.ts +++ b/packages/auth/src/providers/cognito/index.ts @@ -1,7 +1,7 @@ // Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. // SPDX-License-Identifier: Apache-2.0 -import './polyfill'; +import './polyfills'; export { signUp } from './apis/signUp'; export { resetPassword } from './apis/resetPassword'; diff --git a/packages/auth/src/providers/cognito/polyfills/index.native.ts b/packages/auth/src/providers/cognito/polyfills/index.native.ts new file mode 100644 index 00000000000..065c0fecb15 --- /dev/null +++ b/packages/auth/src/providers/cognito/polyfills/index.native.ts @@ -0,0 +1,5 @@ +// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. +// SPDX-License-Identifier: Apache-2.0 +import { loadUrlPolyfill } from '@aws-amplify/react-native'; + +loadUrlPolyfill(); diff --git a/packages/auth/src/providers/cognito/polyfills/index.ts b/packages/auth/src/providers/cognito/polyfills/index.ts new file mode 100644 index 00000000000..f0daa8d350d --- /dev/null +++ b/packages/auth/src/providers/cognito/polyfills/index.ts @@ -0,0 +1,4 @@ +// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. +// SPDX-License-Identifier: Apache-2.0 + +// noop - polyfills not required on platform diff --git a/packages/auth/src/providers/cognito/utils/signInHelpers.ts b/packages/auth/src/providers/cognito/utils/signInHelpers.ts index dc64995c161..48437930e34 100644 --- a/packages/auth/src/providers/cognito/utils/signInHelpers.ts +++ b/packages/auth/src/providers/cognito/utils/signInHelpers.ts @@ -3,6 +3,7 @@ import { Amplify, CognitoUserPoolConfig } from '@aws-amplify/core'; import { + AuthAction, assertTokenProviderConfig, base64Encoder, } from '@aws-amplify/core/internals/utils'; @@ -55,6 +56,7 @@ import { USER_ALREADY_AUTHENTICATED_EXCEPTION } from '../../../errors/constants' import { getCurrentUser } from '../apis/getCurrentUser'; import { AuthTokenOrchestrator, DeviceMetadata } from '../tokenProvider/types'; import { assertDeviceMetadata } from './types'; +import { getAuthUserAgentValue } from '../../../utils'; const USER_ATTRIBUTES = 'userAttributes.'; @@ -105,7 +107,10 @@ export async function handleCustomChallenge({ }; const response = await respondToAuthChallenge( - { region: getRegion(userPoolId) }, + { + region: getRegion(userPoolId), + userAgentValue: getAuthUserAgentValue(AuthAction.ConfirmSignIn) + }, jsonReq ); @@ -134,7 +139,10 @@ export async function handleMFASetupChallenge({ }; const { Session } = await verifySoftwareToken( - { region: getRegion(userPoolId) }, + { + region: getRegion(userPoolId), + userAgentValue: getAuthUserAgentValue(AuthAction.ConfirmSignIn) + }, { UserCode: challengeResponse, Session: session, @@ -183,7 +191,13 @@ export async function handleSelectMFATypeChallenge({ ClientId: userPoolClientId, }; - return respondToAuthChallenge({ region: getRegion(userPoolId) }, jsonReq); + return respondToAuthChallenge( + { + region: getRegion(userPoolId), + userAgentValue: getAuthUserAgentValue(AuthAction.ConfirmSignIn) + }, + jsonReq + ); } export async function handleSMSMFAChallenge({ @@ -206,7 +220,13 @@ export async function handleSMSMFAChallenge({ ClientId: userPoolClientId, }; - return respondToAuthChallenge({ region: getRegion(userPoolId) }, jsonReq); + return respondToAuthChallenge( + { + region: getRegion(userPoolId), + userAgentValue: getAuthUserAgentValue(AuthAction.ConfirmSignIn) + }, + jsonReq + ); } export async function handleSoftwareTokenMFAChallenge({ challengeResponse, @@ -227,7 +247,13 @@ export async function handleSoftwareTokenMFAChallenge({ ClientMetadata: clientMetadata, ClientId: userPoolClientId, }; - return respondToAuthChallenge({ region: getRegion(userPoolId) }, jsonReq); + return respondToAuthChallenge( + { + region: getRegion(userPoolId), + userAgentValue: getAuthUserAgentValue(AuthAction.ConfirmSignIn) + }, + jsonReq + ); } export async function handleCompleteNewPasswordChallenge({ challengeResponse, @@ -252,7 +278,13 @@ export async function handleCompleteNewPasswordChallenge({ ClientId: userPoolClientId, }; - return respondToAuthChallenge({ region: getRegion(userPoolId) }, jsonReq); + return respondToAuthChallenge( + { + region: getRegion(userPoolId), + userAgentValue: getAuthUserAgentValue(AuthAction.ConfirmSignIn) + }, + jsonReq + ); } export async function handleUserPasswordAuthFlow( @@ -280,7 +312,10 @@ export async function handleUserPasswordAuthFlow( }; const response = await initiateAuth( - { region: getRegion(userPoolId) }, + { + region: getRegion(userPoolId), + userAgentValue: getAuthUserAgentValue(AuthAction.SignIn) + }, jsonReq ); @@ -322,7 +357,13 @@ export async function handleUserSRPAuthFlow( ClientId: userPoolClientId, }; - const resp = await initiateAuth({ region: getRegion(userPoolId) }, jsonReq); + const resp = await initiateAuth( + { + region: getRegion(userPoolId), + userAgentValue: getAuthUserAgentValue(AuthAction.SignIn) + }, + jsonReq + ); const { ChallengeParameters: challengeParameters, Session: session } = resp; return handlePasswordVerifierChallenge( @@ -359,7 +400,10 @@ export async function handleCustomAuthFlowWithoutSRP( }; const response = await initiateAuth( - { region: getRegion(userPoolId) }, + { + region: getRegion(userPoolId), + userAgentValue: getAuthUserAgentValue(AuthAction.SignIn) + }, jsonReq ); if (response.ChallengeName === 'DEVICE_SRP_AUTH') @@ -405,7 +449,13 @@ export async function handleCustomSRPAuthFlow( }; const { ChallengeParameters: challengeParameters, Session: session } = - await initiateAuth({ region: getRegion(userPoolId) }, jsonReq); + await initiateAuth( + { + region: getRegion(userPoolId), + userAgentValue: getAuthUserAgentValue(AuthAction.SignIn) + }, + jsonReq + ); return handlePasswordVerifierChallenge( password, diff --git a/packages/aws-amplify/__tests__/exports.test.ts b/packages/aws-amplify/__tests__/exports.test.ts index 8beba6816e5..5530c2c6c9d 100644 --- a/packages/aws-amplify/__tests__/exports.test.ts +++ b/packages/aws-amplify/__tests__/exports.test.ts @@ -228,8 +228,8 @@ describe('aws-amplify Exports', () => { it('should only export expected symbols from the top-level', () => { expect(Object.keys(apiTopLevelExports)).toMatchInlineSnapshot(` Array [ - "GraphQLAuthError", "generateClient", + "GraphQLAuthError", "get", "put", "post", diff --git a/packages/aws-amplify/package.json b/packages/aws-amplify/package.json index 629cc8a69d0..edc1f327de6 100644 --- a/packages/aws-amplify/package.json +++ b/packages/aws-amplify/package.json @@ -254,6 +254,24 @@ "import": "{ record }", "limit": "21.10 kB" }, + { + "name": "[Analytics] record (Kinesis)", + "path": "./lib-esm/analytics/kinesis/index.js", + "import": "{ record }", + "limit": "46.40 kB" + }, + { + "name": "[Analytics] record (Kinesis Firehose)", + "path": "./lib-esm/analytics/kinesis-firehose/index.js", + "import": "{ record }", + "limit": "42.73 kB" + }, + { + "name": "[Analytics] record (Personalize)", + "path": "./lib-esm/analytics/personalize/index.js", + "import": "{ record }", + "limit": "47.0 kB" + }, { "name": "[Analytics] identifyUser (Pinpoint)", "path": "./lib-esm/analytics/index.js", @@ -272,23 +290,17 @@ "import": "{ disable }", "limit": "0.50 kB" }, - { - "name": "[API] class (AppSync)", - "path": "./lib-esm/api/index.js", - "import": "{ API }", - "limit": "70.00 kB" - }, { "name": "[API] generateClient (AppSync)", "path": "./lib-esm/api/index.js", "import": "{ generateClient }", - "limit": "70.00 kB" + "limit": "49.68 kB" }, { "name": "[API] REST API handlers", "path": "./lib-esm/api/index.js", "import": "{ get, post, put, del, patch, head, isCancelError }", - "limit": "13.63 kB" + "limit": "13.7 kB" }, { "name": "[Auth] signUp (Cognito)", @@ -306,19 +318,19 @@ "name": "[Auth] confirmResetPassword (Cognito)", "path": "./lib-esm/auth/index.js", "import": "{ confirmResetPassword }", - "limit": "11.00 kB" + "limit": "11.05 kB" }, { "name": "[Auth] signIn (Cognito)", "path": "./lib-esm/auth/index.js", "import": "{ signIn }", - "limit": "28.30 kB" + "limit": "29.17 kB" }, { "name": "[Auth] resendSignUpCode (Cognito)", "path": "./lib-esm/auth/index.js", "import": "{ resendSignUpCode }", - "limit": "11.00 kB" + "limit": "11.08 kB" }, { "name": "[Auth] confirmSignUp (Cognito)", @@ -330,37 +342,37 @@ "name": "[Auth] confirmSignIn (Cognito)", "path": "./lib-esm/auth/index.js", "import": "{ confirmSignIn }", - "limit": "28.20 kB" + "limit": "29.05 kB" }, { "name": "[Auth] updateMFAPreference (Cognito)", "path": "./lib-esm/auth/index.js", "import": "{ updateMFAPreference }", - "limit": "10.10 kB" + "limit": "10.22 kB" }, { "name": "[Auth] fetchMFAPreference (Cognito)", "path": "./lib-esm/auth/index.js", "import": "{ fetchMFAPreference }", - "limit": "10.10 kB" + "limit": "10.23 kB" }, { "name": "[Auth] verifyTOTPSetup (Cognito)", "path": "./lib-esm/auth/index.js", "import": "{ verifyTOTPSetup }", - "limit": "11.10 kB" + "limit": "11.16 kB" }, { "name": "[Auth] updatePassword (Cognito)", "path": "./lib-esm/auth/index.js", "import": "{ updatePassword }", - "limit": "11.10 kB" + "limit": "11.19 kB" }, { "name": "[Auth] setUpTOTP (Cognito)", "path": "./lib-esm/auth/index.js", "import": "{ setUpTOTP }", - "limit": "11.50 kB" + "limit": "12.08 kB" }, { "name": "[Auth] updateUserAttributes (Cognito)", @@ -384,67 +396,67 @@ "name": "[Auth] signInWithRedirect (Cognito)", "path": "./lib-esm/auth/index.js", "import": "{ signInWithRedirect }", - "limit": "21.50 kB" + "limit": "22.47 kB" }, { "name": "[Auth] fetchUserAttributes (Cognito)", "path": "./lib-esm/auth/index.js", "import": "{ fetchUserAttributes }", - "limit": "10.10 kB" + "limit": "10.19 kB" }, { "name": "[Auth] Basic Auth Flow (Cognito)", "path": "./lib-esm/auth/index.js", "import": "{ signIn, signOut, fetchAuthSession, confirmSignIn }", - "limit": "30.30 kB" + "limit": "31.35 kB" }, { "name": "[Auth] OAuth Auth Flow (Cognito)", "path": "./lib-esm/auth/index.js", "import": "{ signInWithRedirect, signOut, fetchAuthSession }", - "limit": "22.00 kB" + "limit": "23.04 kB" }, { "name": "[Storage] copy (S3)", "path": "./lib-esm/storage/index.js", "import": "{ copy }", - "limit": "16.87 kB" + "limit": "16.98 kB" }, { "name": "[Storage] downloadData (S3)", "path": "./lib-esm/storage/index.js", "import": "{ downloadData }", - "limit": "17.65 kB" + "limit": "17.73 kB" }, { "name": "[Storage] getProperties (S3)", "path": "./lib-esm/storage/index.js", "import": "{ getProperties }", - "limit": "16.90 kB" + "limit": "17.02 kB" }, { "name": "[Storage] getUrl (S3)", "path": "./lib-esm/storage/index.js", "import": "{ getUrl }", - "limit": "18.30 kB" + "limit": "18.46 kB" }, { "name": "[Storage] list (S3)", "path": "./lib-esm/storage/index.js", "import": "{ list }", - "limit": "17.46 kB" + "limit": "17.53 kB" }, { "name": "[Storage] remove (S3)", "path": "./lib-esm/storage/index.js", "import": "{ remove }", - "limit": "16.73 kB" + "limit": "16.85 kB" }, { "name": "[Storage] uploadData (S3)", "path": "./lib-esm/storage/index.js", "import": "{ uploadData }", - "limit": "23.3 kB" + "limit": "23.66 kB" } ], "jest": { diff --git a/packages/core/__tests__/AwsClients/CognitoIdentity/getCredentialsForIdentity.test.ts b/packages/core/__tests__/awsClients/cognitoIdentity/getCredentialsForIdentity.test.ts similarity index 98% rename from packages/core/__tests__/AwsClients/CognitoIdentity/getCredentialsForIdentity.test.ts rename to packages/core/__tests__/awsClients/cognitoIdentity/getCredentialsForIdentity.test.ts index 3841edf63b8..51c2a5c2ecb 100644 --- a/packages/core/__tests__/AwsClients/CognitoIdentity/getCredentialsForIdentity.test.ts +++ b/packages/core/__tests__/awsClients/cognitoIdentity/getCredentialsForIdentity.test.ts @@ -7,7 +7,7 @@ import { getCredentialsForIdentity, GetCredentialsForIdentityInput, GetCredentialsForIdentityOutput, -} from '../../../src/AwsClients/CognitoIdentity'; +} from '../../../src/awsClients/cognitoIdentity'; import { cognitoIdentityHandlerOptions, mockCredentials, diff --git a/packages/core/__tests__/AwsClients/CognitoIdentity/getId.test.ts b/packages/core/__tests__/awsClients/cognitoIdentity/getId.test.ts similarity index 98% rename from packages/core/__tests__/AwsClients/CognitoIdentity/getId.test.ts rename to packages/core/__tests__/awsClients/cognitoIdentity/getId.test.ts index 736b5d8f47d..b65ab75af07 100644 --- a/packages/core/__tests__/AwsClients/CognitoIdentity/getId.test.ts +++ b/packages/core/__tests__/awsClients/cognitoIdentity/getId.test.ts @@ -7,7 +7,7 @@ import { getId, GetIdInput, GetIdOutput, -} from '../../../src/AwsClients/CognitoIdentity'; +} from '../../../src/awsClients/cognitoIdentity'; import { cognitoIdentityHandlerOptions, mockIdentityId, diff --git a/packages/core/__tests__/AwsClients/Pinpoint/getInAppMessages.test.ts b/packages/core/__tests__/awsClients/pinpoint/getInAppMessages.test.ts similarity index 98% rename from packages/core/__tests__/AwsClients/Pinpoint/getInAppMessages.test.ts rename to packages/core/__tests__/awsClients/pinpoint/getInAppMessages.test.ts index bdc1b474435..d4044084aaf 100644 --- a/packages/core/__tests__/AwsClients/Pinpoint/getInAppMessages.test.ts +++ b/packages/core/__tests__/awsClients/pinpoint/getInAppMessages.test.ts @@ -6,7 +6,7 @@ import { getInAppMessages, GetInAppMessagesInput, GetInAppMessagesOutput, -} from '../../../src/AwsClients/Pinpoint'; +} from '../../../src/awsClients/pinpoint'; import { mockApplicationId, mockEndpointId, diff --git a/packages/core/__tests__/AwsClients/Pinpoint/putEvents.test.ts b/packages/core/__tests__/awsClients/pinpoint/putEvents.test.ts similarity index 98% rename from packages/core/__tests__/AwsClients/Pinpoint/putEvents.test.ts rename to packages/core/__tests__/awsClients/pinpoint/putEvents.test.ts index 3b2b9e010a3..e50f18c6055 100644 --- a/packages/core/__tests__/AwsClients/Pinpoint/putEvents.test.ts +++ b/packages/core/__tests__/awsClients/pinpoint/putEvents.test.ts @@ -6,7 +6,7 @@ import { putEvents, PutEventsInput, PutEventsOutput, -} from '../../../src/AwsClients/Pinpoint'; +} from '../../../src/awsClients/pinpoint'; import { mockApplicationId, mockEventsRequest, diff --git a/packages/core/__tests__/AwsClients/Pinpoint/updateEndpoint.test.ts b/packages/core/__tests__/awsClients/pinpoint/updateEndpoint.test.ts similarity index 98% rename from packages/core/__tests__/AwsClients/Pinpoint/updateEndpoint.test.ts rename to packages/core/__tests__/awsClients/pinpoint/updateEndpoint.test.ts index ffacf4a8d97..05f713d0cca 100644 --- a/packages/core/__tests__/AwsClients/Pinpoint/updateEndpoint.test.ts +++ b/packages/core/__tests__/awsClients/pinpoint/updateEndpoint.test.ts @@ -6,7 +6,7 @@ import { updateEndpoint, UpdateEndpointInput, UpdateEndpointOutput, -} from '../../../src/AwsClients/Pinpoint'; +} from '../../../src/awsClients/pinpoint'; import { mockApplicationId, mockEndpointId, diff --git a/packages/core/__tests__/AwsClients/testUtils/data.ts b/packages/core/__tests__/awsClients/testUtils/data.ts similarity index 100% rename from packages/core/__tests__/AwsClients/testUtils/data.ts rename to packages/core/__tests__/awsClients/testUtils/data.ts diff --git a/packages/core/__tests__/providers/pinpoint/apis/record.test.ts b/packages/core/__tests__/providers/pinpoint/apis/record.test.ts index 85faf1ee2d1..7e75c556006 100644 --- a/packages/core/__tests__/providers/pinpoint/apis/record.test.ts +++ b/packages/core/__tests__/providers/pinpoint/apis/record.test.ts @@ -1,5 +1,5 @@ import { v4 } from 'uuid'; -import { putEvents as clientPutEvents } from '../../../../src/AwsClients/Pinpoint'; +import { putEvents as clientPutEvents } from '../../../../src/awsClients/pinpoint'; import { record } from '../../../../src/providers/pinpoint/apis'; import { updateEndpoint } from '../../../../src/providers/pinpoint/apis/updateEndpoint'; import { getEndpointId } from '../../../../src/providers/pinpoint/utils'; @@ -16,7 +16,7 @@ import { import { getEventBuffer } from '../../../../src/providers/pinpoint/utils/getEventBuffer'; jest.mock('uuid'); -jest.mock('../../../../src/AwsClients/Pinpoint'); +jest.mock('../../../../src/awsClients/pinpoint'); jest.mock('../../../../src/providers/pinpoint/utils'); jest.mock('../../../../src/providers/pinpoint/apis/updateEndpoint'); jest.mock('../../../../src/providers/pinpoint/utils/getEventBuffer'); diff --git a/packages/core/__tests__/providers/pinpoint/apis/updateEndpoint.test.ts b/packages/core/__tests__/providers/pinpoint/apis/updateEndpoint.test.ts index 6e9185755e8..7536697f5bb 100644 --- a/packages/core/__tests__/providers/pinpoint/apis/updateEndpoint.test.ts +++ b/packages/core/__tests__/providers/pinpoint/apis/updateEndpoint.test.ts @@ -3,7 +3,7 @@ import { v4 } from 'uuid'; import { ClientDevice } from '../../../../src/ClientDevice'; -import { updateEndpoint as clientUpdateEndpoint } from '../../../../src/AwsClients/Pinpoint'; +import { updateEndpoint as clientUpdateEndpoint } from '../../../../src/awsClients/pinpoint'; import { cacheEndpointId, getEndpointId, @@ -23,7 +23,7 @@ import { import { getExpectedInput } from './testUtils/getExpectedInput'; jest.mock('uuid'); -jest.mock('../../../../src/AwsClients/Pinpoint'); +jest.mock('../../../../src/awsClients/pinpoint'); jest.mock('../../../../src/providers/pinpoint/utils'); describe('Pinpoint Provider API: updateEndpoint', () => { diff --git a/packages/core/__tests__/utils/globalHelpers/globalHelpers.native.test.ts b/packages/core/__tests__/utils/globalHelpers/globalHelpers.native.test.ts index ffc9b7bd516..5c49126827e 100644 --- a/packages/core/__tests__/utils/globalHelpers/globalHelpers.native.test.ts +++ b/packages/core/__tests__/utils/globalHelpers/globalHelpers.native.test.ts @@ -1,8 +1,7 @@ // Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. // SPDX-License-Identifier: Apache-2.0 -import { loadGetRandomValues } from '@aws-amplify/react-native'; -import { decode, encode } from 'base-64'; +import { loadGetRandomValues, loadBase64 } from '@aws-amplify/react-native'; import { getAtob, getBtoa, @@ -21,12 +20,14 @@ jest.mock('@aws-amplify/react-native', () => ({ writable: true, }); }), + loadBase64: jest.fn(() => ({ + decode: jest.fn(() => 'isMockDecode'), + encode: jest.fn(() => 'isMockEncode'), + })), })); -jest.mock('base-64'); -const mockDecode = decode as jest.Mock; -const mockEncode = encode as jest.Mock; const mockLoadGetRandomValues = loadGetRandomValues as jest.Mock; +const mockLoadBase64 = loadBase64 as jest.Mock; describe('getGlobal (native)', () => { beforeAll(() => { @@ -42,13 +43,13 @@ describe('getGlobal (native)', () => { describe('getBtoa()', () => { it('returns encode provided by base-64', () => { - expect(getBtoa()).toEqual(mockEncode); + expect(getBtoa()('input')).toEqual('isMockEncode'); }); }); describe('getAtob()', () => { it('returns decode provided by base-64', () => { - expect(getAtob()).toEqual(mockDecode); + expect(getAtob()('input')).toEqual('isMockDecode'); }); }); }); diff --git a/packages/core/internals/aws-clients/pinpoint/package.json b/packages/core/internals/aws-clients/pinpoint/package.json index 4205492184a..321819a9c6d 100644 --- a/packages/core/internals/aws-clients/pinpoint/package.json +++ b/packages/core/internals/aws-clients/pinpoint/package.json @@ -1,8 +1,8 @@ { "name": "@aws-amplify/core/internals/aws-clients/pinpoint", - "types": "../../../lib-esm/AwsClients/Pinpoint/index.d.ts", - "main": "../../../lib/AwsClients/Pinpoint/index.js", - "module": "../../../lib-esm/AwsClients/Pinpoint/index.js", - "react-native": "../../../lib-esm/AwsClients/Pinpoint/index.js", + "types": "../../../lib-esm/awsClients/pinpoint/index.d.ts", + "main": "../../../lib/awsClients/pinpoint/index.js", + "module": "../../../lib-esm/awsClients/pinpoint/index.js", + "react-native": "../../../lib-esm/awsClients/pinpoint/index.js", "sideEffects": false } \ No newline at end of file diff --git a/packages/core/src/Platform/types.ts b/packages/core/src/Platform/types.ts index 7e594981dbe..fe2b293bad0 100644 --- a/packages/core/src/Platform/types.ts +++ b/packages/core/src/Platform/types.ts @@ -53,40 +53,30 @@ export enum ApiAction { Head = '7', } export enum AuthAction { - // SignUp = '1', - // ConfirmSignUp = '2', - // ResendSignUp = '3', - // SignIn = '4', - // GetMFAOptions = '5', - // GetPreferredMFA = '6', - // SetPreferredMFA = '7', - // DisableSMS = '8', - // EnableSMS = '9', - // SetupTOTP = '10', - // VerifyTotpToken = '11', - // ConfirmSignIn = '12', - // CompleteNewPassword = '13', - // SendCustomChallengeAnswer = '14', - // DeleteUserAttributes = '15', - // DeleteUser = '16', - // UpdateUserAttributes = '17', - // UserAttributes = '18', - // CurrentUserPoolUser = '19', - // CurrentAuthenticatedUser = '20', - // CurrentSession = '21', - // VerifyUserAttribute = '22', - // VerifyUserAttributeSubmit = '23', - // VerifyCurrentUserAttribute = '24', - // VerifyCurrentUserAttributeSubmit = '25', - // SignOut = '26', - // ChangePassword = '27', - // ForgotPassword = '28', - // ForgotPasswordSubmit = '29', + SignUp = '1', + ConfirmSignUp = '2', + ResendSignUpCode = '3', + SignIn = '4', + FetchMFAPreference = '6', + UpdateMFAPreference = '7', + SetUpTOTP = '10', + VerifyTOTPSetup = '11', + ConfirmSignIn = '12', + DeleteUserAttributes = '15', + DeleteUser = '16', + UpdateUserAttributes = '17', + FetchUserAttributes = '18', + ConfirmUserAttribute = '22', + SignOut = '26', + UpdatePassword = '27', + ResetPassword = '28', + ConfirmResetPassword = '29', FederatedSignIn = '30', - // CurrentUserInfo = '31', - // RememberDevice = '32', - // ForgetDevice = '33', - // FetchDevices = '34', + RememberDevice = '32', + ForgetDevice = '33', + FetchDevices = '34', + SendUserAttributeVerificationCode = '35', + SignInWithRedirect = '36', } export enum DataStoreAction { Subscribe = '1', @@ -114,12 +104,13 @@ export enum PushNotificationAction { None = '0', } export enum StorageAction { - Put = '1', - Get = '2', + UploadData = '1', + DownloadData = '2', List = '3', Copy = '4', Remove = '5', GetProperties = '6', + GetUrl = '7' } type ActionMap = { diff --git a/packages/core/src/AwsClients/CognitoIdentity/base.ts b/packages/core/src/awsClients/cognitoIdentity/base.ts similarity index 100% rename from packages/core/src/AwsClients/CognitoIdentity/base.ts rename to packages/core/src/awsClients/cognitoIdentity/base.ts diff --git a/packages/core/src/AwsClients/CognitoIdentity/getCredentialsForIdentity.ts b/packages/core/src/awsClients/cognitoIdentity/getCredentialsForIdentity.ts similarity index 100% rename from packages/core/src/AwsClients/CognitoIdentity/getCredentialsForIdentity.ts rename to packages/core/src/awsClients/cognitoIdentity/getCredentialsForIdentity.ts diff --git a/packages/core/src/AwsClients/CognitoIdentity/getId.ts b/packages/core/src/awsClients/cognitoIdentity/getId.ts similarity index 100% rename from packages/core/src/AwsClients/CognitoIdentity/getId.ts rename to packages/core/src/awsClients/cognitoIdentity/getId.ts diff --git a/packages/core/src/AwsClients/CognitoIdentity/index.ts b/packages/core/src/awsClients/cognitoIdentity/index.ts similarity index 100% rename from packages/core/src/AwsClients/CognitoIdentity/index.ts rename to packages/core/src/awsClients/cognitoIdentity/index.ts diff --git a/packages/core/src/AwsClients/CognitoIdentity/types.ts b/packages/core/src/awsClients/cognitoIdentity/types.ts similarity index 100% rename from packages/core/src/AwsClients/CognitoIdentity/types.ts rename to packages/core/src/awsClients/cognitoIdentity/types.ts diff --git a/packages/core/src/AwsClients/Pinpoint/base.ts b/packages/core/src/awsClients/pinpoint/base.ts similarity index 100% rename from packages/core/src/AwsClients/Pinpoint/base.ts rename to packages/core/src/awsClients/pinpoint/base.ts diff --git a/packages/core/src/AwsClients/Pinpoint/errorHelpers.ts b/packages/core/src/awsClients/pinpoint/errorHelpers.ts similarity index 100% rename from packages/core/src/AwsClients/Pinpoint/errorHelpers.ts rename to packages/core/src/awsClients/pinpoint/errorHelpers.ts diff --git a/packages/core/src/AwsClients/Pinpoint/getInAppMessages.ts b/packages/core/src/awsClients/pinpoint/getInAppMessages.ts similarity index 100% rename from packages/core/src/AwsClients/Pinpoint/getInAppMessages.ts rename to packages/core/src/awsClients/pinpoint/getInAppMessages.ts diff --git a/packages/core/src/AwsClients/Pinpoint/index.ts b/packages/core/src/awsClients/pinpoint/index.ts similarity index 100% rename from packages/core/src/AwsClients/Pinpoint/index.ts rename to packages/core/src/awsClients/pinpoint/index.ts diff --git a/packages/core/src/AwsClients/Pinpoint/putEvents.ts b/packages/core/src/awsClients/pinpoint/putEvents.ts similarity index 100% rename from packages/core/src/AwsClients/Pinpoint/putEvents.ts rename to packages/core/src/awsClients/pinpoint/putEvents.ts diff --git a/packages/core/src/AwsClients/Pinpoint/types.ts b/packages/core/src/awsClients/pinpoint/types.ts similarity index 100% rename from packages/core/src/AwsClients/Pinpoint/types.ts rename to packages/core/src/awsClients/pinpoint/types.ts diff --git a/packages/core/src/AwsClients/Pinpoint/updateEndpoint.ts b/packages/core/src/awsClients/pinpoint/updateEndpoint.ts similarity index 100% rename from packages/core/src/AwsClients/Pinpoint/updateEndpoint.ts rename to packages/core/src/awsClients/pinpoint/updateEndpoint.ts diff --git a/packages/core/src/clients/middleware/signing/signer/signatureV4/index.native.ts b/packages/core/src/clients/middleware/signing/signer/signatureV4/index.native.ts deleted file mode 100644 index 7b2ad5cb2a5..00000000000 --- a/packages/core/src/clients/middleware/signing/signer/signatureV4/index.native.ts +++ /dev/null @@ -1,12 +0,0 @@ -// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. -// SPDX-License-Identifier: Apache-2.0 - -import { loadUrlPolyfill } from '@aws-amplify/react-native'; - -loadUrlPolyfill(); - -// TODO: V6 replace Signer -export { signRequest } from './signRequest'; -export { presignUrl } from './presignUrl'; -export { TOKEN_QUERY_PARAM } from './constants'; -export { getHashedPayload } from './utils/getHashedPayload'; diff --git a/packages/core/src/clients/middleware/signing/signer/signatureV4/index.ts b/packages/core/src/clients/middleware/signing/signer/signatureV4/index.ts index e8ef35a57eb..2365096e44a 100644 --- a/packages/core/src/clients/middleware/signing/signer/signatureV4/index.ts +++ b/packages/core/src/clients/middleware/signing/signer/signatureV4/index.ts @@ -1,6 +1,8 @@ // Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. // SPDX-License-Identifier: Apache-2.0 +import './polyfills'; + // TODO: V6 replace Signer export { signRequest } from './signRequest'; export { presignUrl } from './presignUrl'; diff --git a/packages/core/src/clients/middleware/signing/signer/signatureV4/polyfills/index.native.ts b/packages/core/src/clients/middleware/signing/signer/signatureV4/polyfills/index.native.ts new file mode 100644 index 00000000000..065c0fecb15 --- /dev/null +++ b/packages/core/src/clients/middleware/signing/signer/signatureV4/polyfills/index.native.ts @@ -0,0 +1,5 @@ +// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. +// SPDX-License-Identifier: Apache-2.0 +import { loadUrlPolyfill } from '@aws-amplify/react-native'; + +loadUrlPolyfill(); diff --git a/packages/core/src/clients/middleware/signing/signer/signatureV4/polyfills/index.ts b/packages/core/src/clients/middleware/signing/signer/signatureV4/polyfills/index.ts new file mode 100644 index 00000000000..f0daa8d350d --- /dev/null +++ b/packages/core/src/clients/middleware/signing/signer/signatureV4/polyfills/index.ts @@ -0,0 +1,4 @@ +// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. +// SPDX-License-Identifier: Apache-2.0 + +// noop - polyfills not required on platform diff --git a/packages/core/src/index.ts b/packages/core/src/index.ts index d67d3fc296a..e8f762e16b8 100644 --- a/packages/core/src/index.ts +++ b/packages/core/src/index.ts @@ -44,7 +44,7 @@ export { getId, GetCredentialsForIdentityInput, GetCredentialsForIdentityOutput, -} from './AwsClients/CognitoIdentity'; +} from './awsClients/cognitoIdentity'; // Amplify-wide constructs export { UserProfile } from './types'; diff --git a/packages/core/src/providers/pinpoint/apis/updateEndpoint.ts b/packages/core/src/providers/pinpoint/apis/updateEndpoint.ts index 0cc0b769d75..2700b79a861 100644 --- a/packages/core/src/providers/pinpoint/apis/updateEndpoint.ts +++ b/packages/core/src/providers/pinpoint/apis/updateEndpoint.ts @@ -6,7 +6,7 @@ import { ClientDevice } from '../../../ClientDevice'; import { updateEndpoint as clientUpdateEndpoint, UpdateEndpointInput, -} from '../../../AwsClients/Pinpoint'; +} from '../../../awsClients/pinpoint'; import { PinpointUpdateEndpointInput } from '../types'; import { cacheEndpointId, getEndpointId } from '../utils'; diff --git a/packages/core/src/providers/pinpoint/utils/PinpointEventBuffer.ts b/packages/core/src/providers/pinpoint/utils/PinpointEventBuffer.ts index 66e77fc6148..616e0ca2767 100644 --- a/packages/core/src/providers/pinpoint/utils/PinpointEventBuffer.ts +++ b/packages/core/src/providers/pinpoint/utils/PinpointEventBuffer.ts @@ -7,7 +7,7 @@ import { putEvents, PutEventsInput, PutEventsOutput, -} from '../../../AwsClients/Pinpoint'; +} from '../../../awsClients/pinpoint'; import { EventBufferConfig, BufferedEvent, diff --git a/packages/core/src/utils/globalHelpers/index.native.ts b/packages/core/src/utils/globalHelpers/index.native.ts index 43cb0e8d1b3..8c0ca524792 100644 --- a/packages/core/src/utils/globalHelpers/index.native.ts +++ b/packages/core/src/utils/globalHelpers/index.native.ts @@ -1,11 +1,11 @@ // Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. // SPDX-License-Identifier: Apache-2.0 -import { loadGetRandomValues } from '@aws-amplify/react-native'; -import { encode, decode } from 'base-64'; +import { loadGetRandomValues, loadBase64 } from '@aws-amplify/react-native'; import { AmplifyError } from '../../errors'; loadGetRandomValues(); +const { encode, decode } = loadBase64(); export const getCrypto = () => { if ( diff --git a/packages/datastore/__tests__/IndexedDBAdapter.test.ts b/packages/datastore/__tests__/IndexedDBAdapter.test.ts index a9702ea978c..91980b2e9d8 100644 --- a/packages/datastore/__tests__/IndexedDBAdapter.test.ts +++ b/packages/datastore/__tests__/IndexedDBAdapter.test.ts @@ -623,7 +623,7 @@ describe('IndexedDB benchmarks', () => { expect(time).toBeLessThan(JOIN_TIME_LIMIT); }); - test('wide joins with outer level ORs operate within expected time limits', async () => { + test.skip('wide joins with outer level ORs operate within expected time limits', async () => { const parents: CompositePKParent[] = []; await sideloadIDBData(100, 'CompositePKParent', i => { const parent = new CompositePKParent({ diff --git a/packages/datastore/package.json b/packages/datastore/package.json index 4df903a899d..0a22b56292f 100644 --- a/packages/datastore/package.json +++ b/packages/datastore/package.json @@ -74,7 +74,7 @@ "name": "DataStore (top-level class)", "path": "./lib-esm/index.js", "import": "{ Amplify, DataStore }", - "limit": "137 kB" + "limit": "89.0 kB" } ], "jest": { diff --git a/packages/geo/package.json b/packages/geo/package.json index ffc3ed48ad1..d993a5dbe2e 100644 --- a/packages/geo/package.json +++ b/packages/geo/package.json @@ -73,7 +73,7 @@ "name": "Geo (top-level class)", "path": "./lib-esm/index.js", "import": "{ Amplify, Geo }", - "limit": "52.12 kB" + "limit": "43.9 kB" } ], "jest": { diff --git a/packages/notifications/package.json b/packages/notifications/package.json index 8ece7c2db94..01fda45dc36 100644 --- a/packages/notifications/package.json +++ b/packages/notifications/package.json @@ -14,7 +14,6 @@ "test:default": "jest -w 1 --coverage", "test:native": "jest -w 1 --coverage --config=jest.native.config.js --coverageDirectory=coverage-native", "test:watch": "tslint 'src/**/*.ts' && jest -w 1 --watch", - "test:size": "size-limit", "build-with-test": "npm run clean && npm test && tsc && webpack", "build:cjs": "node ./build es5 && webpack && webpack --config ./webpack.config.dev.js", "build:esm": "node ./build es6", @@ -106,19 +105,5 @@ "@babel/plugin-proposal-private-methods": "^7.0.0", "@babel/plugin-proposal-private-property-in-object": "^7.0.0", "metro-react-native-babel-preset": "^0.66.2" - }, - "size-limit": [ - { - "name": "Notifications (top-level class)", - "path": "./lib-esm/index.js", - "import": "{ Amplify, Notifications }", - "limit": "29.95 kB" - }, - { - "name": "Notifications (with Analytics)", - "path": "./lib-esm/index.js", - "import": "{ Amplify, Notifications, Analytics }", - "limit": "29.95 kB" - } - ] + } } diff --git a/packages/react-native/src/index.ts b/packages/react-native/src/index.ts index 5ea4dcf6dab..f1880abb4fe 100644 --- a/packages/react-native/src/index.ts +++ b/packages/react-native/src/index.ts @@ -8,4 +8,5 @@ export { loadBuffer, loadUrlPolyfill, loadGetRandomValues, + loadBase64, } from './moduleLoaders'; diff --git a/packages/react-native/src/moduleLoaders/index.ts b/packages/react-native/src/moduleLoaders/index.ts index a620987f50d..0eeef2ad7cb 100644 --- a/packages/react-native/src/moduleLoaders/index.ts +++ b/packages/react-native/src/moduleLoaders/index.ts @@ -6,3 +6,4 @@ export { loadNetInfo } from './loadNetInfo'; export { loadBuffer } from './loadBuffer'; export { loadUrlPolyfill } from './loadUrlPolyfill'; export { loadGetRandomValues } from './loadGetRandomValues'; +export { loadBase64 } from './loadBase64'; diff --git a/packages/react-native/src/moduleLoaders/loadBase64.ts b/packages/react-native/src/moduleLoaders/loadBase64.ts new file mode 100644 index 00000000000..6be904c556b --- /dev/null +++ b/packages/react-native/src/moduleLoaders/loadBase64.ts @@ -0,0 +1,6 @@ +// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. +// SPDX-License-Identifier: Apache-2.0 + +import { decode, encode } from 'base-64'; + +export const loadBase64 = () => ({ decode, encode }); diff --git a/packages/storage/__tests__/providers/s3/apis/copy.test.ts b/packages/storage/__tests__/providers/s3/apis/copy.test.ts index dc33c10276c..1db4b9e9391 100644 --- a/packages/storage/__tests__/providers/s3/apis/copy.test.ts +++ b/packages/storage/__tests__/providers/s3/apis/copy.test.ts @@ -38,6 +38,7 @@ const credentials: Credentials = { const copyObjectClientConfig = { credentials, region, + userAgentValue: expect.any(String) }; const copyObjectClientBaseParams = { Bucket: bucket, diff --git a/packages/storage/__tests__/providers/s3/apis/downloadData.test.ts b/packages/storage/__tests__/providers/s3/apis/downloadData.test.ts index e107f05e6ad..5dc89d72df1 100644 --- a/packages/storage/__tests__/providers/s3/apis/downloadData.test.ts +++ b/packages/storage/__tests__/providers/s3/apis/downloadData.test.ts @@ -108,6 +108,7 @@ describe('downloadData', () => { useAccelerateEndpoint: true, onDownloadProgress: onProgress, abortSignal: expect.any(AbortSignal), + userAgentValue: expect.any(String) }, { Bucket: bucket, diff --git a/packages/storage/__tests__/providers/s3/apis/getProperties.test.ts b/packages/storage/__tests__/providers/s3/apis/getProperties.test.ts index 946eac7c245..1fa04f63e8b 100644 --- a/packages/storage/__tests__/providers/s3/apis/getProperties.test.ts +++ b/packages/storage/__tests__/providers/s3/apis/getProperties.test.ts @@ -58,6 +58,7 @@ describe('getProperties api', () => { const config = { credentials, region: 'region', + userAgentValue: expect.any(String) }; const key = 'key'; beforeEach(() => { @@ -136,6 +137,7 @@ describe('getProperties api', () => { { credentials, region: 'region', + userAgentValue: expect.any(String) }, { Bucket: 'bucket', diff --git a/packages/storage/__tests__/providers/s3/apis/getUrl.test.ts b/packages/storage/__tests__/providers/s3/apis/getUrl.test.ts index 5fb759584e8..2064cc11a6e 100644 --- a/packages/storage/__tests__/providers/s3/apis/getUrl.test.ts +++ b/packages/storage/__tests__/providers/s3/apis/getUrl.test.ts @@ -52,6 +52,7 @@ describe('getUrl test', () => { const config = { credentials, region, + userAgentValue: expect.any(String) }; const key = 'key'; beforeEach(() => { diff --git a/packages/storage/__tests__/providers/s3/apis/list.test.ts b/packages/storage/__tests__/providers/s3/apis/list.test.ts index c1bc773127d..461d8612e5f 100644 --- a/packages/storage/__tests__/providers/s3/apis/list.test.ts +++ b/packages/storage/__tests__/providers/s3/apis/list.test.ts @@ -40,6 +40,7 @@ const credentials: Credentials = { const listObjectClientConfig = { credentials, region, + userAgentValue: expect.any(String) }; const listObjectClientBaseResultItem = { ETag: eTag, diff --git a/packages/storage/__tests__/providers/s3/apis/remove.test.ts b/packages/storage/__tests__/providers/s3/apis/remove.test.ts index f5dcf3813d6..8ac7629e803 100644 --- a/packages/storage/__tests__/providers/s3/apis/remove.test.ts +++ b/packages/storage/__tests__/providers/s3/apis/remove.test.ts @@ -32,6 +32,7 @@ const credentials: Credentials = { const deleteObjectClientConfig = { credentials, region, + userAgentValue: expect.any(String) }; describe('remove API', () => { diff --git a/packages/storage/__tests__/providers/s3/apis/uploadData/putObjectJob.test.ts b/packages/storage/__tests__/providers/s3/apis/uploadData/putObjectJob.test.ts index 80c97bdb405..b2b9e0096a3 100644 --- a/packages/storage/__tests__/providers/s3/apis/uploadData/putObjectJob.test.ts +++ b/packages/storage/__tests__/providers/s3/apis/uploadData/putObjectJob.test.ts @@ -95,6 +95,7 @@ describe('putObjectJob', () => { abortSignal: abortController.signal, onUploadProgress: expect.any(Function), useAccelerateEndpoint: true, + userAgentValue: expect.any(String) }, { Bucket: 'bucket', diff --git a/packages/storage/src/providers/s3/apis/downloadData.ts b/packages/storage/src/providers/s3/apis/downloadData.ts index 494667c8269..2e2caf4a447 100644 --- a/packages/storage/src/providers/s3/apis/downloadData.ts +++ b/packages/storage/src/providers/s3/apis/downloadData.ts @@ -2,12 +2,14 @@ // SPDX-License-Identifier: Apache-2.0 import { Amplify } from '@aws-amplify/core'; +import { StorageAction } from '@aws-amplify/core/internals/utils'; import { DownloadDataInput, DownloadDataOutput, S3Exception } from '../types'; import { resolveS3ConfigAndInput } from '../utils/resolveS3ConfigAndInput'; import { StorageValidationErrorCode } from '../../../errors/types/validation'; import { createDownloadTask } from '../utils'; import { getObject } from '../utils/client'; +import { getStorageUserAgentValue } from '../utils/userAgent'; /** * Download S3 object data to memory @@ -77,6 +79,7 @@ const downloadDataJob = ...s3Config, abortSignal, onDownloadProgress: downloadDataOptions?.onProgress, + userAgentValue: getStorageUserAgentValue(StorageAction.DownloadData) }, { Bucket: bucket, diff --git a/packages/storage/src/providers/s3/apis/internal/copy.ts b/packages/storage/src/providers/s3/apis/internal/copy.ts index 0120a49e97b..3644f0b96dc 100644 --- a/packages/storage/src/providers/s3/apis/internal/copy.ts +++ b/packages/storage/src/providers/s3/apis/internal/copy.ts @@ -2,11 +2,13 @@ // SPDX-License-Identifier: Apache-2.0 import { AmplifyClassV6 } from '@aws-amplify/core'; +import { StorageAction } from '@aws-amplify/core/internals/utils'; import { CopyInput, CopyOutput } from '../../types'; import { resolveS3ConfigAndInput } from '../../utils'; import { StorageValidationErrorCode } from '../../../../errors/types/validation'; import { assertValidationError } from '../../../../errors/utils/assertValidationError'; import { copyObject } from '../../utils/client'; +import { getStorageUserAgentValue } from '../../utils/userAgent'; export const copy = async ( amplify: AmplifyClassV6, @@ -35,12 +37,18 @@ export const copy = async ( // TODO(ashwinkumar6) V6-logger: warn `You may copy files from another user if the source level is "protected", currently it's ${srcLevel}` // TODO(ashwinkumar6) V6-logger: debug `copying ${finalSrcKey} to ${finalDestKey}` - await copyObject(s3Config, { - Bucket: bucket, - CopySource: `${bucket}/${sourceKeyPrefix}${sourceKey}`, - Key: `${destinationKeyPrefix}${destinationKey}`, - MetadataDirective: 'COPY', // Copies over metadata like contentType as well - }); + await copyObject( + { + ...s3Config, + userAgentValue: getStorageUserAgentValue(StorageAction.Copy) + }, + { + Bucket: bucket, + CopySource: `${bucket}/${sourceKeyPrefix}${sourceKey}`, + Key: `${destinationKeyPrefix}${destinationKey}`, + MetadataDirective: 'COPY', // Copies over metadata like contentType as well + } + ); return { key: destinationKey, diff --git a/packages/storage/src/providers/s3/apis/internal/getProperties.ts b/packages/storage/src/providers/s3/apis/internal/getProperties.ts index ce8c4d3168e..e2807ac35fd 100644 --- a/packages/storage/src/providers/s3/apis/internal/getProperties.ts +++ b/packages/storage/src/providers/s3/apis/internal/getProperties.ts @@ -2,13 +2,16 @@ // SPDX-License-Identifier: Apache-2.0 import { AmplifyClassV6 } from '@aws-amplify/core'; +import { StorageAction } from '@aws-amplify/core/internals/utils'; import { GetPropertiesInput, GetPropertiesOutput } from '../../types'; import { resolveS3ConfigAndInput } from '../../utils'; import { headObject } from '../../utils/client'; +import { getStorageUserAgentValue } from '../../utils/userAgent'; export const getProperties = async function ( amplify: AmplifyClassV6, - input: GetPropertiesInput + input: GetPropertiesInput, + action?: StorageAction ): Promise { const { key, options } = input; const { s3Config, bucket, keyPrefix } = await resolveS3ConfigAndInput( @@ -16,10 +19,16 @@ export const getProperties = async function ( options ); - const response = await headObject(s3Config, { - Bucket: bucket, - Key: `${keyPrefix}${key}`, - }); + const response = await headObject( + { + ...s3Config, + userAgentValue: getStorageUserAgentValue(action ?? StorageAction.GetProperties) + }, + { + Bucket: bucket, + Key: `${keyPrefix}${key}`, + } + ); return { key, contentType: response.ContentType, diff --git a/packages/storage/src/providers/s3/apis/internal/getUrl.ts b/packages/storage/src/providers/s3/apis/internal/getUrl.ts index a0562c7c479..47c78e5135a 100644 --- a/packages/storage/src/providers/s3/apis/internal/getUrl.ts +++ b/packages/storage/src/providers/s3/apis/internal/getUrl.ts @@ -12,6 +12,7 @@ import { DEFAULT_PRESIGN_EXPIRATION, MAX_URL_EXPIRATION, } from '../../utils/constants'; +import { StorageAction } from '@aws-amplify/core/lib-esm/libraryUtils'; export const getUrl = async function ( amplify: AmplifyClassV6, @@ -20,7 +21,7 @@ export const getUrl = async function ( const { key, options } = input; if (options?.validateObjectExistence) { - await getProperties(amplify, { key, options }); + await getProperties(amplify, { key, options }, StorageAction.GetUrl); } const { s3Config, keyPrefix, bucket } = await resolveS3ConfigAndInput( diff --git a/packages/storage/src/providers/s3/apis/internal/list.ts b/packages/storage/src/providers/s3/apis/internal/list.ts index f5321198262..8118254147d 100644 --- a/packages/storage/src/providers/s3/apis/internal/list.ts +++ b/packages/storage/src/providers/s3/apis/internal/list.ts @@ -2,6 +2,7 @@ // SPDX-License-Identifier: Apache-2.0 import { AmplifyClassV6 } from '@aws-amplify/core'; +import { StorageAction } from '@aws-amplify/core/internals/utils'; import { ListAllInput, ListPaginateInput, @@ -16,6 +17,7 @@ import { ListObjectsV2Input, ListObjectsV2Output, } from '../../utils/client'; +import { getStorageUserAgentValue } from '../../utils/userAgent'; const MAX_PAGE_SIZE = 1000; @@ -85,7 +87,10 @@ const _list = async ({ } const response: ListObjectsV2Output = await listObjectsV2( - s3Config, + { + ...s3Config, + userAgentValue: getStorageUserAgentValue(StorageAction.List) + }, listParamsClone ); diff --git a/packages/storage/src/providers/s3/apis/internal/remove.ts b/packages/storage/src/providers/s3/apis/internal/remove.ts index 93fc9a6bead..57ee214387f 100644 --- a/packages/storage/src/providers/s3/apis/internal/remove.ts +++ b/packages/storage/src/providers/s3/apis/internal/remove.ts @@ -2,9 +2,11 @@ // SPDX-License-Identifier: Apache-2.0 import { AmplifyClassV6 } from '@aws-amplify/core'; +import { StorageAction } from '@aws-amplify/core/internals/utils'; import { RemoveInput, RemoveOutput } from '../../types'; import { resolveS3ConfigAndInput } from '../../utils'; import { deleteObject } from '../../utils/client'; +import { getStorageUserAgentValue } from '../../utils/userAgent'; export const remove = async ( amplify: AmplifyClassV6, @@ -17,10 +19,16 @@ export const remove = async ( ); // TODO(ashwinkumar6) V6-logger: debug `remove ${key} from ${finalKey}` - await deleteObject(s3Config, { - Bucket: bucket, - Key: `${keyPrefix}${key}`, - }); + await deleteObject( + { + ...s3Config, + userAgentValue: getStorageUserAgentValue(StorageAction.Remove) + }, + { + Bucket: bucket, + Key: `${keyPrefix}${key}` + } + ); return { key, }; diff --git a/packages/storage/src/providers/s3/apis/uploadData/multipart/uploadHandlers.ts b/packages/storage/src/providers/s3/apis/uploadData/multipart/uploadHandlers.ts index 62f01d1de1e..6cf6d13fb4f 100644 --- a/packages/storage/src/providers/s3/apis/uploadData/multipart/uploadHandlers.ts +++ b/packages/storage/src/providers/s3/apis/uploadData/multipart/uploadHandlers.ts @@ -2,6 +2,7 @@ // SPDX-License-Identifier: Apache-2.0 import { Amplify, StorageAccessLevel } from '@aws-amplify/core'; +import { StorageAction } from '@aws-amplify/core/internals/utils'; import { getDataChunker } from './getDataChunker'; import { UploadDataInput } from '../../../types'; @@ -24,6 +25,7 @@ import { completeMultipartUpload, headObject, } from '../../../utils/client'; +import { getStorageUserAgentValue } from '../../../utils/userAgent'; /** * Create closure hiding the multipart upload implementation details and expose the upload job and control functions( @@ -148,6 +150,7 @@ export const getMultipartUploadHandlers = ( { ...s3Config, abortSignal: abortController.signal, + userAgentValue: getStorageUserAgentValue(StorageAction.UploadData) }, { Bucket: bucket, diff --git a/packages/storage/src/providers/s3/apis/uploadData/putObjectJob.ts b/packages/storage/src/providers/s3/apis/uploadData/putObjectJob.ts index 50922b1334b..adf463565e1 100644 --- a/packages/storage/src/providers/s3/apis/uploadData/putObjectJob.ts +++ b/packages/storage/src/providers/s3/apis/uploadData/putObjectJob.ts @@ -2,11 +2,13 @@ // SPDX-License-Identifier: Apache-2.0 import { Amplify } from '@aws-amplify/core'; +import { StorageAction } from '@aws-amplify/core/internals/utils'; import { UploadDataInput } from '../../types'; import { calculateContentMd5, resolveS3ConfigAndInput } from '../../utils'; import { Item as S3Item } from '../../types/outputs'; import { putObject } from '../../utils/client'; +import { getStorageUserAgentValue } from '../../utils/userAgent'; /** * Get a function the returns a promise to call putObject API to S3. @@ -38,6 +40,7 @@ export const putObjectJob = ...s3Config, abortSignal, onUploadProgress: onProgress, + userAgentValue: getStorageUserAgentValue(StorageAction.UploadData) }, { Bucket: bucket, diff --git a/packages/storage/src/providers/s3/utils/client/index.native.ts b/packages/storage/src/providers/s3/utils/client/index.native.ts deleted file mode 100644 index 8dcb21848e4..00000000000 --- a/packages/storage/src/providers/s3/utils/client/index.native.ts +++ /dev/null @@ -1,44 +0,0 @@ -// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. -// SPDX-License-Identifier: Apache-2.0 -import { loadUrlPolyfill } from '@aws-amplify/react-native'; - -loadUrlPolyfill(); - -export { SERVICE_NAME } from './base'; -export { - getObject, - GetObjectInput, - GetObjectOutput, - getPresignedGetObjectUrl, -} from './getObject'; -export { - listObjectsV2, - ListObjectsV2Input, - ListObjectsV2Output, -} from './listObjectsV2'; -export { putObject, PutObjectInput, PutObjectOutput } from './putObject'; -export { - createMultipartUpload, - CreateMultipartUploadInput, - CreateMultipartUploadOutput, -} from './createMultipartUpload'; -export { uploadPart, UploadPartInput, UploadPartOutput } from './uploadPart'; -export { - completeMultipartUpload, - CompleteMultipartUploadInput, - CompleteMultipartUploadOutput, -} from './completeMultipartUpload'; -export { listParts, ListPartsInput, ListPartsOutput } from './listParts'; -export { - abortMultipartUpload, - AbortMultipartUploadInput, - AbortMultipartUploadOutput, -} from './abortMultipartUpload'; -export { copyObject, CopyObjectInput, CopyObjectOutput } from './copyObject'; -export { headObject, HeadObjectInput, HeadObjectOutput } from './headObject'; -export { - deleteObject, - DeleteObjectInput, - DeleteObjectOutput, -} from './deleteObject'; -export { CompletedPart, Part, _Object } from './types'; diff --git a/packages/storage/src/providers/s3/utils/client/index.ts b/packages/storage/src/providers/s3/utils/client/index.ts index d32be9658ae..ee3f022a3a2 100644 --- a/packages/storage/src/providers/s3/utils/client/index.ts +++ b/packages/storage/src/providers/s3/utils/client/index.ts @@ -1,6 +1,8 @@ // Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. // SPDX-License-Identifier: Apache-2.0 +import './polyfills'; + export { SERVICE_NAME } from './base'; export { getObject, diff --git a/packages/storage/src/providers/s3/utils/client/polyfills/index.native.ts b/packages/storage/src/providers/s3/utils/client/polyfills/index.native.ts new file mode 100644 index 00000000000..065c0fecb15 --- /dev/null +++ b/packages/storage/src/providers/s3/utils/client/polyfills/index.native.ts @@ -0,0 +1,5 @@ +// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. +// SPDX-License-Identifier: Apache-2.0 +import { loadUrlPolyfill } from '@aws-amplify/react-native'; + +loadUrlPolyfill(); diff --git a/packages/storage/src/providers/s3/utils/client/polyfills/index.ts b/packages/storage/src/providers/s3/utils/client/polyfills/index.ts new file mode 100644 index 00000000000..f0daa8d350d --- /dev/null +++ b/packages/storage/src/providers/s3/utils/client/polyfills/index.ts @@ -0,0 +1,4 @@ +// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. +// SPDX-License-Identifier: Apache-2.0 + +// noop - polyfills not required on platform diff --git a/packages/storage/src/providers/s3/utils/userAgent.ts b/packages/storage/src/providers/s3/utils/userAgent.ts new file mode 100644 index 00000000000..1779ddfd0c5 --- /dev/null +++ b/packages/storage/src/providers/s3/utils/userAgent.ts @@ -0,0 +1,14 @@ +// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. +// SPDX-License-Identifier: Apache-2.0 +import { + StorageAction, + Category, + getAmplifyUserAgent, +} from '@aws-amplify/core/internals/utils'; + +export function getStorageUserAgentValue(action: StorageAction) { + return getAmplifyUserAgent({ + category: Category.Storage, + action, + }); +} diff --git a/scripts/dts-bundler/dts-bundler.config.js b/scripts/dts-bundler/dts-bundler.config.js index 31d9e9ad288..5d741bfb877 100644 --- a/scripts/dts-bundler/dts-bundler.config.js +++ b/scripts/dts-bundler/dts-bundler.config.js @@ -23,7 +23,7 @@ const corePackageSrcClientsPath = join( 'packages', 'core', 'src', - 'AwsClients' + 'awsClients' ); const storagePackageSrcClientsPath = join(