Changed rendering template and router

This commit is contained in:
Pablo Ferreiro 2022-01-03 13:43:22 +01:00
parent 5ae3b5c11c
commit 328f70e4f6
No known key found for this signature in database
GPG key ID: 41FBCE65B779FA24
14 changed files with 331 additions and 1207 deletions

View file

@ -2,11 +2,15 @@
require __DIR__ . "/vendor/autoload.php";
require __DIR__ . "/helpers/domains.php";
require __DIR__ . "/helpers/settings_elements.php";
use Steampixel\Route;
use Jenssegers\Blade\Blade;
// LOAD DOTENV
$dotenv = Dotenv\Dotenv::createImmutable(__DIR__);
$dotenv->load();
function getApi(array $proxy_elements): \Sovit\TikTok\Api {
$options = [];
// Proxy config
if (in_array($proxy_elements, $_COOKIE)) {
foreach ($proxy_elements as $proxy_element) {
$options[$proxy_element] = $_COOKIE[$proxy_element];
@ -16,19 +20,27 @@ function getApi(array $proxy_elements): \Sovit\TikTok\Api {
return $api;
}
$router = new \Bramus\Router\Router();
function getLatte(): \Latte\Engine {
$latte = new Latte\Engine;
$latte->setTempDirectory('./cache/views');
return $latte;
}
$router->get('/', function () {
function getView(string $template): string {
return "./views/{$template}.latte";
}
Route::add('/', function () {
http_response_code(302);
header('Location: ./home');
});
$router->get('/home', function () {
$blade = new Blade('./views', './cache/views');
echo $blade->render('home');
Route::add('/home', function () {
$latte = getLatte();
$latte->render('./views/home.latte');
});
$router->get('/images', function () use ($domains) {
Route::add('/images', function () use ($domains) {
if (!isset($_GET['url'])) {
die('You need to send a url!');
}
@ -41,13 +53,13 @@ $router->get('/images', function () use ($domains) {
$img = file_get_contents($url, false, stream_context_create(['http' => ['ignore_errors' => true]]));
if ($img) {
header('Content-Type: image/jpeg');
echo $img;
return $img;
} else {
echo 'Error while getting image!';
return 'Error while getting image!';
}
});
$router->get('/audios', function () use ($domains) {
Route::add('/audios', function () use ($domains) {
if (!isset($_GET['url'])) {
die('You need to send a url!');
}
@ -59,13 +71,13 @@ $router->get('/audios', function () use ($domains) {
$audio = file_get_contents($url, false, stream_context_create(['http' => ['ignore_errors' => true]]));
if ($audio) {
header('Content-Type: audio/mp3');
echo $audio;
return $audio;
} else {
echo 'Error while getting audio!';
return 'Error while getting audio!';
}
});
$router->get('/stream', function () use ($domains) {
Route::add('/stream', function () use ($domains) {
if (!isset($_GET['url'])) {
die('You need to send a url!');
}
@ -77,48 +89,54 @@ $router->get('/stream', function () use ($domains) {
die('Not a valid URL');
}
header('Content-Disposition: attachment; filename="tiktok.mp4"');
if (isset($_GET['download'])) {
header('Content-Disposition: attachment; filename="tiktok.mp4"');
}
$streamer = new \Sovit\TikTok\Stream();
$streamer->stream($url);
});
$router->get("/trending", function () use ($proxy_elements) {
Route::add("/trending", function () use ($proxy_elements) {
$cursor = 0;
if (isset($_GET['cursor']) && is_numeric($_GET['cursor'])) {
$cursor = (int) $_GET['cursor'];
}
$blade = new Blade('./views', './cache/views');
$latte = getLatte();
$api = getApi($proxy_elements);
$feed = $api->getTrendingFeed($cursor);
if ($feed) {
echo $blade->render('trending', ['feed' => $feed]);
$latte->render(getView('trending'), ['feed' => $feed]);
} else {
echo 'ERROR!';
return 'ERROR!';
}
});
$router->get("/@([^/]+)", function (string $username) use ($proxy_elements) {
Route::add("/@([^/]+)", function (string $username) use ($proxy_elements) {
$cursor = 0;
if (isset($_GET['cursor']) && is_numeric($_GET['cursor'])) {
$cursor = (int) $_GET['cursor'];
}
$blade = new Blade('./views', './cache/views');
$latte = getLatte();
$api = getApi($proxy_elements);
$feed = $api->getUserFeed($username, $cursor);
if ($feed) {
echo $blade->render('user', ['feed' => $feed]);
if ($feed->info->detail->user->privateAccount) {
http_response_code(400);
return 'Private account detected! Not supported';
}
$latte->render(getView('user'), ['feed' => $feed]);
} else {
echo 'ERROR!';
return 'ERROR!';
}
});
$router->get("/settings", function () use ($proxy_elements) {
$blade = new Blade('./views', './cache/views');
echo $blade->render('settings', ["proxy_elements" => $proxy_elements]);
Route::add("/settings", function () use ($proxy_elements) {
$latte = getLatte();
$latte->render(getView('settings'), ["proxy_elements" => $proxy_elements]);
});
$router->post("/settings", function () use ($proxy_elements) {
Route::add("/settings", function () use ($proxy_elements) {
if (in_array($proxy_elements, $_POST)) {
foreach ($proxy_elements as $proxy_element) {
setcookie($proxy_element, $_POST[$proxy_element], time()+60*60*24*30, '/', '', true, true);
@ -126,6 +144,7 @@ $router->post("/settings", function () use ($proxy_elements) {
}
http_response_code(302);
header('Location: ./home');
});
}, 'POST');
$router->run();
$subdir = getenv('APP_SUBDIR');
Route::run($subdir);