SENG406-24S2 (C) Semester Two 2024

Software Security

15 points

Start Date: Monday, 15 July 2024
End Date: Sunday, 10 November 2024
Withdrawal Dates
Last Day to withdraw from this course:
  • Without financial penalty (full fee refund): Sunday, 28 July 2024
  • Without academic penalty (including no fee refund): Sunday, 29 September 2024


Building secure software is an intricate task that involves careful design of both preemptive and corrective measures. This course will cover the secure development lifecycle where students will learn about techniques to model security threats, follow secure coding standards and perform security-focused testing to prevent software to expose vulnerabilities. Students will learn how to combine tools of various natures to identify threats as part of a continuous integration pipeline. The course also addresses data privacy and governance issues, including (indigenous) data sovereignty principles.

Covid-19 Update: Please refer to the course page on AKO | Learn for all information about your course, including lectures, labs, tutorials and assessments.

Learning Outcomes

  • Evaluate data privacy practices, e.g., policies, regulations (e.g., NZ Information Security Manual) and data sovereignty (e.g., Te Mana Raraunga Principles of Māori Data Sovereignty).
  • Understand and critically assess different malicious strategies and their taxonomies, e.g., OWASP Top 10, MITRE ATT&CK(tm).
  • Systematically evaluate and apply software resilience engineering principles, e.g., cryptography, security risk management and reinstatement methods in order to design resilience, strategies built from the literature and the current state of the practice.
  • Explain, apply and evaluate secure coding principles when creating software, e.g., defensive and offensive programming, canonisation, sanitisation and least privilege execution.
  • Apply, evaluate and develop software verification and validation strategies to discover security vulnerabilities, e.g., penetration, fuzzy and formal testing, as well as the usage of analysis tools.


SENG201 and ENCE260, or
approval by the Head of Department



Timetable 2024

Students must attend one activity from each section.

Lecture A
Activity Day Time Location Weeks
01 Tuesday 11:00 - 13:00 Rehua 103 Project Workshop
15 Jul - 25 Aug
9 Sep - 20 Oct
Computer Lab A
Activity Day Time Location Weeks
01 Monday 16:00 - 18:00 Rehua 329 (15/7-29/7)
Jack Erskine 134 Lab 3 (5/8-19/8, 9/9-14/10)
15 Jul - 25 Aug
9 Sep - 20 Oct
02 Wednesday 12:00 - 14:00 Jack Erskine 244 (17/7-31/7)
Jack Erskine 131 Lab 1 (7/8-21/8, 11/9-16/10)
15 Jul - 25 Aug
9 Sep - 20 Oct

Timetable Note

Please note that the course activity times advertised here are currently in draft form, to be finalised at the end of January for S1 and whole year courses, and at the end of June for S2 courses.

Please hold off enquiries about these times until those finalisation dates.

Course Coordinator

Fabian Gilson


Assessment Due Date Percentage  Description
Vulnerabilities & Countermeasures 5% Week 3 - Presentation of a vulnerability (in class)
Resilience engineering and risk management plan 20% Week 4 - Develop a risk assessment plan of a company
Secure coding 20% Week 7 - Enhance existing code base using secure coding practices
Security evaluation of existing software 25% Week 12 - Conduct a security audit of an open source project
Final Examination 30% Examination on lecture material

Covid-19 Update: Please refer to the course page on AKO | Learn for all information about your course, including lectures, labs, tutorials and assessments.

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 C+ 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.

Indicative Fees

Domestic fee $1,110.00

International fee $5,275.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 SENG406 Occurrences

  • SENG406-24S2 (C) Semester Two 2024