Compare commits
	
		
			3 Commits
		
	
	
		
			91102c2375
			...
			v4.3.1
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 94ff3febe8 | ||
|  | 4e79e361e5 | ||
|  | e073191d8c | 
| @@ -3,8 +3,8 @@ | |||||||
|  |  | ||||||
| #let education = indent[ | #let education = indent[ | ||||||
|   #work_entry( |   #work_entry( | ||||||
|     "B.A.Sc. in Computer Engineering", |  | ||||||
|     "University of Waterloo", |     "University of Waterloo", | ||||||
|  |     "B.A.Sc. in Computer Engineering, Honours", | ||||||
|     start_date: "Sep 2022", |     start_date: "Sep 2022", | ||||||
|     end_date: "Apr 2027", |     end_date: "Apr 2027", | ||||||
|     location: "Waterloo, ON", |     location: "Waterloo, ON", | ||||||
| @@ -40,12 +40,12 @@ | |||||||
|     location: "New York, NY", |     location: "New York, NY", | ||||||
|     tools: "Rust, TypeScript, Solidity, React, GraphQL", |     tools: "Rust, TypeScript, Solidity, React, GraphQL", | ||||||
|     tasks: ( |     tasks: ( | ||||||
|       [Created tooling to build and deploy new customer landing portals based off of |       [Created tooling to construct and deploy new customer landing portals based off | ||||||
|         Figma designs with Vercel's API], |         of Figma designs with Vercel's API], | ||||||
|       [Developed a new external REST API for customers who wanted to access their token |       [Developed a new external REST API for customers who wanted to access their token | ||||||
|         data programmatically], // termination display (FE), external API for customers not using our platform (BE) |         data programmatically], // termination display (FE), external API for customers not using our platform (BE) | ||||||
|       [Wrote and audited smart contracts on Solana blockchain to add claim fees to our |       [Wrote and audited smart contracts on the Solana blockchain to add claim fees to | ||||||
|         token vesting platform], |         our token vesting platform], | ||||||
|     ), |     ), | ||||||
|   ) |   ) | ||||||
|  |  | ||||||
| @@ -62,9 +62,10 @@ | |||||||
|         documents with S3 and Textract], |         documents with S3 and Textract], | ||||||
|       [Championed and shipped features for *SOC 2 security compliance*, including |       [Championed and shipped features for *SOC 2 security compliance*, including | ||||||
|         *role-based permissions with JWTs* in Spring Boot, alert logging with |         *role-based permissions with JWTs* in Spring Boot, alert logging with | ||||||
|         CloudWatch, and stronger privacy controls for user data], |         CloudWatch, and strong privacy controls for user data], | ||||||
|       [Reduced dashboard load time by 38% by implementing a stale-while-revalidate |       [Reduced dashboard load time by 38% by implementing a stale-while-revalidate | ||||||
|         caching strategy], |         caching strategy], | ||||||
|  |       // [?? Calendly integration + OAuth], | ||||||
|       [Created a parallel *CI/CD system from scratch* with Terraform and Jenkins to |       [Created a parallel *CI/CD system from scratch* with Terraform and Jenkins to | ||||||
|         automatically deploy AWS Lambdas], // BE-infra only, FE ver is admin dashboard |         automatically deploy AWS Lambdas], // BE-infra only, FE ver is admin dashboard | ||||||
|     ), |     ), | ||||||
| @@ -82,7 +83,7 @@ | |||||||
|       [Architected a data query builder and executor engine for customers to visualise |       [Architected a data query builder and executor engine for customers to visualise | ||||||
|         their data warehouses by custom-tailoring forms on-the-fly, supporting complex |         their data warehouses by custom-tailoring forms on-the-fly, supporting complex | ||||||
|         nested logic for 3000+ enterprise users across 8 database types], // |         nested logic for 3000+ enterprise users across 8 database types], // | ||||||
|       [Shipped an *LSP server for our custom query DSL*, including user-specific |       [Shipped an *LSP server for our custom query language*, including user-specific | ||||||
|         autocomplete and syntax highlighting], |         autocomplete and syntax highlighting], | ||||||
|       [Developed a serverless microservice to asynchronously ingest email attachments |       [Developed a serverless microservice to asynchronously ingest email attachments | ||||||
|         directly into ETL pipelines], |         directly into ETL pipelines], | ||||||
| @@ -103,12 +104,12 @@ | |||||||
|     tasks: ( |     tasks: ( | ||||||
|       [Streamlined event check-in times for *1900+* guests by generating scannable |       [Streamlined event check-in times for *1900+* guests by generating scannable | ||||||
|         mobile wallet passes over Express], |         mobile wallet passes over Express], | ||||||
|       [Overhauled CI/CD pipelines, speeding up builds by 35% by parallelising testing |       [Overhauled CI/CD pipelines, speeding up builds by *35%* by parallelising testing | ||||||
|         and type checking], |         and type checking], | ||||||
|       [Introduced backend tracing with OpenTelemetry and Grafana to profile performance |       [*Introduced backend tracing* with OpenTelemetry and Grafana to profile | ||||||
|         issues in production], |         performance issues in production], | ||||||
|       [Resolved load spike crashes in prod by caching queries via *Redis* and |       [*Resolved load spike crashes* in prod by caching queries via Redis and | ||||||
|         horizontally scaling services on *Kubernetes*], |         horizontally scaling services on Kubernetes], | ||||||
|     ), |     ), | ||||||
|   ) |   ) | ||||||
| ] | ] | ||||||
| @@ -143,6 +144,18 @@ | |||||||
|     ), |     ), | ||||||
|   ) |   ) | ||||||
|  |  | ||||||
|  |   #project( | ||||||
|  |     "Arch Linux Server", | ||||||
|  |     "Linux, Docker, nginx, systemd", | ||||||
|  |     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 | ||||||
|  |     ), | ||||||
|  |   ) | ||||||
|  |  | ||||||
|   // #project( |   // #project( | ||||||
|   //   "Genshin Rewards Simulator", |   //   "Genshin Rewards Simulator", | ||||||
|   //   "Vue, TypeScript", |   //   "Vue, TypeScript", | ||||||
| @@ -181,15 +194,4 @@ | |||||||
|   // - 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( |  | ||||||
|     "Arch Linux Server (\"hwaboon\")", |  | ||||||
|     "Linux, Docker, nginx, systemd", |  | ||||||
|     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 |  | ||||||
|     ), |  | ||||||
|   ) |  | ||||||
| ] | ] | ||||||
							
								
								
									
										33
									
								
								lib/lib.typ
									
									
									
									
									
								
							
							
						
						
									
										33
									
								
								lib/lib.typ
									
									
									
									
									
								
							| @@ -1,27 +1,30 @@ | |||||||
| #import "fontawesome.typ": github, fa, link-icon | #import "fontawesome.typ": github, fa, link-icon | ||||||
|  |  | ||||||
| #let DEFAULT_STRONG = 300; | #let DEFAULT_STRONG = 300; | ||||||
| #let SMALL_STRONG = 200; | #let SMALL_STRONG = 300; | ||||||
|  |  | ||||||
| #let TITLE_FONT = "Bitter" | #let TITLE_FONT = "Bitter" | ||||||
| #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.75pt | #let BODY_FONT_SIZE = 9.75pt | ||||||
| #let HEADING_FONT_SIZE = 0.95em | #let HEADING_FONT_SIZE = 0.9em | ||||||
| #let TITLE_FONT_SIZE = 2em | #let TITLE_FONT_SIZE = 2em | ||||||
|  |  | ||||||
| #let HEADING_LINE_GAP = 3mm | #let HEADING_LINE_GAP = 3mm | ||||||
| #let BODY_LINE_HEIGHT = 0.75em | #let HEADING_ABOVE_GAP = 1em | ||||||
|  | #let HEADING_BELOW_GAP = 0.75em | ||||||
|  |  | ||||||
| #let HEADING_DETAILS_LIST_SPACING = 0.9em | #let BODY_LINE_HEIGHT = 0.7em | ||||||
|  |  | ||||||
|  | #let HEADING_DETAILS_LIST_SPACING = 1em | ||||||
| #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.9em | ||||||
| #let DETAILS_LIST_INDENT = 1.5em | #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.4in, top: 0.3in, left: 0.3in, bottom: 0.4in) | ||||||
|  |  | ||||||
| // Format locations. | // Format locations. | ||||||
| #let format_location(location) = { | #let format_location(location) = { | ||||||
| @@ -49,7 +52,7 @@ | |||||||
|     { |     { | ||||||
|       set strong(delta: SMALL_STRONG) |       set strong(delta: SMALL_STRONG) | ||||||
|       show link: underline |       show link: underline | ||||||
|       list(tight: false, spacing: DETAILS_LIST_SPACING, marker: [•], ..details) |       list(tight: false, spacing: DETAILS_LIST_SPACING, marker: [*•*], ..details) | ||||||
|     }, |     }, | ||||||
|   ) |   ) | ||||||
| } | } | ||||||
| @@ -66,24 +69,22 @@ | |||||||
|   company_link: none, |   company_link: none, | ||||||
| ) = { | ) = { | ||||||
|   cv_entry(left_content: { |   cv_entry(left_content: { | ||||||
|     set par(leading: 0.75em) |     text(1.05em)[*#role*] | ||||||
|  |  | ||||||
|     text(1.1em)[*#role*] |  | ||||||
|  |  | ||||||
|     if tools != none { |     if tools != none { | ||||||
|       text[ | _ #tools _ ] |       // text[ | _ #tools _ ] | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     "\n" |     "\n" | ||||||
|     set strong(delta: SMALL_STRONG) |     set strong(delta: SMALL_STRONG) | ||||||
|  |  | ||||||
|     if company_link == none { |     if company_link == none { | ||||||
|       [*#company*] |       [_#company _] | ||||||
|     } else { |     } else { | ||||||
|       [#link(company_link)[*#company*]] |       [#link(company_link)[_#company _]] | ||||||
|     } |     } | ||||||
|   }, right_content: { |   }, right_content: { | ||||||
|     [*#start_date -- #end_date*] |     [#start_date -- #end_date] | ||||||
|  |  | ||||||
|     if location != none { |     if location != none { | ||||||
|       "\n" + format_location(location) |       "\n" + format_location(location) | ||||||
| @@ -140,7 +141,7 @@ | |||||||
|       ) |       ) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     set block(above: 0.9em, below: 0.75em) |     set block(above: HEADING_ABOVE_GAP, below: HEADING_BELOW_GAP) | ||||||
|     set text(size: HEADING_FONT_SIZE, fill: color, font: HEADING_FONT) |     set text(size: HEADING_FONT_SIZE, fill: color, font: HEADING_FONT) | ||||||
|     stack( |     stack( | ||||||
|       dir: ltr, |       dir: ltr, | ||||||
| @@ -149,6 +150,8 @@ | |||||||
|       box(height: 2pt, fill: color, colored_line(title)), |       box(height: 2pt, fill: color, colored_line(title)), | ||||||
|     ) |     ) | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  |   set strong(delta: SMALL_STRONG) | ||||||
|   doc |   doc | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| #import "fontawesome.typ": fa, globe, github, linkedin, envelope | #import "fontawesome.typ": fa, globe, github, linkedin, envelope | ||||||
| #import "lib.typ": template, work_entry, project, indent, SMALL_STRONG, DEFAULT_STRONG, render_contact_data | #import "lib.typ": template, work_entry, project, indent, SMALL_STRONG, DEFAULT_STRONG, render_contact_data | ||||||
|  |  | ||||||
| #let SEQUENCE = ("skills", "content", "education") | #let SEQUENCE = ("content", "skills", "education") | ||||||
|  |  | ||||||
| // orange!! | // orange!! | ||||||
| #let color = blue // rgb("#ff983e") | #let color = blue // rgb("#ff983e") | ||||||
|   | |||||||
							
								
								
									
										42
									
								
								systems.typ
									
									
									
									
									
								
							
							
						
						
									
										42
									
								
								systems.typ
									
									
									
									
									
								
							| @@ -3,8 +3,8 @@ | |||||||
|  |  | ||||||
| #let education = indent[ | #let education = indent[ | ||||||
|   #work_entry( |   #work_entry( | ||||||
|     "B.A.Sc. in Computer Engineering", |  | ||||||
|     "University of Waterloo", |     "University of Waterloo", | ||||||
|  |     "B.A.Sc. in Computer Engineering, Honours", | ||||||
|     start_date: "Sep 2022", |     start_date: "Sep 2022", | ||||||
|     end_date: "Apr 2027", |     end_date: "Apr 2027", | ||||||
|     location: "Waterloo, ON", |     location: "Waterloo, ON", | ||||||
| @@ -40,12 +40,12 @@ | |||||||
|     location: "New York, NY", |     location: "New York, NY", | ||||||
|     tools: "Rust, TypeScript, Solidity, React, GraphQL", |     tools: "Rust, TypeScript, Solidity, React, GraphQL", | ||||||
|     tasks: ( |     tasks: ( | ||||||
|       [Created tooling to automate building and deploying new customer landing portals |       [Created tooling to automate constructing and deploying new customer landing | ||||||
|         based off of Figma designs], |         portals based off of Figma designs], | ||||||
|       [Developed a new external REST API for customers who wanted to access their token |       [Developed a new external REST API for customers who wanted to access their token | ||||||
|         data programmatically], // termination display (FE), external API for customers not using our platform (BE) |         data programmatically], // termination display (FE), external API for customers not using our platform (BE) | ||||||
|       [Wrote and audited smart contracts on Solana blockchain to add claim fees to our |       [Wrote and audited smart contracts on the Solana blockchain to add claim fees to | ||||||
|         token vesting platform], |         our token vesting platform], | ||||||
|     ), |     ), | ||||||
|   ) |   ) | ||||||
|  |  | ||||||
| @@ -62,7 +62,7 @@ | |||||||
|         documents with S3 and Textract], |         documents with S3 and Textract], | ||||||
|       [Championed and shipped features for *SOC 2 security compliance*, including |       [Championed and shipped features for *SOC 2 security compliance*, including | ||||||
|         *role-based permissions with JWTs* in Spring Boot, alert logging with |         *role-based permissions with JWTs* in Spring Boot, alert logging with | ||||||
|         CloudWatch, and stronger privacy controls for user data], |         CloudWatch, and strong privacy controls for user data], | ||||||
|       [Reduced dashboard load time by *38%* by implementing a stale-while-revalidate |       [Reduced dashboard load time by *38%* by implementing a stale-while-revalidate | ||||||
|         caching strategy], |         caching strategy], | ||||||
|       [Created a parallel *CI/CD system from scratch* with Terraform and Jenkins to |       [Created a parallel *CI/CD system from scratch* with Terraform and Jenkins to | ||||||
| @@ -101,7 +101,7 @@ | |||||||
|     location: "Waterloo, ON", |     location: "Waterloo, ON", | ||||||
|     tools: "TypeScript, Express, Postgres, Kubernetes", |     tools: "TypeScript, Express, Postgres, Kubernetes", | ||||||
|     tasks: ( |     tasks: ( | ||||||
|       [Overhauled CI/CD pipelines, speeding up builds by 35% by parallelising testing |       [Overhauled CI/CD pipelines, speeding up builds by *35%* by parallelising testing | ||||||
|         and type checking], |         and type checking], | ||||||
|       [Introduced backend tracing with OpenTelemetry and Grafana to profile performance |       [Introduced backend tracing with OpenTelemetry and Grafana to profile performance | ||||||
|         issues in production], |         issues in production], | ||||||
| @@ -147,23 +147,35 @@ | |||||||
|     "PNG Crawler", |     "PNG Crawler", | ||||||
|     "C++", |     "C++", | ||||||
|     tasks: ( |     tasks: ( | ||||||
|       [Developed a web crawler to download and parse PNG files from the internet with |       [Developed a web crawler and a custom PNG validator to download and parse PNGs | ||||||
|         *libcurl* and *libpng*], |         from the internet with *libcurl*], | ||||||
|       [Optimised the crawler to download and process images concurrently with *POSIX |       [Optimised the crawler to download and process images concurrently with *POSIX | ||||||
|         threads*], |         threads* and curl_multi], | ||||||
|     ), |     ), | ||||||
|   ) |   ) | ||||||
|  |  | ||||||
|   #project( |   #project( | ||||||
|     "Kobink", |     "Arch Linux Server", | ||||||
|     "Rust, Axum", |     "Linux, Docker, nginx, systemd", | ||||||
|     repo_link: "https://github.com/potatoeggy/kobink", |     demo_link: "https://eggworld.me", | ||||||
|     tasks: ( |     tasks: ( | ||||||
|       [Built a backend to sync custom ebook files to Kobos by reverse-engineering and |       [Created a *self-hosted CI/CD pipeline* with *Gitea* to automatically deploy | ||||||
|         mimicking the Kobo Sync API], |         personal projects behind *nginx*], // TODO | ||||||
|  |       [Managed services with *Docker* and *systemd* to simplify deployment and resource | ||||||
|  |         constrainment], // TODO | ||||||
|     ), |     ), | ||||||
|   ) |   ) | ||||||
|  |  | ||||||
|  |   // #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( |   // #project( | ||||||
|   //   "Kobo Sync Server", |   //   "Kobo Sync Server", | ||||||
|   //   "Rust, Axum", |   //   "Rust, Axum", | ||||||
|   | |||||||
| @@ -3,8 +3,8 @@ | |||||||
|  |  | ||||||
| #let education = indent[ | #let education = indent[ | ||||||
|   #work_entry( |   #work_entry( | ||||||
|     "B.A.Sc. in Computer Engineering", |  | ||||||
|     "University of Waterloo", |     "University of Waterloo", | ||||||
|  |     "B.A.Sc. in Computer Engineering, Honours", | ||||||
|     start_date: "Sep 2022", |     start_date: "Sep 2022", | ||||||
|     end_date: "Apr 2027", |     end_date: "Apr 2027", | ||||||
|     location: "Waterloo, ON", |     location: "Waterloo, ON", | ||||||
| @@ -38,8 +38,8 @@ | |||||||
|     location: "New York, NY", |     location: "New York, NY", | ||||||
|     tools: "Rust, TypeScript, React, GraphQL, Figma", |     tools: "Rust, TypeScript, React, GraphQL, Figma", | ||||||
|     tasks: ( |     tasks: ( | ||||||
|       [Created tooling to build and deploy new customer landing portals based off of |       [Created tooling to construct and deploy new customer landing portals based off | ||||||
|         Figma designs with Vercel's API], |         of Figma designs with Vercel's API], | ||||||
|       [Developed a new external REST API for customers who wanted to access their token |       [Developed a new external REST API for customers who wanted to access their token | ||||||
|         data programmatically], |         data programmatically], | ||||||
|       [Revamped error propagation to support returning multiple errors per request, |       [Revamped error propagation to support returning multiple errors per request, | ||||||
| @@ -60,7 +60,7 @@ | |||||||
|         documents with S3 and Textract], |         documents with S3 and Textract], | ||||||
|       [Championed and shipped features for *SOC 2 security compliance*, including |       [Championed and shipped features for *SOC 2 security compliance*, including | ||||||
|         *role-based permissions with JWTs* in Spring Boot, alert logging with |         *role-based permissions with JWTs* in Spring Boot, alert logging with | ||||||
|         CloudWatch, and stronger privacy controls for user data], |         CloudWatch, and strong privacy controls for user data], | ||||||
|       [Reduced dashboard load time by 38% by implementing a stale-while-revalidate |       [Reduced dashboard load time by 38% by implementing a stale-while-revalidate | ||||||
|         caching strategy], |         caching strategy], | ||||||
|     ), |     ), | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user