Algılamayı Atlamak İçin Derlenmiş Python Kodu Kullanan Kötü Amaçlı PyPI Paketleri


01 Haziran 2023Ravie LakshmananProgramlama / Tedarik Zinciri

Kötü Amaçlı PyPI Paketleri

Araştırmacılar, uygulama güvenlik araçları tarafından tespit edilmekten kaçınmak için derlenmiş Python kodunu kullanan Python Paket Dizini (PyPI) deposuna yönelik yeni bir saldırı keşfettiler.

ReversingLabs analisti Karlo Zanki, The Hacker News ile paylaştığı bir raporda, “Python bytecode (PYC) dosyalarının doğrudan çalıştırılabilmesi gerçeğinden yararlanan ilk tedarik zinciri saldırısı olabilir.” dedi.

Söz konusu paket fshec217 Nisan 2023 tarihinde aynı gün yapılan sorumlu açıklamanın ardından paket kayıt defterinden kaldırılmıştır.

PYC dosyaları, bir Python programı yürütüldüğünde Python yorumlayıcısı tarafından oluşturulan derlenmiş bayt kodu dosyalarıdır.

“Bir modül ilk kez içe aktarıldığında (veya mevcut derlenmiş dosya oluşturulduktan sonra kaynak dosya değiştiğinde), .py dosyasını içeren dizinin __pycache__ alt dizininde derlenmiş kodu içeren bir .pyc dosyası oluşturulmalıdır. ” Python belgelerini açıklar.

Yazılım tedarik zinciri güvenlik firmasına göre paket, sonuncusu kötü amaçlı işlevsellik barındıran üç dosya (_init_.py, main.py ve full.pyc) içerir.

“Paketin giriş noktası, diğer dosyalardan birinde bulunan Python derlenmiş modülünün yüklenmesinden sorumlu Python kaynak kodunu içeren diğer düz metin dosyası olan main.py’den bir işlevi içe aktaran __init__.py dosyasında bulundu. , full.pyc,” diye işaret etti Zanki.

Kötü Amaçlı PyPI Paketleri

Bu da, .pyc dosyasında bulunan kodu yüklemek ve yürütmek için importlib paketi kullanılarak (normal içe aktarmanın aksine) gerçekleştirilir.

PYC dosyasının tersine mühendislik uygulanmış sürümünün analizi, bunun kullanıcı adlarını, ana bilgisayar adlarını ve dizin listelerini toplamak için yapılandırıldığını ve bunun yanı sıra sabit kodlu bir sunucudan (13.51.44) ana bilgisayarda yürütülecek getirme komutlarını ortaya çıkarır.[.]246).

YAKLAŞAN WEBİNAR

🔐 API Güvenliğinde Uzmanlaşma: Gerçek Saldırı Yüzeyinizi Anlamak

API ekosisteminizdeki kullanılmayan güvenlik açıklarını keşfedin ve güçlü güvenlik için proaktif adımlar atın. Bilgilendirici web seminerimize katılın!

Oturuma Katılın

ReversingLabs, modülün indirildiğini ve bir dosyaya yerleştirilen yeni komutların getirilmesinden sorumlu olan ve tehdit aktörü tarafından farklı talimatlar vermek üzere istediği zaman değiştirilebilen başka bir Python betiğinin çalıştırıldığını da gözlemlediğini söyledi.

Komut ve kontrol sunucusunun daha ayrıntılı incelenmesi, dosyaları kimliklerine göre (1’den başlayarak) herhangi bir yetkilendirme olmadan indirmeyi mümkün kılan bir yanlış yapılandırma ortaya çıkardı. Bu, saldırının büyük olasılıkla sofistike bir aktör tarafından düzenlenmediğini gösteriyor.

Geliştirme, tehdit aktörlerinin güvenlik çözümlerinden tespit edilmekten kaçınmak için farklı şaşırtma tekniklerini benimseme çabalarının bir devamıdır.

Zanki, “fshec2 paketinde keşfedilenler gibi yükleyici komut dosyaları, minimum miktarda Python kodu içerir ve basit bir eylem gerçekleştirir: derlenmiş bir Python modülünün yüklenmesi,” dedi. “Sadece kötü niyetli bir modül oluyor.”

Bu makaleyi ilginç buldunuz mu? Bizi takip edin twitter ve yayınladığımız daha özel içeriği okumak için LinkedIn.





Source link