More stuff for the ASVS analysis

Signed-off-by: Tiago Garcia <tiago.rgarcia@ua.pt>
This commit is contained in:
Tiago Garcia 2024-12-28 22:50:47 +00:00
parent 6764f8bbe1
commit 8647008205
Signed by: TiagoRG
GPG Key ID: DFCD48E3F420DB42
5 changed files with 167 additions and 17 deletions

View File

@ -6,6 +6,16 @@ ifeq ($(ASCIIDOCTOR),)
ASCIIDOCTOR := $(shell ruby -r rubygems -e 'puts Gem.bin_path("asciidoctor", "asciidoctor")')
endif
ASCIIDOCTOR-PDF := $(shell which asciidoctor-pdf > /dev/null 2>&1 && which asciidoctor-pdf)
ifeq ($(ASCIIDOCTOR-PDF),)
ASCIIDOCTOR-PDF := $(shell ruby -r rubygems -e 'puts Gem.bin_path("asciidoctor-pdf", "asciidoctor-pdf")')
endif
html:
@echo "Building HTML"
@$(ASCIIDOCTOR) -b html -o report.html main.adoc
@$(ASCIIDOCTOR) -b html5 -o report.html main.adoc
pdf:
@echo "Building PDF"
@$(ASCIIDOCTOR-PDF) -o report.pdf main.adoc

View File

@ -53,13 +53,25 @@ The current implementation meets the requirement, as the session tokens are not
The application generates a new session token on session creation when a user logs in.
This token is generated using the `secrets.token_hex(128)`
function, which generates a 256-character hexadecimal string, providing more than 64 bits of entropy. This function has been certified as secure by OWASP in their https://cheatsheetseries.owasp.org/cheatsheets/Cryptographic_Storage_Cheat_Sheet.html#secure-random-number-generation[cheat sheet series].
function, which generates a 256-character hexadecimal string, providing more than 64 bits of entropy. This function has been certified as secure by OWASP in their link:https://cheatsheetseries.owasp.org/cheatsheets/Cryptographic_Storage_Cheat_Sheet.html#secure-random-number-generation[cheat sheet series].
This generation is implemented in the code as follows:
[source,python]
----
include::create_session.py[]
def create_session(user: User, org: Organization) -> Session:
session = Session(
user_id=user.id,
org_id=org.id,
token=secrets.token_hex(128),
roles=[],
challenge=secrets.token_hex(128),
verified=False
)
db.add(session)
db.commit()
db.refresh(session)
return session
----
==== Session Termination
@ -86,13 +98,137 @@ include::create_session.py[]
| 3.3.4
| Verify that users are able to view and (having re-entered login credentials) log out of any or all currently active sessions and devices.
| ✔
|
|
|===
===== 3.3.1
Upon logout, or any session deletion, the session data is completely removed from the database also deleting the session token, thus invalidating the session.
This is implemented in the code as follows, and accessed through the `POST /user/logout` endpoint:
[source,python]
----
def delete_session(session: Session) -> None:
db.delete(session)
db.commit()
----
===== 3.3.2
The application does not currently implement re-authentication after a period of inactivity.
This could be implemented by storing, for each session, the last time it was used, and checking this timestamp against the current time when a request is made. If the time difference exceeds the threshold defined in ASVS (12 hours or 15 minutes of inactivity, with 2FA), the user would be required to re-authenticate. This could be implemented in the code as follows:
[source,python]
----
def check_session_timeout(session: Session) -> bool:
return (datetime.now() - session.last_used).total_seconds() > SESSION_TIMEOUT
----
===== 3.3.4
Currently, there isn't a mechanism to view and log out of active sessions and devices.
This could be implemented by storing the device information in the session data and enabling an endpoint for the user to view all active sessions and devices, and then revoke access to them.
==== Cookie-based Session Management
NOTE: None of the requirements in this section are applicable to the current implementation.
[cols="^1,10,^1,^1", options="header", source]
|===
| Requirement | Description | Applicable | Implemented
| 3.4.1
| Verify that cookie-based session tokens have the 'Secure' attribute set.
| ✗
| ✗
| 3.4.2
| Verify that cookie-based session tokens have the 'HttpOnly' attribute set.
| ✗
| ✗
| 3.4.3
| Verify that cookie-based session tokens utilize the 'SameSite' attribute to limit exposure to cross-site request forgery attacks.
| ✗
| ✗
| 3.4.4
| Verify that cookie-based session tokens use the "__Host-" prefix so cookies are only sent to the host that initially set the cookie.
| ✗
| ✗
| 3.4.5
| Verify that if the application is published under a domain name with other applications that set or use session cookies that might disclose the session cookies, set the path attribute in cookie-based session tokens using the most precise path possible.
| ✗
| ✗
|===
==== Token-based Session Management
[cols="^1,10,^1,^1", options="header", source]
|===
| Requirement | Description | Applicable | Implemented
| 3.5.1
| Verify the application allows users to revoke OAuth tokens that form trust relationships with linked applications.
| ✗
| ✗
| 3.5.2
| Verify the application uses session tokens rather than static API secrets and keys, except with legacy implementations.
| ✔
| ✔
| 3.5.3
| Verify that stateless session tokens use digital signatures, encryption, and other countermeasures to protect against tampering, enveloping, replay, null cipher, and key substitution attacks.
| ✔
| ✗
|===
===== 3.5.2
The application uses that exact implementation, using session tokens instead of static API secrets and keys to manage sessions.
===== 3.5.3
TBD
==== Federated Re-authentication
NOTE: None of the requirements in this section are applicable to the current implementation.
[cols="^1,10,^1,^1", options="header", source]
|===
| Requirement | Description | Applicable | Implemented
| 3.6.1
| Verify that Relying Parties (RPs) specify the maximum authentication time to Credential Service Providers (CSPs) and that CSPs re- authenticate the user if they haven't used a session within that period.
| ✗
| ✗
| 3.6.2
| Verify that Credential Service Providers (CSPs) inform Relying Parties (RPs) of the last authentication event, to allow RPs to determine if they need to re-authenticate the user.
| ✗
| ✗
|===
==== Defenses Against Session Management Exploits
[cols="^1,10,^1,^1", options="header", source]
|===
| Requirement | Description | Applicable | Implemented
| 3.7.1
| Verify the application ensures a full, valid login session or requires re-authentication or secondary verification before allowing any sensitive transactions or account modifications.
| ✔
| ✗
|===
===== 3.7.1
Currently, the application does not require re-authentication or secondary verification before allowing sensitive transactions or account modifications, it just checks if the user is authenticated and has the required permissions.
This could be implemented by adding a challenge signature to the request using the rsa key pair, which would be verified by the server before allowing the transaction. This is the same mechanism already used for the login endpoint.

View File

@ -1,13 +0,0 @@
def create_session(user: User, org: Organization) -> Session:
session = Session(
user_id=user.id,
org_id=org.id,
token=secrets.token_hex(128),
roles=[],
challenge=secrets.token_hex(128),
verified=False
)
db.add(session)
db.commit()
db.refresh(session)
return session

View File

@ -5,6 +5,7 @@ Authors: Rúben Gomes (113435), João Bastos (113470), Tiago Garcia (114184) | 3
:doctype: article
:source-highlighter: highlightjs
:icons: font
:stylesheet: style.css
:sectnums:
:sectlinks:
:!last-update-label:
@ -18,10 +19,17 @@ This document serves as the final report for the SIO-2425 project. This project
This report will cover the features implemented, the decisions made as a group, as well as results and conclusions of the project.
<<<
include::features.adoc[]
<<<
include::decisions.adoc[]
<<<
include::analysis.adoc[]
<<<
include::results_conclusions.adoc[]

9
delivery3/style.css Normal file
View File

@ -0,0 +1,9 @@
@import "https://fonts.googleapis.com/css?family=Open+Sans:300,300italic,400,400italic,600,600italic%7CNoto+Serif:400,400italic,700,700italic%7CDroid+Sans+Mono:400,700";
@import "https://cdn.jsdelivr.net/gh/asciidoctor/asciidoctor@2.0/data/stylesheets/asciidoctor-default.css";
@media print {
a::after {
content: none !important; /* Prevent showing URLs in print */
}
}