<?xml version="1.0" encoding="utf-8"?><rss version="2.0" xmlns:dc="http://purl.org/dc/elements/1.1/"><channel><language>en</language><title>Blog posts by Kunal Shetye</title> <link>https://world.optimizely.com/blogs/kunal-shetye/</link><description></description><ttl>60</ttl><generator>Optimizely World</generator><item> <title>Authentication Modes in Optimizely Graph</title>            <link>https://kunalshetye.com/posts/optimizely-graph-using-appkey-appsecret/</link>            <description>Fetching Content with Optimizely Graph There&amp;rsquo;s two common modes of authentication when trying to fetch data with Optimizely Graph:
 Single Key - This mode of authentication is used to fetch latest Published version of the content Authorization with AppKey/AppSecret - This mode of authentication is used to fetch data you get from Single Key plus Previous Versions and Draft Versions of the content     Content Type Single Key Authorization with AppKey/AppSecret     Latest Published Content ✅ ✅   Previous Versions ❌ ✅   Draft Content ❌ ✅    What mode does the embedded GraphiQL use?</description>            <guid>https://kunalshetye.com/posts/optimizely-graph-using-appkey-appsecret/</guid>            <pubDate>Fri, 20 Oct 2023 11:59:47 GMT</pubDate>           <category>Blog post</category></item><item> <title>Content Sources in Optimizely Graph</title>            <link>https://kunalshetye.com/posts/content-sources-in-optimizely-graph/</link>            <description>Content Sources in Optimizely Graph? Optimizely Graph offers endpoints that enable customers to seamlessly integrate custom content types from external sources such as CMS and Product Catalogs into the Optimizely Graph. Once this data is defined and indexed, it gains access to the full suite of Optimizely Graph capabilities, including Full Text Search, Faceted Search, and Semantic Search.
How do I define a content type? This is done by creating a schema definition as shown in the example below and leveraging the Sync API for Content Types  endpoint</description>            <guid>https://kunalshetye.com/posts/content-sources-in-optimizely-graph/</guid>            <pubDate>Mon, 16 Oct 2023 13:25:47 GMT</pubDate>           <category>Blog post</category></item><item> <title>Content Graph - Letting GraphQL do all the hard work for you</title>            <link>https://kunalshetye.com/posts/content-graph-letting-graphql-do-all-the-hard-work-for-you/</link>            <description>Background As we have seen before, setting up Content Graph on the CMS side is pretty easy. However, when it comes to the &amp;ldquo;head&amp;rdquo; part of the setup, things can get a bit tricky at times. There&amp;rsquo;s a lot of ways to achieve the same results on the frontend side of things.
Note: I&amp;rsquo;m using next.js and yarn for my frontend setup. Also I&amp;rsquo;m assuming that you have a content-graph endpoint that you can query without which none of the following would be possible</description>            <guid>https://kunalshetye.com/posts/content-graph-letting-graphql-do-all-the-hard-work-for-you/</guid>            <pubDate>Fri, 26 May 2023 10:18:47 GMT</pubDate>           <category>Blog post</category></item><item> <title>DXP and Github Workflows</title>            <link>https://kunalshetye.com/posts/dxp-and-github-workflows/</link>            <description>Prerequisistes  Access to a DXP Environment Access to Github Basic Understanding of CI/CD pipelines and YAML An existing CMS12 website connected to DXP  Generate API Keys I&amp;rsquo;ve generated a seperate API Key for usage from Github which only has access to my integration environment because I want to deploy to production by hand and avoid &amp;ldquo;accidental&amp;rdquo; releases to production. You could however choose to let github deloy the site to the production environment if you like.</description>            <guid>https://kunalshetye.com/posts/dxp-and-github-workflows/</guid>            <pubDate>Wed, 22 Jun 2022 13:47:23 GMT</pubDate>           <category>Blog post</category></item><item> <title>Adding A/B Testing to CMS12</title>            <link>https://kunalshetye.com/posts/add-a-b-testing-to-cms12/</link>            <description>I recently saw that Optimizely released A/B Testing Package (EPiServer.Marketing.Testing) for dotnet core, meaning you can now install the A/B Testing Addon on CMS12
Install For .NET 5 use dotnet add package EPiServer.Marketing.Testing -v 3.0.0 For .NET 6 use dotnet add package EPiServer.Marketing.Testing -v 3.1.0 Configure But if you try running the site after the install, you might notice an error similar to this:
info: EPiServer.Framework.Initialization.InitializationEngine[0] Initialization started fail: EPiServer.Framework.Initialization.InitializationEngine[0] Initialize action failed for &amp;#39;Initialize on class EPiServer.</description>            <guid>https://kunalshetye.com/posts/add-a-b-testing-to-cms12/</guid>            <pubDate>Fri, 20 May 2022 12:50:47 GMT</pubDate>           <category>Blog post</category></item><item> <title>Customizing VisitorGroup Behavior in Optimizely CMS</title>            <link>https://kunalshetye.com/posts/customizing-visitorgroup-behavior-in-optimizely-cms/</link>            <description>VisitorGroups One way you can personalize a digital experience in Optimizely is to create a visitor group with criteria for that group. For example, you can design a product banner specifically for first-time visitors, or for visitors from a geographic region or market.
If you have multiple visitor groups, a visitor may match more than one visitor group. You then can use personalization groups to group content to avoid displaying the same content twice, and display fallback content to visitors who match no visitor groups.</description>            <guid>https://kunalshetye.com/posts/customizing-visitorgroup-behavior-in-optimizely-cms/</guid>            <pubDate>Thu, 12 May 2022 16:11:23 GMT</pubDate>           <category>Blog post</category></item></channel>
</rss>