Welcome to Gptmap, a startup project crafted using Kotlin and Jetpack Compose.
This project will guide you through creating a comprehensive Android application using a modern toolkit, highlighting the integration of AI technologies and illustrating the real-world applications of these advanced technologies, providing valuable insights and best practices.
Go to the Releases to download the latest APK.
-
Kotlin: The primary language for application development, emphasizing safety, simplicity, and interoperability.
-
Jetpack Compose: Used for modern UI development, leveraging custom composables and animations for a dynamic and responsive design.
-
Jetpack Libraries:
- ViewModel: Centralizes UI-related data management, making it resilient to configuration changes.
- SavedStateHandle: Enhances state management by preserving UI data across system-initiated process terminations.
- Proto DataStore: A modern, type-safe data storage solution that leverages Kotlin coroutines and Flow for storing structured data asynchronously, securely, and consistently. Proto DataStore uses protocol buffers to serialize data, enabling more complex data storage scenarios than traditional key-value stores.
-
Ktor: Enables server and client-side HTTP communications, seamlessly integrating with various third-party APIs for extended functionality.
-
Database and Storage Solutions:
- MongoDB Realm: Provides a robust local database and synchronization solutions, enabling efficient offline data access and seamless cloud integration.
- Firebase Firestore and Storage: Facilitates real-time data synchronization and scalable cloud storage, ensuring smooth data operations and media management.
-
Asynchronous Programming:
- Coroutines and Flow: Manage asynchronous tasks and streamline data stream processing, guaranteeing a smooth user experience.
-
Authentication Systems:
- Firebase Auth: Offers support for diverse authentication mechanisms, including email & password and Gmail, ensuring secure user access and streamlined account management.
- MongoDB Realm JWT Auth: Implements JSON Web Token (JWT) authentication to ensure secure and scalable user authentication within the MongoDB Realm ecosystem.
-
Dependency Injection Frameworks:
-
APIs & Services Integration:
- Google Maps API: Enhances app functionality with comprehensive mapping and location services.
- Third-party APIs (Gemini, Unsplash): Enrich the application with a diverse range of services, including cryptocurrency data, AI-generated content, and high-quality images.
-
Image Loading and Animation Libraries:
- Coil: Efficiently loads and displays images, optimizing memory and network usage.
- Lottie: Implements complex animations sourced from JSON files, enriching the UI with engaging visuals.
-
Material Design 3: Adopts the latest Material Design guidelines for a cohesive, dynamic user interface and enhanced user experience, leveraging the newest components, theming, and layout principles.
-
Kotlin Symbol Processing (KSP): Streamlines code generation and processing, enhancing development efficiency.
-
WorkManager: Manages background tasks and asynchronous operations, ensuring reliable execution under various system conditions.
-
Architectural Patterns:
- MVVM and MVI: Adopt modern architectural patterns for a clean separation of concerns, facilitating the development of testable and maintainable code.
-
Core Android Features:
- Utilizes Services, Broadcast Receivers, and Intents for robust background processing and inter-component communication.
-
Project Organization:
- Implements a multi-module structure with a version catalogue, promoting modular development and easier dependency management.
-
Networking:
- Retrofit: Simplifies REST API communication, enhancing data exchange and integration.
-
Testing Suite:
-
Code Quality Tools:
-
Performance Optimization:
- Baseline Profiles: Enhances app startup and runtime performance by pre-compiling essential methods.
- Macrobenchmark: Optimizes critical user journeys, addressing performance bottlenecks for a smoother experience.
-
Continuous Integration and Deployment (CI/CD):
- GitHub Actions: Automates testing, building, and deployment, streamlining development cycles.
- Docker: Ensures consistent environments across development, testing, and deployment phases, integral to our CI/CD pipelines.
-
GCP Secret Manager: Protects sensitive configuration secrets.
This project is designed following the principles of Clean Architecture, utilizing a multi-modular approach. It includes several layers, including the UI Layer, Domain Layer, Data Layer, and the backend, to ensure a solid separation of concerns and enhance maintainability.
For the backend, Ktor for server-side logic, MongoDB for database management (Realm Sync and Auth for synchronization and authentication), Firebase for authentication, storage, and real-time database capabilities (Auth, Storage, Firestore), and GCP's Secret Manager for secure management of secrets and API keys.
Check out the resources for the full list.
appFlow.mp4
Getting started with this project involves several key steps to ensure everything is set up correctly. Follow this guide to configure your development environment and integrate all necessary services:
- Android Studio Iguana: This project is optimized for Android Studio Iguana. While it might work on lower versions, Gradle plugin 8.2.2 is required for the best experience. If you're using an older version, consider updating to avoid compatibility issues.
- Setting up
local.properties
: This file contains essential environment variables. You won't need an OpenAI key as it will be deprecated. Fill in the necessary API keys and URLs except for the OpenAI key:
sdk.dir=<path_to_your_android_sdk>
MAPS_API_KEY=<your_google_maps_api_key>
OPENAI_API_KEY= (will be deprecated, no need to fill this)
PALM_API_KEY=<your_gemini_api_key>
UNSPLASH_BASE_URL=<unsplash_api_base_url>
Ensure you replace placeholder text with actual values relevant to your development environment.
- Remove Keystore Related Configurations: For development purposes, remove or comment out any keystore configurations in your Gradle build files. This simplifies the build process for initial setup and testing.
- Setup Docker and GCP Secret Manager: Docker is used for containerization, ensuring a consistent environment for development and deployment. GCP Secret Manager stores and manages access to your application's secrets. Skipping this step means you won't be able to use AI features on images, though you can still proceed with other functionalities. For Docker, install Docker and follow the setup instructions for your OS. For GCP Secret Manager, set up a GCP account, create a new project, and follow the instructions to store your secrets.
- Firebase Setup: To integrate Firebase, create a new project in the Firebase console, register your app, and download the
google-services.json
file. Place this file in your app'sapp
directory. This step is crucial for utilizing Firebase Auth, Firestore, and Storage. - MongoDB Atlas Setup: Sign up or log in to MongoDB Atlas, create a new cluster, and connect your application using the provided connection string. Ensure you've configured the network access and database user for your cluster.
- GCP Account Requirement: A Google Cloud Platform (GCP) account is necessary for utilizing Google Maps API and GCP Secret Manager. If you don't already have an account, sign up at GCP's website and set up billing to access these services.