update .ignores, projects work
This commit is contained in:
parent
df5abad06d
commit
275f58b1df
10 changed files with 107 additions and 21 deletions
|
@ -1,6 +1,5 @@
|
||||||
# don't ever lint node_modules
|
node_modules/
|
||||||
node_modules
|
public/
|
||||||
# don't lint build output (make sure it's set to your correct build folder name)
|
.cache/
|
||||||
dist
|
|
||||||
# don't lint nyc coverage output
|
# don't lint nyc coverage output
|
||||||
coverage
|
coverage
|
|
@ -1,4 +1,5 @@
|
||||||
.cache
|
.cache/
|
||||||
package.json
|
package.json
|
||||||
package-lock.json
|
package-lock.json
|
||||||
public
|
public/
|
||||||
|
node_modules/
|
|
@ -92,7 +92,7 @@ exports.createPages = async ({ actions, graphql, reporter }) => {
|
||||||
'**/src/notes/*',
|
'**/src/notes/*',
|
||||||
'/notes',
|
'/notes',
|
||||||
'./src/templates/notes.tsx',
|
'./src/templates/notes.tsx',
|
||||||
'./src/templates/note.tsx'
|
'./src/templates/note.tsx',
|
||||||
);
|
);
|
||||||
await generatePages(
|
await generatePages(
|
||||||
createPage,
|
createPage,
|
||||||
|
@ -101,7 +101,7 @@ exports.createPages = async ({ actions, graphql, reporter }) => {
|
||||||
'**/src/projects/*',
|
'**/src/projects/*',
|
||||||
'/projects',
|
'/projects',
|
||||||
'./src/templates/projects.tsx',
|
'./src/templates/projects.tsx',
|
||||||
'./src/templates/note.tsx'
|
'./src/templates/project.tsx',
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -114,7 +114,8 @@ exports.createSchemaCustomization = ({ actions: { createTypes } }) => {
|
||||||
type CommonFrontmatter {
|
type CommonFrontmatter {
|
||||||
hidden: Boolean,
|
hidden: Boolean,
|
||||||
lang: String,
|
lang: String,
|
||||||
tags: [String]
|
tags: [String],
|
||||||
|
subtitle: String,
|
||||||
}
|
}
|
||||||
`);
|
`);
|
||||||
};
|
};
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
.project-item {
|
.project-item {
|
||||||
display: flex;
|
display: flex;
|
||||||
align-items: baseline;
|
align-items: baseline;
|
||||||
|
justify-content: space-between;
|
||||||
}
|
}
|
||||||
|
|
||||||
.project-title {
|
.project-title {
|
||||||
|
|
|
@ -9,8 +9,10 @@ interface ItemProps {
|
||||||
}
|
}
|
||||||
|
|
||||||
export default (props: ItemProps): JSX.Element => (
|
export default (props: ItemProps): JSX.Element => (
|
||||||
<Link to={props.to} className={style.projectItem}>
|
<article className={style.projectItem}>
|
||||||
|
<Link to={props.to}>
|
||||||
<h3 className={style.projectTitle}>{props.title}</h3>
|
<h3 className={style.projectTitle}>{props.title}</h3>
|
||||||
<p className={style.projectSubtitle}>{props.subtitle}</p>
|
|
||||||
</Link>
|
</Link>
|
||||||
|
<p className={style.projectSubtitle}>{props.subtitle}</p>
|
||||||
|
</article>
|
||||||
);
|
);
|
||||||
|
|
50
src/projects/bunbun.mdx
Normal file
50
src/projects/bunbun.mdx
Normal file
|
@ -0,0 +1,50 @@
|
||||||
|
---
|
||||||
|
title: "Bunbun"
|
||||||
|
subtitle: "Cross-browser search commands"
|
||||||
|
path: "bunbun"
|
||||||
|
date: 2020-01-01
|
||||||
|
lang: "rust"
|
||||||
|
tags: []
|
||||||
|
---
|
||||||
|
|
||||||
|
[Bunbun][1] is a search delegation service and my first project in Rust. It's a
|
||||||
|
implementation of [bunny1][bunny1] that offers a simple config file as well as
|
||||||
|
an extensible plugin system.
|
||||||
|
|
||||||
|
An interesting note about the project is that [I've submitted a patch][hotwatch]
|
||||||
|
to an library to fix a bug where the file descriptor for watching the config
|
||||||
|
file would get stale.
|
||||||
|
|
||||||
|
For me, it solves a lot of problems I have, particularly in the sense that it
|
||||||
|
lets me write shortcuts that I know will always work, instead of relying on
|
||||||
|
browsers to remember for me.
|
||||||
|
|
||||||
|
Yes, existing solutions exist, such as DuckDuckGo's [bang!][ddg-bangs] as well
|
||||||
|
as FireFox's shortcuts, but I believe this has a niche particularly for
|
||||||
|
self-hosted or enterprise environments. As it allows for plugins to run, it can
|
||||||
|
offer a uniform experience for employees or users to access common resources.
|
||||||
|
|
||||||
|
Honestly, this idea didn't sell me at first, but after using a similar variant
|
||||||
|
at my past work, I was completely dependent on it in only 12 weeks.
|
||||||
|
|
||||||
|
I've been living on this project for months now, so I can guarantee that it
|
||||||
|
works. From a privacy and security perspective, I find it to be satisfactory for
|
||||||
|
my needs:
|
||||||
|
1. It only logs to `stdout` with the option to completely disable logging.
|
||||||
|
2. It's built in Rust without any `unsafe` usage, which guarantees that my code
|
||||||
|
should be sound.
|
||||||
|
3. It uses `actix`, a well respected HTTP server library that is relatively
|
||||||
|
receptive of security concerns.
|
||||||
|
4. Its plugin system is as private and secure as the host it's running on, and
|
||||||
|
fails safe on improperly defined inputs.
|
||||||
|
5. It has meaningful tests!
|
||||||
|
|
||||||
|
_Caveat emptor_[^1], of course. You should audit the code yourself, but I'm
|
||||||
|
happy with the work I've made (and always receptive of feedback).
|
||||||
|
|
||||||
|
[1]: https://github.com/edward-shen/bunbun
|
||||||
|
[bunny1]: http://www.bunny1.org/
|
||||||
|
[hotwatch]: https://github.com/francesca64/hotwatch/pull/4
|
||||||
|
[ddg-bangs]: https://duckduckgo.com/bang
|
||||||
|
|
||||||
|
[^1]: https://en.wikipedia.org/wiki/Caveat_emptor
|
|
@ -1,8 +1,10 @@
|
||||||
---
|
---
|
||||||
|
title: "Shlink"
|
||||||
|
subtitle: "1-click link shortening"
|
||||||
path: "shlink"
|
path: "shlink"
|
||||||
date: 2020-01-01
|
date: 2020-01-01
|
||||||
title: "Shlink"
|
|
||||||
lang: "js"
|
lang: "js"
|
||||||
|
tags: []
|
||||||
---
|
---
|
||||||
|
|
||||||
Hello World
|
Shlink
|
|
@ -4,8 +4,7 @@ import { graphql } from 'gatsby';
|
||||||
import { MDXRenderer } from 'gatsby-plugin-mdx';
|
import { MDXRenderer } from 'gatsby-plugin-mdx';
|
||||||
|
|
||||||
export default ({ data }) => {
|
export default ({ data }) => {
|
||||||
const { frontmatter, body } = data.mdx;
|
const { frontmatter, tableOfContents, body } = data.mdx;
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
<Navbar />
|
<Navbar />
|
||||||
|
|
31
src/templates/project.tsx
Normal file
31
src/templates/project.tsx
Normal file
|
@ -0,0 +1,31 @@
|
||||||
|
import React from 'react';
|
||||||
|
import Navbar from '../components/navbar';
|
||||||
|
import { graphql } from 'gatsby';
|
||||||
|
import { MDXRenderer } from 'gatsby-plugin-mdx';
|
||||||
|
|
||||||
|
export default ({ data }) => {
|
||||||
|
const { frontmatter, body } = data.mdx;
|
||||||
|
return (
|
||||||
|
<>
|
||||||
|
<Navbar />
|
||||||
|
<main>
|
||||||
|
<h1>{frontmatter.title}</h1>
|
||||||
|
<h5>{frontmatter.subtitle}</h5>
|
||||||
|
<MDXRenderer>{body}</MDXRenderer>
|
||||||
|
</main>
|
||||||
|
</>
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
export const query = graphql`
|
||||||
|
query ProjectsItemQuery($id: String!) {
|
||||||
|
mdx(id: { eq: $id }) {
|
||||||
|
frontmatter {
|
||||||
|
title
|
||||||
|
subtitle
|
||||||
|
}
|
||||||
|
tableOfContents
|
||||||
|
body
|
||||||
|
}
|
||||||
|
}
|
||||||
|
`;
|
|
@ -11,14 +11,14 @@ export default ({ data, pageContext }): JSX.Element => {
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
<Navbar />
|
<Navbar />
|
||||||
{posts.map(({ node }) => {
|
{posts.map(({ node: { id, frontmatter } }) => {
|
||||||
const frontmatter = node.frontmatter;
|
|
||||||
return (
|
return (
|
||||||
<Item
|
<Item
|
||||||
|
key={id}
|
||||||
title={frontmatter.title}
|
title={frontmatter.title}
|
||||||
subtitle={frontmatter.lang}
|
subtitle={frontmatter.subtitle}
|
||||||
to={rootPath + '/' + frontmatter.path}
|
to={rootPath + '/' + frontmatter.path}
|
||||||
></Item>
|
/>
|
||||||
);
|
);
|
||||||
})}
|
})}
|
||||||
<PaginationNav
|
<PaginationNav
|
||||||
|
@ -48,7 +48,7 @@ export const query = graphql`
|
||||||
title
|
title
|
||||||
date(formatString: "YYYY-MM-DD")
|
date(formatString: "YYYY-MM-DD")
|
||||||
path
|
path
|
||||||
lang
|
subtitle
|
||||||
}
|
}
|
||||||
id
|
id
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue