Compare commits
	
		
			15 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 10889dba25 | ||
|  | 6bfc3273c0 | ||
|  | f0e9e96fe4 | ||
|  | baa386a39e | ||
|  | f9b8dd6b0e | ||
|  | d165a1b259 | ||
|  | 2cddfcbf6e | ||
|  | de8fb56d48 | ||
|  | 0f0ff6ba1f | ||
|  | 1591bdaba5 | ||
|  | 7d289c8757 | ||
|  | 2d4d0dd6d4 | ||
|  | 6e8763b88d | ||
|  | 08201c3406 | ||
|  | dd3d479a92 | 
| @@ -30,11 +30,12 @@ | |||||||
| = 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, Heroku, | ||||||
|   OpenTelemetry, GraphQL |   OpenTelemetry, GraphQL, Webpack | ||||||
| ] | ] | ||||||
|  |  | ||||||
| = Experience | = Experience | ||||||
| @@ -48,30 +49,30 @@ | |||||||
|     end_date: "Aug 2023", |     end_date: "Aug 2023", | ||||||
|     location: "Remote", |     location: "Remote", | ||||||
|     tasks: ( |     tasks: ( | ||||||
|       [Developed a *FastAPI backend* to sync HubSpot and Airtable data with Google |       [Engineered a database-specific *SQL IDE autocompletion tool* via a heuristic | ||||||
|         Sheets via *AWS Lambda*], |         algorithm to validate queries], | ||||||
|       [Engineered a *heuristic algorithm* to guarantee *SQL* aliases referenced in |       [Developed a service to sync HubSpot and Airtable data with Google Sheets via | ||||||
|         queries match the database schema], |         *AWS Lambda*], | ||||||
|       [Refactored the frontend to use *react-hook-form* to aggregate and validate user |       [Constructed dynamic forms in *react-hook-form* by generating questions from the | ||||||
|         input, improving DX], |         backend on-the-fly], | ||||||
|       [Built a #link("https://dropmail.dev")[service] for *validating and importing |       [Created testing infrastructure for the backend with *Pytest* to catch | ||||||
|         CSV/Excel* files from customer emails into client databases], |         regressions across database engines], | ||||||
|     ), |     ), | ||||||
|   ) |   ) | ||||||
|  |  | ||||||
|   #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 by dynamically generating *user-specific Apple Wallet | ||||||
|         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 |       [Automated judging scheduling by creating a *greedy algorithm* to match judges to | ||||||
|         on their preferences], |         project themes], | ||||||
|       [Integrated *OpenTelemetry* and Grafana in a *Kubernetes* cluster to collect |       [Integrated *OpenTelemetry* and Grafana in a *Kubernetes* cluster to collect | ||||||
|         traces and improve observability], |         traces and improve observability], | ||||||
|     ), |     ), | ||||||
| @@ -83,7 +84,7 @@ | |||||||
|  |  | ||||||
| #indent[ | #indent[ | ||||||
|   #project( |   #project( | ||||||
|     "Mandown Comic Converter", |     "Comic Downloader & Converter", | ||||||
|     "https://github.com/potatoeggy/mandown", |     "https://github.com/potatoeggy/mandown", | ||||||
|     "Python, Qt", |     "Python, Qt", | ||||||
|   ) |   ) | ||||||
| @@ -97,21 +98,27 @@ | |||||||
|     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 | ||||||
|   - Constructed an *extensible JSON data schema* to let the user dynamically switch |   - Reduced action latency by *90%* by lazily loading art assets at opportune times, | ||||||
|     between game versions |     such as during cutscenes | ||||||
|  |  | ||||||
|   // #project("Kobink — Kobo Sync Server", "https://github.com/potatoeggy/kobink", "Rust, Axum, Postgres") |  | ||||||
|   // - ??? something here (reverse engineering) |  | ||||||
|   // - ??? something here (synchronisation and DB, HTTP headers) |  | ||||||
|  |  | ||||||
|   #project( |   #project( | ||||||
|     "RecipeReady Recipe Aggregator", |     "RecipeReady", | ||||||
|     "https://github.com/vincentjguo/recipeready-server", |     "https://github.com/vincentjguo/recipeready-server", | ||||||
|     "Flutter, Selenium, FastAPI, Android", |     "Flutter, Selenium, FastAPI, Android", | ||||||
|   ) |   ) | ||||||
| @@ -122,15 +129,11 @@ | |||||||
|   - Aggregated common ingredients heuristically to build a shopping list and a meal |   - Aggregated common ingredients heuristically to build a shopping list and a meal | ||||||
|     plan for each week |     plan for each week | ||||||
|  |  | ||||||
|   #project( |   // #project("Arch Linux Server", none, "Linux, nginx, systemd") | ||||||
|     "Box Box Revolution", |   // - Created a *self-hosted CI/CD pipeline* with *Gitea* to automatically deploy | ||||||
|     "https://github.com/potatoeggy/boxboxrevolution", |   //   personal projects behind *nginx* | ||||||
|     "Rust, STM32", |   // - Set up *Jellyfin* for media streaming, a *Minecraft* server, *Calibre* for ebook | ||||||
|   ) |   //   syncing, and other services | ||||||
|   - Created a rhythm game to detect punches with an ultrasonic sensor in line wth |  | ||||||
|     notes of popular songs |  | ||||||
|   - Developed firmware to measure from an ultrasonic sensor, tone a buzzer, and show |  | ||||||
|     scrolling notes on an LCD |  | ||||||
| ] | ] | ||||||
|  |  | ||||||
| = Awards | = Awards | ||||||
| @@ -149,7 +152,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 | ||||||
|   | |||||||
							
								
								
									
										10
									
								
								lib.typ
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								lib.typ
									
									
									
									
									
								
							| @@ -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) | ||||||
|  |   if repo_link != none { | ||||||
|     link(repo_link)[#text(1.1em)[*#title* #fa(github)]] + [ | _ #tools _ ] |     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 | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user