Compare commits

..

No commits in common. "ad241fafbbd3f2dcc171c8bf523ddef4effbb731" and "717674318cd5ab2ad49d20f93a6f18ae3c4f24db" have entirely different histories.

33 changed files with 640 additions and 652 deletions

48
404.html Normal file → Executable file
View File

@ -1,36 +1,32 @@
<!DOCTYPE html>
<html lang="en">
<html lang='en'>
<head>
<title>Johannes Olzem</title>
<meta name="description" content="Johannes Olzem"s personal website">
<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">
<title>Page not found - 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 class="body">
<body>
<header>
<a href="/">
<img src="/img/logo.png">
<a href='/' class='home-ref'>
<img src='/assets/logo.png' alt='Johannes Olzem'>
<span>Johannes Olzem</span>
</a>
<a href="/about/">About</a>
<a href="/blog/">Blog</a>
<a href="/contact/">Contact</a>
<nav>
<a href='/blog/'>Blog</a>
<a href='/about/'>About Me</a>
<a href='/contact/'>Contact</a>
</nav>
</header>
<main>
<h1>Johannes Olzem</h1>
<blockquote>Less is more</blockquote>
<h2>404 Not Found</h2>
<p>
The resource you requested was not found on this server. Click
<a href="/">here</a> to return home.
</p>
<main class='full'>
<h1>404 Error</h1>
<p style='text-align: center;'>The page you requested couldn't be found. </p>
<a href='/'>Return to homepage</a>
</main>
<footer>
&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>
<h6><a href><script>document.write(window.location.href);</script></a></h6>
</footer>
</body>
</html>

115
about/index.html Normal file → Executable file
View File

@ -1,84 +1,65 @@
<!DOCTYPE html>
<html lang="en">
<html lang='en'>
<head>
<title>About - Johannes Olzem</title>
<meta name="description" content="Johannes Olzem's personal website">
<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">
<meta name='description' content="Johannes Olzem's Webspace.">
<meta charset='utf-8'>
<meta name='viewport' content='width=device-width, initial-scale=1.0'>
<link rel='stylesheet' href='/css/style.css'>
<link rel='icon' href='/favico.ico'>
</head>
<body class="body">
<body>
<header>
<a href="/">
<img src="/img/logo.png">
<a href='/' class='home-ref'>
<img src='/assets/logo.png' alt='Johannes Olzem'>
<span>Johannes Olzem</span>
</a>
<a href="/about/">About</a>
<a href="/blog/">Blog</a>
<a href="/contact/">Contact</a>
<nav>
<a href='/blog/'>Blog</a>
<a href='/about/'>About Me</a>
<a href='/contact/'>Contact</a>
</nav>
</header>
<main>
<h1>Johannes Olzem</h1>
<blockquote>Less is more</blockquote>
<h2>About me</h2>
<img src="/img/portrait.png" alt="Me" class="portrait">
<p>
Hey there!
My name is Johannes, and I'm a computer enthusiast born and raised in
Germany. Recently, I graduated from school, majoring in IT and English,
and I am now training to become an IT specialist. I am passionate about
most things related to technology, but specifically I am passionate about
using free and open-source software, exploring different aspects of
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.
<h2>About Me</h2>
<!--<img src='/img/me.png' style='float:left;margin:1rem;border-radius:1rem;height:256px;'>-->
<p style='margin-bottom: 2rem;'>
Hey there!<br />
My name is Johannes, and I'm a computer enthusiast born and raised in Germany.
Currently, I'm majoring in IT and English, and I'm passionate about most things related to technology.
I love using free and open-source software, exploring different aspects about Linux, setting up and tinkering with servers,
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.
Apart from computers, I also have an interest in cars, ranging from classic to modern sports cars.
</p>
<h2>My Skills</h2>
<p>I have at least basic knowledge in the following technologies:</p>
<div style="float:left" class="skills">
<h3>Languages</h3>
<ul>
<li>HTML &amp; CSS</li>
<li>Java</li>
<li>Python</li>
<li>PHP</li>
</ul>
</div>
<div style="float:right" class="skills">
<h3>Other technologies</h3>
<ul>
<li>Linux</li>
<li>Git</li>
<li>SQL</li>
<li>LaTeX</li>
<li>Docker</li>
</ul>
</div>
<br>
<h3>Languages</h3>
<p style='margin: 1rem !important; text-align: center;'>I have at least basic knowledge in the following programming languages:</p>
<ul>
<li>HTML &amp; CSS</li>
<li>Java</li>
<li>Python</li>
<li>PHP</li>
</ul>
<h3>Other Technologies</h3>
<ul>
<li>Linux</li>
<li>Git</li>
<li>SQL</li>
<li>LaTeX</li>
<li>Docker</li>
</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>
<h2>About this website</h2>
<p>
While I might not have been using the internet much or at all during the
web 1.0 times (which this site is heavily modeled after) I do believe that
modern websites are unnecessarly bloated in many ways. They contain 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>
It is also free and Open Source under the GNU
General Public License V3, which you can find <a href="/LICENSE.txt">here.</a>
This website has no ads or trackers and does not use cookies.<br>
It is also free and open source under the <a href='/LICENSE.txt'>GNU General Public License v3</a>.<br>
<a href='https://github.com/jolzem/jolzem.github.io/'>View Source Code</a><br>
</p>
<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>
</main>
<footer>
&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>
<h6><a href><script>document.write(window.location.href);</script></a></h6>
</footer>
</body>
</html>

BIN
assets/logo.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 18 KiB

BIN
assets/logogradient.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 110 KiB

109
blog/how-to-create-a-rust-server-on-linux/index.html Normal file → Executable file
View File

@ -1,68 +1,69 @@
<!DOCTYPE html>
<html lang="en">
<html lang='en'>
<head>
<title>How to create a Rust server on Linux - Johannes Olzem</title>
<meta name="description" content="Johannes Olzem's personal website">
<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">
<title>How to create a Rust server on Linux - 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 class="body">
<body>
<header>
<a href="/">
<img src="/img/logo.png">
<a href='/' class='home-ref'>
<img src='/assets/logo.png' alt='Johannes Olzem'>
<span>Johannes Olzem</span>
</a>
<a href="/about/">About</a>
<a href="/blog/">Blog</a>
<a href="/contact/">Contact</a>
<nav>
<a href='/blog/'>Blog</a>
<a href='/about/'>About Me</a>
<a href='/contact/'>Contact</a>
</nav>
</header>
<main class="blog-entry">
<h1>Johannes Olzem</h1>
<blockquote>Less is more</blockquote>
<h2>How to create a Rust server on Linux</h2>
<div class="author">Johannes Olzem</div>
<div class="date">May 23, 2023</div>
<main>
<h1>How to create a Rust server on Linux</h1>
<div class='author'>Johannes Olzem</div>
<div class='date'>May 23, 2023</div>
<h2>Table of Contents</h2>
<ul>
<li><a href="#Requirements">Requirements</a></li>
<li><a href="#SteamCMD">SteamCMD</a><br /></li>
<li><a href="#Installing">Installing</a><br /></li>
<li><a href="#Running">Running</a></li>
<li><a href='#Requirements'>Requirements</a></li>
<li><a href='#SteamCMD'>SteamCMD</a><br /></li>
<li><a href='#Installing'>Installing</a><br /></li>
<li><a href='#Running'>Running</a></li>
</ul>
<h2 id="Requirements">Requirements</h2>
<h2 id='Requirements'>Requirements</h2>
<ul>
<li>Debian Linux</li>
<li>&#62;5GB of RAM</li>
<li>&#62;4.5GB of free disc space</li>
</ul>
<h2 id="SteamCMD">SteamCMD</h2>
<h2 id='SteamCMD'>SteamCMD</h2>
<h3>Configuring the envoirenment</h3>
<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 class="code cmd">
<p class='code'>
sudo useradd -m steam
</p>
<p class="code cmd">
<p class='code'>
sudo passwd steam
</p>
<br />
<p>
When prompted, enter a new password for the "steam" user. <br />
Then switch to the "steam" user and go to its home folder.
When prompted, enter a new password for the 'steam' user. <br />
Then switch to the 'steam' user and go to its home folder.
</p>
<p class="code cmd">
<p class='code'>
su steam
</p>
<p class="code cmd">
<p class='code'>
cd
</p>
<br />
<p>
Enable the contrib and non-free repositories by changing your <code>/etc/apt/sources.list</code> to resemble the following:
</p>
<p class="code no-dollar" style="text-align:left;">
<p class='code no-dollar' style='text-align:left;'>
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 />
<br />
@ -76,15 +77,15 @@
<p>
Finally, to install SteamCMD run:
</p>
<p class="code cmd">
<p class='code'>
sudo apt install steamcmd
</p>
<br />
<h2 id="Installing">Installing</h2>
<h2 id='Installing'>Installing</h2>
<p>
Run SteamCMD
</p>
<p class="code cmd">
<p class='code'>
steamcmd
</p>
<br />
@ -92,14 +93,14 @@
After a short update period, a prompt like <code>Steam&#62;</code> should appear.<br />
To login anonymously type:
</p>
<p class="code">
<p class='code no-dollar'>
login anonymous
</p>
<br />
<p>
Now install the Rust Dedicated Server application.
</p>
<p class="code">
<p class='code no-dollar'>
app_update 258550
</p>
<p>
@ -108,22 +109,22 @@
<br />
Afterwards you can quit the SteamCMD shell.
</p>
<p class="code">
<p class='code no-dollar'>
quit
</p>
<br />
<h2 id="Running">Running</h2>
<h2 id='Running'>Running</h2>
<p>
First navigate to the Rust server directory.
</p>
<p class="code cmd">
<p class='code'>
cd ~/Steam/steamapps/common/rust_dedicated
</p>
<br />
<p>
Finally, start up the Rust server by running:
</p>
<p class="code cmd">
<p class='code'>
./RustDedicated -batchmode
</p>
<br />
@ -184,14 +185,14 @@
<tr>
<td><code>+server.hostname</code>
</td>
<td><code>"Your Server Name"</code>
<td><code>'Your Server Name'</code>
</td>
<td>The displayed name of your server.
</td></tr>
<tr>
<td><code>+server.identity</code>
</td>
<td><code>"my_server_identity"</code>
<td><code>'my_server_identity'</code>
</td>
<td>Changes path to your server data rust/server/my_server_identity. Useful for running multiple instances.
</td></tr>
@ -226,7 +227,7 @@
<tr>
<td><code>+rcon.password</code>
</td>
<td><code>"YourPassword"</code>
<td><code>'YourPassword'</code>
</td>
<td>Sets the RCON password
</td></tr>
@ -235,37 +236,35 @@
</td>
<td><code>gamelog.txt</code>
</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>
<tr>
<td><code>-silent-crashes</code>
</td>
<td><code> - </code>
</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>
</table>
<br />
<h2>Sources</h2>
<ul>
<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>
<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>
<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>
<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>
</ul>
</main>
<footer>
&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>
<h6><a href><script>document.write(window.location.href);</script></a></h6>
</footer>
</body>
</html>

52
blog/index.html Normal file → Executable file
View File

@ -1,41 +1,35 @@
<!DOCTYPE html>
<html lang="en">
<html lang='en'>
<head>
<title>Blog - Johannes Olzem</title>
<meta name="description" content="Johannes Olzem's personal website">
<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">
<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 class="body">
<body>
<header>
<a href="/">
<img src="/img/logo.png">
<a href='/' class='home-ref'>
<img src='/assets/logo.png' alt='Johannes Olzem'>
<span>Johannes Olzem</span>
</a>
<a href="/about/">About</a>
<a href="/blog/">Blog</a>
<a href="/contact/">Contact</a>
<nav>
<a href='/blog/'>Blog</a>
<a href='/about/'>About Me</a>
<a href='/contact/'>Contact</a>
</nav>
</header>
<main>
<h1>Johannes Olzem</h1>
<blockquote>Less is more</blockquote>
<main class='full'>
<h2>Blog</h2>
<ul>
<li>
<a href="/blog/quick-fixes/">Quick fixes</a>
</li>
<li>
<a href="/blog/how-to-create-a-rust-server-on-linux/">
How to create a Rust server on linux.
</a>
</li>
</ul>
<div class='blog-entries'>
<a href='quick-fixes/'>Quick Fixes</a>
<a href='the-current-state-of-software-is-utterly-ridiculous/'>The current state of software is utterly ridiculous</a>
<a href='how-to-create-a-rust-server-on-linux/'>How to create a Rust server on Linux</a>
</div>
</main>
<footer>
&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>
<h6><a href><script>document.write(window.location.href);</script></a></h6>
</footer>
</body>
</html>

47
blog/quick-fixes/android-pihole-no-internet/index.html Normal file → Executable file
View File

@ -1,37 +1,34 @@
<!DOCTYPE html>
<html lang="en">
<html lang='en'>
<head>
<title>Quick fix - Johannes Olzem</title>
<meta name="description" content="Johannes Olzem's personal website">
<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">
<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 class="body">
<body>
<header>
<a href="/">
<img src="/img/logo.png">
<a href='/' class='home-ref'>
<img src='/assets/logo.png' alt='Johannes Olzem'>
<span>Johannes Olzem</span>
</a>
<a href="/about/">About</a>
<a href="/blog/">Blog</a>
<a href="/contact/">Contact</a>
<nav>
<a href='/blog/'>Blog</a>
<a href='/about/'>About Me</a>
<a href='/contact/'>Contact</a>
</nav>
</header>
<main>
<h1>Johannes Olzem</h1>
<blockquote>Less is more</blockquote>
<h2>
Connected without internet on Android after setting PiHole as DNS server.
</h2>
<main class='full'>
<h1>Connected without internet on Android after setting PiHole as DNS server.</h1>
<br>
<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>
</main>
<footer>
&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>
<h6><a href><script>document.write(window.location.href);</script></a></h6>
</footer>
</body>
</html>

62
blog/quick-fixes/homeassistant-proxy/index.html Normal file → Executable file
View File

@ -1,52 +1,38 @@
<!DOCTYPE html>
<html lang="en">
<html lang='en'>
<head>
<title>Quick fix - Johannes Olzem</title>
<meta name="description" content="Johannes Olzem's personal website">
<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">
<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 class="body">
<body>
<header>
<a href="/">
<img src="/img/logo.png">
<a href='/' class='home-ref'>
<img src='/assets/logo.png' alt='Johannes Olzem'>
<span>Johannes Olzem</span>
</a>
<a href="/about/">About</a>
<a href="/blog/">Blog</a>
<a href="/contact/">Contact</a>
<nav>
<a href='/blog/'>Blog</a>
<a href='/about/'>About Me</a>
<a href='/contact/'>Contact</a>
</nav>
</header>
<main>
<h1>Johannes Olzem</h1>
<blockquote>Less is more</blockquote>
<h2>HomeAssistant not connecting over reverse proxy</h2>
<main class='full'>
<h1>HomeAssistant not connecting over reverse proxy</h1>
<br>
<p>
Make sure you have enabled <em>Websockets Supports</em> or similar
functionality in your reverse proxy client.<br><br>
If you are getting a <em>400 Bad Request</em> error, find the
HomeAssistant log file and look for the following error message:<br>
<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</code><br><br>
In your <code>configuration.yaml</code> file, add the following lines:<br>
<pre>
http:<br>
use_x_forwarded_for: true<br>
trusted_proxies:<br>
- 12.34.56.78 # The IP address from the error message
</pre>
Make sure you have enabled <em>Websockets Supports</em> or similar functionality in your reverse proxy client.
</p>
<h3>Explanation</h3>
<h2>Explanation</h2>
<p>
HomeAssistant uses websockets to communicate with the browser.<br><br>
If you are using a reverse proxy, the IP address of the incoming
connection is not trusted and gets rejected by HomeAssistant.<br>
HomeAssistant uses websockets to communicate with the browser.
</p>
</main>
<footer>
&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>
<h6><a href><script>document.write(window.location.href);</script></a></h6>
</footer>
</body>
</html>

75
blog/quick-fixes/index.html Normal file → Executable file
View File

@ -1,68 +1,39 @@
<!DOCTYPE html>
<html lang='en'>
<head>
<title>Quick fixes - Johannes Olzem</title>
<meta name='description' content='Johannes Olzem's personal website'>
<title>Quick Fixes - 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 class='body'>
<body>
<header>
<a href='/'>
<img src='/img/logo.png'>
<a href='/' class='home-ref'>
<img src='/assets/logo.png' alt='Johannes Olzem'>
<span>Johannes Olzem</span>
</a>
<a href='/about/'>About</a>
<a href='/blog/'>Blog</a>
<a href='/contact/'>Contact</a>
<nav>
<a href='/blog/'>Blog</a>
<a href='/about/'>About Me</a>
<a href='/contact/'>Contact</a>
</nav>
</header>
<main>
<h1>Johannes Olzem</h1>
<blockquote>Less is more</blockquote>
<h2>Quick fixes</h2>
<p>
This is a page with small problems, to which I have found easy
solutions, so as to not litter the blog page.
</p>
<ul>
<li>
<a href='/blog/quick-fixes/android-pihole-no-internet/'>
Connected without internet on Android after setting PiHole as DNS
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/pacman-404/'>
Pacman install fails with 404
</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>
<h2>Quick Fixes</h2>
<h3>This is a page with small problems, to which I have found easy solutions, so as to not litter the blog page.</h3>
<div class='blog-entries'>
<a href='nextcloud-file-not-supported/'>Nextcloud file not supported error</a>
<a href='android-pihole-no-internet/'>Connected without internet on Android after setting PiHole as DNS server.</a>
<a href='thinkpad-r61-beep/'> Thinkpad R61 repeated beep on startup</a>
<a href='pacman-404/'>Pacman install fails with 404</a>
<a href='proton-audio-stuttering/'>Proton / Wine audio stuttering when using qpaeq equalizer</a>
<a href='homeassistant-proxy/'>HomeAssistant not connecting over reverse proxy</a>
</div>
</main>
<footer>
&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>
<h6><a href><script>document.write(window.location.href);</script></a></h6>
</footer>
</body>
</html>

View File

@ -1,43 +1,39 @@
<!DOCTYPE html>
<html lang="en">
<html lang='en'>
<head>
<title>Quick fix - Johannes Olzem</title>
<meta name="description" content="Johannes Olzem's personal website">
<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">
<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 class="body">
<body>
<header>
<a href="/">
<img src="/img/logo.png">
<a href='/' class='home-ref'>
<img src='/assets/logo.png' alt='Johannes Olzem'>
<span>Johannes Olzem</span>
</a>
<a href="/about/">About</a>
<a href="/blog/">Blog</a>
<a href="/contact/">Contact</a>
<nav>
<a href='/blog/'>Blog</a>
<a href='/about/'>About Me</a>
<a href='/contact/'>Contact</a>
</nav>
</header>
<main>
<h1>Johannes Olzem</h1>
<blockquote>Less is more</blockquote>
<h2>Nextcloud file not supported error</h2>
<h3>
<code>
exif_read_data(): File not supported at
/var/www/html/lib/private/Metadata/Provider/ExifProvider.php#59
</code>
</h3>
<p>Upload over IP and port rather than over nginx proxy.</p>
<h3>Explanation</h3>
<main class='full'>
<h1>Nextcloud file not supported error</h1>
<h2><code>exif_read_data(): File not supported at /var/www/html/lib/private/Metadata/Provider/ExifProvider.php#59</code></h2>
<br>
<p>
The request payload (the data your are trying to upload) is too large for
nginx.
Upload over IP and port rather than over nginx proxy.
</p>
<h2>Explanation</h2>
<p>
The request payload (the data your are trying to upload) is too large for nginx.
</p>
</main>
<footer>
&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>
<h6><a href><script>document.write(window.location.href);</script></a></h6>
</footer>
</body>
</html>

63
blog/quick-fixes/pacman-404/index.html Normal file → Executable file
View File

@ -1,50 +1,41 @@
<!DOCTYPE html>
<html lang="en">
<html lang='en'>
<head>
<title>Quick fix - Johannes Olzem</title>
<meta name="description" content="Johannes Olzem's personal website">
<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">
<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 class="body">
<body>
<header>
<a href="/">
<img src="/img/logo.png">
<a href='/' class='home-ref'>
<img src='/assets/logo.png' alt='Johannes Olzem'>
<span>Johannes Olzem</span>
</a>
<a href="/about/">About</a>
<a href="/blog/">Blog</a>
<a href="/contact/">Contact</a>
<nav>
<a href='/blog/'>Blog</a>
<a href='/about/'>About Me</a>
<a href='/contact/'>Contact</a>
</nav>
</header>
<main>
<h1>Johannes Olzem</h1>
<blockquote>Less is more</blockquote>
<h2>Pacman install fails with 404</h2>
<h3><code>error: failed retrieving file 'X' from Y : The requested URL
returned error: 404</code></h3>
<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.
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>
<h3>Explanation</h3>
<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>.
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>
&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>
<h6><a href><script>document.write(window.location.href);</script></a></h6>
</footer>
</body>
</html>

46
blog/quick-fixes/proton-audio-stuttering/index.html Normal file → Executable file
View File

@ -1,32 +1,34 @@
<!DOCTYPE html>
<html lang="en">
<html lang='en'>
<head>
<title>Quick fix - Johannes Olzem</title>
<meta name="description" content="Johannes Olzem's personal website">
<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">
<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 class="body">
<body>
<header>
<a href="/">
<img src="/img/logo.png">
<a href='/' class='home-ref'>
<img src='/assets/logo.png' alt='Johannes Olzem'>
<span>Johannes Olzem</span>
</a>
<a href="/about/">About</a>
<a href="/blog/">Blog</a>
<a href="/contact/">Contact</a>
<nav>
<a href='/blog/'>Blog</a>
<a href='/about/'>About Me</a>
<a href='/contact/'>Contact</a>
</nav>
</header>
<main>
<h1>Johannes Olzem</h1>
<blockquote>Less is more</blockquote>
<h2>Proton / Wine audio stuttering when using qpaeq equalizer</h2>
<p>Switch to normal audio device.</p>
<main class='full'>
<h1>Proton / Wine audio stuttering when using qpaeq equalizer</h1>
<br>
<p>
Switch to normal audio device.
</p>
</main>
<footer>
&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>
<h6><a href><script>document.write(window.location.href);</script></a></h6>
</footer>
</body>
</html>

52
blog/quick-fixes/template.html Normal file → Executable file
View File

@ -1,37 +1,39 @@
<!DOCTYPE html>
<html lang="en">
<html lang='en'>
<head>
<title>Quick fix - Johannes Olzem</title>
<meta name="description" content="Johannes Olzem's personal website">
<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">
<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 class="body">
<body>
<header>
<a href="/">
<img src="/img/logo.png">
<a href='/' class='home-ref'>
<img src='/assets/logo.png' alt='Johannes Olzem'>
<span>Johannes Olzem</span>
</a>
<a href="/about/">About</a>
<a href="/blog/">Blog</a>
<a href="/contact/">Contact</a>
<nav>
<a href='/blog/'>Blog</a>
<a href='/about/'>About Me</a>
<a href='/contact/'>Contact</a>
</nav>
</header>
<main>
<h1>Johannes Olzem</h1>
<blockquote>Less is more</blockquote>
<h2>Title</h2>
<h3>Problem</h3>
<p>Fix</p>
<h3>Explanation</h3>
<main class='full'>
<h1>{{ Title }}</h1>
<h2>{{ Problem }}</h2>
<br>
<p>
Explanation
{{ Fix }}
</p>
<h2>Explanation</h2>
<p>
{{ Explanation }}
</p>
</main>
<footer>
&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>
<h6><a href><script>document.write(window.location.href);</script></a></h6>
</footer>
</body>
</html>

50
blog/quick-fixes/thinkpad-r61-beep/index.html Normal file → Executable file
View File

@ -1,37 +1,39 @@
<!DOCTYPE html>
<html lang="en">
<html lang='en'>
<head>
<title>Quick fix - Johannes Olzem</title>
<meta name="description" content="Johannes Olzem's personal website">
<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">
<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 class="body">
<body>
<header>
<a href="/">
<img src="/img/logo.png">
<a href='/' class='home-ref'>
<img src='/assets/logo.png' alt='Johannes Olzem'>
<span>Johannes Olzem</span>
</a>
<a href="/about/">About</a>
<a href="/blog/">Blog</a>
<a href="/contact/">Contact</a>
<nav>
<a href='/blog/'>Blog</a>
<a href='/about/'>About Me</a>
<a href='/contact/'>Contact</a>
</nav>
</header>
<main>
<h1>Johannes Olzem</h1>
<blockquote>Less is more</blockquote>
<h2>Thinkpad R61 repeated beep on startup</h2>
<h3>(or any older ThinkPad model, I believe)</h3>
<p>Check keyboard connector / swap out keyboard.</p>
<h3>Explanation</h3>
<main class='full'>
<h1>Thinkpad R61 repeated beep on startup</h1>
<h2>(or any older ThinkPad model, I believe)</h2>
<br>
<p>
Check keyboard connector / swap out keyboard.
</p>
<h2>Explanation</h2>
<p>
No keyboard detected on bootup.
</p>
</main>
<footer>
&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>
<h6><a href><script>document.write(window.location.href);</script></a></h6>
</footer>
</body>
</html>

View File

@ -1,36 +0,0 @@
<!DOCTYPE html>
<html lang="en">
<head>
<title>{{ Title }} - Johannes Olzem</title>
<meta name="description" content="Johannes Olzem's personal website">
<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 class="body">
<header>
<a href="/">
<img src="/img/logo.png">
</a>
<a href="/about/">About</a>
<a href="/blog/">Blog</a>
<a href="/contact/">Contact</a>
</header>
<main class="blog-entry">
<h1>Johannes Olzem</h1>
<blockquote>Less is more</blockquote>
<h2>Title</h2>
<div class="author">Johannes Olzem</div>
<div class="date"></div>
<p>
</p>
</main>
<footer>
&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>
</body>

View File

@ -0,0 +1,67 @@
<!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>

46
contact/index.html Normal file → Executable file
View File

@ -1,36 +1,38 @@
<!DOCTYPE html>
<html lang="en">
<html lang='en'>
<head>
<title>Contact - Johannes Olzem</title>
<meta name="description" content="Johannes Olzem"s personal website">
<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">
<meta name='description' content="Johannes Olzem's Webspace.">
<meta charset='utf-8'>
<meta name='viewport' content='width=device-width, initial-scale=1.0'>
<link rel='stylesheet' href='/css/style.css'>
<link rel='icon' href='/favico.ico'>
</head>
<body class="body">
<body>
<header>
<a href="/">
<img src="/img/logo.png">
<a href='/' class='home-ref'>
<img src='/assets/logo.png' alt='Johannes Olzem'>
<span>Johannes Olzem</span>
</a>
<a href="/about/">About</a>
<a href="/blog/">Blog</a>
<a href="/contact/">Contact</a>
<nav>
<a href='/blog/'>Blog</a>
<a href='/about/'>About Me</a>
<a href='/contact/'>Contact</a>
</nav>
</header>
<main>
<h1>Johannes Olzem</h1>
<blockquote>Less is more</blockquote>
<main class='full'>
<h2>Contact</h2>
<p>
Email me: <a href="mailto:johannes@jolzem.com">johannes@jolzem.com</a>
<br>
Find me on <a href="https://github.com/jolzem">Github</a>
Email me:
<a href='mailto:jolzem@pm.me?subject=Hi!' target='_blank'>jolzem@pm.me</a>
</p>
<br>
<p>
Find me on <a href='https://github.com/jolzem'>GitHub</a>.
</p>
</main>
<footer>
&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>
<h6><a href><script>document.write(window.location.href);</script></a></h6>
</footer>
</body>
</html>

BIN
css/WorkSans-Italic.woff2 Normal file

Binary file not shown.

BIN
css/WorkSans-Medium.woff2 Normal file

Binary file not shown.

BIN
css/WorkSans-Regular.woff2 Normal file

Binary file not shown.

244
css/style.css Normal file → Executable file
View File

@ -1,99 +1,156 @@
@font-face {
font-family: 'Work Sans';
src: url('WorkSans-Regular.woff2');
font-weight: normal;
}
@font-face {
font-family: 'Work Sans';
src: url('WorkSans-Medium.woff2');
font-weight: bold;
}
@font-face {
font-family: 'Work Sans';
src: url('WorkSans-Italic.woff2');
font-style: italic;
}
:root {
--bg: #152528;
--dark-bg: #0f1c1e;
--txt: #e6eaea;
--header-txt: #e85c51;
--sec-header-txt: #ff8349;
--link-txt: #5a93aa;
--header-bg: rgba(0, 0, 0, 0.95);
--txt: #eee;
--body-bg: #111;
--accent: #6690d9;
--border: #aaa;
--font-body: 'Work Sans', sans-serif;
}
body {
background: var(--bg);
font-family: var(--font-body);
color: var(--txt);
font-family: 'Consolas', 'Courier', monospace;
font-size: 130%
background-color: var(--body-bg);
text-align: center;
margin: 0 auto;
position: relative;
min-height: 100vh;
}
header {
min-height: 52pt;
margin-bottom: 2.5rem;
background-color: var(--header-bg);
padding: 1.5rem 0;
display: flex;
align-items: center;
max-width: 95vw;
margin: 0 auto;
}
header a {
display: inline-block;
padding: 4pt 12pt;
justify-content: space-between;
flex-wrap: wrap;
position: sticky;
top: 0;
z-index: 100;
}
header img {
height: 24pt;
height: 3rem;
margin-left: 1.5rem;
display: block;
}
blockquote {
font-style: italic;
padding-bottom: 24pt;
}
main {
max-width: min(800px, 80vw);
margin: 0 auto;
padding-bottom: 24pt;
}
.cowsay-wrapper {
min-width: 100%;
.home-ref {
display: flex;
align-items: center;
justify-content: center;
}
.cowsay {
font-family: monospace;
text-align: left;
white-space: pre;
max-width: fit-content;
.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 {
margin-right: 1.5rem;
}
nav a {
border: 1px solid var(--border);
border-radius: .3rem;
margin: .7rem;
padding: .4rem 1.2rem;
text-decoration: none;
user-select: none;
display: inline-block;
color: var(--txt);
transition: 0.5s;
}
.cards {
nav a:hover, nav a:active {
background-color: var(--txt);
border: 1px solid var(--border);
color: var(--header-bg);
}
main {
overflow: hidden;
padding: 0 2.5rem 5rem 2.5rem;
max-width: 800px;
margin: 0 auto;
}
main p {
margin: 0 auto;
text-align: justify;
}
.full {
height: 80vh;
display: flex;
justify-content: space-evenly;
margin-bottom:48pt;
align-items: center;
justify-content: center;
flex-direction: column;
position: relative;
}
.portrait {
max-width: min(220px, 60vw);
.full p {
text-align: justify-all !important;
max-width: 600px;
}
.skills {
float: left !important;
width: 100%;
margin-bottom: 24pt;
.arrow {
position: absolute;
bottom: 0;
}
/* float right when on desktop */
@media (min-width: 500px) {
.portrait {
float: right;
height: 300px;
margin-left: 2rem;
}
.skills {
width: 50%;
height: 14rem;
}
.full-secondary {
height: 100vh;
}
.blog-entry p {
margin: 0;
main ul {
margin: 0 auto;
margin-bottom: 2rem;
max-width: fit-content;
text-align: left;
}
.blog-entries a {
padding-top: 1rem;
display: block;
}
.author {
float: left;
max-width: 400px;
margin-bottom: 2rem;
}
.date {
@ -103,41 +160,64 @@ main {
}
.code {
background: var(--dark-bg);
padding: 1rem;
border-radius: 1rem;
font-family: monospace;
padding: .2rem .3rem;
border-radius: .3rem;
border: 1px solid var(--border);
margin: .3rem;
}
.cmd::before {
.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%;
text-align: center;
}
h1 {
color: var(--header-txt);
}
h2, h3, h4, h5, h6 {
color: var(--sec-header-txt);
}
p {
margin: 16pt;
display: block;
text-align: justify;
line-height: 1.25;
margin: 1rem;
font-size: 1.1em;
line-height: 1.5rem;
}
a {
color: var(--link-txt);
text-decoration-color: rgba(0,0,0,0);
transition: text-decoration .3s;
color: var(--txt);
text-decoration: underline;
transition: 300ms;
}
a:hover, a:active {
text-decoration-color: var(--link-txt);
h1,
h2,
h3,
h4,
h5,
h6,
a:hover,
a:active {
color: var(--accent);
}
code {
padding: .2rem .3rem;
border-radius: .3rem;
border: 1px solid var(--border);
margin: .3rem;
}

2
donate/index.html Executable file
View File

@ -0,0 +1,2 @@
<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>

View File

@ -1,32 +0,0 @@
<!DOCTYPE html>
<html lang='en'>
<head>
<title> - Johannes Olzem</title>
<meta name='description' content='Johannes Olzem's personal website'>
<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 class='body'>
<header>
<a href='/'>
<img src='/img/logo.png'>
</a>
<a href='/about/'>About</a>
<a href='/blog/'>Blog</a>
<a href='/contact/'>Contact</a>
</header>
<main>
<h1>Johannes Olzem</h1>
<blockquote>Less is more</blockquote>
<h2></h2>
</main>
<footer>
&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>
</body>

BIN
favico.ico Normal file → Executable file

Binary file not shown.

Before

Width:  |  Height:  |  Size: 19 KiB

After

Width:  |  Height:  |  Size: 121 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 3.2 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 7.2 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 14 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 8.1 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 581 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 249 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 760 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.3 KiB

88
index.html Normal file → Executable file
View File

@ -1,48 +1,47 @@
<!DOCTYPE html>
<html lang="en">
<html lang='en'>
<head>
<title>Johannes Olzem</title>
<meta name="description" content="Johannes Olzem"s personal website">
<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">
<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 class="body">
<body>
<header>
<a href="/">
<img src="/img/logo.png">
<a href='/' class='home-ref'>
<img src='/assets/logo.png' alt='Johannes Olzem'>
<span>Johannes Olzem</span>
</a>
<a href="/about/">About</a>
<a href="/blog/">Blog</a>
<a href="/contact/">Contact</a>
<nav>
<a href='/blog/'>Blog</a>
<a href='/about/'>About Me</a>
<a href='/contact/'>Contact</a>
</nav>
</header>
<main>
<h1>Johannes Olzem</h1>
<blockquote>Less is more</blockquote>
<h2>Welcome to my webspace</h2>
<p>
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, you can do that <a href="/contact/">here</a>.
</p>
<h2>Why run this website?</h2>
<p>
The internet used to be a place of personal expression, not just
corporate dominance. I believe in keeping that spirit alive.
<br>
This site is a small step towards a more independent web.
It also allows me to share my experiences, how I do things, and other
stuff 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>
<div class='full'>
<h2>Welcome to my Webspace!</h2>
<p>
Here I maintain my <a href='/blog/' class='inline'>blog</a>
about various topics and with various guides.<br />
You can learn more about me <a href='/about/' class='inline'>here</a>.<br />
</p>
<span class='arrow'>&darr;</span>
</div>
<div class='full full-secondary'>
<h2>Why run this website?</h2>
<p>
As you (should) know, most websites collect data about you.
This is especially true for social media sites, which this is supposed to be a substitute for.
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 />
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 />
And now you are here! I don't know how you got here, but feel free to explore every crevasse of this site.
</p>
</div>
<br>
<div class="cowsay-wrapper">
<p class="cowsay">
<p class='cowsay'>
_____________________________
&#60; Have fun on this website! &#62;
-----------------------------
@ -51,22 +50,11 @@ _____________________________
(__)\ )\/\
||----w |
|| ||
</p>
</div>
</p>
<br>
<div class="cards">
<img src="/img/linux_powered.gif" alt="Linux powered">
<img src="/img/vim.gif" alt="vim">
<img src="/img/nocookie.gif" alt="No Cookies">
<img src="/img/bestvieweddesktop.gif" alt="Best viewed with desktop">
<img src="/img/internetprivacy.gif" alt="Internet privacy now!">
<img src="/img/smile.gif" alt="Have a smile">
</div>
</main>
<footer>
&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>
<h6><a href><script>document.write(window.location.href);</script></a></h6>
</footer>
</body>
</html>