Edited Some Content

This commit is contained in:
2025-10-25 12:52:03 -05:00
parent be126ca157
commit e5a93affa2
11 changed files with 130 additions and 150 deletions

View File

@@ -8,14 +8,14 @@
using namespace ftxui;
// New reusable styles (orange/red theme)
const auto theme_text_style = color(Color::OrangeRed1) | bold | dim;
const auto theme_border_style = border | color(Color::Red);
const auto theme_link_style = color(Color::RedLight) | underlined;
const auto theme_button_style = color(Color::Red) | bold;
const auto theme_button_active_style = color(Color::Yellow1) | bold;
// Hacker-style reusable styles
const auto hacker_text_style = color(Color::Green) | bold | dim;
const auto hacker_border_style = border | color(Color::Green);
const auto hacker_link_style = color(Color::LightGreen) | underlined;
const auto hacker_button_style = color(Color::Green) | bold;
const auto hacker_button_active_style = color(Color::LightGreen) | bold;
// ------------------x
// ------------------
// Pages
// ------------------
@@ -24,40 +24,29 @@ Component MakeAboutPage() {
return vbox({
// Header section
vbox({
text("Keshav Anand") | color(Color::Blue) | bold | center,
text("Subtitle") | theme_text_style | center,
}) | theme_border_style,
text("Keshav Anand") | color(Color::LightGreen) | bold | center,
text("ML Researcher, FTC Programmer, & CS/Maths Enthusiast") | hacker_text_style | center,
}) | hacker_border_style,
separator(),
// Tags section
vbox({
text("insert_content") | theme_text_style | center,
}) | theme_border_style,
separator(),
// Focus areas
vbox({
text("Summ1") | color(Color::LightSkyBlue1) | bold,
}) | theme_border_style,
separator(),
// Current status
vbox({
text("Summ2") | color(Color::LightSkyBlue1) | bold,
}) | theme_border_style,
text("Current Status:") | color(Color::LightGreen) | bold,
text("Junior at Plano East (1/1264)") | hacker_text_style,
text("Lead SW for FTC 23344 Technical Turbulence") | hacker_text_style,
text("Vice President, Science Fair") | hacker_text_style,
text("President, Cricket Club") | hacker_text_style,
}) | hacker_border_style,
separator(),
// Location and contact
vbox({
text("Location") | theme_text_style | center,
text("Email") | theme_text_style | center,
text("Phone") | theme_link_style | center,
}) | theme_border_style,
text("DFW Metroplex, Texas") | hacker_text_style | center,
text("keshavanandofficial.gmail.com") | hacker_link_style | center,
}) | hacker_border_style,
}) | flex;
});
@@ -65,21 +54,26 @@ Component MakeAboutPage() {
Component MakeProjectsPage() {
const std::vector<Project> projects = {
{"Insert Gibbersish"},
{"🗃️ Matrix FS — L2 distributed storage over IPFS", "Rust + Tauri + Svelte, AES-256-CBC/ChaCha20-Poly1305 encryption"},
{"🎓 Bon Voyage — AI MOOC content generator", "Java + Stanford CoreNLP, MLH Hackathon winner"},
{"🏥 EHR System — Secure health records platform", "Java client-server, TCP/IP sockets, Swing GUI, SMB integration"},
{"🧮 Rule-based Tensor Mutations for LLMs", "Novel LLaMA 3B enhancement, published on TechRxiv"},
{"🏠 Home Infrastructure — 50-user self-hosted platform", "40+ Docker containers, WireGuard mesh, 150TB ZFS NAS"},
{"🤖 SLAM Guide for Autonomous Robotics", "Probabilistic mapping algorithms, F1Tenth platform experience"},
{"⚔️ CyberPatriot Automation Suite", "Rust/PowerShell scripts, 30+ points per round, licensed to other teams"}
};
Component container = Container::Vertical({});
for (const Project& project : projects) {
Component card = Renderer([project]() -> Element {
Element title = text(project.title) | theme_text_style | bold;
Element title = text(project.title) | hacker_text_style | bold;
Element desc = text(project.link) | color(Color::GreenYellow);
return vbox({
title,
desc
}) | theme_border_style;
}) | hacker_border_style;
});
container->Add(card);
@@ -95,26 +89,33 @@ Component MakeEducationPage() {
return vbox({
// School section
vbox({
text("Education") | color(Color::LightGreen) | bold,
}) | theme_border_style,
text("🏫 Plano East Senior High School (20222026)") | color(Color::LightGreen) | bold,
text("STEM & Multi-disciplinary Endorsement") | hacker_text_style,
text("Computer Science & Mathematics concentrations") | hacker_text_style | dim,
}) | hacker_border_style,
separator(),
// Coursework section
vbox({
text("TODO: ADD AP scores, nonsense, etc.") | color(Color::LightGreen) | bold,
}) | theme_border_style,
text("📚 Relevant Coursework:") | color(Color::LightGreen) | bold,
text("• Data Structures & Algorithms") | hacker_text_style,
text("• Object-Oriented Programming") | hacker_text_style,
text("• Calculus & Differential Equations") | hacker_text_style,
text("• Probability & Statistics") | hacker_text_style,
text("• Newtonian Physics") | hacker_text_style,
}) | hacker_border_style,
separator(),
// Research section
vbox({
text("Research:") | color(Color::Blue) | bold,
text("GaitGuardian, LASER, TEG, etc.") | theme_text_style,
}) | theme_border_style,
text("🔬 Research Experience:") | color(Color::LightGreen) | bold,
text("Research Assistant to Dr. Madan M. T. Ayyalasomayajula (2022Present)") | hacker_text_style,
text("• Literature review and concept summarization") | hacker_text_style | dim,
text("• Technical framework evaluation and benchmarking") | hacker_text_style | dim,
text("• Research direction discussions and workflow analysis") | hacker_text_style | dim,
}) | hacker_border_style,
}) | flex;
});
@@ -127,9 +128,16 @@ Component MakeWorkPage() {
};
const std::vector<WorkEntry> jobs = {
{"exp",
"desc"},
{"👑 President, Cybersecurity Club at PESH (20232026)",
"Ethical hacking workshops, CTF prep, digital forensics mentoring"},
{"💻 Officer, Computer Science Club at PESH (20232026)",
"Data structures instruction, Java sessions, Git workflows"},
{"🔍 Trace Labs OSINT Search Party (20232024)",
"Missing person investigations, OSINT pivoting, geolocation analysis"},
{"🇺🇦 IT Army of Ukraine (Dec 2023Feb 2024)",
"Offensive squad leader, DDoS campaigns, persistent takedowns"},
{"🎯 Active Red Team Practitioner",
"Hack The Box (Rank 564), TryHackMe KoTH Top 5, 15+ HTB machines"}
};
Component container = Container::Vertical({});
@@ -138,8 +146,8 @@ Component MakeWorkPage() {
Component card = Renderer([job]() -> Element {
return vbox({
text(job.title) | color(Color::LightGreen) | bold,
text(job.description) | theme_text_style | dim,
}) | theme_border_style;
text(job.description) | hacker_text_style | dim,
}) | hacker_border_style;
});
container->Add(card);
}
@@ -151,7 +159,18 @@ Component MakeWorkPage() {
Component MakeAwardsPage() {
const std::vector<std::string> awards = {
"Award 1", "Description 1",
"🥈 Lockheed Martin Cyber Quest — 2nd Place (2025)",
"DFW metroplex, reverse engineering & low-level security",
"🥇 CyberPatriot — State Level Gold Tier (2025)",
"Offensive security analysis in blue-team environment",
"🏆 Battle of the Brains — 5th Place Spring 2024, 10th Place Spring 2025",
"Regional algorithms competitions at UTD",
"🔓 NSA Codebreaker Challenge (Nov 2024)",
"5 advanced tasks: protocol exploitation, reverse engineering",
"👑 TryHackMe King of the Hill — Top 5 (2024)",
"2 consecutive days, live red team capabilities",
"💀 Hack The Box — Peak Rank 564",
"15+ Medium machines, 90% progress toward 'Hacker' rank"
};
Component container = Container::Vertical({});
@@ -164,8 +183,8 @@ Component MakeAwardsPage() {
Component card = Renderer([title, desc]() -> Element {
return vbox({
text(title) | color(Color::LightGreen) | bold,
text(desc) | theme_text_style | dim,
}) | theme_border_style;
text(desc) | hacker_text_style | dim,
}) | hacker_border_style;
});
container->Add(card);
@@ -178,19 +197,39 @@ Component MakeAwardsPage() {
Component MakeSkillsPage() {
const std::string skills_content =
"Skills:\n";
"🦀 Languages: Rust (5/5), Async Rust, Python, Java, C/C++, TypeScript, Solidity\n\n"
"🌐 Networking: WireGuard, Tailscale, Tor, I2P, DNS, DHCP, TLS, gRPC, QUIC\n\n"
"⚔️ Red Team Arsenal:\n"
" • Recon: amass, subfinder, shodan, nuclei, ffuf\n"
" • Web: sqlmap, Burp Suite Pro, OWASP ZAP, nikto\n"
" • Post-Exploit: Empire, Covenant, Metasploit, Cobalt Strike\n"
" • AD: BloodHound, Rubeus, mimikatz, impacket\n"
" • PrivEsc: linPEAS, winPEAS, JuicyPotato\n\n"
"🔐 Crypto: ChaCha20Poly1305, Ed25519, Kyber1024, Dilithium5, TLS 1.3\n\n"
"🐧 Systems: Arch Linux, kernel patching, BPF/eBPF, QEMU/KVM, systemd\n\n"
"☁️ Cloud: AWS (EC2, S3, Lambda), Terraform, Docker, Kubernetes";
return Renderer([skills_content]() -> Element {
return paragraph(skills_content) | theme_text_style | flex;
return paragraph(skills_content) | hacker_text_style | flex;
});
}
Component MakeContactPage() {
const std::string contact_info =
"Contact Me:\n";
"📫 Email: krishna@ayyalasomayajula.net\n"
"🌐 Website: https://krishna.ayyalasomayajula.net\n"
"📞 Phone: (214) 293-5743\n"
"📍 Based in DFW Metroplex, Texas\n"
"💳 US Green Card Holder\n"
"📄 Resume: https://git.cyber.ayyalasomayajula.net/marsultor/resume-cv/raw/branch/master/resume.pdf\n\n"
"🔗 Connect with me for:\n"
" • Cybersecurity research collaboration\n"
" • Red team consulting\n"
" • Distributed systems projects\n"
" • AI/ML security research";
return Renderer([contact_info]() -> Element {
return paragraph(contact_info) | theme_text_style | flex;
return paragraph(contact_info) | hacker_text_style | flex;
});
}
@@ -214,13 +253,13 @@ PortfolioApp::PortfolioApp() {
pages_.push_back(skills_page_);
pages_.push_back(contact_page_);
// Create navigation sidebar with orange/red styling
// Create navigation sidebar with green styling
std::vector<std::string> labels = {"About", "Projects", "Education", "Work", "Awards", "Skills", "Contact"};
std::vector<Component> buttons;
for (int i = 0; i < (int)labels.size(); ++i) {
Component button = Button(labels[i], [&, i] { SwitchPage(i); })
| (i == current_page_ ? theme_button_active_style : theme_button_style);
| (i == current_page_ ? hacker_button_active_style : hacker_button_style);
buttons.push_back(button);
}
@@ -255,9 +294,9 @@ void PortfolioApp::SwitchPage(int index) {
// Render method implementation
Element PortfolioApp::Render() {
return hbox({
navigation_->Render() | theme_border_style,
navigation_->Render() | hacker_border_style,
separator(),
pages_[current_page_]->Render() | theme_border_style | flex
pages_[current_page_]->Render() | hacker_border_style | flex
});
}