diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml
deleted file mode 100644
index dd3bba47c37ec95c989d8367cae13b63402c66d7..0000000000000000000000000000000000000000
--- a/.gitlab-ci.yml
+++ /dev/null
@@ -1,62 +0,0 @@
-stages:
- - test
- - production
- - prepare
- - release
-
-test:
- image: rust:alpine
- stage: test
- script:
- - apk add musl-dev
- - cargo install cargo2junit
- - cargo test -- -Z unstable-options --format json --report-time | cargo2junit > results.xml
- only:
- - master
- artifacts:
- reports:
- junit: results.xml
-
-production:
- stage: production
- image: ruby:latest
- needs:
- - test
- script:
- - apt-get update -qy
- - apt-get install -y ruby-dev
- - gem install dpl
- - gem install faraday -v 1.8.0
- - dpl --provider=heroku --app=$HEROKU_APP --api-key=$HEROKU_API_KEY
- only:
- - master
-
-prepare_job:
- stage: prepare
- image: rust:alpine
- rules:
- - if: $CI_COMMIT_TAG
- script:
- - echo "running release_job"
- - apk add musl-dev
- - cargo build --release
- artifacts:
- paths:
- - target/release/hyper
- - target/release/actix
-
-release_job:
- stage: release
- image: registry.gitlab.com/gitlab-org/release-cli:latest
- rules:
- - if: $CI_COMMIT_TAG
- script:
- - echo "running release_job for $TAG"
- needs:
- - job: prepare_job
- artifacts: true
- release:
- name: 'Release $CI_COMMIT_TAG'
- description: 'New macroblog version'
- tag_name: '$CI_COMMIT_TAG'
- ref: '$CI_COMMIT_TAG'
diff --git a/Procfile b/Procfile
deleted file mode 100644
index 51c4728eb99f1e7da51cd1de9cc2b6ef2d19578e..0000000000000000000000000000000000000000
--- a/Procfile
+++ /dev/null
@@ -1 +0,0 @@
-web: ./target/release/actix
diff --git a/content/posts/2020-07-12Road_to_local_K8S.html b/content/posts/2020-07-12Road_to_local_K8S.html
index 5d34b27775f6d3c0c5d80da76ab4d5372aba440d..52820b3a59f6fcff401ca6c19b6990cf0a36c485 100644
--- a/content/posts/2020-07-12Road_to_local_K8S.html
+++ b/content/posts/2020-07-12Road_to_local_K8S.html
@@ -1,43 +1,43 @@
<section>
- <h3>Goal</h3>
- <p>
+ <h3>Goal</h3>
+ <p>
The goal is to deploy kubernetes on my local networks, and keep everything
as reproducible as possible.
- </p>
- <h3>Stack</h3>
- <p>
+ </p>
+ <h3>Stack</h3>
+ <p>
I'll use Fedora Core OS, Matchbox and Terraform
<sup><a href="#footnotes">1</a></sup>, a match the requirements for
Tectonic<sup><a href="#footnotes">2</a></sup>.</p>
- <h3>Steps</h3>
- <ul>
- <li>Network Setup DHCP/TFTP/DNS<sup><a href="#footnotes">3</a></sup></li>
- <li>Matchbox<sup><a href="#footnotes">4</a></sup></li>
- <li>PXE nextwork boot evnrionment</li>
- <li>Terraform Tectonic<sup><a href="#footnotes">5</a></sup></li>
- </ul>
- <h3>Network Setup DHCP/TFTP/DNS</h3>
- <p>First learning the basics</p>
- <ul>
- <li>
- <a href="https://linuxhint.com/install_dhcp_server_ubuntu/">
- https://linuxhint.com/install_dhcp_server_ubuntu/
- </a>
- </li>
- <li>
- <a href="https://www.youtube.com/watch?v=XQ3T14SIlV4">
- https://www.youtube.com/watch?v=XQ3T14SIlV4
- </a>
- </li>
- </ul>
- <p>
+ <h3>Steps</h3>
+ <ul>
+ <li>Network Setup DHCP/TFTP/DNS<sup><a href="#footnotes">3</a></sup></li>
+ <li>Matchbox<sup><a href="#footnotes">4</a></sup></li>
+ <li>PXE nextwork boot evnrionment</li>
+ <li>Terraform Tectonic<sup><a href="#footnotes">5</a></sup></li>
+ </ul>
+ <h3>Network Setup DHCP/TFTP/DNS</h3>
+ <p>First learning the basics</p>
+ <ul>
+ <li>
+ <a href="https://linuxhint.com/install_dhcp_server_ubuntu/">
+ https://linuxhint.com/install_dhcp_server_ubuntu/
+ </a>
+ </li>
+ <li>
+ <a href="https://www.youtube.com/watch?v=XQ3T14SIlV4">
+ https://www.youtube.com/watch?v=XQ3T14SIlV4
+ </a>
+ </li>
+ </ul>
+ <p>
To check open ports
-<pre><code>lsof -Pni | grep LISTEN</code></pre>
- </p>
- <p>
+ <pre><code>lsof -Pni | grep LISTEN</code></pre>
+ </p>
+ <p>
Run the provided<sup><a href="#footnotes">6</a></sup> image with dnsmasq and
PXE toolkit
-<pre><code>docker run --rm --cap-add=NET_ADMIN --net=host quay.io/coreos/dnsmasq \
+ <pre><code>docker run --rm --cap-add=NET_ADMIN --net=host quay.io/coreos/dnsmasq \
-d -q \
--dhcp-range=192.168.1.3,192.168.1.254 \
--enable-tftp --tftp-root=/var/lib/tftpboot \
@@ -54,48 +54,48 @@ --dhcp-boot=tag:ipxe,http://matchbox.example.com:8080/boot.ipxe \
--address=/matchbox.example/192.168.1.2 \
--log-queries \
--log-dhcp</code></pre>
- </p>
- <h3>Matchbox</h3>
- <p>...</p>
- <h3>PXE network boot enviroment</h3>
- <p>...</p>
- <h3>Terraform Tectonic</h3>
- <p>...</p>
- <h3 id="footnotes">Links</h3>
- <div >
- <sup>1</sup>
- <a href="https://coreos.com/tectonic/docs/latest/install/bare-metal/metal-terraform.html">
- https://coreos.com/tectonic/docs/latest/install/bare-metal/metal-terraform.html
- </a>
- <div>
- <div>
- <sup>2</sup>
- <a href="https://coreos.com/tectonic/docs/latest/install/bare-metal/requirements.html">
- https://coreos.com/tectonic/docs/latest/install/bare-metal/requirements.html
- </a>
- <div>
- <div>
- <sup>3</sup>
- <a href="https://coreos.com/matchbox/docs/latest/network-setup.html">
- https://coreos.com/matchbox/docs/latest/network-setup.html
- </a>
- <div>
- <div>
- <sup>4</sup>
- <a href="https://coreos.com/matchbox/docs/latest/deployment.html">
- https://coreos.com/matchbox/docs/latest/deployment.html
- </a>
- <div>
- <div>
- <sup>5</sup>
- <a href="https://coreos.com/tectonic/releases/">
- https://coreos.com/tectonic/releases/
- </a>
- <div>
- <div>
- <sup>6</sup>
- <a href="https://github.com/poseidon/matchbox/tree/v0.7.0/contrib/dnsmasq">
- https://github.com/poseidon/matchbox/tree/v0.7.0/contrib/dnsmasq
- </a>
- <div>
+ </p>
+ <h3>Matchbox</h3>
+ <p>...</p>
+ <h3>PXE network boot enviroment</h3>
+ <p>...</p>
+ <h3>Terraform Tectonic</h3>
+ <p>...</p>
+ <h3 id="footnotes">Links</h3>
+ <div >
+ <sup>1</sup>
+ <a href="https://coreos.com/tectonic/docs/latest/install/bare-metal/metal-terraform.html">
+ https://coreos.com/tectonic/docs/latest/install/bare-metal/metal-terraform.html
+ </a>
+ <div>
+ <div>
+ <sup>2</sup>
+ <a href="https://coreos.com/tectonic/docs/latest/install/bare-metal/requirements.html">
+ https://coreos.com/tectonic/docs/latest/install/bare-metal/requirements.html
+ </a>
+ <div>
+ <div>
+ <sup>3</sup>
+ <a href="https://coreos.com/matchbox/docs/latest/network-setup.html">
+ https://coreos.com/matchbox/docs/latest/network-setup.html
+ </a>
+ <div>
+ <div>
+ <sup>4</sup>
+ <a href="https://coreos.com/matchbox/docs/latest/deployment.html">
+ https://coreos.com/matchbox/docs/latest/deployment.html
+ </a>
+ <div>
+ <div>
+ <sup>5</sup>
+ <a href="https://coreos.com/tectonic/releases/">
+ https://coreos.com/tectonic/releases/
+ </a>
+ <div>
+ <div>
+ <sup>6</sup>
+ <a href="https://github.com/poseidon/matchbox/tree/v0.7.0/contrib/dnsmasq">
+ https://github.com/poseidon/matchbox/tree/v0.7.0/contrib/dnsmasq
+ </a>
+ <div>
</section>
diff --git a/src/blog.rs b/src/blog.rs
index 6bbda4996f521103a23a5b6667ed3db8c9388ae1..0fa9543d0587f6369870ffe56a30084a0beec241 100644
--- a/src/blog.rs
+++ b/src/blog.rs
@@ -1,16 +1,15 @@
+use chrono::NaiveDate;
+use regex::Regex;
use rust_embed::RustEmbed;
use sailfish::TemplateOnce;
-use chrono::NaiveDate;
-use regex::{Regex};
+use std::cmp::{Eq, Ord, PartialEq, PartialOrd};
use std::str;
-use std::cmp::{PartialOrd, Ord, PartialEq, Eq};
const BLOG_REGEX: &str = r"(?P<date>[\d]{4}-[\d]{2}-[\d]{2})(?P<title>[a-zA-Z0-9-_]*)";
#[derive(RustEmbed)]
#[folder = "content/posts/"]
struct PostAsset;
-
#[derive(TemplateOnce)]
#[template(path = "index.html")]
@@ -23,7 +22,7 @@ #[template(path = "post.html")]
struct PostTemplate {
content: String,
title: String,
- date: String
+ date: String,
}
#[derive(PartialEq, Eq, PartialOrd, Ord)]
@@ -43,12 +42,11 @@
BlogEntry {
title: String::from(title),
file: String::from(path),
- datetime: NaiveDate::parse_from_str(date, "%Y-%m-%d").unwrap()
+ datetime: NaiveDate::parse_from_str(date, "%Y-%m-%d").unwrap(),
}
}
pub fn read_assets() -> Vec<BlogEntry> {
-
let mut entries: Vec<BlogEntry> = PostAsset::iter()
.map(|e| format!("{}", e))
.map(|e| BlogEntry::new(&e))
@@ -61,14 +59,10 @@ }
}
fn get_file_content(path: &str) -> String {
- let buffer = PostAsset::get(path)
- .unwrap()
- .data
- .into_owned();
+ let buffer = PostAsset::get(path).unwrap().data.into_owned();
return String::from_utf8(buffer).unwrap();
}
-
pub fn render_post_page(path: &String) -> String {
let blog = BlogEntry::new(path);
@@ -76,14 +70,16 @@
PostTemplate {
content: get_file_content(path),
title: blog.title,
- date: blog.datetime.format("%Y-%m-%d").to_string()
+ date: blog.datetime.format("%Y-%m-%d").to_string(),
}
- .render_once()
- .unwrap()
+ .render_once()
+ .unwrap()
}
pub fn render_index_page() -> String {
- IndexTemplate { posts: BlogEntry::read_assets() }
- .render_once()
- .unwrap()
+ IndexTemplate {
+ posts: BlogEntry::read_assets(),
+ }
+ .render_once()
+ .unwrap()
}
diff --git a/src/router.rs b/src/router.rs
index 0bba091cb8533672e794fd3b48c9dac9cdd2e6a0..35fdf3e8bed96a76bda385f0242e4757bfa06553 100644
--- a/src/router.rs
+++ b/src/router.rs
@@ -1,4 +1,4 @@
-use regex::{Regex};
+use regex::Regex;
const ACTION_REGEX: &str = r"/{0,1}(?P<action>\w*)/(?P<id>.+)";
@@ -14,14 +14,15 @@ let re = Regex::new(ACTION_REGEX).unwrap();
let caps = re.captures(path);
let action = match caps {
Some(ref value) => &value["action"],
- None => "index"
+ None => "index",
};
match action {
- "posts" => Router::Post { page: caps.unwrap()["id"].to_string() },
+ "posts" => Router::Post {
+ page: caps.unwrap()["id"].to_string(),
+ },
"index" => Router::Index,
- _ => Router::NotFound
+ _ => Router::NotFound,
}
}
}
-
diff --git a/templates/head.html b/templates/head.html
index c054157d1cca5c47cf8b8fc57f0cb15d5c9753d7..3492eda3a3d46094ceefe503b72da649081712b5 100644
--- a/templates/head.html
+++ b/templates/head.html
@@ -3,5 +3,5 @@ <meta name="viewport" content="width=device-width, initial-scale=1">
<title>Yet Another Blog</title>
<link rel="icon" type="image/x-icon" href="">
<style>
- <% include!("pico.min.css"); %>
+<% include!("main.css"); %>
</style>
diff --git a/templates/header.html b/templates/header.html
index 1340aa1711011046f6730f8e278513acd64228b5..c830273fec5e96c3e65e4832315f6ab9d164aec4 100644
--- a/templates/header.html
+++ b/templates/header.html
@@ -1,10 +1,12 @@
<header class="container">
- <nav class="container-fluid">
- <ul>
- <li><h2><a href="/">Yet Another Blog</a></h2></li>
- </ul>
- <ul>
- <li><a href="https://gitlab.com/gabrielgio/cv/-/raw/main/cv.pdf?inline=false" class="secondary">Resume</a></li>
- </ul>
- </nav>
+ <div class="title-wrapper">
+ <a href="/">
+ <h2 class="title">Yet Another Blog</h2>
+ </a>
+ <nav class="container-fluid">
+ <ul>
+ <li><a href="https://gitlab.com/gabrielgio/cv/-/raw/main/cv.pdf?inline=false" class="secondary">Resume</a></li>
+ </ul>
+ </nav>
+ </div>
</header>
diff --git a/templates/index.html b/templates/index.html
index 006643a237521f0b87c035d7114c6e2e3faf5aaa..f6f3ca982b6751d9de2f0c3d94df228b02b95591 100644
--- a/templates/index.html
+++ b/templates/index.html
@@ -1,22 +1,28 @@
<!DOCTYPE html>
<html data-theme="light" lang="en">
-<head>
- <% include!("head.html"); %>
-</head>
-<body>
-<% include!("header.html"); %>
-<main class="container">
- <section>
- A gathering of information about some things I do on my spare time.
- You can find me on gitlab, twitter and linkedin.
- </section>
- <section>
- <ul>
- <% for p in &posts { %>
- <li><a href="/posts/<%- p.file %>"><%- p.title %></a></li>
- <% } %>
- </ul>
- </section>
-</main>
-</body>
+ <head>
+ <% include!("head.html"); %>
+ </head>
+ <body>
+ <div class="layout">
+ <% include!("header.html"); %>
+ <main>
+ <div class="slim-description">
+ A gathering of information about some things I do on my
+ spare time. You can find me on gitlab, twitter and
+ linkedin.
+ </div>
+ <div class="blog-list">
+ <% for p in &posts { %>
+ <article class="list-item">
+ <div class="post-title">
+ <a href="/posts/<%- p.file %>"><%- p.title %></a>
+ </div>
+ <span classname="data-label"><%- p.datetime | disp %></span>
+ </article>
+ <% } %>
+ </div>
+ </main>
+ </div>
+ </body>
</html>
diff --git a/templates/main.css b/templates/main.css
new file mode 100644
index 0000000000000000000000000000000000000000..f056a50c86db44dcce5364e35447b7733d795510
--- /dev/null
+++ b/templates/main.css
@@ -0,0 +1,263 @@
+* {
+ box-sizing: border-box;
+ font-family: dejavu sans;
+}
+body {
+ margin: 0;
+}
+h1,
+h2,
+h3,
+h4 {
+ font-weight: 400;
+}
+code[class*="language-"],
+nav,
+.blog-list {
+ font-style: normal;
+ font-weight: 400;
+ font-size: 1.025rem;
+}
+code {
+ font-family: dejavu sans mono;
+}
+tags {
+ font-family: dejavu sans mono;
+}
+.list-item {
+ font-family: dejavu sans mono;
+}
+html {
+ font-size: 16px;
+}
+body {
+ line-height: 1.8em;
+ color: #333;
+ background: #fefefe;
+}
+.post-title,
+.date-label {
+ letter-spacing: 0.025rem;
+}
+p,
+sub,
+nav {
+ letter-spacing: 0.05rem;
+}
+.title-wrapper,
+.title {
+ letter-spacing: 0.075rem;
+}
+a {
+ text-decoration: none;
+}
+.brand-icon {
+ color: #f93a3a;
+ display: inline-flex;
+ border-bottom: 1px solid;
+}
+.brand-icon:hover {
+ border-bottom: none;
+}
+.layout {
+ max-width: 48rem;
+ margin-left: auto;
+ margin-right: auto;
+ padding: 2.625rem 1.3125rem;
+}
+.layout .title-wrapper {
+ display: flex;
+ flex-direction: column;
+ align-items: center;
+ margin-bottom: 0.5rem;
+}
+.layout .title {
+ color: #333;
+ text-align: left;
+ display: block;
+ font-size: 1.875rem;
+ margin: 0;
+}
+nav {
+ font-size: 1.025rem;
+ text-align: center;
+}
+nav ul {
+ display: block;
+ padding: 0;
+}
+nav ul li {
+ display: inline;
+ list-style-type: none;
+}
+nav ul li a {
+ color: #333;
+ display: inline-block;
+ padding-top: 0.5rem;
+ padding-bottom: 0.5rem;
+ border-bottom: 1px solid #fefefe;
+}
+nav ul li a:hover {
+ color: #f93a3a;
+}
+nav ul li:not(:last-child) {
+ padding: 0 1rem 0 0;
+}
+.slim-description {
+ margin-bottom: calc(16px * 2);
+ color: #666;
+}
+.blog-post-content a {
+ color: #f93a3a;
+ text-decoration: none;
+ border-bottom: 1px solid;
+}
+.blog-post-content a:hover {
+ border-bottom: none;
+}
+.blog-list .list-item {
+ display: flex;
+ flex-direction: column-reverse;
+ align-items: baseline;
+ padding: 0.5rem 0.5rem 0.5rem 0;
+}
+.blog-list .post-title a {
+ text-decoration: none;
+ color: #333;
+ border-bottom: none;
+}
+.blog-list .post-title a:hover {
+ border-bottom: 1px solid;
+}
+.blog-list .date-label {
+ font-size: 80%;
+ margin-right: 1rem;
+}
+.content .title {
+ font-size: 1.275rem;
+}
+.blog-post-content a {
+ color: #f93a3a;
+ text-decoration: none;
+ border-bottom: 1px solid;
+}
+.blog-post-content a:hover {
+ border-bottom: none;
+}
+.blog-post-content img {
+ width: 100%;
+}
+.post-image {
+ margin-left: calc(-1.3125rem);
+ margin-right: calc(-1.3125rem);
+}
+.post-image img {
+ width: 100%;
+}
+.tags {
+ font-size: 0.9em;
+ text-align: left;
+}
+.tags ul {
+ display: block;
+ padding: 0;
+}
+.tags ul li {
+ display: inline;
+ list-style-type: none;
+ text-align: center;
+}
+.tags ul li a {
+ border: 1px solid #f93a3a;
+ border-radius: 3px;
+ background: #f93a3a;
+ padding: 0.2em;
+ color: #fff;
+ margin: 10px 2px 10px 0;
+ line-height: 1em;
+}
+.tags ul li a:hover {
+ background: #fefefe;
+ color: #f93a3a;
+}
+.tags ul li:not(:last-child) {
+ padding: 0 0.1rem 0 0;
+}
+.highlight {
+ margin-left: calc(-1.3125rem);
+ margin-right: calc(-1.3125rem);
+}
+.highlight pre {
+ line-height: 1.2rem;
+ border: 1px solid #ddd;
+ border-radius: 5px;
+ overflow: auto;
+ padding: 1.3125rem;
+ margin: 0;
+}
+.highlight pre code[class*="language-"] {
+ font-size: 0.9em;
+}
+.highlight pre .token.comment {
+ font-style: italic;
+}
+blockquote {
+ background: #f9f9f9;
+ border-left: 5px solid #333;
+ margin: 1.5em 10px;
+ padding: 0.5em 10px;
+ quotes: "“" "”" "‘" "’";
+}
+blockquote:before {
+ color: #333;
+ content: open-quote;
+ font-size: 4em;
+ line-height: 0.1em;
+ margin-right: 0.25em;
+ vertical-align: -0.4em;
+}
+blockquote p {
+ display: inline;
+}
+time {
+ font-size: 80%;
+ margin-right: 1rem;
+}
+@media only screen and (min-width: 600px) {
+ .layout .title-wrapper {
+ display: flex;
+ justify-content: space-between;
+ align-items: center;
+ flex-direction: row;
+ }
+ .layout .title {
+ margin-block-start: 0.83em;
+ margin-block-end: 0.83em;
+ margin-inline-start: 0;
+ margin-inline-end: 0;
+ }
+ .blog-list .list-item {
+ display: flex;
+ justify-content: space-between;
+ align-items: center;
+ flex-direction: unset;
+ padding: 0;
+ margin-bottom: 0.5rem;
+ }
+ .blog-list .date-label {
+ font-size: 100%;
+ margin-right: 0;
+ }
+ .project-board {
+ grid-template-columns: 1fr 1fr;
+ }
+ .highlight {
+ margin-left: 0;
+ margin-right: 0;
+ }
+ .post-image {
+ margin-left: 0;
+ margin-right: 0;
+ }
+}
+
diff --git a/templates/post.html b/templates/post.html
index 7e0a909a4d894a4bb21020e25283e8a3fff97dcc..99a7852ec2df5ca8c82cd5af3fde2abf6bc2a5b1 100644
--- a/templates/post.html
+++ b/templates/post.html
@@ -1,18 +1,20 @@
<!DOCTYPE html>
<html data-theme="light" lang="en">
-<head>
- <% include!("head.html"); %>
-</head>
-<body>
-<% include!("header.html"); %>
-<main class="container">
- <h2><%- title %></h2>
- <h5>Created At: <%- date %></h2>
- <%- content %>
- </section>
-</main>
-</body>
-
-<script>
-</script>
+ <head>
+ <% include!("head.html"); %>
+ </head>
+ <body>
+ <div class="layout">
+ <% include!("header.html"); %>
+ <main>
+ <article>
+ <h1><%- title %></h1>
+ <time>Created At: <%- date %></time>
+ <div class="blog-post-content">
+ <%- content %>
+ </div>
+ </article>
+ </main>
+ </div>
+ </body>
</html>