Skip to content
View harukiki97's full-sized avatar

Block or report harukiki97

Block user

Prevent this user from interacting with your repositories and sending you notifications. Learn more about blocking users.

You must be logged in to block users.

Maximum 250 characters. Please don’t include any personal information such as legal names or email addresses. Markdown is supported. This note will only be visible to you.
Report abuse

Contact GitHub support about this user’s behavior. Learn more about reporting abuse.

Report abuse
harukiki97/README.md

KIKI | Security-minded Full-stack Developer

WebAssembly runtime security, browser engine bug analysis, and full-stack product development.

WebAssembly V8 C++ React Spring Boot

Hello, I am Jinwoo Han, a developer focused on WebAssembly runtime security, browser engine bug hunting, compiler optimization bugs, and full-stack product development.

I find and report low-level bugs where small implementation assumptions become security or correctness impact: validator soundness gaps, runtime invariants, sanitizer findings, compiler semantic divergence, and upstream-ready vulnerability reports. I also build user-facing web products with React, TypeScript, Spring Boot, and cloud infrastructure.

Currently

  • Hyundai AutoEver Mobility SW School, 3rd cohort, in progress through June 2026
  • Researching WebAssembly runtime and browser engine security
  • Open to opportunities: security engineer and full-stack developer roles

Highlights

  • Discovered and responsibly reported a WasmEdge validator soundness vulnerability; upstream PR and regression tests were merged, and the GHSA/CVE process is in progress.
  • Discovered a V8 Turboshaft Wasm SIMD miscompilation and reported it through Google VRP; the fix CL landed upstream, and reward review is in progress.
  • Built PINT, a photo location and filter-sharing platform, focusing on masonry feed UX, infinite scrolling, SPA auth UX, and frontend state synchronization.

Featured Work Summary

Project Summary
WasmEdge Validator Soundness Vulnerability Discovered a typed function reference validation gap in WasmEdge, responsibly reported the issue, and demonstrated malformed Wasm module acceptance, runtime invariant breakage, and host-side heap OOB write. Upstream fix and regression tests were merged; GHSA/CVE process is in progress.
V8 Turboshaft Wasm SIMD Compiler Bug Discovered an ARM64 optimized-tier miscompilation in V8 Turboshaft's Wasm SIMD optimizer and reported it through Google VRP. The upstream V8 fix CL landed with a regression test; reward review is in progress.
Leviathan Engine Patent-pending security architecture that tracks sensitive bytes in WebAssembly linear memory and deterministically overwrites exact allocation ranges.
PINT Photo location and filter-sharing platform. Frontend work included masonry feed behavior, interaction design, SPA auth UX, and team collaboration.

Visual Evidence

WasmEdge Vulnerability Evidence

I discovered a validator soundness issue in WasmEdge involving active element segments with typed function references. On the vulnerable revision, my targeted malformed module passed validation and reached executor paths. Under ASan, it triggered a host-process ValueStack heap OOB write. On the patched tree, the same malformed path is blocked with IndirectCallTypeMismatch, showing fail-closed behavior.

WasmEdge reproducer evidence

  • Upstream fix: WasmEdge PR #4814
  • Status: upstream fix merged, GHSA/CVE advisory process in progress
  • Key point: the observed memory-safety impact was in the executor's host-side ValueStack, not guest linear memory

V8 Turboshaft Bug Evidence

I discovered an ARM64 miscompilation in V8 Turboshaft's Wasm SIMD shuffle reducer and reported it through Google VRP. The root cause was demanded-byte analysis underestimating required input bytes when demand propagated through a low-half widening operation.

V8 reproducer evidence

Key V8 divergence signals
branch baseline:   0x00001111
branch optimized:  0x00003333

index baseline:    0x00001111
index optimized:   0x00003333

write baseline:    mem[1] = 0xaa
write optimized:   mem[3] = 0xaa

read baseline:     0x00000001
read optimized:    0x00000042

trap baseline:     returns normally
trap optimized:    RuntimeError: memory access out of bounds

My control run with --nowasm-simd-opt does not diverge, isolating the issue to the Wasm SIMD optimization path.

PINT Masonry Feed Evidence

PINT is a photo-first community platform for sharing where a photo was taken and how it was edited. The screenshot below shows a masonry feed built from real post preview data, including hover metadata, author/location/camera information, and like feedback UI.

PINT masonry feed evidence

  • Frontend role: React 19, TypeScript, Vite, Zustand, Tailwind CSS, GSAP
  • Contributions: Masonry-style feed, infinite scrolling, image preload and animation flow, feed card hover interactions, like micro-interactions, profile state synchronization
  • Links: Frontend, Backend, Live Demo

What I Care About

  • Validation gaps that turn into memory-safety failures at runtime
  • Whether compiler optimizations preserve source-level semantics
  • Reporting security findings with reproducible evidence rather than overstated impact
  • Connecting low-level analysis to user-facing product quality

Technical Focus

Security / Runtime
WebAssembly, WasmEdge, V8, Turboshaft, runtime validation, compiler correctness,
ASan, UBSan, malformed module construction, responsible disclosure

Frontend
React, TypeScript, Vite, Zustand, Tailwind CSS, GSAP, SPA authentication UX,
photo-first interaction design

Backend / Infra
Java, Spring Boot, Spring Security, PostgreSQL, Redis, AWS S3, EC2, Nginx,
Docker, Vercel, session and CSRF-based authentication

Contact

  • Email: qwejinoohan@gmail.com
  • GitHub: @harukiki97
  • LinkedIn: Jinwoo Han
  • Open to opportunities: security engineer and full-stack developer roles
  • Main keywords: WebAssembly, V8, WasmEdge, Runtime Security, Compiler Correctness, React, TypeScript, Spring Boot

Popular repositories Loading

  1. harukiki97 harukiki97 Public

  2. v8-wasm-shuffle-reducer-miscompilation v8-wasm-shuffle-reducer-miscompilation Public

    Portfolio write-up and reproducers for a V8 WebAssembly SIMD shuffle reducer miscompilation fixed upstream.

    HTML

  3. wasmedge-validator-soundness-case-study wasmedge-validator-soundness-case-study Public

    WasmEdge validator soundness bug security research case study

  4. quantcheck-mobile quantcheck-mobile Public

    QuantCheck Android native app built with Kotlin and Jetpack Compose.

    Kotlin

  5. quantcheck-backend quantcheck-backend Public

    QuantCheck Kotlin Spring Boot backend deployed on GCP Cloud Run.

    Kotlin