„Minus 50 000 linii kodu”: Meta przepisała część komunikatora WhatsApp z C++ na Rust

„Minus 50 000 linii kodu”: Meta przepisała część komunikatora WhatsApp z C++ na Rust

Meta poinformowała, że przepisała swoją bibliotekę wamedia z C++ na Rust. Odpowiada ona za przetwarzanie i weryfikację plików multimedialnych wysyłanych przez użytkowników WhatsApp.

Według firmy wamedia przetwarza miliardy plików miesięcznie na różnych platformach: Androidzie, iOS, macOS, w wersji webowej, na urządzeniach typu wearables oraz w przeglądarkach. Zadaniem biblioteki jest sprawdzanie, czy pliki multimedialne spełniają wymagania dotyczące formatu i struktury, oraz blokowanie tych, które mogłyby powodować błędy w podatnych bibliotekach systemowych.

Historia przejścia na Rust sięga 2015 roku, kiedy ujawniono podatność Stagefright. Umożliwiała ona atakowanie użytkowników za pomocą złośliwych plików MP4 i infekowanie urządzeń z Androidem poprzez biblioteki systemowe. Wówczas WhatsApp zaczął chronić użytkowników po stronie aplikacji, weryfikując pliki przed ich przetwarzaniem, zamiast polegać wyłącznie na aktualizacjach systemu operacyjnego.

Migracja biblioteki do Rust odbywała się równolegle z oryginalną implementacją w C++. Zespół testował nową wersję i porównywał wyniki, aby upewnić się, że implementacja w Rust zachowuje się identycznie jak wcześniejsza wersja w C++. W efekcie zamiast 160 000 linii kodu w C++ (bez testów) powstało 90 000 linii kodu w Rust (wraz z testami), co oznacza redukcję kodu o 50 000 linii.

„To największe jak dotąd wdrożenie kodu w Rust na różnorodnych platformach końcowych i w produktach, o jakim wiemy. Nasze doświadczenie potwierdza gotowość Rusta do użycia po stronie klienta oraz jego unikalną wartość” — podkreślają przedstawiciele firmy.

WhatsApp dodał także dodatkowe mechanizmy weryfikacji dla bardziej ryzykownych typów plików, takich jak PDF, oraz plików z fałszywymi rozszerzeniami lub typami MIME. Ten zestaw kontroli otrzymał nazwę Kaleidoscope.

Avatar
Oct 21

Amazon AWS wraca do działania po globalnej awarii

Amazon Web Services (AWS) stopniowo przywraca działanie swoich systemów po poważnej awarii, która w poniedziałek 20 października sparaliżowała tysiące stron internetowych i aplikacji na całym świecie. Problemy dotyczyły m.in. Snapchata, Reddita, Roblox, PayPal Venmo i wielu innych popularnych platform
0
May 26, 2025

Oracle zamierza zainwestować około 40 miliardów dolarów w chipy Nvidii

Zgodnie z informacjami podanymi przez The Financial Times, Oracle zamierza zainwestować około 40 miliardów dolarów w chipy Nvidii, które będą zasilać nowe centrum danych OpenAI w Teksasie. To część dynamicznego wyścigu infrastrukturalnego między gigantami technologicznymi, którzy budują zaplecze dla kolejnej generacji systemów AI.
0
Feb 21, 2025

30 filmów o sztucznej inteligencji: jak AI jest przedstawiane w kinie

Sztuczna inteligencja to jeden z kluczowych tematów współczesnej technologii. Systemy AI rozwijają się w zawrotnym tempie, a ich zastosowanie w przemyśle, medycynie czy rozrywce zaczyna odgrywać coraz większą rolę w kształtowaniu gospodarki i społeczeństwa.
0

This site uses cookies to offer you a better browsing experience.

Find out more on how we use cookies and how to change cookie preferences in our Cookies Policy.

Customize
Save Accept all cookies