Files
SamiAhmed7777 0b7e2d0a5b feat: Add comprehensive documentation suite and reorganize project structure
- Created complete documentation in docs/ directory
- Added PROJECT_OVERVIEW.md with feature highlights and getting started guide
- Added ARCHITECTURE.md with system design and technical details
- Added SECURITY.md with comprehensive security implementation guide
- Added DEVELOPMENT.md with development workflows and best practices
- Added DEPLOYMENT.md with production deployment instructions
- Added API.md with complete REST API documentation
- Added CONTRIBUTING.md with contribution guidelines
- Added CHANGELOG.md with version history and migration notes
- Reorganized all documentation files into docs/ directory for better organization
- Updated README.md with proper documentation links and quick navigation
- Enhanced project structure with professional documentation standards
2025-10-21 00:39:45 -07:00

100 lines
4.2 KiB
PHP

<?php
/*******************************************************************************************************************
| Software Name : EasyStream
| Software Description : High End YouTube Clone Script with Videos, Shorts, Streams, Images, Audio, Documents, Blogs
| Software Author : (c) Sami Ahmed
|*******************************************************************************************************************
|
|*******************************************************************************************************************
| This source file is subject to the EasyStream Proprietary License Agreement.
|
| By using this software, you acknowledge having read this Agreement and agree to be bound thereby.
|*******************************************************************************************************************
| Copyright (c) 2025 Sami Ahmed. All rights reserved.
|*******************************************************************************************************************/
ini_set("error_reporting", E_ALL & ~E_STRICT & ~E_NOTICE & ~E_DEPRECATED);
define('_ISVALID', true);
$main_dir = realpath(dirname(__FILE__) . '/../../../../');
set_include_path($main_dir);
include_once 'filter.php';
$class_filter = new VFilter;
//include_once $class_language->setLanguageFile('frontend', 'language.global');
$host = array('127.0.0.1');
$_POST = $HTTP_RAW_POST_DATA = file_get_contents('php://input');
$post = json_decode($_POST);
if ($_POST and in_array($_SERVER["REMOTE_ADDR"], $host)) {
require 'cfg.php';
$conn = mysqli_connect($dbhost, $dbuser, $dbpass, $dbname);
if (!$conn) {
die('Could not connect: ' . mysqli_error($conn));
}
echo "Connected successfully\n";
$cid = $class_filter->clr_str($post->a);
$sid = $class_filter->clr_str($post->e);
$type = is_array($post->b) ? $post->b : $class_filter->clr_str($post->b);
$user = $class_filter->clr_str($post->c);
$user2 = $class_filter->clr_str($post->d);
$pk = $class_filter->clr_str($post->g);
switch ($type) {
case "follow":
case "unfollow":
$text = $type == 'follow' ? $user . ' is now following' : $user . ' has unfollowed';
$sql = sprintf("SELECT `db_id`, `chat_user`, `channel_id`, `channel_owner`, `usr_id`, `logged_in` FROM `db_livechat` WHERE `stream_id`='%s' AND `chat_id`='%s' ORDER BY `db_id` DESC LIMIT 1;", $sid, $cid);
$r = mysqli_query($conn, $sql);
$rn = $r->num_rows;
$rv = $r->fetch_assoc();
if ($rn > 0) {
$ch_id = $rv["channel_id"];
$sql = sprintf("SELECT `db_id` FROM `db_livenotifications` WHERE `type`='follow' AND `channel_id`='%s' AND `text` LIKE '%s' LIMIT 1;", $ch_id, $user . '%');
$rr = mysqli_query($conn, $sql);
if ($rr->num_rows == 0 and $type == 'follow') {
$q = sprintf("INSERT INTO `db_livenotifications` (`type`, `channel_id`, `text`, `displayed`) VALUES ('%s', '%s', '%s', '0');", $type, $ch_id, $text);
mysqli_query($conn, $q);
}
}
mysqli_close($conn);
break;
default:
if (is_array($type) and ($type[0] == 'subscribe' or $type[0] == 'unsubscribe')) {
$text = $type[0] == 'subscribe' ? $user2 . ' has subscribed with a ' . $pk . ' subscription' : $user2 . ' has unsubscribed';
$sql = sprintf("SELECT `db_id`, `chat_user`, `channel_id`, `channel_owner`, `usr_id`, `logged_in` FROM `db_livechat` WHERE `stream_id`='%s' AND `chat_id`='%s' ORDER BY `db_id` DESC LIMIT 1;", $sid, $cid);
$r = mysqli_query($conn, $sql);
$rn = $r->num_rows;
$rv = $r->fetch_assoc();
if ($rn > 0) {
$ch_id = $rv["channel_id"];
if ($type[0] == 'subscribe') {
$q = sprintf("INSERT INTO `db_livenotifications` (`type`, `channel_id`, `text`, `displayed`) VALUES ('%s', '%s', '%s', '0');", $type[0], $ch_id, $text);
mysqli_query($conn, $q);
}
}
}
mysqli_close($conn);
break;
}
}
if ($conn) {
mysqli_close($conn);
}