Cybersecurity First Principles Janica Edmonds
Cybersecurity Introduction
Security Needs Confidentiality Integrity Availability Basic security needs are confidentiality, integrity, and availability of all components within a system or network. Confidentiality is preserving sensitive data or resources from unauthorized disclosure. Integrity is preventing the modification of data or resources by unauthorized users, preventing unauthorized or unintentional modification by authorized users, and preserving the consistency of the data and resources. Availability is the timely and uninterrupted access to data and resources.
Security Threats A potential occurrence, malicious or otherwise, that might damage or compromise assets. Interception – asset is diverted. Interruption – asset is delayed Modification – asset is altered. Fabrication – asset is manufactured.
Security Assets Components of the system or network. Hardware Software People Data
Cybersecurity First Principles Domain separation Process Isolation Resource encapsulation Layering Modularization Least Privilege Information hiding Abstraction Simplicity Minimization
Domain Separation Separating areas where resources are located prevents accidents and loss of data, keeping information worlds from colliding. Good fences make good neighbors. When trying to secure a home or computer, separating the areas where resources are and people work prevents accidents and loss of data or private information. We are preventing the information worlds from colliding. *The images come from a game developed by the GenCyber team at California State University, San Bernardino.
Process Isolation A process occurs when a task is executed. Keeping processes separate prevents the failure of one process from negatively impacting another. A process is when a program is run. By keeping processes separated, it prevents the failure of one process from causing another to fail.
Resource Encapsulation Resources – hardware, system objects, or processes – must be separated and used as intended. A resource can be hardware such as memory, disk drives, or a display screen. It can also be system objects such as semaphores, a linked list, or shared memory. Processes (or programs) need resources to run. Resources have to be separated and used in the way they were intended.
Layering Multiple layers of defense protect information. If one layer is defeated, the next one should catch it. Cybersecurity uses multiple layers of defenses for protecting information. If one layer is defeated then the next one should catch it.
Modularization Able to be inserted or removed from a project; each module has its own function, interchangeable with other modules. The concept of modularity is like building blocks. Each block (or module) can be put in or taken out from a bigger project. Each module has its own separate function that is interchangeable with other modules.
Least Privilege Limits what access people have to your resources and what they can do with them. One of the ways to protect information is by limiting what people can do with your information and resources. Like a private letter, you may allow a friend to read it, but not edit it. Your friend may make a mistake. You might let a teacher edit it because she will correct it.
Information Hiding Any attempt to prevent people from being able to see information. Information hiding is any attempt to prevent people from being able to see information. It can be hiding the content of a letter, or it can be applied to hiding how the letter is delivered. Both ways can prevent people from being able to see the information.
Abstraction Abstraction is a fancy word for summarizing or explaining in a way that can be easily understood. Abstraction is a fancy word for summarizing or explaining in a way that we can easily understand. A map is an abstraction of the Earth. The speedometer on a car is an abstraction for how fast the car is going.
Simplicity If something is less complicated, it is less likely to have problems and it is easier to troubleshoot and fix. The less complicated something is, the less likely it is to have problems. It is also easier to troubleshoot and fix. Keep it simple!
Minimization Minimization’s goal is to simplify and decrease the number of ways the software can be exploited. Minimization refers to having the least functionality of a program or device. The goal of minimization is to simplify and decrease the number of ways the software can be exploited. This can include turning off the ports that are not needed, reduce the amount of code running, and turn off unneeded features.