Changed rendering template and router
This commit is contained in:
parent
5ae3b5c11c
commit
328f70e4f6
14 changed files with 331 additions and 1207 deletions
75
index.php
75
index.php
|
|
@ -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);
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue