This deliberately vulnerable application (DVA) is exam material used in the ‘Development security in iOS' blue level course by Zsombor Kovács (huobb0). The application has some serious security issues while providing ‘life like’ functionality (of a conceptual banking app).
Note, that the main purpose with this app is code review, so building and installation is possibly not the major concern in using it as a learning and practicing material.
- git clone (the 'main' branch is sufficient for the purpose)
pod install
- Open the vulnabankIOs.xcworkspace in Xcode
- Swift
- MVVM app architecture
- Sqlite database implementation
- Encryption CocoaPod libraries SwiftRSA and CryptoSwift
- Dependency injection with Swinject CocoaPod.
- XML serialization with XMLCoder CocoaPod
- iOS 12.0 and later
- Xcode 10 and later
- Apple Silicon compatible
Each of the ViewControllers has a ViewModel class which provides data and logic for the ViewController. The ViewModels use DynamicValue type which provides observable listeners for events to the ViewControllers
- NavigationViewController: manages the application's ViewControllers
- RegistrationViewController: shows the registration form modally
- LoginViewController: shows the login form modally
- TransactionsViewController: shows the transactions list with the NavigationBar
- NewTransactionsViewController: shows the new transaction form modally
- DatabaseDaoProtocol: SQLite database access
- AuthServiceProtocol: Authentication service
- BackendServiceProtocol: Network layer for sending transaction
- TransactionRepositoryProtocol: Repository for the transactions
- DeepLink: provides URL Scheme from outside of the application
- Logger: Custom file logger
- CryptoUtils: RSA and AES encoding, decoding
-
Registration and first run
- Install and run VulnaBank application
- Type correct pins (only 4 numeric characters accepted in password and re-password field -> Register button goes enabled)
- When two pin is not equals, local validation shows error message
-
Login
- Start the application
- Type incorrect pin, press Login button, local validation error message shows
- Type correct pin, press Login button, application enters the transaction screen
- Send app to background, select application from running apps, application shows the Login screen
-
Send transaction
- Start and log into the application
- Press + button on the NavigationBar
- If you press cancel in the dialog, ot will close down
- Fill the form with any data. The amount must be numeric.
- Send the transaction with the send button. The popup form will disappear, and the new transaction going to be in the list.
- In case of failed transaction, the error shows in the transaction list as well.
-
Edit
- You can delete transactions individually with left swipe, or with Edit button on the NavigationBar on multiple items.
-
DeepLink
- The application can handle custom URL Scheme which provides add transaction functionality from other applications.
ddemsg://add?recipient=xy&amount=123
- Implemented by Ferenc Sági (sagifer)
- Idea and specification by Zsombor Kovács (huobb0)
- Contributors: Julia Hanol (JGanol), Sander Frenken (sanderfrenken)
- Photo by Agustin Mariano Quezada used under the Unsplash Licence; derived work by Ksenia Kotelnikova