Mobile, Web and Rest API
-
Google Docs: Access our project documentation on Google Docs. View Document)
-
pgAdmin: Manage and interact with our databases through pgAdmin. Access it here.
-
API Endpoint: Utilize our REST API by connecting to this endpoint.
-
API Documentation: For detailed information about API usage and endpoints, visit our API Documentation.
-
Web Interface (In Progress): The web interface is currently under development. (Link will be provided when available)
In our project, we use a configuration file that loads environment variables. This allows us to interact with them. The configuration file is located at:
src/web/core/configs.py
We can initialize environment variables using the EXPORT
command or by creating a .env file based on the .env.template.
export POSTGRES_HOST=jp2
To create a .env file, copy the .env.template and fill in the values:
POSTGRES_HOST=
POSTGRES_PORT=
POSTGRES_USER=
POSTGRES_PASSWORD=
POSTGRES_DB=
SECRET_KEY=
ALGORITHM=
ACCESS_TOKEN_EXPIRE_MINUTES=
MINIO_HOST_URL=
MINIO_ACCESS_KEY=
MINIO_SECRET_KEY=
MINIO_SECURE=
There are two methods to start our application:
To start the application with Uvicorn, use the following command:
uvicorn src.main:app --host 0.0.0.0 --port 80 --reload
Ensure you are in the root directory (e.g., trip-planner). Docker Compose can be used for rebuilding and launching the application. Execute the command below:
docker-compose up -d --build
To run the frontend in a developer environment, you should install the following:
For web:
- Node.js (Specify the version according to your OS)
- React Native:
npm install react-native
For Android: All the requirements mentioned for the web, and additionally:
- Android Studio
- Android SDK
- Create an Android emulator
For iOS:
- Xcode: This is the IDE for iOS development. Install the latest version from the Mac App Store. Ensure your Mac is updated to a compatible OS version as required by Xcode.
To start, run the following command:
npm start
Then, choose the desired option from the Expo menu.
If cannot find android SDK
export ANDROID_HOME=$HOME/Library/Android/sdk
export PATH=$PATH:$ANDROID_HOME/emulator
export PATH=$PATH:$ANDROID_HOME/platform-tools
If you have error with local.properties:
android/local.properties
sdk.dir = /Users/<your_name>/Library/Android/sdk