COSC424-18S2 (C) Semester Two 2018

Secure Software

15 points

Details:
Start Date: Monday, 16 July 2018
End Date: Sunday, 18 November 2018
Withdrawal Dates
Last Day to withdraw from this course:
  • Without financial penalty (full fee refund): Friday, 27 July 2018
  • Without academic penalty (including no fee refund): Friday, 12 October 2018

Description

This course provides students with skills to design and implement secure application programs, which are not vulnerable to malicious attacks.

This course provides students with skills to design and implement secure application programs, which are not vulnerable to malicious attacks. This course is concerned with designing and implementing secure application programs, that is, programs that are not vulnerable to malicious attacks. By the end of the course, students should be familiar with why security is important, what types of vulnerabilities can be present in software, how they can be exploited, and how to go about developing software that is sufficiently secure. The course involves significant practical work including a project.

Learning Outcomes

  • Students who successfully complete this course will be able to:
  • understand various types of vulnerabilities in software, how they can be exploited,
  • understand and explain how to develop sufficiently secure  software,
  • critique secure software design, implementation and evaluation in practice.
  • develop an ability to design, implement and test a secure software application

Prerequisites

Subject to approval of the Head of Department.

Course Coordinator

For further information see Computer Science and Software Engineering Head of Department

Assessment

The final exam will be used to evaluate a student’s overall understanding of the theoretical and technical aspects discussed in the course.

An important component of this course is to gain skills in the testing and evaluation of software cybersecurity systems. Thus a set of labs will be run which are outlined below

1. Wireless and Mobile Software Security: Wireless LANs, Wireless Enterprise Architecture, Android, Bluetooth and NFC/RFID Smartcard security.

This lab focuses on graduates who will work in the area of wireless and mobile enterprise software engineering security and will be responsible for design, implementation and testing and will required to address key cybersecurity issues in this framework.

2. Practical Network Software Security Policy Implementation and Testing:  Stateful packet inspection, cryptographic tools, Public Key Infrastructure, VPNs (SSL & IPSec) tunnel design, implementation and testing

This lab addresses the implementation and design of secure software VPN infrastructure and develops a good knowledge of firewall security policy implementation and testing thus aiming to avoid cybersecurity disasters.

3. Penetration Testing and Intrusion Detection:  SSL Data Leakage - Heartbleed, SSL Interception - Man-In-The-Middle Vulnerabilities, Penetration Testing using Zenmap, Nessus and Snorby Graphical User Interface Intrusion Detection

There are two components to this lab. The first provides experience and expertise with industry Penetration Testing and Intrusion Detection systems and tools as used in practice in addressing issues in the software cybersecurity world. The second part addresses legal interception and provides skills used by software security intelligence services and the police.

4. Identity and Access Management Software for Cloud Services:  Active Directory, RSA multifactor authentication using hardware, software and mobile phone devices, smartcard identity, Gallagher cloud service security

This lab is an extension of the previous one and develops the tools necessary for linking many of these devices and systems together as well as providing for implementation and testing.

5. Application Forensics: TCP/IP, VoIP (Voice over IP) and Video – attacks, exploits and software forensic analysis, Analysing voice, image and video traffic with Wireshark

This lab is for those who intend to work in police forensics and security intelligence services and must address and understand cybersecurity attacks.

6. Web Server Security and Fuzzing:  Asynchronous JavaScript and XML Security, Cross-Site Scripting, Injection Flaws, Privilege Escalation, Web Services Fuzzing

This lab will be valuable for those graduates who will be responsible for the secure operation of an organisations web servers.

Textbooks / Resources

There is no official course text, but the following are useful sources.
• Mark Dowd, John McDonald, Justin Schuh, The Art of Software Security Assessment: Identifying and Preventing Software Vulnerabilities,  Addison-Wesley, 2006
• Haralambos Mouratidis, Paolo Giorgini, Integrating Security and Software Engineering: Advances and Future Visions, IDEA Group Publishin, 2007
• Adam Shostack, Threat Modeling: Designing for Security , Wiley, 2014
• James A. Whittaker, Herbert H. Thompson, How to Break Software Security: Effective Techniques for Security Testing, Addison-Wesley Longman, 2004.
• William Stallings and Lawrie Brown, Computer Security: Principles and Practice, 2nd edition, Pearson, 2012.
• Michael Howard, David LeBlanc, John Viega, 19 Deadly Sins of Software Security: Programming Flaws and How to Fix Them, McGraw-Hill, 2005.
• Other books will be used in the course if necessary.
• Material (e.g., PowerPoint slides) from the course reader and lecture slides will be published on Learn as the course progresses.

Additional Course Outline Information

Grade moderation

The Computer Science department's grading policy states that in order to pass a course you must meet two requirements:
1. You must achieve an average grade of at least 50% over all assessment items.
2. You must achieve an average mark of at least 45% on invigilated assessment items.
If you satisfy both these criteria, your grade will be determined by the following University- wide scale for converting marks to grades: an average mark of 50% is sufficient for a C- grade, an average mark of 55% earns a C grade, 60% earns a B- grade and so forth. However if you do not satisfy both the passing criteria you will be given either a D or E grade depending on marks. Marks are sometimes scaled to achieve consistency between courses from year to year.

Students may apply for special consideration if their performance in an assessment is affected by extenuating circumstances beyond their control.

Applications for special consideration should be submitted via the Examinations Office website within five days of the assessment.

Where an extension may be granted for an assessment, this will be decided by direct application to the Department and an application to the Examinations Office may not be required.

Special consideration is not available for items worth less than 10% of the course.

Students prevented by extenuating circumstances from completing the course after the final date for withdrawing, may apply for special consideration for late discontinuation of the course. Applications must be submitted to the Examinations Office within five days of the end of the main examination period for the semester.

Tentative lecture schedule

Week 1 Software Security Assessment in Wireless, Mobile, Bluetooth and Smartcards (1)
Week 2 Software Security Assessment in Wireless, Mobile, Bluetooth and Smartcards (2)
Week 3 Network Software Security Policy Implementation and Testing (1)
Week 4 Network Software Security Policy Implementation and Testing (2)
Week 5 Penetration Testing and Intrusion Detection (1)
Week 6 Penetration Testing and Intrusion Detection (2)
Semester Break
Week 7 Identity and Access Management Software for Cloud Services (1)
Week 8 Identity and Access Management Software for Cloud Services (2)
Week 9 Application Forensics (1)
Week 10 Application Forensics (2)
Week 11 Web Server Security and Fuzzing (1)
Week 12 Web Server Security and Fuzzing (2)

Indicative Fees

Domestic fee $982.00

* All fees are inclusive of NZ GST or any equivalent overseas tax, and do not include any programme level discount or additional course-related expenses.

For further information see Computer Science and Software Engineering .

All COSC424 Occurrences

  • COSC424-18S2 (C) Semester Two 2018