Network Security and Privacy Vitaly Shmatikov CS 378
Course Personnel uInstructor: Vitaly Shmatikov Office: TAYLOR 4.115C Office hours: Thursday, 3:30-4:30pm (after class) Open door policy – don’t hesitate to stop by! uTA: Justin Brickell Office hours TBA uWatch the course website Assignments, reading materials, lecture notes uThis course is an experiment! First UT course on network security
Prerequisites uRequired: CS 372 (Operating Systems) My course has a substantial implementation component No waivers! uRecommended: Introduction to Computer Security; Cryptography; Computer Networks Not much overlap with this course, but will help gain deeper understanding of security mechanisms and where they fit in the big picture uRecommended: exposure to C programming Project will involve implementing buffer overflow exploits in C
Class Poll uIntroduction to computer security? Access control, Web security, sandboxing, firewalls? uCryptography? Public-key and symmetric encryption, digital signatures, cryptographic hash, random-number generators? uComputer networks? Network architecture, application and transport layer protocols? uProgramming in C?
Course Logistics uLectures Tuesday, Thursday 2-3:30pm uFive homeworks (40% of the grade) One or two may involve implementation uProject (15% of the grade) Involves a fair bit of implementation Security is a contact sport! uMidterm (20% of the grade) uFinal (25% of the grade) uUTCS Code of Conduct will be strictly enforced
Course Materials uTextbook: William Stallings. “Network Security Essentials: Applications and Standards.” Focuses on details of deployed security systems Lectures will focus on “big-picture” principles and ideas of network attack and defense Attend lectures! Lectures will cover some material that is not in the textbook – and you will be tested on it! uOccasional assigned readings Start reading “Smashing the Stack For Fun and Profit” by Aleph One (from Phrack hacker magazine) Understanding it will be essential for your project
Other Helpful Books uRoss Anderson. “Security Engineering”. Focuses on design principles for secure systems Wide range of entertaining examples: banking, nuclear command and control, burglar alarms Ross Anderson is famous for hacking tamper-resistant hardware uKaufman, Perlman, Speciner. “Network Security: Private Communication in a Public World”. Comprehensive network security textbook
Main Themes of the Course u Vulnerabilities of networked applications Worms, denial of service attacks, malicious code arriving from the network, attacks on infrastructure uDefense technologies Protection of information in transit: cryptography, application- and transport-layer security protocols Protection of networked applications: firewalls and intrusion detection uStudy a few deployed systems in detail: from design principles to gory implementation details Kerberos, SSL/TLS, IPSec
What This Course is Not About uNot a comprehensive course on computer security uNot a course on ethical, legal or economic issues No file sharing, DMCA, free speech issues uOnly cursory overview of cryptography Take CS 346 for deeper understanding uOnly some issues in systems security No access control, OS security, secure hardware Will cover buffer overflow: #1 cause of remote penetration attacks uNo language-based security
Motivation
Excerpt From “General Terms of Use” YOU ACKNOWLEDGE THAT NEITHER WELLS FARGO, ITS AFFILIATES NOR ANY OF THEIR RESPECTIVE EMPLOYEES, AGENTS, THIRD PARTY CONTENT PROVIDERS OR LICENSORS WARRANT THAT THE SERVICES OR THE SITE WILL BE UNINTERRUPTED OR ERROR FREE; NOR DO THEY MAKE ANY WARRANTY AS TO THE RESULTS THAT MAY BE OBTAINED FROM USE OF THE SERVICES OR THE SITE, OR AS TO THE TIMELINESS, SEQUENCE, ACCURACY, RELIABILITY, COMPLETENESS OR CONTENT OF ANY INFORMATION, SERVICE, OR MERCHANDISE PROVIDED THROUGH THE SERVICES AND THE SITE.
“Privacy and Security” “As a Wells Fargo customer, your privacy and security always come first.” Privacy policy for individuals Online privacy policy Our commitment to online security Online and computer security tips How we protect you General terms of use
What Do You Think? What do you think should be included in “privacy and security” for an e-commerce website? ?
Desirable Security Properties uAuthenticity uConfidentiality uIntegrity uAvailability uNon-repudiation uFreshness uAccess control uPrivacy of collected information uIntegrity of routing and DNS infrastructure
Syllabus (1): Security Mechanisms uBasics of cryptography Symmetric and public-key encryption, certificates, cryptographic hash functions, pseudo-random generators uAuthentication and key establishment Case study: Kerberos uIP security Case study: IPSec protocol suite uWeb security Case study: SSL/TLS (Transport Layer Security)
Syllabus (2): Attacks and Defenses uBuffer overflow attacks uNetwork attacks Distributed denial of service Worms and viruses Attacks on routing infrastructure uDefense tools Firewalls and intrusion detection systems uWireless security uPrivacy-enhancing technologies
network Attack on Confidentiality uConfidentiality is concealment of information Eavesdropping, packet sniffing, illegal copying
network Attack on Integrity uIntegrity is prevention of unauthorized changes Intercept messages, tamper, release again
network Attack on Authenticity uAuthenticity is identification and assurance of origin of information Unauthorized assumption of another’s identity
network Attack on Availability uAvailability is ability to use information or resources desired Overwhelm or crash servers, disrupt infrastructure
Network Stack application presentation session transport network data link physical IP TCP , Web, NFS RPC Sendmail, FTP, NFS bugs, chosen-protocol and version-rollback attacks SYN flooding, RIP attacks, sequence number prediction IP smurfing and other address spoofing attacks RPC worms, portmapper exploits WEP attacks Only as secure as the single weakest layer…
Network Defenses Cryptographic primitives Protocols and policies Implementations Building blocks Blueprints Systems RSA, DSS, SHA-1… SSL, IPSec, access control… Firewalls, intrusion detection… …all defense mechanisms must work correctly and securely
Correctness versus Security uProgram or system correctness: program satisfies specification For reasonable input, get reasonable output uProgram or system security: program properties preserved in face of attack For unreasonable input, output not completely disastrous uMain difference: active interference from adversary uModular design may increase vulnerability Abstraction is very difficult to achieve in security: what if the adversary operates below your level of abstraction?
Bad News uSecurity often not a primary consideration Performance and usability take precedence uFeature-rich systems may be poorly understood Higher-level protocols make mistaken assumptions uImplementations are buggy Buffer overflows are the “vulnerability of the decade” uNetworks are more open and accessible than ever Increased exposure, easier to cover tracks uMany attacks are not even technical in nature Phishing, impersonation, etc.
Better News uThere are a lot of defense mechanisms We’ll study some, but by no means all, in this course uIt’s important to understand their limitations “If you think cryptography will solve your problem, then you don’t understand cryptography… and you don’t understand your problem” -- Bruce Schneier Many security holes are based on misunderstanding uSecurity awareness and user “buy-in” help uOther important factors: usability and economics
Reading Assignment uStallings, sections uStart reading buffer overflow materials on the website