æŠèŠ
- Guardicoreã¯ãæŽç·Žããããã¢ã»ããŒã»ãã¢ïŒP2PïŒãããããããçºèŠãFritzFrogç©æ¥µçã«2020幎1æä»¥æ¥ãSSHãµãŒãã«ãããã³ã°ãããŠããŸãã
- Golangã®ãã«ãŠã§ã¢ïŒFritzFrogã¯ãGolangã§ã¢ãžã¥ã©ãŒããã«ãã¹ã¬ããããã¡ã€ã«ã¬ã¹ã®æªæã®ããã³ãŒããå®è¡ããææããããã€ã¹ã®ããŒããã©ã€ãã«çè·¡ãæ®ããŸããã
- æ¿åºãæè²ãéèããã®ä»ã®ãªãœãŒã¹ãç©æ¥µçã«ã¿ãŒã²ããã«ããïŒFritzFrogã¯ãæ¿åºæ©é¢ãæè²æ©é¢ãå»çã»ã³ã¿ãŒãéè¡ãããã³å€ãã®éä¿¡äŒç€Ÿã®æ°åäžã®IPã¢ãã¬ã¹ã«åãå ¥ããŠé åžããããšããŸããããã®äžã§ãç±³åœãšãšãŒãããã®æåãªå€§åŠãš1ã€ã®ééäŒç€Ÿãå«ãã500ãè¶ ãããµãŒããŒãæ»æã«æåããŸããã
- è€éãïŒFritzFrogã¯å®å šã«ç¬èªä»æ§ã§ããããã®P2På®è£ ã¯ãŒãããäœæãããŠããŸããããã¯ããœãããŠã§ã¢éçºã®åéã«ãããäœæè ã®é«ãã¬ãã«ã®ããæèã瀺ããŠããŸãã
- ååïŒGuardcore Labsã¯ãFritzFrogã®P2Pæ¥ç¶ãååãããã¢ã®ããã«ãããã¯ãŒã¯ã«æ¥ç¶ã§ããGolangã¯ã©ã€ã¢ã³ãããã°ã©ã ãéçºããŸããã
- æå±ïŒFritzFrogã®äœæãæ åœããç¹å®ã®ã°ã«ãŒããç¹å®ã§ããŸããã§ããããçŸåšã®ããããããã¯ã以åã«ç¥ãããŠããRakosãããããããšéšåçã«é¡äŒŒããŠããŸãã
åæžã
FritzFrogã¯ãäžçäžã®SSHãµãŒããŒã«ç©æ¥µçã«äŸµå ¥ããéåžžã«æŽç·Žããããã¢ããŒãã¢ããããããã§ãã忣æ§é ã®ãããã§ããã¹ãŠã®ããŒãã«å¶åŸ¡ã忣ããŸãããã®ãããã¯ãŒã¯ã«ã¯åäžã®é害ç¹ããªãããã¢ã¯åžžã«çžäºã«éä¿¡ããŠããããã¯ãŒã¯ãå®å®ãããæŽæ°ããåžžã«ã¢ã¯ãã£ãã«ä¿ã¡ãŸãã P2Pæ¥ç¶ã¯ã察称æå·åã«AESã䜿çšããããŒäº€æã«Diffie-Hellmanã䜿çšããŠãæå·åããããã£ãã«ãä»ããŠè¡ãããŸãã
ä»ã®P2Pãããããããšã¯ç°ãªããFritzFrogã¯ãã®ããããã£ã®ã»ããããŠããŒã¯ã§ããã¡ã¢ãªå ã§çŽæ¥ããã±ãŒãžããã«ãããŠå®è¡ããããããã¡ã€ã«ã¬ã¹ã§ãã圌ã®ãããã¯ãŒã¯ã§ã¯ã¿ãŒã²ããã广çã«åçã«åæ£ãããŠããã«ããããããã圌ã¯éåžžã«ç©æ¥µçã«ã¿ãŒã²ããããã«ãŒããã©ãŒã¹ããŸãããã®ç¬èªã®P2Pãããã³ã«ã¯ãçŸåšç¥ãããŠããå®è£ ã®ãããã«ãåºã¥ããŠããŸããã
Golangã§èšè¿°ãããæªæã®ããã³ãŒãã¯éåžžã«å€æŽå¯èœã§ãããããŒããã©ã€ãã«çè·¡ãæ®ããŸãããå ¬éSSHããŒã®åœ¢åŒã§ããã¯ãã¢ãäœæããããã«ãã£ãŠæ»æè ã«è¢«å®³è ã®ããã€ã¹ãžã®æ°žç¶çãªã¢ã¯ã»ã¹ãæäŸããŸãããã®æŽ»åã®æåãããå®è¡å¯èœãªãã«ãŠã§ã¢ã®20ã®ç°ãªãããŒãžã§ã³ãç¹å®ããŸããã
ãã®æçš¿ã§ã¯ãFritzFrogãã©ã®ããã«å ¬éãããããããã³ãã®P2Pãããã¯ãŒã¯ã®æ§è³ªãšãææããã»ã¹ãã³ãã³ãã®æå·åãæ®çºæ§ã®åäœãªã©ãæªæã®ããã³ãŒãã®å éšã«ã€ããŠèª¬æããŸãã
Guardicore Labsã¯ããã®ãã«ãŠã§ã¢ãæ€åºããããã®ã¹ã¯ãªãããšããã®ã¢ã¯ãã£ããã£ã®äŸµå®³ã®ææšïŒIoCïŒã®ãªã¹ããå«ãGithubãªããžããªãå©çšã§ããããã«ããŸããã
ææãããã¹ãã®å°ççååžãæãè匱ãªåœã¯ãç±³åœãäžåœãéåœã§ããã
ããªãããããã°ãªãµãŒã
Guardcore Labsã¯æåã«FritzFrogèŠããããããçŸç§äºå žç ç©¶ã 1æ9æ¥ãæªæã®ããããã»ã¹ã®å®è¡ãäŒŽãæ°ããæ»æ
ifconfigãšnginxãæªæã®ããã¢ã¯ãã£ããã£ã®çå®ãã€å€§å¹
ãªå¢å ã®è¿œè·¡ãéå§ããããã«Guardcoreã°ããŒãã«ã»ã³ãµãŒãããã¯ãŒã¯ïŒGGSNïŒãžã®æ»æã13,000ã«éããŸãããäœå¹Žã«ãããã£ãŠãFritzFrogãã€ããªã®20ã®ç°ãªãããŒãžã§ã³ã远跡ããŸããã
ã°ã©ãã¯ãGGSNã«å¯ŸããFritzFrogæ»æã®æ°ã瀺ããŠããŸãã
é©ããããšã«ãäžèŠãããšãããæªæã®ããã³ãŒãã¯ã³ãã³ãã¢ã³ãã³ã³ãããŒã«ïŒCNCïŒãµãŒããŒã«æ¥ç¶ããŠããŸããã§ããããããããããçå£ã«èª¿æ»ãå§ããŠåããŠããµãŒããŒããŸã£ãããªãããšã«æ°ã¥ããŸããã
ãããããããããã¯ãŒã¯ãååããããã«ãGuardcore Labsã¯ãããŒããã«ãŠã§ã¢ãšäº€æããããã³ãã³ããéä¿¡ãããå¿çãåä¿¡ãããã§ããã¯ã©ã€ã¢ã³ããGolangã§éçºããŸããããã®ããã°ã©ã ã¯ãåœæãããã¬ãŒããšåŒã°ãããããã¯ãŒã¯ã®æ§è³ªãšç®çã調æ»ããããšãã§ããŸãããããã¬ãŒã®ãããã§ãç¬èªã®ããŒãããããã¯ãŒã¯ã«ã远å ãããããããããã«æ¥ç¶ããŠãã¢ã¯ãã£ããªP2Pãã©ãã£ãã¯ããŒã¿ã®éä¿¡ã«åå ããŸããã
FritzFrogã¯ãå®å ¬åºãæè²æ©é¢ãå»çã»ã³ã¿ãŒãéè¡ãããã³å€ãã®éä¿¡äŒç€Ÿãå«ããäœçŸäžãã®IPã¢ãã¬ã¹ã匷åŒã«åŒ·å¶ããŠããŸããããããã®ãã¡ãç±³åœãšãšãŒãããã®æåãªå€§åŠãš1ã€ã®ééäŒç€Ÿãå«ãã500ãè¶ ãããµãŒããŒãæ»æã«æåããŸããã
次äžä»£P2P
ãªãæ°äžä»£ãªã®ãïŒ
FritzFrog , :
- : FritzFrog , (BLOB).
- : .
- : . , P2P DDG «root».
- : .
- : P2P - P2P , ÎŒTP.
被害è ãæ£åžžã«ãããã³ã°ããããšããã«ãUPXãããã¯ãããæªæã®ããã³ãŒããèµ·åããã被害è ã¯ããã«èªåèªèº«ãåé€ããŸããçæãæå°éã«æããããã«ãæªæã®ããããã»ã¹ã¯ifconfigããã³nginxãšããååã§å®è¡ãããŸããäœæ¥ã®æåã®æ®µéã§ãæªæã®ããã³ãŒãã¯ããŒã1234ã§ãªãã¹ã³ããã³ãã³ããåŸ æ©ããŸããåä¿¡ããæåã®ã³ãã³ãã¯ã被害è ããããã¯ãŒã¯ãã¢ããã³ãã«ãŒããã©ãŒã¹ã¿ãŒã²ããã®ããŒã¿ããŒã¹ãšåæããŸãã
FritzFrogãã¹ãã¯ã©ã¹ã¿ãŒãåããŒãã¯ææããSSHãµãŒããŒã§ããããŒãã®ãµã€ãºã¯ããããã¯ãŒã¯ã®ä»ã®éšåãžã®æ¥ç¶ã瀺ããŠããŸãã
1234ãªã©ã®éæšæºããŒãã®ãã©ãã£ãã¯ã¯ããã¡ã€ã¢ãŠã©ãŒã«ããã®ä»ã®ã»ãã¥ãªãã£ã·ã¹ãã ã«ãã£ãŠç°¡åã«èªèããããããã¯ãããå¯èœæ§ããããŸãããããã£ãŠãFritzFrogã®éçºè ã¯åµé çã«åé¡ã«åãçµã¿ãããŒã1234ãä»ããŠã³ãã³ããçŽæ¥éä¿¡ãã代ããã«ãæ»æè ã¯SSHãä»ããŠè¢«å®³è ã«æ¥ç¶ããnetcatããã€ã¹ã§ã¯ã©ã€ã¢ã³ããèµ·åããnetcatããã€ã¹ããããããããµãŒããŒã«æ¥ç¶ããŸãããã®ããã«ããŠãã³ãã³ãã¯netcatå ¥åãšããŠSSHãä»ããŠæž¡ãããæªæã®ããã³ãŒãã«ç°¡åã«å°éããŸãã
FritzFrogã¯ãææããããã€ã¹ã®ããŒã«ã«netcatã¯ã©ã€ã¢ã³ãã䜿çšããŠãåŸæ¥ã®SSHããŒããä»ããŠP2Pã³ãã³ãããã³ããªã³ã°ããŸãã
FritzFrogã®æ»æè ã¯ã30ãè¶ ããç°ãªãã³ãã³ãã䜿çšããŠæå·åãããã³ãã³ããã£ãã«ãå±éããŸãããã³ãã³ããã©ã¡ãŒã¿ãšå¿çã¯ãæå®ãããããŒã¿æ§é ã§æž¡ãããJSON圢åŒã§ãªãªãŒã¹ïŒãã¢ãã€ã«åãïŒãããŸããããŒã¿ã¯å¯Ÿç§°AESæå·åã§æå·åãããéä¿¡ãããåã«Base64ã§ãšã³ã³ãŒããããŸããããŒã¿è»¢éã«é¢äžããããŒãã¯ãDiffie-Hellmanãããã³ã«ã䜿çšããŠããŒã亀æããŸãã
FritzFrogãããã¯ãŒã¯äžã®ããŒãã¯å¯æ¥ãªæ¥è§Šãç¶æããæ¥ç¶ããã¢ãšã¿ãŒã²ããã®äº€æãããã³çžäºåæã確èªããããã«åžžã«çžäºã«pingãå®è¡ããŸããããŒãã¯ãŸãããããã¯ãŒã¯å šäœã®ãã«ãŒããã©ãŒã¹ã¿ãŒã²ããã®åæ£ã«åœ±é¿ãäžããå·§åŠãªéžæããã»ã¹ã«åŸäºããŸãã Guardcore Labsã®èгå¯ã«ãããšãã¿ãŒã²ããã¯ãããã¯ãŒã¯å šäœã«åçã«åæ£ãããŠããã2ã€ã®ããŒããåãã¿ãŒã²ããããããã³ã°ããããšã¯ããŸããã
æªæã®ããã³ãŒãã«é£ã³èŸŒã
FritzFrogãã€ããªã¯ãGolangã®é«åºŠãªæªæã®ããã³ãŒãã§ããããã¯å®å šã«ã¡ã¢ãªå ã§æ©èœããæªæã®ããã³ãŒããæã€åããŒãã¯ãã¿ãŒã²ãããšãã¢ã®ããŒã¿ããŒã¹å šäœãã¡ã¢ãªã«æ ŒçŽããŸããæ¬¡ã®è¡šã«ç€ºãããã«ãæªæã®ããã³ãŒãã¯è€æ°ã®ã¹ã¬ãããäœæããŠãããŸããŸãªã¿ã¹ã¯ãåæã«åŠçããŸãã
FritzFrogã¯ãç ç²è ãšã¿ãŒã²ããããã€ã¹ã®å¶åŸ¡ç¶æ ãæ¬¡ã®ããã«å®çŸ©ããŸãã
- ã¿ãŒã²ããïŒã¿ãŒã²ãããªã¯ãšã¹ãã®ããã€ã¹ã¯ã¯ã©ãã«ãŒã¢ãžã¥ãŒã«ã«æž¡ãããã¯ã©ãã«ãŒã¢ãžã¥ãŒã«ã¯ã¹ãã£ã³ããŠã¯ã©ããã³ã°ã詊ã¿ãŸãã
- ãããã€ïŒæ£åžžã«äŸµå®³ãããããã€ã¹ã¯ãDeployMgmtã¢ãžã¥ãŒã«ãä»ããŠãã«ãŠã§ã¢ææã®ããã«ãã¥ãŒã«å ¥ããããŸãã
- Owned (): P2P Owned.
æªæã®ããã³ãŒããæã€åããŒãã«ã¯ãã³ãã³ãã®åä¿¡ãã³ãã³ãã®è§£æãããã³ã³ãŒãå ã®é©åãªé¢æ°ãžã®åãæž¡ããæ åœããã¯ãŒã«ãŒã¹ã¬ããããããŸãã
åè§£è£ çœ®ã®åäœæ©èœãåãã©ã³ãã¯ããµããŒããããŠããP2Pæ©èœã«å¯Ÿå¿ããŠããŸãã
æªæã®ããã³ãŒãã¯äžæçãªãã®ã§ããã·ã¹ãã ã®åèµ·ååŸãåç¶ããããšããŸããããããã³ã°ãããã¿ãŒã²ããã«å°æ¥ã¢ã¯ã»ã¹ã§ããããã«ãããã¯ãã¢ãä¿åããããã®ãã°ã€ã³ãšãã¹ã¯ãŒãã¯ãããã¯ãŒã¯äžã®ãã¢ã«ãã£ãŠä¿åãããŸããæªæã®ããã³ãŒãã¯ãå ¬éSSH-RSAããŒããã¡ã€ã«ã«è¿œå ããŸã
authorized_keysããã®åçŽãªããã¯ãã¢ã«ãããæ»æè
ã¯ãå
ã®ãã¹ã¯ãŒãã倿Žãããå Žåã«ãç§å¯ã®ç§å¯éµã䜿çšããŠããã¹ã¯ãŒããªãã§èªèšŒããããšãã§ããŸãã FritzFrogã䜿çšããå¯äžã®å
¬éããŒã以äžã«ç€ºããŸãã
ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQDJYZIsncBTFc+iCRHXkeGfFA67j+kUVf7h/IL+sh0RXJn7yDN0vEXz7ig73hC//2/71sND+x+Wu0zytQhZxrCPzimSyC8FJCRtcqDATSjvWsIoI4j/AJyKk5k3fCzjPex3moc48TEYiSbAgXYVQ62uNhx7ylug50nTcUH1BNKDiknXjnZfueiqAO1vcgNLH4qfqIj7WWXu8YgFJ9qwYmwbMm+S7jYYgCtD107bpSR7/WoXSr1/SJLGX6Hg1sTet2USiNevGbfqNzciNxOp08hHQIYp2W9sMuo02pXj9nEoiximR4gSKrNoVesqNZMcVA0Kku01uOuOBAOReN7KJQBt
æªæã®ãããã¡ã€ã«ã¯ãããŒã«ã«ããã€ã¹ã§ããããçš®é¡ã®ã·ã§ã«ã³ãã³ããè€æ°åå®è¡ããŠãã·ã¹ãã ã®ç¶æ ãç£èŠããŸããããšãã°ã
free âm䜿çšå¯èœãªRAMã確èªãããuptimeãjournalctl âs @0 âu sshdSSHãã°ã€ã³ã远跡ããããCPUè² è·çµ±èšã衚瀺ãããã®ä»ã®ã³ãã³ããå®è¡ãããããŸãããããã®çµ±èšã¯ããããã¯ãŒã¯äžã®ä»ã®ããŒãã§å©çšå¯èœã§ãããããã€ã¹ã§ã¯ãªãããã€ããŒãå®è¡ãããã©ãããªã©ãããŸããŸãªæ±ºå®ãè¡ãããã«äœ¿çšãããŸããæ±ºå®ãäžããããšãæªæã®ããã³ãŒãã¯libexecMoneroããã€ãã³ã°ããããã®å¥ã®ããã»ã¹ãèµ·åããŸãããã®ãã€ããŒã¯ã人æ°ã®ããXMRigãã€ããŒã«åºã¥ããŠãããweb.xmrpool.euããŒã5555ãä»ããŠãããªãã¯ããŒã«ãšéä¿¡ããŸãã
æªè³ªãªæ¥æµã®ãããªãããã¯ãŒã¯
FritzFrogã¯ããããã¯ãŒã¯å šäœã§ãã¡ã€ã«ãå ±æããæ©èœã«äŸåããŠãããæ°ããããã€ã¹ã«ææããããMoneroã¯ãªãããã€ããŒãªã©ã®æªæã®ããèŠçŽ ãèµ·åãããããŸãã
ããŒãéã§ãã¡ã€ã«ã亀æããããã«ãFritzFrogã¯ã¹ãã«ã¹ãã¡ã€ã«ã¬ã¹ã¢ãããŒãã䜿çšããŸãããã¡ã€ã«ã¯ã¡ã¢ãªã«æ ŒçŽããããã€ããªããŒã¿ã®é åã«åå²ãããæªæã®ããã³ãŒãã¯åé åã®ããã·ã¥å€ãšãšãã«ãããã«æ ŒçŽããããšã§äœ¿çšå¯èœãªé åãç£èŠããŸãã
ããŒãAããã¢ã§ããããŒãBãããã¡ã€ã«ãåä¿¡ããå ŽåãããŒãAã¯ããŒãBã«èŠæ±
getblobstatsãéä¿¡ããŠãææããŠããã¢ã¬ã€ãèŠã€ããããšãã§ããŸããæ¬¡ã«ãããŒãAã¯ãP2Pã³ãã³ãã䜿çšãããgetbinãã¢ãã¬ã¹ã§HTTPã䜿çšããŠãããã·ã¥ãä»ããŠç¹å®ã®é
åãååŸã§ããŸãhttp://1234/ãããŒãAã¯ãã¹ãŠã®ã¢ã¬ã€ãåä¿¡ãããšãAssembleã¢ãžã¥ãŒã«ãä»ããŠãã¡ã€ã«ãäœæããå®è¡ããŸãã
getblolbstats. , .
P2Pããããããã®æäœã远跡ããããšã¯å°é£ã§ãããããã¯ãŒã¯ã®åæ£æ§ã«ããããããã¯ãŒã¯å ã®ã³ãã³ãã¯ä»»æã®ããŒãããä»»æã®ããŒãã«éä¿¡ã§ããŸãããã ãããã®P2Pããããããã以åã®åæ§ã®è åšãšæ¯èŒããããšããŸããã
ä»ã®P2Pãããããããšæ¯èŒããŠããFritzFrogã¯ãŠããŒã¯ãªãŸãŸã§ããDDGãšã¯ç°ãªããIRCfluã®ããã«IRCã䜿çšãããã¡ã¢ãªå ã§çŽæ¥å®è¡ãããInterPlanetaryStormãããããããšã¯å¯Ÿç §çã«Unixããã€ã¹ã§å®è¡ãããŸããããã¯ãç¹ã«æ©èœã®åœåãšããŒãžã§ã³çªå·ã®ç¹ã§ã¯èª°ããã®ããã«èŠããå Žåãããã¯äžã«ããRakosãA P2PããããããGolangã«2016幎ã«ESETããã¯ã«ãã£ãŠåæããŸããã
ã¢ã¯ãã£ããã£ã®è¿œè·¡ãšè»œæž
Guardcore Labsã¯ã SSHãµãŒããŒã§å®è¡ããFritzFrog远跡ã¹ã¯ãªãããæäŸããŸãããæ¬¡ã®ããããããã€ã³ãžã±ãŒã¿ãŒãæ¢ããŸãã
- èµ·åããã»ã¹
nginxãifconfigãŸãã¯libexecãã®å®è¡å¯èœãã¡ã€ã«ïŒããªãã¯ä»¥äžãåç §ããããšãã§ããŸãããã«ïŒãã¯ãã·ã¹ãã äžã«ååšããŠããŸãã - ããŒã1234ã§ãªãã¹ã³ããŠããŸãã
ããã«å ããŠãããŒã5555ã®TCPãã©ãã£ãã¯ã¯ãMoneroããŒã«ãžã®ãããã¯ãŒã¯ãã©ãã£ãã¯ã瀺ããŠããå¯èœæ§ããããŸãã
ubuntu@ip-111-11-11-11:~$ ./detect_fritzfrog.sh
FritzFrog Detection Script by Guardicore Labs
=============================================
[*] Fileless process nginx is running on the server.
[*] Listening on port 1234
[*] There is evidence of FritzFrog's malicious activity on this machine.
FritzFrogã¯ãã»ãšãã©ã®ãã¡ã€ã¢ãŠã©ãŒã«ã·ã¹ãã ã®ããŒãããã³ãããã³ã«åŒ·å¶æ©èœãå©çšããŸããããã»ã¹ããŒã¹ã®ã»ã°ã¡ã³ããŒã·ã§ã³ã«ãŒã«ã䜿çšããããšã§ããã®ãããªè åšãæé€ã§ããŸãã
匱ããã¹ã¯ãŒãã¯ãFritzFrogæ»æã®äž»èŠãªè匱æ§ã§ããããšã蚌æãããŠããŸããããå®å šãªåŒ·åãªãã¹ã¯ãŒããšå ¬éèªèšŒããŒã䜿çšããããšããå§ãããŸããããã«ã
authorization_keysæ»æè
ãããã€ã¹ã«ã¢ã¯ã»ã¹ããã®ãé²ãããã«ããã¡ã€ã«ããFritzFrogå
¬ééµãé€å€ããããšãéåžžã«éèŠã§ããã«ãŒã¿ãŒãšIoTããã€ã¹ã¯éåžžSSHãå
¬éãããããFritzFrogæ»æã«å¯ŸããŠè匱ã«ãªããŸãããã®ãããªããã€ã¹ã®SSHããŒãã倿Žããããæ©èœã䜿çšããªãå Žåã¯SSHãå®å
šã«ç¡å¹ã«ããããšããå§ãããŸãã