Threat modeling begins with a clear understanding of the system in question. There are several areas to consider when trying to understand possible threats to an application. The areas of concern include the mobile application structure, the data, identifying threat agents and methods of attack, and controls to prevent attacks. The threat model should be created with an outline or checklist of items that need to be documented, reviewed, and discussed when developing a mobile application.
In this project, you will create a threat model. There are seven steps, which will lead you through this project, beginning with the scenario as it might occur in the workplace, and continuing with Step 1: “Describe Your Mobile Application Architecture.” Most steps in this project should take no more than two hours to complete, and the project as a whole should take no more than two weeks to complete.
The following are the deliverables for this project:
- Threat Model Report: An eight- to 10-page double-spaced Word document with citations in APA format. The report should include your findings and any recommendations for mitigating the threats found. The page count does not include figures, diagrams, tables, or citations.
Step 1: Describe Your Mobile Application Architecture
In your role as a cyber threat analyst, senior management has asked you to identify how a particular mobile application of your choosing conforms to mobile architecture standards. You are asked to:
- Describe device-specific features used by the application, wireless transmission protocols, data transmission media, interaction with hardware components, and other applications.
- Identify the needs and requirements for application security, computing security, and device management and security.
- Describe the operational environment and use cases.
- Identify the operating system security and enclave/computing environment security concerns, if there are any.
This can be fictional or modeled after a real-world application. This will be part of your final report. Click the following links and review the topics and their resources. These resources will guide you in completing this task:
- network security threats
- threat modeling
- mobile architectures
- application security
- operating system security
- enclave/computing environment
Begin by first reviewing the OWASP Mobile Security Project Testing Guide.
Architecture Considerations
Although mobile applications vary in function, they can be described in general as follows:
- wireless interfaces
- transmission type
- hardware interaction
- interaction with on device applications/services
- interaction with off device applications/services
- encryption protocols
- platforms
In Section 1 of your research report, you will focus your discussion on the security threats, vulnerabilities, and mitigations of the above considerations.
The following resources will continue to educate your management about mobile devices and mobile application security: mobile platform security, mobile protocols and security, mobile security vulnerabilities, and related technologies and their security. Related technologies can include the hardware and software needed to interoperate with mobile devices and mobile applications.
Include an overview of these topics in your report.
Use Mobile Application and Architecture Considerations to review the architectural considerations for mobile applications and architecture. Then, include those that are relevant to your mobile application in your report to senior management. Address the following questions:
- What is the design of the architecture (network infrastructure, web services, trust boundaries, third-party APIs, etc.)?
- What are the common hardware components?
- What are the authentication specifics?
- What should or shouldn’t the app do?
You will include this information in your report.
When you have completed the work for Section 1, describing the architecture for your app, move on to the next step, where you will define the requirements for the app.
Step 2: Define the Requirements for Your Mobile Application
In the previous step, you described your app’s architecture. In Step 2, you will define what purpose the mobile app serves from a business perspective and what data the app will store, transmit, and receive. Include a data flow diagram to showing exactly how data are handled and managed by the application. You can use fictional information or model it after a real-world application. Here are some questions to consider as you define your requirements:
- What is the business function of the app?
- What data does the application store/process (provide data flow diagram)?
- This diagram should outline network, device file system, and application data flows
- How are data transmitted between third-party APIs and app(s)?
- Will there be remote access and connectivity? Read this resource about mobile VPN security, and include any of these security issues in your report.
- Are there different data-handling requirements between different mobile platforms? (iOS/Android/Blackberry/Windows/J2ME)
- Does the app use cloud storage APIs (e.g., Dropbox, Google Drive, iCloud, Lookout) for device data backups?
- Does personal data intermingle with corporate data?
- Is there specific business logic built into the app to process data?
- What does the data give you (or an attacker) access to? Think about data at restand data in motion as they relate to your app.
- Do stored credentials provide authentication?
- Do stored keys allow attackers to break crypto functions (data integrity)?
- Are third-party data being stored and/or transmitted?
- What are the privacy requirements of user data? Consider, for example, a unique device identifier (UDID) or geolocation being transmitted to a third party.
- Are there user privacy-specific regulatory requirements to meet?
- How do other data on the device affect the app? Consider, for example, authentication credentials shared between apps.
- Compare between jailbroken (i.e., a device with hacked or bypassed digital rights software) and nonjailbroken devices.
- How do the differences affect app data? This can also relate to threat agent identification.
In this step, you defined the app’s requirements. Move to the next step, where you will identify any threats to the app’s operation.
Step 3: Identify Threats and Threat Agents
Now that you have identified the mobile app’s requirements, you will define its threats.
In Section 3 of the report, you will:
- Identify possible threats to the mobile application
- Identify the threat agents
- Outline the process for defining what threats apply to your mobile application
Review this Threat Agent Identification Example resource for an example of threat agent identification.
Review this List of Threat Agents resource for a list of threat agents.
After you have identified threats and threat agents, move to the next step, where you will consider the ways an attacker might reach your app’s data.
Step 4: Identify Methods of Attack
In the previous step, you identified threat agents. In this step and in Section 4 of the report, you will identify different methods an attacker can use to reach the data. These data can be sensitive information to the device or something sensitive to the app itself.
Read these resources on cyberattacks.
Provide senior management an understanding of the possible methods of attack of your app.
When you have identified the attack methods, move to the next step, where you will analyze threats to your app.
Step 6: Controls
You have identified the methods of attack, and now you will discuss the controls to prevent attacks. Consider the following questions:
Note: Not all of the following may apply. You will address only the areas that apply to the application you have chosen.
- What are the controls to prevent an attack? Conduct independent research and then define these controls by platform (e.g., Apple iOS, Android, Windows Mobile, BlackBerry).
- What are the controls to detect an attack? Define these controls by platform.
- What are the controls to mitigate/minimize impact of an attack? Define these controls by platform.
- What are the privacy controls (i.e., controls to protect users’ private information)? An example of this would be a security prompt for users to access an address book or geolocation.
- Create a mapping of controls to each specific method of attack (defined in the previous step)
- Create a level of assurance framework based on controls implemented. This would be subjective to a certain point, but it would be useful in guiding organizations that want to achieve a certain level of risk management based on the threats and vulnerabilities.
In the next step, you will complete work on the threat model.
You have just discussed the controls to prevent attacks. You have completed all the components of your report. Now compile all your findings and produce your Threat Model Report.
The following are the deliverables for this project:
Deliverables
- Threat Model Report: An eight- to 10-page double-spaced Word document with citations in APA format. The report should include your findings and any recommendations for mitigating the threats found. The page count does not include figures, diagrams, tables, or citations.
- Lab Report: A Word document sharing your la
-
ScreenShot2019-11-21at7.07.24PM.png
-
ScreenShot2019-11-21at7.07.10PM.png
-
ScreenShot201