About me
I’m a third-year Computer Science student at Purdue University. I enjoy writing software, managing servers, and learning about new technologies. I’m a big fan of open-source software and self-hosting. I enjoy lower-level development, systems/network programming, and back-end development. Lately, I’ve found system design and architecture to be quite interesting, and am actively learning more about that field.
Outside of the digital world, I’m an Eagle Scout, an amateur radio operator, a former gymnastics coach, and a pole vaulter. I also love plants! I have a small collection of houseplants as well as a bonsai tree in my dorm room.
I've formerly worked as a software engineer intern at Theom and a head teaching assistant for Purdue’s CS 240 course, Programming in C. See my resume for more about my experience.
Languages & Tools
These are many of the languages, tools, frameworks, etc. that I have experience with. I’ve used all of these in my projects and/or coursework, though some I have more experience with than others. There are several tools & languages that I used to use many years ago, but I don’t list them here because I am no longer confident in my ability to use them effectively.
The lists below are in no particular order.
Languages
Tools
Projects
c2e

c2e is a program that translates C (programming language) variable/type declarations into English explanations of the declarations.
c2e comes in two forms: it runs as a CLI program and as a website. Both are powered by a common library containing the core functionality, written in Rust. The library is compiled to WebAssembly (WASM) for the website and runs fully client-side, allowing it to be immediately responsive on every keystroke.
Skills/concepts applied
- Rust programming
- C programming
- Unit testing
- Code coverage
- WebAssembly (WASM)
Userspace network stack (in progress)

To learn more about the inner workings of the IPv4 and TCP protocols, I decided to go about implementing both myself from scratch.
The userspace network stack (“unet” for short) uses TAP devices to bypass the Linux kernel's handling of network packets. Unet reads the raw IP packets straight from the kernel and processes them itself. It manages things like packet fragmentation, reassembly, and (once finished) all aspects of the TCP protocol, such as retransmission and congestion control. Unet also makes use of concepts like zero-copy programming (avoiding making copies of data) to ensure its performance and robustness.
Unet is currently a (slow) work in progress. As of the time of writing this, I've implemented IPv4 packet reassembly and have begun work on the TCP implementation.
Skills/concepts applied
- Rust programming
- Unit testing
- Zero-copy data structures
- Linux kernel
- Network programming
Crashlog

Crashlog is a library that catches panics in Rust programs, logs relevant information, and provides the user with information on how to report the crash.
Crashlog promotes privacy by allowing programs to get anonoymized crash reports from users without relying on automatic data collection. It also provides users with a better interface, as they get a friendly explanation of what went wrong without having to decode a sometimes-cryptic panic message.
It originally started as a piece of Westwood, but was generalized and split off into a library usable by anyone.
Skills/concepts applied
- Rust programming
- Unit testing
- Continuous integration
- Open-source development
Westwood (in progress)

While taking and now working as the head developer for Purdue's CS 240: Programming in C course, I've run into numerous issues with the current linter provided by the course, so I decided to write a (hopefully) better one!
Westwood is a C source code linter, specifically built to enforce CS 240's code standard. It's written in Rust and uses the Tree-sitter parser library to handle parsing, and the codespan-reporting library to handle output formatting.
While still under development, my goal is to complete Westwood by the start of the Fall 2025 semester and open-source the project.
Skills/concepts applied
- C programming
- Rust programming
- Unit testing
- Continuous integration
- Open-source development
Home server

Over the past few years, I have experimented with self-hosting several services, using a variety of hardware. But when the laptop I was using as a server died, I realized I needed a more reproducible and maintainable setup.
This summer (2024), I dove into learning Ansible so I could create a fully-reproducible server deployment. Ansible is an infrastructure-as-code tool, which allows me to define the desired state of my server in a set of YAML files with some custom modules written in Python. Over the span of a few months, I wrote a playbook that installs and configures all the services I need for my home server.
This allows me to not only set up the server quickly, but I also track the entire server configuration in a single Git repository, including details such as packages installed, firewall rules, and much more. This makes it easy to recover from inevitable mistakes or hardware failures.
The playbook is hosted in a GitHub repository with an automated CI pipeline that runs the playbook in a virtual machine every time I push a commit. This ensures that the playbook will always work properly on a fresh installed of Debian or Ubuntu Linux.
The server runs several services in Docker containers, all served behind a Traefik reverse proxy, complete with TLS certificates and domain names. The services include monitoring and observability tools such as Grafana, Prometheus, and Loki, so I can keep an eye on the server’s health and performance. I even get alerts sent to my email when unusual events occur!
Skills/concepts applied
- Ansible
- Infrastructure as code
- Monitoring & observability
- Docker containerization
- Linux system administration
- Continuous Integration testing
CIter: Rust-style iterators for C

One of the amazing features of Rust is its powerful iterator system. It allows you to chain transformations on collections of data in a way that is both efficient and easy to write. I wanted to bring this power to C, so I wrote CIter.
CIter implements the most important parts of Rust’s iterator system, including nearly all transformations. It supports double-ended iterators, fixed-size iterators, and even iterators with known but non-exact size bounds.
This library is one of many smaller open-source projects I’ve worked on. The main goal was practice for myself, but I also made Citer available to others who might find it useful. To ensure its quality, I set up a continuous integration pipeline which tests the code on each commit.
Skills/concepts applied
- C programming
- Rust programming
- Continuous Integration testing
- Open-source software
Raspberry Pi backup system for classrooms

In high school, my computer science teacher used a classroom set of Raspberry Pi computers to teach programming. Raspberry Pis’ SD cards are not the most reliable, and that combined with students’ unfamiliarity with Linux led to lots of accidental data loss.
To solve this, I built a software system which runs on every Raspberry Pi in the room, and automatically backs up all student data at the end of each class period and school day. The backups are sent to a central server (also a Raspberry Pi), which deduplicates and compresses the data to save space.
The system has several key features which make it suitable for classroom use: it is fully automated, can be installed on a Pi using a single command, and allows the teacher to configure the entire system using a single configuration file. As an added bonus, this configuration file can be used to run custom shell scripts on all the nodes in the classroom. This makes it easy to, for example, install new software for all students, without having to manually perform the installation process 30 times.
I encountered many challenges when building this system. For one, I don’t control the school’s network infrastructure, so I couldn’t hard-code IP addresses. Instead, I had to ensure that mDNS responders were set up on all nodes so they could discover each other automatically. Another issue was the thundering herd problem: having all nodes back up at the end of each class period would overload the backup server, so I had to add randomized offsets to the backup times to spread out the load. Several other problems, such as security, are laid out in the write-up linked above.
Skills/concepts applied
- Python programming
- Linux/systemd service scheduling
- Data deduplication & compression
- Thundering herd problem
- Incremental backups
- Zero-configuration networking
TI Wordle
What do you do when you’re bored in math class, you like programming in C, and Wordle just went viral? Duh! You write a Wordle clone for your calculator so you can play it in class. Okay maybe you wouldn’t do that, but I did.
This project opened up a new side of C programming for me: embedded systems. On the TI-84,
				you don’t have the standard C library functions, so you can’t just printf() text to the screen or even dynamically allocate memory. But even more importantly, the calculator
				only has a few kilobytes of both RAM and storage, so I had to be very careful with how I stored
				data in my program.
Because of the storage limitations, I had to get creative. Instead of using all 12,986 allowed Wordle words, I opted to use just the subset of 2,309 words which can appear as answers. This strays a bit from the original Wordle game, but it was a necessary trade-off to fit the game on the calculator.
Skills/concepts applied
- C programming
- Embedded systems programming
vnStat-web

vnStat-web is a web-based interface for the vnStat network traffic monitoring tool. It allows you to view your server’s network usage through a convenient web interface, rather than vnStat’s built-in command-line interface.
I created this project in 2021, before I was aware of tools like Prometheus & Grafana, which I now use to monitor my servers’ network traffic. However, vnStat-web is still a useful tool and it still runs on kasad.com. Additionally, the GitHub repository has been “starred” by several people, which suggests that the tool is being used by others as well.
vnStat-web is a fairly small project. It’s written as a static HTML/CSS/JS site, with a single API endpoint written in PHP to fetch the data. That PHP script uses vnStat’s JSON API to get the necessary data about the server it’s running on. It then filters & transforms that data before returning it to the frontend, where it is displayed using the Chart.js library.
Skills/concepts applied
- Web development
- PHP programming
- JavaScript programming
- Open-source software
kasad.com

neofetch command run on the kasad.com server.
			kasad.com is a Debian server I’ve been running since 2020. It’s a very low-spec VPS, but it still hosts my website (the one you’re reading now), plus a variety of services for my personal use.
The most difficult one to set up by far was the mail server. It requires configuring SMTP, IMAP, DMARC, SPF, DKIM, DNS, spam filtering, authentication, mail aliasing/forwarding, and more in order to meet the stringent anti-spam requirements of other mail servers like Google’s Gmail. I spent several months learning about the nitty-gritty details of email protocols, and despite the challenges, I now have my very own self-hosted email server. You can reach me at kian@kasad.com!
I first booted up the kasad.com server in 2020, and I’ve been slowly building it up ever since. Most recently, I set up metrics collection & exporting, allowing me to use the Grafana & Prometheus instances on my other server to monitor the kasad.com server.
As this is a long-running project, I’ve written documentation on how the server is set up—mainly for my own reference, but it has helped a few other people as well. While the documentation site is not live right now, you can view an archived version using the link above.
Skills/concepts applied
- Web development
- Linux system administration
- Network security
- Mail server configuration
