Skip to content
/ Podo Public

Non-official iOS application for top-up contactless metropolitan multi-tickets

License

Notifications You must be signed in to change notification settings

m3g0byt3/Podo

Folders and files

NameName
Last commit message
Last commit date

Latest commit

b467876 · Sep 16, 2018
Sep 16, 2018
Nov 23, 2017
Sep 16, 2018
Feb 10, 2018
Feb 10, 2018
Sep 16, 2018
Aug 31, 2018
Aug 21, 2018
Dec 3, 2017
Sep 7, 2018
Sep 7, 2018
Sep 16, 2018
Aug 31, 2018

Repository files navigation

Podo

Non-official iOS application for top-up russian contactless metropolitan multi-tickets "Podorozhnik" and "Sputnik", written in Swift. MVVM-C architecture inspired by ApplicationCoordinator example from Andrey Panov.

Using Moya for network layer, Swinject assemblies for dependency injection, RealmSwift for persistence layer and RxSwift & RxCocoa for MVVM bindings.

Project Status

Not released yet, actively under development.

Features

Top-up following types of metropolitan transport cards:

  • "Podorozhnik" multi-tickets with 19-digit number length
  • "Podorozhnik" multi-tickets with 26-digit number length
  • "Sputnik" multi-tickets with 11-digit number length

Using following payment methods for top-up:

  • Credit or debit cards
  • Cellphone balance
  • Yandex Money
  • Qiwi Wallet
  • Apple Pay

TODO

  • Payment history persistence (Realm)
  • Add more payment methods
  • Scan and recognize payment card (CardIO)
  • Scan and recognize transport card (Tesseract)
  • Show onboarding on first launch
  • "Settings" menu
  • "Contacts" menu
  • "About" menu

Requirements

  • iOS 9.3+
  • Xcode 9.0+
  • Swift 4.0+

Installation

git clone https://github.com/m3g0byt3/Podo.git\
 && cd Podo\
  && pod install\
   && open Podo.xcworkspace

Replace non-valid randomly-generated Firebase configuration files (./Podo/Supporting\ Files/GoogleService-Info-dev.plist and ./Podo/Supporting\ Files/GoogleService-Info-prod.plist) with your own valid configuration files.

Replace non-valid randomly-generated Crashlytics API key and Build secret with working ones in the api-keys file.

Contributing

  1. Fork
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create new Pull Request

That's it!

Used 3rd party libraries and frameworks

Author

m3g0byt3

License

Podo is released under an Apache 2.0 license. See LICENSE.md for more information.

About

Non-official iOS application for top-up contactless metropolitan multi-tickets

Resources

License

Stars

Watchers

Forks

Packages

No packages published