index.html 38 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354
  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="icon" href="../assets/images/favicon.png">
  7. <meta name="generator" content="mkdocs-1.2.3, mkdocs-material-8.1.9">
  8. <title>SecretStore - External Secrets Operator</title>
  9. <link rel="stylesheet" href="../assets/stylesheets/main.2b4465f4.min.css">
  10. <link rel="stylesheet" href="../assets/stylesheets/palette.e6a45f82.min.css">
  11. <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
  12. <link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Roboto:300,400,400i,700%7CRoboto+Mono&display=fallback">
  13. <style>:root{--md-text-font:"Roboto";--md-code-font:"Roboto Mono"}</style>
  14. <script>__md_scope=new URL("..",location),__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>
  15. <script>function gtag(){dataLayer.push(arguments)}window.dataLayer=window.dataLayer||[],gtag("js",new Date),gtag("config","G-QP38TD8K7V"),document.addEventListener("DOMContentLoaded",function(){document.forms.search&&document.forms.search.query.addEventListener("blur",function(){this.value&&gtag("event","search",{search_term:this.value})}),"undefined"!=typeof location$&&location$.subscribe(function(e){gtag("config","G-QP38TD8K7V",{page_path:e.pathname})})})</script>
  16. <script async src="https://www.googletagmanager.com/gtag/js?id=G-QP38TD8K7V"></script>
  17. </head>
  18. <body dir="ltr" data-md-color-scheme="" data-md-color-primary="none" data-md-color-accent="none">
  19. <input class="md-toggle" data-md-toggle="drawer" type="checkbox" id="__drawer" autocomplete="off">
  20. <input class="md-toggle" data-md-toggle="search" type="checkbox" id="__search" autocomplete="off">
  21. <label class="md-overlay" for="__drawer"></label>
  22. <div data-md-component="skip">
  23. </div>
  24. <div data-md-component="announce">
  25. </div>
  26. <div data-md-component="outdated" hidden>
  27. <aside class="md-banner md-banner--warning">
  28. <div class="md-banner__inner md-grid md-typeset">
  29. You're not viewing the latest version.
  30. <a href="../..">
  31. <strong>Click here to go to latest.</strong>
  32. </a>
  33. </div>
  34. <script>var el=document.querySelector("[data-md-component=outdated]"),outdated=__md_get("__outdated",sessionStorage);!0===outdated&&el&&(el.hidden=!1)</script>
  35. </aside>
  36. </div>
  37. <header class="md-header" data-md-component="header">
  38. <nav class="md-header__inner md-grid" aria-label="Header">
  39. <a href=".." title="External Secrets Operator" class="md-header__button md-logo" aria-label="External Secrets Operator" data-md-component="logo">
  40. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M12 8a3 3 0 0 0 3-3 3 3 0 0 0-3-3 3 3 0 0 0-3 3 3 3 0 0 0 3 3m0 3.54C9.64 9.35 6.5 8 3 8v11c3.5 0 6.64 1.35 9 3.54 2.36-2.19 5.5-3.54 9-3.54V8c-3.5 0-6.64 1.35-9 3.54z"/></svg>
  41. </a>
  42. <label class="md-header__button md-icon" for="__drawer">
  43. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M3 6h18v2H3V6m0 5h18v2H3v-2m0 5h18v2H3v-2z"/></svg>
  44. </label>
  45. <div class="md-header__title" data-md-component="header-title">
  46. <div class="md-header__ellipsis">
  47. <div class="md-header__topic">
  48. <span class="md-ellipsis">
  49. External Secrets Operator
  50. </span>
  51. </div>
  52. <div class="md-header__topic" data-md-component="header-topic">
  53. <span class="md-ellipsis">
  54. SecretStore
  55. </span>
  56. </div>
  57. </div>
  58. </div>
  59. <label class="md-header__button md-icon" for="__search">
  60. <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.516 6.516 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 5z"/></svg>
  61. </label>
  62. <div class="md-search" data-md-component="search" role="dialog">
  63. <label class="md-search__overlay" for="__search"></label>
  64. <div class="md-search__inner" role="search">
  65. <form class="md-search__form" name="search">
  66. <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>
  67. <label class="md-search__icon md-icon" for="__search">
  68. <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.516 6.516 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 5z"/></svg>
  69. <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 11h12z"/></svg>
  70. </label>
  71. <nav class="md-search__options" aria-label="Search">
  72. <button type="reset" class="md-search__icon md-icon" aria-label="Clear" tabindex="-1">
  73. <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 12 19 6.41z"/></svg>
  74. </button>
  75. </nav>
  76. </form>
  77. <div class="md-search__output">
  78. <div class="md-search__scrollwrap" data-md-scrollfix>
  79. <div class="md-search-result" data-md-component="search-result">
  80. <div class="md-search-result__meta">
  81. Initializing search
  82. </div>
  83. <ol class="md-search-result__list"></ol>
  84. </div>
  85. </div>
  86. </div>
  87. </div>
  88. </div>
  89. <div class="md-header__source">
  90. <a href="https://github.com/external-secrets/external-secrets/" title="Go to repository" class="md-source" data-md-component="source">
  91. <div class="md-source__icon md-icon">
  92. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"><path d="M439.55 236.05 244 40.45a28.87 28.87 0 0 0-40.81 0l-40.66 40.63 51.52 51.52c27.06-9.14 52.68 16.77 43.39 43.68l49.66 49.66c34.23-11.8 61.18 31 35.47 56.69-26.49 26.49-70.21-2.87-56-37.34L240.22 199v121.85c25.3 12.54 22.26 41.85 9.08 55a34.34 34.34 0 0 1-48.55 0c-17.57-17.6-11.07-46.91 11.25-56v-123c-20.8-8.51-24.6-30.74-18.64-45L142.57 101 8.45 235.14a28.86 28.86 0 0 0 0 40.81l195.61 195.6a28.86 28.86 0 0 0 40.8 0l194.69-194.69a28.86 28.86 0 0 0 0-40.81z"/></svg>
  93. </div>
  94. <div class="md-source__repository">
  95. External Secrets Operator
  96. </div>
  97. </a>
  98. </div>
  99. </nav>
  100. </header>
  101. <div class="md-container" data-md-component="container">
  102. <main class="md-main" data-md-component="main">
  103. <div class="md-main__inner md-grid">
  104. <div class="md-sidebar md-sidebar--primary" data-md-component="sidebar" data-md-type="navigation" >
  105. <div class="md-sidebar__scrollwrap">
  106. <div class="md-sidebar__inner">
  107. <nav class="md-nav md-nav--primary" aria-label="Navigation" data-md-level="0">
  108. <label class="md-nav__title" for="__drawer">
  109. <a href=".." title="External Secrets Operator" class="md-nav__button md-logo" aria-label="External Secrets Operator" data-md-component="logo">
  110. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M12 8a3 3 0 0 0 3-3 3 3 0 0 0-3-3 3 3 0 0 0-3 3 3 3 0 0 0 3 3m0 3.54C9.64 9.35 6.5 8 3 8v11c3.5 0 6.64 1.35 9 3.54 2.36-2.19 5.5-3.54 9-3.54V8c-3.5 0-6.64 1.35-9 3.54z"/></svg>
  111. </a>
  112. External Secrets Operator
  113. </label>
  114. <div class="md-nav__source">
  115. <a href="https://github.com/external-secrets/external-secrets/" title="Go to repository" class="md-source" data-md-component="source">
  116. <div class="md-source__icon md-icon">
  117. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"><path d="M439.55 236.05 244 40.45a28.87 28.87 0 0 0-40.81 0l-40.66 40.63 51.52 51.52c27.06-9.14 52.68 16.77 43.39 43.68l49.66 49.66c34.23-11.8 61.18 31 35.47 56.69-26.49 26.49-70.21-2.87-56-37.34L240.22 199v121.85c25.3 12.54 22.26 41.85 9.08 55a34.34 34.34 0 0 1-48.55 0c-17.57-17.6-11.07-46.91 11.25-56v-123c-20.8-8.51-24.6-30.74-18.64-45L142.57 101 8.45 235.14a28.86 28.86 0 0 0 0 40.81l195.61 195.6a28.86 28.86 0 0 0 40.8 0l194.69-194.69a28.86 28.86 0 0 0 0-40.81z"/></svg>
  118. </div>
  119. <div class="md-source__repository">
  120. External Secrets Operator
  121. </div>
  122. </a>
  123. </div>
  124. <ul class="md-nav__list" data-md-scrollfix>
  125. <li class="md-nav__item">
  126. <a href=".." class="md-nav__link">
  127. Introduction
  128. </a>
  129. </li>
  130. <li class="md-nav__item">
  131. <a href="../api-overview/" class="md-nav__link">
  132. Overview
  133. </a>
  134. </li>
  135. <li class="md-nav__item md-nav__item--active md-nav__item--nested">
  136. <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_3" type="checkbox" id="__nav_3" checked>
  137. <label class="md-nav__link" for="__nav_3">
  138. API Types
  139. <span class="md-nav__icon md-icon"></span>
  140. </label>
  141. <nav class="md-nav" aria-label="API Types" data-md-level="1">
  142. <label class="md-nav__title" for="__nav_3">
  143. <span class="md-nav__icon md-icon"></span>
  144. API Types
  145. </label>
  146. <ul class="md-nav__list" data-md-scrollfix>
  147. <li class="md-nav__item">
  148. <a href="../api-externalsecret/" class="md-nav__link">
  149. ExternalSecret
  150. </a>
  151. </li>
  152. <li class="md-nav__item md-nav__item--active">
  153. <input class="md-nav__toggle md-toggle" data-md-toggle="toc" type="checkbox" id="__toc">
  154. <a href="./" class="md-nav__link md-nav__link--active">
  155. SecretStore
  156. </a>
  157. </li>
  158. <li class="md-nav__item">
  159. <a href="../api-clustersecretstore/" class="md-nav__link">
  160. ClusterSecretStore
  161. </a>
  162. </li>
  163. </ul>
  164. </nav>
  165. </li>
  166. <li class="md-nav__item md-nav__item--nested">
  167. <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_4" type="checkbox" id="__nav_4" >
  168. <label class="md-nav__link" for="__nav_4">
  169. Guides
  170. <span class="md-nav__icon md-icon"></span>
  171. </label>
  172. <nav class="md-nav" aria-label="Guides" data-md-level="1">
  173. <label class="md-nav__title" for="__nav_4">
  174. <span class="md-nav__icon md-icon"></span>
  175. Guides
  176. </label>
  177. <ul class="md-nav__list" data-md-scrollfix>
  178. <li class="md-nav__item">
  179. <a href="../guides-introduction/" class="md-nav__link">
  180. Introduction
  181. </a>
  182. </li>
  183. <li class="md-nav__item">
  184. <a href="../guides-getting-started/" class="md-nav__link">
  185. Getting started
  186. </a>
  187. </li>
  188. <li class="md-nav__item">
  189. <a href="../guides-templating/" class="md-nav__link">
  190. Advanced Templating
  191. </a>
  192. </li>
  193. <li class="md-nav__item">
  194. <a href="../guides-controller-class/" class="md-nav__link">
  195. Controller Classes
  196. </a>
  197. </li>
  198. <li class="md-nav__item">
  199. <a href="../guides-all-keys-one-secret/" class="md-nav__link">
  200. All keys, One secret
  201. </a>
  202. </li>
  203. <li class="md-nav__item">
  204. <a href="../guides-common-k8s-secret-types/" class="md-nav__link">
  205. Common K8S Secret Types
  206. </a>
  207. </li>
  208. <li class="md-nav__item">
  209. <a href="../guides-multi-tenancy/" class="md-nav__link">
  210. Multi Tenancy
  211. </a>
  212. </li>
  213. <li class="md-nav__item">
  214. <a href="../guides-metrics/" class="md-nav__link">
  215. Metrics
  216. </a>
  217. </li>
  218. <li class="md-nav__item">
  219. <a href="../guides-using-latest-image/" class="md-nav__link">
  220. Using Latest Image
  221. </a>
  222. </li>
  223. </ul>
  224. </nav>
  225. </li>
  226. <li class="md-nav__item md-nav__item--nested">
  227. <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_5" type="checkbox" id="__nav_5" >
  228. <label class="md-nav__link" for="__nav_5">
  229. Provider
  230. <span class="md-nav__icon md-icon"></span>
  231. </label>
  232. <nav class="md-nav" aria-label="Provider" data-md-level="1">
  233. <label class="md-nav__title" for="__nav_5">
  234. <span class="md-nav__icon md-icon"></span>
  235. Provider
  236. </label>
  237. <ul class="md-nav__list" data-md-scrollfix>
  238. <li class="md-nav__item md-nav__item--nested">
  239. <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_5_1" type="checkbox" id="__nav_5_1" >
  240. <label class="md-nav__link" for="__nav_5_1">
  241. AWS
  242. <span class="md-nav__icon md-icon"></span>
  243. </label>
  244. <nav class="md-nav" aria-label="AWS" data-md-level="2">
  245. <label class="md-nav__title" for="__nav_5_1">
  246. <span class="md-nav__icon md-icon"></span>
  247. AWS
  248. </label>
  249. <ul class="md-nav__list" data-md-scrollfix>
  250. <li class="md-nav__item">
  251. <a href="../provider-aws-secrets-manager/" class="md-nav__link">
  252. Secrets Manager
  253. </a>
  254. </li>
  255. <li class="md-nav__item">
  256. <a href="../provider-aws-parameter-store/" class="md-nav__link">
  257. Parameter Store
  258. </a>
  259. </li>
  260. </ul>
  261. </nav>
  262. </li>
  263. <li class="md-nav__item md-nav__item--nested">
  264. <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_5_2" type="checkbox" id="__nav_5_2" >
  265. <label class="md-nav__link" for="__nav_5_2">
  266. Azure
  267. <span class="md-nav__icon md-icon"></span>
  268. </label>
  269. <nav class="md-nav" aria-label="Azure" data-md-level="2">
  270. <label class="md-nav__title" for="__nav_5_2">
  271. <span class="md-nav__icon md-icon"></span>
  272. Azure
  273. </label>
  274. <ul class="md-nav__list" data-md-scrollfix>
  275. <li class="md-nav__item">
  276. <a href="../provider-azure-key-vault/" class="md-nav__link">
  277. Key Vault
  278. </a>
  279. </li>
  280. </ul>
  281. </nav>
  282. </li>
  283. <li class="md-nav__item md-nav__item--nested">
  284. <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_5_3" type="checkbox" id="__nav_5_3" >
  285. <label class="md-nav__link" for="__nav_5_3">
  286. Google
  287. <span class="md-nav__icon md-icon"></span>
  288. </label>
  289. <nav class="md-nav" aria-label="Google" data-md-level="2">
  290. <label class="md-nav__title" for="__nav_5_3">
  291. <span class="md-nav__icon md-icon"></span>
  292. Google
  293. </label>
  294. <ul class="md-nav__list" data-md-scrollfix>
  295. <li class="md-nav__item">
  296. <a href="../provider-google-secrets-manager/" class="md-nav__link">
  297. Secret Manager
  298. </a>
  299. </li>
  300. </ul>
  301. </nav>
  302. </li>
  303. <li class="md-nav__item md-nav__item--nested">
  304. <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_5_4" type="checkbox" id="__nav_5_4" >
  305. <label class="md-nav__link" for="__nav_5_4">
  306. IBM
  307. <span class="md-nav__icon md-icon"></span>
  308. </label>
  309. <nav class="md-nav" aria-label="IBM" data-md-level="2">
  310. <label class="md-nav__title" for="__nav_5_4">
  311. <span class="md-nav__icon md-icon"></span>
  312. IBM
  313. </label>
  314. <ul class="md-nav__list" data-md-scrollfix>
  315. <li class="md-nav__item">
  316. <a href="../provider-ibm-secrets-manager/" class="md-nav__link">
  317. Secrets Manager
  318. </a>
  319. </li>
  320. </ul>
  321. </nav>
  322. </li>
  323. <li class="md-nav__item">
  324. <a href="../provider-akeyless/" class="md-nav__link">
  325. Akeyless
  326. </a>
  327. </li>
  328. <li class="md-nav__item">
  329. <a href="../provider-hashicorp-vault/" class="md-nav__link">
  330. HashiCorp Vault
  331. </a>
  332. </li>
  333. <li class="md-nav__item md-nav__item--nested">
  334. <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_5_7" type="checkbox" id="__nav_5_7" >
  335. <label class="md-nav__link" for="__nav_5_7">
  336. Yandex
  337. <span class="md-nav__icon md-icon"></span>
  338. </label>
  339. <nav class="md-nav" aria-label="Yandex" data-md-level="2">
  340. <label class="md-nav__title" for="__nav_5_7">
  341. <span class="md-nav__icon md-icon"></span>
  342. Yandex
  343. </label>
  344. <ul class="md-nav__list" data-md-scrollfix>
  345. <li class="md-nav__item">
  346. <a href="../provider-yandex-lockbox/" class="md-nav__link">
  347. Lockbox
  348. </a>
  349. </li>
  350. </ul>
  351. </nav>
  352. </li>
  353. <li class="md-nav__item md-nav__item--nested">
  354. <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_5_8" type="checkbox" id="__nav_5_8" >
  355. <label class="md-nav__link" for="__nav_5_8">
  356. Gitlab
  357. <span class="md-nav__icon md-icon"></span>
  358. </label>
  359. <nav class="md-nav" aria-label="Gitlab" data-md-level="2">
  360. <label class="md-nav__title" for="__nav_5_8">
  361. <span class="md-nav__icon md-icon"></span>
  362. Gitlab
  363. </label>
  364. <ul class="md-nav__list" data-md-scrollfix>
  365. <li class="md-nav__item">
  366. <a href="../provider-gitlab-project-variables/" class="md-nav__link">
  367. Gitlab Project Variables
  368. </a>
  369. </li>
  370. </ul>
  371. </nav>
  372. </li>
  373. <li class="md-nav__item md-nav__item--nested">
  374. <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_5_9" type="checkbox" id="__nav_5_9" >
  375. <label class="md-nav__link" for="__nav_5_9">
  376. Oracle
  377. <span class="md-nav__icon md-icon"></span>
  378. </label>
  379. <nav class="md-nav" aria-label="Oracle" data-md-level="2">
  380. <label class="md-nav__title" for="__nav_5_9">
  381. <span class="md-nav__icon md-icon"></span>
  382. Oracle
  383. </label>
  384. <ul class="md-nav__list" data-md-scrollfix>
  385. <li class="md-nav__item">
  386. <a href="../provider-oracle-vault/" class="md-nav__link">
  387. Oracle Vault
  388. </a>
  389. </li>
  390. </ul>
  391. </nav>
  392. </li>
  393. <li class="md-nav__item">
  394. <a href="../provider-webhook/" class="md-nav__link">
  395. Webhook
  396. </a>
  397. </li>
  398. <li class="md-nav__item">
  399. <a href="../provider-fake/" class="md-nav__link">
  400. Fake
  401. </a>
  402. </li>
  403. </ul>
  404. </nav>
  405. </li>
  406. <li class="md-nav__item md-nav__item--nested">
  407. <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_6" type="checkbox" id="__nav_6" >
  408. <label class="md-nav__link" for="__nav_6">
  409. Examples
  410. <span class="md-nav__icon md-icon"></span>
  411. </label>
  412. <nav class="md-nav" aria-label="Examples" data-md-level="1">
  413. <label class="md-nav__title" for="__nav_6">
  414. <span class="md-nav__icon md-icon"></span>
  415. Examples
  416. </label>
  417. <ul class="md-nav__list" data-md-scrollfix>
  418. <li class="md-nav__item">
  419. <a href="../examples-gitops-using-fluxcd/" class="md-nav__link">
  420. FluxCD
  421. </a>
  422. </li>
  423. <li class="md-nav__item">
  424. <a href="../examples-anchore-engine-credentials/" class="md-nav__link">
  425. Anchore Engine
  426. </a>
  427. </li>
  428. <li class="md-nav__item">
  429. <a href="../examples-jenkins-kubernetes-credentials/" class="md-nav__link">
  430. Jenkins
  431. </a>
  432. </li>
  433. </ul>
  434. </nav>
  435. </li>
  436. <li class="md-nav__item md-nav__item--nested">
  437. <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_7" type="checkbox" id="__nav_7" >
  438. <label class="md-nav__link" for="__nav_7">
  439. References
  440. <span class="md-nav__icon md-icon"></span>
  441. </label>
  442. <nav class="md-nav" aria-label="References" data-md-level="1">
  443. <label class="md-nav__title" for="__nav_7">
  444. <span class="md-nav__icon md-icon"></span>
  445. References
  446. </label>
  447. <ul class="md-nav__list" data-md-scrollfix>
  448. <li class="md-nav__item">
  449. <a href="../spec/" class="md-nav__link">
  450. API specification
  451. </a>
  452. </li>
  453. </ul>
  454. </nav>
  455. </li>
  456. <li class="md-nav__item md-nav__item--nested">
  457. <input class="md-nav__toggle md-toggle" data-md-toggle="__nav_8" type="checkbox" id="__nav_8" >
  458. <label class="md-nav__link" for="__nav_8">
  459. Contributing
  460. <span class="md-nav__icon md-icon"></span>
  461. </label>
  462. <nav class="md-nav" aria-label="Contributing" data-md-level="1">
  463. <label class="md-nav__title" for="__nav_8">
  464. <span class="md-nav__icon md-icon"></span>
  465. Contributing
  466. </label>
  467. <ul class="md-nav__list" data-md-scrollfix>
  468. <li class="md-nav__item">
  469. <a href="../contributing-devguide/" class="md-nav__link">
  470. Developer guide
  471. </a>
  472. </li>
  473. <li class="md-nav__item">
  474. <a href="../contributing-process/" class="md-nav__link">
  475. Contributing Process
  476. </a>
  477. </li>
  478. <li class="md-nav__item">
  479. <a href="../contributing-coc/" class="md-nav__link">
  480. Code of Conduct
  481. </a>
  482. </li>
  483. </ul>
  484. </nav>
  485. </li>
  486. <li class="md-nav__item">
  487. <a href="../deprecation-policy/" class="md-nav__link">
  488. Deprecation Policy
  489. </a>
  490. </li>
  491. </ul>
  492. </nav>
  493. </div>
  494. </div>
  495. </div>
  496. <div class="md-content" data-md-component="content">
  497. <article class="md-content__inner md-typeset">
  498. <a href="https://github.com/external-secrets/external-secrets/edit/master/docs/api-secretstore.md" title="Edit this page" class="md-content__button md-icon">
  499. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M20.71 7.04c.39-.39.39-1.04 0-1.41l-2.34-2.34c-.37-.39-1.02-.39-1.41 0l-1.84 1.83 3.75 3.75M3 17.25V21h3.75L17.81 9.93l-3.75-3.75L3 17.25z"/></svg>
  500. </a>
  501. <h1>SecretStore</h1>
  502. <p><img alt="SecretStore" src="../pictures/diagrams-high-level-ns-detail.png" /></p>
  503. <p>The <code>SecretStore</code> is namespaced and specifies how to access the external API.
  504. The SecretStore maps to exactly one instance of an external API.</p>
  505. <div class="highlight"><pre><span></span><code><span class="nt">apiVersion</span><span class="p">:</span> <span class="l l-Scalar l-Scalar-Plain">external-secrets.io/v1alpha1</span>
  506. <span class="nt">kind</span><span class="p">:</span> <span class="l l-Scalar l-Scalar-Plain">SecretStore</span>
  507. <span class="nt">metadata</span><span class="p">:</span>
  508. <span class="nt">name</span><span class="p">:</span> <span class="l l-Scalar l-Scalar-Plain">example</span>
  509. <span class="nt">namespace</span><span class="p">:</span> <span class="l l-Scalar l-Scalar-Plain">example-ns</span>
  510. <span class="nt">spec</span><span class="p">:</span>
  511. <span class="c1"># Used to select the correct ESO controller (think: ingress.ingressClassName)</span>
  512. <span class="c1"># The ESO controller is instantiated with a specific controller name</span>
  513. <span class="c1"># and filters ES based on this property</span>
  514. <span class="c1"># Optional</span>
  515. <span class="nt">controller</span><span class="p">:</span> <span class="l l-Scalar l-Scalar-Plain">dev</span>
  516. <span class="c1"># You can specify retry settings for the http connection</span>
  517. <span class="c1"># these fields allow you to set a maxRetries before failure, and</span>
  518. <span class="c1"># an interval between the retries.</span>
  519. <span class="c1"># Current supported providers: IBM</span>
  520. <span class="nt">retrySettings</span><span class="p">:</span>
  521. <span class="nt">maxRetries</span><span class="p">:</span> <span class="l l-Scalar l-Scalar-Plain">5</span>
  522. <span class="nt">retryInterval</span><span class="p">:</span> <span class="s">&quot;10s&quot;</span>
  523. <span class="c1"># provider field contains the configuration to access the provider</span>
  524. <span class="c1"># which contains the secret exactly one provider must be configured.</span>
  525. <span class="nt">provider</span><span class="p">:</span>
  526. <span class="c1"># (1): AWS Secrets Manager</span>
  527. <span class="c1"># aws configures this store to sync secrets using AWS Secret Manager provider</span>
  528. <span class="nt">aws</span><span class="p">:</span>
  529. <span class="nt">service</span><span class="p">:</span> <span class="l l-Scalar l-Scalar-Plain">SecretsManager</span>
  530. <span class="c1"># Role is a Role ARN which the SecretManager provider will assume</span>
  531. <span class="nt">role</span><span class="p">:</span> <span class="l l-Scalar l-Scalar-Plain">iam-role</span>
  532. <span class="c1"># AWS Region to be used for the provider</span>
  533. <span class="nt">region</span><span class="p">:</span> <span class="l l-Scalar l-Scalar-Plain">eu-central-1</span>
  534. <span class="c1"># Auth defines the information necessary to authenticate against AWS by</span>
  535. <span class="c1"># getting the accessKeyID and secretAccessKey from an already created Kubernetes Secret</span>
  536. <span class="nt">auth</span><span class="p">:</span>
  537. <span class="nt">secretRef</span><span class="p">:</span>
  538. <span class="nt">accessKeyID</span><span class="p">:</span>
  539. <span class="nt">name</span><span class="p">:</span> <span class="l l-Scalar l-Scalar-Plain">awssm-secret</span>
  540. <span class="nt">key</span><span class="p">:</span> <span class="l l-Scalar l-Scalar-Plain">access-key</span>
  541. <span class="nt">secretAccessKey</span><span class="p">:</span>
  542. <span class="nt">name</span><span class="p">:</span> <span class="l l-Scalar l-Scalar-Plain">awssm-secret</span>
  543. <span class="nt">key</span><span class="p">:</span> <span class="l l-Scalar l-Scalar-Plain">secret-access-key</span>
  544. <span class="nt">vault</span><span class="p">:</span>
  545. <span class="nt">server</span><span class="p">:</span> <span class="s">&quot;https://vault.acme.org&quot;</span>
  546. <span class="c1"># Path is the mount path of the Vault KV backend endpoint</span>
  547. <span class="nt">path</span><span class="p">:</span> <span class="s">&quot;secret&quot;</span>
  548. <span class="c1"># Version is the Vault KV secret engine version.</span>
  549. <span class="c1"># This can be either &quot;v1&quot; or &quot;v2&quot;, defaults to &quot;v2&quot;</span>
  550. <span class="nt">version</span><span class="p">:</span> <span class="s">&quot;v2&quot;</span>
  551. <span class="c1"># vault enterprise namespace: https://www.vaultproject.io/docs/enterprise/namespaces</span>
  552. <span class="nt">namespace</span><span class="p">:</span> <span class="s">&quot;a-team&quot;</span>
  553. <span class="c1"># base64 encoded string of certificate</span>
  554. <span class="nt">caBundle</span><span class="p">:</span> <span class="s">&quot;...&quot;</span>
  555. <span class="c1"># Instead of caBundle you can also specify a caProvider</span>
  556. <span class="c1"># this will retrieve the cert from a Secret or ConfigMap</span>
  557. <span class="nt">caProvider</span><span class="p">:</span>
  558. <span class="c1"># Can be Secret or ConfigMap</span>
  559. <span class="nt">type</span><span class="p">:</span> <span class="s">&quot;Secret&quot;</span>
  560. <span class="nt">name</span><span class="p">:</span> <span class="s">&quot;my-cert-secret&quot;</span>
  561. <span class="nt">key</span><span class="p">:</span> <span class="s">&quot;cert-key&quot;</span>
  562. <span class="nt">auth</span><span class="p">:</span>
  563. <span class="c1"># static token: https://www.vaultproject.io/docs/auth/token</span>
  564. <span class="nt">tokenSecretRef</span><span class="p">:</span>
  565. <span class="nt">name</span><span class="p">:</span> <span class="s">&quot;my-secret&quot;</span>
  566. <span class="nt">namespace</span><span class="p">:</span> <span class="s">&quot;secret-admin&quot;</span>
  567. <span class="nt">key</span><span class="p">:</span> <span class="s">&quot;vault-token&quot;</span>
  568. <span class="c1"># AppRole auth: https://www.vaultproject.io/docs/auth/approle</span>
  569. <span class="nt">appRole</span><span class="p">:</span>
  570. <span class="nt">path</span><span class="p">:</span> <span class="s">&quot;approle&quot;</span>
  571. <span class="nt">roleId</span><span class="p">:</span> <span class="s">&quot;db02de05-fa39-4855-059b-67221c5c2f63&quot;</span>
  572. <span class="nt">secretRef</span><span class="p">:</span>
  573. <span class="nt">name</span><span class="p">:</span> <span class="s">&quot;my-secret&quot;</span>
  574. <span class="nt">namespace</span><span class="p">:</span> <span class="s">&quot;secret-admin&quot;</span>
  575. <span class="nt">key</span><span class="p">:</span> <span class="s">&quot;vault-token&quot;</span>
  576. <span class="c1"># Kubernetes auth: https://www.vaultproject.io/docs/auth/kubernetes</span>
  577. <span class="nt">kubernetes</span><span class="p">:</span>
  578. <span class="nt">mountPath</span><span class="p">:</span> <span class="s">&quot;kubernetes&quot;</span>
  579. <span class="nt">role</span><span class="p">:</span> <span class="s">&quot;demo&quot;</span>
  580. <span class="c1"># Optional service account reference</span>
  581. <span class="nt">serviceAccountRef</span><span class="p">:</span>
  582. <span class="nt">name</span><span class="p">:</span> <span class="s">&quot;my-sa&quot;</span>
  583. <span class="nt">namespace</span><span class="p">:</span> <span class="s">&quot;secret-admin&quot;</span>
  584. <span class="c1"># Optional secret field containing a Kubernetes ServiceAccount JWT</span>
  585. <span class="c1"># used for authenticating with Vault</span>
  586. <span class="nt">secretRef</span><span class="p">:</span>
  587. <span class="nt">name</span><span class="p">:</span> <span class="s">&quot;my-secret&quot;</span>
  588. <span class="nt">namespace</span><span class="p">:</span> <span class="s">&quot;secret-admin&quot;</span>
  589. <span class="nt">key</span><span class="p">:</span> <span class="s">&quot;vault&quot;</span>
  590. <span class="c1"># (2): GCP Secret Manager</span>
  591. <span class="nt">gcpsm</span><span class="p">:</span>
  592. <span class="c1"># Auth defines the information necessary to authenticate against GCP by getting</span>
  593. <span class="c1"># the credentials from an already created Kubernetes Secret.</span>
  594. <span class="nt">auth</span><span class="p">:</span>
  595. <span class="nt">secretRef</span><span class="p">:</span>
  596. <span class="nt">secretAccessKeySecretRef</span><span class="p">:</span>
  597. <span class="nt">name</span><span class="p">:</span> <span class="l l-Scalar l-Scalar-Plain">gcpsm-secret</span>
  598. <span class="nt">key</span><span class="p">:</span> <span class="l l-Scalar l-Scalar-Plain">secret-access-credentials</span>
  599. <span class="nt">projectID</span><span class="p">:</span> <span class="l l-Scalar l-Scalar-Plain">myproject</span>
  600. <span class="c1"># (TODO): add more provider examples here</span>
  601. <span class="nt">status</span><span class="p">:</span>
  602. <span class="c1"># Standard condition schema</span>
  603. <span class="nt">conditions</span><span class="p">:</span>
  604. <span class="c1"># SecretStore ready condition indicates the given store is in ready</span>
  605. <span class="c1"># state and able to referenced by ExternalSecrets</span>
  606. <span class="c1"># If the `status` of this condition is `False`, ExternalSecret controllers</span>
  607. <span class="c1"># should prevent attempts to fetch secrets</span>
  608. <span class="p p-Indicator">-</span> <span class="nt">type</span><span class="p">:</span> <span class="l l-Scalar l-Scalar-Plain">Ready</span>
  609. <span class="nt">status</span><span class="p">:</span> <span class="s">&quot;False&quot;</span>
  610. <span class="nt">reason</span><span class="p">:</span> <span class="s">&quot;ConfigError&quot;</span>
  611. <span class="nt">message</span><span class="p">:</span> <span class="s">&quot;SecretStore</span><span class="nv"> </span><span class="s">validation</span><span class="nv"> </span><span class="s">failed&quot;</span>
  612. <span class="nt">lastTransitionTime</span><span class="p">:</span> <span class="s">&quot;2019-08-12T12:33:02Z&quot;</span>
  613. </code></pre></div>
  614. </article>
  615. </div>
  616. </div>
  617. </main>
  618. <footer class="md-footer">
  619. <nav class="md-footer__inner md-grid" aria-label="Footer">
  620. <a href="../api-externalsecret/" class="md-footer__link md-footer__link--prev" aria-label="Previous: ExternalSecret" rel="prev">
  621. <div class="md-footer__button md-icon">
  622. <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 11h12z"/></svg>
  623. </div>
  624. <div class="md-footer__title">
  625. <div class="md-ellipsis">
  626. <span class="md-footer__direction">
  627. Previous
  628. </span>
  629. ExternalSecret
  630. </div>
  631. </div>
  632. </a>
  633. <a href="../api-clustersecretstore/" class="md-footer__link md-footer__link--next" aria-label="Next: ClusterSecretStore" rel="next">
  634. <div class="md-footer__title">
  635. <div class="md-ellipsis">
  636. <span class="md-footer__direction">
  637. Next
  638. </span>
  639. ClusterSecretStore
  640. </div>
  641. </div>
  642. <div class="md-footer__button md-icon">
  643. <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M4 11v2h12l-5.5 5.5 1.42 1.42L19.84 12l-7.92-7.92L10.5 5.5 16 11H4z"/></svg>
  644. </div>
  645. </a>
  646. </nav>
  647. <div class="md-footer-meta md-typeset">
  648. <div class="md-footer-meta__inner md-grid">
  649. <div class="md-copyright">
  650. Made with
  651. <a href="https://squidfunk.github.io/mkdocs-material/" target="_blank" rel="noopener">
  652. Material for MkDocs
  653. </a>
  654. </div>
  655. </div>
  656. </div>
  657. </footer>
  658. </div>
  659. <div class="md-dialog" data-md-component="dialog">
  660. <div class="md-dialog__inner md-typeset"></div>
  661. </div>
  662. <script id="__config" type="application/json">{"base": "..", "features": [], "translations": {"clipboard.copy": "Copy to clipboard", "clipboard.copied": "Copied to clipboard", "search.config.lang": "en", "search.config.pipeline": "trimmer, stopWordFilter", "search.config.separator": "[\\s\\-]+", "search.placeholder": "Search", "search.result.placeholder": "Type to start searching", "search.result.none": "No matching documents", "search.result.one": "1 matching document", "search.result.other": "# matching documents", "search.result.more.one": "1 more on this page", "search.result.more.other": "# more on this page", "search.result.term.missing": "Missing", "select.version.title": "Select version"}, "search": "../assets/javascripts/workers/search.22074ed6.min.js", "version": {"provider": "mike"}}</script>
  663. <script src="../assets/javascripts/bundle.960e086b.min.js"></script>
  664. </body>
  665. </html>