Merge pull request #1 from Radiquum/vercel

Add a vercel deployment
This commit is contained in:
Kentai Radiquum 2024-05-15 21:21:41 +05:00 committed by GitHub
commit bbca9f1bd1
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
9 changed files with 112 additions and 12 deletions

View file

@ -4,5 +4,5 @@ commitizen:
name: cz_conventional_commits name: cz_conventional_commits
tag_format: $version tag_format: $version
update_changelog_on_bump: true update_changelog_on_bump: true
version: 0.10.0 version: 0.11.0
version_scheme: semver version_scheme: semver

View file

@ -1,3 +1,16 @@
## 0.11.0 (2024-05-15)
### Feat
- **deployment**: allow deploy to vercel
### Fix
- **vercel/backend**: fix vercel backend deploy
- **vercel/backend**: fix vercel.json headers schema
- **vercel/backend**: fix missing CORS headers
- **frontend**: fix API_URL environment variable being undefined
## 0.10.0 (2024-05-13) ## 0.10.0 (2024-05-13)
### Feat ### Feat

View file

@ -2,6 +2,10 @@
AniX is an unofficial web client for the Android application Anixart. It allows you to access and manage your Anixart account from a web browser on your desktop or laptop computer. AniX is an unofficial web client for the Android application Anixart. It allows you to access and manage your Anixart account from a web browser on your desktop or laptop computer.
[Changelog](./CHANGELOG.md)
[Backend Readme](./backend/README.md)
## Screenshots ## Screenshots
**User profile page** **User profile page**
@ -89,6 +93,8 @@ To access the docker logs you can use `docker compose -f docker-compose.dev.yml
## Deployment ## Deployment
### first steps
1. clone this repository via `git clone https://github.com/Radiquum/AniX.git` 1. clone this repository via `git clone https://github.com/Radiquum/AniX.git`
2. cd into the repository folder. 2. cd into the repository folder.
3. deploy app with below instructions. 3. deploy app with below instructions.
@ -152,6 +158,27 @@ To access the docker logs you can use `docker compose -f docker-compose.dev.yml
You can find more details in the Deta Space documentation: [Deta Space Docs](https://docs.deta.space/) You can find more details in the Deta Space documentation: [Deta Space Docs](https://docs.deta.space/)
### Vercel
*note* you don't need to complete the first steps for vercel deploy
1. [Deploy the backend](./backend/README.md#vercel) and copy the production url, including the prefix
2. create a new project on vercel and set the root directory to frontend
3. set API_URL env variable to copied url
4. click deploy
#### Available environment variables
- API_URL - sets the api url to use for frontend to connect to the backend
#### One-Click Deploy
[![Deploy with Vercel](https://vercel.com/button)](https://vercel.com/new/clone?repository-url=https://github.com/Radiquum/AniX/tree/main/frontend)
*note*: this will create a new repository.
*note*: don't forget to set API_URL to backend url.
## Contributing ## Contributing
We welcome contributions to this project! If you have any bug fixes, improvements, or new features, please feel free to create a pull request. We welcome contributions to this project! If you have any bug fixes, improvements, or new features, please feel free to create a pull request.

View file

@ -0,0 +1,28 @@
# Anix Backend
This is the backend for AniX, an unofficial WEB client for the Android app Anixart.
It is using FastAPI and server as a proxy between app API and Web Client.
## Deployment
### Environment variables
- API_PREFIX - sets the api prefix
### Docker
[Refer the docker deployment from root README file](../README.md#docker-deployment)
## Vercel
1. fork the repository
2. create a new project on vercel and set the root directory to backend
3. (optionally) set API_PREFIX env variable
4. click deploy
### One-Click Deploy
[![Deploy with Vercel](https://vercel.com/button)](https://vercel.com/new/clone?repository-url=https://github.com/Radiquum/AniX/tree/main/backend)
*note*: this will create a new repository

View file

@ -1,5 +1,8 @@
import os
import uvicorn import uvicorn
from fastapi import FastAPI from fastapi import FastAPI
from fastapi.middleware.cors import CORSMiddleware
from modules import proxy from modules import proxy
from modules.pages import bookmarks from modules.pages import bookmarks
from modules.pages import favorites from modules.pages import favorites
@ -38,6 +41,9 @@ TAGS = [
PREFIX = "/v1" PREFIX = "/v1"
if os.getenv("API_PREFIX"):
PREFIX = os.getenv("API_PREFIX")
app = FastAPI( app = FastAPI(
openapi_tags=TAGS, openapi_tags=TAGS,
title="AniX API", title="AniX API",
@ -47,6 +53,14 @@ app = FastAPI(
redoc_url=None, redoc_url=None,
) )
app.add_middleware(
CORSMiddleware,
allow_origins=["*"],
allow_credentials=True,
allow_methods=["GET", "POST"],
allow_headers=["*"],
)
app.include_router(profile.router, prefix=f"{PREFIX}/profile", tags=["Profile"]) app.include_router(profile.router, prefix=f"{PREFIX}/profile", tags=["Profile"])
app.include_router(auth.router, prefix=f"{PREFIX}/auth", tags=["Profile"]) app.include_router(auth.router, prefix=f"{PREFIX}/auth", tags=["Profile"])

21
backend/vercel.json Normal file
View file

@ -0,0 +1,21 @@
{
"$schema": "https://openapi.vercel.sh/vercel.json",
"builds": [
{
"src": "main.py",
"use": "@vercel/python"
}
],
"routes": [
{
"src": "/(.*)",
"dest": "main.py",
"headers": {
"Access-Control-Allow-Credentials": "true",
"Access-Control-Allow-Origin": "*",
"Access-Control-Allow-Methods": "GET,POST",
"Access-Control-Allow-Headers": "X-CSRF-Token, X-Requested-With, Accept, Accept-Version, Content-Length, Content-MD5, Content-Type, Date, X-Api-Version"
}
}
]
}

View file

@ -1,10 +0,0 @@
This is a [Next.js](https://nextjs.org/) project bootstrapped with [`create-next-app`](https://github.com/vercel/next.js/tree/canary/packages/create-next-app).
## Learn More
To learn more about Next.js, take a look at the following resources:
- [Next.js Documentation](https://nextjs.org/docs) - learn about Next.js features and API.
- [Learn Next.js](https://nextjs.org/learn) - an interactive Next.js tutorial.
You can check out [the Next.js GitHub repository](https://github.com/vercel/next.js/) - your feedback and contributions are welcome!

View file

@ -1,4 +1,8 @@
export let API_URL = "/api/v1"; let API_URL = "/api/v1";
if (process.env.API_URL) {
API_URL = process.env.API_URL;
}
export const endpoints = { export const endpoints = {
index: { index: {

View file

@ -14,6 +14,9 @@ const nextConfig = {
}, },
], ],
}, },
env: {
API_URL: process.env.API_URL,
},
}; };
export default nextConfig; export default nextConfig;