2024-02-26 16:42:10 -05:00
<!DOCTYPE html>
< html lang = "en" dir = "auto" >
< head > < script src = "/livereload.js?mindelay=10&v=2&port=1313&path=livereload" data-no-instant defer > < / script > < meta charset = "utf-8" >
< meta http-equiv = "X-UA-Compatible" content = "IE=edge" >
< meta name = "viewport" content = "width=device-width, initial-scale=1, shrink-to-fit=no" >
< meta name = "robots" content = "index, follow" >
< title > Posts | Norm-working Packets 💾< / title >
< meta name = "keywords" content = "" >
< meta name = "description" content = "Posts - Norm-working Packets 💾" >
< meta name = "author" content = "Norm Rasmussen" >
< link rel = "canonical" href = "//localhost:1313/posts.html" >
2024-03-19 13:47:03 -04:00
< script defer data-domain = "selfhosted.rsmsn.co" src = "https://analytics.rsmsn.co/js/script.js" > < / script >
2024-02-26 16:42:10 -05:00
< link crossorigin = "anonymous" href = "../../assets/css/stylesheet.b609c58d5c11bb90b1a54e04005d74ad1ddf22165eb79f5533967e57df9c3b50.css" integrity = "sha256-tgnFjVwRu5CxpU4EAF10rR3fIhZet59VM5Z+V9+cO1A=" rel = "preload stylesheet" as = "style" >
< link rel = "icon" href = "//localhost:1313/favicon.ico" >
< link rel = "icon" type = "image/png" sizes = "16x16" href = "//localhost:1313/favicon-16x16.png" >
< link rel = "icon" type = "image/png" sizes = "32x32" href = "//localhost:1313/rsmsncircles.ico" >
< link rel = "apple-touch-icon" href = "//localhost:1313/apple-touch-icon.png" >
< link rel = "mask-icon" href = "//localhost:1313/safari-pinned-tab.svg" >
< meta name = "theme-color" content = "#2e2e33" >
< meta name = "msapplication-TileColor" content = "#2e2e33" >
< link rel = "alternate" type = "application/rss+xml" href = "//localhost:1313/posts/index.xml" >
< link rel = "alternate" hreflang = "en" href = "//localhost:1313/posts.html" >
< noscript >
< style >
#theme-toggle,
.top-link {
display: none;
}
< / style >
< / noscript > < meta property = "og:title" content = "Posts" / >
< meta property = "og:description" content = "A semi-technical blog & series of experiences working in tech and my homelab" / >
< meta property = "og:type" content = "website" / >
< meta property = "og:url" content = "//localhost:1313/posts.html" / > < meta property = "og:site_name" content = "Norm-working Packets" / >
< meta name = "twitter:card" content = "summary" / >
< meta name = "twitter:title" content = "Posts" / >
< meta name = "twitter:description" content = "A semi-technical blog & series of experiences working in tech and my homelab" / >
< script type = "application/ld+json" >
{
"@context": "https://schema.org",
"@type": "BreadcrumbList",
"itemListElement": [
{
"@type": "ListItem",
"position": 1 ,
"name": "Posts",
"item": "//localhost:1313/posts.html"
}
]
}
< / script >
< / head >
< body class = "list dark" id = "top" >
< script >
if (localStorage.getItem("pref-theme") === "light") {
document.body.classList.remove('dark')
}
< / script >
< header class = "header" >
< nav class = "nav" >
< div class = "logo" >
< a href = "//localhost:1313/" accesskey = "h" title = "Norm-working Packets 💾 (Alt + H)" > Norm-working Packets 💾< / a >
< div class = "logo-switches" >
< button id = "theme-toggle" accesskey = "t" title = "(Alt + T)" >
< svg id = "moon" xmlns = "http://www.w3.org/2000/svg" width = "24" height = "18" viewBox = "0 0 24 24"
fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round"
stroke-linejoin="round">
< path d = "M21 12.79A9 9 0 1 1 11.21 3 7 7 0 0 0 21 12.79z" > < / path >
< / svg >
< svg id = "sun" xmlns = "http://www.w3.org/2000/svg" width = "24" height = "18" viewBox = "0 0 24 24"
fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round"
stroke-linejoin="round">
< circle cx = "12" cy = "12" r = "5" > < / circle >
< line x1 = "12" y1 = "1" x2 = "12" y2 = "3" > < / line >
< line x1 = "12" y1 = "21" x2 = "12" y2 = "23" > < / line >
< line x1 = "4.22" y1 = "4.22" x2 = "5.64" y2 = "5.64" > < / line >
< line x1 = "18.36" y1 = "18.36" x2 = "19.78" y2 = "19.78" > < / line >
< line x1 = "1" y1 = "12" x2 = "3" y2 = "12" > < / line >
< line x1 = "21" y1 = "12" x2 = "23" y2 = "12" > < / line >
< line x1 = "4.22" y1 = "19.78" x2 = "5.64" y2 = "18.36" > < / line >
< line x1 = "18.36" y1 = "5.64" x2 = "19.78" y2 = "4.22" > < / line >
< / svg >
< / button >
< ul class = "lang-switch" > < li > |< / li >
< / ul >
< / div >
< / div >
< ul id = "menu" >
< li >
< a href = "//localhost:1313/posts.html" title = "Posts" >
< span > Posts< / span >
< / a >
< / li >
< / ul >
< / nav >
< / header >
< main class = "main" >
< header class = "page-header" > < div class = "breadcrumbs" > < a href = "//localhost:1313/" > Home< / a > < / div >
< h1 >
Posts
< / h1 >
< / header >
< article class = "post-entry" >
< header class = "entry-header" >
< h2 class = "entry-hint-parent" > Tutorial: Move from NginxProxyManager to Nginx
< / h2 >
< / header >
< div class = "entry-content" >
< p > Goal A Tutorial Repo for migrating your Nginx Proxy Manager proxy setup to Nginx. I wrote this originally for this reddit post and to post this my Github profile. Thought my website would also be a good place to share it for any passers-by.
To give clear instructions to help users migrate from using Nginx Proxy Manager (NPM) to standard Nginx. This tutorial is not exhaustive and there are many other implementations of this transition....< / p >
< / div >
< footer class = "entry-footer" > < span title = '2023-08-05 15:23:51 -0500 -0500' > August 5, 2023< / span > · 8 min · 1635 words · Me< / footer >
< a class = "entry-link" aria-label = "post link to Tutorial: Move from NginxProxyManager to Nginx" href = "//localhost:1313/posts/npm_to_nginx_tutorial.html" > < / a >
< / article >
< article class = "post-entry" >
< header class = "entry-header" >
< h2 class = "entry-hint-parent" > My First Merged PR!
< / h2 >
< / header >
< div class = "entry-content" >
< p > Admittedly, I feel a bit like a child sharing something like this, as there are so many devs that pull and merge requests from contributors on a regular basis. However, while I’ ve contributed to documentation and/or tutorials and other non-coding portions of repositories, I feel a tiny bit proud that this was the first instance where I was using a library, found a bug, created an issue, cloned the repo to my local machine, found and fixed the code, and opened a pull request....< / p >
< / div >
< footer class = "entry-footer" > < span title = '2022-09-01 13:25:02 -0400 EDT' > September 1, 2022< / span > · 2 min · 328 words · Me< / footer >
< a class = "entry-link" aria-label = "post link to My First Merged PR!" href = "//localhost:1313/posts/whiptail-first-merged-pr.html" > < / a >
< / article >
< footer class = "page-footer" >
< nav class = "pagination" >
< a class = "prev" href = "//localhost:1313/posts/page/2.html" >
« Prev
< / a >
< / nav >
< / footer >
< / main >
< footer class = "footer" >
< span > © 2024 < a href = "//localhost:1313/" > Norm-working Packets 💾< / a > < / span >
< span >
Powered by
< a href = "https://gohugo.io/" rel = "noopener noreferrer" target = "_blank" > Hugo< / a > &
< a href = "https://github.com/adityatelange/hugo-PaperMod/" rel = "noopener" target = "_blank" > PaperMod< / a >
< / span >
< / footer >
< a href = "#top" aria-label = "go to top" title = "Go to Top (Alt + G)" class = "top-link" id = "top-link" accesskey = "g" >
< svg xmlns = "http://www.w3.org/2000/svg" viewBox = "0 0 12 6" fill = "currentColor" >
< path d = "M12 6H0l6-6z" / >
< / svg >
< / a >
< script >
let menu = document.getElementById('menu')
if (menu) {
menu.scrollLeft = localStorage.getItem("menu-scroll-position");
menu.onscroll = function () {
localStorage.setItem("menu-scroll-position", menu.scrollLeft);
}
}
document.querySelectorAll('a[href^="#"]').forEach(anchor => {
anchor.addEventListener("click", function (e) {
e.preventDefault();
var id = this.getAttribute("href").substr(1);
if (!window.matchMedia('(prefers-reduced-motion: reduce)').matches) {
document.querySelector(`[id='${decodeURIComponent(id)}']`).scrollIntoView({
behavior: "smooth"
});
} else {
document.querySelector(`[id='${decodeURIComponent(id)}']`).scrollIntoView();
}
if (id === "top") {
history.replaceState(null, null, " ");
} else {
history.pushState(null, null, `#${id}`);
}
});
});
< / script >
< script >
var mybutton = document.getElementById("top-link");
window.onscroll = function () {
if (document.body.scrollTop > 800 || document.documentElement.scrollTop > 800) {
mybutton.style.visibility = "visible";
mybutton.style.opacity = "1";
} else {
mybutton.style.visibility = "hidden";
mybutton.style.opacity = "0";
}
};
< / script >
< script >
document.getElementById("theme-toggle").addEventListener("click", () => {
if (document.body.className.includes("dark")) {
document.body.classList.remove('dark');
localStorage.setItem("pref-theme", 'light');
} else {
document.body.classList.add('dark');
localStorage.setItem("pref-theme", 'dark');
}
})
< / script >
< / body >
< / html >