Add unsafe login docker image
This commit is contained in:
		@@ -2,4 +2,4 @@
 | 
			
		||||
 | 
			
		||||
Appliances used to build GNS3 labs.
 | 
			
		||||
 | 
			
		||||
This images are freely inspired from [Chewie's](https://github.com/Chewie/gns3-docker-appliances) ones
 | 
			
		||||
These images are freely inspired from [Chewie's](https://github.com/Chewie/gns3-docker-appliances) ones
 | 
			
		||||
							
								
								
									
										4
									
								
								unsafe_login/Dockerfile
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								unsafe_login/Dockerfile
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,4 @@
 | 
			
		||||
FROM php:8.3-apache
 | 
			
		||||
COPY src/ /var/www/html/
 | 
			
		||||
 | 
			
		||||
ENV FLAG=CHANGEME
 | 
			
		||||
							
								
								
									
										8
									
								
								unsafe_login/README.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								unsafe_login/README.md
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,8 @@
 | 
			
		||||
# Unsafe login challenge
 | 
			
		||||
You need to set the `FLAG` environment variable for this challenge to work!
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
## Run the image
 | 
			
		||||
```bash
 | 
			
		||||
docker run --rm --name unsafe_login --env FLAG='FLAG{EASYINJECTION}' -p 3565:80 -it pierre42100/gns3-appliance-unsafe-login
 | 
			
		||||
```
 | 
			
		||||
							
								
								
									
										1
									
								
								unsafe_login/build.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								unsafe_login/build.sh
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1 @@
 | 
			
		||||
sudo docker build -t pierre42100/gns3-appliance-unsafe-login .
 | 
			
		||||
							
								
								
									
										6
									
								
								unsafe_login/src/bootstrap.min.css
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								unsafe_login/src/bootstrap.min.css
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								unsafe_login/src/database.db
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								unsafe_login/src/database.db
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										220
									
								
								unsafe_login/src/index.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										220
									
								
								unsafe_login/src/index.php
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,220 @@
 | 
			
		||||
<?php
 | 
			
		||||
session_start();
 | 
			
		||||
 | 
			
		||||
$user = NULL;
 | 
			
		||||
 | 
			
		||||
// First, connect to database
 | 
			
		||||
try
 | 
			
		||||
{
 | 
			
		||||
    $db = new PDO('sqlite:'.__DIR__.'/database.db');
 | 
			
		||||
}
 | 
			
		||||
catch (PDOException $e)
 | 
			
		||||
{
 | 
			
		||||
  echo 'Connection to database failed: ' . $e->getMessage();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Check if user requested to be signed out
 | 
			
		||||
if(isset($_GET['sign_out']))
 | 
			
		||||
{
 | 
			
		||||
    unset($_SESSION["user"]);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
// Check for authentication
 | 
			
		||||
if(isset($_POST["user"]) && isset($_POST["password"]))
 | 
			
		||||
{
 | 
			
		||||
    $username = $_POST["user"];
 | 
			
		||||
    $password_hash = hash("sha512", $_POST["password"]);
 | 
			
		||||
 | 
			
		||||
    $query = "SELECT * FROM users WHERE user = '$username' AND password = '$password_hash'";
 | 
			
		||||
    $stmt = $db->prepare($query);
 | 
			
		||||
    $stmt->execute(array());
 | 
			
		||||
 | 
			
		||||
    $res = $stmt->fetchAll();
 | 
			
		||||
 | 
			
		||||
    if(count($res) === 0)
 | 
			
		||||
        $error = "The specified credentials are invalid!";
 | 
			
		||||
 | 
			
		||||
    else {
 | 
			
		||||
        $_SESSION["user"] = $res[0]["id"];
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
if(isset($_SESSION["user"]))
 | 
			
		||||
{
 | 
			
		||||
    // Extract current user information
 | 
			
		||||
    $stmt = $db->prepare("SELECT * FROM users WHERE id = ?");
 | 
			
		||||
    $stmt->execute(array($_SESSION["user"]));
 | 
			
		||||
    $user = $stmt->fetchAll()[0];
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
?><!doctype html>
 | 
			
		||||
<html lang="en" data-bs-theme="auto">
 | 
			
		||||
  <head>
 | 
			
		||||
 | 
			
		||||
    <meta charset="utf-8">
 | 
			
		||||
    <meta name="viewport" content="width=device-width, initial-scale=1">
 | 
			
		||||
    <title>Safesys</title>
 | 
			
		||||
 | 
			
		||||
    <link href="/bootstrap.min.css" rel="stylesheet" integrity="sha384-QWTKZyjpPEjISv5WaRU9OFeRpok6YctnYmDr5pNlyT2bRjXh0JMhjY6hW+ALEwIH" crossorigin="anonymous">
 | 
			
		||||
 | 
			
		||||
    <style>
 | 
			
		||||
        html,
 | 
			
		||||
    body {
 | 
			
		||||
    height: 100%;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    .form-signin {
 | 
			
		||||
    max-width: 330px;
 | 
			
		||||
    padding: 1rem;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    .form-signin .form-floating:focus-within {
 | 
			
		||||
    z-index: 2;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    .form-signin input[type="email"] {
 | 
			
		||||
    margin-bottom: -1px;
 | 
			
		||||
    border-bottom-right-radius: 0;
 | 
			
		||||
    border-bottom-left-radius: 0;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    .form-signin input[type="password"] {
 | 
			
		||||
    margin-bottom: 10px;
 | 
			
		||||
    border-top-left-radius: 0;
 | 
			
		||||
    border-top-right-radius: 0;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
      .bd-placeholder-img {
 | 
			
		||||
        font-size: 1.125rem;
 | 
			
		||||
        text-anchor: middle;
 | 
			
		||||
        -webkit-user-select: none;
 | 
			
		||||
        -moz-user-select: none;
 | 
			
		||||
        user-select: none;
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      @media (min-width: 768px) {
 | 
			
		||||
        .bd-placeholder-img-lg {
 | 
			
		||||
          font-size: 3.5rem;
 | 
			
		||||
        }
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      .b-example-divider {
 | 
			
		||||
        width: 100%;
 | 
			
		||||
        height: 3rem;
 | 
			
		||||
        background-color: rgba(0, 0, 0, .1);
 | 
			
		||||
        border: solid rgba(0, 0, 0, .15);
 | 
			
		||||
        border-width: 1px 0;
 | 
			
		||||
        box-shadow: inset 0 .5em 1.5em rgba(0, 0, 0, .1), inset 0 .125em .5em rgba(0, 0, 0, .15);
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      .b-example-vr {
 | 
			
		||||
        flex-shrink: 0;
 | 
			
		||||
        width: 1.5rem;
 | 
			
		||||
        height: 100vh;
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      .bi {
 | 
			
		||||
        vertical-align: -.125em;
 | 
			
		||||
        fill: currentColor;
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      .nav-scroller {
 | 
			
		||||
        position: relative;
 | 
			
		||||
        z-index: 2;
 | 
			
		||||
        height: 2.75rem;
 | 
			
		||||
        overflow-y: hidden;
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      .nav-scroller .nav {
 | 
			
		||||
        display: flex;
 | 
			
		||||
        flex-wrap: nowrap;
 | 
			
		||||
        padding-bottom: 1rem;
 | 
			
		||||
        margin-top: -1px;
 | 
			
		||||
        overflow-x: auto;
 | 
			
		||||
        text-align: center;
 | 
			
		||||
        white-space: nowrap;
 | 
			
		||||
        -webkit-overflow-scrolling: touch;
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      .btn-bd-primary {
 | 
			
		||||
        --bd-violet-bg: #712cf9;
 | 
			
		||||
        --bd-violet-rgb: 112.520718, 44.062154, 249.437846;
 | 
			
		||||
 | 
			
		||||
        --bs-btn-font-weight: 600;
 | 
			
		||||
        --bs-btn-color: var(--bs-white);
 | 
			
		||||
        --bs-btn-bg: var(--bd-violet-bg);
 | 
			
		||||
        --bs-btn-border-color: var(--bd-violet-bg);
 | 
			
		||||
        --bs-btn-hover-color: var(--bs-white);
 | 
			
		||||
        --bs-btn-hover-bg: #6528e0;
 | 
			
		||||
        --bs-btn-hover-border-color: #6528e0;
 | 
			
		||||
        --bs-btn-focus-shadow-rgb: var(--bd-violet-rgb);
 | 
			
		||||
        --bs-btn-active-color: var(--bs-btn-hover-color);
 | 
			
		||||
        --bs-btn-active-bg: #5a23c8;
 | 
			
		||||
        --bs-btn-active-border-color: #5a23c8;
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      .bd-mode-toggle {
 | 
			
		||||
        z-index: 1500;
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      .bd-mode-toggle .dropdown-menu .active .bi {
 | 
			
		||||
        display: block !important;
 | 
			
		||||
      }
 | 
			
		||||
    </style>    
 | 
			
		||||
  </head>
 | 
			
		||||
  <body class="d-flex align-items-center py-4 bg-body-tertiary">    
 | 
			
		||||
<main class="form-signin w-100 m-auto">
 | 
			
		||||
<?php
 | 
			
		||||
    if($user === NULL) {
 | 
			
		||||
        ?><form method="POST" action="/">
 | 
			
		||||
            <?php
 | 
			
		||||
                if(isset($error))
 | 
			
		||||
                {
 | 
			
		||||
                    ?><div class="alert alert-danger">
 | 
			
		||||
                        <?=$error?>
 | 
			
		||||
                    </div><?php
 | 
			
		||||
                }
 | 
			
		||||
            ?>
 | 
			
		||||
 | 
			
		||||
        <h1 class="h3 mb-3 fw-normal">Please sign in</h1>
 | 
			
		||||
 | 
			
		||||
        <div class="form-floating">
 | 
			
		||||
        <input type="user" class="form-control" id="floatingInput" placeholder="user" name="user" required />
 | 
			
		||||
        <label for="floatingInput">Username</label>
 | 
			
		||||
        </div>
 | 
			
		||||
        <div class="form-floating">
 | 
			
		||||
        <input type="password" class="form-control" id="floatingPassword" placeholder="Password" name="password" required />
 | 
			
		||||
        <label for="floatingPassword">Password</label>
 | 
			
		||||
        </div>
 | 
			
		||||
 | 
			
		||||
        <div class="form-check text-start my-3">
 | 
			
		||||
        <input class="form-check-input" type="checkbox" value="remember-me" id="flexCheckDefault">
 | 
			
		||||
        <label class="form-check-label" for="flexCheckDefault">
 | 
			
		||||
            Remember me
 | 
			
		||||
        </label>
 | 
			
		||||
        </div>
 | 
			
		||||
        <button class="btn btn-primary w-100 py-2" type="submit">Sign in</button>
 | 
			
		||||
        <p class="mt-5 mb-3 text-body-secondary">© 2025 Safesys</p>
 | 
			
		||||
        </form><?php
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    else {
 | 
			
		||||
        ?><h3>Welcome <?=$user['user']?>! <a href='/?sign_out=1'>Sign out</a></h3><?php
 | 
			
		||||
 | 
			
		||||
        if($user["is_admin"]) {
 | 
			
		||||
            ?><div class="alert alert-success">
 | 
			
		||||
            Hey admin ! You can access the secret value: <?=getenv("FLAG")?>
 | 
			
		||||
        </div><?php
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        else {
 | 
			
		||||
            ?><div class="alert alert-light">
 | 
			
		||||
                You are not an administrator, you cannot access privileged information!
 | 
			
		||||
            </div><?php
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
?></main>
 | 
			
		||||
    </body>
 | 
			
		||||
</html>
 | 
			
		||||
		Reference in New Issue
	
	Block a user