Jeremy
Jeremy

Reputation: 675

Is it possible to use the amplify framework without using the cli?

The amplify FAQ says specifically you can. But the github links now just redirect you to the main amplify page and the instructions only talk about using the cli.

Q: Can I use the Amplify Framework libraries even if I do not use the CLI? Yes. The libraries can be used to access backend resources that were created without the Amplify CLI.

Upvotes: 19

Views: 12880

Answers (5)

Nick K9
Nick K9

Reputation: 4718

Yes, this is possible. As pointed out by Mohammed, this is covered in the documentation, although they definitely aren't in a hurry to inform you that this option is available. Anyway, the setup for a React app is:

npm install aws-amplify @aws-amplify/ui-react

And then all you have to do is:

import Amplify from '@aws-amplify/core';
import { withAuthenticator } from '@aws-amplify/ui-react';

Amplify.configure({
  Auth: {
    region: 'XX-XXXX-X',
    userPoolId: 'XX-XXXX-X_abcd1234',
    userPoolWebClientId: 'a1b2c3d4e5f6g7h8i9j0k1l2m3',
    mandatorySignIn: true,
  }
});

export default withAuthenticator(function Home() {
  return (<h1>Protected Content</h1>)
})

PLEASE NOTE: as of February 2022, the Amplify UI components for auth recently changed their API substantially. You'll find lots of old posts and documentation about AmplifyAuthenticator and its child components, like this page for example. If you try to use these examples with the current version of Amplify UI, it will fail without explaining why! You need to be using the Authenticator component. Instead, use the examples in the Amplify UI docs.

Upvotes: 9

Mohammed Noureldin
Mohammed Noureldin

Reputation: 16936

Well this should be pretty much no problem. It is mentioned that you are able to use Amplify library without the CLI in the official docs:

If you are not using the Amplify CLI or need to override these settings, this documentation shows the available configuration properties for each category.

So from that you see that this is ok.

In the following link you may find the configuration (that normally gets generated) for the different services:

https://docs.amplify.aws/lib/client-configuration/configuring-amplify-categories/q/platform/js#general-configuration

Upvotes: 1

Jeremy
Jeremy

Reputation: 675

I have learned that you are able to use the amplify libraries without the Amplify CLI.

To do this you simply install the amplify library as normal.

In react web:

npm install --save aws-amplify
npm install --save aws-amplify-react

After that you need to manually configure any features you're going to use with Amplify.configure();. You can find the manual configuration in the Amplify documentation for each library you plan to use.

Here is an example using Cognito:

https://aws-amplify.github.io/docs/js/authentication#manual-setup

Amplify.configure({
    "aws_project_region": process.env.REACT_APP_REGION,
    "aws_cognito_identity_pool_id": process.env.REACT_APP_IDENTITY_POOL_ID,
    "aws_cognito_region": process.env.REACT_APP_REGION,
    "aws_user_pools_id": process.env.REACT_APP_USER_POOL_ID,
    "aws_user_pools_web_client_id": process.env.REACT_APP_CLIENT_ID,
    "oauth": {},
    Auth: {
        // REQUIRED - Amazon Cognito Identity Pool ID
        identityPoolId: process.env.REACT_APP_IDENTITY_POOL_ID,
        // REQUIRED - Amazon Cognito Region
        region: process.env.REACT_APP_REGION, 
        // OPTIONAL - Amazon Cognito User Pool ID
        userPoolId: process.env.REACT_APP_USER_POOL_ID, 
        // OPTIONAL - Amazon Cognito Web Client ID (26-char alphanumeric string)
        userPoolWebClientId: process.env.REACT_APP_CLIENT_ID,
    }
});

You do not have to use the amplify push for deployments. You can manually deploy and configure any features you're working with.

I find this approach gives you full control over using the Amplify library without the overhead of the CLI and deployment process.

Upvotes: 32

Erez
Erez

Reputation: 1750

I'm using the react amplify libraries with Auth, AppSync and Storage that were manually setup, so it is doable.

For setting up S3 you can follow the guide here. For AppSync setup I'm using this plugin.

Upvotes: 1

J. Hesters
J. Hesters

Reputation: 14816

You can, if you know what you are doing. The devil is in the details. The docs say:

Can I use the Amplify Framework libraries even if I do not use the CLI? Yes.

Notice how it explicitly says framework libraries. This means you can't generate resources manually. (Technically, you could write the templates yourself, but AFAIK you would still need the CLI's amplify push command to affect the cloud.) But you can use the framework components.

This means, you can for example manually configure AWS Amplify to use a custom GraphQL endpoint and then use the helpers, components and methods exposed by the framework (e.g. graphqlOperation) to make your requests.

Upvotes: 2

Related Questions