Compare commits

..

20 Commits

Author SHA1 Message Date
eggy
4705415045 feat: make lines include outcomes
I HATE THIS SO MUCH
2023-12-12 23:12:43 -05:00
eggy
c09d0bdc1a Revert "feat: remove awards"
This reverts commit 18ebf61e9b.
2023-12-05 15:11:51 -05:00
eggy
18ebf61e9b feat: remove awards 2023-12-05 12:23:49 -05:00
eggy
8b5a085447 feat: move education to top 2023-12-04 21:53:07 -05:00
eggy
f078060477 feat: better points 2023-12-04 21:10:10 -05:00
eggy
5eadcfe0ba feat: add android 2023-12-04 16:51:43 -05:00
eggy
10889dba25 feat: stronger points 2023-12-04 15:59:17 -05:00
eggy
6bfc3273c0 feat: stronger points 2023-12-04 15:58:57 -05:00
eggy
f0e9e96fe4 feat: add more tools 2023-12-04 14:22:55 -05:00
eggy
baa386a39e feat: better form line 2023-12-04 01:02:06 -05:00
eggy
f9b8dd6b0e feat: add more languages 2023-11-29 23:14:59 -05:00
eggy
d165a1b259 feat: make primoprod sound better 2023-11-28 16:20:35 -05:00
eggy
2cddfcbf6e feat: better dropbase wording 2023-11-28 15:56:37 -05:00
eggy
de8fb56d48 chore: better syntax 2023-11-28 03:06:22 -05:00
eggy
0f0ff6ba1f feat: add kobink
such a scuffed project
2023-11-28 03:05:41 -05:00
eggy
1591bdaba5 chore: move edu to bottom 2023-11-07 12:41:33 -05:00
eggy
7d289c8757 fix: remove (expected) 2023-11-07 12:41:19 -05:00
eggy
2d4d0dd6d4 chore: remove comment 2023-11-07 12:40:54 -05:00
eggy
6e8763b88d feat: add arch server 2023-11-07 12:39:21 -05:00
eggy
08201c3406 feat: adjust text styling 2023-11-06 21:10:59 -05:00
2 changed files with 66 additions and 60 deletions

View File

@@ -34,7 +34,7 @@
"University of Waterloo", "University of Waterloo",
"B.A.Sc. in Computer Engineering", "B.A.Sc. in Computer Engineering",
start_date: "Sep 2022", start_date: "Sep 2022",
end_date: "Apr 2027 (expected)", 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, digital
@@ -46,50 +46,44 @@
= Skills = Skills
#indent[ #indent[
*Languages:* Python, TypeScript/JavaScript, Rust, SQL, C++, Java, HTML, CSS \ *Languages:* Python, TypeScript, JavaScript, Rust, SQL, MATLAB, C, C++, Java,
HTML, CSS, Dart \
*Frameworks:* Node.js, Express, React, Next.js, Vue, Flutter, Qt, Prisma, *Frameworks:* Node.js, Express, React, Next.js, Vue, Flutter, Qt, Prisma,
Apollo, Axum \ Apollo, Axum, Jest, Pytest \
*Tools:* Linux, Git, Docker, PostgreSQL, Redis, Kubernetes, AWS, GCP, *Tools:* Linux, Git, Docker, PostgreSQL, Redis, Kubernetes, AWS, GCP,
OpenTelemetry, GraphQL OpenTelemetry, GraphQL, Android
] ]
= Experience = Experience
#indent[ #indent[
#show link: underline
#work_entry( #work_entry(
"Software Engineering Intern", "Software Engineering Intern",
"Dropbase", "Dropbase",
start_date: "May 2023", start_date: "May 2023",
end_date: "Aug 2023", end_date: "Aug 2023",
location: "Remote", location: "San Francisco, CA",
tasks: ( tasks: (
[Developed a *FastAPI backend* to sync HubSpot and Airtable data with Google [Designed a conflict resolution algorithm for business smart tables, *reducing unrecoverable errors by 75%*],
Sheets via *AWS Lambda*], [Solely planned and shipped to *46 000+ enterprise users* a Google Sheets sync feature with HubSpot and Airtable by writing *AWS Lambda* functions in Python],
[Engineered a *heuristic algorithm* to guarantee *SQL* aliases referenced in [Productionised a service importing CSV/Excel attachments into DBs by expanding DB engine support by *6x*],
queries match the database schema], [Spearheaded the creation of backend testing infrastructure with *Pytest* to catch regressions and test new features across database engines with *90% code coverage*],
[Refactored the frontend to use *react-hook-form* to aggregate and validate user
input, improving DX],
[Built a #link("https://dropmail.dev")[service] for *validating and importing
CSV/Excel* files from customer emails into client databases],
), ),
) )
#work_entry( #work_entry(
"Backend Developer", "Backend Developer",
"Techyon", "Hack the North",
start_date: "Mar 2023", start_date: "Mar 2023",
end_date: "present", end_date: "present",
location: "Waterloo, ON", location: "Waterloo, ON",
tasks: ( tasks: (
[Dynamically generated user-specific *Apple Wallet* passes over *Apollo GraphQL* [Streamlined registration times by *80%* by generating *user-specific mobile ticket
Server to streamline check-in], passes* over *Apollo GraphQL*],
[Horizontally scaled the *Node.js* server to handle *1000+ concurrent users* with [Horizontally scaled the *Node.js* server to handle *1000+ concurrent users* with
*Redis* and *Kubernetes*], *Redis* and *Kubernetes*],
[Automated judge-to-hacker matching and scheduling with a custom algorithm based [Integrated backend *tracing* with *OpenTelemetry* and *Grafana* to monitor performance and trigger alerts],
on their preferences], [Slashed dev server reload time by *93%* by splitting parallelisable tasks across threads, pre-transpiling GraphQL resolvers, and profiling then cutting unnecessary work]
[Integrated *OpenTelemetry* and Grafana in a *Kubernetes* cluster to collect
traces and improve observability],
), ),
) )
] ]
@@ -99,28 +93,7 @@
#indent[ #indent[
#project( #project(
"Flashnote Flashcard Generator", "Comic Converter",
"https://github.com/potatoeggy/flashnote",
"Java, Android",
)
- Created an Android app to generate study flashcards from handwritten notes using *Google Cloud*
- Interfaced with GCP's Vision and NLP APIs to extract text and
keywords from images with *Retrofit* and *Gson*
#project(
"RecipeReady Recipe Aggregator",
"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 tagging system*
- Aggregated common ingredients heuristically to build a shopping list and a meal
plan for each week
#project(
"Mandown Comic Converter",
"https://github.com/potatoeggy/mandown", "https://github.com/potatoeggy/mandown",
"Python, Qt", "Python, Qt",
) )
@@ -134,24 +107,49 @@
tests* with 55% code coverage tests* with 55% code coverage
#project( #project(
"Primoprod Genshin Simulator", "Kobo Sync Server",
"https://github.com/potatoeggy/kobink",
"Rust, Axum",
)
- Developed an Axum backend to *automatically convert and sync* ebooks to a Kobo
eReader over the network
- *Reverse-engineered* the Kobo eReader Sync API to support updating ebook
metadata and covers
#project(
"Genshin Simulator",
"https://github.com/potatoeggy/primoprod", "https://github.com/potatoeggy/primoprod",
"Vue, TypeScript", "Vue, TypeScript",
) )
- Built an interactive, realistic, and beautiful game simulator with fluid - Built an realistic and beautiful *loot box simulator* with fluid animations
animations based off a popular game based off a popular game
- Ported the game to native desktop and mobile applications with *Capacitor*, *WebView*, and *Electron* - Reduced action latency by *90%* by lazily loading art assets at opportune times,
such as during cutscenes
// #project("Kobink — Kobo Sync Server", "https://github.com/potatoeggy/kobink", "Rust, Axum, Postgres") #project(
// - ??? something here (reverse engineering) "RecipeReady",
// - ??? something here (synchronisation and DB, HTTP headers) "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
// #project("Arch Linux Server", none, "Linux, nginx, systemd")
// - Created a *self-hosted CI/CD pipeline* with *Gitea* to automatically deploy
// personal projects behind *nginx*
// - Set up *Jellyfin* for media streaming, a *Minecraft* server, *Calibre* for ebook
// syncing, and other services
] ]
= Awards // = Awards
#show link: underline // #show link: underline
- Winner of the #link("https://github.com/anyuan-chen/resketch")[EdTech] prize at // - Winner of the #link("https://github.com/anyuan-chen/resketch")[EdTech] prize at
StormHacks 2022 from 350+ participants // StormHacks 2022 from 350+ participants
- Winner of the #link("https://github.com/anyuan-chen/perdiem")[IBM Open Source] prize // - Winner of the #link("https://github.com/anyuan-chen/perdiem")[IBM Open Source] prize
at YRHacks 2022 from 90+ participants // at YRHacks 2022 from 90+ participants

16
lib.typ
View File

@@ -9,7 +9,7 @@
#let BODY_FONT_SIZE = 10pt #let BODY_FONT_SIZE = 10pt
#let HEADING_FONT_SIZE = 1em #let HEADING_FONT_SIZE = 1em
#let TITLE_FONT_SIZE = 2em #let TITLE_FONT_SIZE = 2.25em
#let HEADING_LINE_GAP = 3mm #let HEADING_LINE_GAP = 3mm
#let BODY_LINE_HEIGHT = 0.85em #let BODY_LINE_HEIGHT = 0.85em
@@ -67,7 +67,11 @@
none none
} }
cv_entry(left_content: { cv_entry(left_content: {
text(1.1em)[*#role*] + "\n" + text[#emph[#company]] set par(leading: 0.75em)
text(1.1em)[*#role*]
"\n"
set strong(delta: SMALL_STRONG)
text[*#company*]
}, right_content: { }, right_content: {
[*#start_date -- #end_date*] [*#start_date -- #end_date*]
@@ -79,7 +83,11 @@
#let project(title, repo_link, tools) = { #let project(title, repo_link, tools) = {
set strong(delta: DEFAULT_STRONG) set strong(delta: DEFAULT_STRONG)
link(repo_link)[#text(1.1em)[*#title* #fa(github)]] + [ | _ #tools _ ] if repo_link != none {
link(repo_link)[#text(1.1em)[*#title* #fa(github)]] + [ | _ #tools _ ]
} else {
text(1.1em)[*#title*] + [ | _ #tools _ ]
}
} }
// Set name and contact data and format headings // Set name and contact data and format headings
@@ -96,7 +104,7 @@
let elements = for el in contact_data { let elements = for el in contact_data {
(link(el.link)[#{ el.service + " " + el.display }],) (link(el.link)[#{ el.service + " " + el.display }],)
} }
text(1.1em)[#elements.join(" | ")] text(1em)[#elements.join(" | ")]
} }
} }
] ]