2023-08-27 09:07:08 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
// Load dependencies
|
|
|
|
require_once (__DIR__ . '/../config/app.php');
|
|
|
|
require_once (__DIR__ . '/../library/database.php');
|
|
|
|
require_once (__DIR__ . '/../../vendor/autoload.php');
|
|
|
|
|
|
|
|
// Connect database
|
|
|
|
try {
|
|
|
|
|
|
|
|
$db = new Database(DB_HOST, DB_PORT, DB_NAME, DB_USERNAME, DB_PASSWORD);
|
|
|
|
|
|
|
|
} catch (Exception $e) {
|
|
|
|
|
|
|
|
var_dump($e);
|
|
|
|
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Define response
|
|
|
|
$response = (object)
|
|
|
|
[
|
|
|
|
'success' => true,
|
2023-09-05 23:18:05 +00:00
|
|
|
'message' => _('Internal server error'),
|
|
|
|
'title' => sprintf(_('Oops - %s'), WEBSITE_NAME)
|
2023-08-27 09:07:08 +00:00
|
|
|
];
|
|
|
|
|
|
|
|
// Begin action request
|
|
|
|
switch (isset($_GET['target']) ? urldecode($_GET['target']) : false)
|
|
|
|
{
|
2023-08-29 18:26:38 +00:00
|
|
|
case 'profile':
|
|
|
|
|
|
|
|
switch (isset($_GET['toggle']) ? $_GET['toggle'] : false)
|
|
|
|
{
|
2023-08-29 18:51:16 +00:00
|
|
|
case 'jidenticon':
|
2023-08-29 18:26:38 +00:00
|
|
|
|
|
|
|
// Yggdrasil connections only
|
|
|
|
if (!preg_match(YGGDRASIL_URL_REGEX, $_SERVER['REMOTE_ADDR']))
|
|
|
|
{
|
|
|
|
$response->success = false;
|
|
|
|
$response->message = _('Yggdrasil connection required for this action');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Init session
|
|
|
|
else if (!$userId = $db->initUserId($_SERVER['REMOTE_ADDR'], USER_DEFAULT_APPROVED, time()))
|
|
|
|
{
|
|
|
|
$response->success = false;
|
|
|
|
$response->message = _('Could not init user session');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Get user
|
|
|
|
else if (!$user = $db->getUser($userId))
|
|
|
|
{
|
|
|
|
$response->success = false;
|
|
|
|
$response->message = _('Could not init user info');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Render icon
|
|
|
|
else
|
|
|
|
{
|
|
|
|
header('Cache-Control: max-age=604800');
|
|
|
|
|
|
|
|
|
|
|
|
$icon = new Jdenticon\Identicon();
|
|
|
|
|
2023-08-29 18:51:16 +00:00
|
|
|
$icon->setValue($user->{USER_IDENTICON_FIELD});
|
2023-08-29 18:26:38 +00:00
|
|
|
$icon->setSize(empty($_GET['size']) ? 100 : (int) $_GET['size']);
|
|
|
|
$icon->setStyle(
|
|
|
|
[
|
|
|
|
'backgroundColor' => 'rgba(255, 255, 255, 0)',
|
|
|
|
]
|
|
|
|
);
|
|
|
|
$icon->displayImage('webp');
|
|
|
|
}
|
|
|
|
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
2023-08-27 09:07:08 +00:00
|
|
|
case 'comment':
|
|
|
|
|
2023-08-28 22:09:55 +00:00
|
|
|
switch (isset($_GET['toggle']) ? $_GET['toggle'] : false)
|
|
|
|
{
|
|
|
|
case 'approved':
|
|
|
|
|
|
|
|
// Yggdrasil connections only
|
|
|
|
if (!preg_match(YGGDRASIL_URL_REGEX, $_SERVER['REMOTE_ADDR']))
|
|
|
|
{
|
|
|
|
$response->success = false;
|
|
|
|
$response->message = _('Yggdrasil connection required for this action');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Init session
|
|
|
|
else if (!$userId = $db->initUserId($_SERVER['REMOTE_ADDR'], USER_DEFAULT_APPROVED, time()))
|
|
|
|
{
|
|
|
|
$response->success = false;
|
|
|
|
$response->message = _('Could not init user session');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Get user
|
|
|
|
else if (!$user = $db->getUser($userId))
|
|
|
|
{
|
|
|
|
$response->success = false;
|
|
|
|
$response->message = _('Could not init user info');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Magnet comment exists
|
|
|
|
else if (!$magnetComment = $db->getMagnetComment(isset($_GET['magnetCommentId']) && $_GET['magnetCommentId'] > 0 ? (int) $_GET['magnetCommentId'] : 0))
|
|
|
|
{
|
|
|
|
$response->success = false;
|
|
|
|
$response->message = _('Requested magnet comment not found');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Access allowed
|
|
|
|
else if (!in_array($user->address, MODERATOR_IP_LIST)) {
|
|
|
|
|
|
|
|
$response->success = false;
|
|
|
|
$response->message = _('Access denied');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Validate callback
|
|
|
|
else if (empty($_GET['callback']))
|
|
|
|
{
|
|
|
|
$response->success = false;
|
|
|
|
$response->message = _('Callback required');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Validate base64
|
|
|
|
else if (!$callback = (string) @base64_decode($_GET['callback']))
|
|
|
|
{
|
|
|
|
$response->success = false;
|
|
|
|
$response->message = _('Invalid callback encoding');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Request valid
|
|
|
|
else
|
|
|
|
{
|
|
|
|
if ($magnetComment->approved)
|
|
|
|
{
|
|
|
|
$db->updateMagnetCommentApproved($magnetComment->magnetCommentId, false);
|
|
|
|
|
|
|
|
if (USER_AUTO_APPROVE_ON_COMMENT_APPROVE)
|
|
|
|
{
|
|
|
|
$db->updateUserApproved($magnetComment->userId, false, time());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
$db->updateMagnetCommentApproved($magnetComment->magnetCommentId, true);
|
|
|
|
|
|
|
|
if (USER_AUTO_APPROVE_ON_COMMENT_APPROVE)
|
|
|
|
{
|
|
|
|
$db->updateUserApproved($magnetComment->userId, true, time());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Redirect to edit page
|
|
|
|
header(
|
|
|
|
sprintf('Location: %s', $callback)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'public':
|
|
|
|
|
|
|
|
// Yggdrasil connections only
|
|
|
|
if (!preg_match(YGGDRASIL_URL_REGEX, $_SERVER['REMOTE_ADDR']))
|
|
|
|
{
|
|
|
|
$response->success = false;
|
|
|
|
$response->message = _('Yggdrasil connection required for this action');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Init session
|
|
|
|
else if (!$userId = $db->initUserId($_SERVER['REMOTE_ADDR'], USER_DEFAULT_APPROVED, time()))
|
|
|
|
{
|
|
|
|
$response->success = false;
|
|
|
|
$response->message = _('Could not init user session');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Get user
|
|
|
|
else if (!$user = $db->getUser($userId))
|
|
|
|
{
|
|
|
|
$response->success = false;
|
|
|
|
$response->message = _('Could not init user info');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Magnet comment exists
|
|
|
|
else if (!$magnetComment = $db->getMagnetComment(isset($_GET['magnetCommentId']) && $_GET['magnetCommentId'] > 0 ? (int) $_GET['magnetCommentId'] : 0))
|
|
|
|
{
|
|
|
|
$response->success = false;
|
|
|
|
$response->message = _('Requested magnet comment not found');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Access allowed
|
|
|
|
else if (!($user->address == $db->getUser($magnetComment->userId)->address || in_array($user->address, MODERATOR_IP_LIST))) {
|
|
|
|
|
|
|
|
$response->success = false;
|
|
|
|
$response->message = _('Access denied');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Validate callback
|
|
|
|
else if (empty($_GET['callback']))
|
|
|
|
{
|
|
|
|
$response->success = false;
|
|
|
|
$response->message = _('Callback required');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Validate base64
|
|
|
|
else if (!$callback = (string) @base64_decode($_GET['callback']))
|
|
|
|
{
|
|
|
|
$response->success = false;
|
|
|
|
$response->message = _('Invalid callback encoding');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Request valid
|
|
|
|
else
|
|
|
|
{
|
|
|
|
if ($magnetComment->public)
|
|
|
|
{
|
|
|
|
$db->updateMagnetCommentPublic($magnetComment->magnetCommentId, false);
|
|
|
|
}
|
|
|
|
else{
|
|
|
|
$db->updateMagnetCommentPublic($magnetComment->magnetCommentId, true);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Redirect to edit page
|
|
|
|
header(
|
|
|
|
sprintf('Location: %s', $callback)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'new':
|
|
|
|
|
|
|
|
// Yggdrasil connections only
|
|
|
|
if (!preg_match(YGGDRASIL_URL_REGEX, $_SERVER['REMOTE_ADDR']))
|
|
|
|
{
|
|
|
|
$response->success = false;
|
|
|
|
$response->message = _('Yggdrasil connection required for this action');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Init session
|
|
|
|
else if (!$userId = $db->initUserId($_SERVER['REMOTE_ADDR'], USER_DEFAULT_APPROVED, time()))
|
|
|
|
{
|
|
|
|
$response->success = false;
|
|
|
|
$response->message = _('Could not init user session');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Get user
|
|
|
|
else if (!$user = $db->getUser($userId))
|
|
|
|
{
|
|
|
|
$response->success = false;
|
|
|
|
$response->message = _('Could not init user info');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Magnet exists
|
|
|
|
else if (!$magnet = $db->getMagnet(isset($_GET['magnetId']) && $_GET['magnetId'] > 0 ? (int) $_GET['magnetId'] : 0))
|
|
|
|
{
|
|
|
|
$response->success = false;
|
|
|
|
$response->message = _('Requested magnet not found');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Access allowed
|
|
|
|
else if (!($user->address == $db->getUser($magnet->userId)->address || in_array($user->address, MODERATOR_IP_LIST) || ($magnet->public && $magnet->approved))) {
|
|
|
|
|
|
|
|
$response->success = false;
|
|
|
|
$response->message = _('Magnet not available for this action');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Validate callback
|
|
|
|
else if (empty($_GET['callback']))
|
|
|
|
{
|
|
|
|
$response->success = false;
|
|
|
|
$response->message = _('Callback required');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Validate base64
|
|
|
|
else if (!$callback = (string) @base64_decode($_GET['callback']))
|
|
|
|
{
|
|
|
|
$response->success = false;
|
|
|
|
$response->message = _('Invalid callback encoding');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Validate comment value
|
|
|
|
else if (empty($_POST['comment']) ||
|
|
|
|
mb_strlen($_POST['comment']) < COMMENT_MIN_LENGTH ||
|
|
|
|
mb_strlen($_POST['comment']) > COMMENT_MAX_LENGTH)
|
|
|
|
{
|
|
|
|
$response->success = false;
|
|
|
|
$response->message = sprintf(_('Valid comment value required, %s-%s chars allowed'), COMMENT_MIN_LENGTH, COMMENT_MAX_LENGTH);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Request valid
|
|
|
|
else
|
|
|
|
{
|
|
|
|
if ($magnetCommentId = $db->addMagnetComment($magnet->magnetId,
|
|
|
|
$user->userId,
|
|
|
|
null, // @TODO implement threads
|
|
|
|
trim($_POST['comment']),
|
|
|
|
$user->approved || in_array($user->address, MODERATOR_IP_LIST) ? true : COMMENT_DEFAULT_APPROVED,
|
|
|
|
COMMENT_DEFAULT_PUBLIC,
|
|
|
|
time()))
|
|
|
|
{
|
|
|
|
// Redirect to referrer page
|
|
|
|
header(
|
|
|
|
sprintf('Location: %s#comment-%s', $callback, $magnetCommentId)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
|
|
|
|
header(
|
|
|
|
sprintf('Location: %s', WEBSITE_URL)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2023-08-27 09:07:08 +00:00
|
|
|
break;
|
|
|
|
|
2023-08-29 16:47:41 +00:00
|
|
|
case 'magnet':
|
2023-08-27 09:07:08 +00:00
|
|
|
|
2023-08-29 16:47:41 +00:00
|
|
|
switch (isset($_GET['toggle']) ? $_GET['toggle'] : false)
|
2023-08-27 09:07:08 +00:00
|
|
|
{
|
2023-08-29 16:47:41 +00:00
|
|
|
case 'star':
|
2023-08-27 09:07:08 +00:00
|
|
|
|
2023-08-29 16:47:41 +00:00
|
|
|
// Yggdrasil connections only
|
|
|
|
if (!preg_match(YGGDRASIL_URL_REGEX, $_SERVER['REMOTE_ADDR']))
|
|
|
|
{
|
|
|
|
$response->success = false;
|
|
|
|
$response->message = _('Yggdrasil connection required for this action');
|
|
|
|
}
|
2023-08-27 09:07:08 +00:00
|
|
|
|
2023-08-29 16:47:41 +00:00
|
|
|
// Init session
|
|
|
|
else if (!$userId = $db->initUserId($_SERVER['REMOTE_ADDR'], USER_DEFAULT_APPROVED, time()))
|
|
|
|
{
|
|
|
|
$response->success = false;
|
|
|
|
$response->message = _('Could not init user session');
|
|
|
|
}
|
2023-08-27 09:07:08 +00:00
|
|
|
|
2023-08-29 16:47:41 +00:00
|
|
|
// Magnet exists
|
|
|
|
else if (!$magnet = $db->getMagnet(isset($_GET['magnetId']) && $_GET['magnetId'] > 0 ? (int) $_GET['magnetId'] : 0))
|
|
|
|
{
|
|
|
|
$response->success = false;
|
|
|
|
$response->message = _('Requested magnet not found');
|
|
|
|
}
|
2023-08-27 09:07:08 +00:00
|
|
|
|
2023-08-29 16:47:41 +00:00
|
|
|
// Access allowed
|
|
|
|
else if (!($_SERVER['REMOTE_ADDR'] == $db->getUser($magnet->userId)->address || in_array($_SERVER['REMOTE_ADDR'], MODERATOR_IP_LIST) || ($magnet->public && $magnet->approved))) {
|
2023-08-27 09:07:08 +00:00
|
|
|
|
2023-08-29 16:47:41 +00:00
|
|
|
$response->success = false;
|
|
|
|
$response->message = _('Magnet not available for this action');
|
|
|
|
}
|
2023-08-27 09:07:08 +00:00
|
|
|
|
2023-08-29 16:47:41 +00:00
|
|
|
// Validate callback
|
|
|
|
else if (empty($_GET['callback']))
|
|
|
|
{
|
|
|
|
$response->success = false;
|
|
|
|
$response->message = _('Callback required');
|
|
|
|
}
|
2023-08-27 09:07:08 +00:00
|
|
|
|
2023-08-29 16:47:41 +00:00
|
|
|
// Validate base64
|
|
|
|
else if (!$callback = (string) @base64_decode($_GET['callback']))
|
|
|
|
{
|
|
|
|
$response->success = false;
|
|
|
|
$response->message = _('Invalid callback encoding');
|
|
|
|
}
|
2023-08-27 09:07:08 +00:00
|
|
|
|
2023-08-29 16:47:41 +00:00
|
|
|
// Request valid
|
|
|
|
else
|
|
|
|
{
|
|
|
|
// Star exists, trigger delete
|
|
|
|
if ($db->findMagnetStarsTotalByUserId($magnet->magnetId, $userId))
|
|
|
|
{
|
|
|
|
$db->deleteMagnetStarByUserId($magnet->magnetId, $userId);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
// Star not exists, trigger add
|
|
|
|
$db->addMagnetStar($magnet->magnetId, $userId, time());
|
|
|
|
}
|
2023-08-27 09:07:08 +00:00
|
|
|
|
2023-08-29 16:47:41 +00:00
|
|
|
// Redirect to edit page
|
|
|
|
header(
|
|
|
|
sprintf('Location: %s', $callback)
|
|
|
|
);
|
|
|
|
}
|
2023-08-27 09:07:08 +00:00
|
|
|
|
2023-08-29 16:47:41 +00:00
|
|
|
break;
|
2023-08-27 09:07:08 +00:00
|
|
|
|
2023-08-29 16:47:41 +00:00
|
|
|
case 'download':
|
2023-08-27 09:07:08 +00:00
|
|
|
|
2023-08-29 16:47:41 +00:00
|
|
|
// Yggdrasil connections only
|
|
|
|
if (!preg_match(YGGDRASIL_URL_REGEX, $_SERVER['REMOTE_ADDR']))
|
|
|
|
{
|
|
|
|
$response->success = false;
|
|
|
|
$response->message = _('Yggdrasil connection required for this action');
|
|
|
|
}
|
2023-08-27 09:07:08 +00:00
|
|
|
|
2023-08-29 16:47:41 +00:00
|
|
|
// Init session
|
|
|
|
else if (!$userId = $db->initUserId($_SERVER['REMOTE_ADDR'], USER_DEFAULT_APPROVED, time()))
|
|
|
|
{
|
|
|
|
$response->success = false;
|
|
|
|
$response->message = _('Could not init user session');
|
|
|
|
}
|
2023-08-27 09:07:08 +00:00
|
|
|
|
2023-08-29 16:47:41 +00:00
|
|
|
// Magnet exists
|
|
|
|
else if (!$magnet = $db->getMagnet(isset($_GET['magnetId']) && $_GET['magnetId'] > 0 ? (int) $_GET['magnetId'] : 0))
|
|
|
|
{
|
|
|
|
$response->success = false;
|
|
|
|
$response->message = _('Requested magnet not found');
|
|
|
|
}
|
2023-08-27 09:07:08 +00:00
|
|
|
|
2023-08-29 16:47:41 +00:00
|
|
|
// Access allowed
|
|
|
|
else if (!($_SERVER['REMOTE_ADDR'] == $db->getUser($magnet->userId)->address || in_array($_SERVER['REMOTE_ADDR'], MODERATOR_IP_LIST) || ($magnet->public && $magnet->approved))) {
|
2023-08-27 09:07:08 +00:00
|
|
|
|
2023-08-29 16:47:41 +00:00
|
|
|
$response->success = false;
|
|
|
|
$response->message = _('Magnet not available for this action');
|
|
|
|
}
|
2023-08-27 09:07:08 +00:00
|
|
|
|
2023-08-29 16:47:41 +00:00
|
|
|
// Request valid
|
|
|
|
else
|
|
|
|
{
|
|
|
|
// Update download stats
|
|
|
|
$db->addMagnetDownload($magnet->magnetId, $userId, time());
|
2023-08-27 09:07:08 +00:00
|
|
|
|
2023-08-29 16:47:41 +00:00
|
|
|
// Build magnet link
|
|
|
|
$link = [];
|
2023-08-27 09:07:08 +00:00
|
|
|
|
2023-08-29 16:47:41 +00:00
|
|
|
/// Exact Topic
|
2023-09-03 23:48:24 +00:00
|
|
|
$xt = [];
|
|
|
|
|
|
|
|
foreach ($db->findMagnetToInfoHashByMagnetId($magnet->magnetId) as $result)
|
|
|
|
{
|
|
|
|
if ($infoHash = $db->getInfoHash($result->infoHashId))
|
|
|
|
{
|
|
|
|
switch ($infoHash->version)
|
|
|
|
{
|
|
|
|
case 1:
|
|
|
|
|
|
|
|
$xt[] = sprintf('xt=urn:btih:%s', $infoHash->value);
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 2:
|
|
|
|
|
2023-09-05 16:14:14 +00:00
|
|
|
$xt[] = sprintf('xt=urn:btmh:1220%s', $infoHash->value);
|
2023-09-03 23:48:24 +00:00
|
|
|
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$link[] = sprintf('magnet:?%s', implode('&', $xt));
|
2023-08-27 09:07:08 +00:00
|
|
|
|
2023-08-29 16:47:41 +00:00
|
|
|
/// Display Name
|
|
|
|
$link[] = sprintf('dn=%s', urlencode($magnet->dn));
|
2023-08-27 21:29:49 +00:00
|
|
|
|
2023-08-29 16:47:41 +00:00
|
|
|
// Keyword Topic
|
|
|
|
$kt = [];
|
2023-08-27 09:07:08 +00:00
|
|
|
|
2023-08-29 16:47:41 +00:00
|
|
|
foreach ($db->findKeywordTopicByMagnetId($magnet->magnetId) as $result)
|
|
|
|
{
|
|
|
|
$kt[] = urlencode($db->getKeywordTopic($result->keywordTopicId)->value);
|
|
|
|
}
|
2023-08-27 09:07:08 +00:00
|
|
|
|
2023-08-29 16:47:41 +00:00
|
|
|
$link[] = sprintf('kt=%s', implode('+', $kt));
|
2023-08-27 09:07:08 +00:00
|
|
|
|
2023-08-29 16:47:41 +00:00
|
|
|
/// Address Tracker
|
|
|
|
foreach ($db->findAddressTrackerByMagnetId($magnet->magnetId) as $result)
|
|
|
|
{
|
|
|
|
$addressTracker = $db->getAddressTracker($result->addressTrackerId);
|
|
|
|
|
|
|
|
$scheme = $db->getScheme($addressTracker->schemeId);
|
|
|
|
$host = $db->getHost($addressTracker->hostId);
|
|
|
|
$port = $db->getPort($addressTracker->portId);
|
|
|
|
$uri = $db->getUri($addressTracker->uriId);
|
|
|
|
|
2023-08-30 10:19:50 +00:00
|
|
|
$url = sprintf('tr=%s', urlencode($port->value ? sprintf('%s://%s:%s%s', $scheme->value,
|
2023-08-29 16:47:41 +00:00
|
|
|
$host->value,
|
|
|
|
$port->value,
|
|
|
|
$uri->value) : sprintf('%s://%s%s', $scheme->value,
|
|
|
|
$host->value,
|
|
|
|
$uri->value)));
|
2023-08-30 10:19:50 +00:00
|
|
|
|
2023-08-31 18:12:25 +00:00
|
|
|
// Yggdrasil url only
|
|
|
|
if (!preg_match(YGGDRASIL_URL_REGEX, $url))
|
2023-08-30 10:19:50 +00:00
|
|
|
{
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
$link[] = $url;
|
2023-08-29 16:47:41 +00:00
|
|
|
}
|
|
|
|
|
2023-08-31 19:21:43 +00:00
|
|
|
// Append trackers.json
|
|
|
|
foreach (json_decode(file_get_contents(__DIR__ . '/../config/trackers.json')) as $tracker)
|
2023-08-29 16:55:46 +00:00
|
|
|
{
|
2023-08-31 19:21:43 +00:00
|
|
|
$link[] = sprintf('tr=%s', urlencode($tracker->announce));
|
2023-08-29 16:55:46 +00:00
|
|
|
}
|
|
|
|
|
2023-08-29 16:47:41 +00:00
|
|
|
/// Acceptable Source
|
|
|
|
foreach ($db->findAcceptableSourceByMagnetId($magnet->magnetId) as $result)
|
|
|
|
{
|
|
|
|
$acceptableSource = $db->getAcceptableSource($result->acceptableSourceId);
|
|
|
|
|
|
|
|
$scheme = $db->getScheme($acceptableSource->schemeId);
|
|
|
|
$host = $db->getHost($acceptableSource->hostId);
|
|
|
|
$port = $db->getPort($acceptableSource->portId);
|
|
|
|
$uri = $db->getUri($acceptableSource->uriId);
|
|
|
|
|
2023-08-30 10:19:50 +00:00
|
|
|
$url = sprintf('as=%s', urlencode($port->value ? sprintf('%s://%s:%s%s', $scheme->value,
|
2023-08-29 16:47:41 +00:00
|
|
|
$host->value,
|
|
|
|
$port->value,
|
|
|
|
$uri->value) : sprintf('%s://%s%s', $scheme->value,
|
|
|
|
$host->value,
|
|
|
|
$uri->value)));
|
2023-08-30 10:19:50 +00:00
|
|
|
|
2023-08-31 18:12:25 +00:00
|
|
|
// Yggdrasil url only
|
|
|
|
if (!preg_match(YGGDRASIL_URL_REGEX, $url))
|
2023-08-30 10:19:50 +00:00
|
|
|
{
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
$link[] = $url;
|
2023-08-29 16:47:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/// Exact Source
|
|
|
|
foreach ($db->findExactSourceByMagnetId($magnet->magnetId) as $result)
|
|
|
|
{
|
|
|
|
$eXactSource = $db->getExactSource($result->eXactSourceId);
|
|
|
|
|
|
|
|
$scheme = $db->getScheme($eXactSource->schemeId);
|
|
|
|
$host = $db->getHost($eXactSource->hostId);
|
|
|
|
$port = $db->getPort($eXactSource->portId);
|
|
|
|
$uri = $db->getUri($eXactSource->uriId);
|
|
|
|
|
2023-08-30 10:19:50 +00:00
|
|
|
$url = sprintf('xs=%s', urlencode($port->value ? sprintf('%s://%s:%s%s', $scheme->value,
|
2023-08-29 16:47:41 +00:00
|
|
|
$host->value,
|
|
|
|
$port->value,
|
|
|
|
$uri->value) : sprintf('%s://%s%s', $scheme->value,
|
|
|
|
$host->value,
|
|
|
|
$uri->value)));
|
2023-08-30 10:19:50 +00:00
|
|
|
|
2023-08-31 18:12:25 +00:00
|
|
|
// Yggdrasil url only
|
|
|
|
if (!preg_match(YGGDRASIL_URL_REGEX, $url))
|
2023-08-30 10:19:50 +00:00
|
|
|
{
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
$link[] = $url;
|
2023-08-29 16:47:41 +00:00
|
|
|
}
|
|
|
|
|
2023-09-05 23:18:05 +00:00
|
|
|
// Return link @TODO implement .bittorrent and separated v1/v2 magnet links
|
|
|
|
$response->title = sprintf(
|
|
|
|
_('%s - Download - %s'),
|
|
|
|
htmlentities($magnet->metaTitle),
|
|
|
|
WEBSITE_NAME
|
|
|
|
);
|
|
|
|
|
|
|
|
$response->message = sprintf( // @TODO MVC page for downloads needed
|
|
|
|
'<h1 class="display-block margin-b-16 font-size-16">%s</h1>
|
2023-09-05 23:34:37 +00:00
|
|
|
<div class="margin-b-16 text-color-night">
|
|
|
|
* make sure BitTorrent client listening Yggdrasil interface!
|
|
|
|
</div>
|
2023-09-05 23:18:05 +00:00
|
|
|
<a href="%s">
|
|
|
|
<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill="currentColor" class="bi bi-magnet" viewBox="0 0 16 16">
|
|
|
|
<path d="M8 1a7 7 0 0 0-7 7v3h4V8a3 3 0 0 1 6 0v3h4V8a7 7 0 0 0-7-7Zm7 11h-4v3h4v-3ZM5 12H1v3h4v-3ZM0 8a8 8 0 1 1 16 0v8h-6V8a2 2 0 1 0-4 0v8H0V8Z"/>
|
|
|
|
</svg>
|
|
|
|
</a>',
|
|
|
|
htmlentities($magnet->metaTitle),
|
|
|
|
implode('&', array_unique($link))
|
2023-08-29 16:47:41 +00:00
|
|
|
);
|
2023-09-05 23:18:05 +00:00
|
|
|
|
|
|
|
// Direct link output could not be useful because not cover all downloads options available on page.
|
|
|
|
// Also opens default app, when Yggdrasil users may run separated client for that needs.
|
|
|
|
// Feedback https://github.com/YGGverse/YGGtracker/issues
|
|
|
|
# header(
|
|
|
|
# sprintf('Location: %s', implode('&', array_unique($link)))
|
|
|
|
# );
|
2023-08-29 16:47:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 'new':
|
|
|
|
|
|
|
|
// Yggdrasil connections only
|
|
|
|
if (!preg_match(YGGDRASIL_URL_REGEX, $_SERVER['REMOTE_ADDR']))
|
|
|
|
{
|
|
|
|
$response->success = false;
|
|
|
|
$response->message = _('Yggdrasil connection required for this action');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Init session
|
|
|
|
else if (!$userId = $db->initUserId($_SERVER['REMOTE_ADDR'], USER_DEFAULT_APPROVED, time()))
|
|
|
|
{
|
|
|
|
$response->success = false;
|
|
|
|
$response->message = _('Could not init user session');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Get user
|
|
|
|
else if (!$user = $db->getUser($userId))
|
|
|
|
{
|
|
|
|
$response->success = false;
|
|
|
|
$response->message = _('Could not init user info');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Validate link
|
|
|
|
if (empty($_GET['magnet']))
|
|
|
|
{
|
|
|
|
$response->success = false;
|
|
|
|
$response->message = _('Link required');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Validate base64
|
|
|
|
else if (!$link = (string) @base64_decode($_GET['magnet']))
|
|
|
|
{
|
|
|
|
$response->success = false;
|
|
|
|
$response->message = _('Invalid link encoding');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Validate magnet
|
|
|
|
else if (!$magnet = Yggverse\Parser\Magnet::parse($link))
|
|
|
|
{
|
|
|
|
$response->success = false;
|
|
|
|
$response->message = _('Invalid magnet link');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Request valid
|
|
|
|
else
|
|
|
|
{
|
|
|
|
// Begin magnet registration
|
|
|
|
try
|
2023-08-27 09:07:08 +00:00
|
|
|
{
|
2023-08-29 16:47:41 +00:00
|
|
|
$db->beginTransaction();
|
|
|
|
|
|
|
|
// Init magnet
|
2023-09-03 23:48:24 +00:00
|
|
|
if ($magnetId = $db->addMagnet( $user->userId,
|
|
|
|
$magnet->xl,
|
|
|
|
$magnet->dn,
|
|
|
|
$link,
|
|
|
|
MAGNET_DEFAULT_PUBLIC,
|
|
|
|
MAGNET_DEFAULT_COMMENTS,
|
|
|
|
MAGNET_DEFAULT_SENSITIVE,
|
|
|
|
$user->approved ? true : MAGNET_DEFAULT_APPROVED,
|
|
|
|
time()))
|
2023-08-27 09:07:08 +00:00
|
|
|
{
|
2023-09-03 23:48:24 +00:00
|
|
|
foreach ($magnet as $key => $value)
|
2023-08-27 09:07:08 +00:00
|
|
|
{
|
2023-09-03 23:48:24 +00:00
|
|
|
switch ($key)
|
2023-08-29 16:47:41 +00:00
|
|
|
{
|
2023-09-03 23:48:24 +00:00
|
|
|
case 'xt':
|
|
|
|
foreach ($value as $xt)
|
|
|
|
{
|
|
|
|
if (Yggverse\Parser\Magnet::isXTv1($xt))
|
2023-08-29 16:47:41 +00:00
|
|
|
{
|
2023-09-03 23:48:24 +00:00
|
|
|
$db->addMagnetToInfoHash(
|
|
|
|
$magnetId,
|
|
|
|
$db->initInfoHashId(
|
|
|
|
Yggverse\Parser\Magnet::filterInfoHash($xt), 1
|
|
|
|
)
|
|
|
|
);
|
2023-08-29 16:47:41 +00:00
|
|
|
}
|
2023-09-03 23:48:24 +00:00
|
|
|
if (Yggverse\Parser\Magnet::isXTv2($xt))
|
2023-08-29 16:47:41 +00:00
|
|
|
{
|
2023-09-03 23:48:24 +00:00
|
|
|
$db->addMagnetToInfoHash(
|
|
|
|
$magnetId,
|
|
|
|
$db->initInfoHashId(
|
|
|
|
Yggverse\Parser\Magnet::filterInfoHash($xt), 2
|
|
|
|
)
|
|
|
|
);
|
2023-08-29 16:47:41 +00:00
|
|
|
}
|
2023-09-03 23:48:24 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 'tr':
|
|
|
|
foreach ($value as $tr)
|
|
|
|
{
|
|
|
|
if ($url = Yggverse\Parser\Url::parse($tr))
|
2023-08-29 16:47:41 +00:00
|
|
|
{
|
2023-09-03 23:48:24 +00:00
|
|
|
if (preg_match(YGGDRASIL_URL_REGEX, str_replace(['[',']'], false, $url->host->name)))
|
2023-08-29 16:47:41 +00:00
|
|
|
{
|
2023-09-03 23:48:24 +00:00
|
|
|
$db->initMagnetToAddressTrackerId(
|
|
|
|
$magnetId,
|
|
|
|
$db->initAddressTrackerId(
|
|
|
|
$db->initSchemeId($url->host->scheme),
|
|
|
|
$db->initHostId($url->host->name),
|
|
|
|
$db->initPortId($url->host->port),
|
|
|
|
$db->initUriId($url->page->uri)
|
|
|
|
)
|
|
|
|
);
|
2023-08-29 16:47:41 +00:00
|
|
|
}
|
|
|
|
}
|
2023-09-03 23:48:24 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 'ws':
|
|
|
|
foreach ($value as $ws)
|
|
|
|
{
|
|
|
|
// @TODO
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 'as':
|
|
|
|
foreach ($value as $as)
|
|
|
|
{
|
|
|
|
if ($url = Yggverse\Parser\Url::parse($as))
|
2023-08-29 16:47:41 +00:00
|
|
|
{
|
2023-09-03 23:48:24 +00:00
|
|
|
if (preg_match(YGGDRASIL_URL_REGEX, str_replace(['[',']'], false, $url->host->name)))
|
2023-08-29 16:47:41 +00:00
|
|
|
{
|
2023-09-03 23:48:24 +00:00
|
|
|
$db->initMagnetToAcceptableSourceId(
|
|
|
|
$magnetId,
|
|
|
|
$db->initAcceptableSourceId(
|
|
|
|
$db->initSchemeId($url->host->scheme),
|
|
|
|
$db->initHostId($url->host->name),
|
|
|
|
$db->initPortId($url->host->port),
|
|
|
|
$db->initUriId($url->page->uri)
|
|
|
|
)
|
|
|
|
);
|
2023-08-29 16:47:41 +00:00
|
|
|
}
|
|
|
|
}
|
2023-09-03 23:48:24 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 'xs':
|
|
|
|
foreach ($value as $xs)
|
|
|
|
{
|
|
|
|
if ($url = Yggverse\Parser\Url::parse($xs))
|
2023-08-29 16:47:41 +00:00
|
|
|
{
|
2023-09-03 23:48:24 +00:00
|
|
|
if (preg_match(YGGDRASIL_URL_REGEX, str_replace(['[',']'], false, $url->host->name)))
|
|
|
|
{
|
|
|
|
$db->initMagnetToExactSourceId(
|
|
|
|
$magnetId,
|
|
|
|
$db->initExactSourceId(
|
|
|
|
$db->initSchemeId($url->host->scheme),
|
|
|
|
$db->initHostId($url->host->name),
|
|
|
|
$db->initPortId($url->host->port),
|
|
|
|
$db->initUriId($url->page->uri)
|
|
|
|
)
|
|
|
|
);
|
|
|
|
}
|
2023-08-29 16:47:41 +00:00
|
|
|
}
|
2023-09-03 23:48:24 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 'mt':
|
|
|
|
foreach ($value as $mt)
|
|
|
|
{
|
|
|
|
// @TODO
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 'x.pe':
|
|
|
|
foreach ($value as $xPe)
|
|
|
|
{
|
|
|
|
// @TODO
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case 'kt':
|
|
|
|
foreach ($value as $kt)
|
|
|
|
{
|
|
|
|
$db->initMagnetToKeywordTopicId(
|
|
|
|
$magnetId,
|
|
|
|
$db->initKeywordTopicId(trim(mb_strtolower(strip_tags(html_entity_decode($kt)))))
|
|
|
|
);
|
|
|
|
}
|
|
|
|
break;
|
2023-08-29 16:47:41 +00:00
|
|
|
}
|
2023-09-03 23:48:24 +00:00
|
|
|
}
|
2023-08-29 16:47:41 +00:00
|
|
|
|
2023-09-03 23:48:24 +00:00
|
|
|
$db->commit();
|
2023-08-29 16:47:41 +00:00
|
|
|
|
2023-09-03 23:48:24 +00:00
|
|
|
// Redirect to edit page
|
|
|
|
header(sprintf('Location: %s/edit.php?magnetId=%s', trim(WEBSITE_URL, '/'), $magnetId));
|
2023-08-27 09:07:08 +00:00
|
|
|
}
|
|
|
|
|
2023-08-29 16:47:41 +00:00
|
|
|
} catch (Exception $e) {
|
|
|
|
|
|
|
|
var_dump($e);
|
2023-08-27 09:07:08 +00:00
|
|
|
|
2023-08-29 16:47:41 +00:00
|
|
|
$db->rollBack();
|
2023-08-27 09:07:08 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-08-29 16:47:41 +00:00
|
|
|
break;
|
2023-08-27 09:07:08 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
?>
|
|
|
|
|
|
|
|
<!DOCTYPE html>
|
|
|
|
<html lang="en-US">
|
|
|
|
<head>
|
|
|
|
<link rel="stylesheet" type="text/css" href="<?php echo WEBSITE_URL ?>/assets/theme/default/css/common.css?<?php echo WEBSITE_CSS_VERSION ?>" />
|
|
|
|
<link rel="stylesheet" type="text/css" href="<?php echo WEBSITE_URL ?>/assets/theme/default/css/framework.css?<?php echo WEBSITE_CSS_VERSION ?>" />
|
|
|
|
<title>
|
2023-09-05 23:18:05 +00:00
|
|
|
<?php echo $response->title ?>
|
2023-08-27 09:07:08 +00:00
|
|
|
</title>
|
|
|
|
<meta name="robots" content="noindex,nofollow"/>
|
|
|
|
<meta name="author" content="YGGtracker" />
|
|
|
|
<meta charset="UTF-8" />
|
|
|
|
</head>
|
|
|
|
<body>
|
|
|
|
<header>
|
|
|
|
<div class="container">
|
|
|
|
<div class="row margin-t-8 text-center">
|
|
|
|
<a class="logo" href="<?php echo WEBSITE_URL ?>"><?php echo str_replace('YGG', '<span>YGG</span>', WEBSITE_NAME) ?></a>
|
|
|
|
<form class="margin-t-8" name="search" method="get" action="<?php echo WEBSITE_URL ?>/index.php">
|
|
|
|
<input type="text" name="query" value="" placeholder="<?php echo _('search or submit magnet link') ?>" />
|
|
|
|
<input type="submit" value="<?php echo _('submit') ?>" />
|
|
|
|
</form>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</header>
|
|
|
|
<main>
|
|
|
|
<div class="container">
|
|
|
|
<div class="row">
|
|
|
|
<div class="column width-100">
|
|
|
|
<div class="padding-16 margin-y-8 border-radius-3 background-color-night">
|
|
|
|
<div class="text-center"><?php echo $response->message ?></div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
2023-09-05 23:18:05 +00:00
|
|
|
<?php if (!empty($_SERVER['HTTP_REFERER']) && false !== strpos($_SERVER['HTTP_REFERER'], WEBSITE_URL)) { ?>
|
|
|
|
<div class="row">
|
|
|
|
<div class="column width-100 text-right">
|
|
|
|
<a class="button margin-l-8"
|
|
|
|
rel="nofollow"
|
|
|
|
href="<?php echo $_SERVER['HTTP_REFERER'] ?>">
|
2023-09-05 23:34:37 +00:00
|
|
|
<?php echo _('back') ?>
|
2023-09-05 23:18:05 +00:00
|
|
|
</a>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<?php } ?>
|
2023-08-27 09:07:08 +00:00
|
|
|
</div>
|
|
|
|
</main>
|
|
|
|
<footer>
|
|
|
|
<div class="container">
|
|
|
|
<div class="row">
|
|
|
|
<div class="column width-100 text-center margin-y-8">
|
2023-08-31 19:21:43 +00:00
|
|
|
<?php foreach (json_decode(file_get_contents(__DIR__ . '/../config/trackers.json')) as $i => $tracker) { ?>
|
|
|
|
<?php if (!empty($tracker->announce) && !empty($tracker->stats)) { ?>
|
|
|
|
<a href="<?php echo $tracker->announce ?>"><?php echo sprintf('Tracker %s', $i + 1) ?></a>
|
|
|
|
/
|
|
|
|
<a href="<?php echo $tracker->stats ?>"><?php echo _('Stats') ?></a>
|
|
|
|
|
|
|
|
|
<?php } ?>
|
2023-08-27 09:07:08 +00:00
|
|
|
<?php } ?>
|
2023-08-30 12:53:57 +00:00
|
|
|
<a href="<?php echo WEBSITE_URL ?>/node.php"><?php echo _('Node') ?></a>
|
2023-08-30 12:32:31 +00:00
|
|
|
|
|
2023-09-05 21:27:05 +00:00
|
|
|
<a rel="nofollow" href="<?php echo WEBSITE_URL ?>/index.php?rss"><?php echo _('RSS') ?></a>
|
2023-08-27 09:20:07 +00:00
|
|
|
|
|
2023-08-27 09:07:08 +00:00
|
|
|
<a href="https://github.com/YGGverse/YGGtracker"><?php echo _('GitHub') ?></a>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</footer>
|
|
|
|
</body>
|
|
|
|
</html>
|