...
This commit is contained in:
43
.Trash-1000/files/TagController.php
Normal file
43
.Trash-1000/files/TagController.php
Normal file
@@ -0,0 +1,43 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Controllers;
|
||||
|
||||
use App\Models\Tag;
|
||||
use App\Models\Video;
|
||||
use Illuminate\Http\Request;
|
||||
|
||||
class TagController extends Controller
|
||||
{
|
||||
/**
|
||||
* Display a listing of the resource.
|
||||
*
|
||||
* @return \Illuminate\View\View
|
||||
*/
|
||||
public function index()
|
||||
{
|
||||
return view('tags', ['tags' => Tag::all()]);
|
||||
}
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* Display the specified resource.
|
||||
*
|
||||
* @param string $normalized
|
||||
* @param int|null $id
|
||||
* @return \Illuminate\Http\RedirectResponse|\Illuminate\View\View
|
||||
*/
|
||||
public function showVideo($tagName)
|
||||
{
|
||||
// Retrieve the tag based on the provided tag name
|
||||
$tag = Tag::where('name', $tagName)->firstOrFail();
|
||||
|
||||
// Get a random video related to the tag
|
||||
$randomVideo = \App\Models\Video::getSingleRandom($tag);
|
||||
|
||||
// Pass the tag and the random video to your view
|
||||
return view('tag.show')->with(compact('tag', 'randomVideo'));
|
||||
}
|
||||
|
||||
// Define other CRUD operations for tags as needed.
|
||||
}
|
@@ -42,7 +42,6 @@ class CategoryController extends Controller
|
||||
{
|
||||
//
|
||||
}
|
||||
|
||||
/**
|
||||
* Display the specified resource.
|
||||
*
|
||||
@@ -52,10 +51,12 @@ class CategoryController extends Controller
|
||||
*/
|
||||
public function showVideo($shortname, $id = null)
|
||||
{
|
||||
// return $shortname;
|
||||
$category = Category::whereShortname($shortname)->first();
|
||||
if (is_null($category)) {
|
||||
return redirect()->back()->with('error', 'Category not found');
|
||||
}
|
||||
|
||||
if (is_null($id)) {
|
||||
$video = Video::getRandom($category);
|
||||
if ($video instanceof HasMany) {
|
||||
@@ -70,6 +71,7 @@ class CategoryController extends Controller
|
||||
// TODO: Add warning page
|
||||
$video = $category->videos()->find($id);
|
||||
}
|
||||
|
||||
if (is_null($video)) {
|
||||
return redirect()->back()->with('error', 'Category is empty.');
|
||||
}
|
||||
|
118
app/Http/Controllers/DebugController.php
Normal file
118
app/Http/Controllers/DebugController.php
Normal file
@@ -0,0 +1,118 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Controllers;
|
||||
|
||||
use Illuminate\Http\Request;
|
||||
|
||||
use App\Http\Requests;
|
||||
use App\Http\Controllers\Controller;
|
||||
|
||||
use App\Models\Category;
|
||||
use App\Models\Tag;
|
||||
|
||||
class DebugController extends Controller
|
||||
{
|
||||
public function getRandomVideoForCategory(Category $category)
|
||||
{
|
||||
$randomVideo = \App\Models\Video::getRandom($category);
|
||||
|
||||
// Now you can return or use $randomVideo as needed
|
||||
}
|
||||
|
||||
public function getRandomVideoForTag(Tag $tag)
|
||||
{
|
||||
$randomVideo = \App\Models\Video::getRandom($tag);
|
||||
|
||||
// Now you can return or use $randomVideo as needed
|
||||
}
|
||||
|
||||
public function getSingleRandomVideoForCategory(Category $category)
|
||||
{
|
||||
$singleRandomVideo = \App\Models\Video::getSingleRandom($category);
|
||||
|
||||
// Now you can return or use $singleRandomVideo as needed
|
||||
}
|
||||
|
||||
public function getSingleRandomVideoForTag(Tag $tag)
|
||||
{
|
||||
$singleRandomVideo = \App\Models\Video::getSingleRandom($tag);
|
||||
|
||||
// Now you can return or use $singleRandomVideo as needed
|
||||
}
|
||||
|
||||
/**
|
||||
* Display a listing of the resource.
|
||||
*
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function index()
|
||||
{
|
||||
//
|
||||
}
|
||||
|
||||
/**
|
||||
* Show the form for creating a new resource.
|
||||
*
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function create()
|
||||
{
|
||||
//
|
||||
}
|
||||
|
||||
/**
|
||||
* Store a newly created resource in storage.
|
||||
*
|
||||
* @param \Illuminate\Http\Request $request
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function store(Request $request)
|
||||
{
|
||||
//
|
||||
}
|
||||
|
||||
/**
|
||||
* Display the specified resource.
|
||||
*
|
||||
* @param int $id
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function show($id)
|
||||
{
|
||||
//
|
||||
}
|
||||
|
||||
/**
|
||||
* Show the form for editing the specified resource.
|
||||
*
|
||||
* @param int $id
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function edit($id)
|
||||
{
|
||||
//
|
||||
}
|
||||
|
||||
/**
|
||||
* Update the specified resource in storage.
|
||||
*
|
||||
* @param \Illuminate\Http\Request $request
|
||||
* @param int $id
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function update(Request $request, $id)
|
||||
{
|
||||
//
|
||||
}
|
||||
|
||||
/**
|
||||
* Remove the specified resource from storage.
|
||||
*
|
||||
* @param int $id
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function destroy($id)
|
||||
{
|
||||
//
|
||||
}
|
||||
}
|
230
app/Http/Controllers/TagviewController.php
Normal file
230
app/Http/Controllers/TagviewController.php
Normal file
@@ -0,0 +1,230 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Controllers;
|
||||
|
||||
use App\Models\Category;
|
||||
use App\Models\Video;
|
||||
use App\Models\Banner;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Database\Eloquent\Relations\HasMany;
|
||||
|
||||
use App\Http\Requests;
|
||||
class TagviewController extends Controller
|
||||
{
|
||||
/**
|
||||
* Display a listing of the resource.
|
||||
*
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function index($tag)
|
||||
{
|
||||
$tag = $video = Video::with('tags')->find($tag->id);
|
||||
return $tag;
|
||||
// $tag = Video::withAnyTags($tag)->first();
|
||||
// return $tag;
|
||||
// $video = Video::with('tags')->find($tag->id);
|
||||
// return redirect('t/' . $tag->normalized . '/' . $video->id);
|
||||
}
|
||||
|
||||
/**
|
||||
* Show the form for creating a new resource.
|
||||
*
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function create()
|
||||
{
|
||||
//
|
||||
}
|
||||
|
||||
public function tagview($tag, $id = null)
|
||||
{
|
||||
|
||||
if (is_null($tag)) {
|
||||
return "penis";
|
||||
}
|
||||
// return $tag;
|
||||
// $tag =
|
||||
$video = Video::getRandom($tag);
|
||||
return $video;
|
||||
|
||||
|
||||
//$video = Video::with('tags')->find($tag->id);
|
||||
if(!$id) {
|
||||
// id unset
|
||||
return redirect('t/' . $tag . '/' . $video->id);
|
||||
} else {
|
||||
|
||||
return view('tagviewdev',[
|
||||
'video' => $video,
|
||||
'related' => $video
|
||||
]);
|
||||
}
|
||||
}
|
||||
|
||||
// public function tagview($tag, $id = null)
|
||||
// {
|
||||
// $x = Video::withAllTags($tag)->first();
|
||||
|
||||
// // return $x;
|
||||
// // id 1
|
||||
// // file "1.webm"
|
||||
// // videotitle "su"
|
||||
// // interpret null
|
||||
// // songtitle null
|
||||
// // imgsource null
|
||||
// // category_id 8
|
||||
// // user_id 1
|
||||
// // created_at "2024-02-22 00:31:49"
|
||||
// // updated_at "2024-02-22 00:31:49"
|
||||
// // deleted_at null
|
||||
// // hash "3cdd7e0aa1a1cf175e06f22da2f485091f3b9f22"
|
||||
// // tag_id 2
|
||||
// // taggable_id 1
|
||||
// // taggable_type "App\\Models\\Video"
|
||||
// // name "misc"
|
||||
// // normalized "misc"
|
||||
|
||||
// if(!$id) {
|
||||
// // gibs keine...
|
||||
// $z = Video::getAllTags();
|
||||
// return $z;
|
||||
// } else {
|
||||
// $y = $x->id;
|
||||
// return $y;
|
||||
// }
|
||||
// }
|
||||
|
||||
// public function tagview($tag, $id = null)
|
||||
// {
|
||||
// // $tag_in = Video::withAnyTags($tag)->first();
|
||||
// // return $tag_in;
|
||||
// $video = Video::getRandom($tag->id);
|
||||
// if ($video instanceof HasMany) {
|
||||
// $video = $video->first();
|
||||
// }
|
||||
// // $video = Video::getRandom($tag->id);
|
||||
|
||||
// if (is_null($id)) {
|
||||
// $video = Video::getRandom($tag);
|
||||
// } else {
|
||||
|
||||
// }
|
||||
// }
|
||||
|
||||
// public function helloworld($tag, $id = null)
|
||||
// {
|
||||
// if(!$tag) {
|
||||
// return redirect()->back()->with('error', 'Tag not found');
|
||||
// }
|
||||
|
||||
// if (is_null($id)) {
|
||||
// $tag = Video::withAnyTags($tag)->first();
|
||||
// return redirect('t/' . $tag->normalized . '/' . $tag->id);
|
||||
// } else {
|
||||
// $tag = Video::withAnyTags($tag)->first();
|
||||
// $video = Video::with('tags')->find($tag->id);
|
||||
|
||||
// return view('tagviewdev', [
|
||||
// 'id' => $tag->id,
|
||||
// 'video' => $video,
|
||||
// 'tag' => $tag->name,
|
||||
// 'related' => $video->name,
|
||||
// 'banner' => 'banner'
|
||||
// ]);
|
||||
// }
|
||||
|
||||
// if(!$id) {
|
||||
// // is not null
|
||||
// // implement redirect to t/$tag/$id
|
||||
// } else {
|
||||
// $tag = Video::withAnyTags($tag)->first();
|
||||
// // reverse lookup of $video thanks to the api for tag
|
||||
// $video = Video::with('tags')->find($tag->id);
|
||||
|
||||
// $tags = $video->tags;
|
||||
|
||||
// return view('tagviewdev', [
|
||||
// 'video' => $video,
|
||||
// 'tags' => $tags,
|
||||
// 'related' => $tag->name
|
||||
// ]);
|
||||
// //return redirect('t/' . $tag . '/' . );
|
||||
// }
|
||||
|
||||
// $blub = $tag->id;
|
||||
// return $blub;
|
||||
|
||||
// if (is_null($id)) {
|
||||
|
||||
// $video = Video::getRandom($tag);
|
||||
// if ($video instanceof HasMany) {
|
||||
// $video = $video->first();
|
||||
// }
|
||||
// else {
|
||||
// return redirect()->back()->with('error', '404');
|
||||
// }
|
||||
// return redirect('t/' . $tag . '/' . $video->id);
|
||||
// } else {
|
||||
// // Don't filter on specific video.
|
||||
// // TODO: Add warning page
|
||||
// // $video = $tag->videos()->find($id);
|
||||
// }
|
||||
|
||||
// //return $tag;
|
||||
// return view('tagviewdev', [
|
||||
// 'tag' => $tag,
|
||||
// 'related' => $tag,
|
||||
// ]);
|
||||
|
||||
|
||||
/**
|
||||
* Store a newly created resource in storage.
|
||||
*
|
||||
* @param \Illuminate\Http\Request $request
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
/**
|
||||
* Display the specified resource.
|
||||
*
|
||||
* @param int $id
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function show($id)
|
||||
{
|
||||
//
|
||||
}
|
||||
|
||||
/**
|
||||
* Show the form for editing the specified resource.
|
||||
*
|
||||
* @param int $id
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function edit($id)
|
||||
{
|
||||
//
|
||||
}
|
||||
|
||||
/**
|
||||
* Update the specified resource in storage.
|
||||
*
|
||||
* @param \Illuminate\Http\Request $request
|
||||
* @param int $id
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function update(Request $request, $id)
|
||||
{
|
||||
//
|
||||
}
|
||||
|
||||
/**
|
||||
* Remove the specified resource from storage.
|
||||
*
|
||||
* @param int $id
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function destroy($id)
|
||||
{
|
||||
//
|
||||
}
|
||||
}
|
@@ -141,7 +141,7 @@ Route::group(["middleware" => "theme"], function() {
|
||||
#Route::get('rulez', 'rulezController@index')->middleware('auth');
|
||||
Route::get('todo', function() { return view('todo'); })->middleware('auth');
|
||||
Route::get('contact', function() { return view('contact'); });
|
||||
Route::get('change', function() { return view('change'); });
|
||||
//Route::get('change', function() { return view('change'); });
|
||||
#Route::get('terms', function() { return view('tos'); })->middleware('auth');
|
||||
Route::get('privacy', function() { return view('privacy'); });
|
||||
Route::get('marderchen', function() { return view('marder'); });
|
||||
@@ -154,6 +154,7 @@ Route::group(["middleware" => "theme"], function() {
|
||||
//'fav_count' => \App\Models\UserFavorite::count(),
|
||||
'latest_video' => \App\Models\Video::getLastId(),
|
||||
'newest_user' => \App\Models\User::orderBy('id', 'DESC')->first()->username,
|
||||
// this function heavily slows down the page load on /stats in prod. should be addressed some day
|
||||
'dirsize' => shell_exec("(du -sh " . public_path() . "/b | cut -f1)")
|
||||
]);
|
||||
})->middleware('auth');
|
||||
@@ -185,4 +186,9 @@ Route::group(["middleware" => "theme"], function() {
|
||||
##Category View
|
||||
Route::get('{shortname}', 'CategoryController@showVideo')->where('shortname', '[a-z][a-z0-9]+');
|
||||
Route::get('{shortname}/{id}', 'CategoryController@showVideo')->where(['shortname' => '[a-z][a-z0-9]+', 'id' => '[0-9]+']);
|
||||
|
||||
##Tag View anybody?
|
||||
Route::get('t/{tag}', 'TagviewController@tagview')->where('tag', '[a-z][a-z0-9]+');
|
||||
Route::get('t/{tag}/{id}', 'TagviewController@tagview')->where(['tag' => '[a-z][a-z0-9]+', 'id' => '[0-9]+']);
|
||||
|
||||
});
|
||||
|
@@ -4,26 +4,6 @@ namespace App\Models;
|
||||
|
||||
use Illuminate\Database\Eloquent\Model;
|
||||
|
||||
/**
|
||||
* App\Models\Category
|
||||
*
|
||||
* @property integer $id
|
||||
* @property string $name
|
||||
* @property string $shortname
|
||||
* @property string $description
|
||||
* @property \Carbon\Carbon $created_at
|
||||
* @property \Carbon\Carbon $updated_at
|
||||
* @property string $deleted_at
|
||||
* @property-read \Illuminate\Database\Eloquent\Collection|Video[] $videos
|
||||
* @method static \Illuminate\Database\Query\Builder|\App\Models\Category whereId($value)
|
||||
* @method static \Illuminate\Database\Query\Builder|\App\Models\Category whereName($value)
|
||||
* @method static \Illuminate\Database\Query\Builder|\App\Models\Category whereShortname($value)
|
||||
* @method static \Illuminate\Database\Query\Builder|\App\Models\Category whereDescription($value)
|
||||
* @method static \Illuminate\Database\Query\Builder|\App\Models\Category whereCreatedAt($value)
|
||||
* @method static \Illuminate\Database\Query\Builder|\App\Models\Category whereUpdatedAt($value)
|
||||
* @method static \Illuminate\Database\Query\Builder|\App\Models\Category whereDeletedAt($value)
|
||||
* @property-read \Illuminate\Database\Eloquent\Collection|User[] $users
|
||||
*/
|
||||
class Rulez extends Model
|
||||
{
|
||||
|
||||
|
@@ -51,6 +51,10 @@ class Video extends Model
|
||||
use SoftDeletes;
|
||||
use \Cviebrock\EloquentTaggable\Taggable;
|
||||
|
||||
public static function getTags() {
|
||||
return $tag_list;
|
||||
}
|
||||
|
||||
public function user() {
|
||||
return $this->belongsTo(User::class);
|
||||
}
|
||||
@@ -237,13 +241,24 @@ public function blurryThumb() {
|
||||
return static::filtered()->skip($id);
|
||||
}
|
||||
|
||||
public static function getSingleRandom($related = null) {
|
||||
$query = $related ? $related->videos()->filtered() : static::filtered();
|
||||
$count = $query->countScoped()->count();
|
||||
if ($count < 1) {
|
||||
return null; // Return null if no videos found
|
||||
}
|
||||
return $query->inRandomOrder()->first();
|
||||
}
|
||||
|
||||
public function isSfw() {
|
||||
return !$this->tags->contains(function ($key, $tag) {
|
||||
return $tag->normalized === 'nsfw';
|
||||
});
|
||||
}
|
||||
|
||||
|
||||
public function filesize() {
|
||||
return filesize(getcwd() . "/b/" . $this->file);
|
||||
}
|
||||
}
|
||||
|
||||
|
13
public/css/w0bmcustom.css
vendored
13
public/css/w0bmcustom.css
vendored
@@ -1505,7 +1505,7 @@ div#tag-add {
|
||||
}
|
||||
|
||||
/* Sidebar Mobile */
|
||||
|
||||
/*
|
||||
@media (max-width: 767px) {
|
||||
#sidebar {
|
||||
top: 40em;
|
||||
@@ -1563,15 +1563,14 @@ div#tag-add {
|
||||
}
|
||||
@media (max-width: 367px) {
|
||||
#sidebar {
|
||||
/*top: 24.6em;*/
|
||||
top: 27em;
|
||||
}
|
||||
}
|
||||
@media (max-width: 360px) {
|
||||
}*/
|
||||
/*@media (max-width: 360px) {
|
||||
#sidebar {
|
||||
top: 26.6em;
|
||||
}
|
||||
}
|
||||
} */
|
||||
/* Sidebar Mobile Queries END */
|
||||
/* TAGS MOBILE FIXED */
|
||||
|
||||
@@ -2278,7 +2277,7 @@ input.form-control {
|
||||
}
|
||||
|
||||
/* Handy fix */
|
||||
@media (max-width: 690px) {
|
||||
/* @media (max-width: 690px) {
|
||||
.text-center {
|
||||
font-size: 19px;
|
||||
display: flex;
|
||||
@@ -2304,7 +2303,7 @@ input.form-control {
|
||||
margin-bottom: 5px;
|
||||
color: #eaedec;
|
||||
}
|
||||
}
|
||||
} */
|
||||
|
||||
|
||||
@media (max-width: 690px) {
|
||||
|
@@ -20,9 +20,8 @@
|
||||
}
|
||||
</style>
|
||||
|
||||
<h5>Oh shit! Something went wrong!</h5>
|
||||
<h5>If you can see this message something with the software went wrong.</h5>
|
||||
<div id="sf-resetcontent" class="sf-reset box">
|
||||
<h6>Please don't send this fucking text to an admin, we have other problems.</h6>
|
||||
<?php
|
||||
$iv = openssl_random_pseudo_bytes(16);
|
||||
?>
|
||||
|
@@ -2,8 +2,6 @@
|
||||
<html>
|
||||
<head>
|
||||
<title>Please Stand By we are just fucking this up</title>
|
||||
<link href="https://fonts.googleapis.com/css?family=Lato:100" rel="stylesheet" type="text/css">
|
||||
|
||||
<style>
|
||||
html, body {
|
||||
height: 100%;
|
||||
|
@@ -4,8 +4,7 @@
|
||||
<head>
|
||||
<meta http-equiv="X-UA-Compatible" content="IE=edge">
|
||||
<meta name="theme-color" content="#161618">
|
||||
<meta name="viewport"
|
||||
content="width=device-width,initial-scale=1">
|
||||
<meta name="viewport" content="width=device-width,initial-scale=1">
|
||||
<meta charset="UTF-8">
|
||||
<meta name="_token" content="{{csrf_token()}}">
|
||||
<meta name="keywords" content="Random WebMs, WebMs, Internet Videos">
|
||||
|
@@ -19,6 +19,7 @@
|
||||
<p>Also make sure to check out his uploads <a href="https://w0bm.com/main?q=marderchen">https://w0bm.com/main?q=marderchen</a> and enjoy it.</p>
|
||||
|
||||
<p><i>- w0bm staff</i></p>
|
||||
<p style="float: right;">21.6.2023</p>
|
||||
</div>
|
||||
@endsection
|
||||
|
||||
|
5
resources/views/layout1/partials/devtools.blade.php
Normal file
5
resources/views/layout1/partials/devtools.blade.php
Normal file
@@ -0,0 +1,5 @@
|
||||
<div style="position: relative;">
|
||||
<?php
|
||||
echo $category;
|
||||
?>
|
||||
</div>
|
1
resources/views/layout1/tagviewdev.blade.php
Normal file
1
resources/views/layout1/tagviewdev.blade.php
Normal file
@@ -0,0 +1 @@
|
||||
{{$related}} lol
|
@@ -1,3 +1,6 @@
|
||||
<div style="background:black;color:green;">
|
||||
{{$video}}
|
||||
</div>
|
||||
@extends('layout')
|
||||
@section('content')
|
||||
|
||||
@@ -135,6 +138,7 @@
|
||||
</aside>
|
||||
|
||||
@else
|
||||
{{{-- Wenn man nicht eingeloggt ist könnte man folgendes sehen, bzw machen --}}}
|
||||
<div class="centered">
|
||||
<div class="modal-content col-md-5">
|
||||
<div class="modal-header">
|
||||
|
Reference in New Issue
Block a user