macOS Gatekeeper / Quarantine / XProtect
Reading time: 22 minutes
tip
Leer & oefen AWS Hacking:HackTricks Training AWS Red Team Expert (ARTE)
Leer & oefen GCP Hacking: HackTricks Training GCP Red Team Expert (GRTE)
Ondersteun HackTricks
- Kyk na die subskripsie planne!
- Sluit aan by die đŹ Discord groep of die telegram groep of volg ons op Twitter đŠ @hacktricks_live.
- Deel hacking truuks deur PRs in te dien na die HackTricks en HackTricks Cloud github repos.
Gatekeeper
Gatekeeper is 'n sekuriteitskenmerk wat ontwikkel is vir Mac-bedryfstelsels, ontwerp om te verseker dat gebruikers slegs vertroude sagteware op hul stelsels uitvoer. Dit funksioneer deur sagteware te verifieer wat 'n gebruiker aflaai en probeer om te open vanaf bronne buite die App Store, soos 'n app, 'n plug-in, of 'n installer-pakket.
Die sleutelmeganisme van Gatekeeper lĂȘ in sy verifikasie proses. Dit kontroleer of die afgelaaide sagteware onderteken is deur 'n erkende ontwikkelaar, wat die sagteware se egtheid verseker. Verder bepaal dit of die sagteware notarised is deur Apple, wat bevestig dat dit vry is van bekende kwaadwillige inhoud en nie na notarisation gewysig is nie.
Boonop versterk Gatekeeper gebruikersbeheer en sekuriteit deur gebruikers te vra om die opening van afgelaaide sagteware vir die eerste keer goed te keur. Hierdie beskerming help om te voorkom dat gebruikers per ongeluk potensieel skadelike uitvoerbare kode uitvoer wat hulle dalk vir 'n onskadelike data-lĂȘer verwar het.
Toepassing Handtekeninge
Toepassing handtekeninge, ook bekend as kodehandtekeninge, is 'n kritieke komponent van Apple se sekuriteitsinfrastruktuur. Hulle word gebruik om die identiteit van die sagteware-outeur (die ontwikkelaar) te verifieer en om te verseker dat die kode nie gewysig is sedert dit laas onderteken is nie.
Hier is hoe dit werk:
- Ondertekening van die Toepassing: Wanneer 'n ontwikkelaar gereed is om hul toepassing te versprei, onderteken hulle die toepassing met 'n private sleutel. Hierdie private sleutel is geassosieer met 'n sertifikaat wat Apple aan die ontwikkelaar uitreik wanneer hulle in die Apple Developer Program inskryf. Die ondertekeningsproses behels die skep van 'n kriptografiese hash van al die dele van die app en die versleuteling van hierdie hash met die ontwikkelaar se private sleutel.
- Verspreiding van die Toepassing: Die ondertekende toepassing word dan aan gebruikers versprei saam met die ontwikkelaar se sertifikaat, wat die ooreenstemmende publieke sleutel bevat.
- Verifikasie van die Toepassing: Wanneer 'n gebruiker die toepassing aflaai en probeer om dit uit te voer, gebruik hul Mac-bedryfstelsel die publieke sleutel van die ontwikkelaar se sertifikaat om die hash te ontsleutel. Dit bereken dan die hash weer op grond van die huidige toestand van die toepassing en vergelyk dit met die ontsleutelde hash. As hulle ooreenstem, beteken dit die toepassing is nie gewysig nie sedert die ontwikkelaar dit onderteken het, en die stelsel laat die toepassing toe om uit te voer.
Toepassing handtekeninge is 'n noodsaaklike deel van Apple se Gatekeeper-tegnologie. Wanneer 'n gebruiker probeer om 'n toepassing wat van die internet afgelaai is, te open, verifieer Gatekeeper die toepassing handtekening. As dit onderteken is met 'n sertifikaat wat deur Apple aan 'n bekende ontwikkelaar uitgereik is en die kode nie gewysig is nie, laat Gatekeeper die toepassing toe om uit te voer. Andersins blokkeer dit die toepassing en waarsku die gebruiker.
Vanaf macOS Catalina, kontroleer Gatekeeper ook of die toepassing notarised is deur Apple, wat 'n ekstra laag van sekuriteit toevoeg. Die notarisation proses kontroleer die toepassing vir bekende sekuriteitskwessies en kwaadwillige kode, en as hierdie kontroles slaag, voeg Apple 'n kaartjie by die toepassing wat Gatekeeper kan verifieer.
Kontroleer Handtekeninge
Wanneer jy 'n malware monster kontroleer, moet jy altyd die handtekening van die binĂȘre kontroleer, aangesien die ontwikkelaar wat dit onderteken het dalk reeds verbonde is met malware.
# Get signer
codesign -vv -d /bin/ls 2>&1 | grep -E "Authority|TeamIdentifier"
# Check if the appâs contents have been modified
codesign --verify --verbose /Applications/Safari.app
# Get entitlements from the binary
codesign -d --entitlements :- /System/Applications/Automator.app # Check the TCC perms
# Check if the signature is valid
spctl --assess --verbose /Applications/Safari.app
# Sign a binary
codesign -s <cert-name-keychain> toolsdemo
Notarization
Apple se notarization proses dien as 'n addisionele beskerming om gebruikers te beskerm teen potensieel skadelike sagteware. Dit behels die ontwikkelaar wat hul aansoek indien vir ondersoek deur Apple se Notary Service, wat nie verwar moet word met App Review nie. Hierdie diens is 'n geoutomatiseerde stelsel wat die ingediende sagteware ondersoek vir die teenwoordigheid van skadelike inhoud en enige potensiële probleme met kode-handtekening.
As die sagteware slaag vir hierdie inspeksie sonder om enige bekommernisse te wek, genereer die Notary Service 'n notarization kaartjie. Die ontwikkelaar moet dan hierdie kaartjie aan hul sagteware heg, 'n proses bekend as 'stapling.' Verder word die notarization kaartjie ook aanlyn gepubliseer waar Gatekeeper, Apple se sekuriteitstegnologie, dit kan toegang.
By die gebruiker se eerste installasie of uitvoering van die sagteware, informeer die bestaan van die notarization kaartjie - of dit aan die uitvoerbare geheg is of aanlyn gevind word - Gatekeeper dat die sagteware deur Apple genotariseer is. As gevolg hiervan vertoon Gatekeeper 'n beskrywende boodskap in die aanvanklike lanseringsdialoog, wat aandui dat die sagteware onderhewig was aan kontrole vir skadelike inhoud deur Apple. Hierdie proses verbeter dus die gebruiker se vertroue in die sekuriteit van die sagteware wat hulle op hul stelsels installeer of uitvoer.
spctl & syspolicyd
caution
Let daarop dat vanaf Sequoia weergawe, spctl
nie meer toelaat om Gatekeeper konfigurasie te wysig nie.
spctl
is die CLI-gereedskap om te tel en te kommunikeer met Gatekeeper (met die syspolicyd
daemon via XPC boodskappe). Byvoorbeeld, dit is moontlik om die status van GateKeeper te sien met:
# Check the status
spctl --status
caution
Let daarop dat GateKeeper-handtekeningkontroles slegs uitgevoer word op lĂȘers met die Quarantine-attribuut, nie op elke lĂȘer nie.
GateKeeper sal nagaan of 'n binĂȘre volgens die voorkeure & die handtekening uitgevoer kan word:
syspolicyd
is die hoofdaemon wat verantwoordelik is vir die afdwinging van Gatekeeper. Dit hou 'n databasis in /var/db/SystemPolicy
en dit is moontlik om die kode te vind om die databasis hier te ondersteun en die SQL-sjabloon hier. Let daarop dat die databasis nie deur SIP beperk is nie en skryfbaar is deur root, en die databasis /var/db/.SystemPolicy-default
word as 'n oorspronklike rugsteun gebruik in die geval dat die ander beskadig raak.
Boonop bevat die bundels /var/db/gke.bundle
en /var/db/gkopaque.bundle
lĂȘers met reĂ«ls wat in die databasis ingevoeg word. Jy kan hierdie databasis as root nagaan met:
# Open database
sqlite3 /var/db/SystemPolicy
# Get allowed rules
SELECT requirement,allow,disabled,label from authority where label != 'GKE' and disabled=0;
requirement|allow|disabled|label
anchor apple generic and certificate 1[subject.CN] = "Apple Software Update Certification Authority"|1|0|Apple Installer
anchor apple|1|0|Apple System
anchor apple generic and certificate leaf[field.1.2.840.113635.100.6.1.9] exists|1|0|Mac App Store
anchor apple generic and certificate 1[field.1.2.840.113635.100.6.2.6] exists and (certificate leaf[field.1.2.840.113635.100.6.1.14] or certificate leaf[field.1.2.840.113635.100.6.1.13]) and notarized|1|0|Notarized Developer ID
[...]
syspolicyd
stel ook 'n XPC-bediener bloot met verskillende operasies soos assess
, update
, record
en cancel
wat ook bereik kan word met Security.framework
se SecAssessment*
API's en xpctl
praat eintlik met syspolicyd
via XPC.
Let op hoe die eerste reël eindig in "App Store" en die tweede een in "Developer ID" en dat dit in die vorige beeld geaktiveer was om aansoeke van die App Store en geïdentifiseerde ontwikkelaars uit te voer.
As jy daardie instelling na App Store wysig, sal die "Notarized Developer ID" reëls verdwyn.
Daar is ook duisende reëls van type GKE :
SELECT requirement,allow,disabled,label from authority where label = 'GKE' limit 5;
cdhash H"b40281d347dc574ae0850682f0fd1173aa2d0a39"|1|0|GKE
cdhash H"5fd63f5342ac0c7c0774ebcbecaf8787367c480f"|1|0|GKE
cdhash H"4317047eefac8125ce4d44cab0eb7b1dff29d19a"|1|0|GKE
cdhash H"0a71962e7a32f0c2b41ddb1fb8403f3420e1d861"|1|0|GKE
cdhash H"8d0d90ff23c3071211646c4c9c607cdb601cb18f"|1|0|GKE
Dit is hashes wat afkomstig is van:
/var/db/SystemPolicyConfiguration/gke.bundle/Contents/Resources/gke.auth
/var/db/gke.bundle/Contents/Resources/gk.db
/var/db/gkopaque.bundle/Contents/Resources/gkopaque.db
Of jy kan die vorige inligting lys met:
sudo spctl --list
Die opsies --master-disable
en --global-disable
van spctl
sal hierdie handtekening kontroles heeltemal deaktiveer:
# Disable GateKeeper
spctl --global-disable
spctl --master-disable
# Enable it
spctl --global-enable
spctl --master-enable
Wanneer dit heeltemal geaktiveer is, sal 'n nuwe opsie verskyn:
Dit is moontlik om te kontroleer of 'n App deur GateKeeper toegelaat sal word met:
spctl --assess -v /Applications/App.app
Dit is moontlik om nuwe reëls in GateKeeper by te voeg om die uitvoering van sekere toepassings toe te laat met:
# Check if allowed - nop
spctl --assess -v /Applications/App.app
/Applications/App.app: rejected
source=no usable signature
# Add a label and allow this label in GateKeeper
sudo spctl --add --label "whitelist" /Applications/App.app
sudo spctl --enable --label "whitelist"
# Check again - yep
spctl --assess -v /Applications/App.app
/Applications/App.app: accepted
Betreffende kernel uitbreidings, die gids /var/db/SystemPolicyConfiguration
bevat lĂȘers met lyste van kexts wat toegelaat word om gelaai te word. Boonop het spctl
die regte com.apple.private.iokit.nvram-csr
omdat dit in staat is om nuwe vooraf-goedgekeurde kernel uitbreidings by te voeg wat ook in NVRAM in 'n kext-allowed-teams
sleutel gestoor moet word.
Karantyn LĂȘers
By aflaai van 'n toepassing of lĂȘer, heg spesifieke macOS toepassings soos webblaaiers of e-pos kliĂ«nte 'n uitgebreide lĂȘer eienskap aan, algemeen bekend as die "karantyn vlag," aan die afgelaaide lĂȘer. Hierdie eienskap dien as 'n sekuriteitsmaatreĂ«l om die lĂȘer te merk as afkomstig van 'n onbetroubare bron (die internet), en potensieel risiko's dra. egter, nie alle toepassings heg hierdie eienskap aan nie, byvoorbeeld, algemene BitTorrent kliĂ«nt sagteware omseil gewoonlik hierdie proses.
Die teenwoordigheid van 'n karantyn vlag dui op macOS se Gatekeeper sekuriteitskenmerk wanneer 'n gebruiker probeer om die lĂȘer uit te voer.
In die geval waar die karantyn vlag nie teenwoordig is nie (soos met lĂȘers afgelaai via sommige BitTorrent kliĂ«nte), mag Gatekeeper se kontroles nie uitgevoer word nie. Dus, gebruikers moet versigtig wees wanneer hulle lĂȘers van minder veilige of onbekende bronne oopmaak.
[!NOTE] > Kontroleer die geldigheid van kode handtekeninge is 'n hulpbron-intensiewe proses wat die generering van kriptografiese hashes van die kode en al sy saamgebonde hulpbronne insluit. Verder behels die kontrole van sertifikaat geldigheid 'n aanlyn kontrole teen Apple se bedieners om te sien of dit herroep is nadat dit uitgereik is. Om hierdie redes is 'n volledige kode handtekening en notarization kontrole onprakties om elke keer uit te voer wanneer 'n app gelaai word.
Daarom word hierdie kontroles slegs uitgevoer wanneer toepassings met die karantyn eienskap uitgevoer word.
warning
Hierdie eienskap moet gestel word deur die toepassing wat die lĂȘer skep/aflaai.
egter, lĂȘers wat in 'n sandbox is, sal hierdie eienskap op elke lĂȘer wat hulle skep, stel. En nie-sandboxed toepassings kan dit self stel, of die LSFileQuarantineEnabled sleutel in die Info.plist spesifiseer wat die stelsel sal laat die com.apple.quarantine
uitgebreide eienskap op die geskepte lĂȘers stel,
Boonop is alle lĂȘers wat deur 'n proses wat qtn_proc_apply_to_self
aanroep, in karantyn. Of die API qtn_file_apply_to_path
voeg die karantyn eienskap by 'n gespesifiseerde lĂȘer pad.
Dit is moontlik om sy status te kontroleer en in/uit te skakel (root benodig) met:
spctl --status
assessments enabled
spctl --enable
spctl --disable
#You can also allow nee identifies to execute code using the binary "spctl"
Jy kan ook vind of 'n lĂȘer die kwarantyn-uitgebreide attribuut het met:
xattr file.png
com.apple.macl
com.apple.quarantine
Kontroleer die waarde van die verlengde kenmerke en vind die toepassing wat die kwarantyn kenmerk geskryf het met:
xattr -l portada.png
com.apple.macl:
00000000 03 00 53 DA 55 1B AE 4C 4E 88 9D CA B7 5C 50 F3 |..S.U..LN.....P.|
00000010 16 94 03 00 27 63 64 97 98 FB 4F 02 84 F3 D0 DB |....'cd...O.....|
00000020 89 53 C3 FC 03 00 27 63 64 97 98 FB 4F 02 84 F3 |.S....'cd...O...|
00000030 D0 DB 89 53 C3 FC 00 00 00 00 00 00 00 00 00 00 |...S............|
00000040 00 00 00 00 00 00 00 00 |........|
00000048
com.apple.quarantine: 00C1;607842eb;Brave;F643CD5F-6071-46AB-83AB-390BA944DEC5
# 00c1 -- It has been allowed to eexcute this file (QTN_FLAG_USER_APPROVED = 0x0040)
# 607842eb -- Timestamp
# Brave -- App
# F643CD5F-6071-46AB-83AB-390BA944DEC5 -- UID assigned to the file downloaded
Werklik kan 'n proses "kwarantynvlagte op die lĂȘers wat dit skep, stel" (Ek het reeds probeer om die USER_APPROVED-vlag in 'n geskepte lĂȘer toe te pas, maar dit sal nie toegepas word nie):
Bronkode pas kwarantynvlagte toe
#include <stdio.h>
#include <stdlib.h>
enum qtn_flags {
QTN_FLAG_DOWNLOAD = 0x0001,
QTN_FLAG_SANDBOX = 0x0002,
QTN_FLAG_HARD = 0x0004,
QTN_FLAG_USER_APPROVED = 0x0040,
};
#define qtn_proc_alloc _qtn_proc_alloc
#define qtn_proc_apply_to_self _qtn_proc_apply_to_self
#define qtn_proc_free _qtn_proc_free
#define qtn_proc_init _qtn_proc_init
#define qtn_proc_init_with_self _qtn_proc_init_with_self
#define qtn_proc_set_flags _qtn_proc_set_flags
#define qtn_file_alloc _qtn_file_alloc
#define qtn_file_init_with_path _qtn_file_init_with_path
#define qtn_file_free _qtn_file_free
#define qtn_file_apply_to_path _qtn_file_apply_to_path
#define qtn_file_set_flags _qtn_file_set_flags
#define qtn_file_get_flags _qtn_file_get_flags
#define qtn_proc_set_identifier _qtn_proc_set_identifier
typedef struct _qtn_proc *qtn_proc_t;
typedef struct _qtn_file *qtn_file_t;
int qtn_proc_apply_to_self(qtn_proc_t);
void qtn_proc_init(qtn_proc_t);
int qtn_proc_init_with_self(qtn_proc_t);
int qtn_proc_set_flags(qtn_proc_t, uint32_t flags);
qtn_proc_t qtn_proc_alloc();
void qtn_proc_free(qtn_proc_t);
qtn_file_t qtn_file_alloc(void);
void qtn_file_free(qtn_file_t qf);
int qtn_file_set_flags(qtn_file_t qf, uint32_t flags);
uint32_t qtn_file_get_flags(qtn_file_t qf);
int qtn_file_apply_to_path(qtn_file_t qf, const char *path);
int qtn_file_init_with_path(qtn_file_t qf, const char *path);
int qtn_proc_set_identifier(qtn_proc_t qp, const char* bundleid);
int main() {
qtn_proc_t qp = qtn_proc_alloc();
qtn_proc_set_identifier(qp, "xyz.hacktricks.qa");
qtn_proc_set_flags(qp, QTN_FLAG_DOWNLOAD | QTN_FLAG_USER_APPROVED);
qtn_proc_apply_to_self(qp);
qtn_proc_free(qp);
FILE *fp;
fp = fopen("thisisquarantined.txt", "w+");
fprintf(fp, "Hello Quarantine\n");
fclose(fp);
return 0;
}
En verwyder daardie attribuut met:
xattr -d com.apple.quarantine portada.png
#You can also remove this attribute from every file with
find . -iname '*' -print0 | xargs -0 xattr -d com.apple.quarantine
En vind al die karantynlĂȘers met:
find / -exec ls -ld {} \; 2>/dev/null | grep -E "[x\-]@ " | awk '{printf $9; printf "\n"}' | xargs -I {} xattr -lv {} | grep "com.apple.quarantine"
Quarantynasie-inligting word ook in 'n sentrale databasis gestoor wat deur LaunchServices bestuur word in ~/Library/Preferences/com.apple.LaunchServices.QuarantineEventsV2
, wat die GUI toelaat om data oor die lĂȘer oorspronge te verkry. Boonop kan dit oorgeskryf word deur toepassings wat dalk belangstel om sy oorspronge te verberg. Boonop kan dit vanaf LaunchServices APIS gedoen word.
libquarantine.dylb
Hierdie biblioteek voer verskeie funksies uit wat toelaat om die uitgebreide attribuut velde te manipuleer.
Die qtn_file_*
APIs handel met lĂȘer quarantynbeleid, die qtn_proc_*
APIs word toegepas op prosesse (lĂȘers geskep deur die proses). Die nie-uitgevoerde __qtn_syscall_quarantine*
funksies is diegene wat die beleid toepas wat mac_syscall
met "Quarantine" as eerste argument aanroep wat die versoeke na Quarantine.kext
stuur.
Quarantine.kext
Die kernuitbreiding is slegs beskikbaar deur die kernkas op die stelsel; egter, jy kan die Kernel Debug Kit van https://developer.apple.com/ aflaai, wat 'n gesimboliseerde weergawe van die uitbreiding sal bevat.
Hierdie Kext sal via MACF verskeie oproepe haak om alle lĂȘer lewensiklus gebeurtenisse te vang: Skepping, opening, hernoeming, hard-koppeling... selfs setxattr
om te voorkom dat dit die com.apple.quarantine
uitgebreide attribuut stel.
Dit gebruik ook 'n paar MIBs:
security.mac.qtn.sandbox_enforce
: Handhaaf quarantyn langs Sandboxsecurity.mac.qtn.user_approved_exec
: Quarantined prosesse kan slegs goedgekeurde lĂȘers uitvoer
XProtect
XProtect is 'n ingeboude anti-malware kenmerk in macOS. XProtect kontroleer enige toepassing wanneer dit eerste keer gelaai of gewysig word teen sy databasis van bekende malware en onveilige lĂȘertipes. Wanneer jy 'n lĂȘer aflaai deur sekere toepassings, soos Safari, Mail, of Messages, skandeer XProtect outomaties die lĂȘer. As dit ooreenstem met enige bekende malware in sy databasis, sal XProtect verhoed dat die lĂȘer loop en jou waarsku oor die bedreiging.
Die XProtect databasis word gereeld opgedateer deur Apple met nuwe malware definisies, en hierdie opdaterings word outomaties afgelaai en op jou Mac geĂŻnstalleer. Dit verseker dat XProtect altyd op datum is met die nuutste bekende bedreigings.
Dit is egter die moeite werd om te noem dat XProtect nie 'n volwaardige antivirusoplossing is nie. Dit kontroleer slegs vir 'n spesifieke lys van bekende bedreigings en voer nie op-toegang skandering uit soos die meeste antivirusprogrammatuur nie.
Jy kan inligting oor die nuutste XProtect-opdatering verkry deur:
system_profiler SPInstallHistoryDataType 2>/dev/null | grep -A 4 "XProtectPlistConfigData" | tail -n 5
XProtect is geleë op. SIP beskermde ligging by /Library/Apple/System/Library/CoreServices/XProtect.bundle en binne die bundel kan jy inligting vind wat XProtect gebruik:
XProtect.bundle/Contents/Resources/LegacyEntitlementAllowlist.plist
: Laat kode met daardie cdhashes toe om legacy regte te gebruik.XProtect.bundle/Contents/Resources/XProtect.meta.plist
: Lys van plugins en uitbreidings wat nie toegelaat word om te laai via BundleID en TeamID of wat 'n minimum weergawe aandui nie.XProtect.bundle/Contents/Resources/XProtect.yara
: Yara reëls om malware te detecteer.XProtect.bundle/Contents/Resources/gk.db
: SQLite3 databasis met hashes van geblokkeerde toepassings en TeamIDs.
Let daarop dat daar 'n ander App in /Library/Apple/System/Library/CoreServices/XProtect.app
is wat verband hou met XProtect wat nie betrokke is by die Gatekeeper-proses nie.
Nie Gatekeeper nie
caution
Let daarop dat Gatekeeper nie elke keer uitgevoer word wanneer jy 'n toepassing uitvoer nie, net AppleMobileFileIntegrity (AMFI) sal slegs uitvoerbare kode handtekeninge verifieer wanneer jy 'n app uitvoer wat reeds deur Gatekeeper uitgevoer en geverifieer is.
Daarom was dit voorheen moontlik om 'n app uit te voer om dit met Gatekeeper te kas, dan nie-uitvoerbare lĂȘers van die toepassing te wysig (soos Electron asar of NIB lĂȘers) en as daar geen ander beskermings in plek was nie, is die toepassing uitgevoer met die kwaadwillige toevoegings.
Nou is dit egter nie meer moontlik nie omdat macOS wysig lĂȘers binne toepassingsbundels voorkom. So, as jy die Dirty NIB aanval probeer, sal jy vind dat dit nie meer moontlik is om dit te misbruik nie omdat jy, nadat jy die app uitgevoer het om dit met Gatekeeper te kas, nie die bundel kan wysig nie. En as jy byvoorbeeld die naam van die Contents-gids na NotCon verander (soos aangedui in die exploit), en dan die hoof binĂȘre van die app uitvoer om dit met Gatekeeper te kas, sal dit 'n fout veroorsaak en nie uitvoer nie.
Gatekeeper Omseilings
Enige manier om Gatekeeper te omseil (om te regverdig dat die gebruiker iets aflaai en dit uitvoer wanneer Gatekeeper dit sou verhoed) word beskou as 'n kwesbaarheid in macOS. Dit is 'n paar CVE's wat aan tegnieke toegeken is wat in die verlede toegelaat het om Gatekeeper te omseil:
CVE-2021-1810
Daar is waargeneem dat as die Archive Utility vir ekstraksie gebruik word, lĂȘers met pade wat 886 karakters oorskry nie die com.apple.quarantine uitgebreide attribuut ontvang nie. Hierdie situasie laat onbedoeld toe dat daardie lĂȘers Gatekeeper se sekuriteitskontroles omseil.
Kyk na die oorspronklike verslag vir meer inligting.
CVE-2021-30990
Wanneer 'n toepassing geskep word met Automator, is die inligting oor wat dit benodig om uit te voer binne application.app/Contents/document.wflow
en nie in die uitvoerbare nie. Die uitvoerbare is net 'n generiese Automator binĂȘre genaamd Automator Application Stub.
Daarom kon jy application.app/Contents/MacOS/Automator\ Application\ Stub
met 'n simboliese skakel na 'n ander Automator Application Stub binne die stelsel laat wys en dit sal uitvoer wat binne document.wflow
(jou skrip) is sonder om Gatekeeper te aktiveer omdat die werklike uitvoerbare nie die kwarantyn xattr het nie.
Voorbeeld van verwagte ligging: /System/Library/CoreServices/Automator\ Application\ Stub.app/Contents/MacOS/Automator\ Application\ Stub
Kyk na die oorspronklike verslag vir meer inligting.
CVE-2022-22616
In hierdie omseiling is 'n zip-lĂȘer geskep met 'n toepassing wat begin om te komprimeer vanaf application.app/Contents
in plaas van application.app
. Daarom is die kwarantyn attribuut op al die lĂȘers van application.app/Contents
toegepas maar nie op application.app
nie, wat was wat Gatekeeper nagegaan het, so Gatekeeper is omseil omdat wanneer application.app
geaktiveer is, dit nie die kwarantyn attribuut gehad het nie.
zip -r test.app/Contents test.zip
Kontroleer die oorspronklike verslag vir meer inligting.
CVE-2022-32910
Selfs al is die komponente verskillend, is die uitbuiting van hierdie kwesbaarheid baie soortgelyk aan die vorige een. In hierdie geval sal ons 'n Apple-argief genereer vanaf application.app/Contents
sodat application.app
nie die kwarantyn-attribuut sal ontvang wanneer dit deur Archive Utility uitgepak word.
aa archive -d test.app/Contents -o test.app.aar
Kontroleer die oorspronklike verslag vir meer inligting.
CVE-2022-42821
Die ACL writeextattr
kan gebruik word om te verhoed dat iemand 'n attribuut in 'n lĂȘer skryf:
touch /tmp/no-attr
chmod +a "everyone deny writeextattr" /tmp/no-attr
xattr -w attrname vale /tmp/no-attr
xattr: [Errno 13] Permission denied: '/tmp/no-attr'
Boonop, AppleDouble lĂȘerformaat kopieer 'n lĂȘer insluitend sy ACEs.
In die bronkode is dit moontlik om te sien dat die ACL teksverteenwoordiging wat binne die xattr genaamd com.apple.acl.text
gestoor is, as ACL in die gedecomprimeerde lĂȘer gestel gaan word. So, as jy 'n toepassing in 'n zip-lĂȘer met AppleDouble lĂȘerformaat gekompresseer het met 'n ACL wat voorkom dat ander xattrs daarin geskryf word... was die kwarantyn xattr nie in die toepassing gestel nie:
chmod +a "everyone deny write,writeattr,writeextattr" /tmp/test
ditto -c -k test test.zip
python3 -m http.server
# Download the zip from the browser and decompress it, the file should be without a quarantine xattr
Kontroleer die oorspronklike verslag vir meer inligting.
Let daarop dat dit ook met AppleArchives uitgebuit kan word:
mkdir app
touch app/test
chmod +a "everyone deny write,writeattr,writeextattr" app/test
aa archive -d app -o test.aar
CVE-2023-27943
Daar is ontdek dat Google Chrome nie die kwarantyn-attribuut aan afgelaaide lĂȘers toegeken het nie weens sommige macOS interne probleme.
CVE-2023-27951
AppleDouble lĂȘerformate stoor die attribuut van 'n lĂȘer in 'n aparte lĂȘer wat begin met ._
, dit help om lĂȘerattribuut oor macOS masjiene te kopieer. Dit is egter opgemerk dat na die dekompressie van 'n AppleDouble lĂȘer, die lĂȘer wat met ._
begin nie die kwarantyn-attribuut ontvang het nie.
mkdir test
echo a > test/a
echo b > test/b
echo ._a > test/._a
aa archive -d test/ -o test.aar
# If you downloaded the resulting test.aar and decompress it, the file test/._a won't have a quarantitne attribute
Die vermoĂ« om 'n lĂȘer te skep wat nie die kwarantyn-attribuut sal hĂȘ nie, het dit moontlik gemaak om Gatekeeper te omseil. Die truuk was om 'n DMG-lĂȘer toepassing te skep met die AppleDouble naam konvensie (begin dit met ._
) en 'n sigbare lĂȘer as 'n sim link na hierdie versteekte lĂȘer te skep sonder die kwarantyn-attribuut.
Wanneer die dmg-lĂȘer uitgevoer word, sal dit, aangesien dit nie 'n kwarantyn-attribuut het nie, Gatekeeper omseil.
# Create an app bundle with the backdoor an call it app.app
echo "[+] creating disk image with app"
hdiutil create -srcfolder app.app app.dmg
echo "[+] creating directory and files"
mkdir
mkdir -p s/app
cp app.dmg s/app/._app.dmg
ln -s ._app.dmg s/app/app.dmg
echo "[+] compressing files"
aa archive -d s/ -o app.aar
uchg (uit hierdie praatjie)
- Skep 'n gids wat 'n app bevat.
- Voeg uchg by die app.
- Komprimeer die app na 'n tar.gz-lĂȘer.
- Stuur die tar.gz-lĂȘer na 'n slagoffer.
- Die slagoffer open die tar.gz-lĂȘer en voer die app uit.
- Gatekeeper kontroleer nie die app nie.
Voorkom Quarantine xattr
In 'n ".app" bundel, as die quarantine xattr nie daaraan bygevoeg word nie, wanneer dit uitgevoer word sal Gatekeeper nie geaktiveer word.
tip
Leer & oefen AWS Hacking:HackTricks Training AWS Red Team Expert (ARTE)
Leer & oefen GCP Hacking: HackTricks Training GCP Red Team Expert (GRTE)
Ondersteun HackTricks
- Kyk na die subskripsie planne!
- Sluit aan by die đŹ Discord groep of die telegram groep of volg ons op Twitter đŠ @hacktricks_live.
- Deel hacking truuks deur PRs in te dien na die HackTricks en HackTricks Cloud github repos.