„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
Lip 18

Zuckerberg i członkowie zarządu Meta unikają procesu w sprawie naruszeń prywatności – zawarto ugodę

Mark Zuckerberg oraz byli i obecni członkowie zarządu Meta Platforms zawarli ugodę z akcjonariuszami, którzy domagali się 8 miliardów dolarów odszkodowania za dopuszczenie do wielokrotnych naruszeń prywatności użytkowników Facebooka w związku ze skandalem Cambridge Analytica
0
Cze 27

Apple modyfikuje zasady App Store w UE po karze za naruszenie DMA

Apple wdraża nowy model opłat w App Store na terenie Unii Europejskiej w odpowiedzi na karę w wysokości 500 mln euro za ograniczanie możliwości promowania alternatywnych systemów płatności przez deweloperów. Nowe warunki obejmują dwupoziomową strukturę prowizji, dodatkową opłatę Core Technology Commission (CTC) oraz zmienione zasady promocji ofert wewnątrz aplikacji.
0
Mar 10, 2023

Google, w odpowiedzi na ChatGPT, wprowadza AI do wszystkich flagowych produktów

Wyższe kierownictwo Google’a ogłosiło, że "generatywna sztuczna inteligencja" powinna zostać włączona do wszystkich jego największych produktów w ciągu kilku miesięcy.
0

Ta strona używa plików cookie, aby zapewnić Ci lepsze wrażenia podczas przeglądania.

Dowiedz się więcej o tym, jak używamy plików cookie i jak zmienić preferencje dotyczące plików cookie w naszej Polityka plików cookie.

Zmień ustawienia
Zapisz Akceptuj wszystkie cookies