Authentication Flow
Introduction
The sparrow app essentially is expected to be used by four categories of users.
- Indie Developers
- Small teams (students + early stage startups)
- Mid sized companies
- Enterprises
Each of the user types would have separate expectation from Sparrow in terms of deployment mode, flexibility requirements and budgeting constraints.
Sparrow can be either used direction by signing up on Sparrowapp.dev or in certain cases can be self hosted for more flexibility and customization.
Here is the current expectation on how flow should work like.

Auth Flow of the Application in detail
Sparrow doesn't have a built-in login flow in the same way as a web application would. However, you can simulate a login flow in Sparrow using various authentication methods like Basic Auth, OAuth 2.0, API keys, etc. Here's a general outline of how you might simulate a login flow in Sparrow using OAuth 2.0:
- 
SignUp/SignIn traditional way: You can signup via traditional register flow which will be on the web application of sparrow (redirected from desktop app on signIn/signUp button click). User once registered successfully, will be redirected back to sparrow app after login. 
- 
Set up SignUp/SignIn OAuth 2.0 in Sparrow: You can login via different OAuth platforms like google/github. For this you have to click on the login button on the app that will redirect you to the Web Application login of Sparrow. 
- 
Get Authorization Code: Send a request to the authorization URL using Sparrow's built-in authentication helpers. This will typically redirect you to a login page where you can authenticate and authorize the application. 
- 
Exchange Authorization Code for Access Token: After successful login, Sparrow will automatically handle the exchange of the authorization code for an access token by sending a request to the token URL with the appropriate parameters. 
- 
Use Access Token: Once you receive the access token, you can use it in the Authorization header of your API requests to access protected resources. 
- 
Handle Token Expiry and Refresh: If the access token expires, you may need to manually refresh it using the refresh token if provided, or repeat steps 2-4 to obtain a new access token. 
This is a basic overview, and the exact steps may vary depending on the specific authentication method you're using and the configuration of your authentication server.
Step by step flow
Starting from the desktop application, we will have login button for inititaitng the login process.

Sparrow app will redirect you to the web application which will have the complete login/signup flow and Google authentication flow as well.

Traditional Approach
- 
Once the user goes to the web application, he can sign up with the details required like name, email, password etc. 
- 
After completion of the signup process, you can login to the same web application and after successful authentication, it will redirect to the desktop app back. Here you will get directly logged in to the application and you can start using sparrow. 

Oauth Approach
- 
Another way of signing in is via Google authentication or GitHub authentication. 
- 
Once you are redirected to login web application of sparrow, you can click on the Google button. 
- 
The moment you click the Google button, you will be redirected to your Google account which will ask for authenticating sparrow to fetch certain details which are mandatory for login to the sparrow app. 
- 
Once you approve, the web app will get the authentication token and will be passed onto the sparrow app, and you will be notified to open sparrow app or if already allowed will be redirected to the sparrow app and can start using the sparrow app.