Checklist and Methodology
Checklist
Static Analysis
Static analysis involves inspecting the app's code and configuration without running it. It checks for coding and design issues that may lead to security vulnerabilities.
1. Code Quality Checks
Check for coding standards adherence.
Look for common coding errors and insecure coding practices.
Identify hardcoded sensitive data such as passwords, API keys, and tokens.
2. Security Configuration Checks
Review the app's configuration settings for any insecure default or inappropriate settings.
Check for appropriate permissions requested by the app.
Inspect the app for any insecure file storage.
3. Cryptography Checks
Review the usage of cryptographic protocols and algorithms.
Look for hard-coded cryptographic keys.
4. Privacy Checks
Inspect the code for any violation of user privacy.
Look for proper handling of personally identifiable information (PII).
5. Third-Party Libraries Checks
Inspect the use of third-party libraries and frameworks.
Check the versions of the libraries for known vulnerabilities.
Dynamic Analysis
Dynamic analysis involves testing the app while it is running. It helps to identify security vulnerabilities at runtime, interactions with the environment, and user input handling issues.
1. Input Validation Checks
Check for proper validation of user-provided inputs.
Test for common injection attacks such as SQL injection, command injection, etc.
2. Authentication and Session Management Checks
Verify proper implementation of authentication mechanisms.
Check for proper session management.
Test for potential bypass of authentication mechanism.
3. Network Communication Checks
Verify the security of network communications.
Check for proper use of SSL/TLS and certificate pinning.
4. Data Storage and Privacy Checks
Inspect how the app handles data storage.
Test for insecure data storage vulnerabilities.
Verify proper implementation of data encryption.
5. Inter-process Communication (IPC) Checks
Test for vulnerabilities related to IPC mechanisms.
6. Environment Interaction Checks
Check for vulnerabilities related to the interaction with the mobile environment.
Test for code execution in the background.
Methodology
Pre-requisites
Setup Testing Environment
A macOS-based system, as some tools used for iOS app testing are only available on macOS.
An iOS device or a simulator for running the app, available in Xcode.
Install the .IPA file
Get the .IPA file onto the device. you could use services such as:
https://www.installonair.com/home If your rooted iPhone doesn't trust the source of the .ipa file you're trying to install, you may encounter issues during the installation process. By default, iOS devices only allow the installation of apps from trusted sources, typically from the App Store or sources explicitly trusted by Apple.
To bypass this restriction, you can follow these steps:
On your rooted iPhone, open the Settings app.
Navigate to "General" and then "Device Management" or "Profiles & Device Management."
Look for the profile associated with the app or the developer of the .ipa file you want to install.
Tap on the profile and then tap "Trust [Profile Name]" or "Verify App."
Confirm your trust for the developer or app when prompted.
Install and Configure Necessary Tools
Xcode: This is Apple's Integrated Development Environment (IDE). You can download it from the Mac App Store. It comes with the iOS Simulator and other necessary tools for iOS development and testing.
Homebrew: This is a package manager for macOS. Open Terminal and run the following command to install it:
SwiftLint: This is a tool for enforcing Swift style and conventions. Install it with Homebrew:
MobSF (Mobile Security Framework): An automated, all-in-one mobile application (Android/iOS/Windows) pen-testing, malware analysis, and security assessment framework capable of performing static and dynamic analysis. Instructions for its installation can be found on its GitHub page.
class-dump: This is a command-line tool for examining the Objective-C runtime information stored in Mach-O files. It generates declarations for the classes, categories, and protocols. You can install it using Homebrew:
Hopper Disassembler (Optional): This is a reverse engineering tool that can be used to disassemble, decompile, and debug your applications. Please note that it's not free, but it offers a 30-day trial.
Now, let's move on to how to perform individual parts of the static analysis.
Static Analysis
Code Quality Checks
Checking for Adherence to Coding Standards
After SwiftLint is installed, navigate to the root directory of your project in Terminal and run the following command:
This will provide you a list of warnings and errors if the code doesn't adhere to the guidelines specified in SwiftLint. You can configure SwiftLint by adding a .swiftlint.yml
file in your project directory. SwiftLint will automatically read this file.
Checking for Hardcoded Sensitive Data
This can be performed by manual code review or by searching through the codebase using grep-like tools for patterns related to sensitive information like passwords, API keys, tokens, etc. Be aware that this process may produce false positives and negatives.
Security Configuration Checks
Reviewing Configuration Settings
Review Info.plist
file and other configuration files for insecure settings, like allowing arbitrary loads, not enforcing App Transport Security (ATS), etc.
Checking for Appropriate Permission
Review the app's requested permissions in Info.plist
and ensure the app isn't requesting more permissions than it needs.
Cryptography Checks
Manual code review should be conducted to find usage of weak cryptography protocols or hard-coded cryptographic keys. Developers should use Apple's built-in cryptographic APIs, like CommonCrypto
and CryptoKit
, instead of custom solutions.
Here is an example of what to look for, insecure usage of kCCAlgorithmDES
(Data Encryption Standard) which is considered weak:
Privacy Checks
Review the app's data handling processes for any violation of user privacy. Make sure the app isn't collecting more data than necessary and it's using secure methods to store and transmit personal identifiable information (PII).
Third-Party Libraries Checks
Check the versions of third-party libraries used in the app for any known vulnerabilities. You can use MobSF for scanning the app's codebase for known vulnerabilities.
Please note that each application is different and additional checks may be necessary depending on the specific features of the app being tested. Always refer back to the detailed OWASP guides when conducting these tests.
Binary uses insecure APIs (iOS)
How to Test
Extracting the binary from the IPA: First, we need to extract the binary file from the IPA. An IPA file is just a ZIP archive. Unzip it and you will find the binary in the Payload folder.
Searching for insecure APIs: Use the strings
command to extract strings from the binary and grep
to filter the results.
This command will search all the strings in the binary for the insecure APIs and print the matches.
You can use the following command to combine the two, in order to check for false possitives.
Alternatively, you could use
You can also use reverse engineering tools like Ghidra, IDA Pro, or radare2 to perform a more in-depth analysis and understand the context of these API usages.
Using Tools:
The Clang Static Analyzer is a source code analysis tool that finds bugs in C, C++, and Objective-C programs. It can be used to detect the usage of insecure APIs.
Remediation Advice
If the insecure APIs are found, developers should replace these functions with their secure counterparts where possible.
For _memcpy
, consider using memcpy_s
(if available) or ensure the copied data is limited to the size of the destination buffer.
For _fopen
, consider using fopen_s
or other methods with better error handling and more secure behaviors.
For _sscanf
, use sscanf_s
or ensure input validation.
For _printf
, use snprintf
, vsnprintf
, or similar to avoid buffer overflows.
However, it's important to note that the "_s" versions of these functions are part of the optional Annex K of the ISO C11 standard, and may not be available on all platforms or compilers. Therefore, when using these functions in iOS, especially when using Objective-C or Swift, the traditional versions of these functions might be the only ones available. In such cases, additional care should be taken to use these functions in a secure manner, such as by ensuring proper size checks and error handling.
The specific remediation steps will depend on the nature of the native code, the iOS app's functionality, and the specific usage of these insecure functions within the context of the app. It's crucial to review the code carefully to determine the best mitigation strategy for each instance of insecure API usage.
Dynamic Analysis
Input Validation Checks
Test for Injection Attacks
To test for injection attacks, you can use fuzzing techniques which involve providing unexpected input to the application and monitoring for exceptions or failures.
Remediation: Always use parameterized queries or prepared statements to prevent SQL or command injection attacks. Validate, sanitize, and encode user inputs as necessary.
Authentication and Session Management Checks
Test Authentication Mechanisms
Try to bypass the login mechanism by providing malformed inputs. Try common or weak credentials to test for weak password policy.
2.2 Test Session Management
After authenticating, look for session identifiers. Check if they change after logging out and logging back in, to make sure the session is properly invalidated.
Remediation: Implement strong password policies and use secure, server-side session management. Session identifiers should be securely generated and should expire after a period of inactivity.
3. Network Communication Checks
3.1 Test SSL/TLS Implementation
You can intercept the network traffic using proxy tools like Charles or Burp Suite to check if the application is properly using SSL/TLS. Try to use an invalid certificate and see if the application accepts it.
Remediation: Always use secure connections for transmitting sensitive data. Implement SSL pinning to prevent man-in-the-middle attacks.
4. Data Storage and Privacy Checks
4.1 Test Data Storage Mechanisms
You can use the iOS file explorer tools like iExplorer to explore the app's files stored on the device. Check if any sensitive data is stored insecurely.
Remediation: Sensitive data should not be stored on the device without proper security measures. Use the iOS Keychain for storing small pieces of sensitive data.
5. Inter-process Communication (IPC) Checks
5.1 Test IPC Mechanisms
Check if the application is using insecure IPC mechanisms, such as insecure custom URL schemes. Use Frida to hook into IPC methods and manipulate data.
Remediation: Implement proper permission checks and data validation for IPC mechanisms. Do not expose sensitive functionalities through IPC.
6. Environment Interaction Checks
6.1 Test Code Execution in the Background
Check if the app continues to run code or keep sensitive data in memory while in the background. You can use Xcode's debug and memory analysis tools for this.
Remediation: Sensitive operations should be paused or terminated when the app goes into the background. Sensitive data should be removed from memory.
useful links:
https://aupsham98.medium.com/practical-ios-penetration-testing-a-step-by-step-guide-8214d35aaf3c
Last updated