feat: backend is done

This commit is contained in:
eggy 2025-01-13 02:43:26 -05:00
parent 5b0eca1072
commit e1ee8bdf93
2 changed files with 59 additions and 57 deletions

View File

@ -9,8 +9,8 @@
end_date: "Apr 2027", end_date: "Apr 2027",
location: "Waterloo, ON", location: "Waterloo, ON",
tasks: ( tasks: (
[Courses: Object-oriented programming, data structures & algorithms, digital // [Courses: Object-oriented programming, data structures & algorithms, concurrency,
logic & circuits, operating systems], // operating systems],
[Extracurriculars: Hack the North Organising Team, UW Orbital Satellite Design [Extracurriculars: Hack the North Organising Team, UW Orbital Satellite Design
Team, Creative Writing Club], Team, Creative Writing Club],
), ),
@ -20,9 +20,10 @@
#let skills = indent[ #let skills = indent[
*Languages:* TypeScript/JavaScript, Rust, Python, Java, SQL, HTML/CSS \ *Languages:* TypeScript/JavaScript, Rust, Python, Java, SQL, HTML/CSS \
// Dart // Dart
*Technologies:* Spring Boot, Express, Prisma, Apollo, Axum, GraphQL, React \ *Technologies:* Postgres, Spring Boot, Express, Redis, Terraform, Prisma,
*Tools:* Linux, Git, Docker, Postgres, Pytest, Jest, AWS/GCP, Kubernetes, Apollo, Axum, GraphQL, React \
Terraform, Jenkins, nginx // Jenkins, systemd, Jira *Developer Tools:* Linux, Git, Docker, Pytest, Jest, AWS, GCP, Kubernetes,
Jenkins, nginx // Jenkins, systemd, Jira
] ]
#show: doc => template_common(education, skills, doc) #show: doc => template_common(education, skills, doc)
@ -39,11 +40,12 @@
location: "New York, NY", location: "New York, NY",
tools: "Rust, TypeScript, Solidity, React, GraphQL", tools: "Rust, TypeScript, Solidity, React, GraphQL",
tasks: ( tasks: (
[?? Portal claim config (db, FE, BE, how lucrative it is) padding padding [Created an internal tool to spin up new custom Airdrop landing portals based off
padding, automated deployments], of Figma designs with Vercel's API],
[?? Solana claim fees Wrote a Rust smart contract to add a fee for claiming [Developed a new external REST API for customers who wanted to access our token
tokens on Solana], data programmatically], // termination display (FE), external API for customers not using our platform (BE)
[?? perf and databasest], [Wrote smart contracts for the Solana blockchain to add claim fees to our token
vesting platform],
), ),
) )
@ -56,17 +58,15 @@
location: "Remote", location: "Remote",
tools: "TypeScript, Spring Boot, React, Postgres, Terraform, AWS", tools: "TypeScript, Spring Boot, React, Postgres, Terraform, AWS",
tasks: ( tasks: (
// [Owned the creation of an end-to-end document vault feature in React for users to [Owned end-to-end development of a secure document vault for users to upload ID
// upload and verify identity documents with Textract, reducing support tickets by documents with S3 and Textract],
// *25%*], [Championed and shipped features for *SOC 2 security compliance*, including
[Planned and executed a roadmap to *SOC 2 security compliance* by implementing *role-based permissions with JWTs* in Spring Boot, alert logging with
*role-based permissions with JWTs* in Spring Boot, logging alerts to CloudWatch, CloudWatch, and stronger privacy controls for user data],
and introducing new privacy controls for user data], [Reduced dashboard load time by 38% by implementing a stale-while-revalidate
[?? be specific Investigated and improved initial load time by *80%* for tool caching strategy],
using async data fetching and optimising relations], [Created a CI/CD system from scratch with Terraform and Jenkins to automatically
[?? make it clear that you deployed the entire setup, atm makes it seem like you deploy AWS Lambdas], // BE-infra only, FE ver is admin dashboard
clicked some buttons Created CI/CD pipelines to automatically deploy AWS Lambdas
with Terraform and Jenkins],
), ),
) )
@ -79,13 +79,13 @@
location: "Remote", location: "Remote",
tools: "TypeScript, Python, React, Postgres, AWS", tools: "TypeScript, Python, React, Postgres, AWS",
tasks: ( tasks: (
[??? make it clearer what this is Engineered a new React data query builder and [Architected a data query builder and executor engine for customers to visualise
FastAPI backend for our business intelligence visualisation service to *33000+* their data warehouses by custom-tailoring forms on-the-fly, supporting complex
users, eliminating the need for clients to manually write API calls], nested logic for 3000+ enterprise users across 8 database types], //
[?? what is it Shipped a new database sync tool for *46000+* users by abstracting [Shipped an LSP server for our custom query DSL, including customer-specific
data sources behind an adapter-based architecture and AWS Lambdas], autocomplete and syntax highlighting], // TODO
[?? data focus, new tool dDeveloped a *serverless microservice* that [Developed a serverless microservice to asynchronously ingest email attachments
asynchronously ingests email attachments directly into ETL pipelines], directly into ETL pipelines],
// [??? emphasise test driven development or remove line *Reduced request errors by 30%* by creating backend testing infrastructure with // [??? emphasise test driven development or remove line *Reduced request errors by 30%* by creating backend testing infrastructure with
// *Pytest* to catch regressions and test new features across database engines with // *Pytest* to catch regressions and test new features across database engines with
// *90% code coverage*], // *90% code coverage*],
@ -93,7 +93,7 @@
) )
#work_entry( #work_entry(
"Backend Developer", "Backend / Infrastructure Developer",
"Hack the North", "Hack the North",
company_link: "https://hackthenorth.com", company_link: "https://hackthenorth.com",
start_date: "Mar 2023", start_date: "Mar 2023",
@ -101,15 +101,12 @@
location: "Waterloo, ON", location: "Waterloo, ON",
tools: "TypeScript, Express, Postgres, Kubernetes", tools: "TypeScript, Express, Postgres, Kubernetes",
tasks: ( tasks: (
[Built a new travel registration application leveraging GraphQL to track bus [Streamlined event check-in times for *1900+* guests by generating scannable
capacity for *500+* attendees in real time], mobile wallet passes over Express],
[??? Apple wallet, mention it's a new feature], [Overhauled CI/CD pipelines, speeding up builds by 35% by parallelising testing
[Diagnosed and recovered from crashes due to load spikes up to *800k* updates per and type checking],
hour at the world's largest student-run hackathon by maintaining and autoscaling [Resolved four production downtime incidents within 30 minutes of first report as
Redis and Postgres on Kubernetes], part of the on-call team],
[??? CI/infra focus, deploying otel and traces],
// [Upgraded the event statistics dashboard to update in real time with GraphQL
// *subscriptions with Redis PubSub*],
), ),
) )
] ]
@ -118,30 +115,31 @@
#set strong(delta: SMALL_STRONG) #set strong(delta: SMALL_STRONG)
#indent[ #indent[
#project( #project(
"Mandown Comic Downloader", "Mandown",
"Python, Qt", "Python, Qt",
repo_link: "https://github.com/potatoeggy/mandown", repo_link: "https://github.com/potatoeggy/mandown",
tasks: ( tasks: (
[Created a CLI and GUI to scrape, download, and convert webcomics into [Created a CLI and GUI to scrape, download, and convert webcomics into
e-ink-optimised PDF/EPUBs], e-ink-optimised comic files],
[Designed a scalable ebook converter with a *plugin-based architecture* to [Redesigned the ebook converter with a *plugin-based architecture* to increase
improve compatibility], accessibility for new contributors],
[Implemented *image caching and multithreading* to increase download and update [Expanded support for new formats and features #link("https://github.com/potatoeggy/mandown/issues/55")[based on] #link("https://github.com/potatoeggy/mandown/issues/89")[user] #link("https://github.com/potatoeggy/mandown/issues/63")[demand],
speeds by *300%*], minimising regressions with #link(
"https://github.com/potatoeggy/mandown/blob/master/tests/test_source_batoto.py",
)[E2E tests]],
[Implemented *image caching and multithreading* to increase download and
processing speeds by *300%*],
), ),
) )
#project( #project(
"Kobo Sync Server", "Kobink",
"Rust, Axum", "Rust, Axum",
repo_link: "https://github.com/potatoeggy/kobink", repo_link: "https://github.com/potatoeggy/kobink",
tasks: ( tasks: (
[Developed a *Rust* backend to sync custom ebook files to Kobos by reimplementing [Built a backend to sync custom ebook files to Kobos by reverse-engineering and
the Kobo Sync API], mimicking the Kobo Sync API],
[Deployed the service behind an nginx reverse proxy and Cloudflare DNS to sync
over the internet],
), ),
) )
@ -184,12 +182,14 @@
// plan for each week // plan for each week
#project( #project(
"Arch Linux Server", "Arch Linux Server (\"hwaboon\")",
"Linux, Docker, nginx, systemd", "Linux, Docker, nginx, systemd",
demo_link: "https://eggworld.me", demo_link: "https://eggworld.me",
tasks: (
[Created a *self-hosted CI/CD pipeline* with *Gitea* to automatically deploy
personal projects behind *nginx*], // TODO
[Managed services with *Docker* and *systemd* to simplify deployment and resource
constrainment], // TODO
),
) )
- Created a *self-hosted CI/CD pipeline* with *Gitea* to automatically deploy
personal projects behind *nginx*
- Containerised services with *Docker* and *systemd* to simplify deployment and
management
] ]

View File

@ -7,7 +7,7 @@
#let HEADING_FONT = TITLE_FONT #let HEADING_FONT = TITLE_FONT
#let BODY_FONT = "Open Sans" #let BODY_FONT = "Open Sans"
#let BODY_FONT_SIZE = 9.5pt #let BODY_FONT_SIZE = 9.75pt
#let HEADING_FONT_SIZE = 0.95em #let HEADING_FONT_SIZE = 0.95em
#let TITLE_FONT_SIZE = 2em #let TITLE_FONT_SIZE = 2em
@ -18,6 +18,7 @@
#let DETAILS_TITLE_FONT_SIZE = 1.075em #let DETAILS_TITLE_FONT_SIZE = 1.075em
#let DETAILS_LIST_SPACING = 0.8em #let DETAILS_LIST_SPACING = 0.8em
#let DETAILS_LIST_INDENT = 1.5em
// rest = not top // rest = not top
#let PAGE_MARGINS = (right: 0.5in, top: 0.3in, left: 0.4in, bottom: 0.4in) #let PAGE_MARGINS = (right: 0.5in, top: 0.3in, left: 0.4in, bottom: 0.4in)
@ -47,6 +48,7 @@
}), }),
{ {
set strong(delta: SMALL_STRONG) set strong(delta: SMALL_STRONG)
show link: underline
list(tight: false, spacing: DETAILS_LIST_SPACING, marker: [•], ..details) list(tight: false, spacing: DETAILS_LIST_SPACING, marker: [•], ..details)
}, },
) )
@ -116,7 +118,7 @@
// Set name and contact data and format headings // Set name and contact data and format headings
#let template(name, color, doc) = { #let template(name, color, doc) = {
set page(margin: PAGE_MARGINS, paper: "us-letter") set page(margin: PAGE_MARGINS, paper: "us-letter")
set list(indent: 1em, marker: [•]) set list(indent: DETAILS_LIST_INDENT, marker: [•])
set text(font: (BODY_FONT), BODY_FONT_SIZE) set text(font: (BODY_FONT), BODY_FONT_SIZE)
set par(justify: true, leading: BODY_LINE_HEIGHT) set par(justify: true, leading: BODY_LINE_HEIGHT)
align(center)[ align(center)[