Skip to content

consumerfinance/ogwallet

OGWallet

Latest stable release version Github downloads GitHub repo stars Project's License

Get it on Google Play Get it on F-Droid

This is a Kotlin Multiplatform project targeting Android, iOS, Web, Desktop (JVM).

πŸ†• Credit Card Data System

OGWallet now includes a complete system for crowdsourcing and displaying credit card offers and benefits!

Features

  • πŸ“ Microsoft Forms Integration - Collect offers from the community
  • 🐍 Python Processing Server - Validate and process submissions
  • πŸ“¦ Git-based Data Storage - Version-controlled JSON data
  • 🎨 Beautiful UI - Display offers with gradients and emojis
  • πŸ”„ Automated Updates - GitHub Actions for scheduled processing

Quick Start

  1. Set up sample data:

    cd data-server
    python3 test_setup.py
  2. Run the app:

    ./gradlew :composeApp:run
  3. View offers: Navigate to the "Offers & Rewards" screen to see credit card offers!

Documentation


πŸ“± SMS Scanning Feature (Android)

OGWallet can automatically scan your SMS messages and import credit card transactions!

Features

  • πŸ“¨ Automatic SMS Scanning - Scan all existing SMS messages
  • πŸ”„ Real-time Interception - Capture new transaction SMS automatically
  • 🏦 25+ Banks Supported - HDFC, ICICI, SBI, Axis, and more
  • πŸ”’ Privacy First - All processing happens locally on your device
  • πŸ“Š Progress Tracking - Real-time scan progress with statistics

Quick Start

  1. Open the app on your Android device
  2. Grant SMS permissions when prompted
  3. Navigate to the Import tab (πŸ“§)
  4. Tap "Import from SMS"
  5. Select time range (90 days recommended)
  6. Start scan and wait for completion
  7. View your transactions in the Home tab

What Gets Imported?

βœ… Transaction amount βœ… Merchant name βœ… Card last 4 digits βœ… Transaction date & time

❌ Full card numbers (never stored) ❌ CVV codes (never stored) ❌ PINs or OTPs (never stored)

Documentation


  • /composeApp is for code that will be shared across your Compose Multiplatform applications. It contains several subfolders:

    • commonMain is for code that’s common for all targets.
    • Other folders are for Kotlin code that will be compiled for only the platform indicated in the folder name. For example, if you want to use Apple’s CoreCrypto for the iOS part of your Kotlin app, the iosMain folder would be the right place for such calls. Similarly, if you want to edit the Desktop (JVM) specific part, the jvmMain folder is the appropriate location.
  • /iosApp contains iOS applications. Even if you’re sharing your UI with Compose Multiplatform, you need this entry point for your iOS app. This is also where you should add SwiftUI code for your project.

Build and Run Android Application

To build and run the development version of the Android app, use the run configuration from the run widget in your IDE’s toolbar or build it directly from the terminal:

  • on macOS/Linux
    ./gradlew :composeApp:assembleDebug
  • on Windows
    .\gradlew.bat :composeApp:assembleDebug

Build and Run Desktop (JVM) Application

To build and run the development version of the desktop app, use the run configuration from the run widget in your IDE’s toolbar or run it directly from the terminal:

  • on macOS/Linux
    ./gradlew :composeApp:run
  • on Windows
    .\gradlew.bat :composeApp:run

Build and Run Web Application

To build and run the development version of the web app, use the run configuration from the run widget in your IDE's toolbar or run it directly from the terminal:

  • for the Wasm target (faster, modern browsers):
    • on macOS/Linux
      ./gradlew :composeApp:wasmJsBrowserDevelopmentRun
    • on Windows
      .\gradlew.bat :composeApp:wasmJsBrowserDevelopmentRun
  • for the JS target (slower, supports older browsers):
    • on macOS/Linux
      ./gradlew :composeApp:jsBrowserDevelopmentRun
    • on Windows
      .\gradlew.bat :composeApp:jsBrowserDevelopmentRun

Build and Run iOS Application

To build and run the development version of the iOS app, use the run configuration from the run widget in your IDE’s toolbar or open the /iosApp directory in Xcode and run it from there.


Learn more about Kotlin Multiplatform, Compose Multiplatform, Kotlin/Wasm…

We would appreciate your feedback on Compose/Web and Kotlin/Wasm in the public Slack channel #compose-web. If you face any issues, please report them on YouTrack.