summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAnton Šijanec <sijanecantonluka@gmail.com>2019-09-18 00:23:31 +0200
committerGitHub <noreply@github.com>2019-09-18 00:23:31 +0200
commitfb7b3ef8722233365fe2bc39c42345ee98bb829b (patch)
tree6bb3ee755764626a6ac1203e6cb9bcae1ae7276d
parentupdated nginx-server.conf (diff)
downloadbalkan-shortlink-fb7b3ef8722233365fe2bc39c42345ee98bb829b.tar
balkan-shortlink-fb7b3ef8722233365fe2bc39c42345ee98bb829b.tar.gz
balkan-shortlink-fb7b3ef8722233365fe2bc39c42345ee98bb829b.tar.bz2
balkan-shortlink-fb7b3ef8722233365fe2bc39c42345ee98bb829b.tar.lz
balkan-shortlink-fb7b3ef8722233365fe2bc39c42345ee98bb829b.tar.xz
balkan-shortlink-fb7b3ef8722233365fe2bc39c42345ee98bb829b.tar.zst
balkan-shortlink-fb7b3ef8722233365fe2bc39c42345ee98bb829b.zip
-rw-r--r--index.php464
1 files changed, 316 insertions, 148 deletions
diff --git a/index.php b/index.php
index 2d0324f..9397b89 100644
--- a/index.php
+++ b/index.php
@@ -1,67 +1,255 @@
<?php
-// OPOZORILA: PROGRAM MORA BITI NUJNO POD IMENOM index.php IN POGANJATI SE MORA POD Apache 2, ki podpria RewriteEngine, Imeti moraš SQL uporabnika in bazo,
-// .htaccess mora delati, potrebno je imeti dovoljenja za pisanje v mapo. .htaccess ob prvem zagonu ne sme
-// obstajati, naredi se sam. NUJNO MORATE SKOPIRATI MAPO securimage iz phpcaptcha.org/download/ zraven index.php, drugače captcha ne bo delala.
+// OPOZORILA: PROGRAM MORA BITI NUJNO POD IMENOM index.php IN POGANJATI SE MORA POD Apache 2, ki podpria RewriteEngine,
+// ali pa, še bolše, s HTTp strežnikom nginx (ker je boljši). Če uporabite Apache, uporabite .htacess datoteko, za nginx pa uporabite priložen nginx conf fajl.
+// Imeti moraš SQL uporabnika in bazo,
// (C) 2019 Anton Šijanec.
+// inštalacija potrebuje composer. inštalirajte required dependence (dapphp/securimage)
// Uporaba dovoljena za učenje in za nekomercijalne namene, brez zaslužkov in z navedbo avtorja. Hvala!
// exit("Balkan ŠortLink je v pripravi. Pripravljen bo čez okoli 2 dni. Anton Šijanec, Projekt začet 20. januarja, predviden čas začetka obratovanja storitve
-// je 23. januar 2019. Program bo odprtokoden in dostopen na mojem GitHubu, AstiriL!");
+// je 23. januar 2019. Program bo odprtokoden in dostopen na mojem GitHub.com/sijanec/balkan-shortlink!");
session_start();
clearstatcache();
-// ini_set('display_errors', 'On'); // debug
-// error_reporting(E_ALL); // debug
+// ini_set('display_errors', 'On'); //debug
+// error_reporting(E_ALL); //debug
$nadaljuj = "ja";
-include_once $_SERVER['DOCUMENT_ROOT'] . '/securimage/securimage.php';
+require_once $_SERVER['DOCUMENT_ROOT'] . '/vendor/autoload.php';
$securimage = new Securimage();
-$verzija = "0.0.19.01.21";
+$verzija = "0.1.19.09.18";
$log .= "Verzija: " . $verzija . "\n";
// definicije - uporabniškega vnosa ne preverjam, zato si ne naredite sql vrivanja (angl. sql injection) ali vrinjanja skript (ni htmlchars sanitizacije).
// drugače pa je program dokaj varen prej vrivanjem... upajmo... vsi ostali uporabniški vnosi so sanitizirani.
-$servername = "lol.u.though.i.will.show.a4l.space"; // domena, IP naslov oziroma ime gostitelja za dostop do MySQL ali ekvivalentne SQL podatkovne baze (strežnika)
-$username = "nofreesqlforyou"; // uporabniško ime za dostop do strežnika SQL
-$password = "donttrytoconnect"; // geslo za dostop do strežnika SQL
-$baza = "itdoesntwork"; // podatkovna baza SQL v katero naj pišem - naredi jo pred zagonom programa
-$tabela = "srslyitdoesnt"; // tabela, ki naj jo naredim v podatkovni bazi SQL oziroma tabela v podatkovni bazi SQL, ki naj jo uporabljam
-$rxshort = "/^[0-9a-z]{1,6}$/"; // angleško regular expression, ki naj ga uporabim za kratek niz - nujno popravi še besedilne opise. Pusti ga takega, kot je!
-$domena = "š.ga"; // tvoja domena
+$servername = "127.0.0.1"; // domena, IP naslov oziroma ime gostitelja za dostop do MySQL ali ekvivalentne SQL podatkovne baze (strežnika)
+$username = "shortlink"; // uporabniško ime za dostop do strežnika SQL
+$password = "pesvort"; // geslo za dostop do strežnika SQL
+$baza = "shortlink"; // podatkovna baza SQL v katero naj pišem - naredi jo pred zagonom programa
+$tabela = "links"; // tabela, ki naj jo naredim v podatkovni bazi SQL oziroma tabela v podatkovni bazi SQL, ki naj jo uporabljam
+$maxlenght = 9;
+$rxshort = "/^[0-9a-z]{1,".$maxlenght."}$/"; // angleško regular expression, ki naj ga uporabim za kratek niz - nujno popravi še besedilne opise. Pusti ga takega, kot je!
+$domena = $_SERVER['HTTP_HOST']; // tvoja domena
+switch($domena){
+ case "xn--pga.ga":
+ $domena = "š.ga";
+ break;
+ case "xn--oda.ga":
+ $domena = "÷.ga";
+ break;
+ case "xn--e1a.ga":
+ $domena = "е.ga";
+ break;
+}
$captcha = "ja"; // ja/ne: ali naj uporabljam captcho? potrebujete phpcaptcha.org, mapo securimage skopirajte zraven index.php (tega programa).
+$kljuc = "antoniolukas"; // api kljuc, da bi treba captche
+if($_SERVER['HTTP_HOST'] == "xn--pga.ga") {
+ $securimage_folder_missing = "securimage mapa z datotekami za captcho ne obstaja. Naložite jo iz phpcaptcha.org/download in jo postavite zraven index.php, ali pa spremenite
+ nastavitev captcha v konfiguracijah (definicije) iz ja na ne (ne priporočam).\n";
+ $dbconn_error = "<pre>Povezava v podatkovno bazo ni uspela. <!-- Razhroščevanje: ";
+ $dbconn_success = "Povezava v podatkovno bazo uspešna.\n";
+ $dbuse_success = "Izbira podatkovne baze uspešna.\n";
+ $dbuse_error = "Podatkovne baze ni bilo mogoče izbrati. <!-- Razhroščevanje: ";
+ $tableexists = "Tabela v podatkovni bazi obstaja. Program je že bil v uporabi.\n";
+ $tablenotexists = "Tabela v podatkovni bazi ne obstaja. Program je bil zagnan prvič. Poskusil jo bom narediti.\n";
+ $dbtablecreate_success = "Tabela v podatkovni bazi je bila uspešno narejena.\n";
+ $dbtablecreate_error = "<pre>Napaka v izdelavi tabele v podatkovni bazi! <!-- razhroščevanje: ";
+ $shortlink_notexists = "Kratek URL še ne obstaja v podatkovni bazi.\n";
+ $shortlink_notexists_ui = "<div class=alert>
+ <span class=closebtn onclick=this.parentElement.style.display='none';>&times;</span>
+<b>Napaka!</b> Kratek URL še ne obstaja v podatkovni bazi.
+</div><br>";
+ $form_sent = "Obrazec je bil izpolnjen, začenjam preverjanje vnosa.";
+ $captcha_error = "Preverjanje človeštva (CAPTCHA) je negativno. Mogoče niste človek, zato ne bom nadaljeval.";
+ $captcha_error_ui = "<div class=alert>
+ <span class=closebtn onclick=this.parentElement.style.display='none';>&times;</span>
+<b>Napaka preverjanja!</b> Preverjanje CAPTCHA je pokazalo negativni rezultat. Mogoče niste človek, zato ne bom nadaljeval.
+</div><br>";
+ $shortlinkregex_success = "Preverjanje krajšalnega niza je pozitivno. Krajševalni niz se lahko uporabi.\n";
+ $captcha_success = "Preverjanje človeštva (CAPTCHA) je pozitivno. Človek ste.";
+ $shortlinkregex_error = "Krajšalni niz se ne ujema z regexom " . $rxshort . ", zato ne bom nadaljeval.\n";
+ $shortlinkregex_error_ui = "<div class=alert>
+ <span class=closebtn onclick=this.parentElement.style.display='none';>&times;</span>
+<b>Napaka vnosa!</b> Krajševalni niz se ne ujema z njegovimi pravili. Mora biti 1 do ".$maxlenght." znakov dolg in lahko vsebuje male črke in številke.
+</div><br>";
+ $longurlregex_success = "Preverjanje dolgega URL-ja je pozitivno. Dolg URL se lahko uporabi.\n";
+ $longurlregex_error = "Preverjanje dolgega URL-ja je negativno, zato ne bom nadeljeval.\n";
+ $longurlregex_error_ui = "<div class=alert>
+ <span class=closebtn onclick=this.parentElement.style.display='none';>&times;</span>
+<b>Napaka vnosa!</b> Dolg URL se ne ujema z standardi. Poskusite ponovno. Posebni znaki v URL-ju (kot na primer š) morajo biti URL kodirani.
+</div><br>";
+ $longurl_too_long = "Dolg URL je predolg. Mora biti krajši od 767 bajtov, drugače lahko pride do napak v podatkovni bazi.\n";
+ $longurl_too_long_ui = "<div class=alert>
+ <span class=closebtn onclick=this.parentElement.style.display='none';>&times;</span>
+<b>Napaka vnosa!</b> URL je predolg. Mora biti krajši od 767 bajtov.
+</div><br>";
+ $longurl_not_too_long = "Dolg URL ni predolg. To je v redu.\n";
+ $shortlink_free_error_ui = "<div class=alert>
+ <span class=closebtn onclick=this.parentElement.style.display='none';>&times;</span>
+<b>Napaka!</b> Krajšalni tekst že obstaja v podatkovni bazi. Izberite drugega.
+</div><br>";
+ $shortlink_free_error = "Krajševalni tekst že obstaja v podatkovni bazi, zato ne morem nadaljevati.\n";
+ $shortlink_free = "Krajševalni tekst še ne obstaja v podatkovni bazi. To je v redu.\n";
+ $longurl_free_error_ui = "<div class=alert>
+ <span class=closebtn onclick=this.parentElement.style.display='none';>&times;</span>
+<b>Napaka!</b> Dolg URL že obstaja v podatkovni bazi. Nanj kaže <b>";
+ $longurl_free_error = "Dolg URL že obstaja v podatkovni bazi, zato ne morem nadaljevati.\n";
+ $longurl_free_success = "Dolg URL še ne obstaja v podatkovni bazi. To je v redu.\n";
+ $url_was_not_shortened_error = "URL ni bil okrajšan. Glej napake zgoraj!";
+ $unknown_database_error_ui = "<div class=alert>
+ <span class=closebtn onclick=this.parentElement.style.display='none';>&times;</span>
+<b>Sistemska napaka!</b> Neznana napaka podatkovne baze.
+</div><br>";
+ $unknown_database_error = "Neznana napaka podatkovne baze. Glej sistemske dnevnike.\n";
+ $shortlink_success_ui = "<div class=alertok>
+ <span class=closebtn onclick=this.parentElement.style.display='none';>&times;</span>
+<b>Uspešno!</b> Šortlink <b>".$domena."/".htmlspecialchars($_REQUEST['short'])."</b> je bil uspešno narejen!
+</div><br>";
+ $shortlink_success = "Šortlink ".$domena."/".htmlspecialchars($_REQUEST['short'])." je bil uspešno narejen!\n";
+ $form_not_sent = "Obrazec ni bil izpolnjen, zato samo prikazujem stran.\n";
+ $title = "ŠortLink Balkan š.ga";
+ $subtitle = "<h2 align=center>Ste kdaj hoteli narediti iz dolgega linka ŠortLink tako, da bi izgledal bolj balkansko?</h2>
+<h2 align=center>Tudi če niste, je tukaj ŠortLink Balkan, edini Link Šortener, namenjen predvsem slovanskim narodom, saj za njegovo uporabo potrebujete črko Š!</h2>
+<h3 align=center>Vsi Šortani linki se bodo začeli z š.ga, na primer š.ga/tekst. Najs ane?</h3>
+<h4 align=center>Šortlinker deluje v kooperaciji z ÷.ga šortlinkerjem (internacionalizirana verzija tega). Vsi šortani linki,
+izdelani na ÷.ga bodo delovali tudi na š.ga in obratno. Za angleško različico odprite <a href=https://÷.ga/>÷.ga</a>.</h4>";
+ $longurl_placeholder = "Vpiši dolg URL";
+ $shortexpression_placeholder = "Vpiši krajšalnico";
+ $captcha_placeholder = "Prepiši znake";
+ $submit_value = "Skrajšaj";
+ $insecure_warning = "OPOZORILO: Povezan si preko nešifrirane povezave.";
+ $secure_connection = "Varna povezava je vzpostavljena.";
+ $cookie_warning = "ŠortLink Balkan za svoje delovanje potrebuje in uporablja sejne piškotke. Z uporabo storitve se strinajte z shranjevanjem piškotkov
+v vaš brskalnik za največ 24 minut. Piškotek se uporablja samo za interni namen, torej za to, da izvemo katere črke si imel na preverjanju za ljudi (CAPTCHA)
+in nikakor ne za namene vohunjenja (tracking cookies). Piškotki so vidni samo na domeni š.ga, torej samo našemu strežniku. To sporočilo smo vam po veljavnem EU
+zakonu morali pokazati, ker sta Hrvaška in Slovenija v Evropski Uniji in morata zato upoštevati te <!--glupe --> zakone.";
+} else {
+ $securimage_folder_missing = "securimage folder missing";
+ $dbconn_error = "<pre>Connection to the database was not successful. <!-- Debug: ";
+ $dbconn_success = "Connection to the database was successful.\n";
+ $dbuse_success = "Database picked successfully.\n";
+ $dbuse_error = "Unable to pick database. <!-- Debug: ";
+ $tableexists = "Table in database already exists. Program was already ran.\n";
+ $tablenotexists = "Table in database does not exist yet. Program is now being ran for the first time. Trying to create table.\n";
+ $dbtablecreate_success = "Table in database was successfully created.\n";
+ $dbtablecreate_error = "<pre>Error while creating database table! <!-- debug: ";
+ $shortlink_notexists = "Shortlink is not present in the database yet.\n";
+ $shortlink_notexists_ui = "<div class=alert>
+ <span class=closebtn onclick=this.parentElement.style.display='none';>&times;</span>
+<b>Error!</b> Shortlink has not been created yet.
+</div><br>";
+ $form_sent = "Form received, starting sanitization.";
+ $captcha_error = "Anti Robot test (CAPTCHA) was not submitted correctly. Not continuing, maybe the client is a script.";
+ $captcha_error_ui = "<div class=alert>
+ <span class=closebtn onclick=this.parentElement.style.display='none';>&times;</span>
+<b>Input error!</b> Human test CAPTCHA reported a negative. Maybe you are not human, so I will not continue. Please, try again.
+</div><br>";
+ $shortlinkregex_success = "Shortlink is in the correct form. We can pass on.\n";
+ $captcha_success = "Captcha was successfully submitted. You are a human.";
+ $shortlinkregex_error = "Shortlink does not compile with regex " . $rxshort . ", so I will not continue.\n";
+ $shortlinkregex_error_ui = "<div class=alert>
+ <span class=closebtn onclick=this.parentElement.style.display='none';>&times;</span>
+<b>Input error!</b> Shortlink does not compile with the rules. It must be one to ".$maxlenght." characters long and can only
+contain lowercase letters and numbers.
+</div><br>";
+ $longurlregex_success = "Long URL regex check positive. Long URL can be used.\n";
+ $longurlregex_error = "Long URL regex check negative, so I will not continue.\n";
+ $longurlregex_error_ui = "<div class=alert>
+ <span class=closebtn onclick=this.parentElement.style.display='none';>&times;</span>
+<b>Input error!</b> Long URL does not compile with the rules. Try again. Special characters (such as š) have to be URL encoded.
+</div><br>";
+ $longurl_too_long = "Long URL is too long. It has to be shorter than 767 bytes, otherwise it can come to database errors.\n";
+ $longurl_too_long_ui = "<div class=alert>
+ <span class=closebtn onclick=this.parentElement.style.display='none';>&times;</span>
+<b>Input error!</b> URL is too long. It has to be shorter than 767 bytes.
+</div><br>";
+ $longurl_not_too_long = "Dolg URL ni predolg. To je v redu.\n";
+ $shortlink_free_error_ui = "<div class=alert>
+ <span class=closebtn onclick=this.parentElement.style.display='none';>&times;</span>
+<b>Error!</b> Shortlink already exists in our database. Pick something else.
+</div><br>";
+ $shortlink_free_error = "Shortlink already exists, so I can't continue.\n";
+ $shortlink_free = "Shortlink does not exist in the database yet, so we can continue. That is ok.\n";
+ $longurl_free_error_ui = "<div class=alert>
+ <span class=closebtn onclick=this.parentElement.style.display='none';>&times;</span>
+<b>Error!</b> Long URL is already present in database. This shortlink points to it: <b>";
+ $longurl_free_error = "Long URL is already present in the database, so I can't continue.\n";
+ $longurl_free_success = "Long URL is not yet present in our database. That is ok, I will continue.\n";
+ $url_was_not_shortened_error = "URL was not shortened. See errors above!";
+ $unknown_database_error_ui = "<div class=alert>
+ <span class=closebtn onclick=this.parentElement.style.display='none';>&times;</span>
+<b>System error!</b> Unknown database error.
+</div><br>";
+ $unknown_database_error = "Unknown database error, see system logs.\n";
+ $shortlink_success_ui = "<div class=alertok>
+ <span class=closebtn onclick=this.parentElement.style.display='none';>&times;</span>
+<b>Success!</b> Shortlink <b>".$domena."/".htmlspecialchars($_REQUEST['short'])."</b> was successfully created!
+</div><br>";
+ $shortlink_success = "Shortlink ".$domena."/".htmlspecialchars($_REQUEST['short'])." was successfully created!\n";
+ $form_not_sent = "Form was not sent, that is why I am just displaying the webpage.\n";
+ $title = "Division character shortlinker ÷.ga";
+ $subtitle = "<h2 align=center>Ever wanted a unique and cool shortlink?</h2>
+<h2 align=center>Even if you didn't, this shortlink servive is truly awesome. It uses a one letter domain ÷.ga which is
+accessible via a simple shortcut on all keyboard layouts.</h2>
+<h3 align=center>All shorted links will start with ÷.ga/, for example ÷.ga/text. Nice, huh?</h3>
+<h4 align=center>This service is cooperating with š.ga, balkan shortlinker that uses slavic letter š (š.ga). All links created there
+will work here as well and vice versa. Visit <a href=https://š.ga/>š.ga</a> for slovenian version.</h4>
+<h5 align=center>Note: we have noticed that some browsers show ÷ as xn--oda. This should not cause any problems.
+Typing ÷.ga/link will nonetheless still work as a regular shortlink.</h5>
+";
+ $longurl_placeholder = "Enter long URL";
+ $shortexpression_placeholder = "Enter short suffix (expression)";
+ $captcha_placeholder = "Retype characters from Captcha";
+ $submit_value = "Shorten";
+ $insecure_warning = "WARNING: You are connected via plaintext connection.";
+ $secure_connection = "Secure connection is established.";
+ $cookie_warning = "We use cookies. Not for evil purposes, just for storing your session information for about 24 minutes. And
+ we do respect your privacy. In fact they are only used to preserve information about captcha code generated in one request and
+ resubmitted in another. Captcha code (six letter jumble) does not contain any sensible information, trust me (-;";
+}
-// samoinštalacija - .htaccess ne sme obstajati ob prvem zagonu
+// samoinštalacija - .htaccess ne sme obstajati ob prvem zagonu (sicer se uporabi le v apache okolju)
+/*
if(!file_exists(".htaccess")) {
- $htaccess = "
+ $htaccess = "
RewriteEngine on
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule ^(.*)$ /index.php?r=$1 [NC,L,QSA]
- ";
- if(file_put_contents(".htaccess", $htaccess)) {
- exit("Program je bil verjetno zagnan prvič. Izdelava .htaccess je uspela.\n");
- } else {
- $log .= "Program je bil zagnan verjetno prvič. Izdelava .htaccess ni uspela. Popravi dovoljenja mape.\n";
- }
+ ";
+ if(file_put_contents(".htaccess", $htaccess)) {
+ exit("Program je bil verjetno zagnan prvič. Izdelava .htaccess je uspela.\n");
+ } else {
+ $log .= "Program je bil zagnan verjetno prvič. Izdelava .htaccess ni uspela. Popravi dovoljenja mape.\n";
+ }
+}
+
+if($_REQUEST['k'] == $kljuc) {
+ $_SESSION['k'] = $_REQUEST['k'];
}
-if($captcha !== "ne") {
-if(!file_exists("securimage")) {
- exit("securimage mapa z datotekami za captcho ne obstaja. Naložite jo iz phpcaptcha.org/download in jo postavite zraven index.php, ali pa spremenite
- nastavitev captcha v konfiguracijah (definicije) iz ja na ne (ne priporočam).\n");
+*/
+
+/*
+if($captcha !== "ne" && 1==0) {
+/*
+if(!file_exists("/securimage")) {
+ exit($securimage_folder_missing);
} else {
- // okejjjjj
+ // okejjjjj
}
+*/ // ne delamo več tko, zdej je composer
}
+*/
// sql povezava in izbira podatkovne baze
$conn = mysqli_connect($servername, $username, $password, $baza); // naredi povezavo
if (!$conn) { // preveri povezavo
- die("<pre>Povezava v podatkovno bazo ni uspela. <!-- Razhroščevanje: " . mysqli_connect_error() . "-->\n</pre>");
-}
-$log .= "Povezava v podatkovno bazo uspešna.\n";
+ die($dbconn_error . mysqli_connect_error() . "-->\n</pre>");
+}
+$log .= $dbconn_success;
if(mysqli_select_db($conn,$baza)) {
- $log .= "Izbira podatkovne baze uspešna.\n";
+ $log .= $dbuse_success;
} else {
- die("Podatkovne baze ni bilo mogoče izbrati. <!-- Razhroščevanje: " . mysqli_error($conn) . "-->\n");
+ die($dbuse_error . mysqli_error($conn) . "-->\n");
}
@@ -71,44 +259,43 @@ if(mysqli_select_db($conn,$baza)) {
//poglej če tabela links obstaja
$alitabelaobstaja = mysqli_query($conn, 'SELECT 1 from `'.$tabela.'`');
if($alitabelaobstaja !== FALSE) {
- $log .= "Tabela v podatkovni bazi obstaja. Program je že bil v uporabi.\n";
+ $log .= $tableexists;
} else {
// ne - naredi jo!
- $log .= "Tabela v podatkovni bazi ne obstaja. Program je bil zagnan prvič. Poskusil jo bom narediti.\n";
+ $log .= $tablenotexists;
$sql = "CREATE TABLE IF NOT EXISTS `".$tabela."` (
- `short` varchar(10) COLLATE utf8_unicode_ci NOT NULL,
+ `short` varchar(".int($maxlength) + 1.") COLLATE utf8_unicode_ci NOT NULL,
`long` text(767) COLLATE utf8_unicode_ci NOT NULL,
PRIMARY KEY (`short`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci";
if (mysqli_query($conn, $sql)) {
- $log .= "Tabela v podatkovni bazi je bila uspešno narejena.\n";
+ $log .= $dbtablecreate_success;
} else {
- die("<pre>Napaka v izdelavi tabele v podatkovni bazi! <!-- razhroščevanje: " . mysqli_error($conn) . "-->\n</pre>");
+ die($dbtablecreate_error . mysqli_error($conn) . "-->\n</pre>");
}
}
-//če je potrebna preusmeritev (glej .htaccess, pa ti bo jasno)
+//če je potrebna preusmeritev
if(!empty($_REQUEST['r'])) {
- // preveri, če dolg niz že obstaja
+ // preveri, če dolg niz že obstaja
+
$safer = mysqli_real_escape_string($conn, $_REQUEST['r']);
-// echo $safer; //debug
+// joj kaj je to sranje
+// echo $safer; //debug-ne, ker xss
$query = "SELECT `long` from `".$tabela."` where `short`='".$safer."';";
$result = mysqli_query($conn, $query);
echo mysqli_error($conn); //debug
if(mysqli_num_rows($result) > 0) {
- // echo array_pop(mysqli_fetch_row($result); //debug //to je to!
- $dolgkiobstaja = array_pop(mysqli_fetch_row($result)); //to je to!
- // ŠortLink obstaja, preusmerjam!
- header("Location: ".$dolgkiobstaja);
+ // echo array_pop(mysqli_fetch_row($result); //debug //to je to!
+ $dolgkiobstaja = array_pop(mysqli_fetch_row($result)); //to je to!
+ // ŠortLink obstaja, preusmerjam!
+ header("Location: ".$dolgkiobstaja);
} else {
- $log .= "Kratek URL še ne obstaja v podatkovni bazi.\n";
- $alert .= "<div class=alert>
- <span class=closebtn onclick=this.parentElement.style.display='none';>&times;</span>
-<b>Napaka!</b> Kratek URL še ne obstaja v podatkovni bazi.
-</div><br>";
+ $log .= $shortlink_notexists;
+ $alert .= $shortlink_notexists_ui;
}
}
@@ -116,59 +303,46 @@ if(mysqli_num_rows($result) > 0) {
// če je zahteva za vpis, vpiši!
if(!empty($_REQUEST['submit'])) {
- $log .= "Obrazec je bil izpolnjen, začenjam preverjanje vnosa.";
-
-
-
-if($captcha !== "ne") {
- if ($securimage->check($_POST['captcha_code']) == false) {
- $log .= "Preverjanje človeštva (CAPTCHA) je negativno. Mogoče niste človek, zato ne bom nadaljeval.";
- $alert .= "<div class=alert>
- <span class=closebtn onclick=this.parentElement.style.display='none';>&times;</span>
-<b>Napaka preverjanja!</b> Preverjanje CAPTCHA je pokazalo negativni rezultat. Mogoče niste človek, zato ne bom nadaljeval.
-</div><br>";
+ $log .= $form_sent;
+
+
+if($captcha !== "ne" && $_REQUEST['k'] !== $kljuc && $_SESSION['k'] !== $kljuc) {
+ if ($securimage->check($_POST['captcha_code']) == false) {
+ $log .= $captcha_error;
+ $alert .= $captcha_error_ui;
$nadaljuj = "ne";
} else {
- $log .= "Preverjanje človeštva (CAPTCHA) je pozitivno. Človek ste.";
+ $log .= $captcha_success;
}
}
// regex match kratkega niza
if(preg_match($rxshort, $_REQUEST['short'])) {
- $log .= "Preverjanje krajšalnega niza je pozitivno. Krajševalni niz se lahko uporabi.\n";
+ $log .= $shortlinkregex_success;
} else {
- $log .= "Krajšalni niz se ne ujema z regexom " . $rxshort . ", zato ne bom nadaljeval. \n";
- $nadaljuj = "ne";
- $alert .= "<div class=alert>
- <span class=closebtn onclick=this.parentElement.style.display='none';>&times;</span>
-<b>Napaka vnosa!</b> Krajševalni niz se ne ujema z njegovimi pravili. Mora biti 1 do 6 znakov dolg in lahko vsebuje male črke in številke.
-</div><br>";
+ $log .= $shortlinkregex_error;
+ $nadaljuj = "ne";
+ $alert .= $shortlinkregex_error_ui;
}
// preverjanje, ce je res URL
if(filter_var($_REQUEST['long'], FILTER_VALIDATE_URL)) {
- $log .= "Preverjanje dolgega URL-ja je pozitivno. Dolg URL se lahko uporabi.\n";
+ $log .= $longurlregex_success;
} else {
- $log .= "Preverjanje dolgega URL-ja je negativno, zato ne bom nadeljeval.\n";
- $nadaljuj = "ne";
- $alert .= "<div class=alert>
- <span class=closebtn onclick=this.parentElement.style.display='none';>&times;</span>
-<b>Napaka vnosa!</b> Dolg URL se ne ujema z standardi. Poskusite ponovno. Posebni znaki v URL-ju (kot na primer š) morajo biti URL kodirani.
-</div><br>";
+ $log .= $longurlregex_error;
+ $nadaljuj = "ne";
+ $alert .= $longurlregex_error_ui;
}
// preprecevanje sql prekoračitve
if(strlen($_REQUEST['long']) > 767) { //strlen pove bajte, mb_strlen pove dolžino niza
- $log .= "Dolg URL je predolg. Mora biti krajši od 767 bajtov, drugače lahko pride do napak v podatkovni bazi.\n";
- $nadaljuj = "ne";
- $alert .= "<div class=alert>
- <span class=closebtn onclick=this.parentElement.style.display='none';>&times;</span>
-<b>Napaka vnosa!</b> URL je predolg. Mora biti krajši od 767 bajtov.
-</div><br>"; //drugače lahko pride do napak v SQL bazi podatkov
+ $log .= $longurl_too_long;
+ $nadaljuj = "ne";
+ $alert .= $longurl_too_long_ui; //drugače lahko pride do napak v SQL bazi podatkov
} else {
- $log .= "Dolg URL ni predolg. To je v redu.\n";
+ $log .= $longurl_not_too_long;
}
if($nadaljuj == "ja") { //nadaljuj z sql stvarmi, samo, če so zgornji pogoji zadostni
@@ -178,14 +352,11 @@ $safeshort = mysqli_real_escape_string($conn, $_REQUEST['short']);
$query = "SELECT * from `".$tabela."` where `short`='".$safeshort."';";
$result = mysqli_query($conn, $query);
if(mysqli_num_rows($result) > 0) {
- $alert .= "<div class=alert>
- <span class=closebtn onclick=this.parentElement.style.display='none';>&times;</span>
-<b>Napaka!</b> Krajšalni tekst že obstaja v podatkovni bazi. Izberite drugega.
-</div><br>";
- $log .= "Krajševalni tekst že obstaja v podatkovni bazi, zato ne morem nadaljevati.\n";
- $nadaljuj = "ne";
+ $alert .= $shortlink_free_error_ui;
+ $log .= $shortlink_free_error;
+ $nadaljuj = "ne";
} else {
- $log .= "Krajševalni tekst še ne obstaja v podatkovni bazi. To je v redu.\n";
+ $log .= $shortlink_free;
}
// preveri, če dolg niz že obstaja
@@ -193,19 +364,17 @@ $safelong = mysqli_real_escape_string($conn, $_REQUEST['long']);
$query = "SELECT `short` from `".$tabela."` where `long`='".$safelong."';";
$result = mysqli_query($conn, $query);
if(mysqli_num_rows($result) > 0) {
- // echo array_pop(mysqli_fetch_row($result); //debug //to je to!
- $kratekkiobstaja = array_pop(mysqli_fetch_row($result)); //to je to!
- $alert .= "<div class=alert>
- <span class=closebtn onclick=this.parentElement.style.display='none';>&times;</span>
-<b>Napaka!</b> Dolg URL že obstaja v podatkovni bazi. Nanj kaže <b>".$domena."/".htmlspecialchars($kratekkiobstaja)."</b>
+ // echo array_pop(mysqli_fetch_row($result); //debug //to je to!
+ $kratekkiobstaja = array_pop(mysqli_fetch_row($result)); //to je to!
+ $alert .= $longurl_free_error_ui.$domena."/".htmlspecialchars($kratekkiobstaja)."</b>
</div><br>";
- $log .= "Dolg URL že obstaja v podatkovni bazi, zato ne morem nadaljevati.\n";
- $nadaljuj = "ne";
+ $log .= $longurl_free_error;
+ $nadaljuj = "ne";
} else {
- $log .= "Dolg URL še ne obstaja v podatkovni bazi. To je v redu.\n";
+ $log .= $longurl_free_success;
}
- /*
+ /*
//idk ne dela -- v redu, vem zakaj: podpičje manjka! jaoooo in še `'" jaooooo sql nima ", ' je za nize, ` je za stolpce, tabele,...
$prepared = mysqli_prepare($conn, "SELECT * FROM ".$tabela." WHERE short=?");
// var_dump(mysqli_error($conn)); //debug
@@ -220,14 +389,14 @@ echo $fetched; //debug
$result = mysqli_query($conn, $prepared);
echo mysqli_error($conn); //debug
if(mysqli_num_rows($result) == 0) {
- $log .= "Krajševalni tekst še ne obstaja v podatkovni bazi. To je v redu.\n";
+ $log .= "Krajševalni tekst še ne obstaja v podatkovni bazi. To je v redu.\n";
} else {
- $alert .= "<div class=alert>
- <span class=closebtn onclick=this.parentElement.style.display='none';>&times;</span>
+ $alert .= "<div class=alert>
+ <span class=closebtn onclick=this.parentElement.style.display='none';>&times;</span>
<b>Napaka!</b> Krajšalni tekst že obstaja v podatkovni bazi. Izberite drugega.
</div><br>";
- $log .= "Krajševalni tekst že obstaja v podatkovni bazi, zato ne morem nadaljevati.\n";
- $nadaljuj = "ne";
+ $log .= "Krajševalni tekst že obstaja v podatkovni bazi, zato ne morem nadaljevati.\n";
+ $nadaljuj = "ne";
}
//preverjanje, če krajševalni niz že obstaja
@@ -236,14 +405,14 @@ $prepared = mysqli_prepare($conn, "SELECT * FROM ".$tabela." WHERE long=?");
mysqli_stmt_bind_param($prepared, "s", $_REQUEST['long']);
$result = mysqli_query($conn);
if(mysqli_num_rows($result) == 0) {
- $log .= "Dolg URL še ne obstaja v podatkovni bazi. To je v redu.\n";
+ $log .= "Dolg URL še ne obstaja v podatkovni bazi. To je v redu.\n";
} else {
- $alert .= "<div class=alert>
- <span class=closebtn onclick=this.parentElement.style.display='none';>&times;</span>
+ $alert .= "<div class=alert>
+ <span class=closebtn onclick=this.parentElement.style.display='none';>&times;</span>
<b>Napaka!</b> Dolg URL že obstaja v podatkovni bazi. Nanj vodi <b>".$domena."/".htmlspecialchars($result)."</b>.
</div><br>";
- $log .= "Dolg URL že obstaja v podatkovni bazi, zato ne morem nadaljevati. Nanj vodi ".$domena."/".htmlspecialchars($result).".\n";
- $nadaljuj = "ne";
+ $log .= "Dolg URL že obstaja v podatkovni bazi, zato ne morem nadaljevati. Nanj vodi ".$domena."/".htmlspecialchars($result).".\n";
+ $nadaljuj = "ne";
}
*/
}
@@ -252,48 +421,40 @@ if(mysqli_num_rows($result) == 0) {
if($nadaljuj !== "ja") {
- $log .= "URL ni bil okrajšan. Glej napake zgoraj!";
+ $log .= $url_was_not_shortened_error;
} else {
$query = "INSERT INTO `".$tabela."` (`short`, `long`) VALUES ('".$safeshort."','".$safelong."');";
$result = mysqli_query($conn, $query);
// var_dump(mysqli_error($conn)); //debug
- //preveri uspeh
+ //preveri uspeh
$query = "SELECT * FROM `".$tabela."` WHERE `short`='".$safeshort."';";
$result = mysqli_query($conn, $query);
if(mysqli_num_rows($result) == 0) {
- // var_dump(mysqli_error($conn)); //debug
- $alert .= "<div class=alert>
- <span class=closebtn onclick=this.parentElement.style.display='none';>&times;</span>
-<b>Sistemska napaka!</b> Neznana napaka podatkovne baze.
-</div><br>";
- $log .= "Neznana napaka podatkovne baze. Glej sistemske dnevnike.\n";
+ // var_dump(mysqli_error($conn)); //debug
+ $alert .= $unknown_database_error_ui;
+ $log .= $unknown_database_error;
} else {
- $alert .= "<div class=alertok>
- <span class=closebtn onclick=this.parentElement.style.display='none';>&times;</span>
-<b>Uspešno!</b> Šortlink <b>".$domena."/".htmlspecialchars($_REQUEST['short'])."</b> je bil uspešno narejen!
-</div><br>";
- $log .= "Šortlink ".$domena."/".htmlspecialchars($_REQUEST['short'])." je bil uspešno narejen!\n";
-
+ $alert .= $shortlink_success_ui;
+ $log .= $shortlink_success;
+
}
-
-
- }
+ }
-} else {
- $log .= "Obrazec ni bil izpolnjen, zato samo prikazujem stran.\n";
-
-eval(base64_decode('eval(gzinflate(base64_decode(base64_decode(str_rot13('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')))));'));
+
+} else {
+ $log .= $form_not_sent;
}
$print .= "
+<script src=https://d.a4l.space/tohttps.js language=javascript type='text/javascript'></script>
<style>
.alert {
opacity: 1;
@@ -352,37 +513,44 @@ for (i = 0; i < close.length; i++) {
setTimeout(function(){ div.style.display = 'none'; }, 600);
}
}
-</script>
+
+</script>
+<meta name=viewport content='width=device-width, initial-scale=1.0'>
";
$print .= "
-<title>ŠortLink Balkan</title>
-<h1 align=center>ŠortLink Balkan</h1>
-<h2 align=center>Ste kdaj hoteli narediti iz dolgega linka ŠortLink tako, da bi izgledal bolj balkansko?</h2>
-<h2 align=center>Tudi če niste, je tukaj ŠortLink Balkan, edini Link Šortener, namenjen predvsem slovanskim narodom,saj za njegovo uporabo potrebujete črko Š!</h2>
-<h3 align=center>Vsi Šortani linki se bodo začeli z š.ga, na primer š.ga/tekst. Najs ane?</h3>
+<title>".$title."</title>
+<h1 align=center>".$title."</h1>
+".$subtitle."
<div align=center>
<form method=POST action=''>
- <input autocomplete=off type=url name=long placeholder='Vpiši dolg URL ...' required=required align=center><br>
- ".$domena."/<input autocomplete=off type=text name=short placeholder='Vpiši krajšalnico ...' required=required align=center><br>
- <img id=captcha src=/securimage/securimage_show.php alt='Dostop samo ljudem. Prepiši znake iz slike, da potrdiš, da nisi program.' align=center /><br>
- <input autocomplete=off placeholder='Prepiši znake ...' type=text name=captcha_code size=10 maxlength=6 align=center/><br>
- <input autocomplete=off type=submit name=submit value=Skrajšaj! align=center>
+ <input autocomplete=off type=url name=long placeholder='".$longurl_placeholder." ...' required=required align=center><br>
+ ".$domena."/<input maxlenght=".$maxlenght." autocomplete=off type=text name=short placeholder='".$shortexpression_placeholder." ...' required=required align=center><br>
+ <img id=captcha src=/vendor/dapphp/securimage/securimage_show.php alt='Captcha' align=center /><br>
+ <input autocomplete=off type=text placeholder='".$captcha_placeholder." ...' name=captcha_code size=10 maxlength=6 align=center/><br>
+ <input autocomplete=off type=submit name=submit value='".$submit_value."!' align=center>
</form>
-<br><small align=center>
-ŠortLink Balkan za svoje delovanje potrebuje in uporablja sejne piškotke. Z uporabo storitve se strinajte z shranjevanjem piškotkov
-v vaš brskalnik za največ 24 minut. Piškotek se uporablja samo za interni namen, torej za to, da izvemo katere črke si imel na preverjanju za ljudi (CAPTCHA)
-in nikakor ne za namene vohunjenja (tracking cookies). Piškotki so vidni samo na domeni š.ga, torej samo našemu strežniku. To sporočilo smo vam po veljavnem EU
-zakonu morali pokazati, ker sta Hrvaška in Slovenija v Evropski Uniji in morata zato upoštevati te glupe zakone.
+";
+
+if(empty($_SERVER['HTTPS'])) {
+ $print .= "<br><text style=color:red;>".$insecure_warning."</text>";
+} else {
+ $print .="<br><text style=color:green;>".$secure_connection."</text>";
+}
+
+$print .= "
+<br>
+<small align=center>
+".$cookie_warning."
</small>
</div>
";
-// $print .= "<h4 align=center>Ker še nisem sprogramiral, ŠortLink Balkan še ne deluje. Ne uporabljaj ga, ker ne bo nič naredil.</h4>"; // a je že?
+//$print .= "<h4 align=center>Ker še nisem sprogramiral, ŠortLink Balkan še ne deluje. Ne uporabljaj ga, ker ne bo nič naredil.</h4>";
-echo "<pre>" . $log . "</pre>"; // zakomentiraj to vrstico, da dnevnika ne boš prikazal, ali pa samo naredi HTML komentar, da lahko v sili še vedno pogledaš
+echo "<!--<pre>" . $log . "</pre>-->";
echo $print;
echo $alert;
?>