- Lecture Time/Location
- Thursday 4:30pm–7:20pm, Lecture Center 3A
- Instructor
- Amir Masoumzadeh (amasoumzadeh@albany.edu)
- Office Hours: TBA, UAB 422 and Zoom (link on Brightspace)
Course Overview
This course examines the security and privacy considerations in the design and development of software systems. The focus is on the design, implementation, and testing of security and privacy mechanisms that protect data and applications. Topics include security design principles, threat models, authorization models, software vulnerability analysis, differential privacy, federated learning, and machine learning for security. The course readings are selected from foundational and recent research in the area. The assignments provide students with hands-on experience by incorporating open-source tools and frameworks. Students will also engage in a semester-long team project in the context of web-based software systems.
Prerequisites
There are no formal prerequisites for this course. Familiarity with web technologies and web-based software development is helpful. Any necessary background will be briefly reviewed during the course.
Readings
The readings will include book chapters, research papers, and framework documentations. All reading materials are either freely available or accessible using the university’s network.
Communication and Submissions
The course syllabus and schedule is available on the course webpage. Most of the tasks in this class will be handled via course GitHub organization including the distribution of notes, assignments, assignment submission, and feedback.
Assessment and Grading
You will be assessed based on the following:
- Assignments (30%)
- You will work on about 3 hands-on assignments in teams. The purpose of the assignments is to gain hands-on experience and develop deeper understanding of what we review in class.
- Paper Presentation and Discussion Participation (20%)
- You will choose a few research papers from the schedule and prepare a 30-minute conference-style presentation of the work. After each presentation, you are expected to engage the class in a productive discussion on the topic at hand. Other students are expected to actively engage during the presentations and the discussions afterwards.
- Team Project (50%)
- You will work on a semester-long team project involving the design and development of a defense mechanism, an analysis tool, or a measurement study. The projects are expected to have some level of novelty and contributions in theory/application of security and privacy concepts. By the end of the semester you will prepare a conference-style paper reporting on your methodology and results, and present it to the class. You will be graded on intermediary updates and final paper/presentation.
The course is A-E graded. Conversion from the final numerical grade to the letter grade is based on cutoffs determined according to the grade distribution in the class. This results in more flexible and favorable grades compared to using a fixed conversion scale.
Schedule
The following schedule is tentative and will be regularly updated. It is your responsibility to check the schedule regularly. The plus sign (+) means optional reading.
Day | Topic/Readings/Assignment |
---|---|
Jan23 | Course Overview; Security Services, Threats, and Design Principles |
Jan30 |
Threat Modeling
Readings:
Assignment: Threat Modeling Tools
|
Feb06 |
Authorization Models: RBAC and ABAC
Readings:
Assignment: XACML
|
Feb13 |
Authorization Models: ReBAC
Readings:
Assignment: OpenFGA, Cedar
|
Feb20 |
Distributed Authentication and Authorization
Readings:
Assignment: SAML, OAuth
|
Feb27 | Authorization Frameworks. Project Proposal |
Mar06 |
Static Analysis
Readings:
|
Mar13 |
Dynamic Analysis
Readings:
|
Mar20 | No Class (Spring Break) |
Mar27 | Project Progress Presentation |
Apr03 |
Data (De-)Anonymization
Readings:
|
Apr10 |
Differential Privacy
Readings:
|
Apr17 |
Federated Learning
Readings:
|
Apr24 |
Guardrails for Large Language Models
Readings:
|
Apr30 | Showcase Day |
May01 | Project Presentation |
Policies
- No Late Submission (Except One Assignment)
- Assignments will be released at least two weeks before their due date. You are highly recommended to study an assignment as soon as it becomes available. There will be ample opportunities to benefit from office hours and communication with the instructional team before the due date. Assignments are due at 11:59pm on the day of their deadline. Submissions after due time will receive no points. However, in order to account for unforeseen situations, you can request to submit only one assignment late. In order for your late assignment to be graded, you must email the instructor to request a late submission before the deadline. You should note that a late-submission request may not be always accepted (e.g., when the solutions need to be discussed in class immediately after a submission). Therefore, you are recommended to submit a version of your solution before the deadline if your request has not been reviewed yet. You have up to 3 days to submit after the deadline if your late-submission request is approved. Note that you only have one such opportunity during the semester. Therefore, it is advised to leave that option for truly critical situations. In the case of a team assignment, a late submission is considered for all team members.
- Review of Grades
- Any issue regarding your grade in a specific assignment must be communicated to us no later than 5 business days after the posting day of the grades. There will be no re-grading after the 5-day period has passed.
- Attending Classes
- Class attendance is required for successful completion of this course.
- Academic Integrity
- It is every student’s responsibility to become familiar with the standards of academic integrity at the University.
Claims of ignorance, of unintentional error, or of academic or personal pressures are not sufficient reasons for violations of academic integrity.
Any incident of academic dishonesty can result in a zero grade for the affected course component and a report sent to the appropriate University authorities (e.g., Dean of Undergraduate Education or Graduate Studies).
Repeated violations will result in a failing grade for the course.
For all assignments, you must submit your own work, except where collaboration is explicitly permitted or required. Providing your solutions to others or copying even parts of a solution is considered plagiarism. In projects/papers, you must properly cite any resources from which you borrow ideas and clearly distinguish them from your contributions.
- Use of Electronic Devices
- Computers or other electronic devices may be only used during class for note-taking, in-class exercises, or other class-related activities. You are not allowed to perform any unrelated tasks during class.
- Students with Disabilities
- Reasonable accommodation will be provided for students with documented disabilities. If you believe you have a disability requiring accommodation in this class, please notify the Disability Access and Inclusion Student Services (DAISS) (Campus Center 130, 518-442-5501). That office will provide me with verification of your disability, and will recommend appropriate accommodations. In general, it is your responsibility to contact me at least one week before the relevant activity to make arrangements.
- Health and Well-Being
- Your physical and mental health is very important.
The university has several health services when you need them.
In particular, Counseling and Psychological Services (CAPS) provides free, confidential services including psychological counseling and evaluation for emotional, social, and academic concerns.
If your life or someone else’s life is in danger, please call 911. If you are in a crisis and need help right away, please call the National Suicide Prevention Lifeline at 1-800-273-TALK (8255). Students dealing with heightened feelings of sadness or hopelessness, increased anxiety, or thoughts of suicide may also text “GOT5” to 741741 (Crisis Text Line).