resume/backend_infra.typ
2025-02-08 00:00:27 -05:00

215 lines
7.9 KiB
Plaintext

#import "lib/template_common.typ": template_common, work_entry, project, indent, SMALL_STRONG
#let education = indent[
#work_entry(
"University of Waterloo",
"B.A.Sc. in Computer Engineering, Honours — 3.7/4.0 GPA",
start_date: "Sep 2022",
end_date: "Apr 2027",
location: "Waterloo, ON",
tasks: (
[*Involvements*: UW Orbital Satellite Design Team, Intramurals (Beach
Volleyball), Creative Writing Club (Founder)],
[*Hackathons*: StormHacks 2022 (#link("https://devpost.com/software/perdiem")[EdTech Winner]),
YRHacks 2022 (#link("https://devpost.com/software/resketch")[IBM Open Source Winner])],
),
)
]
#let skills = indent[
*Languages:* Python, TypeScript/JavaScript, Rust, Java, C/C++, SQL, HTML/CSS \
// Dart
*Frameworks:* Node, React, Vue, GraphQL, Spring Boot, Express, Redis, Terraform,
Prisma, Apollo, Axum \
*Tools:* Linux, Postgres, Git, Docker, AWS, GCP, Kubernetes, Figma, Jenkins,
nginx // Jenkins, systemd, Jira
]
#show: doc => template_common(education, skills, doc)
= Experience
#indent[
#work_entry(
"Backend Lead",
"Hack the North",
company_link: "https://hackthenorth.com",
start_date: "Mar 2023",
end_date: "Oct 2024",
location: "Waterloo, ON",
tools: "TypeScript, Express, Postgres, Kubernetes",
tasks: (
[Led 6-person engineering team, shipping shift scheduling system and hardware
inventory system to *6000+ users*],
[Streamlined event check-in times for *1900+* guests by automatically generating
Apple Wallet passes],
[Overhauled CI/CD pipelines, speeding up builds by *35%* by parallelising testing
and type checking with *Buildkite*],
[Resolved slowdowns by *introducing OpenTelemetry tracing* onto *Grafana*
dashboards managed in *Kubernetes*],
[ Slashed dev server reload time by *93%* by introducing threading and
pre-transpiling generated code ],
),
)
#work_entry(
"Software Engineering Intern",
"Magna",
company_link: "https://magna.so",
start_date: "Sep 2024",
end_date: "Dec 2024",
location: "New York, NY",
tools: "Rust, TypeScript, Solidity, React, GraphQL",
tasks: (
[Enabled *one-click creation and deployment* of
#link("https://claim.paramgaming.com/")[landing] #link("https://claim.moonray.game/")[pages]
that each distribute *1 million+* token allocations],
[Investigated and *improved initial load times by >60%* for client sites by
caching blockchain reads in *Redis*],
[Created and refactored data models, controllers, and *GraphQL APIs* to store and
deploy site configurations],
[Reduced boilerplate to write database queries by *90%* decoupling business and
domain logic],
),
)
// #work_entry(
// "Data Engineer",
// "Archive Of Our Own",
// company_link: "https://www.transformativeworks.org/",
// start_date: "Jan 2024",
// end_date: "Sep 2024",
// location: "Remote",
// tools: "Python, Ruby, Rails, Docker",
// tasks: (
// [?? Imported #link(
// "https://archiveofourown.org/admin_posts/30949",
// )[*3* now-defunct sites']
// content databases for #link(
// "https://archiveofourown.org/admin_posts/31009",
// )[*8+ million registered users*] by building ETL pipelines],
// [Introduced static typing to Python codebase with *mypy* to catch *10+*
// production bugs and improve maintainability],
// ),
// )
#work_entry(
"Software Engineering Intern",
"Dropbase",
company_link: "https://dropbase.io",
start_date: "May 2023",
end_date: "Aug 2023",
location: "Remote",
tools: "TypeScript, Python, React, Postgres, AWS",
tasks: (
[Shipped *static analysis tool* for platform's *custom SQL dialect* by
recursively processing an abstract syntax tree],
[Architected platform to clone, sync, and visualise databases for *3000+
enterprise users* in *Python* and *React*],
[Designed *merge conflict resolution system* to handle data mismatches, reducing
user-reported errors by *35%*],
[Built a unified API to seamlessly query and filter *8 data sources* such as
MySQL, Airtable, and Stripe],
// [Developed a serverless microservice to asynchronously ingest email attachments
// directly into ETL pipelines],
// [??? 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
// *90% code coverage*],
),
)
#work_entry(
"Software Developer",
"Immigr8",
company_link: "https://immigr8now.com",
start_date: "Jan 2024",
end_date: "Apr 2024",
location: "Remote",
tools: "TypeScript, Spring Boot, React, Postgres, Terraform, AWS",
tasks: (
[Built and launched passport/private document storage platform for *200+ users*
using *Spring Boot* and *React*],
[Secured REST endpoints with *role-based permissions* and *JWTs*; monitored and
logged alerts via CloudWatch],
[Implemented document *OCR pipeline* with Lambda, Textract, and *S3* to
automatically parse and tag uploads],
[Created parallel *CI/CD system from scratch* with *Terraform* and Jenkins to
deploy *AWS Lambdas* on commit], // BE-infra only, FE ver is admin dashboard
),
)
]
= Projects
#indent[
#project(
"Mandown",
"Python, Qt",
repo_link: "https://github.com/potatoeggy/mandown",
tasks: (
[Created a CLI and GUI to convert webcomics into e-ink-optimised files with *50+
stars* and *7 forks* over *3 years*],
[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]*, 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(
// "Kobink",
// "Rust, Axum",
// repo_link: "https://github.com/potatoeggy/kobink",
// tasks: (
// [Built a backend to sync custom ebook files to Kobos by reverse-engineering and
// mimicking the Kobo Sync API],
// [??],
// ),
// )
// #project(
// "Genshin Rewards Simulator",
// "Vue, TypeScript",
// repo_link: "https://github.com/potatoeggy/primoprod",
// demo_link: "https://primoprod.vercel.app",
// tasks: (
// [Built a realistic and beautiful *loot box simulator* with CSS animations based
// off a popular game],
// [Reduced action latency by *90%* by lazily loading art assets at opportune times,
// such as during cutscenes],
// ),
// )
#project(
"Jeopardy!",
"Vue, TypeScript, WebSockets",
repo_link: "https://github.com/potatoeggy/jeopardy",
demo_link: "https://jeopardy.eggworld.me/host",
tasks: (
[Developed a beautiful and polished client/server game with *real-time
multiplayer* in *Vue* and *WebSockets*],
[Designed a *custom JSON protocol* over *WebSockets* to synchronise game state
and handle buzzer events],
),
)
// #project(
// "RecipeReady",
// "https://github.com/vincentjguo/recipeready-server",
// "Flutter, Selenium, FastAPI, Android",
// )
// - Developed a *Flutter app* to generate recipes based on ingredients and filters
// through a FastAPI server
// - Scraped thousands of websites for recipes to build a database with a robust
// *many-to-many tag system*
// - Aggregated common ingredients heuristically to build a shopping list and a meal
// plan for each week
]