Skip to content

feat: Add initial Dockerfile, Pipfile.lock, and Terraform example for…#158

Open
CalinL wants to merge 1 commit intomainfrom
demo-devsecops-02
Open

feat: Add initial Dockerfile, Pipfile.lock, and Terraform example for…#158
CalinL wants to merge 1 commit intomainfrom
demo-devsecops-02

Conversation

@CalinL
Copy link
Copy Markdown
Contributor

@CalinL CalinL commented Apr 2, 2026

… infrastructure setup

@github-actions
Copy link
Copy Markdown

github-actions bot commented Apr 2, 2026

Dependency Review

The following issues were found:
  • ❌ 3 vulnerable package(s)
  • ❌ 7 package(s) with incompatible licenses
  • ✅ 0 package(s) with invalid SPDX license definitions
  • ✅ 0 package(s) with unknown licenses.
See the Details below.

Snapshot Warnings

⚠️: No snapshots were found for the head SHA 0e88b50.
Ensure that dependencies are being submitted on PR branches and consider enabling retry-on-snapshot-warnings. See the documentation for more information and troubleshooting advice.

Vulnerabilities

devsecops-demo/Pipfile.lock

NameVersionVulnerabilitySeverity
flask2.0.2Flask vulnerable to possible disclosure of permanent session cookie due to missing Vary: Cookie headerhigh
werkzeug2.0.2High resource usage when parsing multipart form data with many fieldshigh
Werkzeug debugger vulnerable to remote execution when interacting with attacker controlled domainhigh
Werkzeug DoS: High resource usage when parsing multipart/form-data containing a large part with CR/LF character at the beginningmoderate
Werkzeug safe_join not safe on Windowsmoderate
Werkzeug possible resource exhaustion when parsing file data in formsmoderate
Werkzeug safe_join() allows Windows special device namesmoderate
Werkzeug safe_join() allows Windows special device names with compound extensionsmoderate
Werkzeug safe_join() allows Windows special device namesmoderate
jinja23.0.2Jinja vulnerable to HTML attribute injection when passing user input as keys to xmlattr filtermoderate
Jinja vulnerable to HTML attribute injection when passing user input as keys to xmlattr filtermoderate
Jinja has a sandbox breakout through indirect reference to format methodmoderate
Jinja has a sandbox breakout through malicious filenamesmoderate
Jinja2 vulnerable to sandbox breakout through attr filter selecting format methodmoderate
Only included vulnerabilities with severity moderate or higher.

License Issues

devsecops-demo/Pipfile.lock

PackageVersionLicenseIssue Type
flask2.0.2BSD-2-Clause AND BSD-3-ClauseIncompatible License
werkzeug2.0.2BSD-2-Clause AND BSD-3-ClauseIncompatible License
jinja23.0.2BSD-2-Clause AND BSD-3-ClauseIncompatible License
click8.0.1BSD-2-Clause AND BSD-3-ClauseIncompatible License
itsdangerous2.0.1BSD-2-ClauseIncompatible License
markupsafe2.0.1BSD-2-Clause AND BSD-3-ClauseIncompatible License
python-dotenv0.19.0BSD-2-Clause AND BSD-3-ClauseIncompatible License
Allowed Licenses: MIT, Apache-2.0, GPL-3.0

OpenSSF Scorecard

PackageVersionScoreDetails
pip/flask 2.0.2 UnknownUnknown
pip/werkzeug 2.0.2 UnknownUnknown
pip/jinja2 3.0.2 UnknownUnknown
pip/click 8.0.1 UnknownUnknown
pip/itsdangerous 2.0.1 UnknownUnknown
pip/markupsafe 2.0.1 UnknownUnknown
pip/python-dotenv 0.19.0 🟢 5.2
Details
CheckScoreReason
Maintained🟢 1021 commit(s) and 1 issue activity found in the last 90 days -- score normalized to 10
Code-Review🟢 4Found 12/29 approved changesets -- score normalized to 4
Dangerous-Workflow🟢 10no dangerous workflow patterns detected
Token-Permissions⚠️ 0detected GitHub workflow tokens with excessive permissions
Security-Policy🟢 10security policy file detected
Binary-Artifacts🟢 10no binaries found in the repo
Pinned-Dependencies⚠️ 0dependency not pinned by hash detected -- score normalized to 0
CII-Best-Practices⚠️ 0no effort to earn an OpenSSF best practices badge detected
Fuzzing⚠️ 0project is not fuzzed
License🟢 10license file detected
Packaging🟢 10packaging workflow detected
Signed-Releases⚠️ -1no releases found
Branch-Protection⚠️ 0branch protection not enabled on development/release branches
SAST⚠️ 0SAST tool is not run on all commits -- score normalized to 0

Scanned Files

  • devsecops-demo/Pipfile.lock

1 similar comment
@github-actions
Copy link
Copy Markdown

github-actions bot commented Apr 2, 2026

Dependency Review

The following issues were found:
  • ❌ 3 vulnerable package(s)
  • ❌ 7 package(s) with incompatible licenses
  • ✅ 0 package(s) with invalid SPDX license definitions
  • ✅ 0 package(s) with unknown licenses.
See the Details below.

Snapshot Warnings

⚠️: No snapshots were found for the head SHA 0e88b50.
Ensure that dependencies are being submitted on PR branches and consider enabling retry-on-snapshot-warnings. See the documentation for more information and troubleshooting advice.

Vulnerabilities

devsecops-demo/Pipfile.lock

NameVersionVulnerabilitySeverity
flask2.0.2Flask vulnerable to possible disclosure of permanent session cookie due to missing Vary: Cookie headerhigh
werkzeug2.0.2High resource usage when parsing multipart form data with many fieldshigh
Werkzeug debugger vulnerable to remote execution when interacting with attacker controlled domainhigh
Werkzeug DoS: High resource usage when parsing multipart/form-data containing a large part with CR/LF character at the beginningmoderate
Werkzeug safe_join not safe on Windowsmoderate
Werkzeug possible resource exhaustion when parsing file data in formsmoderate
Werkzeug safe_join() allows Windows special device namesmoderate
Werkzeug safe_join() allows Windows special device names with compound extensionsmoderate
Werkzeug safe_join() allows Windows special device namesmoderate
jinja23.0.2Jinja vulnerable to HTML attribute injection when passing user input as keys to xmlattr filtermoderate
Jinja vulnerable to HTML attribute injection when passing user input as keys to xmlattr filtermoderate
Jinja has a sandbox breakout through indirect reference to format methodmoderate
Jinja has a sandbox breakout through malicious filenamesmoderate
Jinja2 vulnerable to sandbox breakout through attr filter selecting format methodmoderate
Only included vulnerabilities with severity moderate or higher.

License Issues

devsecops-demo/Pipfile.lock

PackageVersionLicenseIssue Type
flask2.0.2BSD-2-Clause AND BSD-3-ClauseIncompatible License
werkzeug2.0.2BSD-2-Clause AND BSD-3-ClauseIncompatible License
jinja23.0.2BSD-2-Clause AND BSD-3-ClauseIncompatible License
click8.0.1BSD-2-Clause AND BSD-3-ClauseIncompatible License
itsdangerous2.0.1BSD-2-ClauseIncompatible License
markupsafe2.0.1BSD-2-Clause AND BSD-3-ClauseIncompatible License
python-dotenv0.19.0BSD-2-Clause AND BSD-3-ClauseIncompatible License
Allowed Licenses: MIT, Apache-2.0, GPL-3.0

OpenSSF Scorecard

PackageVersionScoreDetails
pip/flask 2.0.2 UnknownUnknown
pip/werkzeug 2.0.2 UnknownUnknown
pip/jinja2 3.0.2 UnknownUnknown
pip/click 8.0.1 UnknownUnknown
pip/itsdangerous 2.0.1 UnknownUnknown
pip/markupsafe 2.0.1 UnknownUnknown
pip/python-dotenv 0.19.0 🟢 5.2
Details
CheckScoreReason
Maintained🟢 1021 commit(s) and 1 issue activity found in the last 90 days -- score normalized to 10
Code-Review🟢 4Found 12/29 approved changesets -- score normalized to 4
Dangerous-Workflow🟢 10no dangerous workflow patterns detected
Token-Permissions⚠️ 0detected GitHub workflow tokens with excessive permissions
Security-Policy🟢 10security policy file detected
Binary-Artifacts🟢 10no binaries found in the repo
Pinned-Dependencies⚠️ 0dependency not pinned by hash detected -- score normalized to 0
CII-Best-Practices⚠️ 0no effort to earn an OpenSSF best practices badge detected
Fuzzing⚠️ 0project is not fuzzed
License🟢 10license file detected
Packaging🟢 10packaging workflow detected
Signed-Releases⚠️ -1no releases found
Branch-Protection⚠️ 0branch protection not enabled on development/release branches
SAST⚠️ 0SAST tool is not run on all commits -- score normalized to 0

Scanned Files

  • devsecops-demo/Pipfile.lock

Comment on lines +24 to +64
resource "azurerm_network_security_group" "catapp-sg" {
name = "${var.prefix}-sg"
location = var.location
resource_group_name = azurerm_resource_group.myresourcegroup.name

security_rule {
name = "HTTP"
priority = 100
direction = "Inbound"
access = "Allow"
protocol = "Tcp"
source_port_range = "*"
destination_port_range = "80"
source_address_prefix = "*"
destination_address_prefix = "*"
}

security_rule {
name = "HTTPS"
priority = 102
direction = "Inbound"
access = "Allow"
protocol = "Tcp"
source_port_range = "*"
destination_port_range = "443"
source_address_prefix = "*"
destination_address_prefix = "*"
}

security_rule {
name = "SSH"
priority = 101
direction = "Inbound"
access = "Allow"
protocol = "Tcp"
source_port_range = "*"
destination_port_range = "22"
source_address_prefix = "*"
destination_address_prefix = "*"
}
}
Comment on lines +24 to +64
resource "azurerm_network_security_group" "catapp-sg" {
name = "${var.prefix}-sg"
location = var.location
resource_group_name = azurerm_resource_group.myresourcegroup.name

security_rule {
name = "HTTP"
priority = 100
direction = "Inbound"
access = "Allow"
protocol = "Tcp"
source_port_range = "*"
destination_port_range = "80"
source_address_prefix = "*"
destination_address_prefix = "*"
}

security_rule {
name = "HTTPS"
priority = 102
direction = "Inbound"
access = "Allow"
protocol = "Tcp"
source_port_range = "*"
destination_port_range = "443"
source_address_prefix = "*"
destination_address_prefix = "*"
}

security_rule {
name = "SSH"
priority = 101
direction = "Inbound"
access = "Allow"
protocol = "Tcp"
source_port_range = "*"
destination_port_range = "22"
source_address_prefix = "*"
destination_address_prefix = "*"
}
}
Comment on lines +24 to +64
resource "azurerm_network_security_group" "catapp-sg" {
name = "${var.prefix}-sg"
location = var.location
resource_group_name = azurerm_resource_group.myresourcegroup.name

security_rule {
name = "HTTP"
priority = 100
direction = "Inbound"
access = "Allow"
protocol = "Tcp"
source_port_range = "*"
destination_port_range = "80"
source_address_prefix = "*"
destination_address_prefix = "*"
}

security_rule {
name = "HTTPS"
priority = 102
direction = "Inbound"
access = "Allow"
protocol = "Tcp"
source_port_range = "*"
destination_port_range = "443"
source_address_prefix = "*"
destination_address_prefix = "*"
}

security_rule {
name = "SSH"
priority = 101
direction = "Inbound"
access = "Allow"
protocol = "Tcp"
source_port_range = "*"
destination_port_range = "22"
source_address_prefix = "*"
destination_address_prefix = "*"
}
}
Comment on lines +24 to +64
resource "azurerm_network_security_group" "catapp-sg" {
name = "${var.prefix}-sg"
location = var.location
resource_group_name = azurerm_resource_group.myresourcegroup.name

security_rule {
name = "HTTP"
priority = 100
direction = "Inbound"
access = "Allow"
protocol = "Tcp"
source_port_range = "*"
destination_port_range = "80"
source_address_prefix = "*"
destination_address_prefix = "*"
}

security_rule {
name = "HTTPS"
priority = 102
direction = "Inbound"
access = "Allow"
protocol = "Tcp"
source_port_range = "*"
destination_port_range = "443"
source_address_prefix = "*"
destination_address_prefix = "*"
}

security_rule {
name = "SSH"
priority = 101
direction = "Inbound"
access = "Allow"
protocol = "Tcp"
source_port_range = "*"
destination_port_range = "22"
source_address_prefix = "*"
destination_address_prefix = "*"
}
}
Comment on lines +92 to +129
resource "azurerm_virtual_machine" "catapp" {
name = "${var.prefix}-meow"
location = var.location
resource_group_name = azurerm_resource_group.myresourcegroup.name
vm_size = var.vm_size

network_interface_ids = [azurerm_network_interface.catapp-nic.id]
delete_os_disk_on_termination = "true"

storage_image_reference {
publisher = var.image_publisher
offer = var.image_offer
sku = var.image_sku
version = var.image_version
}

storage_os_disk {
name = "${var.prefix}-osdisk"
managed_disk_type = "Standard_LRS"
caching = "ReadWrite"
create_option = "FromImage"
}

os_profile {
computer_name = var.prefix
admin_username = var.admin_username
admin_password = var.admin_password
}

os_profile_linux_config {
disable_password_authentication = false
}

tags = {}

# Added to allow destroy to work correctly.
depends_on = [azurerm_network_interface_security_group_association.catapp-nic-sg-ass]
}
try:
print(xs[7])
print(xs[8])
except: pass
try:
print(xs[7])
print(xs[8])
except: pass
for y in ys:
try:
print(str(y+3)) #TypeErrors ahead
except: continue #not how to handle them
except: continue #not how to handle them

#some imports
import telnetlib

#some imports
import telnetlib
import ftplib
@@ -0,0 +1,30 @@

from flask import request, render_template, make_response
def index():
name = request.args.get('name')
author = request.args.get('author')
read = bool(request.args.get('read'))
Copy link
Copy Markdown

@github-advanced-security github-advanced-security bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

templateanalyzer found more than 20 potential problems in the proposed changes. Check the Files changed tab for more details.

Copy link
Copy Markdown

@github-advanced-security github-advanced-security bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

checkov found more than 20 potential problems in the proposed changes. Check the Files changed tab for more details.

try:
print(xs[7])
print(xs[8])
except: pass
for y in ys:
try:
print(str(y+3)) #TypeErrors ahead
except: continue #not how to handle them

#B303 and B324
s = b"I am a string"
print("MD5: " +hashlib.md5(s).hexdigest())
#B303 and B324
s = b"I am a string"
print("MD5: " +hashlib.md5(s).hexdigest())
print("SHA1: " +hashlib.sha1(s).hexdigest())
Comment on lines +27 to +34
"flask": {
"hashes": [
"sha256:7b2fb8e934ddd50731893bdcdb00fc8c0315916f9fcd50d22c7cc1a95ab634e2",
"sha256:cb90f62f1d8e4dc4621f52106613488b5ba826b2e1e10a33eac92f723093ab6a"
],
"index": "pypi",
"version": "==2.0.2"
},
Comment on lines +43 to +50
"jinja2": {
"hashes": [
"sha256:827a0e32839ab1600d4eb1c4c33ec5a8edfbc5cb42dafa13b81f182f97784b45",
"sha256:8569982d3f0889eed11dd620c706d39b60c36d6d25843961f33f77fb6bc6b20c"
],
"markers": "python_version >= '3.6'",
"version": "==3.0.2"
},
Comment on lines +43 to +50
"jinja2": {
"hashes": [
"sha256:827a0e32839ab1600d4eb1c4c33ec5a8edfbc5cb42dafa13b81f182f97784b45",
"sha256:8569982d3f0889eed11dd620c706d39b60c36d6d25843961f33f77fb6bc6b20c"
],
"markers": "python_version >= '3.6'",
"version": "==3.0.2"
},
Comment on lines +119 to +126
"werkzeug": {
"hashes": [
"sha256:63d3dc1cf60e7b7e35e97fa9861f7397283b75d765afcaefd993d6046899de8f",
"sha256:aa2bb6fc8dee8d6c504c0ac1e7f5f7dc5810a9903e793b6f715a9f015bdadb9a"
],
"markers": "python_version >= '3.6'",
"version": "==2.0.2"
}
Comment on lines +119 to +126
"werkzeug": {
"hashes": [
"sha256:63d3dc1cf60e7b7e35e97fa9861f7397283b75d765afcaefd993d6046899de8f",
"sha256:aa2bb6fc8dee8d6c504c0ac1e7f5f7dc5810a9903e793b6f715a9f015bdadb9a"
],
"markers": "python_version >= '3.6'",
"version": "==2.0.2"
}
Comment on lines +119 to +126
"werkzeug": {
"hashes": [
"sha256:63d3dc1cf60e7b7e35e97fa9861f7397283b75d765afcaefd993d6046899de8f",
"sha256:aa2bb6fc8dee8d6c504c0ac1e7f5f7dc5810a9903e793b6f715a9f015bdadb9a"
],
"markers": "python_version >= '3.6'",
"version": "==2.0.2"
}
Comment on lines +119 to +126
"werkzeug": {
"hashes": [
"sha256:63d3dc1cf60e7b7e35e97fa9861f7397283b75d765afcaefd993d6046899de8f",
"sha256:aa2bb6fc8dee8d6c504c0ac1e7f5f7dc5810a9903e793b6f715a9f015bdadb9a"
],
"markers": "python_version >= '3.6'",
"version": "==2.0.2"
}
Comment on lines +119 to +126
"werkzeug": {
"hashes": [
"sha256:63d3dc1cf60e7b7e35e97fa9861f7397283b75d765afcaefd993d6046899de8f",
"sha256:aa2bb6fc8dee8d6c504c0ac1e7f5f7dc5810a9903e793b6f715a9f015bdadb9a"
],
"markers": "python_version >= '3.6'",
"version": "==2.0.2"
}
Comment on lines +27 to +34
"flask": {
"hashes": [
"sha256:7b2fb8e934ddd50731893bdcdb00fc8c0315916f9fcd50d22c7cc1a95ab634e2",
"sha256:cb90f62f1d8e4dc4621f52106613488b5ba826b2e1e10a33eac92f723093ab6a"
],
"index": "pypi",
"version": "==2.0.2"
},
Comment on lines +119 to +126
"werkzeug": {
"hashes": [
"sha256:63d3dc1cf60e7b7e35e97fa9861f7397283b75d765afcaefd993d6046899de8f",
"sha256:aa2bb6fc8dee8d6c504c0ac1e7f5f7dc5810a9903e793b6f715a9f015bdadb9a"
],
"markers": "python_version >= '3.6'",
"version": "==2.0.2"
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants