You've already forked OpenShorte.old
							
							
		
			
				
	
	
		
			172 lines
		
	
	
		
			9.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			172 lines
		
	
	
		
			9.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
    if ( file_exists ( 'config.json' ) ) {
 | 
						|
        header ( "Location: " . substr ( $_SERVER [ 'SCRIPT_NAME' ], 0, -10 ) . "/" );
 | 
						|
    }
 | 
						|
    if ( isset ( $_POST [ 'site_name' ] ) && isset ( $_POST [ 'db_host' ] ) && isset ( $_POST [ 'db_port' ] ) && isset ( $_POST [ 'db_username' ] ) && isset ( $_POST [ 'db_password' ] ) && isset ( $_POST [ 'db_name' ] ) ) {
 | 
						|
        $config = [
 | 
						|
            'installed' => true,
 | 
						|
            'website_name' => $_POST [ 'site_name' ],
 | 
						|
            'db' => [
 | 
						|
                'host' => $_POST [ 'db_host' ],
 | 
						|
                'port' => (integer) $_POST [ 'db_port' ],
 | 
						|
                'username' => $_POST [ 'db_username' ],
 | 
						|
                'password' => $_POST [ 'db_password' ],
 | 
						|
                'name' => $_POST [ 'db_name' ],
 | 
						|
            ],
 | 
						|
            'installation_path' => substr ( $_SERVER [ 'SCRIPT_NAME' ], 0, -10 ),
 | 
						|
            'domain' => $_SERVER [ 'HTTP_HOST' ],
 | 
						|
        ];
 | 
						|
        file_put_contents ( 'config.json', json_encode ( $config ) );
 | 
						|
        try {
 | 
						|
            $database = new PDO ( "mysql:dbname=" . $config [ 'db' ] [ 'name' ] . ";host=" . $config [ 'db' ] [ 'host' ] . ":" . $config [ 'db' ] [ 'port' ], $config [ 'db' ] [ 'username' ], $config [ 'db' ] [ 'password' ] );
 | 
						|
        }
 | 
						|
        catch ( PDOException $exception ) {
 | 
						|
            unlink ( "config.json" );
 | 
						|
            http_response_code ( 400 );
 | 
						|
            header ( 'Content-Type: application/json' );
 | 
						|
            echo ( json_encode ( [ 'status' => 400, 'message' => $exception->getMessage ( ) ] ) );
 | 
						|
            exit;
 | 
						|
        }
 | 
						|
        $query = "CREATE TABLE IF NOT EXISTS `users` ( `ID` BIGINT(20) UNSIGNED NOT NULL AUTO_INCREMENT, `username` VARCHAR(50) NOT NULL COLLATE 'utf8mb4_bin', `password` VARCHAR(128) NOT NULL COLLATE 'utf8mb4_bin', PRIMARY KEY (`ID`) ) COLLATE='utf8mb4_bin' ENGINE=InnoDB; CREATE TABLE IF NOT EXISTS `links` ( `ID` BIGINT(20) UNSIGNED NOT NULL AUTO_INCREMENT, `URL` VARCHAR(50) NOT NULL COLLATE 'utf8mb4_bin', `created_by` BIGINT(20) UNSIGNED NOT NULL, PRIMARY KEY (`ID`), INDEX `links.created_by` (`created_by`), CONSTRAINT `links.created_by` FOREIGN KEY (`created_by`) REFERENCES `users` (`ID`) ON UPDATE CASCADE ON DELETE CASCADE ) COLLATE='utf8mb4_bin' ENGINE=InnoDB;";
 | 
						|
        $database->query ( $query );
 | 
						|
        header ( 'Content-Type: application/json' );
 | 
						|
        echo ( json_encode ( [ 'status' => 200, 'message' => 'Installation completed!<br>You will be redirected to the home page in 5 seconds.', 'homelocation' => $config [ 'installation_path' ] ] ) );
 | 
						|
        exit;
 | 
						|
    }
 | 
						|
    else {
 | 
						|
?>
 | 
						|
<DOCTYPE HTML>
 | 
						|
    <html>
 | 
						|
 | 
						|
        <head>
 | 
						|
            <meta charset="UTF-8">
 | 
						|
            <title>Installer | OpenShorte</title>
 | 
						|
            <link href="./favicon.ico" rel="icon" type="image/x-icon">
 | 
						|
            <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0/css/bootstrap.min.css" integrity="sha384-Gn5384xqQ1aoWXA+058RXPxPg6fy4IWvTNh0E263XmFcJlSAwiGgFAW/dAiS6JXm" crossorigin="anonymous">
 | 
						|
            <style>
 | 
						|
            .centered-container {
 | 
						|
                border: solid;
 | 
						|
                border-radius: 25px;
 | 
						|
                border-color: #ABABAB;
 | 
						|
            }
 | 
						|
 | 
						|
            </style>
 | 
						|
        </head>
 | 
						|
 | 
						|
        <body>
 | 
						|
            <div class="mx-auto my-5 col-sm-8 col-md-6 col-xl-4 centered-container">
 | 
						|
                <div class="my-2"></div>
 | 
						|
                <section id="section_welcome">
 | 
						|
                    <p>
 | 
						|
                        Welcome to the OpenShorte installer.<br>
 | 
						|
                        Since it seems that there are no installation found for this website, we'll proceed now with creating one.<br>
 | 
						|
                        Please click 'Next' and provide all the necessary informations for the database and the site name in order to let this website work correctly.
 | 
						|
                    </p>
 | 
						|
                    <button id="btn_next_sitename" class="btn btn-secondary">Next</button>
 | 
						|
                </section>
 | 
						|
                <section id="section_sitename">
 | 
						|
                    <form class="form form-inline">
 | 
						|
                        <div class="input-group col-sm-7 mx-auto">
 | 
						|
                            <div class="input-group-prepend">
 | 
						|
                                <span class="input-group-text" id="sitename_label">Website Name:</span>
 | 
						|
                            </div>
 | 
						|
                            <input type="text" class="form-control" aria-describedby="sitename_label" id="site_name" required>
 | 
						|
                        </div>
 | 
						|
                    </form>
 | 
						|
                    <button id="btn_next_dbdata" class="btn btn-secondary">Next</button>
 | 
						|
                </section>
 | 
						|
                <section id="section_dbdata">
 | 
						|
                    <form class="form form-inline">
 | 
						|
                        <div class="input-group col-sm-7 mx-auto">
 | 
						|
                            <div class="input-group-prepend">
 | 
						|
                                <span class="input-group-text" id="dbdata_label-1">Host:</span>
 | 
						|
                            </div>
 | 
						|
                            <input type="text" class="form-control" aria-describedby="dbdata_label-1" id="db_host" required>
 | 
						|
                        </div>
 | 
						|
                        <div class="input-group col-sm-5 mx-auto">
 | 
						|
                            <div class="input-group-prepend">
 | 
						|
                                <span class="input-group-text" id="dbdata_label-2">Port:</span>
 | 
						|
                            </div>
 | 
						|
                            <input type="text" class="form-control" aria-describedby="dbdata_label-2" id="db_port" required>
 | 
						|
                        </div>
 | 
						|
                    </form>
 | 
						|
                    <form class="form">
 | 
						|
                        <div class="input-group col-sm-12 mx-auto">
 | 
						|
                            <div class="input-group-prepend">
 | 
						|
                                <span class="input-group-text" id="dbdata_label-3">Username:</span>
 | 
						|
                            </div>
 | 
						|
                            <input type="text" class="form-control" aria-describedby="dbdata_label-3" id="db_username" required>
 | 
						|
                        </div>
 | 
						|
                        <div class="input-group col-sm-12 mx-auto">
 | 
						|
                            <div class="input-group-prepend">
 | 
						|
                                <span class="input-group-text" id="dbdata_label-5">Password:</span>
 | 
						|
                            </div>
 | 
						|
                            <input type="password" class="form-control" aria-describedby="dbdata_label-5" id="db_password" required>
 | 
						|
                        </div>
 | 
						|
                        <div class="input-group col-sm-12 mx-auto">
 | 
						|
                            <div class="input-group-prepend">
 | 
						|
                                <span class="input-group-text" id="dbdata_label-6">Repeat Password:</span>
 | 
						|
                            </div>
 | 
						|
                            <input type="password" class="form-control" aria-describedby="dbdata_label-6" id="db_confirmpassword" required>
 | 
						|
                        </div>
 | 
						|
                        <div class="input-group col-sm-12 mx-auto">
 | 
						|
                            <div class="input-group-prepend">
 | 
						|
                                <span class="input-group-text" id="dbdata_label-4">Database Name:</span>
 | 
						|
                            </div>
 | 
						|
                            <input type="text" class="form-control" aria-describedby="dbdata_label-4" id="db_name" required>
 | 
						|
                        </div>
 | 
						|
                    </form>
 | 
						|
                    <button id="btn_next_complete" class="btn btn-secondary">Next</button>
 | 
						|
                </section>
 | 
						|
                <section id="section_complete">
 | 
						|
                    <div class="mx-auto"></div>
 | 
						|
                </section>
 | 
						|
                <div class="my-2"></div>
 | 
						|
            </div>
 | 
						|
            <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js" integrity="sha256-FgpCb/KJQlLNfOu91ta32o/NMZxltwRo8QtmkMRdAu8=" crossorigin="anonymous"></script>
 | 
						|
            <script>
 | 
						|
            $('section:not(#section_welcome)').hide();
 | 
						|
            $('#btn_next_sitename').click(function() {
 | 
						|
                $('section').hide();
 | 
						|
                $('#section_sitename').show();
 | 
						|
            });
 | 
						|
            $('#btn_next_dbdata').click(function() {
 | 
						|
                $('section').hide();
 | 
						|
                $('#section_dbdata').show();
 | 
						|
            });
 | 
						|
            $('#btn_next_complete').click(function() {
 | 
						|
                if ($('#db_password').val() == $('#db_confirmpassword').val()) {
 | 
						|
                    $.ajax({
 | 
						|
                        method: "POST",
 | 
						|
                        datatype: "JSON",
 | 
						|
                        data: {
 | 
						|
                            site_name: $('#site_name').val(),
 | 
						|
                            db_host: $('#db_host').val(),
 | 
						|
                            db_port: $('#db_port').val(),
 | 
						|
                            db_username: $('#db_username').val(),
 | 
						|
                            db_password: $('#db_password').val(),
 | 
						|
                            db_name: $('#db_name').val(),
 | 
						|
                        },
 | 
						|
                        success: function(data) {
 | 
						|
                            if (data.status == 200) {
 | 
						|
                                $('section').hide();
 | 
						|
                                $('#section_complete').show();
 | 
						|
                                $('#section_complete div').html(data.message);
 | 
						|
                                setInterval(function() {
 | 
						|
                                    window.location.href = data.homelocation;
 | 
						|
                                }, 5000);
 | 
						|
                            }
 | 
						|
                        },
 | 
						|
                        error: function(xhr, ajaxOptions, thrownError) {
 | 
						|
                            alert(xhr.responseText.message);
 | 
						|
                        }
 | 
						|
                    });
 | 
						|
                }
 | 
						|
            });
 | 
						|
            </script>
 | 
						|
        </body>
 | 
						|
 | 
						|
    </html>
 | 
						|
    <?php
 | 
						|
    }
 |