index.html 160 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053305430553056305730583059306030613062306330643065306630673068306930703071307230733074307530763077307830793080308130823083308430853086308730883089309030913092309330943095309630973098309931003101310231033104310531063107310831093110311131123113311431153116311731183119312031213122312331243125312631273128312931303131313231333134313531363137313831393140314131423143314431453146314731483149315031513152315331543155315631573158315931603161316231633164316531663167316831693170317131723173317431753176317731783179318031813182318331843185318631873188318931903191319231933194319531963197319831993200320132023203320432053206320732083209321032113212321332143215321632173218321932203221322232233224322532263227322832293230323132323233323432353236323732383239324032413242324332443245324632473248324932503251325232533254325532563257325832593260326132623263326432653266326732683269327032713272327332743275327632773278327932803281328232833284328532863287328832893290329132923293329432953296329732983299330033013302330333043305330633073308330933103311331233133314331533163317331833193320332133223323332433253326332733283329333033313332333333343335333633373338333933403341334233433344334533463347334833493350335133523353335433553356335733583359336033613362336333643365336633673368336933703371337233733374337533763377337833793380338133823383338433853386338733883389339033913392339333943395339633973398339934003401340234033404340534063407340834093410341134123413341434153416341734183419342034213422342334243425342634273428342934303431343234333434343534363437343834393440344134423443344434453446344734483449345034513452345334543455345634573458345934603461346234633464346534663467346834693470347134723473347434753476347734783479348034813482348334843485348634873488348934903491349234933494349534963497349834993500350135023503350435053506350735083509351035113512351335143515351635173518351935203521352235233524352535263527352835293530353135323533353435353536353735383539354035413542354335443545354635473548354935503551355235533554355535563557355835593560356135623563356435653566356735683569357035713572357335743575357635773578357935803581358235833584358535863587358835893590359135923593359435953596359735983599360036013602360336043605360636073608360936103611361236133614361536163617361836193620362136223623362436253626362736283629363036313632363336343635363636373638363936403641364236433644364536463647364836493650365136523653365436553656365736583659366036613662366336643665366636673668366936703671367236733674367536763677367836793680368136823683368436853686368736883689369036913692369336943695369636973698369937003701370237033704370537063707370837093710371137123713371437153716371737183719372037213722372337243725372637273728372937303731373237333734373537363737373837393740374137423743374437453746374737483749375037513752375337543755375637573758375937603761376237633764376537663767376837693770377137723773377437753776377737783779378037813782378337843785378637873788378937903791379237933794379537963797379837993800380138023803380438053806380738083809381038113812381338143815381638173818381938203821382238233824382538263827382838293830383138323833383438353836383738383839384038413842384338443845384638473848384938503851385238533854385538563857385838593860386138623863386438653866386738683869387038713872387338743875387638773878387938803881388238833884388538863887388838893890389138923893389438953896389738983899390039013902390339043905390639073908390939103911391239133914391539163917391839193920392139223923392439253926392739283929393039313932393339343935393639373938393939403941394239433944394539463947394839493950395139523953395439553956395739583959396039613962396339643965396639673968396939703971397239733974397539763977397839793980398139823983398439853986398739883989399039913992399339943995399639973998399940004001400240034004400540064007400840094010401140124013401440154016401740184019402040214022402340244025402640274028402940304031403240334034403540364037403840394040404140424043404440454046404740484049405040514052405340544055405640574058405940604061406240634064406540664067406840694070407140724073407440754076407740784079408040814082408340844085408640874088408940904091409240934094409540964097409840994100410141024103410441054106410741084109411041114112411341144115411641174118411941204121412241234124412541264127412841294130413141324133413441354136413741384139414041414142414341444145414641474148414941504151415241534154415541564157415841594160416141624163416441654166416741684169417041714172417341744175417641774178417941804181418241834184418541864187418841894190419141924193419441954196419741984199420042014202420342044205420642074208420942104211421242134214421542164217421842194220422142224223422442254226422742284229423042314232423342344235423642374238423942404241424242434244424542464247424842494250425142524253425442554256425742584259426042614262426342644265426642674268426942704271427242734274427542764277427842794280428142824283428442854286428742884289429042914292429342944295429642974298429943004301430243034304430543064307430843094310431143124313431443154316431743184319432043214322432343244325432643274328432943304331433243334334433543364337433843394340434143424343434443454346434743484349435043514352435343544355435643574358435943604361436243634364436543664367436843694370437143724373437443754376437743784379438043814382438343844385438643874388438943904391439243934394439543964397439843994400440144024403440444054406440744084409441044114412441344144415441644174418441944204421442244234424442544264427442844294430443144324433443444354436443744384439444044414442444344444445444644474448444944504451445244534454445544564457445844594460446144624463446444654466446744684469447044714472447344744475447644774478447944804481448244834484448544864487448844894490449144924493449444954496449744984499450045014502450345044505450645074508450945104511451245134514451545164517451845194520452145224523452445254526452745284529453045314532453345344535453645374538453945404541454245434544454545464547454845494550455145524553455445554556455745584559456045614562456345644565456645674568456945704571457245734574457545764577457845794580458145824583458445854586458745884589459045914592459345944595459645974598459946004601460246034604460546064607460846094610461146124613461446154616461746184619462046214622462346244625462646274628462946304631463246334634463546364637463846394640464146424643464446454646464746484649465046514652465346544655465646574658465946604661466246634664466546664667466846694670467146724673467446754676467746784679468046814682468346844685468646874688468946904691469246934694469546964697469846994700470147024703470447054706470747084709471047114712471347144715471647174718471947204721472247234724472547264727472847294730473147324733473447354736473747384739474047414742474347444745474647474748474947504751475247534754475547564757475847594760476147624763476447654766476747684769477047714772477347744775477647774778477947804781478247834784478547864787478847894790479147924793479447954796479747984799480048014802480348044805480648074808480948104811481248134814481548164817481848194820482148224823482448254826482748284829483048314832483348344835483648374838483948404841484248434844484548464847484848494850485148524853485448554856485748584859486048614862486348644865486648674868486948704871487248734874487548764877487848794880488148824883488448854886488748884889489048914892489348944895489648974898489949004901490249034904490549064907490849094910491149124913491449154916491749184919492049214922492349244925492649274928492949304931493249334934493549364937493849394940494149424943494449454946494749484949495049514952495349544955495649574958495949604961496249634964496549664967496849694970497149724973497449754976497749784979498049814982498349844985498649874988498949904991499249934994499549964997499849995000500150025003500450055006500750085009501050115012501350145015501650175018501950205021502250235024502550265027502850295030503150325033503450355036503750385039504050415042504350445045504650475048504950505051505250535054505550565057505850595060506150625063506450655066506750685069507050715072507350745075507650775078507950805081508250835084508550865087508850895090509150925093509450955096509750985099510051015102510351045105510651075108510951105111511251135114511551165117511851195120512151225123512451255126512751285129513051315132513351345135513651375138513951405141514251435144514551465147514851495150515151525153515451555156515751585159516051615162516351645165516651675168516951705171517251735174517551765177517851795180518151825183518451855186518751885189519051915192519351945195519651975198519952005201520252035204520552065207520852095210521152125213521452155216521752185219522052215222522352245225522652275228522952305231523252335234523552365237523852395240524152425243524452455246524752485249525052515252525352545255525652575258525952605261526252635264526552665267526852695270527152725273527452755276527752785279528052815282528352845285528652875288528952905291529252935294529552965297529852995300530153025303530453055306530753085309531053115312531353145315531653175318531953205321532253235324532553265327532853295330533153325333533453355336533753385339534053415342534353445345534653475348534953505351535253535354535553565357535853595360536153625363536453655366536753685369537053715372537353745375537653775378537953805381538253835384538553865387538853895390539153925393539453955396539753985399540054015402540354045405540654075408540954105411541254135414541554165417541854195420542154225423542454255426542754285429543054315432543354345435543654375438543954405441544254435444544554465447544854495450545154525453545454555456545754585459546054615462546354645465546654675468546954705471547254735474547554765477547854795480548154825483548454855486548754885489549054915492549354945495549654975498549955005501550255035504550555065507550855095510551155125513551455155516551755185519552055215522552355245525552655275528552955305531553255335534553555365537553855395540554155425543554455455546554755485549555055515552555355545555555655575558555955605561556255635564556555665567556855695570557155725573557455755576557755785579558055815582558355845585558655875588558955905591559255935594559555965597559855995600560156025603560456055606560756085609561056115612561356145615561656175618561956205621562256235624562556265627562856295630563156325633563456355636563756385639564056415642564356445645564656475648564956505651565256535654565556565657565856595660566156625663566456655666566756685669567056715672567356745675567656775678567956805681568256835684568556865687568856895690569156925693569456955696569756985699570057015702570357045705570657075708570957105711571257135714571557165717571857195720572157225723572457255726572757285729573057315732573357345735573657375738573957405741574257435744574557465747574857495750575157525753575457555756575757585759576057615762576357645765576657675768576957705771577257735774577557765777577857795780578157825783578457855786578757885789579057915792579357945795579657975798579958005801580258035804580558065807580858095810581158125813581458155816581758185819582058215822582358245825582658275828582958305831583258335834583558365837583858395840584158425843584458455846584758485849585058515852585358545855585658575858585958605861586258635864586558665867586858695870587158725873587458755876587758785879588058815882588358845885588658875888588958905891589258935894589558965897589858995900590159025903590459055906590759085909591059115912591359145915591659175918591959205921592259235924592559265927592859295930593159325933593459355936593759385939594059415942594359445945594659475948594959505951595259535954595559565957595859595960596159625963596459655966596759685969597059715972597359745975597659775978597959805981598259835984598559865987598859895990599159925993599459955996599759985999600060016002600360046005600660076008600960106011601260136014601560166017601860196020602160226023602460256026602760286029603060316032603360346035603660376038603960406041604260436044604560466047604860496050605160526053605460556056605760586059606060616062606360646065606660676068606960706071607260736074607560766077607860796080608160826083608460856086608760886089609060916092609360946095609660976098609961006101610261036104610561066107610861096110611161126113611461156116611761186119612061216122612361246125612661276128612961306131613261336134613561366137613861396140614161426143614461456146614761486149615061516152615361546155615661576158615961606161616261636164616561666167616861696170617161726173617461756176617761786179618061816182618361846185618661876188618961906191619261936194619561966197619861996200620162026203620462056206620762086209621062116212621362146215621662176218621962206221622262236224622562266227622862296230623162326233623462356236623762386239624062416242624362446245624662476248624962506251625262536254625562566257625862596260626162626263626462656266626762686269627062716272627362746275627662776278627962806281628262836284628562866287628862896290629162926293629462956296629762986299630063016302630363046305630663076308630963106311631263136314631563166317631863196320632163226323632463256326
  1. <!doctype html>
  2. <html lang="en" class="no-js">
  3. <head>
  4. <meta charset="utf-8">
  5. <meta name="viewport" content="width=device-width,initial-scale=1">
  6. <link rel="prev" href="../conjur/">
  7. <link rel="next" href="../hashicorp-vault/">
  8. <link rel="icon" href="../../pictures/eso-round-logo.svg">
  9. <meta name="generator" content="mkdocs-1.6.1, mkdocs-material-9.7.6">
  10. <title>Google Cloud Secret Manager - External Secrets Operator</title>
  11. <link rel="stylesheet" href="../../assets/stylesheets/main.484c7ddc.min.css">
  12. <link rel="stylesheet" href="../../assets/stylesheets/palette.ab4e12ef.min.css">
  13. <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
  14. <link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Roboto:300,300i,400,400i,700,700i%7CRoboto+Mono:400,400i,700,700i&display=fallback">
  15. <style>:root{--md-text-font:"Roboto";--md-code-font:"Roboto Mono"}</style>
  16. <script>__md_scope=new URL("../..",location),__md_hash=e=>[...e].reduce(((e,_)=>(e<<5)-e+_.charCodeAt(0)),0),__md_get=(e,_=localStorage,t=__md_scope)=>JSON.parse(_.getItem(t.pathname+"."+e)),__md_set=(e,_,t=localStorage,a=__md_scope)=>{try{t.setItem(a.pathname+"."+e,JSON.stringify(_))}catch(e){}}</script>
  17. <script id="__analytics">function __md_analytics(){function e(){dataLayer.push(arguments)}window.dataLayer=window.dataLayer||[],e("js",new Date),e("config","G-QP38TD8K7V"),document.addEventListener("DOMContentLoaded",(function(){document.forms.search&&document.forms.search.query.addEventListener("blur",(function(){this.value&&e("event","search",{search_term:this.value})}));document$.subscribe((function(){var t=document.forms.feedback;if(void 0!==t)for(var a of t.querySelectorAll("[type=submit]"))a.addEventListener("click",(function(a){a.preventDefault();var n=document.location.pathname,d=this.getAttribute("data-md-value");e("event","feedback",{page:n,data:d}),t.firstElementChild.disabled=!0;var r=t.querySelector(".md-feedback__note [data-md-value='"+d+"']");r&&(r.hidden=!1)})),t.hidden=!1})),location$.subscribe((function(t){e("config","G-QP38TD8K7V",{page_path:t.pathname})}))}));var t=document.createElement("script");t.async=!0,t.src="https://www.googletagmanager.com/gtag/js?id=G-QP38TD8K7V",document.getElementById("__analytics").insertAdjacentElement("afterEnd",t)}</script>
  18. <script>"undefined"!=typeof __md_analytics&&__md_analytics()</script>
  19. </head>
  20. <body dir="ltr" data-md-color-scheme="default" data-md-color-primary="indigo" data-md-color-accent="indigo">
  21. <input class="md-toggle" data-md-toggle="drawer" type="checkbox" id="__drawer" autocomplete="off">
  22. <input class="md-toggle" data-md-toggle="search" type="checkbox" id="__search" autocomplete="off">
  23. <label class="md-overlay" for="__drawer"></label>
  24. <div data-md-component="skip">
  25. <a href="#authentication" class="md-skip">
  26. Skip to content
  27. </a>
  28. </div>
  29. <div data-md-component="announce">
  30. </div>
  31. <div data-md-color-scheme="default" data-md-component="outdated" hidden>
  32. <aside class="md-banner md-banner--warning">
  33. <div class="md-banner__inner md-grid md-typeset">
  34. You're not viewing the latest version.
  35. <a href="../../..">
  36. <strong>Click here to go to latest.</strong>
  37. </a>
  38. </div>
  39. <script>var el=document.querySelector("[data-md-component=outdated]"),base=new URL("../.."),outdated=__md_get("__outdated",sessionStorage,base);!0===outdated&&el&&(el.hidden=!1)</script>
  40. </aside>
  41. </div>
  42. <header class="md-header" data-md-component="header">
  43. <nav class="md-header__inner md-grid" aria-label="Header">
  44. <a href="../.." title="External Secrets Operator" class="md-header__button md-logo" aria-label="External Secrets Operator" data-md-component="logo">
  45. <img src="../../pictures/eso-round-logo.svg" alt="logo">
  46. </a>
  47. <label class="md-header__button md-icon" for="__drawer">
  48. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M3 6h18v2H3zm0 5h18v2H3zm0 5h18v2H3z"/></svg>
  49. </label>
  50. <div class="md-header__title" data-md-component="header-title">
  51. <div class="md-header__ellipsis">
  52. <div class="md-header__topic">
  53. <span class="md-ellipsis">
  54. External Secrets Operator
  55. </span>
  56. </div>
  57. <div class="md-header__topic" data-md-component="header-topic">
  58. <span class="md-ellipsis">
  59. Google Cloud Secret Manager
  60. </span>
  61. </div>
  62. </div>
  63. </div>
  64. <form class="md-header__option" data-md-component="palette">
  65. <input class="md-option" data-md-color-media="(prefers-color-scheme: light)" data-md-color-scheme="default" data-md-color-primary="indigo" data-md-color-accent="indigo" aria-label="Switch to dark mode" type="radio" name="__palette" id="__palette_0">
  66. <label class="md-header__button md-icon" title="Switch to dark mode" for="__palette_1" hidden>
  67. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M12 8a4 4 0 0 0-4 4 4 4 0 0 0 4 4 4 4 0 0 0 4-4 4 4 0 0 0-4-4m0 10a6 6 0 0 1-6-6 6 6 0 0 1 6-6 6 6 0 0 1 6 6 6 6 0 0 1-6 6m8-9.31V4h-4.69L12 .69 8.69 4H4v4.69L.69 12 4 15.31V20h4.69L12 23.31 15.31 20H20v-4.69L23.31 12z"/></svg>
  68. </label>
  69. <input class="md-option" data-md-color-media="(prefers-color-scheme: dark)" data-md-color-scheme="slate" data-md-color-primary="indigo" data-md-color-accent="indigo" aria-label="Switch to light mode" type="radio" name="__palette" id="__palette_1">
  70. <label class="md-header__button md-icon" title="Switch to light mode" for="__palette_0" hidden>
  71. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M12 18c-.89 0-1.74-.2-2.5-.55C11.56 16.5 13 14.42 13 12s-1.44-4.5-3.5-5.45C10.26 6.2 11.11 6 12 6a6 6 0 0 1 6 6 6 6 0 0 1-6 6m8-9.31V4h-4.69L12 .69 8.69 4H4v4.69L.69 12 4 15.31V20h4.69L12 23.31 15.31 20H20v-4.69L23.31 12z"/></svg>
  72. </label>
  73. </form>
  74. <script>var palette=__md_get("__palette");if(palette&&palette.color){if("(prefers-color-scheme)"===palette.color.media){var media=matchMedia("(prefers-color-scheme: light)"),input=document.querySelector(media.matches?"[data-md-color-media='(prefers-color-scheme: light)']":"[data-md-color-media='(prefers-color-scheme: dark)']");palette.color.media=input.getAttribute("data-md-color-media"),palette.color.scheme=input.getAttribute("data-md-color-scheme"),palette.color.primary=input.getAttribute("data-md-color-primary"),palette.color.accent=input.getAttribute("data-md-color-accent")}for(var[key,value]of Object.entries(palette.color))document.body.setAttribute("data-md-color-"+key,value)}</script>
  75. <label class="md-header__button md-icon" for="__search">
  76. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M9.5 3A6.5 6.5 0 0 1 16 9.5c0 1.61-.59 3.09-1.56 4.23l.27.27h.79l5 5-1.5 1.5-5-5v-.79l-.27-.27A6.52 6.52 0 0 1 9.5 16 6.5 6.5 0 0 1 3 9.5 6.5 6.5 0 0 1 9.5 3m0 2C7 5 5 7 5 9.5S7 14 9.5 14 14 12 14 9.5 12 5 9.5 5"/></svg>
  77. </label>
  78. <div class="md-search" data-md-component="search" role="dialog">
  79. <label class="md-search__overlay" for="__search"></label>
  80. <div class="md-search__inner" role="search">
  81. <form class="md-search__form" name="search">
  82. <input type="text" class="md-search__input" name="query" aria-label="Search" placeholder="Search" autocapitalize="off" autocorrect="off" autocomplete="off" spellcheck="false" data-md-component="search-query" required>
  83. <label class="md-search__icon md-icon" for="__search">
  84. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M9.5 3A6.5 6.5 0 0 1 16 9.5c0 1.61-.59 3.09-1.56 4.23l.27.27h.79l5 5-1.5 1.5-5-5v-.79l-.27-.27A6.52 6.52 0 0 1 9.5 16 6.5 6.5 0 0 1 3 9.5 6.5 6.5 0 0 1 9.5 3m0 2C7 5 5 7 5 9.5S7 14 9.5 14 14 12 14 9.5 12 5 9.5 5"/></svg>
  85. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M20 11v2H8l5.5 5.5-1.42 1.42L4.16 12l7.92-7.92L13.5 5.5 8 11z"/></svg>
  86. </label>
  87. <nav class="md-search__options" aria-label="Search">
  88. <button type="reset" class="md-search__icon md-icon" title="Clear" aria-label="Clear" tabindex="-1">
  89. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M19 6.41 17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z"/></svg>
  90. </button>
  91. </nav>
  92. </form>
  93. <div class="md-search__output">
  94. <div class="md-search__scrollwrap" tabindex="0" data-md-scrollfix>
  95. <div class="md-search-result" data-md-component="search-result">
  96. <div class="md-search-result__meta">
  97. Initializing search
  98. </div>
  99. <ol class="md-search-result__list" role="presentation"></ol>
  100. </div>
  101. </div>
  102. </div>
  103. </div>
  104. </div>
  105. <div class="md-header__source">
  106. <a href="https://github.com/external-secrets/external-secrets" title="Go to repository" class="md-source" data-md-component="source">
  107. <div class="md-source__icon md-icon">
  108. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"><!--! Font Awesome Free 7.1.0 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License) Copyright 2025 Fonticons, Inc.--><path d="M439.6 236.1 244 40.5c-5.4-5.5-12.8-8.5-20.4-8.5s-15 3-20.4 8.4L162.5 81l51.5 51.5c27.1-9.1 52.7 16.8 43.4 43.7l49.7 49.7c34.2-11.8 61.2 31 35.5 56.7-26.5 26.5-70.2-2.9-56-37.3L240.3 199v121.9c25.3 12.5 22.3 41.8 9.1 55-6.4 6.4-15.2 10.1-24.3 10.1s-17.8-3.6-24.3-10.1c-17.6-17.6-11.1-46.9 11.2-56v-123c-20.8-8.5-24.6-30.7-18.6-45L142.6 101 8.5 235.1C3 240.6 0 247.9 0 255.5s3 15 8.5 20.4l195.6 195.7c5.4 5.4 12.7 8.4 20.4 8.4s15-3 20.4-8.4l194.7-194.7c5.4-5.4 8.4-12.8 8.4-20.4s-3-15-8.4-20.4"/></svg>
  109. </div>
  110. <div class="md-source__repository">
  111. External Secrets Operator
  112. </div>
  113. </a>
  114. </div>
  115. </nav>
  116. </header>
  117. <div class="md-container" data-md-component="container">
  118. <nav class="md-tabs" aria-label="Tabs" data-md-component="tabs">
  119. <div class="md-grid">
  120. <ul class="md-tabs__list">
  121. <li class="md-tabs__item">
  122. <a href="../.." class="md-tabs__link">
  123. Introduction
  124. </a>
  125. </li>
  126. <li class="md-tabs__item">
  127. <a href="../../api/components/" class="md-tabs__link">
  128. API
  129. </a>
  130. </li>
  131. <li class="md-tabs__item">
  132. <a href="../../guides/introduction/" class="md-tabs__link">
  133. Guides
  134. </a>
  135. </li>
  136. <li class="md-tabs__item md-tabs__item--active">
  137. <a href="../aws-secrets-manager/" class="md-tabs__link">
  138. Provider
  139. </a>
  140. </li>
  141. <li class="md-tabs__item">
  142. <a href="../../examples/gitops-using-fluxcd/" class="md-tabs__link">
  143. Examples
  144. </a>
  145. </li>
  146. <li class="md-tabs__item">
  147. <a href="../../contributing/devguide/" class="md-tabs__link">
  148. Community
  149. </a>
  150. </li>
  151. </ul>
  152. </div>
  153. </nav>
  154. <main class="md-main" data-md-component="main">
  155. <div class="md-main__inner md-grid">
  156. <div class="md-sidebar md-sidebar--primary" data-md-component="sidebar" data-md-type="navigation" >
  157. <div class="md-sidebar__scrollwrap">
  158. <div class="md-sidebar__inner">
  159. <nav class="md-nav md-nav--primary md-nav--lifted" aria-label="Navigation" data-md-level="0">
  160. <label class="md-nav__title" for="__drawer">
  161. <a href="../.." title="External Secrets Operator" class="md-nav__button md-logo" aria-label="External Secrets Operator" data-md-component="logo">
  162. <img src="../../pictures/eso-round-logo.svg" alt="logo">
  163. </a>
  164. External Secrets Operator
  165. </label>
  166. <div class="md-nav__source">
  167. <a href="https://github.com/external-secrets/external-secrets" title="Go to repository" class="md-source" data-md-component="source">
  168. <div class="md-source__icon md-icon">
  169. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"><!--! Font Awesome Free 7.1.0 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free (Icons: CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License) Copyright 2025 Fonticons, Inc.--><path d="M439.6 236.1 244 40.5c-5.4-5.5-12.8-8.5-20.4-8.5s-15 3-20.4 8.4L162.5 81l51.5 51.5c27.1-9.1 52.7 16.8 43.4 43.7l49.7 49.7c34.2-11.8 61.2 31 35.5 56.7-26.5 26.5-70.2-2.9-56-37.3L240.3 199v121.9c25.3 12.5 22.3 41.8 9.1 55-6.4 6.4-15.2 10.1-24.3 10.1s-17.8-3.6-24.3-10.1c-17.6-17.6-11.1-46.9 11.2-56v-123c-20.8-8.5-24.6-30.7-18.6-45L142.6 101 8.5 235.1C3 240.6 0 247.9 0 255.5s3 15 8.5 20.4l195.6 195.7c5.4 5.4 12.7 8.4 20.4 8.4s15-3 20.4-8.4l194.7-194.7c5.4-5.4 8.4-12.8 8.4-20.4s-3-15-8.4-20.4"/></svg>
  170. </div>
  171. <div class="md-source__repository">
  172. External Secrets Operator
  173. </div>
  174. </a>
  175. </div>
  176. <ul class="md-nav__list" data-md-scrollfix>
  177. <li class="md-nav__item md-nav__item--nested">
  178. <input class="md-nav__toggle md-toggle md-toggle--indeterminate" type="checkbox" id="__nav_1" >
  179. <div class="md-nav__link md-nav__container">
  180. <a href="../.." class="md-nav__link ">
  181. <span class="md-ellipsis">
  182. Introduction
  183. </span>
  184. </a>
  185. <label class="md-nav__link " for="__nav_1" id="__nav_1_label" tabindex="0">
  186. <span class="md-nav__icon md-icon"></span>
  187. </label>
  188. </div>
  189. <nav class="md-nav" data-md-level="1" aria-labelledby="__nav_1_label" aria-expanded="false">
  190. <label class="md-nav__title" for="__nav_1">
  191. <span class="md-nav__icon md-icon"></span>
  192. Introduction
  193. </label>
  194. <ul class="md-nav__list" data-md-scrollfix>
  195. <li class="md-nav__item">
  196. <a href="../../introduction/overview/" class="md-nav__link">
  197. <span class="md-ellipsis">
  198. Overview
  199. </span>
  200. </a>
  201. </li>
  202. <li class="md-nav__item">
  203. <a href="../../introduction/glossary/" class="md-nav__link">
  204. <span class="md-ellipsis">
  205. Glossary
  206. </span>
  207. </a>
  208. </li>
  209. <li class="md-nav__item">
  210. <a href="../../introduction/prerequisites/" class="md-nav__link">
  211. <span class="md-ellipsis">
  212. Prerequisites
  213. </span>
  214. </a>
  215. </li>
  216. <li class="md-nav__item">
  217. <a href="../../introduction/getting-started/" class="md-nav__link">
  218. <span class="md-ellipsis">
  219. Getting started
  220. </span>
  221. </a>
  222. </li>
  223. <li class="md-nav__item">
  224. <a href="../../introduction/faq/" class="md-nav__link">
  225. <span class="md-ellipsis">
  226. FAQ
  227. </span>
  228. </a>
  229. </li>
  230. <li class="md-nav__item">
  231. <a href="../../introduction/stability-support/" class="md-nav__link">
  232. <span class="md-ellipsis">
  233. Stability and Support
  234. </span>
  235. </a>
  236. </li>
  237. <li class="md-nav__item">
  238. <a href="../../introduction/deprecation-policy/" class="md-nav__link">
  239. <span class="md-ellipsis">
  240. Deprecation Policy
  241. </span>
  242. </a>
  243. </li>
  244. </ul>
  245. </nav>
  246. </li>
  247. <li class="md-nav__item md-nav__item--nested">
  248. <input class="md-nav__toggle md-toggle md-toggle--indeterminate" type="checkbox" id="__nav_2" >
  249. <label class="md-nav__link" for="__nav_2" id="__nav_2_label" tabindex="0">
  250. <span class="md-ellipsis">
  251. API
  252. </span>
  253. <span class="md-nav__icon md-icon"></span>
  254. </label>
  255. <nav class="md-nav" data-md-level="1" aria-labelledby="__nav_2_label" aria-expanded="false">
  256. <label class="md-nav__title" for="__nav_2">
  257. <span class="md-nav__icon md-icon"></span>
  258. API
  259. </label>
  260. <ul class="md-nav__list" data-md-scrollfix>
  261. <li class="md-nav__item">
  262. <a href="../../api/components/" class="md-nav__link">
  263. <span class="md-ellipsis">
  264. Components
  265. </span>
  266. </a>
  267. </li>
  268. <li class="md-nav__item md-nav__item--nested">
  269. <input class="md-nav__toggle md-toggle md-toggle--indeterminate" type="checkbox" id="__nav_2_2" >
  270. <label class="md-nav__link" for="__nav_2_2" id="__nav_2_2_label" tabindex="0">
  271. <span class="md-ellipsis">
  272. Core Resources
  273. </span>
  274. <span class="md-nav__icon md-icon"></span>
  275. </label>
  276. <nav class="md-nav" data-md-level="2" aria-labelledby="__nav_2_2_label" aria-expanded="false">
  277. <label class="md-nav__title" for="__nav_2_2">
  278. <span class="md-nav__icon md-icon"></span>
  279. Core Resources
  280. </label>
  281. <ul class="md-nav__list" data-md-scrollfix>
  282. <li class="md-nav__item">
  283. <a href="../../api/externalsecret/" class="md-nav__link">
  284. <span class="md-ellipsis">
  285. ExternalSecret
  286. </span>
  287. </a>
  288. </li>
  289. <li class="md-nav__item">
  290. <a href="../../api/secretstore/" class="md-nav__link">
  291. <span class="md-ellipsis">
  292. SecretStore
  293. </span>
  294. </a>
  295. </li>
  296. <li class="md-nav__item">
  297. <a href="../../api/clustersecretstore/" class="md-nav__link">
  298. <span class="md-ellipsis">
  299. ClusterSecretStore
  300. </span>
  301. </a>
  302. </li>
  303. <li class="md-nav__item">
  304. <a href="../../api/clusterexternalsecret/" class="md-nav__link">
  305. <span class="md-ellipsis">
  306. ClusterExternalSecret
  307. </span>
  308. </a>
  309. </li>
  310. <li class="md-nav__item">
  311. <a href="../../api/clusterpushsecret/" class="md-nav__link">
  312. <span class="md-ellipsis">
  313. ClusterPushSecret
  314. </span>
  315. </a>
  316. </li>
  317. <li class="md-nav__item">
  318. <a href="../../api/pushsecret/" class="md-nav__link">
  319. <span class="md-ellipsis">
  320. PushSecret
  321. </span>
  322. </a>
  323. </li>
  324. </ul>
  325. </nav>
  326. </li>
  327. <li class="md-nav__item md-nav__item--nested">
  328. <input class="md-nav__toggle md-toggle md-toggle--indeterminate" type="checkbox" id="__nav_2_3" >
  329. <div class="md-nav__link md-nav__container">
  330. <a href="../../api/generator/" class="md-nav__link ">
  331. <span class="md-ellipsis">
  332. Generators
  333. </span>
  334. </a>
  335. <label class="md-nav__link " for="__nav_2_3" id="__nav_2_3_label" tabindex="0">
  336. <span class="md-nav__icon md-icon"></span>
  337. </label>
  338. </div>
  339. <nav class="md-nav" data-md-level="2" aria-labelledby="__nav_2_3_label" aria-expanded="false">
  340. <label class="md-nav__title" for="__nav_2_3">
  341. <span class="md-nav__icon md-icon"></span>
  342. Generators
  343. </label>
  344. <ul class="md-nav__list" data-md-scrollfix>
  345. <li class="md-nav__item">
  346. <a href="../../api/generator/acr/" class="md-nav__link">
  347. <span class="md-ellipsis">
  348. Azure Container Registry
  349. </span>
  350. </a>
  351. </li>
  352. <li class="md-nav__item">
  353. <a href="../../api/generator/ecr/" class="md-nav__link">
  354. <span class="md-ellipsis">
  355. AWS Elastic Container Registry
  356. </span>
  357. </a>
  358. </li>
  359. <li class="md-nav__item">
  360. <a href="../../api/generator/sts/" class="md-nav__link">
  361. <span class="md-ellipsis">
  362. AWS STS Session Token
  363. </span>
  364. </a>
  365. </li>
  366. <li class="md-nav__item">
  367. <a href="../../api/generator/cloudsmith/" class="md-nav__link">
  368. <span class="md-ellipsis">
  369. Cloudsmith
  370. </span>
  371. </a>
  372. </li>
  373. <li class="md-nav__item">
  374. <a href="../../api/generator/cluster/" class="md-nav__link">
  375. <span class="md-ellipsis">
  376. Cluster Generator
  377. </span>
  378. </a>
  379. </li>
  380. <li class="md-nav__item">
  381. <a href="../../api/generator/gcr/" class="md-nav__link">
  382. <span class="md-ellipsis">
  383. Google Container Registry
  384. </span>
  385. </a>
  386. </li>
  387. <li class="md-nav__item">
  388. <a href="../../api/generator/grafana/" class="md-nav__link">
  389. <span class="md-ellipsis">
  390. Grafana
  391. </span>
  392. </a>
  393. </li>
  394. <li class="md-nav__item">
  395. <a href="../../api/generator/quay/" class="md-nav__link">
  396. <span class="md-ellipsis">
  397. Quay
  398. </span>
  399. </a>
  400. </li>
  401. <li class="md-nav__item">
  402. <a href="../../api/generator/vault/" class="md-nav__link">
  403. <span class="md-ellipsis">
  404. Vault Dynamic Secret
  405. </span>
  406. </a>
  407. </li>
  408. <li class="md-nav__item">
  409. <a href="../../api/generator/beyondtrustworkloadcredentials/" class="md-nav__link">
  410. <span class="md-ellipsis">
  411. BeyondTrust Workload Credentials
  412. </span>
  413. </a>
  414. </li>
  415. <li class="md-nav__item">
  416. <a href="../../api/generator/password/" class="md-nav__link">
  417. <span class="md-ellipsis">
  418. Password
  419. </span>
  420. </a>
  421. </li>
  422. <li class="md-nav__item">
  423. <a href="../../api/generator/fake/" class="md-nav__link">
  424. <span class="md-ellipsis">
  425. Fake
  426. </span>
  427. </a>
  428. </li>
  429. <li class="md-nav__item">
  430. <a href="../../api/generator/webhook/" class="md-nav__link">
  431. <span class="md-ellipsis">
  432. Webhook
  433. </span>
  434. </a>
  435. </li>
  436. <li class="md-nav__item">
  437. <a href="../../api/generator/github/" class="md-nav__link">
  438. <span class="md-ellipsis">
  439. Github
  440. </span>
  441. </a>
  442. </li>
  443. <li class="md-nav__item">
  444. <a href="../../api/generator/gitlab/" class="md-nav__link">
  445. <span class="md-ellipsis">
  446. Gitlab
  447. </span>
  448. </a>
  449. </li>
  450. <li class="md-nav__item">
  451. <a href="../../api/generator/uuid/" class="md-nav__link">
  452. <span class="md-ellipsis">
  453. UUID
  454. </span>
  455. </a>
  456. </li>
  457. <li class="md-nav__item">
  458. <a href="../../api/generator/mfa/" class="md-nav__link">
  459. <span class="md-ellipsis">
  460. MFA
  461. </span>
  462. </a>
  463. </li>
  464. <li class="md-nav__item">
  465. <a href="../../api/generator/sshkey/" class="md-nav__link">
  466. <span class="md-ellipsis">
  467. SSHKey
  468. </span>
  469. </a>
  470. </li>
  471. </ul>
  472. </nav>
  473. </li>
  474. <li class="md-nav__item md-nav__item--nested">
  475. <input class="md-nav__toggle md-toggle md-toggle--indeterminate" type="checkbox" id="__nav_2_4" >
  476. <label class="md-nav__link" for="__nav_2_4" id="__nav_2_4_label" tabindex="0">
  477. <span class="md-ellipsis">
  478. Reference Docs
  479. </span>
  480. <span class="md-nav__icon md-icon"></span>
  481. </label>
  482. <nav class="md-nav" data-md-level="2" aria-labelledby="__nav_2_4_label" aria-expanded="false">
  483. <label class="md-nav__title" for="__nav_2_4">
  484. <span class="md-nav__icon md-icon"></span>
  485. Reference Docs
  486. </label>
  487. <ul class="md-nav__list" data-md-scrollfix>
  488. <li class="md-nav__item">
  489. <a href="../../api/spec/" class="md-nav__link">
  490. <span class="md-ellipsis">
  491. API specification
  492. </span>
  493. </a>
  494. </li>
  495. <li class="md-nav__item">
  496. <a href="../../api/controller-options/" class="md-nav__link">
  497. <span class="md-ellipsis">
  498. Controller Options
  499. </span>
  500. </a>
  501. </li>
  502. <li class="md-nav__item">
  503. <a href="../../api/metrics/" class="md-nav__link">
  504. <span class="md-ellipsis">
  505. Metrics
  506. </span>
  507. </a>
  508. </li>
  509. <li class="md-nav__item">
  510. <a href="../../api/selectable-fields/" class="md-nav__link">
  511. <span class="md-ellipsis">
  512. Selectable Fields
  513. </span>
  514. </a>
  515. </li>
  516. </ul>
  517. </nav>
  518. </li>
  519. </ul>
  520. </nav>
  521. </li>
  522. <li class="md-nav__item md-nav__item--nested">
  523. <input class="md-nav__toggle md-toggle md-toggle--indeterminate" type="checkbox" id="__nav_3" >
  524. <label class="md-nav__link" for="__nav_3" id="__nav_3_label" tabindex="0">
  525. <span class="md-ellipsis">
  526. Guides
  527. </span>
  528. <span class="md-nav__icon md-icon"></span>
  529. </label>
  530. <nav class="md-nav" data-md-level="1" aria-labelledby="__nav_3_label" aria-expanded="false">
  531. <label class="md-nav__title" for="__nav_3">
  532. <span class="md-nav__icon md-icon"></span>
  533. Guides
  534. </label>
  535. <ul class="md-nav__list" data-md-scrollfix>
  536. <li class="md-nav__item">
  537. <a href="../../guides/introduction/" class="md-nav__link">
  538. <span class="md-ellipsis">
  539. Introduction
  540. </span>
  541. </a>
  542. </li>
  543. <li class="md-nav__item md-nav__item--nested">
  544. <input class="md-nav__toggle md-toggle md-toggle--indeterminate" type="checkbox" id="__nav_3_2" >
  545. <label class="md-nav__link" for="__nav_3_2" id="__nav_3_2_label" tabindex="0">
  546. <span class="md-ellipsis">
  547. External Secrets
  548. </span>
  549. <span class="md-nav__icon md-icon"></span>
  550. </label>
  551. <nav class="md-nav" data-md-level="2" aria-labelledby="__nav_3_2_label" aria-expanded="false">
  552. <label class="md-nav__title" for="__nav_3_2">
  553. <span class="md-nav__icon md-icon"></span>
  554. External Secrets
  555. </label>
  556. <ul class="md-nav__list" data-md-scrollfix>
  557. <li class="md-nav__item">
  558. <a href="../../guides/all-keys-one-secret/" class="md-nav__link">
  559. <span class="md-ellipsis">
  560. Extract structured data
  561. </span>
  562. </a>
  563. </li>
  564. <li class="md-nav__item">
  565. <a href="../../guides/getallsecrets/" class="md-nav__link">
  566. <span class="md-ellipsis">
  567. Find Secrets by Name or Metadata
  568. </span>
  569. </a>
  570. </li>
  571. <li class="md-nav__item">
  572. <a href="../../guides/datafrom-rewrite/" class="md-nav__link">
  573. <span class="md-ellipsis">
  574. Rewriting Keys
  575. </span>
  576. </a>
  577. </li>
  578. <li class="md-nav__item md-nav__item--nested">
  579. <input class="md-nav__toggle md-toggle md-toggle--indeterminate" type="checkbox" id="__nav_3_2_4" >
  580. <label class="md-nav__link" for="__nav_3_2_4" id="__nav_3_2_4_label" tabindex="0">
  581. <span class="md-ellipsis">
  582. Advanced Templating
  583. </span>
  584. <span class="md-nav__icon md-icon"></span>
  585. </label>
  586. <nav class="md-nav" data-md-level="3" aria-labelledby="__nav_3_2_4_label" aria-expanded="false">
  587. <label class="md-nav__title" for="__nav_3_2_4">
  588. <span class="md-nav__icon md-icon"></span>
  589. Advanced Templating
  590. </label>
  591. <ul class="md-nav__list" data-md-scrollfix>
  592. <li class="md-nav__item">
  593. <a href="../../guides/templating/" class="md-nav__link">
  594. <span class="md-ellipsis">
  595. v2
  596. </span>
  597. </a>
  598. </li>
  599. <li class="md-nav__item">
  600. <a href="../../guides/templating-v1/" class="md-nav__link">
  601. <span class="md-ellipsis">
  602. v1
  603. </span>
  604. </a>
  605. </li>
  606. </ul>
  607. </nav>
  608. </li>
  609. <li class="md-nav__item">
  610. <a href="../../guides/common-k8s-secret-types/" class="md-nav__link">
  611. <span class="md-ellipsis">
  612. Kubernetes Secret Types
  613. </span>
  614. </a>
  615. </li>
  616. <li class="md-nav__item">
  617. <a href="../../guides/ownership-deletion-policy/" class="md-nav__link">
  618. <span class="md-ellipsis">
  619. Lifecycle: ownership & deletion
  620. </span>
  621. </a>
  622. </li>
  623. <li class="md-nav__item">
  624. <a href="../../guides/decoding-strategy/" class="md-nav__link">
  625. <span class="md-ellipsis">
  626. Decoding Strategies
  627. </span>
  628. </a>
  629. </li>
  630. <li class="md-nav__item">
  631. <a href="../../guides/controller-class/" class="md-nav__link">
  632. <span class="md-ellipsis">
  633. Controller Classes
  634. </span>
  635. </a>
  636. </li>
  637. </ul>
  638. </nav>
  639. </li>
  640. <li class="md-nav__item">
  641. <a href="../../guides/targeting-custom-resources/" class="md-nav__link">
  642. <span class="md-ellipsis">
  643. Targeting Custom Resources
  644. </span>
  645. </a>
  646. </li>
  647. <li class="md-nav__item">
  648. <a href="../../guides/generator/" class="md-nav__link">
  649. <span class="md-ellipsis">
  650. Generators
  651. </span>
  652. </a>
  653. </li>
  654. <li class="md-nav__item">
  655. <a href="../../guides/pushsecrets/" class="md-nav__link">
  656. <span class="md-ellipsis">
  657. Push Secrets
  658. </span>
  659. </a>
  660. </li>
  661. <li class="md-nav__item md-nav__item--nested">
  662. <input class="md-nav__toggle md-toggle md-toggle--indeterminate" type="checkbox" id="__nav_3_6" >
  663. <label class="md-nav__link" for="__nav_3_6" id="__nav_3_6_label" tabindex="0">
  664. <span class="md-ellipsis">
  665. Operations
  666. </span>
  667. <span class="md-nav__icon md-icon"></span>
  668. </label>
  669. <nav class="md-nav" data-md-level="2" aria-labelledby="__nav_3_6_label" aria-expanded="false">
  670. <label class="md-nav__title" for="__nav_3_6">
  671. <span class="md-nav__icon md-icon"></span>
  672. Operations
  673. </label>
  674. <ul class="md-nav__list" data-md-scrollfix>
  675. <li class="md-nav__item">
  676. <a href="../../guides/multi-tenancy/" class="md-nav__link">
  677. <span class="md-ellipsis">
  678. Multi Tenancy
  679. </span>
  680. </a>
  681. </li>
  682. <li class="md-nav__item">
  683. <a href="../../guides/security-best-practices/" class="md-nav__link">
  684. <span class="md-ellipsis">
  685. Security Best Practices
  686. </span>
  687. </a>
  688. </li>
  689. <li class="md-nav__item">
  690. <a href="../../guides/threat-model/" class="md-nav__link">
  691. <span class="md-ellipsis">
  692. Threat Model
  693. </span>
  694. </a>
  695. </li>
  696. <li class="md-nav__item">
  697. <a href="../../guides/v1beta1/" class="md-nav__link">
  698. <span class="md-ellipsis">
  699. Upgrading to v1beta1
  700. </span>
  701. </a>
  702. </li>
  703. <li class="md-nav__item">
  704. <a href="../../guides/using-latest-image/" class="md-nav__link">
  705. <span class="md-ellipsis">
  706. Using Latest Image
  707. </span>
  708. </a>
  709. </li>
  710. <li class="md-nav__item">
  711. <a href="../../guides/disable-cluster-features/" class="md-nav__link">
  712. <span class="md-ellipsis">
  713. Disable Cluster Features
  714. </span>
  715. </a>
  716. </li>
  717. </ul>
  718. </nav>
  719. </li>
  720. <li class="md-nav__item md-nav__item--nested">
  721. <input class="md-nav__toggle md-toggle md-toggle--indeterminate" type="checkbox" id="__nav_3_7" >
  722. <label class="md-nav__link" for="__nav_3_7" id="__nav_3_7_label" tabindex="0">
  723. <span class="md-ellipsis">
  724. Tooling
  725. </span>
  726. <span class="md-nav__icon md-icon"></span>
  727. </label>
  728. <nav class="md-nav" data-md-level="2" aria-labelledby="__nav_3_7_label" aria-expanded="false">
  729. <label class="md-nav__title" for="__nav_3_7">
  730. <span class="md-nav__icon md-icon"></span>
  731. Tooling
  732. </label>
  733. <ul class="md-nav__list" data-md-scrollfix>
  734. <li class="md-nav__item">
  735. <a href="../../guides/using-esoctl-tool/" class="md-nav__link">
  736. <span class="md-ellipsis">
  737. Using the esoctl tool
  738. </span>
  739. </a>
  740. </li>
  741. </ul>
  742. </nav>
  743. </li>
  744. </ul>
  745. </nav>
  746. </li>
  747. <li class="md-nav__item md-nav__item--active md-nav__item--section md-nav__item--nested">
  748. <input class="md-nav__toggle md-toggle " type="checkbox" id="__nav_4" checked>
  749. <label class="md-nav__link" for="__nav_4" id="__nav_4_label" tabindex="">
  750. <span class="md-ellipsis">
  751. Provider
  752. </span>
  753. <span class="md-nav__icon md-icon"></span>
  754. </label>
  755. <nav class="md-nav" data-md-level="1" aria-labelledby="__nav_4_label" aria-expanded="true">
  756. <label class="md-nav__title" for="__nav_4">
  757. <span class="md-nav__icon md-icon"></span>
  758. Provider
  759. </label>
  760. <ul class="md-nav__list" data-md-scrollfix>
  761. <li class="md-nav__item">
  762. <a href="../aws-secrets-manager/" class="md-nav__link">
  763. <span class="md-ellipsis">
  764. AWS Secrets Manager
  765. </span>
  766. </a>
  767. </li>
  768. <li class="md-nav__item">
  769. <a href="../aws-parameter-store/" class="md-nav__link">
  770. <span class="md-ellipsis">
  771. AWS Parameter Store
  772. </span>
  773. </a>
  774. </li>
  775. <li class="md-nav__item">
  776. <a href="../aws-access/" class="md-nav__link">
  777. <span class="md-ellipsis">
  778. AWS Access
  779. </span>
  780. </a>
  781. </li>
  782. <li class="md-nav__item">
  783. <a href="../azure-key-vault/" class="md-nav__link">
  784. <span class="md-ellipsis">
  785. Azure Key Vault
  786. </span>
  787. </a>
  788. </li>
  789. <li class="md-nav__item">
  790. <a href="../barbican/" class="md-nav__link">
  791. <span class="md-ellipsis">
  792. Barbican
  793. </span>
  794. </a>
  795. </li>
  796. <li class="md-nav__item">
  797. <a href="../beyondtrust/" class="md-nav__link">
  798. <span class="md-ellipsis">
  799. BeyondTrust
  800. </span>
  801. </a>
  802. </li>
  803. <li class="md-nav__item">
  804. <a href="../beyondtrustworkloadcredentials/" class="md-nav__link">
  805. <span class="md-ellipsis">
  806. BeyondTrust Workload Credentials
  807. </span>
  808. </a>
  809. </li>
  810. <li class="md-nav__item">
  811. <a href="../bitwarden-secrets-manager/" class="md-nav__link">
  812. <span class="md-ellipsis">
  813. Bitwarden Secrets Manager
  814. </span>
  815. </a>
  816. </li>
  817. <li class="md-nav__item">
  818. <a href="../chef/" class="md-nav__link">
  819. <span class="md-ellipsis">
  820. Chef
  821. </span>
  822. </a>
  823. </li>
  824. <li class="md-nav__item">
  825. <a href="../cloudru/" class="md-nav__link">
  826. <span class="md-ellipsis">
  827. Cloud.ru Secret Manager
  828. </span>
  829. </a>
  830. </li>
  831. <li class="md-nav__item">
  832. <a href="../conjur/" class="md-nav__link">
  833. <span class="md-ellipsis">
  834. CyberArk Conjur
  835. </span>
  836. </a>
  837. </li>
  838. <li class="md-nav__item md-nav__item--active">
  839. <input class="md-nav__toggle md-toggle" type="checkbox" id="__toc">
  840. <label class="md-nav__link md-nav__link--active" for="__toc">
  841. <span class="md-ellipsis">
  842. Google Cloud Secret Manager
  843. </span>
  844. <span class="md-nav__icon md-icon"></span>
  845. </label>
  846. <a href="./" class="md-nav__link md-nav__link--active">
  847. <span class="md-ellipsis">
  848. Google Cloud Secret Manager
  849. </span>
  850. </a>
  851. <nav class="md-nav md-nav--secondary" aria-label="Table of contents">
  852. <label class="md-nav__title" for="__toc">
  853. <span class="md-nav__icon md-icon"></span>
  854. Table of contents
  855. </label>
  856. <ul class="md-nav__list" data-md-component="toc" data-md-scrollfix>
  857. <li class="md-nav__item">
  858. <a href="#authentication" class="md-nav__link">
  859. <span class="md-ellipsis">
  860. Authentication
  861. </span>
  862. </a>
  863. <nav class="md-nav" aria-label="Authentication">
  864. <ul class="md-nav__list">
  865. <li class="md-nav__item">
  866. <a href="#workload-identity-gke" class="md-nav__link">
  867. <span class="md-ellipsis">
  868. Workload Identity (GKE)
  869. </span>
  870. </a>
  871. <nav class="md-nav" aria-label="Workload Identity (GKE)">
  872. <ul class="md-nav__list">
  873. <li class="md-nav__item">
  874. <a href="#prerequisites" class="md-nav__link">
  875. <span class="md-ellipsis">
  876. Prerequisites
  877. </span>
  878. </a>
  879. </li>
  880. <li class="md-nav__item">
  881. <a href="#using-a-kubernetes-service-account-as-a-gcp-iam-principal" class="md-nav__link">
  882. <span class="md-ellipsis">
  883. Using a Kubernetes service account as a GCP IAM principal
  884. </span>
  885. </a>
  886. </li>
  887. <li class="md-nav__item">
  888. <a href="#linking-a-kubernetes-service-account-to-a-gcp-service-account" class="md-nav__link">
  889. <span class="md-ellipsis">
  890. Linking a Kubernetes service account to a GCP service account
  891. </span>
  892. </a>
  893. </li>
  894. <li class="md-nav__item">
  895. <a href="#authorizing-the-core-controller-pod" class="md-nav__link">
  896. <span class="md-ellipsis">
  897. Authorizing the Core Controller Pod
  898. </span>
  899. </a>
  900. </li>
  901. <li class="md-nav__item">
  902. <a href="#auto-detection-of-gcp-project-id" class="md-nav__link">
  903. <span class="md-ellipsis">
  904. Auto-detection of GCP project ID
  905. </span>
  906. </a>
  907. </li>
  908. <li class="md-nav__item">
  909. <a href="#projectid-vs-clusterprojectid" class="md-nav__link">
  910. <span class="md-ellipsis">
  911. projectID vs clusterProjectID
  912. </span>
  913. </a>
  914. </li>
  915. <li class="md-nav__item">
  916. <a href="#explicitly-specifying-the-gke-clusters-name-and-location" class="md-nav__link">
  917. <span class="md-ellipsis">
  918. Explicitly specifying the GKE cluster's name and location
  919. </span>
  920. </a>
  921. </li>
  922. </ul>
  923. </nav>
  924. </li>
  925. <li class="md-nav__item">
  926. <a href="#workload-identity-federation" class="md-nav__link">
  927. <span class="md-ellipsis">
  928. Workload Identity Federation
  929. </span>
  930. </a>
  931. <nav class="md-nav" aria-label="Workload Identity Federation">
  932. <ul class="md-nav__list">
  933. <li class="md-nav__item">
  934. <a href="#configuration-rules" class="md-nav__link">
  935. <span class="md-ellipsis">
  936. Configuration rules
  937. </span>
  938. </a>
  939. </li>
  940. <li class="md-nav__item">
  941. <a href="#kubernetes-subject-token-serviceaccountref" class="md-nav__link">
  942. <span class="md-ellipsis">
  943. Kubernetes subject token (serviceAccountRef)
  944. </span>
  945. </a>
  946. </li>
  947. <li class="md-nav__item">
  948. <a href="#google-service-account-impersonation" class="md-nav__link">
  949. <span class="md-ellipsis">
  950. Google service account impersonation
  951. </span>
  952. </a>
  953. </li>
  954. <li class="md-nav__item">
  955. <a href="#external-account-json-credconfig" class="md-nav__link">
  956. <span class="md-ellipsis">
  957. External account JSON (credConfig)
  958. </span>
  959. </a>
  960. </li>
  961. <li class="md-nav__item">
  962. <a href="#aws-subject-token-awssecuritycredentials" class="md-nav__link">
  963. <span class="md-ellipsis">
  964. AWS subject token (awsSecurityCredentials)
  965. </span>
  966. </a>
  967. </li>
  968. <li class="md-nav__item">
  969. <a href="#other-api-surfaces" class="md-nav__link">
  970. <span class="md-ellipsis">
  971. Other API surfaces
  972. </span>
  973. </a>
  974. </li>
  975. <li class="md-nav__item">
  976. <a href="#references" class="md-nav__link">
  977. <span class="md-ellipsis">
  978. References
  979. </span>
  980. </a>
  981. </li>
  982. </ul>
  983. </nav>
  984. </li>
  985. <li class="md-nav__item">
  986. <a href="#authenticating-with-a-gcp-service-account-static-key" class="md-nav__link">
  987. <span class="md-ellipsis">
  988. Authenticating with a GCP service account (static key)
  989. </span>
  990. </a>
  991. </li>
  992. </ul>
  993. </nav>
  994. </li>
  995. <li class="md-nav__item">
  996. <a href="#using-pushsecret-with-an-existing-google-secret-manager-secret" class="md-nav__link">
  997. <span class="md-ellipsis">
  998. Using PushSecret with an existing Google Secret Manager secret
  999. </span>
  1000. </a>
  1001. </li>
  1002. <li class="md-nav__item">
  1003. <a href="#secret-replication-and-encryption-configuration" class="md-nav__link">
  1004. <span class="md-ellipsis">
  1005. Secret Replication and Encryption Configuration
  1006. </span>
  1007. </a>
  1008. <nav class="md-nav" aria-label="Secret Replication and Encryption Configuration">
  1009. <ul class="md-nav__list">
  1010. <li class="md-nav__item">
  1011. <a href="#location-and-replication" class="md-nav__link">
  1012. <span class="md-ellipsis">
  1013. Location and Replication
  1014. </span>
  1015. </a>
  1016. </li>
  1017. <li class="md-nav__item">
  1018. <a href="#customer-managed-encryption-keys-cmek" class="md-nav__link">
  1019. <span class="md-ellipsis">
  1020. Customer-Managed Encryption Keys (CMEK)
  1021. </span>
  1022. </a>
  1023. </li>
  1024. </ul>
  1025. </nav>
  1026. </li>
  1027. <li class="md-nav__item">
  1028. <a href="#regional-secrets" class="md-nav__link">
  1029. <span class="md-ellipsis">
  1030. Regional Secrets
  1031. </span>
  1032. </a>
  1033. </li>
  1034. <li class="md-nav__item">
  1035. <a href="#secret-version-management" class="md-nav__link">
  1036. <span class="md-ellipsis">
  1037. Secret Version Management
  1038. </span>
  1039. </a>
  1040. <nav class="md-nav" aria-label="Secret Version Management">
  1041. <ul class="md-nav__list">
  1042. <li class="md-nav__item">
  1043. <a href="#secret-version-selection-policy" class="md-nav__link">
  1044. <span class="md-ellipsis">
  1045. Secret Version Selection Policy
  1046. </span>
  1047. </a>
  1048. <nav class="md-nav" aria-label="Secret Version Selection Policy">
  1049. <ul class="md-nav__list">
  1050. <li class="md-nav__item">
  1051. <a href="#available-policies" class="md-nav__link">
  1052. <span class="md-ellipsis">
  1053. Available Policies
  1054. </span>
  1055. </a>
  1056. </li>
  1057. <li class="md-nav__item">
  1058. <a href="#configuration-example" class="md-nav__link">
  1059. <span class="md-ellipsis">
  1060. Configuration Example
  1061. </span>
  1062. </a>
  1063. </li>
  1064. </ul>
  1065. </nav>
  1066. </li>
  1067. </ul>
  1068. </nav>
  1069. </li>
  1070. </ul>
  1071. </nav>
  1072. </li>
  1073. <li class="md-nav__item">
  1074. <a href="../hashicorp-vault/" class="md-nav__link">
  1075. <span class="md-ellipsis">
  1076. HashiCorp Vault
  1077. </span>
  1078. </a>
  1079. </li>
  1080. <li class="md-nav__item">
  1081. <a href="../kubernetes/" class="md-nav__link">
  1082. <span class="md-ellipsis">
  1083. Kubernetes
  1084. </span>
  1085. </a>
  1086. </li>
  1087. <li class="md-nav__item">
  1088. <a href="../ibm-secrets-manager/" class="md-nav__link">
  1089. <span class="md-ellipsis">
  1090. IBM Secrets Manager
  1091. </span>
  1092. </a>
  1093. </li>
  1094. <li class="md-nav__item">
  1095. <a href="../akeyless/" class="md-nav__link">
  1096. <span class="md-ellipsis">
  1097. Akeyless
  1098. </span>
  1099. </a>
  1100. </li>
  1101. <li class="md-nav__item">
  1102. <a href="../yandex-certificate-manager/" class="md-nav__link">
  1103. <span class="md-ellipsis">
  1104. Yandex Certificate Manager
  1105. </span>
  1106. </a>
  1107. </li>
  1108. <li class="md-nav__item">
  1109. <a href="../yandex-lockbox/" class="md-nav__link">
  1110. <span class="md-ellipsis">
  1111. Yandex Lockbox
  1112. </span>
  1113. </a>
  1114. </li>
  1115. <li class="md-nav__item">
  1116. <a href="../gitlab-variables/" class="md-nav__link">
  1117. <span class="md-ellipsis">
  1118. GitLab Variables
  1119. </span>
  1120. </a>
  1121. </li>
  1122. <li class="md-nav__item">
  1123. <a href="../github/" class="md-nav__link">
  1124. <span class="md-ellipsis">
  1125. Github Actions Secrets
  1126. </span>
  1127. </a>
  1128. </li>
  1129. <li class="md-nav__item">
  1130. <a href="../oracle-vault/" class="md-nav__link">
  1131. <span class="md-ellipsis">
  1132. Oracle Vault
  1133. </span>
  1134. </a>
  1135. </li>
  1136. <li class="md-nav__item">
  1137. <a href="../ovhcloud/" class="md-nav__link">
  1138. <span class="md-ellipsis">
  1139. OVHcloud
  1140. </span>
  1141. </a>
  1142. </li>
  1143. <li class="md-nav__item">
  1144. <a href="../1password-automation/" class="md-nav__link">
  1145. <span class="md-ellipsis">
  1146. 1Password Connect Server
  1147. </span>
  1148. </a>
  1149. </li>
  1150. <li class="md-nav__item">
  1151. <a href="../1password-sdk/" class="md-nav__link">
  1152. <span class="md-ellipsis">
  1153. 1Password SDK
  1154. </span>
  1155. </a>
  1156. </li>
  1157. <li class="md-nav__item">
  1158. <a href="../webhook/" class="md-nav__link">
  1159. <span class="md-ellipsis">
  1160. Webhook
  1161. </span>
  1162. </a>
  1163. </li>
  1164. <li class="md-nav__item">
  1165. <a href="../fake/" class="md-nav__link">
  1166. <span class="md-ellipsis">
  1167. Fake
  1168. </span>
  1169. </a>
  1170. </li>
  1171. <li class="md-nav__item">
  1172. <a href="../senhasegura-dsm/" class="md-nav__link">
  1173. <span class="md-ellipsis">
  1174. senhasegura DevOps Secrets Management (DSM)
  1175. </span>
  1176. </a>
  1177. </li>
  1178. <li class="md-nav__item">
  1179. <a href="../doppler/" class="md-nav__link">
  1180. <span class="md-ellipsis">
  1181. Doppler
  1182. </span>
  1183. </a>
  1184. </li>
  1185. <li class="md-nav__item">
  1186. <a href="../keeper-security/" class="md-nav__link">
  1187. <span class="md-ellipsis">
  1188. Keeper Security
  1189. </span>
  1190. </a>
  1191. </li>
  1192. <li class="md-nav__item">
  1193. <a href="../cloak/" class="md-nav__link">
  1194. <span class="md-ellipsis">
  1195. Cloak End 2 End Encrypted Secrets
  1196. </span>
  1197. </a>
  1198. </li>
  1199. <li class="md-nav__item">
  1200. <a href="../scaleway/" class="md-nav__link">
  1201. <span class="md-ellipsis">
  1202. Scaleway
  1203. </span>
  1204. </a>
  1205. </li>
  1206. <li class="md-nav__item">
  1207. <a href="../delinea/" class="md-nav__link">
  1208. <span class="md-ellipsis">
  1209. Delinea
  1210. </span>
  1211. </a>
  1212. </li>
  1213. <li class="md-nav__item">
  1214. <a href="../secretserver/" class="md-nav__link">
  1215. <span class="md-ellipsis">
  1216. Secret Server
  1217. </span>
  1218. </a>
  1219. </li>
  1220. <li class="md-nav__item">
  1221. <a href="../passbolt/" class="md-nav__link">
  1222. <span class="md-ellipsis">
  1223. Passbolt
  1224. </span>
  1225. </a>
  1226. </li>
  1227. <li class="md-nav__item">
  1228. <a href="../pulumi/" class="md-nav__link">
  1229. <span class="md-ellipsis">
  1230. Pulumi ESC
  1231. </span>
  1232. </a>
  1233. </li>
  1234. <li class="md-nav__item">
  1235. <a href="../onboardbase/" class="md-nav__link">
  1236. <span class="md-ellipsis">
  1237. Onboardbase
  1238. </span>
  1239. </a>
  1240. </li>
  1241. <li class="md-nav__item">
  1242. <a href="../../provider-passworddepot/" class="md-nav__link">
  1243. <span class="md-ellipsis">
  1244. Password Depot
  1245. </span>
  1246. </a>
  1247. </li>
  1248. <li class="md-nav__item">
  1249. <a href="../fortanix/" class="md-nav__link">
  1250. <span class="md-ellipsis">
  1251. Fortanix
  1252. </span>
  1253. </a>
  1254. </li>
  1255. <li class="md-nav__item">
  1256. <a href="../infisical/" class="md-nav__link">
  1257. <span class="md-ellipsis">
  1258. Infisical
  1259. </span>
  1260. </a>
  1261. </li>
  1262. <li class="md-nav__item">
  1263. <a href="../previder/" class="md-nav__link">
  1264. <span class="md-ellipsis">
  1265. Previder
  1266. </span>
  1267. </a>
  1268. </li>
  1269. <li class="md-nav__item">
  1270. <a href="../openbao/" class="md-nav__link">
  1271. <span class="md-ellipsis">
  1272. OpenBao
  1273. </span>
  1274. </a>
  1275. </li>
  1276. <li class="md-nav__item">
  1277. <a href="../volcengine/" class="md-nav__link">
  1278. <span class="md-ellipsis">
  1279. Volcengine
  1280. </span>
  1281. </a>
  1282. </li>
  1283. <li class="md-nav__item">
  1284. <a href="../ngrok/" class="md-nav__link">
  1285. <span class="md-ellipsis">
  1286. ngrok
  1287. </span>
  1288. </a>
  1289. </li>
  1290. <li class="md-nav__item">
  1291. <a href="../devolutions-server/" class="md-nav__link">
  1292. <span class="md-ellipsis">
  1293. Devolutions Server
  1294. </span>
  1295. </a>
  1296. </li>
  1297. <li class="md-nav__item">
  1298. <a href="../nebius-mysterybox/" class="md-nav__link">
  1299. <span class="md-ellipsis">
  1300. Nebius MysteryBox
  1301. </span>
  1302. </a>
  1303. </li>
  1304. </ul>
  1305. </nav>
  1306. </li>
  1307. <li class="md-nav__item md-nav__item--nested">
  1308. <input class="md-nav__toggle md-toggle md-toggle--indeterminate" type="checkbox" id="__nav_5" >
  1309. <label class="md-nav__link" for="__nav_5" id="__nav_5_label" tabindex="0">
  1310. <span class="md-ellipsis">
  1311. Examples
  1312. </span>
  1313. <span class="md-nav__icon md-icon"></span>
  1314. </label>
  1315. <nav class="md-nav" data-md-level="1" aria-labelledby="__nav_5_label" aria-expanded="false">
  1316. <label class="md-nav__title" for="__nav_5">
  1317. <span class="md-nav__icon md-icon"></span>
  1318. Examples
  1319. </label>
  1320. <ul class="md-nav__list" data-md-scrollfix>
  1321. <li class="md-nav__item">
  1322. <a href="../../examples/gitops-using-fluxcd/" class="md-nav__link">
  1323. <span class="md-ellipsis">
  1324. FluxCD
  1325. </span>
  1326. </a>
  1327. </li>
  1328. <li class="md-nav__item">
  1329. <a href="../../examples/anchore-engine-credentials/" class="md-nav__link">
  1330. <span class="md-ellipsis">
  1331. Anchore Engine
  1332. </span>
  1333. </a>
  1334. </li>
  1335. <li class="md-nav__item">
  1336. <a href="../../examples/jenkins-kubernetes-credentials/" class="md-nav__link">
  1337. <span class="md-ellipsis">
  1338. Jenkins
  1339. </span>
  1340. </a>
  1341. </li>
  1342. <li class="md-nav__item">
  1343. <a href="../../examples/bitwarden/" class="md-nav__link">
  1344. <span class="md-ellipsis">
  1345. Bitwarden
  1346. </span>
  1347. </a>
  1348. </li>
  1349. </ul>
  1350. </nav>
  1351. </li>
  1352. <li class="md-nav__item md-nav__item--nested">
  1353. <input class="md-nav__toggle md-toggle md-toggle--indeterminate" type="checkbox" id="__nav_6" >
  1354. <label class="md-nav__link" for="__nav_6" id="__nav_6_label" tabindex="0">
  1355. <span class="md-ellipsis">
  1356. Community
  1357. </span>
  1358. <span class="md-nav__icon md-icon"></span>
  1359. </label>
  1360. <nav class="md-nav" data-md-level="1" aria-labelledby="__nav_6_label" aria-expanded="false">
  1361. <label class="md-nav__title" for="__nav_6">
  1362. <span class="md-nav__icon md-icon"></span>
  1363. Community
  1364. </label>
  1365. <ul class="md-nav__list" data-md-scrollfix>
  1366. <li class="md-nav__item md-nav__item--nested">
  1367. <input class="md-nav__toggle md-toggle md-toggle--indeterminate" type="checkbox" id="__nav_6_1" >
  1368. <label class="md-nav__link" for="__nav_6_1" id="__nav_6_1_label" tabindex="0">
  1369. <span class="md-ellipsis">
  1370. Contributing
  1371. </span>
  1372. <span class="md-nav__icon md-icon"></span>
  1373. </label>
  1374. <nav class="md-nav" data-md-level="2" aria-labelledby="__nav_6_1_label" aria-expanded="false">
  1375. <label class="md-nav__title" for="__nav_6_1">
  1376. <span class="md-nav__icon md-icon"></span>
  1377. Contributing
  1378. </label>
  1379. <ul class="md-nav__list" data-md-scrollfix>
  1380. <li class="md-nav__item">
  1381. <a href="../../contributing/devguide/" class="md-nav__link">
  1382. <span class="md-ellipsis">
  1383. Developer guide
  1384. </span>
  1385. </a>
  1386. </li>
  1387. <li class="md-nav__item">
  1388. <a href="../../contributing/process/" class="md-nav__link">
  1389. <span class="md-ellipsis">
  1390. Contributing Process
  1391. </span>
  1392. </a>
  1393. </li>
  1394. <li class="md-nav__item">
  1395. <a href="../../contributing/release/" class="md-nav__link">
  1396. <span class="md-ellipsis">
  1397. Release Process
  1398. </span>
  1399. </a>
  1400. </li>
  1401. <li class="md-nav__item">
  1402. <a href="../../contributing/coc/" class="md-nav__link">
  1403. <span class="md-ellipsis">
  1404. Code of Conduct
  1405. </span>
  1406. </a>
  1407. </li>
  1408. <li class="md-nav__item">
  1409. <a href="../../contributing/calendar/" class="md-nav__link">
  1410. <span class="md-ellipsis">
  1411. Community meetings calendar
  1412. </span>
  1413. </a>
  1414. </li>
  1415. <li class="md-nav__item">
  1416. <a href="../../contributing/roadmap/" class="md-nav__link">
  1417. <span class="md-ellipsis">
  1418. Roadmap
  1419. </span>
  1420. </a>
  1421. </li>
  1422. <li class="md-nav__item">
  1423. <a href="../../contributing/burnout-mitigation/" class="md-nav__link">
  1424. <span class="md-ellipsis">
  1425. Burnout Prevention
  1426. </span>
  1427. </a>
  1428. </li>
  1429. <li class="md-nav__item">
  1430. <a href="../../contributing/llm-policy/" class="md-nav__link">
  1431. <span class="md-ellipsis">
  1432. LLM Policy
  1433. </span>
  1434. </a>
  1435. </li>
  1436. </ul>
  1437. </nav>
  1438. </li>
  1439. <li class="md-nav__item md-nav__item--nested">
  1440. <input class="md-nav__toggle md-toggle md-toggle--indeterminate" type="checkbox" id="__nav_6_2" >
  1441. <label class="md-nav__link" for="__nav_6_2" id="__nav_6_2_label" tabindex="0">
  1442. <span class="md-ellipsis">
  1443. External Resources
  1444. </span>
  1445. <span class="md-nav__icon md-icon"></span>
  1446. </label>
  1447. <nav class="md-nav" data-md-level="2" aria-labelledby="__nav_6_2_label" aria-expanded="false">
  1448. <label class="md-nav__title" for="__nav_6_2">
  1449. <span class="md-nav__icon md-icon"></span>
  1450. External Resources
  1451. </label>
  1452. <ul class="md-nav__list" data-md-scrollfix>
  1453. <li class="md-nav__item">
  1454. <a href="../../eso-talks/" class="md-nav__link">
  1455. <span class="md-ellipsis">
  1456. Talks
  1457. </span>
  1458. </a>
  1459. </li>
  1460. <li class="md-nav__item">
  1461. <a href="../../eso-demos/" class="md-nav__link">
  1462. <span class="md-ellipsis">
  1463. Demos
  1464. </span>
  1465. </a>
  1466. </li>
  1467. <li class="md-nav__item">
  1468. <a href="../../eso-blogs/" class="md-nav__link">
  1469. <span class="md-ellipsis">
  1470. Blogs
  1471. </span>
  1472. </a>
  1473. </li>
  1474. <li class="md-nav__item">
  1475. <a href="../../eso-tools/" class="md-nav__link">
  1476. <span class="md-ellipsis">
  1477. Tools
  1478. </span>
  1479. </a>
  1480. </li>
  1481. </ul>
  1482. </nav>
  1483. </li>
  1484. </ul>
  1485. </nav>
  1486. </li>
  1487. </ul>
  1488. </nav>
  1489. </div>
  1490. </div>
  1491. </div>
  1492. <div class="md-sidebar md-sidebar--secondary" data-md-component="sidebar" data-md-type="toc" >
  1493. <div class="md-sidebar__scrollwrap">
  1494. <div class="md-sidebar__inner">
  1495. <nav class="md-nav md-nav--secondary" aria-label="Table of contents">
  1496. <label class="md-nav__title" for="__toc">
  1497. <span class="md-nav__icon md-icon"></span>
  1498. Table of contents
  1499. </label>
  1500. <ul class="md-nav__list" data-md-component="toc" data-md-scrollfix>
  1501. <li class="md-nav__item">
  1502. <a href="#authentication" class="md-nav__link">
  1503. <span class="md-ellipsis">
  1504. Authentication
  1505. </span>
  1506. </a>
  1507. <nav class="md-nav" aria-label="Authentication">
  1508. <ul class="md-nav__list">
  1509. <li class="md-nav__item">
  1510. <a href="#workload-identity-gke" class="md-nav__link">
  1511. <span class="md-ellipsis">
  1512. Workload Identity (GKE)
  1513. </span>
  1514. </a>
  1515. <nav class="md-nav" aria-label="Workload Identity (GKE)">
  1516. <ul class="md-nav__list">
  1517. <li class="md-nav__item">
  1518. <a href="#prerequisites" class="md-nav__link">
  1519. <span class="md-ellipsis">
  1520. Prerequisites
  1521. </span>
  1522. </a>
  1523. </li>
  1524. <li class="md-nav__item">
  1525. <a href="#using-a-kubernetes-service-account-as-a-gcp-iam-principal" class="md-nav__link">
  1526. <span class="md-ellipsis">
  1527. Using a Kubernetes service account as a GCP IAM principal
  1528. </span>
  1529. </a>
  1530. </li>
  1531. <li class="md-nav__item">
  1532. <a href="#linking-a-kubernetes-service-account-to-a-gcp-service-account" class="md-nav__link">
  1533. <span class="md-ellipsis">
  1534. Linking a Kubernetes service account to a GCP service account
  1535. </span>
  1536. </a>
  1537. </li>
  1538. <li class="md-nav__item">
  1539. <a href="#authorizing-the-core-controller-pod" class="md-nav__link">
  1540. <span class="md-ellipsis">
  1541. Authorizing the Core Controller Pod
  1542. </span>
  1543. </a>
  1544. </li>
  1545. <li class="md-nav__item">
  1546. <a href="#auto-detection-of-gcp-project-id" class="md-nav__link">
  1547. <span class="md-ellipsis">
  1548. Auto-detection of GCP project ID
  1549. </span>
  1550. </a>
  1551. </li>
  1552. <li class="md-nav__item">
  1553. <a href="#projectid-vs-clusterprojectid" class="md-nav__link">
  1554. <span class="md-ellipsis">
  1555. projectID vs clusterProjectID
  1556. </span>
  1557. </a>
  1558. </li>
  1559. <li class="md-nav__item">
  1560. <a href="#explicitly-specifying-the-gke-clusters-name-and-location" class="md-nav__link">
  1561. <span class="md-ellipsis">
  1562. Explicitly specifying the GKE cluster's name and location
  1563. </span>
  1564. </a>
  1565. </li>
  1566. </ul>
  1567. </nav>
  1568. </li>
  1569. <li class="md-nav__item">
  1570. <a href="#workload-identity-federation" class="md-nav__link">
  1571. <span class="md-ellipsis">
  1572. Workload Identity Federation
  1573. </span>
  1574. </a>
  1575. <nav class="md-nav" aria-label="Workload Identity Federation">
  1576. <ul class="md-nav__list">
  1577. <li class="md-nav__item">
  1578. <a href="#configuration-rules" class="md-nav__link">
  1579. <span class="md-ellipsis">
  1580. Configuration rules
  1581. </span>
  1582. </a>
  1583. </li>
  1584. <li class="md-nav__item">
  1585. <a href="#kubernetes-subject-token-serviceaccountref" class="md-nav__link">
  1586. <span class="md-ellipsis">
  1587. Kubernetes subject token (serviceAccountRef)
  1588. </span>
  1589. </a>
  1590. </li>
  1591. <li class="md-nav__item">
  1592. <a href="#google-service-account-impersonation" class="md-nav__link">
  1593. <span class="md-ellipsis">
  1594. Google service account impersonation
  1595. </span>
  1596. </a>
  1597. </li>
  1598. <li class="md-nav__item">
  1599. <a href="#external-account-json-credconfig" class="md-nav__link">
  1600. <span class="md-ellipsis">
  1601. External account JSON (credConfig)
  1602. </span>
  1603. </a>
  1604. </li>
  1605. <li class="md-nav__item">
  1606. <a href="#aws-subject-token-awssecuritycredentials" class="md-nav__link">
  1607. <span class="md-ellipsis">
  1608. AWS subject token (awsSecurityCredentials)
  1609. </span>
  1610. </a>
  1611. </li>
  1612. <li class="md-nav__item">
  1613. <a href="#other-api-surfaces" class="md-nav__link">
  1614. <span class="md-ellipsis">
  1615. Other API surfaces
  1616. </span>
  1617. </a>
  1618. </li>
  1619. <li class="md-nav__item">
  1620. <a href="#references" class="md-nav__link">
  1621. <span class="md-ellipsis">
  1622. References
  1623. </span>
  1624. </a>
  1625. </li>
  1626. </ul>
  1627. </nav>
  1628. </li>
  1629. <li class="md-nav__item">
  1630. <a href="#authenticating-with-a-gcp-service-account-static-key" class="md-nav__link">
  1631. <span class="md-ellipsis">
  1632. Authenticating with a GCP service account (static key)
  1633. </span>
  1634. </a>
  1635. </li>
  1636. </ul>
  1637. </nav>
  1638. </li>
  1639. <li class="md-nav__item">
  1640. <a href="#using-pushsecret-with-an-existing-google-secret-manager-secret" class="md-nav__link">
  1641. <span class="md-ellipsis">
  1642. Using PushSecret with an existing Google Secret Manager secret
  1643. </span>
  1644. </a>
  1645. </li>
  1646. <li class="md-nav__item">
  1647. <a href="#secret-replication-and-encryption-configuration" class="md-nav__link">
  1648. <span class="md-ellipsis">
  1649. Secret Replication and Encryption Configuration
  1650. </span>
  1651. </a>
  1652. <nav class="md-nav" aria-label="Secret Replication and Encryption Configuration">
  1653. <ul class="md-nav__list">
  1654. <li class="md-nav__item">
  1655. <a href="#location-and-replication" class="md-nav__link">
  1656. <span class="md-ellipsis">
  1657. Location and Replication
  1658. </span>
  1659. </a>
  1660. </li>
  1661. <li class="md-nav__item">
  1662. <a href="#customer-managed-encryption-keys-cmek" class="md-nav__link">
  1663. <span class="md-ellipsis">
  1664. Customer-Managed Encryption Keys (CMEK)
  1665. </span>
  1666. </a>
  1667. </li>
  1668. </ul>
  1669. </nav>
  1670. </li>
  1671. <li class="md-nav__item">
  1672. <a href="#regional-secrets" class="md-nav__link">
  1673. <span class="md-ellipsis">
  1674. Regional Secrets
  1675. </span>
  1676. </a>
  1677. </li>
  1678. <li class="md-nav__item">
  1679. <a href="#secret-version-management" class="md-nav__link">
  1680. <span class="md-ellipsis">
  1681. Secret Version Management
  1682. </span>
  1683. </a>
  1684. <nav class="md-nav" aria-label="Secret Version Management">
  1685. <ul class="md-nav__list">
  1686. <li class="md-nav__item">
  1687. <a href="#secret-version-selection-policy" class="md-nav__link">
  1688. <span class="md-ellipsis">
  1689. Secret Version Selection Policy
  1690. </span>
  1691. </a>
  1692. <nav class="md-nav" aria-label="Secret Version Selection Policy">
  1693. <ul class="md-nav__list">
  1694. <li class="md-nav__item">
  1695. <a href="#available-policies" class="md-nav__link">
  1696. <span class="md-ellipsis">
  1697. Available Policies
  1698. </span>
  1699. </a>
  1700. </li>
  1701. <li class="md-nav__item">
  1702. <a href="#configuration-example" class="md-nav__link">
  1703. <span class="md-ellipsis">
  1704. Configuration Example
  1705. </span>
  1706. </a>
  1707. </li>
  1708. </ul>
  1709. </nav>
  1710. </li>
  1711. </ul>
  1712. </nav>
  1713. </li>
  1714. </ul>
  1715. </nav>
  1716. </div>
  1717. </div>
  1718. </div>
  1719. <div class="md-content" data-md-component="content">
  1720. <article class="md-content__inner md-typeset">
  1721. <h1>Google Cloud Secret Manager</h1>
  1722. <p>External Secrets Operator integrates with the <a href="https://cloud.google.com/secret-manager">Google Cloud Secret Manager</a>.</p>
  1723. <h2 id="authentication">Authentication</h2>
  1724. <p>The Google Secret Manager provider resolves credentials in this order: static service account JSON (<code>auth.secretRef</code>), <a href="#workload-identity-gke">GKE Workload Identity</a> (<code>auth.workloadIdentity</code>), <a href="#workload-identity-federation">GCP Workload Identity Federation</a> (<code>auth.workloadIdentityFederation</code>), then <a href="https://cloud.google.com/docs/authentication/application-default-credentials">Application Default Credentials</a> from the environment (for example the GKE metadata server when no explicit auth is configured).</p>
  1725. <p>Pick the mechanism that matches where the operator runs:</p>
  1726. <table>
  1727. <thead>
  1728. <tr>
  1729. <th>Mechanism</th>
  1730. <th>API field</th>
  1731. <th>Typical use</th>
  1732. </tr>
  1733. </thead>
  1734. <tbody>
  1735. <tr>
  1736. <td>GKE Workload Identity</td>
  1737. <td><code>auth.workloadIdentity</code></td>
  1738. <td>GKE clusters with <a href="https://cloud.google.com/kubernetes-engine/docs/how-to/workload-identity">Workload Identity</a> enabled; uses the GKE metadata server and the identity binding token flow.</td>
  1739. </tr>
  1740. <tr>
  1741. <td>GCP Workload Identity Federation</td>
  1742. <td><code>auth.workloadIdentityFederation</code></td>
  1743. <td>AKS, EKS, self-hosted Kubernetes, or any setup where you configure an IAM workload identity pool and provider per <a href="https://cloud.google.com/iam/docs/workload-identity-federation-with-kubernetes">Google’s federation docs</a>.</td>
  1744. </tr>
  1745. <tr>
  1746. <td>Static service account key</td>
  1747. <td><code>auth.secretRef</code></td>
  1748. <td>Any cluster; long-lived JSON key in a Kubernetes <code>Secret</code> (not recommended where federation or GKE WI is available).</td>
  1749. </tr>
  1750. </tbody>
  1751. </table>
  1752. <p><a id="workload-identity-gke"></a></p>
  1753. <h3 id="workload-identity-gke">Workload Identity (GKE)</h3>
  1754. <p>Through <a href="https://cloud.google.com/kubernetes-engine/docs/how-to/workload-identity">GKE Workload Identity</a>, workloads on <strong>Google Kubernetes Engine</strong> can call Google APIs (including Secret Manager) without storing long-lived keys. In External Secrets Operator this path is implemented as <code>auth.workloadIdentity</code> and expects the <strong>GCP metadata server</strong> (available on GKE nodes) so the operator can discover the cluster project, name, and location when those fields are omitted.</p>
  1755. <p>Authenticating with GKE Workload Identity is the usual choice when the operator runs on GKE. ESO supports three patterns:</p>
  1756. <ul>
  1757. <li><strong>Using a Kubernetes service account as a GCP IAM principal</strong>: The <code>SecretStore</code> (or <code>ClusterSecretStore</code>) references a <a href="https://kubernetes.io/docs/concepts/security/service-accounts">Kubernetes service account</a> that is authorized to access Secret Manager secrets.</li>
  1758. <li><strong>Linking a Kubernetes service account to a GCP service account:</strong> The <code>SecretStore</code> (or <code>ClusterSecretStore</code>) references a Kubernetes service account, which is linked to a <a href="https://cloud.google.com/iam/docs/service-accounts">GCP service account</a> that is authorized to access Secret Manager secrets. This requires that the Kubernetes service account is annotated correctly and granted the <code>iam.workloadIdentityUser</code> role on the GCP service account.</li>
  1759. <li><strong>Authorizing the Core Controller Pod:</strong> The ESO Core Controller Pod's service account is authorized to access Secret Manager secrets. No authentication is required for <code>SecretStore</code> and <code>ClusterSecretStore</code> instances.</li>
  1760. </ul>
  1761. <p>In the following, we will describe each of these options in detail.</p>
  1762. <h4 id="prerequisites">Prerequisites</h4>
  1763. <ul>
  1764. <li>Enable and use <a href="https://cloud.google.com/kubernetes-engine/docs/how-to/workload-identity">Workload Identity on the GKE cluster</a>.</li>
  1765. </ul>
  1766. <h4 id="using-a-kubernetes-service-account-as-a-gcp-iam-principal">Using a Kubernetes service account as a GCP IAM principal</h4>
  1767. <p>The <code>SecretStore</code> (or <code>ClusterSecretStore</code>) references a Kubernetes service account that is authorized to access Secret Manager secrets.</p>
  1768. <p>To demonstrate this approach, we'll create a <code>SecretStore</code> in the <code>demo</code> namespace.</p>
  1769. <p>First, create a Kubernetes service account in the <code>demo</code> namespace:</p>
  1770. <div class="highlight"><pre><span></span><code><span class="nt">apiVersion</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">v1</span>
  1771. <span class="nt">kind</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">ServiceAccount</span>
  1772. <span class="nt">metadata</span><span class="p">:</span>
  1773. <span class="w"> </span><span class="nt">name</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">demo-secrets-sa</span>
  1774. <span class="w"> </span><span class="nt">namespace</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">demo</span>
  1775. </code></pre></div>
  1776. <p>To grant a Kubernetes service account access to Secret Manager secret(s), you need to know four values:</p>
  1777. <ul>
  1778. <li><code>PROJECT_ID</code>: Your GCP project ID, which you can find under "Project Info" on your console dashboard. Note that this might be different from your project's <em>name</em>.</li>
  1779. <li><code>PROJECT_NUMBER</code>: Your GCP project number, which you can find under "Project Info" on your console dashboard or through <code>gcloud projects describe $PROJECT_ID --format="value(projectNumber)"</code>.</li>
  1780. <li><code>K8S_SA</code>: The name of the Kubernetes service account you created. (In our example, <code>demo-secrets-sa</code>.)</li>
  1781. <li><code>K8S_NAMESPACE</code>: The namespace where you created the Kubernetes service account (In our example, <code>demo</code>.)</li>
  1782. </ul>
  1783. <p>For example, the following CLI call grants the Kubernetes service account access to a secret <code>demo-secret</code>:</p>
  1784. <div class="highlight"><pre><span></span><code>gcloud<span class="w"> </span>secrets<span class="w"> </span>add-iam-policy-binding<span class="w"> </span>demo-secret<span class="w"> </span><span class="se">\</span>
  1785. <span class="w"> </span>--project<span class="o">=</span><span class="nv">$PROJECT_ID</span><span class="w"> </span><span class="se">\</span>
  1786. <span class="w"> </span>--role<span class="o">=</span><span class="s2">&quot;roles/secretmanager.secretAccessor&quot;</span><span class="w"> </span><span class="se">\</span>
  1787. <span class="w"> </span>--member<span class="o">=</span><span class="s2">&quot;principal://iam.googleapis.com/projects/</span><span class="si">${</span><span class="nv">PROJECT_NUMBER</span><span class="si">}</span><span class="s2">/locations/global/workloadIdentityPools/</span><span class="si">${</span><span class="nv">PROJECT_ID</span><span class="si">}</span><span class="s2">.svc.id.goog/subject/ns/</span><span class="si">${</span><span class="nv">K8S_NAMESPACE</span><span class="si">}</span><span class="s2">/sa/</span><span class="si">${</span><span class="nv">K8S_SA</span><span class="si">}</span><span class="s2">&quot;</span>
  1788. </code></pre></div>
  1789. <p>You can also grant the Kubernetes service account access to <em>all</em> secrets in a GCP project:</p>
  1790. <div class="highlight"><pre><span></span><code>gcloud<span class="w"> </span>projects<span class="w"> </span>add-iam-policy-binding<span class="w"> </span><span class="nv">$PROJECT_ID</span><span class="w"> </span><span class="se">\</span>
  1791. <span class="w"> </span>--role<span class="o">=</span><span class="s2">&quot;roles/secretmanager.secretAccessor&quot;</span><span class="w"> </span><span class="se">\</span>
  1792. <span class="w"> </span>--member<span class="o">=</span><span class="s2">&quot;principal://iam.googleapis.com/projects/</span><span class="si">${</span><span class="nv">PROJECT_NUMBER</span><span class="si">}</span><span class="s2">/locations/global/workloadIdentityPools/</span><span class="si">${</span><span class="nv">PROJECT_ID</span><span class="si">}</span><span class="s2">.svc.id.goog/subject/ns/</span><span class="si">${</span><span class="nv">K8S_NAMESPACE</span><span class="si">}</span><span class="s2">/sa/</span><span class="si">${</span><span class="nv">K8S_SA</span><span class="si">}</span><span class="s2">&quot;</span>
  1793. </code></pre></div>
  1794. <p>Note that this allows anyone who can create <code>ExternalSecret</code> resources referencing a <code>SecretStore</code> instance using this service account access to all secrets in the project.</p>
  1795. <p><em>For more information about GKE Workload Identity and Secret Manager permissions, refer to:</em></p>
  1796. <ul>
  1797. <li><em><a href="https://cloud.google.com/kubernetes-engine/docs/how-to/workload-identity">Authenticate to Google Cloud APIs from GKE workloads</a> in the GKE documentation.</em></li>
  1798. <li><em><a href="https://cloud.google.com/secret-manager/docs/access-control">Access control with IAM</a> in the Secret Manager documentation.</em></li>
  1799. </ul>
  1800. <p>Next, create a <code>SecretStore</code> that references the <code>demo-secrets-sa</code> Kubernetes service account:</p>
  1801. <div class="highlight"><pre><span></span><code><span class="nt">apiVersion</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">external-secrets.io/v1</span>
  1802. <span class="nt">kind</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">SecretStore</span>
  1803. <span class="nt">metadata</span><span class="p">:</span>
  1804. <span class="w"> </span><span class="nt">name</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">demo-store</span>
  1805. <span class="w"> </span><span class="nt">namespace</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">demo</span>
  1806. <span class="nt">spec</span><span class="p">:</span>
  1807. <span class="w"> </span><span class="nt">provider</span><span class="p">:</span>
  1808. <span class="w"> </span><span class="nt">gcpsm</span><span class="p">:</span>
  1809. <span class="w"> </span><span class="nt">projectID</span><span class="p">:</span><span class="w"> </span><span class="p p-Indicator">[</span><span class="nv">PROJECT_ID</span><span class="p p-Indicator">]</span>
  1810. <span class="w"> </span><span class="nt">auth</span><span class="p">:</span>
  1811. <span class="w"> </span><span class="nt">workloadIdentity</span><span class="p">:</span>
  1812. <span class="w"> </span><span class="nt">serviceAccountRef</span><span class="p">:</span>
  1813. <span class="w"> </span><span class="nt">name</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">demo-secrets-sa</span>
  1814. </code></pre></div>
  1815. <p>In the case of a <code>ClusterSecretStore</code>, you additionally have to define the service account's <code>namespace</code> under <code>auth.workloadIdentity.serviceAccountRef</code>.</p>
  1816. <p>Finally, you can create an <code>ExternalSecret</code> for the <code>demo-secret</code> that references this <code>SecretStore</code>:</p>
  1817. <div class="highlight"><pre><span></span><code><span class="nt">apiVersion</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">external-secrets.io/v1</span>
  1818. <span class="nt">kind</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">ExternalSecret</span>
  1819. <span class="nt">metadata</span><span class="p">:</span>
  1820. <span class="w"> </span><span class="nt">name</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">demo-external-secret</span>
  1821. <span class="w"> </span><span class="nt">namespace</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">demo</span>
  1822. <span class="nt">spec</span><span class="p">:</span>
  1823. <span class="w"> </span><span class="nt">refreshInterval</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">1h0m0s</span>
  1824. <span class="w"> </span><span class="nt">secretStoreRef</span><span class="p">:</span>
  1825. <span class="w"> </span><span class="nt">name</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">demo-store</span>
  1826. <span class="w"> </span><span class="nt">kind</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">SecretStore</span>
  1827. <span class="w"> </span><span class="nt">target</span><span class="p">:</span>
  1828. <span class="w"> </span><span class="nt">name</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">secret-to-be-created</span>
  1829. <span class="w"> </span><span class="nt">creationPolicy</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">Owner</span>
  1830. <span class="w"> </span><span class="nt">data</span><span class="p">:</span>
  1831. <span class="w"> </span><span class="p p-Indicator">-</span><span class="w"> </span><span class="nt">secretKey</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">DEMO_SECRET</span>
  1832. <span class="w"> </span><span class="nt">remoteRef</span><span class="p">:</span>
  1833. <span class="w"> </span><span class="nt">key</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">demo-secret</span>
  1834. </code></pre></div>
  1835. <h4 id="linking-a-kubernetes-service-account-to-a-gcp-service-account">Linking a Kubernetes service account to a GCP service account</h4>
  1836. <p>The <code>SecretStore</code> (or <code>ClusterSecretStore</code>) references a Kubernetes service account, which is linked to a GCP service account that is authorized to access Secret Manager secrets.</p>
  1837. <p>To demonstrate this approach, we'll create a <code>SecretStore</code> in the <code>demo</code> namespace.</p>
  1838. <p>To set up the Kubernetes service account, you need to know or choose the following values:</p>
  1839. <ul>
  1840. <li><code>PROJECT_ID</code>: Your GCP project ID, which you can find under "Project Info" on your console dashboard. Note that this might be different from your project's <em>name</em>.</li>
  1841. <li><code>GCP_SA</code>: The name of the GCP service account you are going to create and use (e.g., <code>external-secrets</code>).</li>
  1842. </ul>
  1843. <p>First, create the Kubernetes service account with an annotation that references the GCP service account:</p>
  1844. <div class="highlight"><pre><span></span><code><span class="nt">apiVersion</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">v1</span>
  1845. <span class="nt">kind</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">ServiceAccount</span>
  1846. <span class="nt">metadata</span><span class="p">:</span>
  1847. <span class="w"> </span><span class="nt">name</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">demo-secrets-sa</span>
  1848. <span class="w"> </span><span class="nt">namespace</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">demo</span>
  1849. <span class="w"> </span><span class="nt">annotations</span><span class="p">:</span>
  1850. <span class="w"> </span><span class="nt">iam.gke.io/gcp-service-account</span><span class="p">:</span><span class="w"> </span><span class="p p-Indicator">[</span><span class="nv">GCP_SA</span><span class="p p-Indicator">]</span><span class="err">@</span><span class="p p-Indicator">[</span><span class="nv">PROJECT_ID</span><span class="p p-Indicator">]</span><span class="l l-Scalar l-Scalar-Plain">.iam.gserviceaccount.com</span>
  1851. </code></pre></div>
  1852. <p>Next, create the GCP service account:</p>
  1853. <div class="highlight"><pre><span></span><code>gcloud<span class="w"> </span>iam<span class="w"> </span>service-accounts<span class="w"> </span>create<span class="w"> </span><span class="nv">$GCP_SA</span><span class="w"> </span><span class="se">\</span>
  1854. <span class="w"> </span>--project<span class="o">=</span><span class="nv">$PROJECT_ID</span>
  1855. </code></pre></div>
  1856. <p>To finalize the link between the GCP service account and the Kubernetes service account, you need two additional values:</p>
  1857. <ul>
  1858. <li><code>K8S_SA</code>: The name of the Kubernetes service account you created. (In our example, <code>demo-secrets-sa</code>.)</li>
  1859. <li><code>K8S_NAMESPACE</code>: The namespace where you created the Kubernetes service account (In our example, <code>demo</code>.)</li>
  1860. </ul>
  1861. <p>Grant the Kubernetes service account the <code>iam.workloadIdentityUser</code> role on the GCP service account:</p>
  1862. <div class="highlight"><pre><span></span><code>gcloud<span class="w"> </span>iam<span class="w"> </span>service-accounts<span class="w"> </span>add-iam-policy-binding<span class="w"> </span><span class="se">\</span>
  1863. <span class="w"> </span><span class="si">${</span><span class="nv">GCP_SA</span><span class="si">}</span>@<span class="si">${</span><span class="nv">PROJECT_ID</span><span class="si">}</span>.iam.gserviceaccount.com<span class="w"> </span><span class="se">\</span>
  1864. <span class="w"> </span>--role<span class="o">=</span><span class="s2">&quot;roles/iam.workloadIdentityUser&quot;</span><span class="w"> </span><span class="se">\</span>
  1865. <span class="w"> </span>--member<span class="w"> </span><span class="s2">&quot;serviceAccount:</span><span class="si">${</span><span class="nv">PROJECT_ID</span><span class="si">}</span><span class="s2">.svc.id.goog[</span><span class="si">${</span><span class="nv">K8S_NAMESPACE</span><span class="si">}</span><span class="s2">/</span><span class="si">${</span><span class="nv">K8S_SA</span><span class="si">}</span><span class="s2">]&quot;</span>
  1866. </code></pre></div>
  1867. <p>Next, grant the GCP service account access to a secret in the Secret Manager.
  1868. For example, the following CLI call grants it access to a secret <code>demo-secret</code>:</p>
  1869. <div class="highlight"><pre><span></span><code>gcloud<span class="w"> </span>secrets<span class="w"> </span>add-iam-policy-binding<span class="w"> </span>demo-secret<span class="w"> </span><span class="se">\</span>
  1870. <span class="w"> </span>--project<span class="o">=</span><span class="nv">$PROJECT_ID</span><span class="w"> </span><span class="se">\</span>
  1871. <span class="w"> </span>--role<span class="o">=</span><span class="s2">&quot;roles/secretmanager.secretAccessor&quot;</span><span class="w"> </span><span class="se">\</span>
  1872. <span class="w"> </span>--member<span class="w"> </span><span class="s2">&quot;serviceAccount:</span><span class="si">${</span><span class="nv">GCP_SA</span><span class="si">}</span><span class="s2">@</span><span class="si">${</span><span class="nv">PROJECT_ID</span><span class="si">}</span><span class="s2">.iam.gserviceaccount.com&quot;</span>
  1873. </code></pre></div>
  1874. <p>You can also grant the GCP service account access to <em>all</em> secrets in a GCP project:</p>
  1875. <div class="highlight"><pre><span></span><code>gcloud<span class="w"> </span>projects<span class="w"> </span>add-iam-policy-binding<span class="w"> </span><span class="nv">$PROJECT_ID</span><span class="w"> </span><span class="se">\</span>
  1876. <span class="w"> </span>--role<span class="o">=</span><span class="s2">&quot;roles/secretmanager.secretAccessor&quot;</span><span class="w"> </span><span class="se">\</span>
  1877. <span class="w"> </span>--member<span class="w"> </span><span class="s2">&quot;serviceAccount:</span><span class="si">${</span><span class="nv">GCP_SA</span><span class="si">}</span><span class="s2">@</span><span class="si">${</span><span class="nv">PROJECT_ID</span><span class="si">}</span><span class="s2">.iam.gserviceaccount.com&quot;</span>
  1878. </code></pre></div>
  1879. <p>Note that this allows anyone who can create <code>ExternalSecret</code> resources referencing a <code>SecretStore</code> instance using this service account access to all secrets in the project.</p>
  1880. <p><em>For more information about GKE Workload Identity and Secret Manager permissions, refer to:</em></p>
  1881. <ul>
  1882. <li><em><a href="https://cloud.google.com/kubernetes-engine/docs/how-to/workload-identity">Authenticate to Google Cloud APIs from GKE workloads</a> in the GKE documentation.</em></li>
  1883. <li><em><a href="https://cloud.google.com/secret-manager/docs/access-control">Access control with IAM</a> in the Secret Manager documentation.</em></li>
  1884. </ul>
  1885. <p>Next, create a <code>SecretStore</code> that references the <code>demo-secrets-sa</code> Kubernetes service account:</p>
  1886. <div class="highlight"><pre><span></span><code><span class="nt">apiVersion</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">external-secrets.io/v1</span>
  1887. <span class="nt">kind</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">SecretStore</span>
  1888. <span class="nt">metadata</span><span class="p">:</span>
  1889. <span class="w"> </span><span class="nt">name</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">demo-store</span>
  1890. <span class="w"> </span><span class="nt">namespace</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">demo</span>
  1891. <span class="nt">spec</span><span class="p">:</span>
  1892. <span class="w"> </span><span class="nt">provider</span><span class="p">:</span>
  1893. <span class="w"> </span><span class="nt">gcpsm</span><span class="p">:</span>
  1894. <span class="w"> </span><span class="nt">projectID</span><span class="p">:</span><span class="w"> </span><span class="p p-Indicator">[</span><span class="nv">PROJECT_ID</span><span class="p p-Indicator">]</span>
  1895. <span class="w"> </span><span class="nt">auth</span><span class="p">:</span>
  1896. <span class="w"> </span><span class="nt">workloadIdentity</span><span class="p">:</span>
  1897. <span class="w"> </span><span class="nt">serviceAccountRef</span><span class="p">:</span>
  1898. <span class="w"> </span><span class="nt">name</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">demo-secrets-sa</span>
  1899. </code></pre></div>
  1900. <p>In the case of a <code>ClusterSecretStore</code>, you additionally have to define the service account's <code>namespace</code> under <code>auth.workloadIdentity.serviceAccountRef</code>.</p>
  1901. <p>Finally, you can create an <code>ExternalSecret</code> for the <code>demo-secret</code> that references this <code>SecretStore</code>:</p>
  1902. <div class="highlight"><pre><span></span><code><span class="nt">apiVersion</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">external-secrets.io/v1</span>
  1903. <span class="nt">kind</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">ExternalSecret</span>
  1904. <span class="nt">metadata</span><span class="p">:</span>
  1905. <span class="w"> </span><span class="nt">name</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">demo-external-secret</span>
  1906. <span class="w"> </span><span class="nt">namespace</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">demo</span>
  1907. <span class="nt">spec</span><span class="p">:</span>
  1908. <span class="w"> </span><span class="nt">refreshInterval</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">1h0m0s</span>
  1909. <span class="w"> </span><span class="nt">secretStoreRef</span><span class="p">:</span>
  1910. <span class="w"> </span><span class="nt">name</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">demo-store</span>
  1911. <span class="w"> </span><span class="nt">kind</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">SecretStore</span>
  1912. <span class="w"> </span><span class="nt">target</span><span class="p">:</span>
  1913. <span class="w"> </span><span class="nt">name</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">secret-to-be-created</span>
  1914. <span class="w"> </span><span class="nt">creationPolicy</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">Owner</span>
  1915. <span class="w"> </span><span class="nt">data</span><span class="p">:</span>
  1916. <span class="w"> </span><span class="p p-Indicator">-</span><span class="w"> </span><span class="nt">secretKey</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">DEMO_SECRET</span>
  1917. <span class="w"> </span><span class="nt">remoteRef</span><span class="p">:</span>
  1918. <span class="w"> </span><span class="nt">key</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">demo-secret</span>
  1919. </code></pre></div>
  1920. <h4 id="authorizing-the-core-controller-pod">Authorizing the Core Controller Pod</h4>
  1921. <p>Instead of managing authentication at the <code>SecretStore</code> and <code>ClusterSecretStore</code> level, you can give the <a href="../../api/components/">Core Controller</a> Pod's service account access to Secret Manager secrets using one of the two GKE Workload Identity approaches described in the previous sections.</p>
  1922. <p>To demonstrate this approach, we'll assume you installed ESO using Helm into the <code>external-secrets</code> namespace, with <code>external-secrets</code> as the release name:</p>
  1923. <div class="highlight"><pre><span></span><code>helm<span class="w"> </span>repo<span class="w"> </span>add<span class="w"> </span>external-secrets<span class="w"> </span>https://charts.external-secrets.io
  1924. helm<span class="w"> </span>install<span class="w"> </span>external-secrets<span class="w"> </span>external-secrets/external-secrets<span class="w"> </span><span class="se">\</span>
  1925. <span class="w"> </span>--namespace<span class="w"> </span>external-secrets<span class="w"> </span>--create-namespace
  1926. </code></pre></div>
  1927. <p>This creates a Kubernetes service account <code>external-secrets</code> in the <code>external-secrets</code> namespace, which is used by the Core Controller Pod.</p>
  1928. <p>To verify this (or to determine the service account's name in a different setup), you can run:</p>
  1929. <div class="highlight"><pre><span></span><code>kubectl<span class="w"> </span>get<span class="w"> </span>pods<span class="w"> </span>--namespace<span class="w"> </span>external-secrets<span class="w"> </span><span class="se">\</span>
  1930. <span class="w"> </span>--selector<span class="w"> </span>app.kubernetes.io/name<span class="o">=</span>external-secrets<span class="w"> </span><span class="se">\</span>
  1931. <span class="w"> </span>--output<span class="w"> </span><span class="nv">jsonpath</span><span class="o">=</span><span class="s1">&#39;{.items[0].spec.serviceAccountName}&#39;</span>
  1932. </code></pre></div>
  1933. <p>Use GKE Workload Identity to grant this Kubernetes service account access to the Secret Manager secrets.
  1934. You can use either of the approaches described in the previous two sections.</p>
  1935. <p><em>For details and further information on GKE Workload Identity and Secret Manager permissions, refer to:</em></p>
  1936. <ul>
  1937. <li><em><a href="https://cloud.google.com/kubernetes-engine/docs/how-to/workload-identity">Authenticate to Google Cloud APIs from GKE workloads</a> in the GKE documentation.</em></li>
  1938. <li><em><a href="https://cloud.google.com/secret-manager/docs/access-control">Access control with IAM</a> in the Secret Manager documentation.</em></li>
  1939. </ul>
  1940. <p>Once the Core Controller Pod can access the Secret Manager secret(s) through GKE Workload Identity via its Kubernetes service account, you can create <code>SecretStore</code> or <code>ClusterSecretStore</code> instances without authentication configuration. You can optionally specify the GCP project ID, or omit it to use auto-detection from the GCP metadata server:</p>
  1941. <div class="highlight"><pre><span></span><code><span class="nt">apiVersion</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">external-secrets.io/v1</span>
  1942. <span class="nt">kind</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">SecretStore</span>
  1943. <span class="nt">metadata</span><span class="p">:</span>
  1944. <span class="w"> </span><span class="nt">name</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">demo-store</span>
  1945. <span class="w"> </span><span class="nt">namespace</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">demo</span>
  1946. <span class="nt">spec</span><span class="p">:</span>
  1947. <span class="w"> </span><span class="nt">provider</span><span class="p">:</span>
  1948. <span class="w"> </span><span class="nt">gcpsm</span><span class="p">:</span>
  1949. <span class="w"> </span><span class="nt">projectID</span><span class="p">:</span><span class="w"> </span><span class="p p-Indicator">[</span><span class="nv">PROJECT_ID</span><span class="p p-Indicator">]</span>
  1950. </code></pre></div>
  1951. <p>Alternatively, with projectID auto-detection (GKE only):</p>
  1952. <div class="highlight"><pre><span></span><code><span class="nt">apiVersion</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">external-secrets.io/v1</span>
  1953. <span class="nt">kind</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">SecretStore</span>
  1954. <span class="nt">metadata</span><span class="p">:</span>
  1955. <span class="w"> </span><span class="nt">name</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">gcp-secret-store</span>
  1956. <span class="w"> </span><span class="nt">namespace</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">demo</span>
  1957. <span class="nt">spec</span><span class="p">:</span>
  1958. <span class="w"> </span><span class="nt">provider</span><span class="p">:</span>
  1959. <span class="w"> </span><span class="nt">gcpsm</span><span class="p">:</span><span class="w"> </span><span class="p p-Indicator">{}</span><span class="w"> </span><span class="c1"># Both projectID and auth are optional when using Core Controller authentication in GKE</span>
  1960. </code></pre></div>
  1961. <h4 id="auto-detection-of-gcp-project-id">Auto-detection of GCP project ID</h4>
  1962. <p>When creating a <code>SecretStore</code> or <code>ClusterSecretStore</code>, the <code>projectID</code> field is optional only if the provider can infer the Google Cloud project another way. The implementation resolves a fallback project from the <a href="https://cloud.google.com/compute/docs/metadata/overview">GCP metadata server</a> when <strong>no</strong> <code>auth.secretRef</code> is set and the controller runs on <strong>GKE</strong> (metadata is not available on most non-GKE clusters).</p>
  1963. <p>In practice:</p>
  1964. <ul>
  1965. <li>With <strong><code>auth.workloadIdentity</code></strong> or ADC on <strong>GKE</strong>, omitting <code>projectID</code> is supported when Secret Manager secrets live in the <strong>same</strong> project as the cluster (or when <code>clusterProjectID</code> / explicit <code>projectID</code> disambiguates cross-project cases; see below).</li>
  1966. <li>With <strong><code>auth.workloadIdentityFederation</code></strong> on clusters <strong>without</strong> GCP metadata, set <strong><code>projectID</code></strong> explicitly to the project that owns your secrets.</li>
  1967. <li>With <strong><code>auth.secretRef</code></strong>, <code>projectID</code> is <strong>required</strong> (no metadata fallback).</li>
  1968. </ul>
  1969. <p>This allows portable <code>SecretStore</code> configurations on GKE without hard-coding the project when the above conditions hold:</p>
  1970. <div class="highlight"><pre><span></span><code><span class="nt">apiVersion</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">external-secrets.io/v1</span>
  1971. <span class="nt">kind</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">SecretStore</span>
  1972. <span class="nt">metadata</span><span class="p">:</span>
  1973. <span class="w"> </span><span class="nt">name</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">gcp-secret-store</span>
  1974. <span class="nt">spec</span><span class="p">:</span>
  1975. <span class="w"> </span><span class="nt">provider</span><span class="p">:</span>
  1976. <span class="w"> </span><span class="nt">gcpsm</span><span class="p">:</span>
  1977. <span class="w"> </span><span class="c1"># projectID optional on GKE when metadata resolves the secrets project</span>
  1978. <span class="w"> </span><span class="nt">auth</span><span class="p">:</span>
  1979. <span class="w"> </span><span class="nt">workloadIdentity</span><span class="p">:</span>
  1980. <span class="w"> </span><span class="nt">serviceAccountRef</span><span class="p">:</span>
  1981. <span class="w"> </span><span class="nt">name</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">demo-secrets-sa</span>
  1982. </code></pre></div>
  1983. <p>You must set <code>projectID</code> explicitly when using static service account credentials (<code>auth.secretRef</code>), when the metadata server is unavailable or points at the wrong project, or when accessing secrets in a different project than the one inferred for the client.</p>
  1984. <h4 id="projectid-vs-clusterprojectid">projectID vs clusterProjectID</h4>
  1985. <p><code>projectID</code> (<code>spec.provider.gcpsm.projectID</code>) tells the provider which GCP project holds the secrets. It is used in secret resource paths like <code>projects/{projectID}/secrets/{name}</code>. For <strong>GKE Workload Identity</strong> (<code>auth.workloadIdentity</code>), it also feeds cluster-side resolution when <code>clusterProjectID</code> is not set.</p>
  1986. <p><code>clusterProjectID</code> (<code>spec.provider.gcpsm.auth.workloadIdentity.clusterProjectID</code>) identifies the project hosting the GKE cluster. It is <strong>only</strong> used by <strong><code>auth.workloadIdentity</code></strong> to build the identity pool and provider URL. When either field is omitted on GKE, the provider can query the <a href="https://cloud.google.com/compute/docs/metadata/overview">GCP metadata server</a> for the project ID. This field does not apply to <code>auth.workloadIdentityFederation</code>.</p>
  1987. <p>For cross-project access, set both fields explicitly:</p>
  1988. <div class="highlight"><pre><span></span><code><span class="nt">spec</span><span class="p">:</span>
  1989. <span class="w"> </span><span class="nt">provider</span><span class="p">:</span>
  1990. <span class="w"> </span><span class="nt">gcpsm</span><span class="p">:</span>
  1991. <span class="w"> </span><span class="nt">projectID</span><span class="p">:</span><span class="w"> </span><span class="s">&quot;secrets-project-456&quot;</span>
  1992. <span class="w"> </span><span class="nt">auth</span><span class="p">:</span>
  1993. <span class="w"> </span><span class="nt">workloadIdentity</span><span class="p">:</span>
  1994. <span class="w"> </span><span class="nt">clusterProjectID</span><span class="p">:</span><span class="w"> </span><span class="s">&quot;cluster-project-123&quot;</span>
  1995. <span class="w"> </span><span class="nt">serviceAccountRef</span><span class="p">:</span>
  1996. <span class="w"> </span><span class="nt">name</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">demo-sa</span>
  1997. </code></pre></div>
  1998. <h4 id="explicitly-specifying-the-gke-clusters-name-and-location">Explicitly specifying the GKE cluster's name and location</h4>
  1999. <p>When creating a <code>SecretStore</code> or <code>ClusterSecretStore</code> that uses <strong><code>auth.workloadIdentity</code></strong>, the GKE cluster's name and location are automatically determined through the <a href="https://cloud.google.com/compute/docs/metadata/overview">GCP metadata server</a>.
  2000. Alternatively, you can explicitly specify some or all of these values.</p>
  2001. <p>For a fully specified configuration, you'll need to know the following three values:</p>
  2002. <ul>
  2003. <li><code>CLUSTER_PROJECT_ID</code>: The ID of GCP project that contains the GKE cluster.</li>
  2004. <li><code>CLUSTER_NAME</code>: The name of the GKE cluster.</li>
  2005. <li><code>CLUSTER_LOCATION</code>: The location of the GKE cluster. For a regional cluster, this is the region. For a zonal cluster, this is the zone.</li>
  2006. </ul>
  2007. <p>You can optionally verify these values through the CLI:</p>
  2008. <div class="highlight"><pre><span></span><code>gcloud<span class="w"> </span>container<span class="w"> </span>clusters<span class="w"> </span>describe<span class="w"> </span><span class="nv">$CLUSTER_NAME</span><span class="w"> </span><span class="se">\</span>
  2009. <span class="w"> </span>--project<span class="o">=</span><span class="nv">$CLUSTER_PROJECT_ID</span><span class="w"> </span>--location<span class="o">=</span><span class="nv">$CLUSTER_LOCATION</span>
  2010. </code></pre></div>
  2011. <p>If the three values are correct, this returns information about your GKE cluster.</p>
  2012. <p>Then, you can create a <code>SecretStore</code> or <code>ClusterSecretStore</code> that explicitly specifies the cluster's project ID, name, and location:</p>
  2013. <div class="highlight"><pre><span></span><code><span class="nt">apiVersion</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">external-secrets.io/v1</span>
  2014. <span class="nt">kind</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">SecretStore</span>
  2015. <span class="nt">metadata</span><span class="p">:</span>
  2016. <span class="w"> </span><span class="nt">name</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">demo-store</span>
  2017. <span class="w"> </span><span class="nt">namespace</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">demo</span>
  2018. <span class="nt">spec</span><span class="p">:</span>
  2019. <span class="w"> </span><span class="nt">provider</span><span class="p">:</span>
  2020. <span class="w"> </span><span class="nt">gcpsm</span><span class="p">:</span>
  2021. <span class="w"> </span><span class="nt">projectID</span><span class="p">:</span><span class="w"> </span><span class="p p-Indicator">[</span><span class="nv">PROJECT_ID</span><span class="p p-Indicator">]</span>
  2022. <span class="w"> </span><span class="nt">auth</span><span class="p">:</span>
  2023. <span class="w"> </span><span class="nt">workloadIdentity</span><span class="p">:</span>
  2024. <span class="w"> </span><span class="nt">clusterProjectID</span><span class="p">:</span><span class="w"> </span><span class="p p-Indicator">[</span><span class="nv">CLUSTER_PROJECT_ID</span><span class="p p-Indicator">]</span>
  2025. <span class="w"> </span><span class="nt">clusterLocation</span><span class="p">:</span><span class="w"> </span><span class="p p-Indicator">[</span><span class="nv">CLUSTER_LOCATION</span><span class="p p-Indicator">]</span>
  2026. <span class="w"> </span><span class="nt">clusterName</span><span class="p">:</span><span class="w"> </span><span class="p p-Indicator">[</span><span class="nv">CLUSTER_NAME</span><span class="p p-Indicator">]</span>
  2027. <span class="w"> </span><span class="nt">serviceAccountRef</span><span class="p">:</span>
  2028. <span class="w"> </span><span class="nt">name</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">demo-secrets-sa</span>
  2029. </code></pre></div>
  2030. <p><a id="workload-identity-federation"></a></p>
  2031. <h3 id="workload-identity-federation">Workload Identity Federation</h3>
  2032. <p><a href="https://cloud.google.com/iam/docs/workload-identity-federation">GCP Workload Identity Federation</a> lets workloads use <strong>short-lived tokens from an external identity provider</strong> (for example a Kubernetes API server or AWS) that Google trusts through an IAM <strong>workload identity pool</strong> and <strong>provider</strong>. This is different from <a href="#workload-identity-gke">GKE Workload Identity</a>: federation uses the <strong>external account</strong> OAuth flow (STS token exchange via <code>golang.org/x/oauth2/google/externalaccount</code>) and does <strong>not</strong> rely on the GKE identity binding token or the default <code>.svc.id.goog</code> pool on the cluster project.</p>
  2033. <p>Use <code>auth.workloadIdentityFederation</code> when you follow Google’s guide to <a href="https://cloud.google.com/iam/docs/workload-identity-federation-with-kubernetes">configure Workload Identity Federation with Kubernetes</a> on AKS, EKS, self-hosted clusters, and OpenShift, or when you <a href="https://cloud.google.com/iam/docs/workload-identity-federation-with-other-clouds#create-cred-config">configure an AWS workload identity pool provider and credential file</a> for AWS-based subject tokens.</p>
  2034. <h4 id="configuration-rules">Configuration rules</h4>
  2035. <p>Under <code>auth.workloadIdentityFederation</code> you must set <strong>exactly one</strong> of <code>serviceAccountRef</code>, <code>credConfig</code>, or <code>awsSecurityCredentials</code>. The provider rejects any other combination.</p>
  2036. <table>
  2037. <thead>
  2038. <tr>
  2039. <th>Field</th>
  2040. <th>Purpose</th>
  2041. </tr>
  2042. </thead>
  2043. <tbody>
  2044. <tr>
  2045. <td><code>serviceAccountRef</code></td>
  2046. <td>Request a bound token for the named Kubernetes <code>ServiceAccount</code> and use it as the STS subject token (<code>urn:ietf:params:oauth:token-type:jwt</code>). <strong>Requires <code>audience</code>.</strong></td>
  2047. </tr>
  2048. <tr>
  2049. <td><code>credConfig</code></td>
  2050. <td>Load an <code>external_account</code> JSON document from a <code>ConfigMap</code> key (<a href="https://cloud.google.com/docs/authentication/application-default-credentials#external-identities">external identity ADC JSON</a>). <code>audience</code> may come from the JSON or be overridden by the spec field; it must be non-empty after merge.</td>
  2051. </tr>
  2052. <tr>
  2053. <td><code>awsSecurityCredentials</code></td>
  2054. <td>Supply static AWS credentials in a Kubernetes <code>Secret</code> plus <code>region</code> so the subject token type is <code>urn:ietf:params:aws:token-type:aws4_request</code> without using the instance metadata service from inside the pod. <strong>Requires <code>audience</code>.</strong></td>
  2055. </tr>
  2056. </tbody>
  2057. </table>
  2058. <p><strong><code>audience</code>:</strong> Required on the spec when <code>serviceAccountRef</code> or <code>awsSecurityCredentials</code> is set. It must be the full workload identity <strong>provider</strong> resource name, for example <code>//iam.googleapis.com/projects/PROJECT_NUMBER/locations/global/workloadIdentityPools/POOL_ID/providers/PROVIDER_ID</code>. When only <code>credConfig</code> is used, <code>audience</code> can be supplied in the JSON; a non-empty <code>audience</code> on the spec overrides the file value.</p>
  2059. <p><strong><code>projectID</code>:</strong> Set <code>spec.provider.gcpsm.projectID</code> to the project that contains your Secret Manager secrets whenever the controller cannot rely on GKE metadata (typical for federation off GCP nodes).</p>
  2060. <h4 id="kubernetes-subject-token-serviceaccountref">Kubernetes subject token (<code>serviceAccountRef</code>)</h4>
  2061. <p>ESO uses the Kubernetes <code>TokenRequest</code> API to mint a token for <code>serviceAccountRef</code> with <code>aud</code> equal to <code>spec.provider.gcpsm.auth.workloadIdentityFederation.audience</code>, optionally appending entries from <code>serviceAccountRef.audiences</code>. That token is exchanged at Google STS for a Google access token.</p>
  2062. <p>Grant access on the secret (or project) to the <strong>federated principal</strong> for that Kubernetes identity:</p>
  2063. <div class="highlight"><pre><span></span><code>gcloud<span class="w"> </span>secrets<span class="w"> </span>add-iam-policy-binding<span class="w"> </span><span class="s2">&quot;</span><span class="si">${</span><span class="nv">SECRET_NAME</span><span class="si">}</span><span class="s2">&quot;</span><span class="w"> </span><span class="se">\</span>
  2064. <span class="w"> </span>--project<span class="o">=</span><span class="s2">&quot;</span><span class="si">${</span><span class="nv">PROJECT_ID</span><span class="si">}</span><span class="s2">&quot;</span><span class="w"> </span><span class="se">\</span>
  2065. <span class="w"> </span>--role<span class="o">=</span><span class="s2">&quot;roles/secretmanager.secretAccessor&quot;</span><span class="w"> </span><span class="se">\</span>
  2066. <span class="w"> </span>--member<span class="o">=</span><span class="s2">&quot;principal://iam.googleapis.com/projects/</span><span class="si">${</span><span class="nv">PROJECT_NUMBER</span><span class="si">}</span><span class="s2">/locations/global/workloadIdentityPools/</span><span class="si">${</span><span class="nv">WIF_POOL_NAME</span><span class="si">}</span><span class="s2">/subject/system:serviceaccount:</span><span class="si">${</span><span class="nv">K8S_NAMESPACE</span><span class="si">}</span><span class="s2">:</span><span class="si">${</span><span class="nv">K8S_SA</span><span class="si">}</span><span class="s2">&quot;</span>
  2067. </code></pre></div>
  2068. <p>If the principal does <strong>not</strong> have <code>secretmanager.secrets.get</code> / accessor on a secret, sync fails with <code>PermissionDenied</code> on <code>secretmanager.versions.access</code> even when the <code>SecretStore</code> is <code>Ready</code>—bind IAM to the identity that actually reaches Secret Manager after impersonation (see below).</p>
  2069. <p>Example <code>SecretStore</code> when Kubernetes is the external identity provider (see the <a href="https://external-secrets.io/latest/api/spec/#external-secrets.io/v1.GCPWorkloadIdentityFederation">WorkloadIdentityFederation API</a>):</p>
  2070. <div class="highlight"><pre><span></span><code><span class="nt">apiVersion</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">external-secrets.io/v1</span>
  2071. <span class="nt">kind</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">SecretStore</span>
  2072. <span class="nt">metadata</span><span class="p">:</span>
  2073. <span class="w"> </span><span class="nt">name</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">demo-store</span>
  2074. <span class="w"> </span><span class="nt">namespace</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">demo</span>
  2075. <span class="nt">spec</span><span class="p">:</span>
  2076. <span class="w"> </span><span class="nt">provider</span><span class="p">:</span>
  2077. <span class="w"> </span><span class="nt">gcpsm</span><span class="p">:</span>
  2078. <span class="w"> </span><span class="nt">projectID</span><span class="p">:</span><span class="w"> </span><span class="p p-Indicator">[</span><span class="nv">PROJECT_ID</span><span class="p p-Indicator">]</span>
  2079. <span class="w"> </span><span class="nt">auth</span><span class="p">:</span>
  2080. <span class="w"> </span><span class="nt">workloadIdentityFederation</span><span class="p">:</span>
  2081. <span class="w"> </span><span class="nt">audience</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">//iam.googleapis.com/projects/[PROJECT_ID]/locations/[CLUSTER_LOCATION]/workloadIdentityPools/[WORKLOAD_IDENTITY_POOL]/providers/[WORKLOAD_IDENTITY_PROVIDER]</span>
  2082. <span class="w"> </span><span class="nt">serviceAccountRef</span><span class="p">:</span>
  2083. <span class="w"> </span><span class="nt">name</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">demo-secrets-sa</span>
  2084. <span class="w"> </span><span class="nt">namespace</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">demo</span>
  2085. <span class="w"> </span><span class="nt">audiences</span><span class="p">:</span>
  2086. <span class="w"> </span><span class="p p-Indicator">-</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">demo-audience</span>
  2087. </code></pre></div>
  2088. <p>For <code>ClusterSecretStore</code>, set <code>serviceAccountRef.namespace</code> when the <code>ServiceAccount</code> lives outside the referent namespace.</p>
  2089. <h4 id="google-service-account-impersonation">Google service account impersonation</h4>
  2090. <p>After STS returns a federated identity, ESO may call the <a href="https://cloud.google.com/iam/docs/reference/credentials/rest">IAM Credentials API</a> to <strong>impersonate</strong> a Google service account (GSA) and obtain an access token with Secret Manager scopes.</p>
  2091. <p>Impersonation is resolved as follows (see <code>updateServiceAccountImpersonationURL</code> in the provider):</p>
  2092. <ol>
  2093. <li><strong><code>gcpServiceAccountEmail</code></strong> on <code>workloadIdentityFederation</code> — if set, it always sets impersonation for that GSA and overrides any other impersonation hint.</li>
  2094. <li>With <strong><code>credConfig</code> only</strong> (no <code>serviceAccountRef</code>): use <strong><code>service_account_impersonation_url</code></strong> from the <code>external_account</code> JSON when present (unless step 1 already applied).</li>
  2095. <li>With <strong><code>serviceAccountRef</code></strong>: if step 1 did not apply, use the <strong><code>iam.gke.io/gcp-service-account</code></strong> annotation on that <code>ServiceAccount</code> when present.</li>
  2096. </ol>
  2097. <p>The implementation only allows impersonation URLs that match Google’s <code>generateAccessToken</code> endpoint pattern (see validation in the provider).</p>
  2098. <p>Typical patterns:</p>
  2099. <ul>
  2100. <li><strong>Direct access:</strong> bind <code>roles/secretmanager.secretAccessor</code> on secrets to the <strong>workload identity principal</strong> (<code>principal://…/subject/system:serviceaccount:…</code>), as in the previous section. No impersonation.</li>
  2101. <li><strong>Access via a GSA:</strong> bind <code>roles/secretmanager.secretAccessor</code> on secrets to the <strong>GSA</strong> (<code>serviceAccount:my-gsa@project.iam.gserviceaccount.com</code>). Grant the federated principal <strong><code>roles/iam.workloadIdentityUser</code></strong> on that GSA (<a href="https://cloud.google.com/iam/docs/workload-identity-federation-with-kubernetes#kubernetes-sa">grant access to service accounts</a>) so it may impersonate it, and set <code>gcpServiceAccountEmail</code> (or the <code>iam.gke.io/gcp-service-account</code> annotation) so ESO uses impersonation. If the federated principal lacks secret access but the GSA has it, sync fails with <code>PermissionDenied</code> until impersonation is configured—see <a href="https://cloud.google.com/iam/docs/using-workload-identity-federation#impersonation">impersonating a service account</a> and <a href="https://cloud.google.com/iam/docs/create-short-lived-credentials-direct#sa-credentials-oauth">creating short-lived credentials</a>.</li>
  2102. </ul>
  2103. <h4 id="external-account-json-credconfig">External account JSON (<code>credConfig</code>)</h4>
  2104. <p>Point <code>credConfig</code> at a <code>ConfigMap</code> key whose value is JSON with <code>"type": "external_account"</code> and the usual fields (<code>audience</code>, <code>subject_token_type</code>, <code>token_url</code>, <code>token_info_url</code>, <code>credential_source</code>, optional <code>service_account_impersonation_url</code>, etc.). Generate a starting file with <a href="https://cloud.google.com/iam/docs/workload-identity-federation-with-other-clouds#create-cred-config"><code>gcloud iam workload-identity-pools create-cred-config</code></a> as described in Google’s documentation.</p>
  2105. <p>Security and validation notes enforced by the provider:</p>
  2106. <ul>
  2107. <li><strong><code>credential_source.executable</code></strong> is <strong>not allowed</strong>.</li>
  2108. <li>After merge, <strong><code>token_url</code></strong> must look like <code>https://sts.&lt;universe&gt;/v1/token</code> and <strong><code>token_info_url</code></strong> like <code>https://sts.&lt;universe&gt;/v1/introspect</code> (defaults are filled for <code>googleapis.com</code> when omitted).</li>
  2109. <li>If <code>credential_source</code> uses a <strong>non-AWS</strong> HTTP <strong><code>url</code></strong>, set <strong><code>externalTokenEndpoint</code></strong> on the spec to the <strong>same</strong> URL; the provider verifies they match.</li>
  2110. <li>If <code>credential_source</code> uses the <strong>AWS</strong> metadata layout (<code>environment_id</code> starting with <code>aws</code>), URLs must match the expected IMDS patterns (metadata host or <code>169.254.169.254</code>, etc.).</li>
  2111. <li>If the JSON sets <code>credential_source.file</code> to the operator pod’s automounted path (<code>/var/run/secrets/kubernetes.io/serviceaccount/token</code>), that source is <strong>ignored</strong> so the ESO controller does not accidentally use its own service account token; use <strong><code>serviceAccountRef</code></strong> instead to select which Kubernetes identity supplies the subject token.</li>
  2112. </ul>
  2113. <h4 id="aws-subject-token-awssecuritycredentials">AWS subject token (<code>awsSecurityCredentials</code>)</h4>
  2114. <p>For an <strong>AWS</strong> workload identity provider, a <code>credConfig</code> file produced by <a href="https://cloud.google.com/iam/docs/workload-identity-federation-with-other-clouds#create-cred-config"><code>gcloud iam workload-identity-pools create-cred-config</code></a> typically reads credentials from the EC2 instance metadata service (IMDS). Pods usually <strong>cannot</strong> reach <code>169.254.169.254</code> from the container network, so that approach often fails with <code>connection refused</code> inside the ESO pod even when the node can reach IMDS. In that situation use <strong><code>awsSecurityCredentials</code></strong>: put <strong><code>aws_access_key_id</code></strong>, <strong><code>aws_secret_access_key</code></strong>, and optionally <strong><code>aws_session_token</code></strong> in a Kubernetes <code>Secret</code>, set <strong><code>region</code></strong>, and reference that secret from <code>awsSecurityCredentials.awsCredentialsSecretRef</code> (namespace may be set on <code>ClusterSecretStore</code>). On <strong>Amazon EKS</strong>, Google recommends <a href="https://cloud.google.com/iam/docs/workload-identity-federation-with-kubernetes">federation with Kubernetes</a> and <code>serviceAccountRef</code> when your cluster exposes an OIDC issuer.</p>
  2115. <p>Grant Secret Manager access to the <strong>AWS principal</strong> in the pool using a <code>principalSet</code> on the mapped account attribute, for example:</p>
  2116. <div class="highlight"><pre><span></span><code>gcloud<span class="w"> </span>secrets<span class="w"> </span>add-iam-policy-binding<span class="w"> </span><span class="s2">&quot;</span><span class="si">${</span><span class="nv">SECRET_NAME</span><span class="si">}</span><span class="s2">&quot;</span><span class="w"> </span><span class="se">\</span>
  2117. <span class="w"> </span>--project<span class="o">=</span><span class="s2">&quot;</span><span class="si">${</span><span class="nv">PROJECT_ID</span><span class="si">}</span><span class="s2">&quot;</span><span class="w"> </span><span class="se">\</span>
  2118. <span class="w"> </span>--role<span class="o">=</span><span class="s2">&quot;roles/secretmanager.secretAccessor&quot;</span><span class="w"> </span><span class="se">\</span>
  2119. <span class="w"> </span>--member<span class="o">=</span><span class="s2">&quot;principalSet://iam.googleapis.com/projects/</span><span class="si">${</span><span class="nv">PROJECT_NUMBER</span><span class="si">}</span><span class="s2">/locations/global/workloadIdentityPools/</span><span class="si">${</span><span class="nv">WIF_POOL_NAME</span><span class="si">}</span><span class="s2">/attribute.account/</span><span class="si">${</span><span class="nv">AWS_ACCOUNT_ID</span><span class="si">}</span><span class="s2">&quot;</span>
  2120. </code></pre></div>
  2121. <p>See <a href="https://cloud.google.com/iam/docs/manage-workload-identity-pools-providers">Manage workload identity pools and providers</a> for creating an AWS provider and attribute mapping, and <a href="https://cloud.google.com/iam/docs/workload-identity-federation-with-other-clouds">Configure Workload Identity Federation with AWS or Azure VMs</a> for the full AWS setup guide.</p>
  2122. <h4 id="other-api-surfaces">Other API surfaces</h4>
  2123. <p>The same <code>workloadIdentityFederation</code> block (including <code>serviceAccountRef</code>, <code>credConfig</code>, <code>awsSecurityCredentials</code>, <code>audience</code>, and <code>gcpServiceAccountEmail</code>) is available on <strong><code>GCRAccessToken</code></strong> and <strong><code>ClusterGenerator</code></strong> resources that talk to Google APIs; see the <a href="https://external-secrets.io/latest/api/spec/#external-secrets.io/v1.GCPWorkloadIdentityFederation">API spec</a>.</p>
  2124. <h4 id="references">References</h4>
  2125. <ul>
  2126. <li><a href="https://cloud.google.com/iam/docs/workload-identity-federation">Workload Identity Federation overview</a></li>
  2127. <li><a href="https://cloud.google.com/iam/docs/workload-identity-federation-with-kubernetes">Federation with Kubernetes</a></li>
  2128. <li><a href="https://cloud.google.com/iam/docs/workload-identity-federation-with-other-clouds">Federation with AWS or Azure VMs</a></li>
  2129. <li><a href="https://cloud.google.com/iam/docs/manage-workload-identity-pools-providers">Manage workload identity pools and providers</a></li>
  2130. <li><a href="https://cloud.google.com/iam/docs/workload-identity-federation-with-other-clouds#create-cred-config">Create credential configuration files</a></li>
  2131. <li><a href="https://cloud.google.com/iam/docs/using-workload-identity-federation">Use Workload Identity Federation (including impersonation)</a></li>
  2132. <li><a href="https://cloud.google.com/docs/authentication/client-libraries#external-identities">External credentials for client libraries</a></li>
  2133. <li><a href="https://cloud.google.com/secret-manager/docs/access-control">Secret Manager access control</a></li>
  2134. </ul>
  2135. <h3 id="authenticating-with-a-gcp-service-account-static-key">Authenticating with a GCP service account (static key)</h3>
  2136. <p>The <code>SecretStore</code> (or <code>ClusterSecretStore</code>) uses a long-lived, static <a href="https://cloud.google.com/iam/docs/service-account-creds#key-types">GCP service account key</a> to authenticate with GCP.
  2137. This approach can be used on any Kubernetes cluster.</p>
  2138. <p>To demonstrate this approach, we'll create a <code>SecretStore</code> in the <code>demo</code> namespace.</p>
  2139. <p>First, create a GCP service account and grant it the <code>secretmanager.secretAccessor</code> role on the Secret Manager secret(s) you want to access.</p>
  2140. <p><em>For details and further information on managing service account permissions and Secret Manager roles, refer to:</em></p>
  2141. <ul>
  2142. <li><em><a href="https://cloud.google.com/iam/docs/attach-service-accounts">Attach service accounts to resources</a> in the IAM documentation.</em></li>
  2143. <li><em><a href="https://cloud.google.com/secret-manager/docs/access-control">Access control with IAM</a> in the Secret Manager documentation.</em></li>
  2144. </ul>
  2145. <p>Then, create a service account key pair using one of the methods described on the page <a href="https://cloud.google.com/iam/docs/keys-create-delete">Create and delete service account keys</a> in the Google Cloud IAM documentation and store the JSON file with the private key in a Kubernetes <code>Secret</code>:</p>
  2146. <div class="highlight"><pre><span></span><code><span class="nt">apiVersion</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">v1</span>
  2147. <span class="nt">kind</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">Secret</span>
  2148. <span class="nt">metadata</span><span class="p">:</span>
  2149. <span class="w"> </span><span class="nt">name</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">gcp-sa-secret</span>
  2150. <span class="w"> </span><span class="nt">namespace</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">demo</span>
  2151. <span class="nt">type</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">Opaque</span>
  2152. <span class="nt">stringData</span><span class="p">:</span>
  2153. <span class="w"> </span><span class="nt">secret-access-credentials</span><span class="p">:</span><span class="w"> </span><span class="p p-Indicator">|-</span>
  2154. <span class="w"> </span><span class="no">{</span>
  2155. <span class="w"> </span><span class="no">&quot;type&quot;: &quot;service_account&quot;,</span>
  2156. <span class="w"> </span><span class="no">&quot;project_id&quot;: &quot;external-secrets-operator&quot;,</span>
  2157. <span class="w"> </span><span class="no">&quot;private_key_id&quot;: &quot;&quot;,</span>
  2158. <span class="w"> </span><span class="no">&quot;private_key&quot;: &quot;-----BEGIN PRIVATE KEY-----\nA key\n-----END PRIVATE KEY-----\n&quot;,</span>
  2159. <span class="w"> </span><span class="no">&quot;client_email&quot;: &quot;test-service-account@external-secrets-operator.iam.gserviceaccount.com&quot;,</span>
  2160. <span class="w"> </span><span class="no">&quot;client_id&quot;: &quot;client ID&quot;,</span>
  2161. <span class="w"> </span><span class="no">&quot;auth_uri&quot;: &quot;https://accounts.google.com/o/oauth2/auth&quot;,</span>
  2162. <span class="w"> </span><span class="no">&quot;token_uri&quot;: &quot;https://oauth2.googleapis.com/token&quot;,</span>
  2163. <span class="w"> </span><span class="no">&quot;auth_provider_x509_cert_url&quot;: &quot;https://www.googleapis.com/oauth2/v1/certs&quot;,</span>
  2164. <span class="w"> </span><span class="no">&quot;client_x509_cert_url&quot;: &quot;https://www.googleapis.com/robot/v1/metadata/x509/test-service-account%40external-secrets-operator.iam.gserviceaccount.com&quot;</span>
  2165. <span class="w"> </span><span class="no">}</span>
  2166. </code></pre></div>
  2167. <p>Finally, reference this secret in the <code>SecretStore</code> manifest:</p>
  2168. <div class="highlight"><pre><span></span><code><span class="nt">apiVersion</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">external-secrets.io/v1</span>
  2169. <span class="nt">kind</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">SecretStore</span>
  2170. <span class="nt">metadata</span><span class="p">:</span>
  2171. <span class="w"> </span><span class="nt">name</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">demo-store</span>
  2172. <span class="w"> </span><span class="nt">namespace</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">demo</span>
  2173. <span class="nt">spec</span><span class="p">:</span>
  2174. <span class="w"> </span><span class="nt">provider</span><span class="p">:</span>
  2175. <span class="w"> </span><span class="nt">gcpsm</span><span class="p">:</span>
  2176. <span class="w"> </span><span class="nt">auth</span><span class="p">:</span>
  2177. <span class="w"> </span><span class="nt">secretRef</span><span class="p">:</span>
  2178. <span class="w"> </span><span class="nt">secretAccessKeySecretRef</span><span class="p">:</span>
  2179. <span class="w"> </span><span class="nt">name</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">gcp-sa-secret</span>
  2180. <span class="w"> </span><span class="nt">key</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">secret-access-credentials</span>
  2181. <span class="w"> </span><span class="nt">projectID</span><span class="p">:</span><span class="w"> </span><span class="p p-Indicator">[</span><span class="nv">PROJECT_ID</span><span class="p p-Indicator">]</span>
  2182. </code></pre></div>
  2183. <p>In the case of a <code>ClusterSecretStore</code>, you additionally have to specify the service account's <code>namespace</code> under <code>auth.secretRef.secretAccessKeySecretRef</code>.</p>
  2184. <h2 id="using-pushsecret-with-an-existing-google-secret-manager-secret">Using PushSecret with an existing Google Secret Manager secret</h2>
  2185. <p>There are some use cases where you want to use PushSecret for an existing Google Secret Manager Secret that already has labels defined. For example when the creation of the secret is managed by another controller like Kubernetes Config Connector (KCC) and the updating of the secret is managed by ESO.</p>
  2186. <p>To allow ESO to take ownership of the existing Google Secret Manager Secret, you need to add the label <code>"managed-by": "external-secrets"</code>.</p>
  2187. <p>By default, the PushSecret spec will replace any existing labels on the existing GCP Secret Manager Secret. To prevent this, a new field was added to the <code>spec.data.metadata</code> object called <code>mergePolicy</code> which defaults to <code>Replace</code> to ensure that there are no breaking changes and is backward compatible. The other option for this field is <code>Merge</code> which will merge the existing labels on the Google Secret Manager Secret with the labels defined in the PushSecret spec. This ensures that the existing labels defined on the Google Secret Manager Secret are retained.</p>
  2188. <p>Example of using the <code>mergePolicy</code> field:</p>
  2189. <div class="highlight"><pre><span></span><code><span class="nt">apiVersion</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">external-secrets.io/v1alpha1</span>
  2190. <span class="nt">kind</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">PushSecret</span>
  2191. <span class="nt">metadata</span><span class="p">:</span>
  2192. <span class="w"> </span><span class="nt">name</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">pushsecret-example</span>
  2193. <span class="w"> </span><span class="nt">namespace</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">default</span>
  2194. <span class="nt">spec</span><span class="p">:</span>
  2195. <span class="w"> </span><span class="nt">updatePolicy</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">Replace</span>
  2196. <span class="w"> </span><span class="nt">deletionPolicy</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">None</span>
  2197. <span class="w"> </span><span class="nt">refreshInterval</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">1h0m0s</span>
  2198. <span class="w"> </span><span class="nt">secretStoreRefs</span><span class="p">:</span>
  2199. <span class="w"> </span><span class="p p-Indicator">-</span><span class="w"> </span><span class="nt">name</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">gcp-secretstore</span>
  2200. <span class="w"> </span><span class="nt">kind</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">SecretStore</span>
  2201. <span class="w"> </span><span class="nt">selector</span><span class="p">:</span>
  2202. <span class="w"> </span><span class="nt">secret</span><span class="p">:</span>
  2203. <span class="w"> </span><span class="nt">name</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">bestpokemon</span>
  2204. <span class="w"> </span><span class="nt">template</span><span class="p">:</span>
  2205. <span class="w"> </span><span class="nt">data</span><span class="p">:</span>
  2206. <span class="w"> </span><span class="nt">bestpokemon</span><span class="p">:</span><span class="w"> </span><span class="s">&quot;{{</span><span class="nv"> </span><span class="s">.bestpokemon</span><span class="nv"> </span><span class="s">}}&quot;</span>
  2207. <span class="w"> </span><span class="nt">data</span><span class="p">:</span>
  2208. <span class="w"> </span><span class="p p-Indicator">-</span><span class="w"> </span><span class="nt">conversionStrategy</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">None</span>
  2209. <span class="w"> </span><span class="nt">metadata</span><span class="p">:</span>
  2210. <span class="w"> </span><span class="nt">apiVersion</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">kubernetes.external-secrets.io/v1alpha1</span>
  2211. <span class="w"> </span><span class="nt">kind</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">PushSecretMetadata</span>
  2212. <span class="w"> </span><span class="nt">spec</span><span class="p">:</span>
  2213. <span class="w"> </span><span class="nt">mergePolicy</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">Merge</span>
  2214. <span class="w"> </span><span class="nt">labels</span><span class="p">:</span>
  2215. <span class="w"> </span><span class="nt">anotherLabel</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">anotherValue</span>
  2216. <span class="w"> </span><span class="nt">match</span><span class="p">:</span>
  2217. <span class="w"> </span><span class="nt">secretKey</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">bestpokemon</span>
  2218. <span class="w"> </span><span class="nt">remoteRef</span><span class="p">:</span>
  2219. <span class="w"> </span><span class="nt">remoteKey</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">best-pokemon</span>
  2220. </code></pre></div>
  2221. <h2 id="secret-replication-and-encryption-configuration">Secret Replication and Encryption Configuration</h2>
  2222. <h3 id="location-and-replication">Location and Replication</h3>
  2223. <p>By default, secrets are automatically replicated across multiple regions. You can specify one or more replication locations for your secrets by setting the <code>replicationLocations</code> field:</p>
  2224. <div class="highlight"><pre><span></span><code><span class="nt">apiVersion</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">external-secrets.io/v1alpha1</span>
  2225. <span class="nt">kind</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">PushSecret</span>
  2226. <span class="nt">metadata</span><span class="p">:</span>
  2227. <span class="w"> </span><span class="nt">name</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">pushsecret-example</span>
  2228. <span class="nt">spec</span><span class="p">:</span>
  2229. <span class="w"> </span><span class="c1"># ... other fields ...</span>
  2230. <span class="w"> </span><span class="nt">data</span><span class="p">:</span>
  2231. <span class="w"> </span><span class="p p-Indicator">-</span><span class="w"> </span><span class="nt">match</span><span class="p">:</span>
  2232. <span class="w"> </span><span class="nt">secretKey</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">mykey</span>
  2233. <span class="w"> </span><span class="nt">remoteRef</span><span class="p">:</span>
  2234. <span class="w"> </span><span class="nt">remoteKey</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">my-secret</span>
  2235. <span class="w"> </span><span class="nt">metadata</span><span class="p">:</span>
  2236. <span class="w"> </span><span class="nt">apiVersion</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">kubernetes.external-secrets.io/v1alpha1</span>
  2237. <span class="w"> </span><span class="nt">kind</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">PushSecretMetadata</span>
  2238. <span class="w"> </span><span class="nt">spec</span><span class="p">:</span>
  2239. <span class="w"> </span><span class="nt">replicationLocations</span><span class="p">:</span>
  2240. <span class="w"> </span><span class="p p-Indicator">-</span><span class="w"> </span><span class="s">&quot;us-east1&quot;</span>
  2241. </code></pre></div>
  2242. <h3 id="customer-managed-encryption-keys-cmek">Customer-Managed Encryption Keys (CMEK)</h3>
  2243. <p>You can use your own encryption keys to encrypt secrets at rest. To use Customer-Managed Encryption Keys (CMEK), you need to:</p>
  2244. <ol>
  2245. <li>Create a Cloud KMS key</li>
  2246. <li>Grant the service account the <code>roles/cloudkms.cryptoKeyEncrypterDecrypter</code> role on the key</li>
  2247. <li>Specify the key in the PushSecret metadata</li>
  2248. </ol>
  2249. <div class="highlight"><pre><span></span><code><span class="nt">apiVersion</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">external-secrets.io/v1alpha1</span>
  2250. <span class="nt">kind</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">PushSecret</span>
  2251. <span class="nt">metadata</span><span class="p">:</span>
  2252. <span class="w"> </span><span class="nt">name</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">pushsecret-example</span>
  2253. <span class="nt">spec</span><span class="p">:</span>
  2254. <span class="w"> </span><span class="c1"># ... other fields ...</span>
  2255. <span class="w"> </span><span class="nt">data</span><span class="p">:</span>
  2256. <span class="w"> </span><span class="p p-Indicator">-</span><span class="w"> </span><span class="nt">match</span><span class="p">:</span>
  2257. <span class="w"> </span><span class="nt">secretKey</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">mykey</span>
  2258. <span class="w"> </span><span class="nt">remoteRef</span><span class="p">:</span>
  2259. <span class="w"> </span><span class="nt">remoteKey</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">my-secret</span>
  2260. <span class="w"> </span><span class="nt">metadata</span><span class="p">:</span>
  2261. <span class="w"> </span><span class="nt">apiVersion</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">kubernetes.external-secrets.io/v1alpha1</span>
  2262. <span class="w"> </span><span class="nt">kind</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">PushSecretMetadata</span>
  2263. <span class="w"> </span><span class="nt">spec</span><span class="p">:</span>
  2264. <span class="w"> </span><span class="nt">cmekKeyName</span><span class="p">:</span><span class="w"> </span><span class="s">&quot;projects/my-project/locations/us-east1/keyRings/my-keyring/cryptoKeys/my-key&quot;</span>
  2265. </code></pre></div>
  2266. <p>Note: When using CMEK, you must specify a location in the SecretStore as customer-managed encryption keys are region-specific.</p>
  2267. <div class="highlight"><pre><span></span><code><span class="nt">apiVersion</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">external-secrets.io/v1</span>
  2268. <span class="nt">kind</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">SecretStore</span>
  2269. <span class="nt">metadata</span><span class="p">:</span>
  2270. <span class="w"> </span><span class="nt">name</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">gcp-secret-store</span>
  2271. <span class="nt">spec</span><span class="p">:</span>
  2272. <span class="w"> </span><span class="nt">provider</span><span class="p">:</span>
  2273. <span class="w"> </span><span class="nt">gcpsm</span><span class="p">:</span>
  2274. <span class="w"> </span><span class="nt">projectID</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">my-project</span>
  2275. <span class="w"> </span><span class="nt">location</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">us-east1</span><span class="w"> </span><span class="c1"># Required when using CMEK</span>
  2276. </code></pre></div>
  2277. <h2 id="regional-secrets">Regional Secrets</h2>
  2278. <p>GCP Secret Manager Regional Secrets are available to be used with both ExternalSecrets and PushSecrets.</p>
  2279. <p>In order to achieve so, add a <code>location</code> to your SecretStore definition:</p>
  2280. <div class="highlight"><pre><span></span><code><span class="nt">apiVersion</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">external-secrets.io/v1</span>
  2281. <span class="nt">kind</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">SecretStore</span>
  2282. <span class="nt">metadata</span><span class="p">:</span>
  2283. <span class="w"> </span><span class="nt">name</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">gcp-secret-store</span>
  2284. <span class="nt">spec</span><span class="p">:</span>
  2285. <span class="w"> </span><span class="nt">provider</span><span class="p">:</span>
  2286. <span class="w"> </span><span class="nt">gcpsm</span><span class="p">:</span>
  2287. <span class="w"> </span><span class="nt">projectID</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">my-project</span>
  2288. <span class="w"> </span><span class="nt">location</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">us-east1</span><span class="w"> </span><span class="c1"># uses regional secrets on us-east1</span>
  2289. </code></pre></div>
  2290. <h2 id="secret-version-management">Secret Version Management</h2>
  2291. <h3 id="secret-version-selection-policy">Secret Version Selection Policy</h3>
  2292. <p>The Google Secret Manager provider includes a <code>secretVersionSelectionPolicy</code> field that controls how the provider handles secret version selection when the default "latest" version is unavailable.</p>
  2293. <p>By default, when you request a secret without specifying a version, the provider attempts to fetch the "latest" version. The <code>secretVersionSelectionPolicy</code> determines what happens if that version is in a DESTROYED or DISABLED state.</p>
  2294. <h4 id="available-policies">Available Policies</h4>
  2295. <ul>
  2296. <li><strong><code>LatestOrFail</code></strong> (default): The provider always uses "latest", or fails if that version is disabled/destroyed.</li>
  2297. <li><strong><code>LatestOrFetch</code></strong>: The provider falls back to fetching the latest enabled version if the "latest" version is DESTROYED or DISABLED.</li>
  2298. </ul>
  2299. <h4 id="configuration-example">Configuration Example</h4>
  2300. <div class="highlight"><pre><span></span><code><span class="nt">apiVersion</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">external-secrets.io/v1</span>
  2301. <span class="nt">kind</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">SecretStore</span>
  2302. <span class="nt">metadata</span><span class="p">:</span>
  2303. <span class="w"> </span><span class="nt">name</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">gcp-secret-store</span>
  2304. <span class="nt">spec</span><span class="p">:</span>
  2305. <span class="w"> </span><span class="nt">provider</span><span class="p">:</span>
  2306. <span class="w"> </span><span class="nt">gcpsm</span><span class="p">:</span>
  2307. <span class="w"> </span><span class="nt">projectID</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">my-project</span>
  2308. <span class="w"> </span><span class="nt">location</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">us-east1</span>
  2309. <span class="w"> </span><span class="nt">secretVersionSelectionPolicy</span><span class="p">:</span><span class="w"> </span><span class="l l-Scalar l-Scalar-Plain">LatestOrFetch</span><span class="w"> </span><span class="c1"># or LatestOrFail (default)</span>
  2310. </code></pre></div>
  2311. <p><strong>Note</strong>: When using <code>secretVersionSelectionPolicy: LatestOrFetch</code>, the service account requires additional permissions to list secret versions. You'll need to grant the <code>roles/secretmanager.viewer</code> role (which includes <code>secretmanager.versions.list</code>) or the specific <code>secretmanager.versions.list</code> permission in addition to the standard <code>secretmanager.secretAccessor</code> role.</p>
  2312. </article>
  2313. </div>
  2314. <script>var target=document.getElementById(location.hash.slice(1));target&&target.name&&(target.checked=target.name.startsWith("__tabbed_"))</script>
  2315. </div>
  2316. </main>
  2317. <img referrerpolicy="no-referrer-when-downgrade"
  2318. src="https://static.scarf.sh/a.png?x-pxid=6658a9eb-067d-49f1-94f2-b8b00f21451e" alt=""
  2319. hidden />
  2320. <footer class="md-footer">
  2321. <div class="md-footer-meta md-typeset">
  2322. <div class="md-footer-meta__inner md-grid">
  2323. <div class="md-copyright">
  2324. <div class="md-copyright__highlight">
  2325. &copy; 2025 The external-secrets Authors.<br/>
  2326. &copy; 2025 The Linux Foundation. All rights reserved.<br/><br/>
  2327. The Linux Foundation has registered trademarks and uses trademarks.<br/>
  2328. For a list of trademarks of The Linux Foundation, please see our <a href="https://www.linuxfoundation.org/trademark-usage/">Trademark Usage page</a>.
  2329. </div>
  2330. Made with
  2331. <a href="https://squidfunk.github.io/mkdocs-material/" target="_blank" rel="noopener">
  2332. Material for MkDocs
  2333. </a>
  2334. </div>
  2335. </div>
  2336. </div>
  2337. </footer>
  2338. </div>
  2339. <div class="md-dialog" data-md-component="dialog">
  2340. <div class="md-dialog__inner md-typeset"></div>
  2341. </div>
  2342. <script id="__config" type="application/json">{"annotate": null, "base": "../..", "features": ["navigation.tabs", "navigation.indexes", "navigation.expand"], "search": "../../assets/javascripts/workers/search.2c215733.min.js", "tags": null, "translations": {"clipboard.copied": "Copied to clipboard", "clipboard.copy": "Copy to clipboard", "search.result.more.one": "1 more on this page", "search.result.more.other": "# more on this page", "search.result.none": "No matching documents", "search.result.one": "1 matching document", "search.result.other": "# matching documents", "search.result.placeholder": "Type to start searching", "search.result.term.missing": "Missing", "select.version": "Select version"}, "version": {"provider": "mike"}}</script>
  2343. <script src="../../assets/javascripts/bundle.79ae519e.min.js"></script>
  2344. </body>
  2345. </html>