Compare commits

..

17 Commits

35 changed files with 851 additions and 693 deletions
Executable → Regular
+32 -22
View File
@@ -1,32 +1,42 @@
<!DOCTYPE html> <!DOCTYPE html>
<html lang='en'> <html lang="en">
<head> <head>
<title>Page not found - Johannes Olzem</title> <title>404 Not found - Johannes Olzem</title>
<meta name='description' content="Johannes Olzem's Webspace."> <meta name="description" content="Johannes Olzem's personal website">
<meta charset='utf-8'> <meta charset="utf-8">
<link rel='stylesheet' href='/css/style.css'> <link rel="stylesheet" href="/css/style.css">
<meta name='viewport' content='width=device-width, initial-scale=1.0'> <meta name="viewport" content="width=device-width, initial-scale=1.0">
<link rel='icon' href='/favico.ico'> <link rel="icon" href="/favico.ico">
</head> </head>
<body> <body>
<header>
<a href='/' class='home-ref'>
<img src='/assets/logo.png' alt='Johannes Olzem'>
<span>Johannes Olzem</span>
</a>
<nav> <nav>
<a href='/blog/'>Blog</a> <a href="/" class="header-logo">
<a href='/about/'>About Me</a> <img src="/img/header-logo.webp" alt="logo">
<a href='/contact/'>Contact</a> </a>
<span class="header-text">Johannes Olzem</span>
<ul>
<li>
<a href="/about/">About</a>
</li>
<li>
<a href="/blog/">Blog</a>
</li>
<li>
<a href="/contact/">Contact</a>
</li>
</ul>
</nav> </nav>
</header> <main>
<main class='full'> <h1>404 Not found</h1>
<h1>404 Error</h1> <p>
<p style='text-align: center;'>The page you requested couldn't be found. </p> The page you want to reach was not found on this server.<br>
<a href='/'>Return to homepage</a> Click <a href="/">here</a> to return home.
</p>
</main> </main>
<footer> <footer>
<h6><a href><script>document.write(window.location.href);</script></a></h6> &copy; 2021 - <script>document.write(new Date().getFullYear())</script> Johannes Olzem
<br>
<small>This website is free software. You can redistribute and modify it under the terms of the GNU General Public License V3.</small>
</footer> </footer>
</body> </body>
</html>
Executable → Regular
+77 -37
View File
@@ -1,46 +1,63 @@
<!DOCTYPE html> <!DOCTYPE html>
<html lang='en'> <html lang="en">
<head> <head>
<title>About - Johannes Olzem</title> <title>About - Johannes Olzem</title>
<meta name='description' content="Johannes Olzem's Webspace."> <meta name="description" content="Johannes Olzem's personal website">
<meta charset='utf-8'> <meta charset="utf-8">
<meta name='viewport' content='width=device-width, initial-scale=1.0'> <link rel="stylesheet" href="/css/style.css">
<link rel='stylesheet' href='/css/style.css'> <meta name="viewport" content="width=device-width, initial-scale=1.0">
<link rel='icon' href='/favico.ico'> <link rel="icon" href="/favico.ico">
</head> </head>
<body> <body>
<header>
<a href='/' class='home-ref'>
<img src='/assets/logo.png' alt='Johannes Olzem'>
<span>Johannes Olzem</span>
</a>
<nav> <nav>
<a href='/blog/'>Blog</a> <a href="/" class="header-logo">
<a href='/about/'>About Me</a> <img src="/img/header-logo.webp" alt="logo">
<a href='/contact/'>Contact</a> </a>
<span class="header-text">Johannes Olzem</span>
<ul>
<li>
<a href="/about/">About</a>
</li>
<li>
<a href="/blog/">Blog</a>
</li>
<li>
<a href="/contact/">Contact</a>
</li>
</ul>
</nav> </nav>
</header>
<main> <main>
<h2>About Me</h2> <h1>About me</h1>
<!--<img src='/img/me.png' style='float:left;margin:1rem;border-radius:1rem;height:256px;'>--> <p>
<p style='margin-bottom: 2rem;'> Hey there!<br>
Hey there!<br /> My name is Johannes, and I'm a computer enthusiast born and raised in
My name is Johannes, and I'm a computer enthusiast born and raised in Germany. Germany. Recently, I graduated from school, majoring in IT and English,
Currently, I'm majoring in IT and English, and I'm passionate about most things related to technology. and I am now training to become an IT specialist. I am passionate about
I love using free and open-source software, exploring different aspects about Linux, setting up and tinkering with servers, most things related to technology, but specifically I am passionate about
and learning about privacy and security. When I'm not busy with the command line, I enjoy playing video games and building/modifying mechanical keyboards. using free and open-source software, exploring different aspects of
Apart from computers, I also have an interest in cars, ranging from classic to modern sports cars. Linux, setting up and tinkering with servers, and learning about online
privacy and security. When I'm not busy with the command line, I enjoy
playing video games and building/modifying mechanical keyboards. Apart
from computers I enjoy making my own pourover coffee, I am a big fan of
technical fashion and I like cars.
</p> </p>
<h2>My Skills</h2> <h1>
<h3>Languages</h3> My Skills
<p style='margin: 1rem !important; text-align: center;'>I have at least basic knowledge in the following programming languages:</p> </h1>
<p>
I have at least basic knowledge in the following technologies:
</p>
<div style="float:left" class="skills">
<h2>Languages</h2>
<ul> <ul>
<li>HTML &amp; CSS</li> <li>HTML &amp; CSS</li>
<li>Java</li> <li>Java</li>
<li>Python</li> <li>Python</li>
<li>PHP</li> <li>PHP</li>
</ul> </ul>
<h3>Other Technologies</h3> </div>
<div style="float:right" class="skills">
<h2>Other technologies</h2>
<ul> <ul>
<li>Linux</li> <li>Linux</li>
<li>Git</li> <li>Git</li>
@@ -48,18 +65,41 @@
<li>LaTeX</li> <li>LaTeX</li>
<li>Docker</li> <li>Docker</li>
</ul> </ul>
<p>If you are interested in a research paper I wrote for a mandatory school project about Linux you can find it <a href='/facharbeit.pdf'>here</a>. My grade for this project was a 13 out of 15 possible grade points.</p> </div>
<h2>About this website</h2> <h1>About this website</h1>
<p> <p>
This website has no ads or trackers and does not use cookies.<br> While I might not have been using the internet much or at all during the
It is also free and open source under the <a href='/LICENSE.txt'>GNU General Public License v3</a>.<br> web 1.0 times (which this site was originally modeled after) I do believe
<a href='https://github.com/jolzem/jolzem.github.io/'>View Source Code</a><br> that modern websites are unnecessarly bloated in many ways. They contain
</p> ads and trackers (that's just how capitalism works, I can't really
complain about that) but also so much useless JavaScript. I agree that it
is very useful in certain areas but sometimes it is just not needed. Like
in the case of a news site, or a recipe site, which in my opinion could
just be served statically without much (or any) JavaScript. Because of
this, I created this website, to make a small contribution to the
debloated minimal web. Just pure HTML and CSS with some (useful) quality
of life JavaScript. No ads, trackers, or cookies.
<br> <br>
<a href="https://www.digitalocean.com/?refcode=bd507e5a75ca&utm_campaign=Referral_Invite&utm_medium=Referral_Program&utm_source=badge"><img src="https://web-platforms.sfo2.cdn.digitaloceanspaces.com/WWW/Badge%201.svg" alt="DigitalOcean Referral Badge" style="height:50px" /></a> It is also free and Open Source under the GNU General Public License V3,
which you can find <a href="/LICENSE.txt">here.</a>
<br>
<a href="https://git.olzem.org/jolzem/olzem.org">Source code</a>
</p>
<h1>What happened to this site?</h1>
<p>
I have recently taken an interest in a lot of different elements of
design. While I was previously already quite interested in interior
design, my recent deep dive into the design rabbit hole led me to learn
about a lot of different design languages, different designers, and
aspects of design like product design or, more importantly, graphic
design. After seeing a few different images online, I felt inspired and
decided to redesign my own website.
</p>
</main> </main>
<footer> <footer>
<h6><a href><script>document.write(window.location.href);</script></a></h6> &copy; 2021 - <script>document.write(new Date().getFullYear())</script> Johannes Olzem
<br>
<small>This website is free software. You can redistribute and modify it under the terms of the GNU General Public License V3.</small>
</footer> </footer>
</body> </body>
</html>
Binary file not shown.

After

Width:  |  Height:  |  Size: 13 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 32 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 12 KiB

BIN
View File
Binary file not shown.

Before

Width:  |  Height:  |  Size: 18 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 110 KiB

+87 -76
View File
@@ -1,137 +1,143 @@
<!DOCTYPE html> <!DOCTYPE html>
<html lang='en'> <html lang="en">
<head> <head>
<title>How to create a Rust server on Linux - Blog - Johannes Olzem</title> <title>How to create a Rust server on Linux - Johannes Olzem</title>
<meta name='description' content="Johannes Olzem's Webspace."> <meta name="description" content="Johannes Olzem's personal website">
<meta charset='utf-8'> <meta charset="utf-8">
<link rel='stylesheet' href='/css/style.css'> <link rel="stylesheet" href="/css/style.css">
<meta name='viewport' content='width=device-width, initial-scale=1.0'> <meta name="viewport" content="width=device-width, initial-scale=1.0">
<link rel='icon' href='/favico.ico'> <link rel="icon" href="/favico.ico">
</head> </head>
<body> <body>
<header>
<a href='/' class='home-ref'>
<img src='/assets/logo.png' alt='Johannes Olzem'>
<span>Johannes Olzem</span>
</a>
<nav> <nav>
<a href='/blog/'>Blog</a> <a href="/" class="header-logo">
<a href='/about/'>About Me</a> <img src="/img/header-logo.webp" alt="logo">
<a href='/contact/'>Contact</a> </a>
<span class="header-text">Johannes Olzem</span>
<ul>
<li>
<a href="/about/">About</a>
</li>
<li>
<a href="/blog/">Blog</a>
</li>
<li>
<a href="/contact/">Contact</a>
</li>
</ul>
</nav> </nav>
</header>
<main> <main>
<h1>How to create a Rust server on Linux</h1> <h1>How to create a Rust server on Linux</h1>
<div class='author'>Johannes Olzem</div> <div class="author">Johannes Olzem</div>
<div class='date'>May 23, 2023</div> <div class="date">May 23, 2023</div>
<h2>Table of Contents</h2> <h2>Table of Contents</h2>
<ul> <ul>
<li><a href='#Requirements'>Requirements</a></li> <li><a href="#Requirements">Requirements</a></li>
<li><a href='#SteamCMD'>SteamCMD</a><br /></li> <li><a href="#SteamCMD">SteamCMD</a><br></li>
<li><a href='#Installing'>Installing</a><br /></li> <li><a href="#Installing">Installing</a><br></li>
<li><a href='#Running'>Running</a></li> <li><a href="#Running">Running</a></li>
</ul> </ul>
<h2 id='Requirements'>Requirements</h2> <h2 id="Requirements">Requirements</h2>
<ul> <ul>
<li>Debian Linux</li> <li>Debian Linux</li>
<li>&#62;5GB of RAM</li> <li>&gt;5GB of RAM</li>
<li>&#62;4.5GB of free disc space</li> <li>&gt;4.5GB of free disc space</li>
</ul> </ul>
<h2 id='SteamCMD'>SteamCMD</h2> <h2 id="SteamCMD">SteamCMD</h2>
<h3>Configuring the envoirenment</h3> <h3>Configuring the envoirenment</h3>
<p> <p>
Create a user with the name 'steam' and give it a password. Create a user with the name "steam" and give it a password.
</p> </p>
<p class='code'> <p class="code cmd">
sudo useradd -m steam sudo useradd -m steam
</p> </p>
<p class='code'> <p class="code cmd">
sudo passwd steam sudo passwd steam
</p> </p>
<br /> <br>
<p> <p>
When prompted, enter a new password for the 'steam' user. <br /> When prompted, enter a new password for the "steam" user. <br>
Then switch to the 'steam' user and go to its home folder. Then switch to the "steam" user and go to its home folder.
</p> </p>
<p class='code'> <p class="code cmd">
su steam su steam
</p> </p>
<p class='code'> <p class="code cmd">
cd cd
</p> </p>
<br /> <br>
<p> <p>
Enable the contrib and non-free repositories by changing your <code>/etc/apt/sources.list</code> to resemble the following: Enable the contrib and non-free repositories by changing your <code>/etc/apt/sources.list</code> to resemble the following:
</p> </p>
<p class='code no-dollar' style='text-align:left;'> <p class="code" style="text-align:left;">
deb http://deb.debian.org/debian bullseye main contrib non-free<br /> deb http://deb.debian.org/debian bullseye main contrib non-free<br>
deb-src http://deb.debian.org/debian bullseye main contrib non-free<br /> deb-src http://deb.debian.org/debian bullseye main contrib non-free<br>
<br /> <br>
deb http://deb.debian.org/debian-security/ bullseye-security main contrib non-free<br /> deb http://deb.debian.org/debian-security/ bullseye-security main contrib non-free<br>
deb-src http://deb.debian.org/debian-security/ bullseye-security main contrib non-free<br /> deb-src http://deb.debian.org/debian-security/ bullseye-security main contrib non-free<br>
<br /> <br>
deb http://deb.debian.org/debian bullseye-updates main contrib non-free<br /> deb http://deb.debian.org/debian bullseye-updates main contrib non-free<br>
deb-src http://deb.debian.org/debian bullseye-updates main contrib non-free<br /> deb-src http://deb.debian.org/debian bullseye-updates main contrib non-free<br>
</p> </p>
<h3>Installing SteamCMD</h3> <h3>Installing SteamCMD</h3>
<p> <p>
Finally, to install SteamCMD run: Finally, to install SteamCMD run:
</p> </p>
<p class='code'> <p class="code cmd">
sudo apt install steamcmd sudo apt install steamcmd
</p> </p>
<br /> <br>
<h2 id='Installing'>Installing</h2> <h2 id="Installing">Installing</h2>
<p> <p>
Run SteamCMD Run SteamCMD
</p> </p>
<p class='code'> <p class="code cmd">
steamcmd steamcmd
</p> </p>
<br /> <br>
<p> <p>
After a short update period, a prompt like <code>Steam&#62;</code> should appear.<br /> After a short update period, a prompt like <code>Steam&gt;</code> should appear.<br>
To login anonymously type: To login anonymously type:
</p> </p>
<p class='code no-dollar'> <p class="code">
login anonymous login anonymous
</p> </p>
<br /> <br>
<p> <p>
Now install the Rust Dedicated Server application. Now install the Rust Dedicated Server application.
</p> </p>
<p class='code no-dollar'> <p class="code">
app_update 258550 app_update 258550
</p> </p>
<p> <p>
This will install and verify the Rust server.<br /> This will install and verify the Rust server.<br>
On my ~100 Mbit/s connection this took around 15-20 Minutes. <br /> On my ~100 Mbit/s connection this took around 15-20 Minutes. <br>
<br /> <br>
Afterwards you can quit the SteamCMD shell. Afterwards you can quit the SteamCMD shell.
</p> </p>
<p class='code no-dollar'> <p class="code">
quit quit
</p> </p>
<br /> <br>
<h2 id='Running'>Running</h2> <h2 id="Running">Running</h2>
<p> <p>
First navigate to the Rust server directory. First navigate to the Rust server directory.
</p> </p>
<p class='code'> <p class="code cmd">
cd ~/Steam/steamapps/common/rust_dedicated cd ~/Steam/steamapps/common/rust_dedicated
</p> </p>
<br /> <br>
<p> <p>
Finally, start up the Rust server by running: Finally, start up the Rust server by running:
</p> </p>
<p class='code'> <p class="code cmd">
./RustDedicated -batchmode ./RustDedicated -batchmode
</p> </p>
<br /> <br>
<p> <p>
There are several arguments you can pass to the server to change its behaviour. There are several arguments you can pass to the server to change its behaviour.
</p> </p>
<br /> <br>
<table> <table>
<tbody><tr> <tbody><tr>
<th>Parameter <th>Parameter
@@ -185,14 +191,14 @@
<tr> <tr>
<td><code>+server.hostname</code> <td><code>+server.hostname</code>
</td> </td>
<td><code>'Your Server Name'</code> <td><code>"Your Server Name"</code>
</td> </td>
<td>The displayed name of your server. <td>The displayed name of your server.
</td></tr> </td></tr>
<tr> <tr>
<td><code>+server.identity</code> <td><code>+server.identity</code>
</td> </td>
<td><code>'my_server_identity'</code> <td><code>"my_server_identity"</code>
</td> </td>
<td>Changes path to your server data rust/server/my_server_identity. Useful for running multiple instances. <td>Changes path to your server data rust/server/my_server_identity. Useful for running multiple instances.
</td></tr> </td></tr>
@@ -227,7 +233,7 @@
<tr> <tr>
<td><code>+rcon.password</code> <td><code>+rcon.password</code>
</td> </td>
<td><code>'YourPassword'</code> <td><code>"YourPassword"</code>
</td> </td>
<td>Sets the RCON password <td>Sets the RCON password
</td></tr> </td></tr>
@@ -236,35 +242,40 @@
</td> </td>
<td><code>gamelog.txt</code> <td><code>gamelog.txt</code>
</td> </td>
<td>If you're using a script, you'd better put the current date as a filename, otherwise, it'll be erased on every start. <td>If you're using a script, you'd better put the current date as a
filename, otherwise, it'll be erased on every start.
</td></tr> </td></tr>
<tr> <tr>
<td><code>-silent-crashes</code> <td><code>-silent-crashes</code>
</td> </td>
<td><code> - </code> <td><code> - </code>
</td> </td>
<td>Won't display a crash dialog and will restart automatically if server is installed as service. <td>Won't display a crash dialog and will restart automatically if server
is installed as service.
</td></tr></tbody> </td></tr></tbody>
</table> </table>
<br /> <br>
<h2>Sources</h2> <h2>Sources</h2>
<ul> <ul>
<li> <li>
<a href='https://wiki.facepunch.com/rust/Creating-a-server'>Rust Wiki, 'Creating a server'</a> <a href="https://wiki.facepunch.com/rust/Creating-a-server">Rust Wiki, "Creating a server"</a>
</li> </li>
<li> <li>
<a href='https://developer.valvesoftware.com/wiki/SteamCMD#Linux'>Valve Developer Community, 'SteamCMD'</a> <a href="https://developer.valvesoftware.com/wiki/SteamCMD#Linux">Valve Developer Community, "SteamCMD"</a>
</li> </li>
<li> <li>
<a href='https://www.rustafied.com/how-to-host-your-own-rust-server'>Rustafied, 'How to: Host your own Rust Dedicated Server'</a> <a href="https://www.rustafied.com/how-to-host-your-own-rust-server">Rustafied, "How to: Host your own Rust Dedicated Server"</a>
</li> </li>
<li> <li>
<a href='https://developer.valvesoftware.com/wiki/Rust_Dedicated_Server'>Valve Developer Community, 'Rust Dedicated Server'</a> <a href="https://developer.valvesoftware.com/wiki/Rust_Dedicated_Server">Valve Developer Community, "Rust Dedicated Server"</a>
</li> </li>
</ul> </ul>
</main> </main>
</main>
<footer> <footer>
<h6><a href><script>document.write(window.location.href);</script></a></h6> &copy; 2021 - <script>document.write(new Date().getFullYear())</script> Johannes Olzem
<br>
<small>This website is free software. You can redistribute and modify it under the terms of the GNU General Public License V3.</small>
</footer> </footer>
</body> </body>
</html>
Executable → Regular
+40 -24
View File
@@ -1,35 +1,51 @@
<!DOCTYPE html> <!DOCTYPE html>
<html lang='en'> <html lang="en">
<head> <head>
<title>Blog - Johannes Olzem</title> <title>Blog - Johannes Olzem</title>
<meta name='description' content="Johannes Olzem's Webspace."> <meta name="description" content="Johannes Olzem's personal website">
<meta charset='utf-8'> <meta charset="utf-8">
<link rel='stylesheet' href='/css/style.css'> <link rel="stylesheet" href="/css/style.css">
<meta name='viewport' content='width=device-width, initial-scale=1.0'> <meta name="viewport" content="width=device-width, initial-scale=1.0">
<link rel='icon' href='/favico.ico'> <link rel="icon" href="/favico.ico">
</head> </head>
<body> <body>
<header>
<a href='/' class='home-ref'>
<img src='/assets/logo.png' alt='Johannes Olzem'>
<span>Johannes Olzem</span>
</a>
<nav> <nav>
<a href='/blog/'>Blog</a> <a href="/" class="header-logo">
<a href='/about/'>About Me</a> <img src="/img/header-logo.webp" alt="logo">
<a href='/contact/'>Contact</a> </a>
<span class="header-text">Johannes Olzem</span>
<ul>
<li>
<a href="/about/">About</a>
</li>
<li>
<a href="/blog/">Blog</a>
</li>
<li>
<a href="/contact/">Contact</a>
</li>
</ul>
</nav> </nav>
</header> <main>
<main class='full'> <h1>Blog</h1>
<h2>Blog</h2> <p>
<div class='blog-entries'> Anything I write will go here:
<a href='quick-fixes/'>Quick Fixes</a> </p>
<a href='the-current-state-of-software-is-utterly-ridiculous/'>The current state of software is utterly ridiculous</a> <ul>
<a href='how-to-create-a-rust-server-on-linux/'>How to create a Rust server on Linux</a> <li>
</div> <a href="/blog/quick-fixes/">Quick fixes</a>
</li>
<li>
<a href="/blog/how-to-create-a-rust-server-on-linux/">
23.05.23: How to create a Rust server on linux.
</a>
</li>
</ul>
</main> </main>
<footer> <footer>
<h6><a href><script>document.write(window.location.href);</script></a></h6> &copy; 2021 - <script>document.write(new Date().getFullYear())</script> Johannes Olzem
<br>
<small>This website is free software. You can redistribute and modify it under the terms of the GNU General Public License V3.</small>
</footer> </footer>
</body> </body>
</html>
+29 -21
View File
@@ -1,34 +1,42 @@
<!DOCTYPE html> <!DOCTYPE html>
<html lang='en'> <html lang="en">
<head> <head>
<title>Quick Fix - Blog - Johannes Olzem</title> <title>Quick fix - Johannes Olzem</title>
<meta name='description' content="Johannes Olzem's Webspace."> <meta name="description" content="Johannes Olzem's personal website">
<meta charset='utf-8'> <meta charset="utf-8">
<link rel='stylesheet' href='/css/style.css'> <link rel="stylesheet" href="/css/style.css">
<meta name='viewport' content='width=device-width, initial-scale=1.0'> <meta name="viewport" content="width=device-width, initial-scale=1.0">
<link rel='icon' href='/favico.ico'> <link rel="icon" href="/favico.ico">
</head> </head>
<body> <body>
<header>
<a href='/' class='home-ref'>
<img src='/assets/logo.png' alt='Johannes Olzem'>
<span>Johannes Olzem</span>
</a>
<nav> <nav>
<a href='/blog/'>Blog</a> <a href="/" class="header-logo">
<a href='/about/'>About Me</a> <img src="/img/header-logo.webp" alt="logo">
<a href='/contact/'>Contact</a> </a>
<span class="header-text">Johannes Olzem</span>
<ul>
<li>
<a href="/about/">About</a>
</li>
<li>
<a href="/blog/">Blog</a>
</li>
<li>
<a href="/contact/">Contact</a>
</li>
</ul>
</nav> </nav>
</header> <main>
<main class='full'> <h1>Quick fix</h1>
<h1>Connected without internet on Android after setting PiHole as DNS server.</h1> <h2>Connected without internet on Android after setting PiHole as DNS server.</h2>
<br>
<p> <p>
Make sure you forward both TCP and UDP of port 53 from your Docker container. Make sure you forward both TCP and UDP of port 53 from your Docker container.
</p> </p>
</main> </main>
<footer> <footer>
<h6><a href><script>document.write(window.location.href);</script></a></h6> &copy; 2021 - <script>document.write(new Date().getFullYear())</script> Johannes Olzem
<br>
<small>This website is free software. You can redistribute and modify it under the terms of the GNU General Public License V3.</small>
</footer> </footer>
</body> </body>
</html>
+52 -22
View File
@@ -1,38 +1,68 @@
<!DOCTYPE html> <!DOCTYPE html>
<html lang='en'> <html lang="en">
<head> <head>
<title>Quick Fix - Blog - Johannes Olzem</title> <title>Quick fix - Johannes Olzem</title>
<meta name='description' content="Johannes Olzem's Webspace."> <meta name="description" content="Johannes Olzem's personal website">
<meta charset='utf-8'> <meta charset="utf-8">
<link rel='stylesheet' href='/css/style.css'> <link rel="stylesheet" href="/css/style.css">
<meta name='viewport' content='width=device-width, initial-scale=1.0'> <meta name="viewport" content="width=device-width, initial-scale=1.0">
<link rel='icon' href='/favico.ico'> <link rel="icon" href="/favico.ico">
</head> </head>
<body> <body>
<header>
<a href='/' class='home-ref'>
<img src='/assets/logo.png' alt='Johannes Olzem'>
<span>Johannes Olzem</span>
</a>
<nav> <nav>
<a href='/blog/'>Blog</a> <a href="/" class="header-logo">
<a href='/about/'>About Me</a> <img src="/img/header-logo.webp" alt="logo">
<a href='/contact/'>Contact</a> </a>
<span class="header-text">Johannes Olzem</span>
<ul>
<li>
<a href="/about/">About</a>
</li>
<li>
<a href="/blog/">Blog</a>
</li>
<li>
<a href="/contact/">Contact</a>
</li>
</ul>
</nav> </nav>
</header> <main>
<main class='full'> <h1>Quick fix</h1>
<h1>HomeAssistant not connecting over reverse proxy</h1> <h2>HomeAssistant not connecting over reverse proxy</h2>
<br>
<p> <p>
Make sure you have enabled <em>Websockets Supports</em> or similar functionality in your reverse proxy client. Make sure you have enabled <em>Websockets Support</em> or similar
functionality in your reverse proxy client.
</p>
<p>
If you are getting a <code>400 Bad Request</code> error, find the
HomeAssistant log file and look for the following error message:
</p>
<p class="code">
A request from a reverse proxy was received from 12.34.56.78, but your
HTTP integration is not set-up for reverse proxies
</p>
<p>
In your <code>configuration.yaml</code> file, add the following lines:
</p>
<p class="code">
http:<br>
&emsp;use_x_forwarded_for: true<br>
&emsp;trusted_proxies:<br>
&emsp;&emsp;- 12.34.56.78 # The IP address from the error message
</p> </p>
<h2>Explanation</h2> <h2>Explanation</h2>
<p> <p>
HomeAssistant uses websockets to communicate with the browser. HomeAssistant uses websockets to communicate with the browser.
</p> </p>
<p>
If you are using a reverse proxy, the IP address of the incoming
connection is not trusted and gets rejected by HomeAssistant.
</p>
</main> </main>
<footer> <footer>
<h6><a href><script>document.write(window.location.href);</script></a></h6> &copy; 2021 - <script>document.write(new Date().getFullYear())</script> Johannes Olzem
<br>
<small>This website is free software. You can redistribute and modify it under the terms of the GNU General Public License V3.</small>
</footer> </footer>
</body> </body>
</html>
Executable → Regular
+59 -28
View File
@@ -1,39 +1,70 @@
<!DOCTYPE html> <!DOCTYPE html>
<html lang='en'> <html lang="en">
<head> <head>
<title>Quick Fixes - Johannes Olzem</title> <title>Quick fixes - Johannes Olzem</title>
<meta name='description' content="Johannes Olzem's Webspace."> <meta name="description" content="Johannes Olzem's personal website">
<meta charset='utf-8'> <meta charset="utf-8">
<link rel='stylesheet' href='/css/style.css'> <link rel="stylesheet" href="/css/style.css">
<meta name='viewport' content='width=device-width, initial-scale=1.0'> <meta name="viewport" content="width=device-width, initial-scale=1.0">
<link rel='icon' href='/favico.ico'> <link rel="icon" href="/favico.ico">
</head> </head>
<body> <body>
<header>
<a href='/' class='home-ref'>
<img src='/assets/logo.png' alt='Johannes Olzem'>
<span>Johannes Olzem</span>
</a>
<nav> <nav>
<a href='/blog/'>Blog</a> <a href="/" class="header-logo">
<a href='/about/'>About Me</a> <img src="/img/header-logo.webp" alt="logo">
<a href='/contact/'>Contact</a> </a>
<span class="header-text">Johannes Olzem</span>
<ul>
<li>
<a href="/about/">About</a>
</li>
<li>
<a href="/blog/">Blog</a>
</li>
<li>
<a href="/contact/">Contact</a>
</li>
</ul>
</nav> </nav>
</header>
<main> <main>
<h2>Quick Fixes</h2> <h1>Quick fixes</h1>
<h3>This is a page with small problems, to which I have found easy solutions, so as to not litter the blog page.</h3> <p>
<div class='blog-entries'> This is a page with small problems, to which I have found easy solutions,
<a href='nextcloud-file-not-supported/'>Nextcloud file not supported error</a> so as to not litter the blog page.
<a href='android-pihole-no-internet/'>Connected without internet on Android after setting PiHole as DNS server.</a> </p>
<a href='thinkpad-r61-beep/'> Thinkpad R61 repeated beep on startup</a> <ul>
<a href='pacman-404/'>Pacman install fails with 404</a> <li>
<a href='proton-audio-stuttering/'>Proton / Wine audio stuttering when using qpaeq equalizer</a> <a href="/blog/quick-fixes/android-pihole-no-internet/">
<a href='homeassistant-proxy/'>HomeAssistant not connecting over reverse proxy</a> Connected without internet on Android after setting PiHole as DNS
</div> server
</a>
</li>
<li>
<a href="/blog/quick-fixes/homeassistant-proxy/">
HomeAssistant not connecting over reverse proxy
</a>
</li>
<li>
<a href="/blog/quick-fixes/nextcloud-file-not-supported/">
Nextcloud file not supported error
</a>
</li>
<li>
<a href="/blog/quick-fixes/proton-audio-stuttering/">
Proton / Wine audio stuttering when using qpaeq equalizer
</a>
</li>
<li>
<a href="/blog/quick-fixes/thinkpad-r61-beep/">
Thinkpad R61 repeated beep on startup
</a>
</li>
</ul>
</main> </main>
<footer> <footer>
<h6><a href><script>document.write(window.location.href);</script></a></h6> &copy; 2021 - <script>document.write(new Date().getFullYear())</script> Johannes Olzem
<br>
<small>This website is free software. You can redistribute and modify it under the terms of the GNU General Public License V3.</small>
</footer> </footer>
</body> </body>
</html>
+35 -23
View File
@@ -1,39 +1,51 @@
<!DOCTYPE html> <!DOCTYPE html>
<html lang='en'> <html lang="en">
<head> <head>
<title>Quick Fix - Blog - Johannes Olzem</title> <title>Quick fix - Johannes Olzem</title>
<meta name='description' content="Johannes Olzem's Webspace."> <meta name="description" content="Johannes Olzem's personal website">
<meta charset='utf-8'> <meta charset="utf-8">
<link rel='stylesheet' href='/css/style.css'> <link rel="stylesheet" href="/css/style.css">
<meta name='viewport' content='width=device-width, initial-scale=1.0'> <meta name="viewport" content="width=device-width, initial-scale=1.0">
<link rel='icon' href='/favico.ico'> <link rel="icon" href="/favico.ico">
</head> </head>
<body> <body>
<header>
<a href='/' class='home-ref'>
<img src='/assets/logo.png' alt='Johannes Olzem'>
<span>Johannes Olzem</span>
</a>
<nav> <nav>
<a href='/blog/'>Blog</a> <a href="/" class="header-logo">
<a href='/about/'>About Me</a> <img src="/img/header-logo.webp" alt="logo">
<a href='/contact/'>Contact</a> </a>
<span class="header-text">Johannes Olzem</span>
<ul>
<li>
<a href="/about/">About</a>
</li>
<li>
<a href="/blog/">Blog</a>
</li>
<li>
<a href="/contact/">Contact</a>
</li>
</ul>
</nav> </nav>
</header> <main>
<main class='full'> <h1>Quick fix</h1>
<h1>Nextcloud file not supported error</h1> <h2>Nextcloud file not supported error</h2>
<h2><code>exif_read_data(): File not supported at /var/www/html/lib/private/Metadata/Provider/ExifProvider.php#59</code></h2> <p class="code">
<br> exif_read_data(): File not supported at
/var/www/html/lib/private/Metadata/Provider/ExifProvider.php#59
</p>
<p> <p>
Upload over IP and port rather than over nginx proxy. Upload over IP and port rather than over nginx proxy.
</p> </p>
<h2>Explanation</h2> <h2>Explanation</h2>
<p> <p>
The request payload (the data your are trying to upload) is too large for nginx. The request payload (the data your are trying to upload) is too large for
nginx.
</p> </p>
</main> </main>
<footer> <footer>
<h6><a href><script>document.write(window.location.href);</script></a></h6> &copy; 2021 - <script>document.write(new Date().getFullYear())</script> Johannes Olzem
<br>
<small>This website is free software. You can redistribute and modify it under the terms of the GNU General Public License V3.</small>
</footer> </footer>
</body> </body>
</html>
-41
View File
@@ -1,41 +0,0 @@
<!DOCTYPE html>
<html lang='en'>
<head>
<title>Quick Fix - Blog - Johannes Olzem</title>
<meta name='description' content="Johannes Olzem's Webspace.">
<meta charset='utf-8'>
<link rel='stylesheet' href='/css/style.css'>
<meta name='viewport' content='width=device-width, initial-scale=1.0'>
<link rel='icon' href='/favico.ico'>
</head>
<body>
<header>
<a href='/' class='home-ref'>
<img src='/assets/logo.png' alt='Johannes Olzem'>
<span>Johannes Olzem</span>
</a>
<nav>
<a href='/blog/'>Blog</a>
<a href='/about/'>About Me</a>
<a href='/contact/'>Contact</a>
</nav>
</header>
<main class='full'>
<h1>Pacman install fails with 404</h1>
<h2><code>error: failed retrieving file 'X' from Y : The requested URL returned error: 404</code></h2>
<br>
<p>
Replace <code>/etc/pacman.d/mirrorlist</code> with a new file generated at <a href='https://archlinux.org/mirrorlist/'>https://archlinux.org/mirrorlist/</a>.
<br>
Then run <code>sudo pacman -Syyu</code> to update the package database with the new mirrorlist. Make sure to use 2 y's, to force the new changes.
</p>
<h2>Explanation</h2>
<p>
Your mirrorlist is outdated, possibly due to the recent <a href='https://archlinux.org/news/git-migration-completed/'>pacman git migration</a>.
</p>
</main>
<footer>
<h6><a href><script>document.write(window.location.href);</script></a></h6>
</footer>
</body>
</html>
+29 -21
View File
@@ -1,34 +1,42 @@
<!DOCTYPE html> <!DOCTYPE html>
<html lang='en'> <html lang="en">
<head> <head>
<title>Quick Fix - Blog - Johannes Olzem</title> <title>Quick fix - Johannes Olzem</title>
<meta name='description' content="Johannes Olzem's Webspace."> <meta name="description" content="Johannes Olzem's personal website">
<meta charset='utf-8'> <meta charset="utf-8">
<link rel='stylesheet' href='/css/style.css'> <link rel="stylesheet" href="/css/style.css">
<meta name='viewport' content='width=device-width, initial-scale=1.0'> <meta name="viewport" content="width=device-width, initial-scale=1.0">
<link rel='icon' href='/favico.ico'> <link rel="icon" href="/favico.ico">
</head> </head>
<body> <body>
<header>
<a href='/' class='home-ref'>
<img src='/assets/logo.png' alt='Johannes Olzem'>
<span>Johannes Olzem</span>
</a>
<nav> <nav>
<a href='/blog/'>Blog</a> <a href="/" class="header-logo">
<a href='/about/'>About Me</a> <img src="/img/header-logo.webp" alt="logo">
<a href='/contact/'>Contact</a> </a>
<span class="header-text">Johannes Olzem</span>
<ul>
<li>
<a href="/about/">About</a>
</li>
<li>
<a href="/blog/">Blog</a>
</li>
<li>
<a href="/contact/">Contact</a>
</li>
</ul>
</nav> </nav>
</header> <main>
<main class='full'> <h1>Quick fix</h1>
<h1>Proton / Wine audio stuttering when using qpaeq equalizer</h1> <h2>Proton / Wine audio stuttering when using qpaeq equalizer</h2>
<br>
<p> <p>
Switch to normal audio device. Switch to normal audio device.
</p> </p>
</main> </main>
<footer> <footer>
<h6><a href><script>document.write(window.location.href);</script></a></h6> &copy; 2021 - <script>document.write(new Date().getFullYear())</script> Johannes Olzem
<br>
<small>This website is free software. You can redistribute and modify it under the terms of the GNU General Public License V3.</small>
</footer> </footer>
</body> </body>
</html>
Executable → Regular
+31 -24
View File
@@ -1,39 +1,46 @@
<!DOCTYPE html> <!DOCTYPE html>
<html lang='en'> <html lang="en">
<head> <head>
<title>Quick Fix - Blog - Johannes Olzem</title> <title>Quick fix - Johannes Olzem</title>
<meta name='description' content="Johannes Olzem's Webspace."> <meta name="description" content="Johannes Olzem's personal website">
<meta charset='utf-8'> <meta charset="utf-8">
<link rel='stylesheet' href='/css/style.css'> <link rel="stylesheet" href="/css/style.css">
<meta name='viewport' content='width=device-width, initial-scale=1.0'> <meta name="viewport" content="width=device-width, initial-scale=1.0">
<link rel='icon' href='/favico.ico'> <link rel="icon" href="/favico.ico">
</head> </head>
<body> <body>
<header>
<a href='/' class='home-ref'>
<img src='/assets/logo.png' alt='Johannes Olzem'>
<span>Johannes Olzem</span>
</a>
<nav> <nav>
<a href='/blog/'>Blog</a> <a href="/" class="header-logo">
<a href='/about/'>About Me</a> <img src="/img/header-logo.webp" alt="logo">
<a href='/contact/'>Contact</a> </a>
<span class="header-text">Johannes Olzem</span>
<ul>
<li>
<a href="/about/">About</a>
</li>
<li>
<a href="/blog/">Blog</a>
</li>
<li>
<a href="/contact/">Contact</a>
</li>
</ul>
</nav> </nav>
</header> <main>
<main class='full'> <h1>Quick fix</h1>
<h1>{{ Title }}</h1> <h2>::Title::</h2>
<h2>{{ Problem }}</h2>
<br>
<p> <p>
{{ Fix }} ::Solution
</p> </p>
<h2>Explanation</h2> <h2>Explanation</h2>
<p> <p>
{{ Explanation }} ::Explanation
</p> </p>
</main> </main>
<footer> <footer>
<h6><a href><script>document.write(window.location.href);</script></a></h6> &copy; 2021 - <script>document.write(new Date().getFullYear())</script> Johannes Olzem
<br>
<small>This website is free software. You can redistribute and modify it under the terms of the GNU General Public License V3.</small>
</footer> </footer>
</body> </body>
</html>
+32 -22
View File
@@ -1,29 +1,37 @@
<!DOCTYPE html> <!DOCTYPE html>
<html lang='en'> <html lang="en">
<head> <head>
<title>Quick Fix - Blog - Johannes Olzem</title> <title>Quick fix - Johannes Olzem</title>
<meta name='description' content="Johannes Olzem's Webspace."> <meta name="description" content="Johannes Olzem's personal website">
<meta charset='utf-8'> <meta charset="utf-8">
<link rel='stylesheet' href='/css/style.css'> <link rel="stylesheet" href="/css/style.css">
<meta name='viewport' content='width=device-width, initial-scale=1.0'> <meta name="viewport" content="width=device-width, initial-scale=1.0">
<link rel='icon' href='/favico.ico'> <link rel="icon" href="/favico.ico">
</head> </head>
<body> <body>
<header>
<a href='/' class='home-ref'>
<img src='/assets/logo.png' alt='Johannes Olzem'>
<span>Johannes Olzem</span>
</a>
<nav> <nav>
<a href='/blog/'>Blog</a> <a href="/" class="header-logo">
<a href='/about/'>About Me</a> <img src="/img/header-logo.webp" alt="logo">
<a href='/contact/'>Contact</a> </a>
<span class="header-text">Johannes Olzem</span>
<ul>
<li>
<a href="/about/">About</a>
</li>
<li>
<a href="/blog/">Blog</a>
</li>
<li>
<a href="/contact/">Contact</a>
</li>
</ul>
</nav> </nav>
</header> <main>
<main class='full'> <h1>Quick fix</h1>
<h1>Thinkpad R61 repeated beep on startup</h1> <h2>Thinkpad R61 repeated beep on startup</h2>
<h2>(or any older ThinkPad model, I believe)</h2> <p>
<br> (or any older ThinkPad model, I believe)
</p>
<p> <p>
Check keyboard connector / swap out keyboard. Check keyboard connector / swap out keyboard.
</p> </p>
@@ -33,7 +41,9 @@
</p> </p>
</main> </main>
<footer> <footer>
<h6><a href><script>document.write(window.location.href);</script></a></h6> &copy; 2021 - <script>document.write(new Date().getFullYear())</script> Johannes Olzem
<br>
<small>This website is free software. You can redistribute and modify it under the terms of the GNU General Public License V3.</small>
</footer> </footer>
</body> </body>
</html>
@@ -1,67 +0,0 @@
<!DOCTYPE html>
<html lang='en'>
<head>
<title>The current state of software is utterly ridiculous - Blog - Johannes Olzem</title>
<meta name='description' content="Johannes Olzem's Webspace.">
<meta charset='utf-8'>
<link rel='stylesheet' href='/css/style.css'>
<meta name='viewport' content='width=device-width, initial-scale=1.0'>
<link rel='icon' href='/favico.ico'>
</head>
<body>
<header>
<a href='/' class='home-ref'>
<img src='/assets/logo.png' alt='Johannes Olzem'>
<span>Johannes Olzem</span>
</a>
<nav>
<a href='/blog/'>Blog</a>
<a href='/about/'>About Me</a>
<a href='/contact/'>Contact</a>
</nav>
</header>
<main>
<h1>The current state of software is utterly ridiculous</h1>
<div class='author'>Johannes Olzem</div>
<div class='date'>May 15, 2023</div>
<p>
First off, I want to say that this is not an informative blog post. It's simply a rant on how modern software is increasingly slow and bloated.
</p>
<br />
<p>
Not too long ago, I, as an avid gamer, decided to play a racing sim game with my racing rig. As this is not something you can do, or something I have spent the time figuring out how to do on Linux (another negative aspect of modern software, but something I have come to accept), I booted into my Microsoft Windows 11 installation.
</p>
<br />
<p>
It should be mentioned that this install is on a separate HDD from my Linux installation. After selecting Windows from the GRUB bootloader, I walked away for about 2 minutes to do something else. When I came back, I was, as expected, greeted with the Windows 11 login screen, or rather, the time on top of a pretty landscape picture. At this point, my first frustration started:
</p>
<br />
<p>
After pressing the spacebar to load the login prompt, the digital clock went away as expected. But guess what didn't appear? The login prompt. As a few seconds pass, the digital clock reappears, and I try again multiple times. After about a half-minute to a minute, before starting my last attempt, something else, in addition to the digital clock, spawned on the screen. It was a series of small details about the randomly picked background picture and other details, which I obviously didn't read. So not only did I not want these details, but they also prevented me from logging into my system. In addition to that, I don't know a single person who reads, likes or wants these details at all.
</p>
<br />
<p>
So what's your solution, you might ask? It's incredibly simple: <b>make it a feature, not a bug</b> or a piece of bloatware in this case. Let the user toggle it on if they so desire, but please don't make it a burden for slower systems like mine. (A quick side note: I wouldn't consider my system slow as a whole. I have a 5th Gen Ryzen and 16GB of RAM, but as Windows 11 is installed on an HDD rather than an SSD, I assume most of its slowness comes from this)
</p>
<br />
<p>
After I successfully logged into my system, it took around another minute to be fully usable, but I was already used to that. During this time, I noticed that the Oculus Updater Program had auto-started. As I had recently sold my Oculus VR headset and the program was probably only slowing down my computer, I decided to uninstall it. This brings me to another frustration with the Microsoft Windows operating system: the fact that you cannot uninstall something without a million registry entries and files being left on your system. To my knowledge, it is currently impossible without third-party software to uninstall something completely and remove all traces of it. Using an uninstallation program, however, which in itself is a major piece of bloatware, I was able to remove what I assume is most of the program and its files.
</p>
<br />
<p>
All of this just contributes to my opinion of <b>free</b> and open-source software. The free aspect is actually somewhat important in this case, as sensible solutions can only be found or created by an entire community, rather than one person or organization publishing their code and another person having an idea for improvements to that code. When big tech companies are the only ones in control of their software, they tend to not only roll out necessary updates but also completely useless features and then completely ignore their communities feedback. The best example I can think of in this case is Youtube: they disabled public dislikes and received a huge amount of negative feedback from creators and other users. And instead of listening to what is essentially their main revenue stream, they kept them disabled. In this case, the community was able to evade that change by using a browser extension specially developed for this issue.
</p>
<br />
<p>
I completely understand that companies want to generate revenue with their product, but by intentionally ruining it for some or even all of the users, they are only achieving the opposite. Maybe there is something in the corporate world doing the exact opposite of what I just described, but I, as a mere end-user, cannot think of such a thing.
</p>
<br />
<p>
<b>TLDR:</b> I am frustrated that software, especially the Windows operating system, has moved from being a tool used to interface with a computer to something that has to look pretty and could probably be used by a three-year-old.
</p>
</main>
<footer>
<h6><a href><script>document.write(window.location.href);</script></a></h6>
</footer>
</body>
</html>
Executable → Regular
+37 -23
View File
@@ -1,38 +1,52 @@
<!DOCTYPE html> <!DOCTYPE html>
<html lang='en'> <html lang="en">
<head> <head>
<title>Contact - Johannes Olzem</title> <title>Contact - Johannes Olzem</title>
<meta name='description' content="Johannes Olzem's Webspace."> <meta name="description" content="Johannes Olzem's personal website">
<meta charset='utf-8'> <meta charset="utf-8">
<meta name='viewport' content='width=device-width, initial-scale=1.0'> <link rel="stylesheet" href="/css/style.css">
<link rel='stylesheet' href='/css/style.css'> <meta name="viewport" content="width=device-width, initial-scale=1.0">
<link rel='icon' href='/favico.ico'> <link rel="icon" href="/favico.ico">
</head> </head>
<body> <body>
<header>
<a href='/' class='home-ref'>
<img src='/assets/logo.png' alt='Johannes Olzem'>
<span>Johannes Olzem</span>
</a>
<nav> <nav>
<a href='/blog/'>Blog</a> <a href="/" class="header-logo">
<a href='/about/'>About Me</a> <img src="/img/header-logo.webp" alt="logo">
<a href='/contact/'>Contact</a> </a>
<span class="header-text">Johannes Olzem</span>
<ul>
<li>
<a href="/about/">About</a>
</li>
<li>
<a href="/blog/">Blog</a>
</li>
<li>
<a href="/contact/">Contact</a>
</li>
</ul>
</nav> </nav>
</header> <main>
<main class='full'> <h1>Contact</h1>
<h2>Contact</h2>
<p> <p>
Email me: If you want to get in touch with me you can do so via e-mail at:
<a href='mailto:jolzem@pm.me?subject=Hi!' target='_blank'>jolzem@pm.me</a> <a href="mailto:johannes@olzem.org">johannes@olzem.org</a>
</p> </p>
<br>
<p> <p>
Find me on <a href='https://github.com/jolzem'>GitHub</a>. Additionally we can also connect via
<a href="https://github.com/jolzem">GitHub</a>.
</p>
<p>
Also feel free to visit my other site
<a href="https://keebparts.eu/">keepbarts.eu</a> where I listed a few
keyboard part stores within the EU to safely shop without worrying about
customs or import taxes.
</p> </p>
</main> </main>
<footer> <footer>
<h6><a href><script>document.write(window.location.href);</script></a></h6> &copy; 2021 - <script>document.write(new Date().getFullYear())</script> Johannes Olzem
<br>
<small>This website is free software. You can redistribute and modify it under the terms of the GNU General Public License V3.</small>
</footer> </footer>
</body> </body>
</html>
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Executable → Regular
+216 -163
View File
@@ -1,156 +1,244 @@
@font-face { @font-face {
font-family: 'Work Sans'; font-family: "DM Sans";
src: url('WorkSans-Regular.woff2'); src: url("/css/fonts/DM_Sans/DMSans-Regular.ttf");
font-weight: normal;
} }
@font-face { @font-face {
font-family: 'Work Sans'; font-family: "DM Sans";
src: url('WorkSans-Medium.woff2'); src: url("/css/fonts/DM_Sans/DMSans-Italic.ttf");
font-weight: bold;
}
@font-face {
font-family: 'Work Sans';
src: url('WorkSans-Italic.woff2');
font-style: italic; font-style: italic;
} }
@font-face {
font-family: "DM Mono";
src: url("/css/fonts/DM_Mono/DMMono-Regular.ttf");
}
:root { :root {
--header-bg: rgba(0, 0, 0, 0.95); --black: #14110F;
--txt: #eee; --white: #D5DCF9;
--body-bg: #111;
--accent: #6690d9; --green-bg: #AABD8C;
--border: #aaa; --beige-bg: #E9E3B4;
--font-body: 'Work Sans', sans-serif; --orange-bg: #F39B6D;
--gray-bg: #788896;
--beige-fg: #654236;
}
::selection {
background-color: var(--orange-bg);
color: var(--black);
} }
body { body {
font-family: var(--font-body); background-color: var(--beige-bg);
color: var(--txt); font-family: "DM Sans", "Helvetica", "Arial", sans-serif;
background-color: var(--body-bg);
text-align: center;
margin: 0 auto; margin: 0 auto;
position: relative; font-size: 130%;
min-height: 100vh;
}
header {
margin-bottom: 2.5rem;
background-color: var(--header-bg);
padding: 1.5rem 0;
display: flex;
align-items: center;
justify-content: space-between;
flex-wrap: wrap;
position: sticky;
top: 0;
z-index: 100;
}
header img {
height: 3rem;
margin-left: 1.5rem;
display: block;
}
.home-ref {
display: flex;
align-items: center;
justify-content: center;
}
.home-ref span {
margin-left: 1.5rem;
font-size: 1.5rem;
color: var(--txt);
max-width: 0;
white-space: nowrap;
overflow: hidden;
transition: max-width 0.5s ease-in-out;
}
.home-ref:hover span {
max-width: 200px;
}
header a {
color: var(--accent);
text-decoration: none;
} }
nav { nav {
margin-right: 1.5rem; padding: 2rem;
width: calc(100% - 4rem);
height: 5rem;
display: flex;
align-items: center;
justify-content: space-between;
background: var(--gray-bg);
}
.landing nav {
position: fixed;
background: none;
}
nav li {
display: inline;
white-space: nowrap;
margin: 0 .5rem;
padding: .5rem;
}
@media (max-width: 465px) {
nav li {
padding: .5rem;
display: block;
}
}
.header-text {
display: inline-block;
opacity: 0;
white-space: nowrap;
font-size: 1.75rem;
margin: 0 1.75rem;
overflow: hidden;
transition: opacity calc(.8s * 1.5);
}
.header-logo:hover + .header-text {
opacity: 1;
}
/* Don't display header text to avoid nav collapsing */
@media (max-width: 740px) {
.header-text {
display: none;
}
} }
nav a { nav a {
border: 1px solid var(--border); text-decoration-color: rgba(0,0,0,0);
border-radius: .3rem; color: var(--black);
margin: .7rem; transition: .4s;
padding: .4rem 1.2rem;
text-decoration: none;
user-select: none; user-select: none;
display: inline-block;
color: var(--txt);
transition: 0.5s;
} }
nav a:hover, nav a:active { nav a:hover {
background-color: var(--txt); text-decoration: underline;
border: 1px solid var(--border); text-decoration-color: var(--black);
color: var(--header-bg);
} }
main { .landing nav .header-text {
overflow: hidden; display: none;
padding: 0 2.5rem 5rem 2.5rem; }
max-width: 800px;
body:not(.landing) main {
min-height: calc(100vh - 11rem);
max-width: 60vw;
margin: 0 auto; margin: 0 auto;
} }
main p { .landing-grid {
margin: 0 auto; display: grid;
text-align: justify; width: 100%;
min-height: 100vh;
grid-template-columns: 1fr 1fr;
grid-template-rows: 1fr 1fr;
} }
.full {
height: 80vh; .tl {
background: var(--beige-bg);
}
.tr {
background: var(--green-bg);
display: flex; display: flex;
align-items: center; align-items: flex-end;
justify-content: center; font-size: 3rem;
flex-direction: column; user-select: none;
position: relative;
} }
.full p { .bl {
text-align: justify-all !important; background: var(--orange-bg);
max-width: 600px; padding: .5rem;
font-size: 1.5rem;
display: flex;
justify-content: flex-end;
user-select: none;
} }
.arrow { .br {
position: absolute; background: var(--gray-bg);
bottom: 0; display: flex;
align-items: flex-end;
} }
.full-secondary { @keyframes floatChev {
0% { transform: translate(-23px, -5px); }
50% { transform: translate(-23px, 5px); }
100% { transform: translate(-23px, -5px); }
}
.br span {
font-size: 46px;
animation: floatChev 3s ease-in-out infinite;
user-select: none;
font-family: "Courier", monospace;
}
.landing-lower {
width: 100%;
min-height: 56vh;
display: grid;
grid-template-columns: 1fr 1fr;
}
.ll {
background: var(--green-bg);
text-align: justify;
padding: 0 2rem;
}
@media (min-width: 790px) {
.ll {
padding-left: 20vw;
}
}
.ll h2 {
text-align: right;
}
.landing h2 {
font-size: 3rem;
font-weight: 400;
font-style: italic;
margin: 0;
}
.lr {
background: var(--beige-bg);
padding-left: 2rem;
padding-right: 10vw;
}
.skills {
width: 50%;
height: 17rem;
}
@media (max-width: 580px) {
.landing-grid {
display: block;
width: 100%;
height: 100vh; height: 100vh;
} }
main ul { .landing {
margin: 0 auto; min-height: calc(100vh/4);
margin-bottom: 2rem;
max-width: fit-content;
text-align: left;
} }
.blog-entries a { .br {
padding-top: 1rem; justify-content: center;
}
.br span {
transform: translate(0, -2rem) !important;
}
.landing-lower {
display: block; display: block;
} }
.ll {
padding: 0 1rem;
}
.skills {
width: 100%;
}
}
.author { .author {
float: left; float: left;
max-width: 400px; max-width: 400px;
margin-bottom: 2rem;
} }
.date { .date {
@@ -160,64 +248,29 @@ main ul {
} }
.code { .code {
font-family: monospace; background: var(--green-bg);
padding: .2rem .3rem; font-family: "DM Mono", monospace;
border-radius: .3rem; padding: 1rem;
border: 1px solid var(--border); border-radius: 1rem;
margin: .3rem;
}
.code::before {
content: '$ ';
user-select: none;
}
.no-dollar::before {
content: '';
}
.cowsay {
font-family: monospace;
text-align: left;
white-space: pre;
max-width: fit-content;
display: inline-block;
border: none;
}
footer {
position: absolute;
bottom: 0;
width: 100%;
}
p {
margin: 1rem;
font-size: 1.1em;
line-height: 1.5rem;
}
a {
color: var(--txt);
text-decoration: underline;
transition: 300ms;
}
h1,
h2,
h3,
h4,
h5,
h6,
a:hover,
a:active {
color: var(--accent);
} }
code { code {
padding: .2rem .3rem; font-family: "DM Mono", monospace;
border-radius: .3rem; font-size: 90%;
border: 1px solid var(--border);
margin: .3rem;
} }
.cmd::before {
content: '$ ';
}
footer {
width: 100%;
min-height: 4rem;
text-align: center;
background: var(--green-bg);
padding: .5rem 0;
}
a {
color: var(--beige-fg);
}
-2
View File
@@ -1,2 +0,0 @@
<p>This is only here so I can copy my Monero adress when I need it and don't want to/cannot access my wallet. Don't give me money.</p>
<p style='overflow-wrap: anywhere;'>4BK7poh4kom8tti2HReRjQFbooWNiCiYj6sYfq4jdqBBhfN1FWn3an4ZRb1fytH5363vzyvTxBKzd5UphnexhJ7t1kjzTzP</p>
Executable → Regular
BIN
View File
Binary file not shown.

Before

Width:  |  Height:  |  Size: 121 KiB

After

Width:  |  Height:  |  Size: 15 KiB

BIN
View File
Binary file not shown.

After

Width:  |  Height:  |  Size: 857 B

BIN
View File
Binary file not shown.

After

Width:  |  Height:  |  Size: 2.0 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1006 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 18 KiB

BIN
View File
Binary file not shown.

After

Width:  |  Height:  |  Size: 20 KiB

Executable → Regular
+61 -44
View File
@@ -1,60 +1,77 @@
<!DOCTYPE html> <!DOCTYPE html>
<html lang='en'> <html lang="en">
<head> <head>
<title>Johannes Olzem</title> <title>Johannes Olzem</title>
<meta name='description' content="Johannes Olzem's Webspace."> <meta name="description" content="Johannes Olzem's personal website">
<meta charset='utf-8'> <meta charset="utf-8">
<link rel='stylesheet' href='/css/style.css'> <link rel="stylesheet" href="/css/style.css">
<meta name='viewport' content='width=device-width, initial-scale=1.0'> <meta name="viewport" content="width=device-width, initial-scale=1.0">
<link rel='icon' href='/favico.ico'> <link rel="icon" href="/favico.ico">
<link rel="apple-touch-icon" sizes="180x180" href="/apple-touch-icon.png">
<link rel="icon" type="image/png" sizes="32x32" href="/favicon-32x32.png">
<link rel="icon" type="image/png" sizes="16x16" href="/favicon-16x16.png">
<link rel="manifest" href="/site.webmanifest">
</head> </head>
<body> <body class="landing">
<header>
<a href='/' class='home-ref'>
<img src='/assets/logo.png' alt='Johannes Olzem'>
<span>Johannes Olzem</span>
</a>
<nav> <nav>
<a href='/blog/'>Blog</a> <a href="/" class="header-logo">
<a href='/about/'>About Me</a> <img src="/img/header-logo.webp" alt="logo">
<a href='/contact/'>Contact</a> </a>
<span class="header-text">Johannes Olzem</span>
<ul>
<li>
<a href="/about/">About</a>
</li>
<li>
<a href="/blog/">Blog</a>
</li>
<li>
<a href="/contact/">Contact</a>
</li>
</ul>
</nav> </nav>
</header>
<main> <main>
<div class='full'> <div class="landing-grid">
<h2>Welcome to my Webspace!</h2> <div class="landing tl"></div>
<p> <div class="landing tr">Johannes Olzem</div>
Here I maintain my <a href='/blog/' class='inline'>blog</a> <div class="landing bl">less is more</div>
about various topics and with various guides.<br /> <div class="landing br"><span>&#8964;</span></div>
You can learn more about me <a href='/about/' class='inline'>here</a>.<br />
</p>
<span class='arrow'>&darr;</span>
</div> </div>
<div class='full full-secondary'> <div class="landing-lower">
<div class="landing ll">
<h2>Welcome</h2>
<p>
Welcome to my Webspace!
I'm Johannes, a computer enthusiast from Germany. On this website I
maintain my
<a href="/blog/">blog</a> about various topics and you can learn more
about me
<a href="/about">here.</a> If you want to get in touch with me, feel
free to do that
<a href="/contact/">here.</a>
</p>
</div>
<div class="landing lr">
<h2>Why run this website?</h2> <h2>Why run this website?</h2>
<p> <p>
As you (should) know, most websites collect data about you. The internet used to be a place of personal expression, not just
This is especially true for social media sites, which this is supposed to be a substitute for. corporate dominance. I believe in keeping that spirit alive.<br>
While I still occasionally use social media platforms like WhatsApp or (very rarely) Instagram, I strictly limit my usage to connecting with people I know in real life for social interactions only. But back to my rant:<br /> This site is a small step towards a more independent web. It also
So the only logical option in my mind was to make a website with some kind of blog function to share my opinion and help people with problems, that I have had and solved.<br /> allows me to share my experiences, how I do things, and other stuff
And now you are here! I don't know how you got here, but feel free to explore every crevasse of this site. that I want to put out into the world.<br>
Please feel free to explore every crevasse of this site! Don't know
where to start? Try the
<a href="/about/">about</a> page, to learn more about who I am.
</p> </p>
</div> </div>
<br> </div>
<p class='cowsay'>
_____________________________
&#60; Have fun on this website! &#62;
-----------------------------
\ ^__^
\ (oo)\_______
(__)\ )\/\
||----w |
|| ||
</p>
<br>
</main> </main>
<footer> <footer>
<h6><a href><script>document.write(window.location.href);</script></a></h6> &copy; 2021 - <script>document.write(new Date().getFullYear())</script> Johannes Olzem
<br>
<small>This website is free software. You can redistribute and modify it under the terms of the GNU General Public License V3.</small>
</footer> </footer>
</body> </body>
</html>
+1
View File
@@ -0,0 +1 @@
{"name":"Johannes Olzem's personal website","short_name":"Johannes Olzem","icons":[{"src":"/android-chrome-192x192.png","sizes":"192x192","type":"image/png"},{"src":"/android-chrome-512x512.png","sizes":"512x512","type":"image/png"}],"theme_color":"#AABD8C","background_color":"#AABD8C","display":"standalone"}