Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/AmreshSinha/OAuth-Tester-Appwrite

Made to test new OAuth Implementation in Appwrite
https://github.com/AmreshSinha/OAuth-Tester-Appwrite

appwrite appwrite-auth

Last synced: 2 months ago
JSON representation

Made to test new OAuth Implementation in Appwrite

Awesome Lists containing this project

README

        

🔖 Appwrite OAuth Tester With React*

A OAuth Tester app built with Appwrite and React to test OAuth Providers in Appwrite. Made to test new providers easily.

## 🎬 Getting Started

### 🤘 Installation
Follow this simple [Installation Guide](https://appwrite.io/docs/installation) to get Appwrite up and running in no time. You can either deploy Appwrite on your local machine or, on any cloud provider of your choice.

> Note: If you setup Appwrite on your local machine, you will need to create a public IP so that your hosted frontend can access it.

We need to make a few configuration changes to your Appwrite server.

1. Clone and Create a ```.env``` in root of this project with the following vars:
* REACT_APP_ENDPOINT - Your Appwrite endpoint
* REACT_APP_PROJECT - Your Appwrite project ID
* REACT_APP_LOGINURL - Login Page URL of OAuth Tester (e.g. http://localhost:3000/login)

2. Add a new Web App in Appwrite and enter the endpoint of your website (`localhost, .vercel.app etc`)
![Create Web App](https://user-images.githubusercontent.com/20852629/113019434-3c27c900-919f-11eb-997c-1da5a8303ceb.png)

4. Open ```Login.js``` in the same directory and add this after Line 7:
* Add a button after Line 18 (You can take help from examples already written there) like:
```
{loginWith(`provider-name`)}}
>
Your-Provider-Name

```
* Remember to replace ```provider-name``` with a valid Provider (which is available in appwrite) in small casings (e.g. ```discord```)
5. Run Dev Server ```npm run start```

### 🚀 Deploy the Front End
**Fork it and make necessary changes first**

You have two options to deploy the front-end and we will cover both of them here. In either case, you will need to fill in these environment variables that help your frontend connect to Appwrite.

* REACT_APP_ENDPOINT - Your Appwrite endpoint
* REACT_APP_PROJECT - Your Appwrite project ID
* REACT_APP_LOGINURL - Login Page URL of OAuth Tester (e.g. http://localhost:3000/login)

### **Deploy to a Static Hosting Provider**

Use the following buttons to deploy to your favourite hosting provider in one click! We support Vercel, Netlify and DigitalOcean. You will need to enter the environment variables above when prompted.

[![Deploy with Vercel](https://vercel.com/button)](https://vercel.com/new/git/external?repository-url=https%3A%2F%2Fgithub.com%2FAmreshSinha%2FOAuth-Tester-Appwrite&env=REACT_APP_PROJECT,REACT_APP_ENDPOINT&envDescription=Your%20Appwrite%20Endpoint%2C%20Project%20ID%20)

[![Deploy to Netlify](https://www.netlify.com/img/deploy/button.svg)](https://app.netlify.com/start/deploy?repository=https://github.com/AmreshSinha/OAuth-Tester-Appwrite)

[![Deploy to DO](https://www.deploytodo.com/do-btn-blue.svg)](https://cloud.digitalocean.com/apps/new?repo=https://github.com/AmreshSinha/OAuth-Tester-Appwrite/tree/master)

### **Run locally**

* Follow these instructions to run the demo app locally

```sh
$ git clone https://github.com/appwrite/todo-with-react
$ cd todo-with-react
```

* Make .env file by following 1st step in Installation and fill in the required vars

* Now run the following commands and you should be good to go 💪🏼

```
$ npm install
$ npm start
```

## 📸 Screenshots
![image](https://user-images.githubusercontent.com/35039730/136904800-b66b8e31-3350-41ef-89e5-d66593dc78d2.png)
![image](https://user-images.githubusercontent.com/35039730/136904613-c7a7c360-01f0-4b97-98fb-494ac52c5b79.png)

## 📝 Note
All Styling is copied from React Todo Repository of Appwrite. (as I am too lazy :/)

## 🤕 Support

If you get stuck anywhere, hop onto appwrite's [support channels in discord](https://appwrite.io/discord) to seek help 🤝