Close Menu
    DevStackTipsDevStackTips
    • Home
    • News & Updates
      1. Tech & Work
      2. View All

      CodeSOD: A Unique Way to Primary Key

      July 22, 2025

      BrowserStack launches Figma plugin for detecting accessibility issues in design phase

      July 22, 2025

      Parasoft brings agentic AI to service virtualization in latest release

      July 22, 2025

      Node.js vs. Python for Backend: 7 Reasons C-Level Leaders Choose Node.js Talent

      July 21, 2025

      The best CRM software with email marketing in 2025: Expert tested and reviewed

      July 22, 2025

      This multi-port car charger can power 4 gadgets at once – and it’s surprisingly cheap

      July 22, 2025

      I’m a wearables editor and here are the 7 Pixel Watch 4 rumors I’m most curious about

      July 22, 2025

      8 ways I quickly leveled up my Linux skills – and you can too

      July 22, 2025
    • Development
      1. Algorithms & Data Structures
      2. Artificial Intelligence
      3. Back-End Development
      4. Databases
      5. Front-End Development
      6. Libraries & Frameworks
      7. Machine Learning
      8. Security
      9. Software Engineering
      10. Tools & IDEs
      11. Web Design
      12. Web Development
      13. Web Security
      14. Programming Languages
        • PHP
        • JavaScript
      Featured

      The Intersection of Agile and Accessibility – A Series on Designing for Everyone

      July 22, 2025
      Recent

      The Intersection of Agile and Accessibility – A Series on Designing for Everyone

      July 22, 2025

      Zero Trust & Cybersecurity Mesh: Your Org’s Survival Guide

      July 22, 2025

      Execute Ping Commands and Get Back Structured Data in PHP

      July 22, 2025
    • Operating Systems
      1. Windows
      2. Linux
      3. macOS
      Featured

      A Tomb Raider composer has been jailed — His legacy overshadowed by $75k+ in loan fraud

      July 22, 2025
      Recent

      A Tomb Raider composer has been jailed — His legacy overshadowed by $75k+ in loan fraud

      July 22, 2025

      “I don’t think I changed his mind” — NVIDIA CEO comments on H20 AI GPU sales resuming in China following a meeting with President Trump

      July 22, 2025

      Galaxy Z Fold 7 review: Six years later — Samsung finally cracks the foldable code

      July 22, 2025
    • Learning Resources
      • Books
      • Cheatsheets
      • Tutorials & Guides
    Home»Development»Natural Language Q&A in Optimizely CMS Using Azure OpenAI and AI Search

    Natural Language Q&A in Optimizely CMS Using Azure OpenAI and AI Search

    April 25, 2025

    In Part 2, we integrated Azure AI Search with Azure Personalizer to build a smarter, user-focused experience in Optimizely CMS. We used ServiceAPI to send CMS content to Azure AI Search. In Part 3, we’ll take things a step further: enabling users to ask natural language questions and get AI-powered answers. But here’s the twist: instead of using ServiceAPI, this time we’ll explore how to query indexed content directly using Azure AI Search’s REST API.

    Why Natural Language Q&A?

    Sometimes users don’t know the exact keywords. They ask things like:

    “How do I return a product?” “Can I book a demo?”

    With OpenAI on Azure and the semantic capabilities of Azure AI Search, your website can now understand those queries and provide helpful, contextual responses.

    Architecture Overview

    1. CMS content is indexed by Azure AI Search (via ServiceAPI or crawler).
    2. The search index is enriched with semantic settings.
    3. A user types a natural language query.
    4. Your backend uses Azure Search’s Semantic Search + Azure OpenAI (chat/completion API) to return a contextual answer.

    Using Azure Search API to Extract Content

    You can directly access indexed content using the Azure Search REST API. Here’s an example of how to fetch top 5 results:

    public async Task<List<string>> SearchAzureContentAsync(string query)
    {
        var searchServiceName = "<your-search-service-name>";
        var indexName = "<your-index-name>";
        var apiKey = "<your-api-key>";
    
        using var client = new HttpClient();
        client.DefaultRequestHeaders.Add("api-key", apiKey);
    
        var url = $"https://{searchServiceName}.search.windows.net/indexes/{indexName}/docs?api-version=2021-04-30-Preview&search={query}&$top=5";
        var result = await client.GetStringAsync(url);
        
        var json = JsonDocument.Parse(result);
        var docs = new List<string>();
    
        foreach (var item in json.RootElement.GetProperty("value").EnumerateArray())
        {
            docs.Add(item.GetProperty("content").GetString());
        }
    
        return docs;
    }

    Generate Answer Using Azure OpenAI

    Once we retrieve relevant documents, we’ll pass them into Azure OpenAI to generate a contextual answer:

    public async Task<string> AskOpenAiAsync(string question, List<string> context)
    {
        var prompt = $"""
    You are a helpful assistant. Based on the following content, answer the question:
    
    {string.Join("nn", context)}
    
    Question: {question}
    Answer:
    """;
    
        var openAiKey = "<your-openai-key>";
        var endpoint = "https://<your-openai-endpoint>.openai.azure.com/openai/deployments/<deployment-name>/completions?api-version=2022-12-01";
    
        var payload = new
        {
            prompt = prompt,
            temperature = 0.7,
            max_tokens = 200
        };
    
        using var client = new HttpClient();
        client.DefaultRequestHeaders.Add("api-key", openAiKey);
        var response = await client.PostAsync(endpoint, new StringContent(JsonSerializer.Serialize(payload), Encoding.UTF8, "application/json"));
    
        var result = JsonDocument.Parse(await response.Content.ReadAsStringAsync());
        return result.RootElement.GetProperty("choices")[0].GetProperty("text").GetString();
    }

    Integrate with Optimizely CMS

    You can create a controller like this:

    public class QnAController : Controller
    {
        [HttpPost]
        public async Task<ActionResult> Ask(string question)
        {
            var docs = await SearchAzureContentAsync(question);
            var answer = await AskOpenAiAsync(question, docs);
            return Json(new { answer });
        }
    }

    And on your view:

    <form method="post" id="qnaForm">
      <input type="text" name="question" placeholder="Ask a question..." />
      <button type="submit">Ask</button>
    </form>
    <div id="answer"></div>
    
    <script>
      $('#qnaForm').submit(function(e) {
        e.preventDefault();
        const question = $('input[name=question]').val();
        fetch('/QnA/Ask', {
          method: 'POST',
          headers: {'Content-Type': 'application/json'},
          body: JSON.stringify({ question })
        })
        .then(r => r.json())
        .then(data => $('#answer').text(data.answer));
      });
    </script>

    Summary

    This wraps up the final puzzle piece: letting users speak freely with your Optimizely site, while AI interprets and responds in real-time. From content indexing to re-ranking to full-on Q&A, your CMS is now intelligent, conversational, and user-first. Want to see this in action? Stay tuned for the sample repo and video walkthrough!

    The blog is also published here Natural Language Q&A in Optimizely CMS Using Azure OpenAI and AI Search

    Source: Read More 

    Facebook Twitter Reddit Email Copy Link
    Previous ArticleHow to use chatgpt4o to redesign your website
    Next Article Perficient Included in IDC Market Glance: Healthcare Provider Operational IT Solutions, 1Q25

    Related Posts

    Development

    GPT-5 is Coming: Revolutionizing Software Testing

    July 22, 2025
    Development

    Win the Accessibility Game: Combining AI with Human Judgment

    July 22, 2025
    Leave A Reply Cancel Reply

    For security, use of Google's reCAPTCHA service is required which is subject to the Google Privacy Policy and Terms of Use.

    Continue Reading

    Star Wars Battlefront 2 player counts are blowing up Steam charts again — It’s thanks to a deal so good it must be from a galaxy far, far away

    News & Updates

    HNS-2025-10 – HN Security Advisory – Local privilege escalation in Zyxel uOS

    Security

    Mastering Modern Monorepo Development with pnpm, Workspaces

    Web Development

    lsr – recursively list files in directories

    Linux

    Highlights

    I Love Lasagna and Latinas Shirt

    April 23, 2025

    Post Content Source: Read More 

    I replaced my Pixel 9 Pro with this $700 Android phone, and didn’t mind that it’s for gamers

    June 3, 2025

    Best early Prime Day Amazon Echo device deals: My 17 favorite deals available now

    July 1, 2025

    Regolith – A JavaScript library immune to ReDoS attacks

    July 11, 2025
    © DevStackTips 2025. All rights reserved.
    • Contact
    • Privacy Policy

    Type above and press Enter to search. Press Esc to cancel.