Metamask Snap revisionsrapport for Qtum

Ledelsesoversigt

Qtum kontaktede Sayfer Security for at udføre penetrationstest på Qtums MetaMask Snap i 05/2024.

Inden vi vurderede ovenstående tjenester, holdt vi et kickoff-møde med Qtums tekniske team og fik et overblik over systemet og målene for denne forskning.

I løbet af undersøgelsesperioden på 2 uger opdagede vi 5 sårbarheder i systemet, ingen af ​​dem kritiske.

Som konklusion bør flere rettelser implementeres efter rapporten, men systemets sikkerhedsposition er kompetent.

Efter en gennemgang fra Sayfer-teamet bekræfter vi, at alle sikkerhedsproblemerne nævnt i denne rapport er blevet løst af Qtum-teamet.

Risikometodologi

Hos Sayfer er vi forpligtet til at levere penetrationstest af højeste kvalitet til vores kunder. Det er derfor, vi har implementeret en omfattende risikovurderingsmodel for at evaluere alvoren af ​​vores resultater og give vores kunder de bedst mulige anbefalinger til afbødning.

Vores risikovurderingsmodel er baseret på to nøglefaktorer: IMPACT og SANDSYNLIGHED. Påvirkning refererer til den potentielle skade, der kan følge af et problem, såsom økonomisk tab, skade på omdømme eller et ikke-operativt system. Sandsynlighed refererer til sandsynligheden for, at et problem vil opstå under hensyntagen til faktorer som kompleksiteten af ​​angrebet og antallet af potentielle angribere.

Ved at kombinere disse to faktorer kan vi skabe en omfattende forståelse af den risiko, et bestemt problem udgør, og give vores kunder en klar og handlekraftig vurdering af problemets alvor. Denne tilgang giver os mulighed for at prioritere vores anbefalinger og sikre, at vores kunder får den bedst mulige rådgivning om, hvordan de beskytter deres forretning.

Risiko er defineret som følger:

Sårbarheder efter risiko

Høj – Direkte trussel mod vigtige forretningsprocesser.
Medium – Indirekte trussel mod vigtige forretningsprocesser eller delvis trussel mod forretningsprocesser.
Lav - Der er ingen direkte trussel. Sårbarheden kan udnyttes ved hjælp af andre sårbarheder.
Informational – Denne konstatering indikerer ikke sårbarhed, men angiver en kommentar, der giver besked om designfejl og ukorrekt implementering, der kan forårsage et problem i det lange løb.

Severity
# af problemer
Høj
0
Medium
0
Lav
3
Informational
2

Tilgang

Introduktion

Qtum kontaktede Sayfer for at udføre penetrationstest på deres MetaMask Snap-applikation.

Denne rapport dokumenterer forskningen udført af Sayfer rettet mod de udvalgte ressourcer, der er defineret under forskningsomfanget. Denne rapport viser især gennemgangen af ​​sikkerhedsstilling for Qtums MetaMask Snap-applikation og dens omgivende infrastruktur og procesimplementeringer.

Vores gennemtrængningstestprojekts livscyklus:

01

Omfangsoversigt

02

Teknisk oversigt

03

Omfangsvalidering

04

Trusselsmodel

05

Sikkerhedsvurdering

06

Sikkerhedsvurdering

Omfangsoversigt

Under vores første møde og efter at have forstået virksomhedens behov, definerede vi applikationens omfang, der ligger på følgende URL'er, som omfanget af projektet:

  • Qtums MetaMask Snap

Vores test blev udført fra 24/05/2024 til 07/06/2024.

Lad det ikke være for sent!

Start din revision med Sayfer

Omfangsvalidering

Vi startede med at sikre, at det omfang, som kunden definerede for os, var teknisk logisk.
At beslutte, hvilket omfang der er det rigtige for et givet system, er en del af den indledende diskussion. At få det rigtige omfang er nøglen til at få maksimal forretningsværdi ud af forskningen.

Trusselsmodel

Under vores kickoff-møder med kunden definerede vi de vigtigste aktiver, som applikationen besidder.
Vi definerede, at den største aktuelle trussel mod systemet, dvss lækage af følsomme brugeroplysninger.

Lad det ikke være for sent!

Start din revision med Sayfer

Sikkerhedsvurderingsmetode

Sayfer bruger OWASP WSTG som vores tekniske standard ved gennemgang af webapplikationer. Efter at have fået en grundig forståelse af systemet besluttede vi, hvilke OWASP-tests der kræves for at evaluere systemet.

Sikkerhedsvurdering

Efter at have forstået og defineret omfanget, udført trusselsmodellering og evalueret de korrekte test, der kræves for fuldt ud at kontrollere applikationen for sikkerhedsfejl, udførte vi vores sikkerhedsvurdering.

Beskrivelse af problemtabel

Udgavetitel

ID SIGE-??: Et ID for nem kommunikation om hver sårbarhed
Status Åben/fast/Anerkendt
Risiko Repræsenterer problemets risikofaktor. For yderligere beskrivelse henvises til Sårbarheder efter risiko sektion.
Virksomhedseffekt Den største risiko for sårbarheden på forretningsniveau.
Lokation URL'en eller filen, hvor dette problem blev opdaget. Problemer uden placering har ingen bestemt placering og refererer til produktet som helhed.

Beskrivelse

Her giver vi en kort beskrivelse af problemet og hvordan det opstod, de trin, vi tog for at finde eller udnytte det, sammen med proof of concept (hvis det er til stede), og hvordan dette problem kan påvirke produktet eller dets brugere.

Mitigation

Foreslåede løsningsmuligheder for dette problem og links til anbefalede websteder for yderligere afhjælpning.

Sikkerhedsvurdering

Følgende test blev udført under revision af systemet

Information Indsamling

Information Indsamling Testnavn
WSTG-INFO-01 Udfør søgemaskineopdagelse for informationslækage
WSTG-INFO-02 Fingeraftryk webserver
WSTG-INFO-03 Gennemgå webservermetafiler for informationslækage
WSTG-INFO-04 Opregn applikationer på webserver
WSTG-INFO-05 Gennemgå websideindhold for informationslækage
WSTG-INFO-06 Identificer applikationsindgangspunkter
WSTG-INFO-07 Kortlæg udførelsesstier gennem applikationen
WSTG-INFO-08 Fingerprint Web Application Framework
WSTG-INFO-09 Webapplikation med fingeraftryk
WSTG-INFO-10 Kortapplikationsarkitektur

Konfiguration og implementering af ledelsestest

Konfiguration og implementering af ledelsestest Testnavn
WSTG-CONF-01 Test netværksinfrastrukturkonfiguration
WSTG-CONF-02 Test applikationsplatformens konfiguration
WSTG-CONF-03 Test filudvidelseshåndtering for følsomme oplysninger
WSTG-CONF-04 Gennemgå gamle sikkerhedskopier og filer uden reference for følsomme oplysninger
WSTG-CONF-05 Opregn infrastruktur- og applikationsadministrationsgrænseflader
WSTG-CONF-06 Test HTTP-metoder
WSTG-CONF-07 Test HTTP Strict Transport Security
WSTG-CONF-08 Test RIA-politik på tværs af domæner
WSTG-CONF-09 Test filtilladelse
WSTG-CONF-10 Test for subdomæneovertagelse
WSTG-CONF-11 Test Cloud Storage

Identitetsstyringstest

Identitetsstyringstest Testnavn
WSTG-IDNT-01 Testrolledefinitioner
WSTG-IDNT-02 Test brugerregistreringsproces
WSTG-IDNT-03 Test kontoprovisioneringsproces
WSTG-IDNT-04 Test for kontooptælling og gættelig brugerkonto
WSTG-IDNT-05 Tester for svag eller uhåndhævet brugernavnpolitik

Autentificeringstest

Autentificeringstest Testnavn
WSTG-ATHN-01 Test af legitimationsoplysninger transporteret over en krypteret kanal
WSTG-ATHN-02 Test for standardlegitimationsoplysninger
WSTG-ATHN-03 Test for svag låsemekanisme
WSTG-ATHN-04 Test for omgåelse af godkendelsesskema
WSTG-ATHN-05 Test for sårbare Husk adgangskode
WSTG-ATHN-06 Test for svagheder i browsercache
WSTG-ATHN-07 Test for svag adgangskodepolitik
WSTG-ATHN-08 Test for svagt sikkerhedsspørgsmål svar
WSTG-ATHN-09 Test for svag adgangskodeændring eller nulstilling af funktioner
WSTG-ATHN-10 Test for svagere autentificering i alternativ kanal

Autorisationstest

Autorisationstest Testnavn
WSTG-ATHZ-01 Test af kataloggennemløbsfil inkluderer
WSTG-ATHZ-02 Test for omgåelse af autorisationsskema
WSTG-ATHZ-03 Test for privilegie-eskalering
WSTG-ATHZ-04 Test for usikre direkte objektreferencer

Sessionsstyringstest

Sessionsstyringstest Testnavn
WSTG-SESS-01 Test for Session Management Schema
WSTG-SESS-02 Test for cookies-attributter
WSTG-SESS-03 Test for sessionsfiksering
WSTG-SESS-04 Test for eksponerede sessionsvariabler
WSTG-SESS-05 Test for forfalskning af anmodninger på tværs af websteder
WSTG-SESS-06 Test for logout funktionalitet
WSTG-SESS-07 Timeout for testsession
WSTG-SESS-08 Test for Session Puzzle
WSTG-SESS-09 Test for sessionskapring

Datavalideringstest

Datavalideringstest Testnavn
WSTG-INPV-01 Test af reflekteret scripting på tværs af websteder
WSTG-INPV-02 Test for Stored Cross Site Scripting
WSTG-INPV-03 Test af HTTP-udsagnsordsmanipulation
WSTG-INPV-04 Test for HTTP-parameterforurening
WSTG-INPV-05 Test for SQL Injection
WSTG-INPV-06 Test for LDAP-injektion
WSTG-INPV-07 Test for XML-injektion
WSTG-INPV-08 Test for SSI-injektion
WSTG-INPV-09 Test for XPath-injektion
WSTG-INPV-10 Test for IMAP SMTP-injektion
WSTG-INPV-11 Test for kodeinjektion
WSTG-INPV-12 Test for kommandoinjektion
WSTG-INPV-13 Test for Format String Injection
WSTG-INPV-14 Test for inkuberet sårbarhed
WSTG-INPV-15 Test for HTTP-smugling
WSTG-INPV-16 Test for indgående HTTP-anmodninger
WSTG-INPV-17 Test for Host Header Injection
WSTG-INPV-18 Test af skabeloninjektion på serversiden
WSTG-INPV-19 Test for server-side anmodningsforfalskning

Fejlhåndtering

Fejlhåndtering Testnavn
WSTG-ERRH-01 Test for forkert fejlhåndtering
WSTG-ERRH-02 Test af stakspor

Kryptografi

Kryptografi Testnavn
WSTG-CRYP-01 Test for svag transportlagssikkerhed
WSTG-CRYP-02 Test af polstring Oracle
WSTG-CRYP-03 Test for følsomme oplysninger sendt via ukrypterede kanaler
WSTG-CRYP-04 Test for svag kryptering

Test af forretningslogik

Test af forretningslogik Testnavn
WSTG-BUSL-01 Test Business Logic Data Validering
WSTG-BUSL-02 Test evne til at forfalske anmodninger
WSTG-BUSL-03 Test integritetstjek
WSTG-BUSL-04 Test for procestiming
WSTG-BUSL-05 Test Antal gange, en funktion kan bruges Grænser
WSTG-BUSL-06 Test for omgåelse af arbejdsgange
WSTG-BUSL-07 Test forsvar mod applikationsmisbrug
WSTG-BUSL-08 Test upload af uventede filtyper
WSTG-BUSL-09 Test upload af ondsindede filer

Test på klientsiden

Test på klientsiden Testnavn
WSTG-CLNT-01 Test af DOM-baseret Cross Site Scripting
WSTG-CLNT-02 Test af JavaScript-udførelse
WSTG-CLNT-03 Test for HTML-injektion
WSTG-CLNT-04 Test af URL-omdirigering på klientsiden
WSTG-CLNT-05 Test for CSS-injektion
WSTG-CLNT-06 Test for klientsideressourcemanipulation
WSTG-CLNT-07 Test Cross Origin-ressourcedeling
WSTG-CLNT-08 Test for Cross Site Flashing
WSTG-CLNT-09 Test for Clickjacking
WSTG-CLNT-10 Test af WebSockets
WSTG-CLNT-11 Test webmeddelelser
WSTG-CLNT-12 Test af browserlagring
WSTG-CLNT-13 Test for Cross Site Script-inkludering

API-testning

API-testning Testnavn
WSTG-APIT-01 Test af GraphQL

Bestil revision hos Sayfer

    Dette websted er beskyttet af reCAPTCHA og Google Privatlivspolitik og Servicevilkår ansøge.

    Sikkerhedsvurderingsresultater

    Ingen metode til at fjerne tilføjede netværk

    ID SIG-01
    Status Fast
    Risiko Lav
    Virksomhedseffekt Det er ikke muligt at fjerne individuelle netværk tilføjet fra snappen.
    Lokation – packages/snap/src/helpers.ts:105

    Beskrivelse

    Koden implementerer muligheden for at tilføje yderligere netværk, hvilket udvider deres liste ud over standarden. Det blev dog bemærket, at der ikke er nogen måde at fjerne dem på, undtagen ved at geninstallere snappen. Denne funktionalitet var sandsynligvis planlagt, fordi der er en removeNetwork() funktion, men det er ikke muligt at kalde den fra offentligt tilgængelige metoder.

    export const networks = {
        get: getNetworks,
        setCurrent: setCurrentNetwork,
        add: addNetwork,
        remove: removeNetwork,
    };

    Mitigation

    Vi anbefaler at implementere denne metode, som det sandsynligvis var meningen.

     

    Manglende bekræftelsesprompt for eksport af private nøgler

    ID SIG-02
    Status Fast
    Risiko Lav
    Virksomhedseffekt Risiko for at lække den private nøgle, når den ved en fejl vises på en skærm, for eksempel på et offentligt sted.
    Lokation – packages/snap/src/index.ts:145

    Beskrivelse

    I de fleste kritiske funktioner på et øjeblik vises en dialogboks, som informerer brugeren om den handling, der udføres, og anmoder om deres godkendelse.

    Denne sikkerhedsforanstaltning er dog ikke til stede i WalletExportPrivateKey-metoden, den der bruges til at vise den private nøgle på snapskærmen. Hvis den påkaldes ved en fejl, vil den straks vise den private nøgle.

    Mitigation

    Før du viser den private nøgle, skal du tilføje en bekræftelsesprompt, der anmoder om brugerens godkendelse.

     

    Flere uimplementerede metoder

    ID SIG-03
    Status Fast
    Risiko Lav
    Virksomhedseffekt Der er en risiko for, at nogle af de metoder, der ikke er implementeret, kan være vigtige for snappens funktionalitet og ved et uheld blev overset.
    Lokation – packages/snap/src/index.ts:163, 169, 260, 266, 272, 278, 284, 290, 296, 302, 308, 314, 320, 326, 472, 509, 541, 568, 574, 580, 586, 592, 609, 615, 637, 643, 649 655, 696, 735, 741, 747, 753, 759, 765, 771, 777, 783, XNUMX, XNUMX, XNUMX, XNUMX, XNUMX, XNUMX, XNUMX

    Beskrivelse

    En stor del af de metoder, der er til stede i snappet, ser ud til at være ubrugte. Kun kedelpladen omkring dem eksisterer, men ikke nogen konkret logik.

    Mitigation

    Vi anbefaler, at du gennemgår de metoder, du gerne vil implementere i dit snap, og sikrer dig, at de alle indeholder egentlig logik. Det skal ikke være muligt for brugeren at kalde unødvendige metoder, som du ikke har tænkt dig at implementere.

     

    Redundant kode

    ID SIG-04
    Status Fast
    Risiko Informational
    Virksomhedseffekt Metoder, der gør det samme og returnerer de samme data, øger unødigt størrelsen af ​​snapsens kodebase.
    Lokation – packages/snap/src/index.ts:332, 338

    Beskrivelse

    Under vores analyse har vi bemærket, at to RPC-metoder, EthRequestAccounts og EthAccounts, ser ud til at gøre det samme og returnere de samme værdier.

    case RPCMethods.EthRequestAccounts: {
        const wallet = await getWallet();
        return [wallet.address];
    }
    case RPCMethods.EthAccounts: {
        console.log('RPCMethods.EthAccounts');
        console.log('request.params', JSON.stringify(request.params));
        const wallet = await getWallet();
        return [wallet.address];
    }

    I begge tilfælde henter disse metoder den aktive tegnebogs data ved at bruge getWallet() og returnerer derefter dens adresse. I øjeblikket er den eneste forskel, at EthAccounts logger, mens EthRequestAccounts ikke gør det.

    Mitigation

    Overvej enten at fjerne en af ​​metoderne eller at ændre den ene for at adskille den fra den anden

     

    Tilbageværende TODO-kommentarer

    ID SIG-05
    Status Fast
    Risiko Informational
    Virksomhedseffekt TODO-kommentarer og kommenterede kodesektioner kan give potentielle angribere værdifuld information, udover at virke uprofessionel.
    Lokation – packages/snap/src/index.ts:460, 550
    – packages/snap/src/polyfill.ts:7
    – packages/snap/src/helpers/parsers/tx.ts:55

    Beskrivelse

    Kodebasen indeholder flere TODO-kommentarer og også dele af kommenteret kode, som ikke længere bruges.

    Selvom dette er acceptabelt i et testmiljø, bør det elimineres i produktionen. Sådanne kommentarer kan give en potentiel interessent værdifuld information om manglende funktionaliteter, sikkerhedsforanstaltninger og udvikleres tanker, som kan bruges til at profilere angreb.

    Mitigation

    Vi foreslår, at du fjerner kommentarer markeret som TODO og ubrugte kodefragmenter i din produktionsgren.

    Du kan finde mere information om det på vores blog

    Sayfers blog fokuserer på web3, sikkerhed og sårbarhedsforskning. Vi tror på, at det i cybersikkerhedsindustrien er afgørende at holde sig opdateret på de seneste trends og fremskridt. I øjeblikket nyder vores team af erfarne forskere at forske i banebrydende blockchain- og web3-teknologier.
    Kontakt os

    Hold kontakten

    Lokation
    Tel Aviv, Israel
    messengers:
    Du er velkommen til at kontakte os, vi vil med glæde svare!

      Dette websted er beskyttet af reCAPTCHA og Google Privatlivspolitik og Servicevilkår ansøge.
      Spring til indhold