@databricks/appkit-ui 0.10.1 → 0.11.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (221) hide show
  1. package/CLAUDE.md +7 -0
  2. package/dist/cli/commands/plugin/sync/sync.js +17 -11
  3. package/dist/cli/commands/plugin/sync/sync.js.map +1 -1
  4. package/dist/react/charts/area/index.d.ts +2 -2
  5. package/dist/react/charts/bar/index.d.ts +2 -2
  6. package/dist/react/charts/base.d.ts +2 -2
  7. package/dist/react/charts/base.d.ts.map +1 -1
  8. package/dist/react/charts/create-chart.d.ts +2 -2
  9. package/dist/react/charts/create-chart.d.ts.map +1 -1
  10. package/dist/react/charts/heatmap/index.d.ts +2 -2
  11. package/dist/react/charts/line/index.d.ts +2 -2
  12. package/dist/react/charts/options.d.ts.map +1 -1
  13. package/dist/react/charts/pie/index.d.ts +3 -3
  14. package/dist/react/charts/radar/index.d.ts +2 -2
  15. package/dist/react/charts/scatter/index.d.ts +2 -2
  16. package/dist/react/charts/wrapper.d.ts +2 -2
  17. package/dist/react/charts/wrapper.d.ts.map +1 -1
  18. package/dist/react/table/data-table.d.ts +2 -2
  19. package/dist/react/table/data-table.d.ts.map +1 -1
  20. package/dist/react/ui/accordion.d.ts +5 -5
  21. package/dist/react/ui/accordion.d.ts.map +1 -1
  22. package/dist/react/ui/alert-dialog.d.ts +12 -12
  23. package/dist/react/ui/alert.d.ts +4 -4
  24. package/dist/react/ui/alert.d.ts.map +1 -1
  25. package/dist/react/ui/aspect-ratio.d.ts +2 -2
  26. package/dist/react/ui/avatar.d.ts +4 -4
  27. package/dist/react/ui/badge.d.ts +2 -2
  28. package/dist/react/ui/breadcrumb.d.ts +8 -8
  29. package/dist/react/ui/button-group.d.ts +4 -4
  30. package/dist/react/ui/button.d.ts +2 -2
  31. package/dist/react/ui/calendar.d.ts +3 -3
  32. package/dist/react/ui/card.d.ts +8 -8
  33. package/dist/react/ui/carousel.d.ts +6 -6
  34. package/dist/react/ui/chart.d.ts +5 -5
  35. package/dist/react/ui/checkbox.d.ts +2 -2
  36. package/dist/react/ui/collapsible.d.ts +4 -4
  37. package/dist/react/ui/command.d.ts +10 -10
  38. package/dist/react/ui/context-menu.d.ts +16 -16
  39. package/dist/react/ui/dialog.d.ts +11 -11
  40. package/dist/react/ui/drawer.d.ts +11 -11
  41. package/dist/react/ui/drawer.d.ts.map +1 -1
  42. package/dist/react/ui/dropdown-menu.d.ts +16 -16
  43. package/dist/react/ui/empty.d.ts +7 -7
  44. package/dist/react/ui/field.d.ts +11 -11
  45. package/dist/react/ui/form.d.ts +7 -7
  46. package/dist/react/ui/hover-card.d.ts +4 -4
  47. package/dist/react/ui/input-group.d.ts +7 -7
  48. package/dist/react/ui/input-otp.d.ts +5 -5
  49. package/dist/react/ui/input.d.ts +2 -2
  50. package/dist/react/ui/item.d.ts +11 -11
  51. package/dist/react/ui/kbd.d.ts +3 -3
  52. package/dist/react/ui/label.d.ts +2 -2
  53. package/dist/react/ui/menubar.d.ts +17 -17
  54. package/dist/react/ui/navigation-menu.d.ts +9 -9
  55. package/dist/react/ui/pagination.d.ts +8 -8
  56. package/dist/react/ui/popover.d.ts +5 -5
  57. package/dist/react/ui/progress.d.ts +2 -2
  58. package/dist/react/ui/radio-group.d.ts +3 -3
  59. package/dist/react/ui/resizable.d.ts +4 -4
  60. package/dist/react/ui/scroll-area.d.ts +3 -3
  61. package/dist/react/ui/select.d.ts +11 -11
  62. package/dist/react/ui/separator.d.ts +2 -2
  63. package/dist/react/ui/sheet.d.ts +9 -9
  64. package/dist/react/ui/sidebar.d.ts +24 -24
  65. package/dist/react/ui/skeleton.d.ts +2 -2
  66. package/dist/react/ui/slider.d.ts +2 -2
  67. package/dist/react/ui/sonner.d.ts +2 -2
  68. package/dist/react/ui/spinner.d.ts +2 -2
  69. package/dist/react/ui/switch.d.ts +2 -2
  70. package/dist/react/ui/table.d.ts +9 -9
  71. package/dist/react/ui/tabs.d.ts +5 -5
  72. package/dist/react/ui/textarea.d.ts +2 -2
  73. package/dist/react/ui/toggle-group.d.ts +3 -3
  74. package/dist/react/ui/toggle.d.ts +2 -2
  75. package/dist/react/ui/tooltip.d.ts +5 -5
  76. package/dist/react/ui/tooltip.d.ts.map +1 -1
  77. package/dist/schemas/plugin-manifest.schema.json +9 -0
  78. package/dist/schemas/template-plugins.schema.json +4 -0
  79. package/docs/docs/api/appkit/Class.AppKitError/index.html +3 -3
  80. package/docs/docs/api/appkit/Class.AuthenticationError/index.html +3 -3
  81. package/docs/docs/api/appkit/Class.ConfigurationError/index.html +3 -3
  82. package/docs/docs/api/appkit/Class.ConnectionError/index.html +3 -3
  83. package/docs/docs/api/appkit/Class.ExecutionError/index.html +3 -3
  84. package/docs/docs/api/appkit/Class.InitializationError/index.html +3 -3
  85. package/docs/docs/api/appkit/Class.Plugin/index.html +3 -3
  86. package/docs/docs/api/appkit/Class.ResourceRegistry/index.html +3 -3
  87. package/docs/docs/api/appkit/Class.ServerError/index.html +3 -3
  88. package/docs/docs/api/appkit/Class.TunnelError/index.html +3 -3
  89. package/docs/docs/api/appkit/Class.ValidationError/index.html +3 -3
  90. package/docs/docs/api/appkit/Enumeration.RequestedClaimsPermissionSet/index.html +3 -3
  91. package/docs/docs/api/appkit/Enumeration.ResourceType/index.html +3 -3
  92. package/docs/docs/api/appkit/Function.appKitTypesPlugin/index.html +3 -3
  93. package/docs/docs/api/appkit/Function.createApp/index.html +3 -3
  94. package/docs/docs/api/appkit/Function.createLakebasePool/index.html +3 -3
  95. package/docs/docs/api/appkit/Function.generateDatabaseCredential/index.html +3 -3
  96. package/docs/docs/api/appkit/Function.getExecutionContext/index.html +3 -3
  97. package/docs/docs/api/appkit/Function.getLakebaseOrmConfig/index.html +3 -3
  98. package/docs/docs/api/appkit/Function.getLakebasePgConfig/index.html +3 -3
  99. package/docs/docs/api/appkit/Function.getPluginManifest/index.html +3 -3
  100. package/docs/docs/api/appkit/Function.getResourceRequirements/index.html +3 -3
  101. package/docs/docs/api/appkit/Function.getUsernameWithApiLookup/index.html +3 -3
  102. package/docs/docs/api/appkit/Function.getWorkspaceClient/index.html +3 -3
  103. package/docs/docs/api/appkit/Function.isSQLTypeMarker/index.html +3 -3
  104. package/docs/docs/api/appkit/Interface.BasePluginConfig/index.html +3 -3
  105. package/docs/docs/api/appkit/Interface.CacheConfig/index.html +3 -3
  106. package/docs/docs/api/appkit/Interface.DatabaseCredential/index.html +3 -3
  107. package/docs/docs/api/appkit/Interface.GenerateDatabaseCredentialRequest/index.html +3 -3
  108. package/docs/docs/api/appkit/Interface.ITelemetry/index.html +3 -3
  109. package/docs/docs/api/appkit/Interface.LakebasePoolConfig/index.html +3 -3
  110. package/docs/docs/api/appkit/Interface.PluginManifest/index.html +8 -4
  111. package/docs/docs/api/appkit/Interface.PluginManifest.md +11 -0
  112. package/docs/docs/api/appkit/Interface.RequestedClaims/index.html +3 -3
  113. package/docs/docs/api/appkit/Interface.RequestedResource/index.html +3 -3
  114. package/docs/docs/api/appkit/Interface.ResourceEntry/index.html +3 -3
  115. package/docs/docs/api/appkit/Interface.ResourceFieldEntry/index.html +3 -3
  116. package/docs/docs/api/appkit/Interface.ResourceRequirement/index.html +3 -3
  117. package/docs/docs/api/appkit/Interface.StreamExecutionSettings/index.html +3 -3
  118. package/docs/docs/api/appkit/Interface.TelemetryConfig/index.html +3 -3
  119. package/docs/docs/api/appkit/Interface.ValidationResult/index.html +3 -3
  120. package/docs/docs/api/appkit/TypeAlias.ConfigSchema/index.html +3 -3
  121. package/docs/docs/api/appkit/TypeAlias.IAppRouter/index.html +3 -3
  122. package/docs/docs/api/appkit/TypeAlias.ResourcePermission/index.html +3 -3
  123. package/docs/docs/api/appkit/TypeAlias.ToPlugin/index.html +3 -3
  124. package/docs/docs/api/appkit/Variable.sql/index.html +3 -3
  125. package/docs/docs/api/appkit/index.html +3 -3
  126. package/docs/docs/api/appkit-ui/data/AreaChart/index.html +3 -3
  127. package/docs/docs/api/appkit-ui/data/BarChart/index.html +3 -3
  128. package/docs/docs/api/appkit-ui/data/DataTable/index.html +3 -3
  129. package/docs/docs/api/appkit-ui/data/DonutChart/index.html +3 -3
  130. package/docs/docs/api/appkit-ui/data/HeatmapChart/index.html +3 -3
  131. package/docs/docs/api/appkit-ui/data/LineChart/index.html +3 -3
  132. package/docs/docs/api/appkit-ui/data/PieChart/index.html +3 -3
  133. package/docs/docs/api/appkit-ui/data/RadarChart/index.html +3 -3
  134. package/docs/docs/api/appkit-ui/data/ScatterChart/index.html +3 -3
  135. package/docs/docs/api/appkit-ui/index.html +3 -3
  136. package/docs/docs/api/appkit-ui/styling/index.html +3 -3
  137. package/docs/docs/api/appkit-ui/ui/Accordion/index.html +3 -3
  138. package/docs/docs/api/appkit-ui/ui/Alert/index.html +3 -3
  139. package/docs/docs/api/appkit-ui/ui/AlertDialog/index.html +3 -3
  140. package/docs/docs/api/appkit-ui/ui/AspectRatio/index.html +3 -3
  141. package/docs/docs/api/appkit-ui/ui/Avatar/index.html +3 -3
  142. package/docs/docs/api/appkit-ui/ui/Badge/index.html +3 -3
  143. package/docs/docs/api/appkit-ui/ui/Breadcrumb/index.html +3 -3
  144. package/docs/docs/api/appkit-ui/ui/Button/index.html +3 -3
  145. package/docs/docs/api/appkit-ui/ui/ButtonGroup/index.html +3 -3
  146. package/docs/docs/api/appkit-ui/ui/Calendar/index.html +3 -3
  147. package/docs/docs/api/appkit-ui/ui/Card/index.html +3 -3
  148. package/docs/docs/api/appkit-ui/ui/Carousel/index.html +3 -3
  149. package/docs/docs/api/appkit-ui/ui/ChartContainer/index.html +3 -3
  150. package/docs/docs/api/appkit-ui/ui/Checkbox/index.html +3 -3
  151. package/docs/docs/api/appkit-ui/ui/Collapsible/index.html +3 -3
  152. package/docs/docs/api/appkit-ui/ui/Command/index.html +3 -3
  153. package/docs/docs/api/appkit-ui/ui/ContextMenu/index.html +3 -3
  154. package/docs/docs/api/appkit-ui/ui/Dialog/index.html +3 -3
  155. package/docs/docs/api/appkit-ui/ui/Drawer/index.html +3 -3
  156. package/docs/docs/api/appkit-ui/ui/DropdownMenu/index.html +3 -3
  157. package/docs/docs/api/appkit-ui/ui/Empty/index.html +3 -3
  158. package/docs/docs/api/appkit-ui/ui/Field/index.html +3 -3
  159. package/docs/docs/api/appkit-ui/ui/FormControl/index.html +3 -3
  160. package/docs/docs/api/appkit-ui/ui/HoverCard/index.html +3 -3
  161. package/docs/docs/api/appkit-ui/ui/Input/index.html +3 -3
  162. package/docs/docs/api/appkit-ui/ui/InputGroup/index.html +3 -3
  163. package/docs/docs/api/appkit-ui/ui/InputOTP/index.html +3 -3
  164. package/docs/docs/api/appkit-ui/ui/Item/index.html +3 -3
  165. package/docs/docs/api/appkit-ui/ui/Kbd/index.html +3 -3
  166. package/docs/docs/api/appkit-ui/ui/Label/index.html +3 -3
  167. package/docs/docs/api/appkit-ui/ui/Menubar/index.html +3 -3
  168. package/docs/docs/api/appkit-ui/ui/NavigationMenu/index.html +3 -3
  169. package/docs/docs/api/appkit-ui/ui/Pagination/index.html +3 -3
  170. package/docs/docs/api/appkit-ui/ui/Popover/index.html +3 -3
  171. package/docs/docs/api/appkit-ui/ui/Progress/index.html +3 -3
  172. package/docs/docs/api/appkit-ui/ui/RadioGroup/index.html +3 -3
  173. package/docs/docs/api/appkit-ui/ui/ResizableHandle/index.html +3 -3
  174. package/docs/docs/api/appkit-ui/ui/ScrollArea/index.html +3 -3
  175. package/docs/docs/api/appkit-ui/ui/Select/index.html +3 -3
  176. package/docs/docs/api/appkit-ui/ui/Separator/index.html +3 -3
  177. package/docs/docs/api/appkit-ui/ui/Sheet/index.html +3 -3
  178. package/docs/docs/api/appkit-ui/ui/Sidebar/index.html +3 -3
  179. package/docs/docs/api/appkit-ui/ui/Skeleton/index.html +3 -3
  180. package/docs/docs/api/appkit-ui/ui/Slider/index.html +3 -3
  181. package/docs/docs/api/appkit-ui/ui/Spinner/index.html +3 -3
  182. package/docs/docs/api/appkit-ui/ui/Switch/index.html +3 -3
  183. package/docs/docs/api/appkit-ui/ui/Table/index.html +3 -3
  184. package/docs/docs/api/appkit-ui/ui/Tabs/index.html +3 -3
  185. package/docs/docs/api/appkit-ui/ui/Textarea/index.html +3 -3
  186. package/docs/docs/api/appkit-ui/ui/Toaster/index.html +3 -3
  187. package/docs/docs/api/appkit-ui/ui/Toggle/index.html +3 -3
  188. package/docs/docs/api/appkit-ui/ui/ToggleGroup/index.html +3 -3
  189. package/docs/docs/api/appkit-ui/ui/Tooltip/index.html +3 -3
  190. package/docs/docs/api/index.html +3 -3
  191. package/docs/docs/app-management/index.html +4 -4
  192. package/docs/docs/architecture/index.html +6 -6
  193. package/docs/docs/category/development/index.html +3 -3
  194. package/docs/docs/configuration/index.html +4 -4
  195. package/docs/docs/core-principles/index.html +3 -3
  196. package/docs/docs/development/ai-assisted-development/index.html +3 -3
  197. package/docs/docs/development/index.html +3 -3
  198. package/docs/docs/development/llm-guide/index.html +3 -3
  199. package/docs/docs/development/local-development/index.html +3 -3
  200. package/docs/docs/development/project-setup/index.html +4 -4
  201. package/docs/docs/development/remote-bridge/index.html +3 -3
  202. package/docs/docs/development/type-generation/index.html +4 -4
  203. package/docs/docs/index.html +3 -3
  204. package/docs/docs/plugins/analytics/index.html +53 -0
  205. package/docs/docs/plugins/analytics.md +66 -0
  206. package/docs/docs/plugins/caching/index.html +23 -0
  207. package/docs/docs/plugins/caching.md +33 -0
  208. package/docs/docs/plugins/custom-plugins/index.html +49 -0
  209. package/docs/docs/plugins/custom-plugins.md +161 -0
  210. package/docs/docs/plugins/execution-context/index.html +40 -0
  211. package/docs/docs/plugins/execution-context.md +45 -0
  212. package/docs/docs/plugins/index.html +6 -173
  213. package/docs/docs/plugins/lakebase/index.html +62 -0
  214. package/docs/docs/plugins/lakebase.md +179 -0
  215. package/docs/docs/plugins/plugin-management/index.html +44 -0
  216. package/docs/docs/plugins/plugin-management.md +88 -0
  217. package/docs/docs/plugins/server/index.html +45 -0
  218. package/docs/docs/plugins/server.md +78 -0
  219. package/docs/docs/plugins.md +0 -481
  220. package/llms.txt +7 -0
  221. package/package.json +1 -1
@@ -0,0 +1,40 @@
1
+ <!doctype html>
2
+ <html lang="en" dir="ltr" class="docs-wrapper plugin-docs plugin-id-default docs-version-current docs-doc-page docs-doc-id-plugins/execution-context" data-has-hydrated="false">
3
+ <head>
4
+ <meta charset="UTF-8">
5
+ <meta name="generator" content="Docusaurus v3.9.2">
6
+ <title data-rh="true">Execution context | AppKit</title><meta data-rh="true" name="viewport" content="width=device-width,initial-scale=1"><meta data-rh="true" name="twitter:card" content="summary_large_image"><meta data-rh="true" property="og:url" content="https://databricks.github.io/appkit/docs/plugins/execution-context"><meta data-rh="true" property="og:locale" content="en"><meta data-rh="true" name="docusaurus_locale" content="en"><meta data-rh="true" name="docsearch:language" content="en"><meta data-rh="true" name="keywords" content="Databricks Apps, Node.js, React.js, SDK, TypeScript, SQL, Databricks, AI, full-stack, development"><meta data-rh="true" name="docusaurus_version" content="current"><meta data-rh="true" name="docusaurus_tag" content="docs-default-current"><meta data-rh="true" name="docsearch:version" content="current"><meta data-rh="true" name="docsearch:docusaurus_tag" content="docs-default-current"><meta data-rh="true" property="og:title" content="Execution context | AppKit"><meta data-rh="true" name="description" content="AppKit manages Databricks authentication via two contexts:"><meta data-rh="true" property="og:description" content="AppKit manages Databricks authentication via two contexts:"><link data-rh="true" rel="icon" href="/appkit/img/favicon.ico"><link data-rh="true" rel="canonical" href="https://databricks.github.io/appkit/docs/plugins/execution-context"><link data-rh="true" rel="alternate" href="https://databricks.github.io/appkit/docs/plugins/execution-context" hreflang="en"><link data-rh="true" rel="alternate" href="https://databricks.github.io/appkit/docs/plugins/execution-context" hreflang="x-default"><script data-rh="true" type="application/ld+json">{"@context":"https://schema.org","@type":"BreadcrumbList","itemListElement":[{"@type":"ListItem","position":1,"name":"Plugins","item":"https://databricks.github.io/appkit/docs/plugins/"},{"@type":"ListItem","position":2,"name":"Execution context","item":"https://databricks.github.io/appkit/docs/plugins/execution-context"}]}</script><link rel="stylesheet" href="/appkit/assets/css/styles.36a38b99.css">
7
+ <script src="/appkit/assets/js/runtime~main.5342f46a.js" defer="defer"></script>
8
+ <script src="/appkit/assets/js/main.bfddc833.js" defer="defer"></script>
9
+ </head>
10
+ <body class="navigation-with-keyboard">
11
+ <svg style="display: none;"><defs>
12
+ <symbol id="theme-svg-external-link" viewBox="0 0 24 24"><path fill="currentColor" d="M21 13v10h-21v-19h12v2h-10v15h17v-8h2zm3-12h-10.988l4.035 4-6.977 7.07 2.828 2.828 6.977-7.07 4.125 4.172v-11z"/></symbol>
13
+ </defs></svg>
14
+ <script>!function(){var t=function(){try{return new URLSearchParams(window.location.search).get("docusaurus-theme")}catch(t){}}()||function(){try{return window.localStorage.getItem("theme")}catch(t){}}();document.documentElement.setAttribute("data-theme",t||(window.matchMedia("(prefers-color-scheme: dark)").matches?"dark":"light")),document.documentElement.setAttribute("data-theme-choice",t||"system")}(),function(){try{const n=new URLSearchParams(window.location.search).entries();for(var[t,e]of n)if(t.startsWith("docusaurus-data-")){var a=t.replace("docusaurus-data-","data-");document.documentElement.setAttribute(a,e)}}catch(t){}}(),document.documentElement.setAttribute("data-announcement-bar-initially-dismissed",function(){try{return"true"===localStorage.getItem("docusaurus.announcement.dismiss")}catch(t){}return!1}())</script><div id="__docusaurus"><link rel="preload" as="image" href="/appkit/img/logo.png"><div role="region" aria-label="Skip to main content"><a class="skipToContent_R3I2" href="#__docusaurus_skipToContent_fallback">Skip to main content</a></div><div class="theme-announcement-bar announcementBar_Upl7" style="background-color:#f0f0f0;color:#000000" role="banner"><div class="announcementBarPlaceholder_Lvio"></div><div class="content_vq0X announcementBarContent_FIMQ">⚠️ AppKit is in an early development phase and is subject to change without notice. <strong>DO NOT</strong> use in production environments.</div><button type="button" aria-label="Close" class="clean-btn close closeButton_J8WU announcementBarClose_jD94"><svg viewBox="0 0 15 15" width="14" height="14"><g stroke="currentColor" stroke-width="3.1"><path d="M.75.75l13.5 13.5M14.25.75L.75 14.25"></path></g></svg></button></div><nav aria-label="Main" class="theme-layout-navbar navbar navbar--fixed-top"><div class="navbar__inner"><div class="theme-layout-navbar-left navbar__items"><button aria-label="Toggle navigation bar" aria-expanded="false" class="navbar__toggle clean-btn" type="button"><svg width="30" height="30" viewBox="0 0 30 30" aria-hidden="true"><path stroke="currentColor" stroke-linecap="round" stroke-miterlimit="10" stroke-width="2" d="M4 7h22M4 15h22M4 23h22"></path></svg></button><a class="navbar__brand" href="/appkit/"><div class="navbar__logo"><img src="/appkit/img/logo.png" alt="AppKit" class="themedComponent_hkXO themedComponent--light_BgK8"><img src="/appkit/img/logo.png" alt="AppKit" class="themedComponent_hkXO themedComponent--dark_RKPt"></div><b class="navbar__title text--truncate">AppKit</b></a><a aria-current="page" class="navbar__item navbar__link navbar__link--active" href="/appkit/docs/">Documentation</a><a class="navbar__item navbar__link" href="/appkit/contributing">Contributing</a></div><div class="theme-layout-navbar-right navbar__items navbar__items--right"><a href="https://github.com/databricks/appkit" target="_blank" rel="noopener noreferrer" class="navbar__item navbar__link">GitHub<svg width="13.5" height="13.5" aria-label="(opens in new tab)" class="iconExternalLink_miaU"><use href="#theme-svg-external-link"></use></svg></a><div class="toggle_eFYw colorModeToggle_EPbi"><button class="clean-btn toggleButton_HRKp toggleButtonDisabled_bICu" type="button" disabled="" title="system mode" aria-label="Switch between dark and light mode (currently system mode)"><svg viewBox="0 0 24 24" width="24" height="24" aria-hidden="true" class="toggleIcon_brDO lightToggleIcon_vxPA"><path fill="currentColor" d="M12,9c1.65,0,3,1.35,3,3s-1.35,3-3,3s-3-1.35-3-3S10.35,9,12,9 M12,7c-2.76,0-5,2.24-5,5s2.24,5,5,5s5-2.24,5-5 S14.76,7,12,7L12,7z M2,13l2,0c0.55,0,1-0.45,1-1s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S1.45,13,2,13z M20,13l2,0c0.55,0,1-0.45,1-1 s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S19.45,13,20,13z M11,2v2c0,0.55,0.45,1,1,1s1-0.45,1-1V2c0-0.55-0.45-1-1-1S11,1.45,11,2z M11,20v2c0,0.55,0.45,1,1,1s1-0.45,1-1v-2c0-0.55-0.45-1-1-1C11.45,19,11,19.45,11,20z M5.99,4.58c-0.39-0.39-1.03-0.39-1.41,0 c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0s0.39-1.03,0-1.41L5.99,4.58z M18.36,16.95 c-0.39-0.39-1.03-0.39-1.41,0c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0c0.39-0.39,0.39-1.03,0-1.41 L18.36,16.95z M19.42,5.99c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06c-0.39,0.39-0.39,1.03,0,1.41 s1.03,0.39,1.41,0L19.42,5.99z M7.05,18.36c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06 c-0.39,0.39-0.39,1.03,0,1.41s1.03,0.39,1.41,0L7.05,18.36z"></path></svg><svg viewBox="0 0 24 24" width="24" height="24" aria-hidden="true" class="toggleIcon_brDO darkToggleIcon_PZNO"><path fill="currentColor" d="M9.37,5.51C9.19,6.15,9.1,6.82,9.1,7.5c0,4.08,3.32,7.4,7.4,7.4c0.68,0,1.35-0.09,1.99-0.27C17.45,17.19,14.93,19,12,19 c-3.86,0-7-3.14-7-7C5,9.07,6.81,6.55,9.37,5.51z M12,3c-4.97,0-9,4.03-9,9s4.03,9,9,9s9-4.03,9-9c0-0.46-0.04-0.92-0.1-1.36 c-0.98,1.37-2.58,2.26-4.4,2.26c-2.98,0-5.4-2.42-5.4-5.4c0-1.81,0.89-3.42,2.26-4.4C12.92,3.04,12.46,3,12,3L12,3z"></path></svg><svg viewBox="0 0 24 24" width="24" height="24" aria-hidden="true" class="toggleIcon_brDO systemToggleIcon_A7x6"><path fill="currentColor" d="m12 21c4.971 0 9-4.029 9-9s-4.029-9-9-9-9 4.029-9 9 4.029 9 9 9zm4.95-13.95c1.313 1.313 2.05 3.093 2.05 4.95s-0.738 3.637-2.05 4.95c-1.313 1.313-3.093 2.05-4.95 2.05v-14c1.857 0 3.637 0.737 4.95 2.05z"></path></svg></button></div><div class="navbarSearchContainer_cVhq"><div class="navbar__search"><span aria-label="expand searchbar" role="button" class="search-icon" tabindex="0"></span><input id="search_input_react" type="search" placeholder="Loading..." aria-label="Search" class="navbar__search-input search-bar" disabled=""></div></div></div></div><div role="presentation" class="navbar-sidebar__backdrop"></div></nav><div id="__docusaurus_skipToContent_fallback" class="theme-layout-main main-wrapper mainWrapper__Y_W"><div class="docsWrapper_cIfN"><button aria-label="Scroll back to top" class="clean-btn theme-back-to-top-button backToTopButton_xQFv" type="button"></button><div class="docRoot_FHtD"><aside class="theme-doc-sidebar-container docSidebarContainer_dvCd"><div class="sidebarViewport_GeRf"><div class="sidebar_T8N1"><nav aria-label="Docs sidebar" class="menu thin-scrollbar menu_uyE9 menuWithAnnouncementBar_Bucd"><ul class="theme-doc-sidebar-menu menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-1 menu__list-item"><a class="menu__link" href="/appkit/docs/"><span title="Getting started" class="linkLabel_hZzm">Getting started</span></a></li><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-1 menu__list-item"><a class="menu__link" href="/appkit/docs/app-management"><span title="App management" class="linkLabel_hZzm">App management</span></a></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item"><div class="menu__list-item-collapsible"><a class="categoryLink_P6CU menu__link menu__link--sublist menu__link--active" href="/appkit/docs/plugins/"><span title="Plugins" class="categoryLinkLabel_ShmP">Plugins</span></a><button aria-label="Collapse sidebar category &#x27;Plugins&#x27;" aria-expanded="true" type="button" class="clean-btn menu__caret"></button></div><ul class="menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link" tabindex="0" href="/appkit/docs/plugins/server"><span title="Server plugin" class="linkLabel_hZzm">Server plugin</span></a></li><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link" tabindex="0" href="/appkit/docs/plugins/analytics"><span title="Analytics plugin" class="linkLabel_hZzm">Analytics plugin</span></a></li><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link" tabindex="0" href="/appkit/docs/plugins/lakebase"><span title="Lakebase plugin" class="linkLabel_hZzm">Lakebase plugin</span></a></li><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link menu__link--active" aria-current="page" tabindex="0" href="/appkit/docs/plugins/execution-context"><span title="Execution context" class="linkLabel_hZzm">Execution context</span></a></li><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link" tabindex="0" href="/appkit/docs/plugins/plugin-management"><span title="Plugin management" class="linkLabel_hZzm">Plugin management</span></a></li><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link" tabindex="0" href="/appkit/docs/plugins/custom-plugins"><span title="Creating custom plugins" class="linkLabel_hZzm">Creating custom plugins</span></a></li><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link" tabindex="0" href="/appkit/docs/plugins/caching"><span title="Caching" class="linkLabel_hZzm">Caching</span></a></li></ul></li><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-1 menu__list-item"><a class="menu__link" href="/appkit/docs/architecture"><span title="Architecture" class="linkLabel_hZzm">Architecture</span></a></li><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-1 menu__list-item"><a class="menu__link" href="/appkit/docs/configuration"><span title="Configuration" class="linkLabel_hZzm">Configuration</span></a></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item"><div class="menu__list-item-collapsible"><a class="categoryLink_P6CU menu__link menu__link--sublist" href="/appkit/docs/category/development"><span title="Development" class="categoryLinkLabel_ShmP">Development</span></a><button aria-label="Collapse sidebar category &#x27;Development&#x27;" aria-expanded="true" type="button" class="clean-btn menu__caret"></button></div><ul class="menu__list"><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link" tabindex="0" href="/appkit/docs/development/local-development"><span title="Local development" class="linkLabel_hZzm">Local development</span></a></li><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link" tabindex="0" href="/appkit/docs/development/ai-assisted-development"><span title="AI-Assisted development" class="linkLabel_hZzm">AI-Assisted development</span></a></li><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link" tabindex="0" href="/appkit/docs/development/"><span title="Development" class="linkLabel_hZzm">Development</span></a></li><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link" tabindex="0" href="/appkit/docs/development/remote-bridge"><span title="Remote Bridge" class="linkLabel_hZzm">Remote Bridge</span></a></li><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link" tabindex="0" href="/appkit/docs/development/project-setup"><span title="Project setup" class="linkLabel_hZzm">Project setup</span></a></li><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link" tabindex="0" href="/appkit/docs/development/type-generation"><span title="Type generation" class="linkLabel_hZzm">Type generation</span></a></li><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-2 menu__list-item"><a class="menu__link" tabindex="0" href="/appkit/docs/development/llm-guide"><span title="LLM Guide" class="linkLabel_hZzm">LLM Guide</span></a></li></ul></li><li class="theme-doc-sidebar-item-link theme-doc-sidebar-item-link-level-1 menu__list-item"><a class="menu__link" href="/appkit/docs/core-principles"><span title="Core principles" class="linkLabel_hZzm">Core principles</span></a></li><li class="theme-doc-sidebar-item-category theme-doc-sidebar-item-category-level-1 menu__list-item menu__list-item--collapsed"><div class="menu__list-item-collapsible"><a class="categoryLink_P6CU menu__link menu__link--sublist" href="/appkit/docs/api/"><span title="API reference" class="categoryLinkLabel_ShmP">API reference</span></a><button aria-label="Expand sidebar category &#x27;API reference&#x27;" aria-expanded="false" type="button" class="clean-btn menu__caret"></button></div></li></ul></nav></div></div></aside><main class="docMainContainer_P5br"><div class="container padding-top--md padding-bottom--lg"><div class="row"><div class="col docItemCol_poBZ"><div class="docItemContainer_TdBg"><article><nav class="theme-doc-breadcrumbs breadcrumbsContainer_bEIa" aria-label="Breadcrumbs"><ul class="breadcrumbs"><li class="breadcrumbs__item"><a aria-label="Home page" class="breadcrumbs__link" href="/appkit/"><svg viewBox="0 0 24 24" class="breadcrumbHomeIcon_sma7"><path d="M10 19v-5h4v5c0 .55.45 1 1 1h3c.55 0 1-.45 1-1v-7h1.7c.46 0 .68-.57.33-.87L12.67 3.6c-.38-.34-.96-.34-1.34 0l-8.36 7.53c-.34.3-.13.87.33.87H5v7c0 .55.45 1 1 1h3c.55 0 1-.45 1-1z" fill="currentColor"></path></svg></a></li><li class="breadcrumbs__item"><a class="breadcrumbs__link" href="/appkit/docs/plugins/"><span>Plugins</span></a></li><li class="breadcrumbs__item breadcrumbs__item--active"><span class="breadcrumbs__link">Execution context</span></li></ul></nav><div class="tocCollapsible_gJxE theme-doc-toc-mobile tocMobile_ZHYV"><button type="button" class="clean-btn tocCollapsibleButton_uxuR">On this page</button></div><div class="theme-doc-markdown markdown"><header><h1>Execution context</h1></header>
15
+ <p>AppKit manages Databricks authentication via two contexts:</p>
16
+ <ul>
17
+ <li class=""><strong>ServiceContext</strong> (singleton): Initialized at app startup with service principal credentials</li>
18
+ <li class=""><strong>ExecutionContext</strong>: Determined at runtime - either service principal or user context</li>
19
+ </ul>
20
+ <h2 class="anchor anchorTargetStickyNavbar_scV4" id="headers-for-user-context">Headers for user context<a href="#headers-for-user-context" class="hash-link" aria-label="Direct link to Headers for user context" title="Direct link to Headers for user context" translate="no">​</a></h2>
21
+ <ul>
22
+ <li class=""><code>x-forwarded-user</code>: required in production; identifies the user</li>
23
+ <li class=""><code>x-forwarded-access-token</code>: required for user token passthrough</li>
24
+ </ul>
25
+ <h2 class="anchor anchorTargetStickyNavbar_scV4" id="using-asuserreq-for-user-scoped-operations">Using <code>asUser(req)</code> for user-scoped operations<a href="#using-asuserreq-for-user-scoped-operations" class="hash-link" aria-label="Direct link to using-asuserreq-for-user-scoped-operations" title="Direct link to using-asuserreq-for-user-scoped-operations" translate="no">​</a></h2>
26
+ <p>The <code>asUser(req)</code> pattern allows plugins to execute operations using the requesting user&#x27;s credentials:</p>
27
+ <div class="language-ts codeBlockContainer_crgn theme-code-block" style="--prism-color:#000000;--prism-background-color:#ffffff"><div class="codeBlockContent__42J"><pre tabindex="0" class="prism-code language-ts codeBlock_CnLD thin-scrollbar" style="color:#000000;background-color:#ffffff"><code class="codeBlockLines_sJEA"><span class="token-line" style="color:#000000"><span class="token comment" style="color:rgb(0, 128, 0)">// In a custom plugin route handler</span><span class="token plain"></span><br></span><span class="token-line" style="color:#000000"><span class="token plain">router</span><span class="token punctuation" style="color:rgb(4, 81, 165)">.</span><span class="token function" style="color:rgb(0, 0, 255)">post</span><span class="token punctuation" style="color:rgb(4, 81, 165)">(</span><span class="token string" style="color:rgb(163, 21, 21)">&quot;/users/me/data&quot;</span><span class="token punctuation" style="color:rgb(4, 81, 165)">,</span><span class="token plain"> </span><span class="token keyword" style="color:rgb(0, 0, 255)">async</span><span class="token plain"> </span><span class="token punctuation" style="color:rgb(4, 81, 165)">(</span><span class="token plain">req</span><span class="token punctuation" style="color:rgb(4, 81, 165)">,</span><span class="token plain"> res</span><span class="token punctuation" style="color:rgb(4, 81, 165)">)</span><span class="token plain"> </span><span class="token operator" style="color:rgb(0, 0, 0)">=&gt;</span><span class="token plain"> </span><span class="token punctuation" style="color:rgb(4, 81, 165)">{</span><span class="token plain"></span><br></span><span class="token-line" style="color:#000000"><span class="token plain"> </span><span class="token comment" style="color:rgb(0, 128, 0)">// Execute as the user (uses their Databricks permissions)</span><span class="token plain"></span><br></span><span class="token-line" style="color:#000000"><span class="token plain"> </span><span class="token keyword" style="color:rgb(0, 0, 255)">const</span><span class="token plain"> result </span><span class="token operator" style="color:rgb(0, 0, 0)">=</span><span class="token plain"> </span><span class="token keyword" style="color:rgb(0, 0, 255)">await</span><span class="token plain"> </span><span class="token keyword" style="color:rgb(0, 0, 255)">this</span><span class="token punctuation" style="color:rgb(4, 81, 165)">.</span><span class="token function" style="color:rgb(0, 0, 255)">asUser</span><span class="token punctuation" style="color:rgb(4, 81, 165)">(</span><span class="token plain">req</span><span class="token punctuation" style="color:rgb(4, 81, 165)">)</span><span class="token punctuation" style="color:rgb(4, 81, 165)">.</span><span class="token function" style="color:rgb(0, 0, 255)">query</span><span class="token punctuation" style="color:rgb(4, 81, 165)">(</span><span class="token string" style="color:rgb(163, 21, 21)">&quot;SELECT ...&quot;</span><span class="token punctuation" style="color:rgb(4, 81, 165)">)</span><span class="token punctuation" style="color:rgb(4, 81, 165)">;</span><span class="token plain"></span><br></span><span class="token-line" style="color:#000000"><span class="token plain"> res</span><span class="token punctuation" style="color:rgb(4, 81, 165)">.</span><span class="token function" style="color:rgb(0, 0, 255)">json</span><span class="token punctuation" style="color:rgb(4, 81, 165)">(</span><span class="token plain">result</span><span class="token punctuation" style="color:rgb(4, 81, 165)">)</span><span class="token punctuation" style="color:rgb(4, 81, 165)">;</span><span class="token plain"></span><br></span><span class="token-line" style="color:#000000"><span class="token plain"></span><span class="token punctuation" style="color:rgb(4, 81, 165)">}</span><span class="token punctuation" style="color:rgb(4, 81, 165)">)</span><span class="token punctuation" style="color:rgb(4, 81, 165)">;</span><span class="token plain"></span><br></span><span class="token-line" style="color:#000000"><span class="token plain" style="display:inline-block"></span><br></span><span class="token-line" style="color:#000000"><span class="token plain"></span><span class="token comment" style="color:rgb(0, 128, 0)">// Service principal execution (default)</span><span class="token plain"></span><br></span><span class="token-line" style="color:#000000"><span class="token plain">router</span><span class="token punctuation" style="color:rgb(4, 81, 165)">.</span><span class="token function" style="color:rgb(0, 0, 255)">post</span><span class="token punctuation" style="color:rgb(4, 81, 165)">(</span><span class="token string" style="color:rgb(163, 21, 21)">&quot;/system/data&quot;</span><span class="token punctuation" style="color:rgb(4, 81, 165)">,</span><span class="token plain"> </span><span class="token keyword" style="color:rgb(0, 0, 255)">async</span><span class="token plain"> </span><span class="token punctuation" style="color:rgb(4, 81, 165)">(</span><span class="token plain">req</span><span class="token punctuation" style="color:rgb(4, 81, 165)">,</span><span class="token plain"> res</span><span class="token punctuation" style="color:rgb(4, 81, 165)">)</span><span class="token plain"> </span><span class="token operator" style="color:rgb(0, 0, 0)">=&gt;</span><span class="token plain"> </span><span class="token punctuation" style="color:rgb(4, 81, 165)">{</span><span class="token plain"></span><br></span><span class="token-line" style="color:#000000"><span class="token plain"> </span><span class="token keyword" style="color:rgb(0, 0, 255)">const</span><span class="token plain"> result </span><span class="token operator" style="color:rgb(0, 0, 0)">=</span><span class="token plain"> </span><span class="token keyword" style="color:rgb(0, 0, 255)">await</span><span class="token plain"> </span><span class="token keyword" style="color:rgb(0, 0, 255)">this</span><span class="token punctuation" style="color:rgb(4, 81, 165)">.</span><span class="token function" style="color:rgb(0, 0, 255)">query</span><span class="token punctuation" style="color:rgb(4, 81, 165)">(</span><span class="token string" style="color:rgb(163, 21, 21)">&quot;SELECT ...&quot;</span><span class="token punctuation" style="color:rgb(4, 81, 165)">)</span><span class="token punctuation" style="color:rgb(4, 81, 165)">;</span><span class="token plain"></span><br></span><span class="token-line" style="color:#000000"><span class="token plain"> res</span><span class="token punctuation" style="color:rgb(4, 81, 165)">.</span><span class="token function" style="color:rgb(0, 0, 255)">json</span><span class="token punctuation" style="color:rgb(4, 81, 165)">(</span><span class="token plain">result</span><span class="token punctuation" style="color:rgb(4, 81, 165)">)</span><span class="token punctuation" style="color:rgb(4, 81, 165)">;</span><span class="token plain"></span><br></span><span class="token-line" style="color:#000000"><span class="token plain"></span><span class="token punctuation" style="color:rgb(4, 81, 165)">}</span><span class="token punctuation" style="color:rgb(4, 81, 165)">)</span><span class="token punctuation" style="color:rgb(4, 81, 165)">;</span><br></span></code></pre></div></div>
28
+ <h2 class="anchor anchorTargetStickyNavbar_scV4" id="context-helper-functions">Context helper functions<a href="#context-helper-functions" class="hash-link" aria-label="Direct link to Context helper functions" title="Direct link to Context helper functions" translate="no">​</a></h2>
29
+ <p>Exported from <code>@databricks/appkit</code>:</p>
30
+ <ul>
31
+ <li class=""><code>getCurrentUserId()</code>: Returns user ID in user context, service user ID otherwise</li>
32
+ <li class=""><code>getWorkspaceClient()</code>: Returns the appropriate WorkspaceClient for current context</li>
33
+ <li class=""><code>getWarehouseId()</code>: <code>Promise&lt;string&gt;</code> (from <code>DATABRICKS_WAREHOUSE_ID</code> or auto-selected in dev)</li>
34
+ <li class=""><code>getWorkspaceId()</code>: <code>Promise&lt;string&gt;</code> (from <code>DATABRICKS_WORKSPACE_ID</code> or fetched)</li>
35
+ <li class=""><code>isInUserContext()</code>: Returns <code>true</code> if currently executing in user context</li>
36
+ </ul>
37
+ <h2 class="anchor anchorTargetStickyNavbar_scV4" id="development-mode-behavior">Development mode behavior<a href="#development-mode-behavior" class="hash-link" aria-label="Direct link to Development mode behavior" title="Direct link to Development mode behavior" translate="no">​</a></h2>
38
+ <p>In local development (<code>NODE_ENV=development</code>), if <code>asUser(req)</code> is called without a user token, it logs a warning and falls back to the service principal.</p></div><footer class="theme-doc-footer docusaurus-mt-lg"><div class="row margin-top--sm theme-doc-footer-edit-meta-row"><div class="col noPrint_Z6Q_"><a href="https://github.com/databricks/appkit/edit/main/docs/docs/plugins/execution-context.md" target="_blank" rel="noopener noreferrer" class="theme-edit-this-page"><svg fill="currentColor" height="20" width="20" viewBox="0 0 40 40" class="iconEdit_kMm5" aria-hidden="true"><g><path d="m34.5 11.7l-3 3.1-6.3-6.3 3.1-3q0.5-0.5 1.2-0.5t1.1 0.5l3.9 3.9q0.5 0.4 0.5 1.1t-0.5 1.2z m-29.5 17.1l18.4-18.5 6.3 6.3-18.4 18.4h-6.3v-6.2z"></path></g></svg>Edit this page</a></div><div class="col lastUpdated_mnLK"></div></div></footer></article><nav class="docusaurus-mt-lg pagination-nav" aria-label="Docs pages"><a class="pagination-nav__link pagination-nav__link--prev" href="/appkit/docs/plugins/lakebase"><div class="pagination-nav__sublabel">Previous</div><div class="pagination-nav__label">Lakebase plugin</div></a><a class="pagination-nav__link pagination-nav__link--next" href="/appkit/docs/plugins/plugin-management"><div class="pagination-nav__sublabel">Next</div><div class="pagination-nav__label">Plugin management</div></a></nav></div></div><div class="col col--3"><div class="tableOfContents_xfIk thin-scrollbar theme-doc-toc-desktop"><ul class="table-of-contents table-of-contents__left-border"><li><a href="#headers-for-user-context" class="table-of-contents__link toc-highlight">Headers for user context</a></li><li><a href="#using-asuserreq-for-user-scoped-operations" class="table-of-contents__link toc-highlight">Using <code>asUser(req)</code> for user-scoped operations</a></li><li><a href="#context-helper-functions" class="table-of-contents__link toc-highlight">Context helper functions</a></li><li><a href="#development-mode-behavior" class="table-of-contents__link toc-highlight">Development mode behavior</a></li></ul></div></div></div></div></main></div></div></div><footer class="theme-layout-footer footer footer--dark"><div class="container container-fluid"><div class="row footer__links"><div class="theme-layout-footer-column col footer__col"><div class="footer__title">Docs</div><ul class="footer__items clean-list"><li class="footer__item"><a class="footer__link-item" href="/appkit/docs/">Getting started</a></li><li class="footer__item"><a class="footer__link-item" href="/appkit/docs/api/">API reference</a></li></ul></div><div class="theme-layout-footer-column col footer__col"><div class="footer__title">Community</div><ul class="footer__items clean-list"><li class="footer__item"><a class="footer__link-item" href="/appkit/contributing">Contributing</a></li><li class="footer__item"><a href="https://github.com/databricks/appkit" target="_blank" rel="noopener noreferrer" class="footer__link-item">GitHub<svg width="13.5" height="13.5" aria-label="(opens in new tab)" class="iconExternalLink_miaU"><use href="#theme-svg-external-link"></use></svg></a></li></ul></div><div class="theme-layout-footer-column col footer__col"><div class="footer__title">More</div><ul class="footer__items clean-list"><li class="footer__item"><a href="https://docs.databricks.com/aws/en/dev-tools/databricks-apps/" target="_blank" rel="noopener noreferrer" class="footer__link-item">Databricks Apps docs<svg width="13.5" height="13.5" aria-label="(opens in new tab)" class="iconExternalLink_miaU"><use href="#theme-svg-external-link"></use></svg></a></li><li class="footer__item"><a href="https://github.com/databricks/cli" target="_blank" rel="noopener noreferrer" class="footer__link-item">Databricks CLI<svg width="13.5" height="13.5" aria-label="(opens in new tab)" class="iconExternalLink_miaU"><use href="#theme-svg-external-link"></use></svg></a></li></ul></div></div><div class="footer__bottom text--center"><div class="footer__copyright">Copyright © 2026 Databricks, Inc.</div></div></div></footer></div>
39
+ </body>
40
+ </html>
@@ -0,0 +1,45 @@
1
+ # Execution context
2
+
3
+ AppKit manages Databricks authentication via two contexts:
4
+
5
+ * **ServiceContext** (singleton): Initialized at app startup with service principal credentials
6
+ * **ExecutionContext**: Determined at runtime - either service principal or user context
7
+
8
+ ## Headers for user context[​](#headers-for-user-context "Direct link to Headers for user context")
9
+
10
+ * `x-forwarded-user`: required in production; identifies the user
11
+ * `x-forwarded-access-token`: required for user token passthrough
12
+
13
+ ## Using `asUser(req)` for user-scoped operations[​](#using-asuserreq-for-user-scoped-operations "Direct link to using-asuserreq-for-user-scoped-operations")
14
+
15
+ The `asUser(req)` pattern allows plugins to execute operations using the requesting user's credentials:
16
+
17
+ ```ts
18
+ // In a custom plugin route handler
19
+ router.post("/users/me/data", async (req, res) => {
20
+ // Execute as the user (uses their Databricks permissions)
21
+ const result = await this.asUser(req).query("SELECT ...");
22
+ res.json(result);
23
+ });
24
+
25
+ // Service principal execution (default)
26
+ router.post("/system/data", async (req, res) => {
27
+ const result = await this.query("SELECT ...");
28
+ res.json(result);
29
+ });
30
+
31
+ ```
32
+
33
+ ## Context helper functions[​](#context-helper-functions "Direct link to Context helper functions")
34
+
35
+ Exported from `@databricks/appkit`:
36
+
37
+ * `getCurrentUserId()`: Returns user ID in user context, service user ID otherwise
38
+ * `getWorkspaceClient()`: Returns the appropriate WorkspaceClient for current context
39
+ * `getWarehouseId()`: `Promise<string>` (from `DATABRICKS_WAREHOUSE_ID` or auto-selected in dev)
40
+ * `getWorkspaceId()`: `Promise<string>` (from `DATABRICKS_WORKSPACE_ID` or fetched)
41
+ * `isInUserContext()`: Returns `true` if currently executing in user context
42
+
43
+ ## Development mode behavior[​](#development-mode-behavior "Direct link to Development mode behavior")
44
+
45
+ In local development (`NODE_ENV=development`), if `asUser(req)` is called without a user token, it logs a warning and falls back to the service principal.