1:HL["/_next/static/media/6905431624c34d00-s.p.woff2","font",{"crossOrigin":"","type":"font/woff2"}] 2:HL["/_next/static/css/9e925a33b1acdac1.css","style",{"crossOrigin":""}] 0:["rmcKjFZ3e9kKdH1iJwCIQ",[[["",{"children":["blog",{"children":[["slug","2022/04/04/Announcing-Apache-Pinot-0-10","c"],{"children":["__PAGE__?{\"slug\":[\"2022\",\"04\",\"04\",\"Announcing-Apache-Pinot-0-10\"]}",{}]}]}]},"$undefined","$undefined",true],"$L3",[[["$","link","0",{"rel":"stylesheet","href":"/_next/static/css/9e925a33b1acdac1.css","precedence":"next","crossOrigin":""}]],"$L4"]]]] 5:HL["/_next/static/css/c130d1629644f070.css","style",{"crossOrigin":""}] 6:I[7821,["326","static/chunks/326-3a90a6443b9c824c.js","980","static/chunks/980-6e243f9cd384c7d2.js","702","static/chunks/702-a2bf9fe707814b79.js","185","static/chunks/app/layout-776a485845c720ef.js"],"ThemeProviders"] 7:I[3994,["326","static/chunks/326-3a90a6443b9c824c.js","980","static/chunks/980-6e243f9cd384c7d2.js","702","static/chunks/702-a2bf9fe707814b79.js","185","static/chunks/app/layout-776a485845c720ef.js"],""] 8:I[9640,["326","static/chunks/326-3a90a6443b9c824c.js","980","static/chunks/980-6e243f9cd384c7d2.js","702","static/chunks/702-a2bf9fe707814b79.js","185","static/chunks/app/layout-776a485845c720ef.js"],"AlgoliaSearchProvider"] 9:I[7975,["326","static/chunks/326-3a90a6443b9c824c.js","980","static/chunks/980-6e243f9cd384c7d2.js","702","static/chunks/702-a2bf9fe707814b79.js","185","static/chunks/app/layout-776a485845c720ef.js"],""] a:I[6954,[],""] b:I[7264,[],""] c:I[8326,["326","static/chunks/326-3a90a6443b9c824c.js","413","static/chunks/413-f9f40b83f7bb3f22.js","980","static/chunks/980-6e243f9cd384c7d2.js","797","static/chunks/app/blog/%5B...slug%5D/page-502e08b6677b55da.js"],""] f:T9fe,M42.99 18.448c1.032-.553 2.21-.831 3.535-.831 1.542 0 2.938.38 4.187 1.14 1.248.76 2.236 1.841 2.965 3.241.728 1.402 1.091 3.025 1.091 4.872s-.363 3.482-1.091 4.903c-.729 1.424-1.717 2.525-2.965 3.307-1.25.782-2.645 1.173-4.187 1.173-1.325 0-2.493-.271-3.503-.815-1.01-.543-1.83-1.226-2.46-2.053v14.612H36V17.912h4.562v2.606c.586-.825 1.395-1.515 2.426-2.068l.002-.002m6.452 5.605c-.445-.793-1.032-1.395-1.76-1.808a4.72 4.72 0 0 0-2.362-.618c-.847 0-1.602.211-2.33.635-.728.423-1.315 1.038-1.76 1.841-.445.804-.668 1.749-.668 2.835 0 1.087.221 2.032.668 2.835.445.804 1.032 1.417 1.76 1.842a4.557 4.557 0 0 0 2.33.635 4.57 4.57 0 0 0 2.362-.652c.728-.435 1.313-1.053 1.76-1.856.445-.804.668-1.76.668-2.867s-.223-2.025-.668-2.818v-.004M62.947 17.912v18.051h-4.562V17.912h4.562m.551-6.079a2.833 2.833 0 1 1-5.666 0 2.833 2.833 0 0 1 5.666 0M82.954 19.687c1.325 1.358 1.988 3.253 1.988 5.685v10.59H80.38v-9.97c0-1.434-.358-2.537-1.075-3.307-.717-.772-1.695-1.157-2.933-1.157-1.239 0-2.254.387-2.982 1.157-.728.772-1.091 1.873-1.091 3.307v9.97h-4.562V17.91h4.562v2.248a6.322 6.322 0 0 1 2.33-1.841c.944-.445 1.981-.669 3.111-.669 2.15 0 3.889.68 5.214 2.037v.002M92.892 35.098c-1.39-.77-2.482-1.861-3.275-3.275-.794-1.411-1.19-3.041-1.19-4.888s.406-3.475 1.221-4.888a8.502 8.502 0 0 1 3.34-3.275c1.412-.772 2.987-1.157 4.725-1.157 1.739 0 3.312.387 4.725 1.157a8.5 8.5 0 0 1 3.34 3.275c.815 1.411 1.222 3.041 1.222 4.888s-.418 3.475-1.255 4.888a8.708 8.708 0 0 1-3.388 3.275c-1.424.772-3.014 1.157-4.774 1.157-1.76 0-3.301-.385-4.691-1.157m7.021-3.421c.729-.402 1.309-1.005 1.744-1.809.435-.803.651-1.781.651-2.933 0-1.715-.451-3.035-1.351-3.958-.902-.924-2.004-1.385-3.307-1.385s-2.395.461-3.275 1.385c-.88.923-1.32 2.243-1.32 3.958 0 1.715.428 3.035 1.287 3.958.858.924 1.938 1.385 3.241 1.385.825 0 1.602-.2 2.33-.603v.002M115.96 21.658v8.734c0 .608.147 1.048.44 1.32.293.271.787.406 1.482.406H120v3.845h-2.867c-3.845 0-5.766-1.868-5.766-5.605v-8.7h-2.15v-3.746h2.15V13l4.595-1v5.912h4.04v3.746h-4.042M20.03 46.757l-5.538-1.385A1.97 1.97 0 0 1 13 43.46v-5.462c0-.841.349-1.601.907-2.146a12.212 12.212 0 0 0 6.975-3.644c2.602-2.731 3.627-6.578 2.882-10.251L21 9h-4V4a1 1 0 0 0-2 0v7a1 1 0 0 1-2 0v-1a1 1 0 0 0-2 0v6.758a4.489 4.489 0 0 1 2.694-.755c2.278.095 4.156 1.934 4.297 4.21a4.501 4.501 0 0 1-6.992 4.029V29a1 1 0 0 1-2 0V7a1 1 0 0 0-2 0v2h-4L.237 21.957c-.745 3.675.279 7.52 2.882 10.251a12.202 12.202 0 0 0 6.975 3.644c.558.545.907 1.305.907 2.146V43.4c0 .938-.639 1.757-1.55 1.985l-5.48 1.37c-.57.143-.97.655-.97 1.243h18c0-.588-.4-1.1-.97-1.243v.0023:[null,["$","html",null,{"lang":"en-us","className":"__variable_1fc36d scroll-smooth","suppressHydrationWarning":true,"children":[["$","head",null,{"children":[["$","meta",null,{"httpEquiv":"Content-Security-Policy","content":"default-src 'self';script-src 'self' 'unsafe-eval' 'unsafe-inline' giscus.app analytics.umami.is www.youtube.com www.googletagmanager.com www.google-analytics.com;style-src 'self' 'unsafe-inline';img-src * blob: data:;media-src *.s3.amazonaws.com;connect-src *;font-src 'self';frame-src www.youtube.com youtube.com giscus.app youtu.be https://www.youtube.com https://youtube.com;"}],["$","link",null,{"rel":"apple-touch-icon","sizes":"76x76","href":"/static/favicons/apple-touch-icon.png"}],["$","link",null,{"rel":"icon","type":"image/png","sizes":"32x32","href":"/static/favicons/favicon-32x32.png"}],["$","link",null,{"rel":"icon","type":"image/png","sizes":"16x16","href":"/static/favicons/favicon-16x16.png"}],["$","link",null,{"rel":"manifest","href":"/static/favicons/site.webmanifest"}],["$","link",null,{"rel":"mask-icon","href":"/static/favicons/safari-pinned-tab.svg","color":"#5bbad5"}],["$","meta",null,{"name":"msapplication-TileColor","content":"#000000"}],["$","meta",null,{"name":"theme-color","media":"(prefers-color-scheme: light)","content":"#fff"}],["$","meta",null,{"name":"theme-color","media":"(prefers-color-scheme: dark)","content":"#000"}],["$","link",null,{"rel":"alternate","type":"application/rss+xml","href":"/feed.xml"}]]}],["$","body",null,{"className":"bg-white text-black antialiased dark:bg-gray-950 dark:text-white","children":["$","$L6",null,{"children":[["$undefined","$undefined","$undefined","$undefined",[["$","$L7",null,{"strategy":"afterInteractive","src":"https://www.googletagmanager.com/gtag/js?id=G-ZXG79NJEBY"}],["$","$L7",null,{"strategy":"afterInteractive","id":"ga-script","children":"\n window.dataLayer = window.dataLayer || [];\n function gtag(){dataLayer.push(arguments);}\n gtag('js', new Date());\n gtag('config', 'G-ZXG79NJEBY');\n "}]]],["$","div",null,{"className":"mx-auto flex max-w-screen-customDesktop flex-col justify-between font-sans","children":["$","$L8",null,{"algoliaConfig":{"appId":"CKRA00L2X9","apiKey":"6531f8f7783a88d76629190843f1801e","indexName":"prod_apache_pinot_docs"},"children":[["$","$L9",null,{}],["$","main",null,{"children":["$","$La",null,{"parallelRouterKey":"children","segmentPath":["children"],"loading":"$undefined","loadingStyles":"$undefined","loadingScripts":"$undefined","hasLoading":false,"error":"$undefined","errorStyles":"$undefined","errorScripts":"$undefined","template":["$","$Lb",null,{}],"templateStyles":"$undefined","templateScripts":"$undefined","notFound":["$","div",null,{"className":"flex flex-col items-start justify-start md:mt-24 md:flex-row md:items-center md:justify-center md:space-x-6","children":[["$","div",null,{"className":"space-x-2 pb-8 pt-6 md:space-y-5","children":["$","h1",null,{"className":"text-6xl font-extrabold leading-9 tracking-tight text-gray-900 dark:text-gray-100 md:border-r-2 md:px-6 md:text-8xl md:leading-14","children":"404"}]}],["$","div",null,{"className":"max-w-md","children":[["$","p",null,{"className":"mb-4 text-xl font-bold leading-normal md:text-2xl","children":"Sorry we couldn't find this page."}],["$","p",null,{"className":"mb-8","children":"But dont worry, you can find plenty of other things on our homepage."}],["$","$Lc",null,{"href":"/","className":"focus:shadow-outline-blue inline rounded-lg border border-transparent bg-blue-600 px-4 py-2 text-sm font-medium leading-5 text-white shadow transition-colors duration-150 hover:bg-blue-700 focus:outline-none dark:hover:bg-blue-500","children":"Back to homepage"}]]}]]}],"notFoundStyles":[],"initialChildNode":["$","$La",null,{"parallelRouterKey":"children","segmentPath":["children","blog","children"],"loading":"$undefined","loadingStyles":"$undefined","loadingScripts":"$undefined","hasLoading":false,"error":"$undefined","errorStyles":"$undefined","errorScripts":"$undefined","template":["$","$Lb",null,{}],"templateStyles":"$undefined","templateScripts":"$undefined","notFound":"$undefined","notFoundStyles":"$undefined","initialChildNode":["$","$La",null,{"parallelRouterKey":"children","segmentPath":["children","blog","children",["slug","2022/04/04/Announcing-Apache-Pinot-0-10","c"],"children"],"loading":"$undefined","loadingStyles":"$undefined","loadingScripts":"$undefined","hasLoading":false,"error":"$undefined","errorStyles":"$undefined","errorScripts":"$undefined","template":["$","$Lb",null,{}],"templateStyles":"$undefined","templateScripts":"$undefined","notFound":"$undefined","notFoundStyles":"$undefined","initialChildNode":["$Ld","$Le",null],"childPropSegment":"__PAGE__?{\"slug\":[\"2022\",\"04\",\"04\",\"Announcing-Apache-Pinot-0-10\"]}","styles":[["$","link","0",{"rel":"stylesheet","href":"/_next/static/css/c130d1629644f070.css","precedence":"next","crossOrigin":""}]]}],"childPropSegment":["slug","2022/04/04/Announcing-Apache-Pinot-0-10","c"],"styles":null}],"childPropSegment":"blog","styles":null}]}],["$","footer",null,{"className":"border-t bg-sky-100 px-5 py-10 md:px-[6.75rem] md:pb-10 md:pt-16","children":[["$","div",null,{"className":"mx-auto flex max-w-7xl flex-wrap justify-between","children":[["$","div",null,{"className":"flex-shrink-0","children":["$","svg",null,{"xmlns":"http://www.w3.org/2000/svg","width":120,"height":48,"fill":"none","children":[["$","g",null,{"fill":"#C7154A","clipPath":"url(#logo_svg__a)","children":[["$","path",null,{"d":"$f"}],["$","path",null,{"d":"M13.5 23a2.5 2.5 0 1 0 0-5 2.5 2.5 0 0 0 0 5M8 5a1 1 0 1 0 0-2 1 1 0 0 0 0 2M12 8a1 1 0 1 0 0-2 1 1 0 0 0 0 2M16 2a1 1 0 1 0 0-2 1 1 0 0 0 0 2"}]]}],["$","defs",null,{"children":["$","clipPath",null,{"id":"logo_svg__a","children":["$","path",null,{"fill":"#fff","d":"M0 0h120v48H0z"}]}]}]]}]}],["$","div",null,{"className":"flex flex-wrap gap-x-16 gap-y-5 py-8 md:pl-24 md:pr-[21.625rem]","children":[" ",[["$","div","Resources",{"children":[["$","h5",null,{"className":"mb-4 text-lg font-semibold","children":"Resources"}],["$","div",null,{"className":"flex justify-between gap-x-10","children":[["$","div",null,{"className":"flex flex-col","children":[["$","a",null,{"target":"_blank","rel":"noopener noreferrer","href":"https://docs.pinot.apache.org/","className":"block py-1 text-gray-600 hover:text-gray-900","children":"Docs"}],["$","a",null,{"target":"_blank","rel":"noopener noreferrer","href":"https://docs.pinot.apache.org/getting-started","className":"block py-1 text-gray-600 hover:text-gray-900","children":"Getting Started"}],["$","a",null,{"target":"_blank","rel":"noopener noreferrer","href":"https://docs.pinot.apache.org/integrations/thirdeye","className":"block py-1 text-gray-600 hover:text-gray-900","children":"ThirdEye"}]]}],["$","div",null,{"className":"flex flex-col","children":[["$","$Lc",null,{"href":"/powered-by","className":"block py-1 text-gray-600 hover:text-gray-900","children":"Company Stories"}],["$","$Lc",null,{"href":"/download","className":"block py-1 text-gray-600 hover:text-gray-900","children":"Download"}],["$","$Lc",null,{"href":"/blog","className":"block py-1 text-gray-600 hover:text-gray-900","children":"Blog"}]]}]]}]]}],["$","div","Apache",{"children":[["$","h5",null,{"className":"mb-4 text-lg font-semibold","children":"Apache"}],["$","div",null,{"className":"flex justify-between gap-x-10","children":[["$","div",null,{"className":"flex flex-col","children":[["$","a",null,{"target":"_blank","rel":"noopener noreferrer","href":"https://www.apache.org","className":"block py-1 text-gray-600 hover:text-gray-900","children":"Foundation"}],["$","a",null,{"target":"_blank","rel":"noopener noreferrer","href":"https://www.apache.org/licenses","className":"block py-1 text-gray-600 hover:text-gray-900","children":"License"}],["$","a",null,{"target":"_blank","rel":"noopener noreferrer","href":"https://www.apache.org/security","className":"block py-1 text-gray-600 hover:text-gray-900","children":"Security"}]]}],["$","div",null,{"className":"flex flex-col","children":[["$","a",null,{"target":"_blank","rel":"noopener noreferrer","href":"https://www.apache.org/foundation/sponsorship.html","className":"block py-1 text-gray-600 hover:text-gray-900","children":"Sponsorship"}],["$","a",null,{"target":"_blank","rel":"noopener noreferrer","href":"https://www.apache.org/events/current-event","className":"block py-1 text-gray-600 hover:text-gray-900","children":"Events"}],["$","a",null,{"target":"_blank","rel":"noopener noreferrer","href":"https://www.apache.org/foundation/thanks.html","className":"block py-1 text-gray-600 hover:text-gray-900","children":"Thanks"}]]}]]}]]}]]]}],["$","div",null,{"className":"mt-4 flex justify-center md:mt-0","children":[["$","a",null,{"target":"_blank","rel":"noopener noreferrer","href":"https://join.slack.com/t/apache-pinot/shared_invite/zt-5z7pav2f-yYtjZdVA~EDmrGkho87Vzw","className":"mr-4","children":["$","svg",null,{"xmlns":"http://www.w3.org/2000/svg","width":24,"height":24,"viewBox":"0 0 24 24","fill":"none","stroke":"currentColor","strokeWidth":2,"strokeLinecap":"round","strokeLinejoin":"round","className":"lucide lucide-slack fill-gray-900","children":[["$","rect","diqz80",{"width":"3","height":"8","x":"13","y":"2","rx":"1.5"}],["$","path","183iwg",{"d":"M19 8.5V10h1.5A1.5 1.5 0 1 0 19 8.5"}],["$","rect","hqg7r1",{"width":"3","height":"8","x":"8","y":"14","rx":"1.5"}],["$","path","76g71w",{"d":"M5 15.5V14H3.5A1.5 1.5 0 1 0 5 15.5"}],["$","rect","1kmz0a",{"width":"8","height":"3","x":"14","y":"13","rx":"1.5"}],["$","path","jc4sz0",{"d":"M15.5 19H14v1.5a1.5 1.5 0 1 0 1.5-1.5"}],["$","rect","1omvl4",{"width":"8","height":"3","x":"2","y":"8","rx":"1.5"}],["$","path","16f3cl",{"d":"M8.5 5H10V3.5A1.5 1.5 0 1 0 8.5 5"}],"$undefined"]}]}],["$","a",null,{"target":"_blank","rel":"noopener noreferrer","href":"https://github.com/apache/pinot","children":["$","svg",null,{"xmlns":"http://www.w3.org/2000/svg","width":24,"height":24,"fill":"currentColor","size":24,"children":[["$","g",null,{"clipPath":"url(#github_svg__a)","children":["$","path",null,{"fillRule":"evenodd","d":"M12.01 0C5.369 0 0 5.5 0 12.304c0 5.44 3.44 10.043 8.212 11.673.597.122.815-.265.815-.59 0-.286-.02-1.264-.02-2.283-3.34.734-4.036-1.466-4.036-1.466-.537-1.426-1.332-1.793-1.332-1.793-1.094-.754.08-.754.08-.754 1.212.082 1.849 1.263 1.849 1.263 1.073 1.874 2.803 1.345 3.5 1.019.098-.795.417-1.345.755-1.65-2.665-.285-5.468-1.345-5.468-6.07 0-1.345.477-2.445 1.232-3.3-.119-.306-.537-1.57.12-3.26 0 0 1.014-.326 3.3 1.263.98-.27 1.989-.407 3.003-.408 1.014 0 2.048.143 3.002.408 2.287-1.59 3.301-1.263 3.301-1.263.657 1.69.239 2.954.12 3.26.775.855 1.232 1.955 1.232 3.3 0 4.725-2.803 5.764-5.488 6.07.438.387.815 1.12.815 2.281 0 1.65-.02 2.975-.02 3.382 0 .326.22.713.816.59C20.56 22.347 24 17.744 24 12.305 24.02 5.5 18.63 0 12.01 0","clipRule":"evenodd"}]}],["$","defs",null,{"children":["$","clipPath",null,{"id":"github_svg__a","children":["$","path",null,{"fill":"#fff","d":"M0 0h24v24H0z"}]}]}]]}]}]]}]]}],["$","div",null,{"className":"mt-8 border-t border-neutral-300 pt-4 text-left text-sm text-gray-600","children":["Copyright © ",2024," The Apache Software Foundation. Apache Pinot, Pinot, Apache, the Apache feather logo, and the Apache Pinot project logo are registered trademarks of The Apache Software Foundation. This page has references to third party software - Presto, PrestoDB, ThirdEye, Trino, TrinoDB, that are not part of the Apache Software Foundation and are not covered under the Apache License."]}]]}]]}]}]]}]}]]}],null] 4:[["$","meta","0",{"name":"viewport","content":"width=device-width, initial-scale=1"}],["$","meta","1",{"charSet":"utf-8"}],["$","title","2",{"children":"Announcing Apache Pinot 0.10 | Apache Pinot™"}],["$","meta","3",{"name":"description","content":"Learn more about the release of Apache Pinot 0.10 and all of new features that have been included in this version of the product."}],["$","meta","4",{"name":"robots","content":"index, follow"}],["$","meta","5",{"name":"googlebot","content":"index, follow, max-video-preview:-1, max-image-preview:large, max-snippet:-1"}],["$","link","6",{"rel":"canonical","href":"https://pinot.apache.org/blog/2022/04/04/Announcing-Apache-Pinot-0-10"}],["$","link","7",{"rel":"alternate","type":"application/rss+xml","href":"https://pinot.apache.org/feed.xml"}],["$","meta","8",{"property":"og:title","content":"Announcing Apache Pinot 0.10"}],["$","meta","9",{"property":"og:description","content":"Learn more about the release of Apache Pinot 0.10 and all of new features that have been included in this version of the product."}],["$","meta","10",{"property":"og:url","content":"https://pinot.apache.org/blog/2022/04/04/Announcing-Apache-Pinot-0-10"}],["$","meta","11",{"property":"og:site_name","content":"Apache Pinot™"}],["$","meta","12",{"property":"og:locale","content":"en_US"}],["$","meta","13",{"property":"og:image","content":"https://pinot.apache.org/static/images/twitter-card.png"}],["$","meta","14",{"property":"og:type","content":"article"}],["$","meta","15",{"property":"article:published_time","content":"2022-04-04T00:00:00.000Z"}],["$","meta","16",{"property":"article:modified_time","content":"2022-04-04T00:00:00.000Z"}],["$","meta","17",{"property":"article:author","content":"Pinot Dev"}],["$","meta","18",{"name":"twitter:card","content":"summary_large_image"}],["$","meta","19",{"name":"twitter:title","content":"Announcing Apache Pinot 0.10"}],["$","meta","20",{"name":"twitter:description","content":"Learn more about the release of Apache Pinot 0.10 and all of new features that have been included in this version of the product."}],["$","meta","21",{"name":"twitter:image","content":"https://pinot.apache.org/static/images/twitter-card.png"}],["$","meta","22",{"name":"next-size-adjust"}]] 10:I[1514,["326","static/chunks/326-3a90a6443b9c824c.js","413","static/chunks/413-f9f40b83f7bb3f22.js","980","static/chunks/980-6e243f9cd384c7d2.js","797","static/chunks/app/blog/%5B...slug%5D/page-502e08b6677b55da.js"],""] 11:I[2529,["326","static/chunks/326-3a90a6443b9c824c.js","413","static/chunks/413-f9f40b83f7bb3f22.js","980","static/chunks/980-6e243f9cd384c7d2.js","797","static/chunks/app/blog/%5B...slug%5D/page-502e08b6677b55da.js"],""] 12:I[413,["326","static/chunks/326-3a90a6443b9c824c.js","413","static/chunks/413-f9f40b83f7bb3f22.js","980","static/chunks/980-6e243f9cd384c7d2.js","797","static/chunks/app/blog/%5B...slug%5D/page-502e08b6677b55da.js"],"Image"] 13:I[5185,["326","static/chunks/326-3a90a6443b9c824c.js","413","static/chunks/413-f9f40b83f7bb3f22.js","980","static/chunks/980-6e243f9cd384c7d2.js","797","static/chunks/app/blog/%5B...slug%5D/page-502e08b6677b55da.js"],""] e:[["$","script",null,{"type":"application/ld+json","dangerouslySetInnerHTML":{"__html":"{\"@context\":\"https://schema.org\",\"@type\":\"BlogPosting\",\"headline\":\"Announcing Apache Pinot 0.10\",\"datePublished\":\"2022-04-04T00:00:00.000Z\",\"dateModified\":\"2022-04-04T00:00:00.000Z\",\"description\":\"Learn more about the release of Apache Pinot 0.10 and all of new features that have been included in this version of the product.\",\"image\":\"/static/images/twitter-card.png\",\"url\":\"https://pinot.apache.org/blog/2022-04-04-Announcing-Apache-Pinot-0-10\",\"author\":[{\"@type\":\"Person\",\"name\":\"Pinot Dev\"}]}"}}],["$","section",null,{"className":" px-5 pt-10 md:px-[13.313rem] md:py-16","children":[["$","$L10",null,{}],["$","article",null,{"className":"","children":["$","div",null,{"className":"mx-auto lg:flex","children":[["$","div",null,{"className":"lg:pr-12","children":[["$","header",null,{"className":"pt-6 md:pr-10","children":[["$","h1",null,{"className":"text-4xl font-semibold","children":"Announcing Apache Pinot 0.10"}],["$","p",null,{"className":"pt-2 text-lg","children":["By: ","Pinot Dev"]}],["$","p",null,{"className":"py-2 text-sm","children":["April 4th, 2022"," • ","5 min read"]}]]}],["$","div",null,{"className":"flex flex-col lg:flex-row","children":["$","main",null,{"className":"","children":["$","div",null,{"className":"prose max-w-[45rem] pb-8 pt-10 dark:prose-invert","children":[["$","p",null,{"children":"We are excited to announce the release this week of Apache Pinot 0.10. Apache Pinot is a real-time distributed datastore designed to answer OLAP queries with high throughput and low latency."}],["$","p",null,{"children":["This release is cut from commit ",["$","a",null,{"target":"_blank","rel":"noopener noreferrer","href":"https://github.com/apache/pinot/commit/fd9c58a11ed16d27109baefcee138eea30132ad3","children":"fd9c58a11ed16d27109baefcee138eea30132ad3"}],". You can find a full list of everything included in the ",["$","a",null,{"target":"_blank","rel":"noopener noreferrer","href":"https://docs.pinot.apache.org/basics/releases/0.10.0","children":"release notes"}],"."]}],["$","p",null,{"children":["Let’s have a look at some of the changes, with the help of the batch ",["$","a",null,{"target":"_blank","rel":"noopener noreferrer","href":"https://docs.pinot.apache.org/basics/getting-started/running-pinot-in-docker","children":"QuickStart configuration"}],"."]}],["$","h2",null,{"id":"query-plans","children":[["$","a",null,{"href":"#query-plans","aria-hidden":"true","tabIndex":"-1","children":["$","span",null,{"className":"icon icon-link"}]}],"Query Plans"]}],["$","p",null,{"children":["Amrish Lal implemented the ",["$","code",null,{"children":"EXPLAIN PLAN"}]," clause, which returns the execution plan that will be chosen by the Pinot Query Engine. This lets us see what the query is likely to do without actually having to run it."]}],["$","$L11",null,{"className":"language-sql","children":["$","code",null,{"className":"language-sql code-highlight","children":[["$","span",null,{"className":"code-line","children":[["$","span",null,{"className":"token keyword","children":"EXPLAIN"}]," ",["$","span",null,{"className":"token keyword","children":"PLAN"}]," ",["$","span",null,{"className":"token keyword","children":"FOR"}],"\n"]}],["$","span",null,{"className":"code-line","children":[["$","span",null,{"className":"token keyword","children":"SELECT"}]," ",["$","span",null,{"className":"token operator","children":"*"}],"\n"]}],["$","span",null,{"className":"code-line","children":[["$","span",null,{"className":"token keyword","children":"FROM"}]," baseballStats\n"]}],["$","span",null,{"className":"code-line","children":[["$","span",null,{"className":"token keyword","children":"WHERE"}]," league ",["$","span",null,{"className":"token operator","children":"="}]," ",["$","span",null,{"className":"token string","children":"'NL'"}],"\n"]}]]}]}],["$","p",null,{"children":"If we run this query, we'll see the following results:"}],["$","div",null,{"className":"w-full overflow-x-auto","children":["$","table",null,{"children":[["$","thead",null,{"children":["$","tr",null,{"children":[["$","th",null,{"children":"Operator"}],["$","th",null,{"children":"Operator_Id"}],["$","th",null,{"children":"Parent_Id"}]]}]}],["$","tbody",null,{"children":[["$","tr",null,{"children":[["$","td",null,{"children":"BROKER_REDUCE(limit:10)"}],["$","td",null,{"children":"0"}],["$","td",null,{"children":"-1"}]]}],["$","tr",null,{"children":[["$","td",null,{"children":"COMBINE_SELECT"}],["$","td",null,{"children":"1"}],["$","td",null,{"children":"0"}]]}],["$","tr",null,{"children":[["$","td",null,{"children":"SELECT(selectList:AtBatting, G_old, baseOnBalls, caughtStealing, doules, groundedIntoDoublePlays, hits, hitsByPitch, homeRuns, intentionalWalks, league, numberOfGames, numberOfGamesAsBatter, playerID, playerName, playerStint, runs, runsBattedIn, sacrificeFlies, sacrificeHits, stolenBases, strikeouts, teamID, tripples, yearID)"}],["$","td",null,{"children":"2"}],["$","td",null,{"children":"1"}]]}],["$","tr",null,{"children":[["$","td",null,{"children":"TRANSFORM_PASSTHROUGH(AtBatting, G_old, baseOnBalls, caughtStealing, doules, groundedIntoDoublePlays, hits, hitsByPitch, homeRuns, intentionalWalks, league, numberOfGames, numberOfGamesAsBatter, playerID, playerName, playerStint, runs, runsBattedIn, sacrificeFlies, sacrificeHits, stolenBases, strikeouts, teamID, tripples, yearID)"}],["$","td",null,{"children":"3"}],["$","td",null,{"children":"2"}]]}],["$","tr",null,{"children":[["$","td",null,{"children":"PROJECT(homeRuns, playerStint, groundedIntoDoublePlays, numberOfGames, AtBatting, stolenBases, tripples, hitsByPitch, teamID, numberOfGamesAsBatter, strikeouts, sacrificeFlies, caughtStealing, baseOnBalls, playerName, doules, league, yearID, hits, runsBattedIn, G_old, sacrificeHits, intentionalWalks, runs, playerID)"}],["$","td",null,{"children":"4"}],["$","td",null,{"children":"3"}]]}],["$","tr",null,{"children":[["$","td",null,{"children":"FILTER_FULL_SCAN(operator:EQ,predicate:league = 'NL')"}],["$","td",null,{"children":"5"}],["$","td",null,{"children":"4"}]]}]]}]]}]}],["$","h2",null,{"id":"filter-clauses-for-aggregates","children":[["$","a",null,{"href":"#filter-clauses-for-aggregates","aria-hidden":"true","tabIndex":"-1","children":["$","span",null,{"className":"icon icon-link"}]}],"FILTER Clauses for Aggregates"]}],["$","p",null,{"children":"Atri Sharma added the filter clause for aggregates. This feature makes it possible to write queries like this:"}],["$","$L11",null,{"className":"language-sql","children":["$","code",null,{"className":"language-sql code-highlight","children":[["$","span",null,{"className":"code-line","children":[["$","span",null,{"className":"token keyword","children":"SELECT"}]," ",["$","span",null,{"className":"token function","children":"SUM"}],["$","span",null,{"className":"token punctuation","children":"("}],"homeRuns",["$","span",null,{"className":"token punctuation","children":")"}]," FILTER",["$","span",null,{"className":"token punctuation","children":"("}],["$","span",null,{"className":"token keyword","children":"WHERE"}]," league ",["$","span",null,{"className":"token operator","children":"="}]," ",["$","span",null,{"className":"token string","children":"'NL'"}],["$","span",null,{"className":"token punctuation","children":")"}]," ",["$","span",null,{"className":"token keyword","children":"AS"}]," nlHomeRuns",["$","span",null,{"className":"token punctuation","children":","}],"\n"]}],["$","span",null,{"className":"code-line","children":[" ",["$","span",null,{"className":"token function","children":"SUM"}],["$","span",null,{"className":"token punctuation","children":"("}],"homeRuns",["$","span",null,{"className":"token punctuation","children":")"}]," FILTER",["$","span",null,{"className":"token punctuation","children":"("}],["$","span",null,{"className":"token keyword","children":"WHERE"}]," league ",["$","span",null,{"className":"token operator","children":"="}]," ",["$","span",null,{"className":"token string","children":"'AL'"}],["$","span",null,{"className":"token punctuation","children":")"}]," ",["$","span",null,{"className":"token keyword","children":"AS"}]," alHomeRuns\n"]}],["$","span",null,{"className":"code-line","children":[["$","span",null,{"className":"token keyword","children":"FROM"}]," baseballStats\n"]}]]}]}],["$","p",null,{"children":"If we run this query, we'll see the following output:"}],["$","div",null,{"className":"w-full overflow-x-auto","children":["$","table",null,{"children":[["$","thead",null,{"children":["$","tr",null,{"children":[["$","th",null,{"children":"nlHomeRuns"}],["$","th",null,{"children":"alHomeRuns"}]]}]}],["$","tbody",null,{"children":["$","tr",null,{"children":[["$","td",null,{"children":"135486"}],["$","td",null,{"children":"135990"}]]}]}]]}]}],["$","h2",null,{"id":"greatest-and-least","children":[["$","a",null,{"href":"#greatest-and-least","aria-hidden":"true","tabIndex":"-1","children":["$","span",null,{"className":"icon icon-link"}]}],"greatest and least"]}],["$","p",null,{"children":["Richard Startin added the ",["$","code",null,{"children":"greatest"}]," and ",["$","code",null,{"children":"least"}]," functions:"]}],["$","$L11",null,{"className":"language-sql","children":["$","code",null,{"className":"language-sql code-highlight","children":[["$","span",null,{"className":"code-line","children":[["$","span",null,{"className":"token keyword","children":"SELECT"}]," playerID",["$","span",null,{"className":"token punctuation","children":","}],"\n"]}],["$","span",null,{"className":"code-line","children":[" least",["$","span",null,{"className":"token punctuation","children":"("}],["$","span",null,{"className":"token number","children":"5.0"}],["$","span",null,{"className":"token punctuation","children":","}]," ",["$","span",null,{"className":"token function","children":"max"}],["$","span",null,{"className":"token punctuation","children":"("}],"homeRuns",["$","span",null,{"className":"token punctuation","children":")"}],["$","span",null,{"className":"token punctuation","children":")"}]," ",["$","span",null,{"className":"token keyword","children":"AS"}]," homeRuns",["$","span",null,{"className":"token punctuation","children":","}],"\n"]}],["$","span",null,{"className":"code-line","children":["\t greatest",["$","span",null,{"className":"token punctuation","children":"("}],["$","span",null,{"className":"token number","children":"5.0"}],["$","span",null,{"className":"token punctuation","children":","}]," ",["$","span",null,{"className":"token function","children":"max"}],["$","span",null,{"className":"token punctuation","children":"("}],"hits",["$","span",null,{"className":"token punctuation","children":")"}],["$","span",null,{"className":"token punctuation","children":")"}]," ",["$","span",null,{"className":"token keyword","children":"AS"}]," hits\n"]}],["$","span",null,{"className":"code-line","children":[["$","span",null,{"className":"token keyword","children":"FROM"}]," baseballStats\n"]}],["$","span",null,{"className":"code-line","children":[["$","span",null,{"className":"token keyword","children":"WHERE"}]," league ",["$","span",null,{"className":"token operator","children":"="}]," ",["$","span",null,{"className":"token string","children":"'NL'"}]," ",["$","span",null,{"className":"token operator","children":"AND"}]," teamID ",["$","span",null,{"className":"token operator","children":"="}]," ",["$","span",null,{"className":"token string","children":"'SFN'"}],"\n"]}],["$","span",null,{"className":"code-line","children":[["$","span",null,{"className":"token keyword","children":"GROUP"}]," ",["$","span",null,{"className":"token keyword","children":"BY"}]," playerID\n"]}],["$","span",null,{"className":"code-line","children":[["$","span",null,{"className":"token keyword","children":"LIMIT"}]," ",["$","span",null,{"className":"token number","children":"5"}],"\n"]}]]}]}],["$","p",null,{"children":"If we run this query, we'll see the following output:"}],["$","div",null,{"className":"w-full overflow-x-auto","children":["$","table",null,{"children":[["$","thead",null,{"children":["$","tr",null,{"children":[["$","th",null,{"children":"playerID"}],["$","th",null,{"children":"homeRuns"}],["$","th",null,{"children":"hits"}]]}]}],["$","tbody",null,{"children":[["$","tr",null,{"children":[["$","td",null,{"children":"ramirju01"}],["$","td",null,{"children":"0"}],["$","td",null,{"children":"5"}]]}],["$","tr",null,{"children":[["$","td",null,{"children":"milneed01"}],["$","td",null,{"children":"4"}],["$","td",null,{"children":"54"}]]}],["$","tr",null,{"children":[["$","td",null,{"children":"testani01"}],["$","td",null,{"children":"0"}],["$","td",null,{"children":"5"}]]}],["$","tr",null,{"children":[["$","td",null,{"children":"shawbo01"}],["$","td",null,{"children":"0"}],["$","td",null,{"children":"8"}]]}],["$","tr",null,{"children":[["$","td",null,{"children":"vogelry01"}],["$","td",null,{"children":"0"}],["$","td",null,{"children":"12"}]]}]]}]]}]}],["$","h2",null,{"id":"distinctcountsmarthll","children":[["$","a",null,{"href":"#distinctcountsmarthll","aria-hidden":"true","tabIndex":"-1","children":["$","span",null,{"className":"icon icon-link"}]}],"DistinctCountSmartHLL"]}],["$","p",null,{"children":["Xiaotian (Jackie) Jiang added the ",["$","code",null,{"children":"DistinctCountSmartHLL"}]," aggregation function, which automatically converts the Set to HyperLogLog if the set size grows too big to protect the servers from running out of memory:"]}],["$","$L11",null,{"className":"language-sql","children":["$","code",null,{"className":"language-sql code-highlight","children":[["$","span",null,{"className":"code-line","children":[["$","span",null,{"className":"token keyword","children":"SELECT"}]," DISTINCTCOUNTSMARTHLL",["$","span",null,{"className":"token punctuation","children":"("}],"homeRuns",["$","span",null,{"className":"token punctuation","children":","}]," ",["$","span",null,{"className":"token string","children":"'hllLog2m=8;hllConversionThreshold=10'"}],["$","span",null,{"className":"token punctuation","children":")"}],"\n"]}],["$","span",null,{"className":"code-line","children":[["$","span",null,{"className":"token keyword","children":"FROM"}]," baseballStats\n"]}]]}]}],["$","p",null,{"children":"If we run this query, we'll see the following output:"}],["$","div",null,{"className":"w-full overflow-x-auto","children":["$","table",null,{"children":[["$","thead",null,{"children":["$","tr",null,{"children":["$","th",null,{"children":"distinctcountsmarthll(homeRuns)"}]}]}],["$","tbody",null,{"children":["$","tr",null,{"children":["$","td",null,{"children":"66"}]}]}]]}]}],["$","h2",null,{"id":"ui-updates","children":[["$","a",null,{"href":"#ui-updates","aria-hidden":"true","tabIndex":"-1","children":["$","span",null,{"className":"icon icon-link"}]}],"UI updates"]}],["$","p",null,{"children":"There were also a bunch of updates to the Pinot Data Explorer, by Sanket Shah and Johan Adami."}],["$","p",null,{"children":"The display of reported size and estimated size is now in a human readable format:"}],["$","div",null,{"children":["$","$L12",null,{"alt":"Human readable sizes","src":"/static/images/blogs/announcing-apache-pinot-0-10/human-readable-sizes.png","width":"1055","height":"115"}]}],["$","p",null,{"children":"Fixes for the following issues:"}],["$","ul",null,{"children":["$","li",null,{"children":"Error messages weren't showing on the UI when an invalid operation is attempted:"}]}],["$","div",null,{"children":["$","$L12",null,{"alt":"A backwards incompatible attempted schema change","src":"/static/images/blogs/announcing-apache-pinot-0-10/backwards-incompatible.png","width":"615","height":"87"}]}],["$","ul",null,{"children":[["$","li",null,{"children":"Query console goes blank on syntax error."}],["$","li",null,{"children":"Query console cannot show query result when multiple columns have the same name."}],["$","li",null,{"children":["Adding extra fields after ",["$","code",null,{"children":"SELECT *"}]," would throw a NullPointerException."]}],["$","li",null,{"children":["Some queries were returning ",["$","code",null,{"children":"--"}]," instead of ",["$","code",null,{"children":"0"}],"."]}],["$","li",null,{"children":"Query console couldn't show the query result if multiple columns had the same name."}],["$","li",null,{"children":"Pinot Dashboard tenant view showing the incorrect amount of servers and brokers."}]]}],["$","h2",null,{"id":"realtimetooffline-task","children":[["$","a",null,{"href":"#realtimetooffline-task","aria-hidden":"true","tabIndex":"-1","children":["$","span",null,{"className":"icon icon-link"}]}],"RealTimeToOffline Task"]}],["$","p",null,{"children":["Xiaotian (Jackie) Jiang made some fixes to the ",["$","a",null,{"target":"_blank","rel":"noopener noreferrer","href":"https://dev.startree.ai/docs/pinot/recipes/real-time-offline-job","children":"RealTimeToOffline job"}]," to handle time gaps and proceed to the next time window when no segment matches the current one."]}],["$","h2",null,{"id":"empty-quickstart","children":[["$","a",null,{"href":"#empty-quickstart","aria-hidden":"true","tabIndex":"-1","children":["$","span",null,{"className":"icon icon-link"}]}],"Empty QuickStart"]}],["$","p",null,{"children":"bastani added an empty QuickStart command, which lets you quickly spin up an empty Pinot cluster:"}],["$","$L11",null,{"className":"language-bash","children":["$","code",null,{"className":"code-highlight language-bash","children":[["$","span",null,{"className":"code-line","children":[["$","span",null,{"className":"token function","children":"docker"}]," run ",["$","span",null,{"className":"token punctuation","children":"\\"}],"\n"]}],["$","span",null,{"className":"code-line","children":[" ",["$","span",null,{"className":"token parameter variable","children":"-p"}]," ",["$","span",null,{"className":"token number","children":"8000"}],":8000 ",["$","span",null,{"className":"token punctuation","children":"\\"}],"\n"]}],["$","span",null,{"className":"code-line","children":[" ",["$","span",null,{"className":"token parameter variable","children":"-p"}]," ",["$","span",null,{"className":"token number","children":"9000"}],":9000 ",["$","span",null,{"className":"token punctuation","children":"\\"}],"\n"]}],["$","span",null,{"className":"code-line","children":[" apachepinot/pinot:0.10.0 QuickStart ",["$","span",null,{"className":"token punctuation","children":"\\"}],"\n"]}],["$","span",null,{"className":"code-line","children":[" ",["$","span",null,{"className":"token parameter variable","children":"-type"}]," empty\n"]}]]}]}],["$","p",null,{"children":"You can then ingest your own dataset without needing to worry about spinning up each of the Pinot components individually."}],["$","h2",null,{"id":"data-ingestion","children":[["$","a",null,{"href":"#data-ingestion","aria-hidden":"true","tabIndex":"-1","children":["$","span",null,{"className":"icon icon-link"}]}],"Data Ingestion"]}],["$","ul",null,{"children":[["$","li",null,{"children":["$","p",null,{"children":"Richard Startin fixed some issues with real-time ingestion where consumption of messages would stop if a bad batch of messages was consumed from Kafka."}]}],["$","li",null,{"children":["$","p",null,{"children":"Mohemmad Zaid Khan added the BoundedColumnValue partition function, which partitions segments based on column values."}]}],["$","li",null,{"children":["$","p",null,{"children":"Xiaobing Li added the fixed name segment generator, which can be used when you want to replace a specific existing segment."}]}]]}],["$","h2",null,{"id":"other-changes","children":[["$","a",null,{"href":"#other-changes","aria-hidden":"true","tabIndex":"-1","children":["$","span",null,{"className":"icon icon-link"}]}],"Other changes"]}],["$","ul",null,{"children":[["$","li",null,{"children":"Richard Startin set LZ4 compression as the default for all metrics fields."}],["$","li",null,{"children":["Mark Needham added the ",["$","code",null,{"children":"ST_Within"}]," geospatial function."]}],["$","li",null,{"children":"Rong Rong fixed a bug where query stats wouldn't show if there was an error processing the query (e.g. if the query timed out)."}],["$","li",null,{"children":["Prashant Pandey fixed the query engine to handle extra columns added to a ",["$","code",null,{"children":"SELECT *"}]," statement."]}],["$","li",null,{"children":"Richard Startin added support for forward indexes on JSON columns."}],["$","li",null,{"children":"Rong Rong added the GRPC broker request handler so that data can be streamed back from the server to the broker when processing queries."}],["$","li",null,{"children":["deemoliu made it possible to add a default strategy when using the ",["$","a",null,{"target":"_blank","rel":"noopener noreferrer","href":"https://dev.startree.ai/docs/pinot/recipes/upserts-partial","children":"partial upsert feature"}],"."]}],["$","li",null,{"children":["Jeff Moszuti added support for the ",["$","code",null,{"children":"TIMESTAMP"}]," data type in the ",["$","a",null,{"target":"_blank","rel":"noopener noreferrer","href":"https://docs.pinot.apache.org/operators/configuration-recommendation-engine","children":"configuration recommendation engine"}],"."]}]]}],["$","h2",null,{"id":"dependency-updates","children":[["$","a",null,{"href":"#dependency-updates","aria-hidden":"true","tabIndex":"-1","children":["$","span",null,{"className":"icon icon-link"}]}],"Dependency updates"]}],["$","p",null,{"children":"The following dependencies were updated:"}],["$","ul",null,{"children":[["$","li",null,{"children":"async-http-client because the library moved to a different organization."}],["$","li",null,{"children":"RoaringBitmap to 0.9.25"}],["$","li",null,{"children":"JsonPath to 2.7.0"}],["$","li",null,{"children":"Kafka to 2.8.1"}],["$","li",null,{"children":"Prometheus to 0.16.1"}]]}],["$","h2",null,{"id":"resources","children":[["$","a",null,{"href":"#resources","aria-hidden":"true","tabIndex":"-1","children":["$","span",null,{"className":"icon icon-link"}]}],"Resources"]}],["$","p",null,{"children":"If you want to try out Apache Pinot, the following resources will help you get started:"}],["$","ul",null,{"children":[["$","li",null,{"children":["Download page: ",["$","a",null,{"target":"_blank","rel":"noopener noreferrer","href":"https://pinot.apache.org/download/","children":"https://pinot.apache.org/download/"}]]}],["$","li",null,{"children":["Getting started: ",["$","a",null,{"target":"_blank","rel":"noopener noreferrer","href":"https://docs.pinot.apache.org/getting-started","children":"https://docs.pinot.apache.org/getting-started"}]]}],["$","li",null,{"children":["Apache Pinot Recipes: ",["$","a",null,{"target":"_blank","rel":"noopener noreferrer","href":"https://dev.startree.ai/docs/pinot/recipes/","children":"https://dev.startree.ai/docs/pinot/recipes/"}]]}],["$","li",null,{"children":["Join our Slack channel: ",["$","a",null,{"target":"_blank","rel":"noopener noreferrer","href":"https://communityinviter.com/apps/apache-pinot/apache-pinot","children":"https://communityinviter.com/apps/apache-pinot/apache-pinot"}]]}],["$","li",null,{"children":["See our upcoming events: ",["$","a",null,{"target":"_blank","rel":"noopener noreferrer","href":"https://www.meetup.com/apache-pinot","children":"https://www.meetup.com/apache-pinot"}]]}],["$","li",null,{"children":["Follow us on Twitter: ",["$","a",null,{"target":"_blank","rel":"noopener noreferrer","href":"https://twitter.com/startreedata","children":"https://twitter.com/startreedata"}]]}],["$","li",null,{"children":["Subscribe to our YouTube channel: ",["$","a",null,{"target":"_blank","rel":"noopener noreferrer","href":"https://www.youtube.com/c/StarTree","children":"https://www.youtube.com/c/StarTree"}]]}]]}]]}]}]}]]}],["$","aside",null,{"className":"mt-10 hidden border-l-2 pl-5 lg:sticky lg:top-1 lg:block lg:h-full","children":["$","section",null,{"className":"sticky top-0 mb-4 w-[15.375rem]","children":[["$","div",null,{"className":"flex flex-col space-y-1.5 pb-3","children":["$","h3",null,{"className":"text-sm font-semibold leading-snug text-neutral-500 dark:text-neutral-100","children":"Table of Contents"}]}],["$","$L13",null,{"chapters":[{"value":"Query Plans","url":"#query-plans","depth":2},{"value":"FILTER Clauses for Aggregates","url":"#filter-clauses-for-aggregates","depth":2},{"value":"greatest and least","url":"#greatest-and-least","depth":2},{"value":"DistinctCountSmartHLL","url":"#distinctcountsmarthll","depth":2},{"value":"UI updates","url":"#ui-updates","depth":2},{"value":"RealTimeToOffline Task","url":"#realtimetooffline-task","depth":2},{"value":"Empty QuickStart","url":"#empty-quickstart","depth":2},{"value":"Data Ingestion","url":"#data-ingestion","depth":2},{"value":"Other changes","url":"#other-changes","depth":2},{"value":"Dependency updates","url":"#dependency-updates","depth":2},{"value":"Resources","url":"#resources","depth":2}]}]]}]}]]}]}]]}]] d:null