From 105562ff6c51c39beac62057d91e7da043d1e288 Mon Sep 17 00:00:00 2001 From: GitHub Action Date: Wed, 30 Aug 2023 08:35:17 +0000 Subject: [PATCH] deploy: dce949219bfe30c111b744fa49acfe30857aaaca --- CNAME | 2 +- feed.xml | 2 +- meta/2023/all.json | 2 +- meta/2023/pages.json | 2 +- meta/all.json | 2 +- posts/cloud-value-between-architectures.html | 2 +- 6 files changed, 6 insertions(+), 6 deletions(-) diff --git a/CNAME b/CNAME index 5b92287d..f930dbc1 100644 --- a/CNAME +++ b/CNAME @@ -1 +1 @@ -ssg-site.servicestack.net +ssg-site.servicestack.netssg-site.servicestack.net diff --git a/feed.xml b/feed.xml index 1b8f7881..fc468d03 100644 --- a/feed.xml +++ b/feed.xml @@ -10,7 +10,7 @@ razor-ssg - Wed, 30 Aug 2023 08:27:58 GMT + Wed, 30 Aug 2023 08:35:11 GMT team@servicestack.net (Team ServiceStack) team@servicestack.net (Team ServiceStack) diff --git a/meta/2023/all.json b/meta/2023/all.json index 314cf243..92ef6f82 100644 --- a/meta/2023/all.json +++ b/meta/2023/all.json @@ -1 +1 @@ -{"pages":[{"slug":"community-rules","draft":false,"title":"Community Rules","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/community-rules","wordCount":412,"lineCount":37},{"slug":"links","draft":false,"title":"Quick Shortcuts to ServiceStack Sites","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/links","wordCount":52,"lineCount":13},{"slug":"mail-preferences","draft":false,"title":"Manage your mail preferences","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/mail-preferences","wordCount":113,"lineCount":13},{"slug":"privacy","draft":false,"title":"Privacy Policy for ServiceStack, Inc","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/privacy","wordCount":1151,"lineCount":92},{"slug":"register","draft":false,"title":"License Registration","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/register","wordCount":327,"lineCount":76},{"slug":"signup-confirmed","draft":false,"title":"Welcome to ServiceStack Newsletter","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/signup-confirmed","wordCount":53,"lineCount":8},{"slug":"terms","draft":false,"title":"ServiceStack License Agreement","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/terms","wordCount":3036,"lineCount":136},{"slug":"creatorkit/about","draft":false,"title":"About","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/creatorkit/about","wordCount":597,"lineCount":100,"order":1},{"slug":"creatorkit/install","draft":false,"title":"Install","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/creatorkit/install","wordCount":1751,"lineCount":263,"order":2},{"slug":"creatorkit/customize","draft":false,"title":"Customize","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/creatorkit/customize","wordCount":463,"lineCount":125,"order":3},{"slug":"creatorkit/components","draft":false,"title":"Components","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/creatorkit/components","wordCount":855,"lineCount":195,"order":4},{"slug":"creatorkit/integrations","draft":false,"title":"Integrations","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/creatorkit/integrations","wordCount":107,"lineCount":29,"order":5},{"slug":"creatorkit/portal-overview","draft":false,"title":"Overview","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/creatorkit/portal-overview","wordCount":163,"lineCount":40,"group":"Portal","order":6},{"slug":"creatorkit/portal-messages","draft":false,"title":"Messages","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/creatorkit/portal-messages","wordCount":1047,"lineCount":250,"group":"Portal","order":7},{"slug":"creatorkit/portal-mailruns","draft":false,"title":"Mail Runs","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/creatorkit/portal-mailruns","wordCount":1303,"lineCount":277,"group":"Portal","order":8},{"slug":"creatorkit/portal-posts","draft":false,"title":"Posts","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/creatorkit/portal-posts","wordCount":180,"lineCount":28,"group":"Portal","order":9}],"whatsnew":[{"slug":"razor-press","draft":false,"title":"Introducing Razor Press","image":"https://servicestack.net/img/whatsnew/v6.10/razor-press.png","tags":[],"date":"\/Date(1690761600000-0000)\/","content":"Razor Press is a **Razor Pages** and **Markdown** powered alternative to Ruby's Jekyll & Vue's VitePress that's ideal for\ngenerating fast, static content-centric & documentation websites. Inspired by [VitePress](https://vitepress.dev),\nit's designed to effortlessly create documentation around content written in Markdown, rendered using C# Razor Pages\nthat's beautifully styled with [tailwindcss](https://tailwindcss.com) and [@tailwindcss/typography](https://tailwindcss.com/docs/typography-plugin).\n\nThe resulting statically generated HTML pages can be easily deployed anywhere, where it can be hosted by any HTTP Server or CDN.\nBy default it includes GitHub Actions to deploy it your GitHub Repo's **gh-pages** branch where it's hosted for FREE\non [GitHub Pages](https://pages.github.com) CDN which can be easily configured to use your\n[Custom Domain](https://docs.github.com/en/pages/configuring-a-custom-domain-for-your-github-pages-site).","url":"https://docs.servicestack.net/releases/v6_10","wordCount":127,"lineCount":16,"group":"v6.10","order":1},{"slug":"new-in-razor-ssg","draft":false,"title":"New in Razor SSG","image":"https://servicestack.net/img/whatsnew/v6.10/twitter-cards.png","tags":[],"date":"\/Date(1690761600000-0000)\/","content":"The Razor SSG template continues to see improvements for creating richer static websites and Blogs: \n\n - RSS Feed for Blog Posts\n - New Razor Press Markdown Containers\n - Support for Markdown Includes\n - Meta Headers support for Twitter cards and Improved SEO\n - Blog Posts can include rich Vue Components\n - Light and Dark Mode Query Params\n - Threads and Mastodon Links for Blog Authors","url":"https://docs.servicestack.net/releases/v6_10#new-in-razor-ssg","wordCount":77,"lineCount":16,"group":"v6.10","order":2},{"slug":"rdbms-bulk-inserts","draft":false,"title":"RDBMS Bulk Inserts","image":"https://servicestack.net/img/whatsnew/v6.10/bulk-inserts.png","tags":[],"date":"\/Date(1690761600000-0000)\/","content":"The latest release of OrmLite includes Bulk Inserts implementations for each supported RDBMS to support the most \nefficient ways for inserting large amounts of data, which is encapsulated behind OrmLite's new BulkInsert API\nwhich are up to **138x times faster** than traditional single INSERT statements.\n\nIn addition to an optimal default Bulk Insert implementation, it can also be configured to execute batched \nSQL Insert statements with configurable batch sizes which enjoys broad support across all RDBMS's.","url":"https://docs.servicestack.net/releases/v6_10#rdbms-bulk-inserts","wordCount":85,"lineCount":12,"group":"v6.10","order":3},{"slug":"jsonl-data-format","draft":false,"title":"JSON Lines Data Format","image":"https://servicestack.net/img/whatsnew/v6.10/jsonl.png","tags":[],"date":"\/Date(1690761600000-0000)\/","content":"JSON Lines is an efficient JSON data format parseable by streaming parsers and text processing tools like Unix \nshell pipelines, whose streamable properties is making it a popular data format for maintaining large datasets \nlike the large AI datasets maintained on [huggingface.co](https://huggingface.co) that's now accessible on \n[Auto HTML API pages](https://docs.servicestack.net/auto-html-api).\n\nThe JSON Lines data format behaves the same way as the CSV format where it will automatically serialize the \nfirst IEnumerable property, including for all AutoQuery APIs which now benefit from a streamable JSON data format.","url":"https://docs.servicestack.net/releases/v6_10#json-lines-data-format","wordCount":104,"lineCount":13,"group":"v6.10","order":4},{"slug":"creator-kit","draft":false,"title":"Introducing CreatorKit","image":"https://servicestack.net/img/whatsnew/v6.9/creatorkit-splash.png","tags":[],"date":"\/Date(1686009600000-0000)\/","content":"CreatorKit is a simple, customizable, self-hostable alternative solution to using Mailchimp for managing an organization's \nmailing lists, accepting newsletter subscriptions, defining customizable email layouts and templates and sending \nrich HTML emails to your Customers and subscribers using your preferred SMTP provider.\n\nIt also provides a private alternative to using Disqus to enhance websites with a threading and commenting system \non your preferred blog posts and website pages that you want to be able to connect with your community on.","url":"https://docs.servicestack.net/releases/v6_09","wordCount":88,"lineCount":12,"group":"v6.9","order":1},{"slug":"build-admin-uis-fast","draft":false,"title":"Build Admin UIs, Fast","image":"https://servicestack.net/img/whatsnew/v6.9/admin-ui.png","tags":[],"date":"\/Date(1686009600000-0000)\/","content":"The new `` is a high-productivity Vue Component that combined with the `` content\ncan save an invaluable amount of time in being able to rapidly create custom Admin UIs.\n\nThe [vue-mjs](https://vue-mjs.web-templates.io) now includes a [Client Admin UI](https://vue-mjs.web-templates.io/portal/)\nshowing how we can replicate most of Locode's Auto UI in a customizable Vue App from a single \n[index.html](https://github.com/NetCoreTemplates/vue-mjs/blob/main/MyApp/wwwroot/portal/index.html) page. It also includes\nan example of a [Server Rendered Admin UI](https://vue-mjs.web-templates.io/admin/) for those that prefer to develop\nMulti Page Apps with Razor Pages.","url":"https://docs.servicestack.net/releases/v6_09#build-admin-uis-fast","wordCount":103,"lineCount":14,"group":"v6.9","order":2},{"slug":"creating-gpt-agents","draft":false,"title":"Creating ChatGPT Agents to call System APIs","image":"https://servicestack.net/img/whatsnew/v6.9/gptmeetings.jpg","tags":[],"date":"\/Date(1686009600000-0000)\/","content":"We've been working on different patterns of development to enable ChatGPT to leverage an App's ServiceStack APIs \nto solve given tasks. This is done through various prompting techniques which allows the Agent to reason about the \ncontext of the conversation and make decisions to reach for different 'tools' (your APIs) when trying to achieve \na specific goal.\n\nFor anyone wishing to incorporate AI into their systems we've created a introductory video into the techniques \nof how to leverage Large Language Models (LLMs) like GPT so they can make informed decisions on which of your \ninternal APIs they should call to accomplish a given task described in natural language.","url":"https://docs.servicestack.net/releases/v6_09#creating-chatgpt-agents-to-call-system-apis","wordCount":122,"lineCount":14,"group":"v6.9","order":3},{"slug":"vue-stable-diffusion","draft":false,"title":"Vue Stable Diffusion","image":"https://servicestack.net/img/whatsnew/v6.9/vuediffusion.png","tags":[],"date":"\/Date(1686009600000-0000)\/","content":"Following [blazordiffusion.com](https://blazordiffusion.com) which was created to showcase ServiceStack's\nBlazor Server and Blazor WASM [project templates and components](https://servicestack.net/blazor), \nwe've rewritten a new Stable Diffusion App in Vue adopting a\n[Simple Modern JavaScript](https://razor-ssg.web-templates.io/posts/javascript) approach to showcase the **Razor SSG**\nProject Template and Tailwind [Vue Component Library](https://docs.servicestack.net/vue/) available at:\n\n

\n https://diffusion.works\n

\n\nVue Diffusion is built differently from other Razor SSG Apps as instead of being pre-rendered from static content \nlike Markdown documents, it's prerendered from https://blazordiffusion.com APIs to render its dynamic \n[Albums](https://diffusion.works/albums/), \n[Top](https://diffusion.works/top) and [Latest](https://diffusion.works/latest) pages at deployment which it does by \nconfiguring the App's Service Gateway to reference external Blazor Diffusion APIs.","url":"https://docs.servicestack.net/releases/v6_09#vue-stable-diffusion","wordCount":137,"lineCount":21,"group":"v6.9","order":4},{"slug":"feature1","draft":false,"title":"New statically generated Razor Pages & Vue website","image":"https://servicestack.net/img/whatsnew/v6.8/servicestack.net-home-1440.png","tags":[],"date":"\/Date(1680048000000-0000)\/","content":"We're celebrating reaching **150M Total Downloads** with a brand new website, rewritten from Ruby's Jekyll and jQuery with an exciting \nnew Razor SSG project template enhanced with Vue 3 components for client interactivity features.\n\nThe new Razor Pages & Markdown powered template takes advantage of the advances made in the last few releases with our npm \ndependency-free approach to [Simple, Modern JavaScript](/posts/javascript), the built-in support for \n[Prerendering Razor Pages](/posts/prerendering) and the rich Tailwind \n[Vue Component Library](https://docs.servicestack.net/vue/) to create an enjoyable experience for creating Fast, FREE, \nbeautiful, CDN-hostable static generated websites & blogs.","url":"https://docs.servicestack.net/releases/v6_08","wordCount":115,"lineCount":13,"group":"v6.8"},{"slug":"feature2","draft":false,"title":"New Razor Pages & Markdown powered static website","image":"https://servicestack.net/img/whatsnew/v6.8/razor-ssg.png","tags":[],"date":"\/Date(1680048000000-0000)\/","content":"We're excited to announce our new [razor-ssg](https://razor-ssg.web-templates.io) project template - a Razor Pages powered Markdown \nalternative to Ruby's Jekyll & Next.js that's ideal for generating static websites & blogs using C#, Razor Pages & Markdown.\n\nIt's now available FREE to all .NET Developers wanting to creating Fast, Beautiful Static Websites & Blogs with Razor Pages. \nIt's FREE to create, FREE to host on GitHub Pages CDN and also designed to support running FREE from any local .NET Installs \nor IDEs where it can be maintained in [GitHub Codespaces](https://github.com/features/codespaces) that you can do entirely from an iPad.","url":"https://docs.servicestack.net/releases/v6_08#razor-ssg","wordCount":117,"lineCount":12,"group":"v6.8"},{"slug":"feature3","draft":false,"title":"Streamlined Development for creating Flutter Apps","image":"https://servicestack.net/img/whatsnew/v6.8/flutter-todos.jpg","tags":[],"date":"\/Date(1680048000000-0000)\/","content":"We've greatly improved the end-to-end development experience of creating Flutter Mobile Apps that integrate with your ServiceStack APIs. \nTo demonstrate the seamless development experience, we've created a [video walk through](https://www.youtube.com/watch?v=t4WcXo4Vnio) \ncreating a new Blazor Server project that we use **mix flutter** to create a new Flutter App that we can use to quickly build \na Mobile App to call its existing Todo .NET APIs using the built-in [Typed Dart DTOs](https://docs.servicestack.net/dart-add-servicestack-reference) integration.\n\nThis release also includes improvements to generated Dart DTOs and servicestack Dart client library with new simplified APIs\nthat greatly improves usage in Reactive UIs by encapsulates Successful and Failed API Responses in a single `ApiResult` \nvalue which can be passed down and bound to reactive components without any inhibitive `try/catch` statements.","url":"https://docs.servicestack.net/releases/v6_08#flutter","wordCount":141,"lineCount":13,"group":"v6.8"},{"slug":"feature4","draft":false,"title":"Improved workflow for creating Flutter gRPC Apps","image":"https://servicestack.net/img/whatsnew/v6.8/flutter-grpc.jpg","tags":[],"date":"\/Date(1680048000000-0000)\/","content":"We've also improved the development experience for developers who prefer or have existing investments in gRPC will be able to \nbenefit from the improved development experience with **mix flutter-grpc** which works like **mix flutter** but instead \nadds a new Flutter gRPC App to an existing ServiceStack grpc project, with pre-configured gRPC integrations. \n\nTo demonstrate this productive workflow we've [created a new video](https://www.youtube.com/watch?v=fgts6sQ2Ags) which walks \nthrough the process of creating a new Flutter App from scratch, adding a Flutter gRPC App to an existing grpc .NET project, \nand using **mix flutter-grpc** to configure the Flutter App to work with ServiceStack's gRPC Services.","url":"https://docs.servicestack.net/releases/v6_08#flutter-grpc","wordCount":118,"lineCount":12,"group":"v6.8"},{"slug":"feature1","draft":false,"title":"New Auto API HTML Page for all APIs!","image":"https://servicestack.net/img/whatsnew/v6.7/autohtml-preview.png","tags":[],"date":"\/Date(1678752000000-0000)\/","content":"The new Auto HTML Page is the best way to visualize, inspect and integrate with your APIs which provides instant utility for API consumers in consuming your APIs with a built-in API Response Visualizer, JSON syntax highlighting, integrated Postman-like UI and API SDK integration all-in-one.\n\nA nice benefit of ServiceStack's API Design is that consuming APIs are fundamentally all done the same way in all languages, which just requires adding a dependency containing a generic ServiceClient which can be used to call any ServiceStack API using the typed DTOs copied directly from the API docs page to enable an end-to-end typed API without any external tooling or build steps.","url":"https://docs.servicestack.net/releases/v6_07","wordCount":125,"lineCount":9,"group":"v6.7"},{"slug":"feature2","draft":false,"title":"Vue AutoQueryGrid Component for Auto CRUD UIs","image":"https://servicestack.net/img/whatsnew/v6.7/gallery-contacts.png","tags":[],"date":"\/Date(1678752000000-0000)\/","content":"The new AutoQueryGrid component is the last high-productivity component missing from the Vue Tailwind Component Library to reach feature parity with Blazor Tailwind Component Library.\n\nIt enables an Effortless CRUD UI without any external dependencies, tooling or build steps, generating a capability-based UI for the currently authenticated user, enabling full CRUD functionality through the App's auth-protected AutoQuery APIs, validated by the APIs Declarative Validation Rules utilizing optimal Form Inputs for each C# property type with contextual validation binding, that displays its results in a rich formatted data grid customized with APIs Declarative UI Attributes.","url":"https://docs.servicestack.net/releases/v6_07#autoquerygrid","wordCount":108,"lineCount":10,"group":"v6.7"},{"slug":"feature3","draft":false,"title":"New Vue 3 Locode, API Explorer & Admin UIs","image":"https://servicestack.net/img/whatsnew/v6.7/new-vue3-uis.png","tags":[],"date":"\/Date(1678752000000-0000)\/","content":"With access to all components needed, we've taken this opportunity to modernize all of ServiceStack's built-in UI's that were previously written with petite-vue and have rewritten them with Vue 3 and the Vue Components Library, which has become our preferred UI technology stack for all of ServiceStack's built-in UIs.\n\nUltimately the new Vue 3 UIs should appeal to a lot more use-cases with better reuse and customizability using the full Vue 3 framework and 3rd Party ecosystem for creating more compelling and interactive UIs.","url":"https://docs.servicestack.net/releases/v6_07#new-locode-api-explorer-admin-uis-now-in-vue-3","wordCount":100,"lineCount":9,"group":"v6.7"},{"slug":"feature4","draft":false,"title":"New API Index Page","image":"https://servicestack.net/img/whatsnew/v6.7/api-gallery.png","tags":[],"date":"\/Date(1678752000000-0000)\/","content":"The `/api` route is now being used as an opportunity to improve API Discovery by returning an App's public APIs grouped by user-defined tags with direct links to the API endpoint, viewing it in API Explorer and in Locode for AutoQuery APIs.","url":"https://docs.servicestack.net/releases/v6_07#api-index","wordCount":53,"lineCount":7,"group":"v6.7"},{"slug":"feature1","draft":false,"title":"New Tailwind Razor Pages & MVC Templates","image":"https://servicestack.net/img/whatsnew/v6.6/vue-mjs.png","tags":[],"date":"\/Date(1675814400000-0000)\/","content":"The new Tailwind Razor Pages & MVC Templates enable rapid development of Modern Tailwind Apps without the pitfalls plaguing SPA development:\n\n- **[vue-mjs](https://vue-mjs.web-templates.io)** - Flagship Vue.mjs template with OrmLite, AutoQuery, boosted htmx links & static pre-rendered blogs\n- **[razor-tailwind](https://razor-tailwind.web-templates.io)** - Simple Razor Pages Template without DB or pre-rendering\n- **[mvc-tailwind](https://mvc-tailwind.web-templates.io)** - Want to use MVC Identity Auth and Entity Framework\n- **[web-tailwind](https://web-tailwind.web-templates.io)** - Empty tailwind template with no web framework configured\n- **[vue-vite](https://vue-vite.jamstacks.net)** - Vite + TypeScript in a simpler JAMStack Vite SPA App\n- **[vue-ssg](https://vue-ssg.jamstacks.net)** - Vite + TypeScript in an advanced JAMStack Vite SSG App","url":"https://docs.servicestack.net/releases/v6_06","wordCount":135,"lineCount":14,"group":"v6.6"},{"slug":"feature2","draft":false,"title":"Vue 3 Tailwind Components","image":"https://servicestack.net/img/whatsnew/v6.6/vue-components.png","tags":[],"date":"\/Date(1675814400000-0000)\/","content":"To maximize productivity, all new Vue Tailwind templates are pre-configured to use the feature-rich [Vue 3 Taiwlind Library](https://docs.servicestack.net/vue/).\n\n**@servicestack/vue** is our growing Vue 3 Tailwind component library with a number of rich Tailwind components useful in .NET Web Apps, including DataGrids, Auto Forms, Modals, Slide Overs, Navigational Components, Formatters, standard HTML Form Input controls inc. FileInput, Autocomplete, TagInput - all with integrated contextual validation binding.\n\nIt's our cornerstone library for enabling a highly productive dev model across our Vue.js Tailwind Project templates that we'll be continuing to invest in to unlock even greater productivity - watch this space!","url":"https://docs.servicestack.net/vue/","wordCount":113,"lineCount":11,"group":"v6.6"},{"slug":"feature3","draft":false,"title":"ES6 JS Module Add ServiceStack Reference","image":"https://servicestack.net/img/whatsnew/v6.6/mjs-update-reference-rider.png","tags":[],"date":"\/Date(1675814400000-0000)\/","content":"The new ES6 classes provide a productive type-safe development model during development but can also be referenced as-is in JS Module scripts and run natively in browsers to enable instant typed API integrations without any build tools!\n\nTo achieve this the ES6 classes are annotated with JSDoc type hints in comments which enjoys broad support in IDEs and tools like TypeScript where it can be used to provide type information in JavaScript files.\n\nThey're now a first-class Add ServiceStack Reference language supported language complete with IDE integration in the latest ServiceStack Plugins for VS .NET and JetBrains IDEs.","url":"https://docs.servicestack.net/releases/v6_06#js-module-es6-class-dtos","wordCount":111,"lineCount":11,"group":"v6.6"},{"slug":"feature4","draft":false,"title":"Static prerendered Markdown Razor Pages","image":"https://servicestack.net/img/whatsnew/v6.6/razor-pages-prerendering.png","tags":[],"date":"\/Date(1675814400000-0000)\/","content":"Prerendering static content is a popular technique used by JAMStack Apps to improve the performance, reliability and scalability of Web Apps that's able to save unnecessary computation at runtime by generating static content at deployment which can be optionally hosted from a CDN for even greater performance.\n\nAs it's a valuable performance optimizing technique it's included in the [vue-mjs](https://vue-mjs.web-templates.io) template to show how it can be easily achieved within a Razor Pages App. Since prerendered content is only updated at deployment, it's primarily only useful for static content like markdown powered blogs.\n\nFor those interested in utilizing this optimization we've published details on how this works in the\n**[Prerendering Razor Pages](https://vue-mjs.web-templates.io/blog/prerendering)** blog post.","url":"https://vue-mjs.web-templates.io/posts/prerendering","wordCount":131,"lineCount":11,"group":"v6.6"}],"videos":[{"slug":"video5","draft":false,"title":"Stream processing of data with JSON Lines","tags":["serialization"," servicestack"," jsonl"],"date":"\/Date(1692057600000+0000)\/","content":"In this video, we explore the efficient JSON Lines (JSONL) data format, a favorite among developers and the AI community\nfor handling large datasets. We walk through working with JSON Lines data, including examples for streaming parsers,\nasynchronous parsing with ServiceStack, and integration with Typesense.","url":"https://youtu.be/m0tAfjvJaZg","wordCount":56,"lineCount":9,"group":"apis"},{"slug":"video1","draft":false,"title":"GitHub for Auto Deployments - Kubernetes Not Required","tags":["github-actions","deployment","hosting"],"date":"\/Date(1691452800000+0000)\/","content":"Step by step walkthrough for deploying your App via GitHub Actions and plain old SSH. \nCheap hardware is getting fast enough that a lot of Web Apps don't need sophisticated orchestration tools like Kubernetes, \nso we show how you can use fundamental tools like SSH, Docker Compose and GitHub Actions to do it yourself! \n\nLow traffic Apps & proof of concepts can easily share cost effective server running Linux, \nNginx Reverse Proxy with LetsEncrypt.","url":"https://youtu.be/7dardvqBFbE","wordCount":87,"lineCount":13,"group":"actions"},{"slug":"video4","draft":false,"title":"Load data fast with ADO.NET RDBMS Bulk Insert APIs","tags":["ormlite","db","performance"],"date":"\/Date(1690848000000+0000)\/","content":"OrmLite includes a Bulk Inserts API that encapsulates the most efficient ways for inserting large amounts of data \nin each supported RDBMS. We ran benchmarks across macOS on Apple M2 ARM, Intel Linux VM and Intel Windows 10 to measure \nhow fast they run across popular Operating System platforms.","url":"https://youtu.be/3gO_OEWIyPo","wordCount":64,"lineCount":10,"group":"features","order":4},{"slug":"video5","draft":false,"title":"GPT Agent Feature Plugin Updated with Semantic Kernel","tags":["gpt"],"date":"\/Date(1690848000000+0000)\/","content":"In this video, we delve into the integration of Microsoft's Semantic Kernel with our GPT Meeting Agent to simplify \nand enhance working with Large Language Models with a common abstraction library that allows for easy substitution\nand experimentation with different LLMs.","url":"https://youtu.be/smM-Bs7CxJ8","wordCount":54,"lineCount":11,"group":"features","order":5},{"slug":"video1","draft":false,"title":"Getting Started with OrmLite fast, code-first ORM for .NET","tags":["ormlite","db"],"date":"\/Date(1688428800000+0000)\/","content":"This video walks though getting started with OrmLite - a powerful, fast and easy to use ORM for .NET that \ncan be used in any .NET and .NET Framework App without the complexity of larger ORMs. \n\nIn this tutorial we'll demonstrate the best patterns to use to install, configure and use OrmLite in your Application, \ndefining code-first POCOs, using them to create RDBMS tables and explore how to Create, Query, Update and Delete them \nusing OrmLite's Typed APIs.","url":"https://youtu.be/vUbpwjfEYzg","wordCount":92,"lineCount":13,"group":"features","order":1},{"slug":"video2","draft":false,"title":"Getting Started with ServiceStack.Redis in .NET","tags":["redis"],"date":"\/Date(1687824000000+0000)\/","content":"In this tutorial we explore the basics of Redis, an in-memory database, and its integration in .NET using the ServiceStack.Redis library. \nThe video covers topics such as setting up a Redis server with Docker, understanding the ServiceStack.Redis library, and making \nthe most of Redis data structures in a .NET context. \n\nFurthermore, it also delves into utilizing the async capabilities of ServiceStack, all demonstrated through clear, practical examples.","url":"https://youtu.be/jBdOvTvjyqY","wordCount":82,"lineCount":13,"group":"features","order":2},{"slug":"custom-admin-uis","draft":false,"title":"Build beautiful custom .NET Admin UIs in minutes","tags":["vue","autoquery"],"date":"\/Date(1686700800000+0000)\/","content":"In this video we explore the Server Multi Razor Page and Client rendered Admin UI Pages in the latest .NET\n[vue-mjs](https://vue-mjs.web-templates.io) project template to see how to use the new SidebarLayout and AutoQueryGrid\nVue Tailwind components to build beautiful Admin UI Pages within minutes.","url":"https://youtu.be/wlRA4_owEsc","wordCount":59,"lineCount":10,"group":"vue-projects","order":4},{"slug":"video2","draft":false,"title":"New Disqus OSS self-host alternative for .NET Websites","tags":["creatorkit","posts","tailwind"],"date":"\/Date(1686268800000+0000)\/","content":"In this video we explore how we can use CreatorKit - a self-hosting alternative to Disqus to add comments, voting\nand moderation to any existing page or blog post.\n\nCreatorKit is especially useful for adding dynamic post comment and voting features to Jamstack and other\nstatically generated websites which can continually be statically pre-rendered and hosted on CDN's whilst its \ndynamic features are powered by an external CreatorKit instance.","url":"https://youtu.be/lgpl-VjxtdU","wordCount":79,"lineCount":12,"group":"creatorkit"},{"slug":"video1","draft":false,"title":"New Mailchimp self-host mail management alternative","tags":["creatorkit","mail","tailwind"],"date":"\/Date(1686182400000+0000)\/","content":"In this video we introduce CreatorKit an OSS self-hosting alternative to Mailchimp for managing mailing lists,\nnewsletter subscriptions, email templating, marketing campaigns & more whose tailwind components can be easily \nintegrated into any existing website.\n\nIt's an ideal companion for .NET Apps looking to manage their mailinglist and newsletter subscribers in an\nisolated customizable .NET App with support for creating custom email layouts, templates and mail campaigns.","url":"https://youtu.be/_qDVtfcHf14","wordCount":75,"lineCount":12,"group":"creatorkit"},{"slug":"video1","draft":false,"title":"Bring static Xkcd dataset to life with AutoQuery","tags":["autoquery"," razor-pages"," ssg"," tailwind"],"date":"\/Date(1683763200000+0000)\/","content":"In this video, we demonstrate how to use AutoQuery to turn a static XKCD comic dataset from Hugging Face into a Web API, \naddressing common issues of siloed data.\n\nBy creating well-defined AutoQuery APIs, we make the data more accessible and enable efficient data integrations \nfor rapid creation of production Web Apps which we demonstrate in new lightweight a Razor SSG Vue App.","url":"https://youtu.be/CrKtXVrPj8Q","wordCount":78,"lineCount":11,"group":"autoquery"},{"slug":"video1","draft":false,"title":"Using Razor SSG to Create Websites in GitHub Codespaces","tags":["razor-pages"," ssg"," tailwind"," codespaces"],"date":"\/Date(1680048000000+0000)\/","content":"This video takes an in-depth look at the [razor-ssg](https://razor-ssg.web-templates.io) ServiceStack template, a powerful tool that \nharnesses the power of .NET Razor Pages to provide seamless static site generation (SSG) capabilities \n\nWith GitHub Codespaces integration, you can develop, test, and manage your application all within your browser, eliminating the need \nfor a dedicated development environment and expediting your workflow, which can all be done on the go from an iPad","url":"https://youtu.be/MRQMBrXi5Sc","wordCount":88,"lineCount":12,"group":"projects"},{"slug":"razor-ssg","draft":false,"title":"Using Razor SSG to Create Websites in GitHub Codespaces","tags":["razor-pages","ssg","markdown","codespaces"],"date":"\/Date(1680048000000+0000)\/","content":"This video takes an in-depth look at the [razor-ssg](https://razor-ssg.web-templates.io) ServiceStack template, a powerful tool that \nharnesses the power of .NET Razor Pages to provide seamless static site generation (SSG) capabilities \n\nWith GitHub Codespaces integration, you can develop, test, and manage your application all within your browser, eliminating the need \nfor a dedicated development environment and expediting your workflow, which can all be done on the go from an iPad","url":"https://youtu.be/MRQMBrXi5Sc","wordCount":86,"lineCount":13,"group":"vue-projects","order":3},{"slug":"video1","draft":false,"title":"Fastest way to a working gRPC Server and Flutter solution","tags":["grpc","flutter","android"],"date":"\/Date(1679875200000+0000)\/","content":"In this video we'll walk through configuring Flutter and gRPC .NET Services with the `flutter-grpc` mix template\nto add a new Flutter application using your locally installed **Flutter SDK** to an existing ServiceStack `grpc` project\nthat has been configured to support gRPC services","url":"https://youtu.be/fgts6sQ2Ags","wordCount":55,"lineCount":9,"group":"flutter-grpc"},{"slug":"video1","draft":false,"title":"Flutter Todo App with .NET API, from Scratch in Minutes","tags":["flutter","android","api"],"date":"\/Date(1679875200000+0000)\/","content":"This video starts from scratch, walking through installing Flutter SDK, \nbefore adding a new native Flutter App to a new .NET Blazor Server project -\ngiving our existing TODO Blazor Web App new native iOS & Android native UIs\n\nNext, we'll demonstrate the iterative development workflow of making changes \nto backend .NET APIs that's easily kept in-sync with our clients Dart DTOs\nfrom within Android Studio or command-line","url":"https://youtu.be/t4WcXo4Vnio","wordCount":79,"lineCount":13,"group":"flutter"},{"slug":"video2","draft":false,"title":"Use Flutter to build a Bookings App Fast","tags":["flutter","android","api"],"date":"\/Date(1679875200000+0000)\/","content":"In this video, we'll show how we can rapidly develop a new Flutter Android Bookings App\nadded to a new [vue-mjs](https://vue-mjs.web-templates.io) .NET Project using `x mix flutter`\n\nNext, we'll dive into the development process, where we'll demonstrate the productivity\nof calling typed .NET APIs using typed Dart DTOs for end-to-end typed integrations\nthat can be effortlessly updated from within Android Studio","url":"https://youtu.be/eMbwaMuIk84","wordCount":72,"lineCount":13,"group":"flutter"},{"slug":"video1","draft":false,"title":"Instantly Manage your data using AutoQueryGrid Vue","tags":["vue","autoquery"],"date":"\/Date(1678924800000+0000)\/","content":"This walkthrough explores the ServiceStack Vue 3 library and the functionality of the AutoQueryGrid component. The AutoQueryGrid component simplifies the integration of AutoQuery services by generating a customizable UI. \n\nBy following this guide, you'll learn how to effectively utilize these tools to enhance your application's user interface and overall user experience.","url":"https://youtu.be/znCoC-Ct0Ps","wordCount":63,"lineCount":10,"group":"vue"},{"slug":"video1","draft":false,"title":"Preview APIs with the Auto Html API Page","tags":["ui","api"],"date":"\/Date(1678665600000+0000)\/","content":"The Auto HTML Page provides instant utility for API consumers in consuming your APIs with a built-in \nAPI Response Visualizer, JSON syntax highlighting, integrated Postman-like UI and API SDK integration all-in-one.\n\nPowered by Vue 3 and the ServiceStack [Vue library](https://docs.servicestack.net/vue/), it's also highly customizable.","url":"https://youtu.be/3gjisRVqhLo","wordCount":61,"lineCount":11,"group":"ui-autohtml"},{"slug":"video2","draft":false,"title":"Vue 3 Tailwind Components Library","tags":["vue","autoquery"],"date":"\/Date(1676332800000+0000)\/","content":"In this video, we demonstrate using the @servicestack/vue components library for Vue.js 3 Multipage Apps (MPAs) along with the `vue-mjs` template. \n\nThe template illustrates building content-heavy or complex sites while avoiding the intricacies of Single Page Apps (SPAs) through the use of JavaScript Modules, Tailwind, Vue.js, Razor Pages, and ServiceStack.","url":"https://youtu.be/YIa0w6whe2U","wordCount":61,"lineCount":9,"group":"vue"}],"posts":[{"slug":"cloud-value-between-architectures","draft":false,"title":"Should .NET Apps switch to ARM?","summary":"Evaluating the cost and performance of ARM vs x86 in AWS, Azure, and Hetzner","image":"https://images.unsplash.com/photo-1587845323226-bad89242c735?crop=entropy&fit=crop&h=1000&w=2000","author":"Darren Reid","tags":["dotnet"," hosting"," arm"," performance"],"date":"\/Date(1693180800000-0000)\/","url":"https://servicestack.net/posts/cloud-value-between-architectures","wordCount":3264,"lineCount":394},{"slug":"razor-ssg-new-blog-features","draft":false,"title":"New Blogging features in Razor SSG","summary":"Explore the new Blogging Features in Razor SSG","image":"https://images.unsplash.com/photo-1486312338219-ce68d2c6f44d?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["razor"," markdown"," blog"," dev"],"date":"\/Date(1692748800000-0000)\/","url":"https://servicestack.net/posts/razor-ssg-new-blog-features","wordCount":1296,"lineCount":337},{"slug":"jsonl-format","draft":false,"title":"Exploring the new streamable JSON Lines Format","summary":"A dive into the JSON Lines format and how to use it in ServiceStack","image":"https://images.unsplash.com/photo-1687042268541-5cc60ad9d3de?crop=entropy&fit=crop&h=1000&w=2000","author":"Darren Reid","tags":["serialization"," servicestack"," jsonl"],"date":"\/Date(1692057600000-0000)\/","url":"https://servicestack.net/posts/jsonl-format","wordCount":1656,"lineCount":217},{"slug":"kubernetes_not_required","draft":false,"title":"Using GitHub for Auto Deployments - Kubernetes Not Required","summary":"A cost-effective and straightforward web app deployment pattern using GitHub and a single Linux server","image":"https://images.unsplash.com/photo-1667372459510-55b5e2087cd0?crop=entropy&fit=crop&h=1000&w=2000","author":"Darren Reid","tags":["github-actions"," devops"," hosting"],"date":"\/Date(1691452800000-0000)\/","url":"https://servicestack.net/posts/kubernetes_not_required","wordCount":5292,"lineCount":693},{"slug":"bulk-insert-performance","draft":false,"title":"Which RDBMS has the fastest .NET Bulk Insert implementation?","summary":"Measuring the different performance of RDBMS Bulk Insert implementations","image":"https://images.unsplash.com/photo-1517026575980-3e1e2dedeab4?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["db"," dev"," dotnet"],"date":"\/Date(1690761600000-0000)\/","url":"https://servicestack.net/posts/bulk-insert-performance","wordCount":6965,"lineCount":1070},{"slug":"postgres-mysql-sqlserver-on-apple-silicon","draft":false,"title":"Install PostgreSQL, MySql and SQL Server on Apple Silicon","summary":"Easiest way to install PostgreSQL, MySql and SQL Server on macOS running Apple Silicon's M2","image":"https://images.unsplash.com/photo-1517663404855-6f96c7aa20e2?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["db"," dev"],"date":"\/Date(1690243200000-0000)\/","url":"https://servicestack.net/posts/postgres-mysql-sqlserver-on-apple-silicon","wordCount":1673,"lineCount":328},{"slug":"semantic-kernel-gptmeetngs","draft":false,"title":"Trying Microsoft's Semantic Kernel","summary":"Incorporating the Semantic Kernel into our GPT Meeting Agent gives developers more flexibility when working with LLMs","image":"https://images.unsplash.com/photo-1579548122080-c35fd6820ecb?crop=entropy&fit=crop&h=1000&w=2000","author":"Darren Reid","tags":["dotnet"," ai"," semantic-kernel"," gpt"],"date":"\/Date(1689638400000-0000)\/","url":"https://servicestack.net/posts/semantic-kernel-gptmeetngs","wordCount":834,"lineCount":54},{"slug":"razor-press","draft":false,"title":"Introducing Razor Press","summary":"Markdown & Razor Pages Static Site Generator for beautiful fast Content & Documentation","image":"https://images.unsplash.com/photo-1681301968680-fe46a0cd51be?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["razor"," markdown"," blog"," dev"],"date":"\/Date(1689552000000-0000)\/","url":"https://servicestack.net/posts/razor-press","wordCount":946,"lineCount":162},{"slug":"using-json-patch","draft":false,"title":"JSON Patch secrets into appsettings.json","summary":"Simplify managing App secrets by JSON patching them into your appsettings.json with during deployments","image":"https://images.unsplash.com/photo-1563089145-599997674d42?crop=entropy&fit=crop&h=1000&w=2000","author":"Darren Reid","tags":["devops"," github-actions"],"date":"\/Date(1689033600000-0000)\/","url":"https://servicestack.net/posts/using-json-patch","wordCount":670,"lineCount":135},{"slug":"new_razor_ssg_docs","draft":false,"title":"New Razor SSG generated docs.servicestack.net","summary":"The new docs.servicestack.net website is now generated with Razor SSG - now with Dark Mode!","image":"https://images.unsplash.com/photo-1526243741027-444d633d7365?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["razor"," ssg"," documentation"],"date":"\/Date(1688947200000-0000)\/","url":"https://servicestack.net/posts/new_razor_ssg_docs","wordCount":750,"lineCount":87},{"slug":"vue-stable-diffusion","draft":false,"title":"Vue Stable Diffusion","summary":"Rewriting Blazor Diffussion image generation & album catalog in Vue & Razor SSG","image":"https://images.unsplash.com/photo-1573490647695-2892d0bf89e7?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["vue"," tailwind"],"date":"\/Date(1686787200000-0000)\/","url":"https://servicestack.net/posts/vue-stable-diffusion","wordCount":1057,"lineCount":209},{"slug":"admin-uis","draft":false,"title":"Build Beautiful Admin UIs, Fast","summary":"Taking a look at the new features in Vue Razor Pages template to build Admin UIs, Fast","image":"https://images.unsplash.com/photo-1667906962043-a3e82dea23a3?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["vue"," tailwind"," admin"],"date":"\/Date(1686614400000-0000)\/","url":"https://servicestack.net/posts/admin-uis","wordCount":1879,"lineCount":364},{"slug":"creatorkit","draft":false,"title":"Introducing CreatorKit","summary":"Exploring CreatorKit - an OSS Self-Hosting alternative to Mailchimp and Disqus","image":"https://images.unsplash.com/photo-1493723843671-1d655e66ac1c?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["creatorkit"," marketing"," publishing"],"date":"\/Date(1686182400000-0000)\/","url":"https://servicestack.net/posts/creatorkit","wordCount":1348,"lineCount":209},{"slug":"chat-gpt-agents","draft":false,"title":"Creating ChatGPT Agents to call System APIs","summary":"A walkthrough of how to enable Large Language Model 'Agents' with access to your own ServiceStack APIs","image":"https://images.unsplash.com/photo-1675271591211-126ad94e495d?crop=entropy&fit=crop&h=1000&w=2000","author":"Darren Reid","tags":["servicestack"," gpt"," chatbot"," ai"],"date":"\/Date(1683849600000-0000)\/","url":"https://servicestack.net/posts/chat-gpt-agents","wordCount":1952,"lineCount":273},{"slug":"autoquery-xkcd","draft":false,"title":"Bringing xkcd static dataset to life with AutoQuery","summary":"Unsiloing data quickly with AutoQuery to make your datasets available from queryable Web APIs","image":"./img/posts/autoquery-xkcd/drawing-xkcd-upscaled.jpg","author":"Darren Reid","tags":["autoquery"," db"," dev"," huggingface"," vue"],"date":"\/Date(1681516800000-0000)\/","url":"https://servicestack.net/posts/autoquery-xkcd","wordCount":3352,"lineCount":551},{"slug":"razor-ssg","draft":false,"title":"Introducing Razor SSG","summary":"Create fast, beautiful statically rendered Razor Websites & Blogs","image":"https://images.unsplash.com/photo-1579767684138-a57e917d30aa?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["razor"," markdown"," blog"," dev"],"date":"\/Date(1680134400000-0000)\/","url":"https://servicestack.net/posts/razor-ssg","wordCount":3070,"lineCount":596},{"slug":"new_razor_ssg_website","draft":false,"title":"New Razor SSG generated servicestack.net","summary":"Celebrating 150M Downloads with a new Razor SSG generated Website","image":"https://images.unsplash.com/photo-1475669698648-2f144fcaaeb1?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["razor"," ssg"," website"],"date":"\/Date(1680048000000-0000)\/","url":"https://servicestack.net/posts/new_razor_ssg_website","wordCount":567,"lineCount":77},{"slug":"javascript","draft":false,"title":"Simple, Modern JavaScript","summary":"Learn about JS Modules, Vue 3 and available rich UI Components","image":"https://images.unsplash.com/photo-1497515114629-f71d768fd07c?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["js"," dev"],"date":"\/Date(1675209600000-0000)\/","url":"https://servicestack.net/posts/javascript","wordCount":3118,"lineCount":612},{"slug":"prerendering","draft":false,"title":"Prerendering Razor Pages","summary":"Improving Blog Performance with Prerendering","image":"https://images.unsplash.com/photo-1522526886914-6e8d4fd91399?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["c#"," dev"," markdown"],"date":"\/Date(1673395200000-0000)\/","url":"https://servicestack.net/posts/prerendering","wordCount":1160,"lineCount":235},{"slug":"rider","draft":false,"title":"Develop using JetBrains Rider","summary":"Setting up & exploring development workflow in Rider","image":"https://images.unsplash.com/photo-1472289065668-ce650ac443d2?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["c#"," dev"],"date":"\/Date(1673395200000-0000)\/","url":"https://servicestack.net/posts/rider","wordCount":472,"lineCount":77},{"slug":"vs","draft":false,"title":"Develop using Visual Studio","summary":"Exploring development workflow in VS Code and Visual Studio .NET","image":"https://images.unsplash.com/photo-1513542789411-b6a5d4f31634?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["c#"," dev"],"date":"\/Date(1673308800000-0000)\/","url":"https://servicestack.net/posts/vs","wordCount":1325,"lineCount":76},{"slug":"jamstacks_hosting","draft":false,"title":"Jamstack Hosting Costs @ $.40 /mo","summary":"Exploring cost & scalability benefits of hybrid CDN & .NET Apps","image":"https://images.unsplash.com/photo-1506399309177-3b43e99fead2?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["dev"," hosting"," devops"],"date":"\/Date(1672617600000-0000)\/","url":"https://servicestack.net/posts/jamstacks_hosting","wordCount":3054,"lineCount":83},{"slug":"deploy","draft":false,"title":"Deployment with GitHub Actions","summary":"Configuring your GitHub repo for SSH and CDN deployments","image":"https://images.unsplash.com/photo-1485841890310-6a055c88698a?crop=entropy&fit=crop&h=1000&w=2000","author":"Darren Reid","tags":["github-actions"," devops"," hosting"],"date":"\/Date(1672531200000-0000)\/","url":"https://servicestack.net/posts/deploy","wordCount":724,"lineCount":107}]} \ No newline at end of file +{"pages":[{"slug":"community-rules","draft":false,"title":"Community Rules","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/community-rules","wordCount":412,"lineCount":37},{"slug":"links","draft":false,"title":"Quick Shortcuts to ServiceStack Sites","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/links","wordCount":52,"lineCount":13},{"slug":"mail-preferences","draft":false,"title":"Manage your mail preferences","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/mail-preferences","wordCount":113,"lineCount":13},{"slug":"privacy","draft":false,"title":"Privacy Policy for ServiceStack, Inc","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/privacy","wordCount":1151,"lineCount":92},{"slug":"register","draft":false,"title":"License Registration","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/register","wordCount":327,"lineCount":76},{"slug":"signup-confirmed","draft":false,"title":"Welcome to ServiceStack Newsletter","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/signup-confirmed","wordCount":53,"lineCount":8},{"slug":"terms","draft":false,"title":"ServiceStack License Agreement","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/terms","wordCount":3036,"lineCount":136},{"slug":"creatorkit/about","draft":false,"title":"About","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/creatorkit/about","wordCount":597,"lineCount":100,"order":1},{"slug":"creatorkit/install","draft":false,"title":"Install","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/creatorkit/install","wordCount":1751,"lineCount":263,"order":2},{"slug":"creatorkit/customize","draft":false,"title":"Customize","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/creatorkit/customize","wordCount":463,"lineCount":125,"order":3},{"slug":"creatorkit/components","draft":false,"title":"Components","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/creatorkit/components","wordCount":855,"lineCount":195,"order":4},{"slug":"creatorkit/integrations","draft":false,"title":"Integrations","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/creatorkit/integrations","wordCount":107,"lineCount":29,"order":5},{"slug":"creatorkit/portal-overview","draft":false,"title":"Overview","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/creatorkit/portal-overview","wordCount":163,"lineCount":40,"group":"Portal","order":6},{"slug":"creatorkit/portal-messages","draft":false,"title":"Messages","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/creatorkit/portal-messages","wordCount":1047,"lineCount":250,"group":"Portal","order":7},{"slug":"creatorkit/portal-mailruns","draft":false,"title":"Mail Runs","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/creatorkit/portal-mailruns","wordCount":1303,"lineCount":277,"group":"Portal","order":8},{"slug":"creatorkit/portal-posts","draft":false,"title":"Posts","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/creatorkit/portal-posts","wordCount":180,"lineCount":28,"group":"Portal","order":9}],"whatsnew":[{"slug":"razor-press","draft":false,"title":"Introducing Razor Press","image":"https://servicestack.net/img/whatsnew/v6.10/razor-press.png","tags":[],"date":"\/Date(1690761600000-0000)\/","content":"Razor Press is a **Razor Pages** and **Markdown** powered alternative to Ruby's Jekyll & Vue's VitePress that's ideal for\ngenerating fast, static content-centric & documentation websites. Inspired by [VitePress](https://vitepress.dev),\nit's designed to effortlessly create documentation around content written in Markdown, rendered using C# Razor Pages\nthat's beautifully styled with [tailwindcss](https://tailwindcss.com) and [@tailwindcss/typography](https://tailwindcss.com/docs/typography-plugin).\n\nThe resulting statically generated HTML pages can be easily deployed anywhere, where it can be hosted by any HTTP Server or CDN.\nBy default it includes GitHub Actions to deploy it your GitHub Repo's **gh-pages** branch where it's hosted for FREE\non [GitHub Pages](https://pages.github.com) CDN which can be easily configured to use your\n[Custom Domain](https://docs.github.com/en/pages/configuring-a-custom-domain-for-your-github-pages-site).","url":"https://docs.servicestack.net/releases/v6_10","wordCount":127,"lineCount":16,"group":"v6.10","order":1},{"slug":"new-in-razor-ssg","draft":false,"title":"New in Razor SSG","image":"https://servicestack.net/img/whatsnew/v6.10/twitter-cards.png","tags":[],"date":"\/Date(1690761600000-0000)\/","content":"The Razor SSG template continues to see improvements for creating richer static websites and Blogs: \n\n - RSS Feed for Blog Posts\n - New Razor Press Markdown Containers\n - Support for Markdown Includes\n - Meta Headers support for Twitter cards and Improved SEO\n - Blog Posts can include rich Vue Components\n - Light and Dark Mode Query Params\n - Threads and Mastodon Links for Blog Authors","url":"https://docs.servicestack.net/releases/v6_10#new-in-razor-ssg","wordCount":77,"lineCount":16,"group":"v6.10","order":2},{"slug":"rdbms-bulk-inserts","draft":false,"title":"RDBMS Bulk Inserts","image":"https://servicestack.net/img/whatsnew/v6.10/bulk-inserts.png","tags":[],"date":"\/Date(1690761600000-0000)\/","content":"The latest release of OrmLite includes Bulk Inserts implementations for each supported RDBMS to support the most \nefficient ways for inserting large amounts of data, which is encapsulated behind OrmLite's new BulkInsert API\nwhich are up to **138x times faster** than traditional single INSERT statements.\n\nIn addition to an optimal default Bulk Insert implementation, it can also be configured to execute batched \nSQL Insert statements with configurable batch sizes which enjoys broad support across all RDBMS's.","url":"https://docs.servicestack.net/releases/v6_10#rdbms-bulk-inserts","wordCount":85,"lineCount":12,"group":"v6.10","order":3},{"slug":"jsonl-data-format","draft":false,"title":"JSON Lines Data Format","image":"https://servicestack.net/img/whatsnew/v6.10/jsonl.png","tags":[],"date":"\/Date(1690761600000-0000)\/","content":"JSON Lines is an efficient JSON data format parseable by streaming parsers and text processing tools like Unix \nshell pipelines, whose streamable properties is making it a popular data format for maintaining large datasets \nlike the large AI datasets maintained on [huggingface.co](https://huggingface.co) that's now accessible on \n[Auto HTML API pages](https://docs.servicestack.net/auto-html-api).\n\nThe JSON Lines data format behaves the same way as the CSV format where it will automatically serialize the \nfirst IEnumerable property, including for all AutoQuery APIs which now benefit from a streamable JSON data format.","url":"https://docs.servicestack.net/releases/v6_10#json-lines-data-format","wordCount":104,"lineCount":13,"group":"v6.10","order":4},{"slug":"creator-kit","draft":false,"title":"Introducing CreatorKit","image":"https://servicestack.net/img/whatsnew/v6.9/creatorkit-splash.png","tags":[],"date":"\/Date(1686009600000-0000)\/","content":"CreatorKit is a simple, customizable, self-hostable alternative solution to using Mailchimp for managing an organization's \nmailing lists, accepting newsletter subscriptions, defining customizable email layouts and templates and sending \nrich HTML emails to your Customers and subscribers using your preferred SMTP provider.\n\nIt also provides a private alternative to using Disqus to enhance websites with a threading and commenting system \non your preferred blog posts and website pages that you want to be able to connect with your community on.","url":"https://docs.servicestack.net/releases/v6_09","wordCount":88,"lineCount":12,"group":"v6.9","order":1},{"slug":"build-admin-uis-fast","draft":false,"title":"Build Admin UIs, Fast","image":"https://servicestack.net/img/whatsnew/v6.9/admin-ui.png","tags":[],"date":"\/Date(1686009600000-0000)\/","content":"The new `` is a high-productivity Vue Component that combined with the `` content\ncan save an invaluable amount of time in being able to rapidly create custom Admin UIs.\n\nThe [vue-mjs](https://vue-mjs.web-templates.io) now includes a [Client Admin UI](https://vue-mjs.web-templates.io/portal/)\nshowing how we can replicate most of Locode's Auto UI in a customizable Vue App from a single \n[index.html](https://github.com/NetCoreTemplates/vue-mjs/blob/main/MyApp/wwwroot/portal/index.html) page. It also includes\nan example of a [Server Rendered Admin UI](https://vue-mjs.web-templates.io/admin/) for those that prefer to develop\nMulti Page Apps with Razor Pages.","url":"https://docs.servicestack.net/releases/v6_09#build-admin-uis-fast","wordCount":103,"lineCount":14,"group":"v6.9","order":2},{"slug":"creating-gpt-agents","draft":false,"title":"Creating ChatGPT Agents to call System APIs","image":"https://servicestack.net/img/whatsnew/v6.9/gptmeetings.jpg","tags":[],"date":"\/Date(1686009600000-0000)\/","content":"We've been working on different patterns of development to enable ChatGPT to leverage an App's ServiceStack APIs \nto solve given tasks. This is done through various prompting techniques which allows the Agent to reason about the \ncontext of the conversation and make decisions to reach for different 'tools' (your APIs) when trying to achieve \na specific goal.\n\nFor anyone wishing to incorporate AI into their systems we've created a introductory video into the techniques \nof how to leverage Large Language Models (LLMs) like GPT so they can make informed decisions on which of your \ninternal APIs they should call to accomplish a given task described in natural language.","url":"https://docs.servicestack.net/releases/v6_09#creating-chatgpt-agents-to-call-system-apis","wordCount":122,"lineCount":14,"group":"v6.9","order":3},{"slug":"vue-stable-diffusion","draft":false,"title":"Vue Stable Diffusion","image":"https://servicestack.net/img/whatsnew/v6.9/vuediffusion.png","tags":[],"date":"\/Date(1686009600000-0000)\/","content":"Following [blazordiffusion.com](https://blazordiffusion.com) which was created to showcase ServiceStack's\nBlazor Server and Blazor WASM [project templates and components](https://servicestack.net/blazor), \nwe've rewritten a new Stable Diffusion App in Vue adopting a\n[Simple Modern JavaScript](https://razor-ssg.web-templates.io/posts/javascript) approach to showcase the **Razor SSG**\nProject Template and Tailwind [Vue Component Library](https://docs.servicestack.net/vue/) available at:\n\n

\n https://diffusion.works\n

\n\nVue Diffusion is built differently from other Razor SSG Apps as instead of being pre-rendered from static content \nlike Markdown documents, it's prerendered from https://blazordiffusion.com APIs to render its dynamic \n[Albums](https://diffusion.works/albums/), \n[Top](https://diffusion.works/top) and [Latest](https://diffusion.works/latest) pages at deployment which it does by \nconfiguring the App's Service Gateway to reference external Blazor Diffusion APIs.","url":"https://docs.servicestack.net/releases/v6_09#vue-stable-diffusion","wordCount":137,"lineCount":21,"group":"v6.9","order":4},{"slug":"feature1","draft":false,"title":"New statically generated Razor Pages & Vue website","image":"https://servicestack.net/img/whatsnew/v6.8/servicestack.net-home-1440.png","tags":[],"date":"\/Date(1680048000000-0000)\/","content":"We're celebrating reaching **150M Total Downloads** with a brand new website, rewritten from Ruby's Jekyll and jQuery with an exciting \nnew Razor SSG project template enhanced with Vue 3 components for client interactivity features.\n\nThe new Razor Pages & Markdown powered template takes advantage of the advances made in the last few releases with our npm \ndependency-free approach to [Simple, Modern JavaScript](/posts/javascript), the built-in support for \n[Prerendering Razor Pages](/posts/prerendering) and the rich Tailwind \n[Vue Component Library](https://docs.servicestack.net/vue/) to create an enjoyable experience for creating Fast, FREE, \nbeautiful, CDN-hostable static generated websites & blogs.","url":"https://docs.servicestack.net/releases/v6_08","wordCount":115,"lineCount":13,"group":"v6.8"},{"slug":"feature2","draft":false,"title":"New Razor Pages & Markdown powered static website","image":"https://servicestack.net/img/whatsnew/v6.8/razor-ssg.png","tags":[],"date":"\/Date(1680048000000-0000)\/","content":"We're excited to announce our new [razor-ssg](https://razor-ssg.web-templates.io) project template - a Razor Pages powered Markdown \nalternative to Ruby's Jekyll & Next.js that's ideal for generating static websites & blogs using C#, Razor Pages & Markdown.\n\nIt's now available FREE to all .NET Developers wanting to creating Fast, Beautiful Static Websites & Blogs with Razor Pages. \nIt's FREE to create, FREE to host on GitHub Pages CDN and also designed to support running FREE from any local .NET Installs \nor IDEs where it can be maintained in [GitHub Codespaces](https://github.com/features/codespaces) that you can do entirely from an iPad.","url":"https://docs.servicestack.net/releases/v6_08#razor-ssg","wordCount":117,"lineCount":12,"group":"v6.8"},{"slug":"feature3","draft":false,"title":"Streamlined Development for creating Flutter Apps","image":"https://servicestack.net/img/whatsnew/v6.8/flutter-todos.jpg","tags":[],"date":"\/Date(1680048000000-0000)\/","content":"We've greatly improved the end-to-end development experience of creating Flutter Mobile Apps that integrate with your ServiceStack APIs. \nTo demonstrate the seamless development experience, we've created a [video walk through](https://www.youtube.com/watch?v=t4WcXo4Vnio) \ncreating a new Blazor Server project that we use **mix flutter** to create a new Flutter App that we can use to quickly build \na Mobile App to call its existing Todo .NET APIs using the built-in [Typed Dart DTOs](https://docs.servicestack.net/dart-add-servicestack-reference) integration.\n\nThis release also includes improvements to generated Dart DTOs and servicestack Dart client library with new simplified APIs\nthat greatly improves usage in Reactive UIs by encapsulates Successful and Failed API Responses in a single `ApiResult` \nvalue which can be passed down and bound to reactive components without any inhibitive `try/catch` statements.","url":"https://docs.servicestack.net/releases/v6_08#flutter","wordCount":141,"lineCount":13,"group":"v6.8"},{"slug":"feature4","draft":false,"title":"Improved workflow for creating Flutter gRPC Apps","image":"https://servicestack.net/img/whatsnew/v6.8/flutter-grpc.jpg","tags":[],"date":"\/Date(1680048000000-0000)\/","content":"We've also improved the development experience for developers who prefer or have existing investments in gRPC will be able to \nbenefit from the improved development experience with **mix flutter-grpc** which works like **mix flutter** but instead \nadds a new Flutter gRPC App to an existing ServiceStack grpc project, with pre-configured gRPC integrations. \n\nTo demonstrate this productive workflow we've [created a new video](https://www.youtube.com/watch?v=fgts6sQ2Ags) which walks \nthrough the process of creating a new Flutter App from scratch, adding a Flutter gRPC App to an existing grpc .NET project, \nand using **mix flutter-grpc** to configure the Flutter App to work with ServiceStack's gRPC Services.","url":"https://docs.servicestack.net/releases/v6_08#flutter-grpc","wordCount":118,"lineCount":12,"group":"v6.8"},{"slug":"feature1","draft":false,"title":"New Auto API HTML Page for all APIs!","image":"https://servicestack.net/img/whatsnew/v6.7/autohtml-preview.png","tags":[],"date":"\/Date(1678752000000-0000)\/","content":"The new Auto HTML Page is the best way to visualize, inspect and integrate with your APIs which provides instant utility for API consumers in consuming your APIs with a built-in API Response Visualizer, JSON syntax highlighting, integrated Postman-like UI and API SDK integration all-in-one.\n\nA nice benefit of ServiceStack's API Design is that consuming APIs are fundamentally all done the same way in all languages, which just requires adding a dependency containing a generic ServiceClient which can be used to call any ServiceStack API using the typed DTOs copied directly from the API docs page to enable an end-to-end typed API without any external tooling or build steps.","url":"https://docs.servicestack.net/releases/v6_07","wordCount":125,"lineCount":9,"group":"v6.7"},{"slug":"feature2","draft":false,"title":"Vue AutoQueryGrid Component for Auto CRUD UIs","image":"https://servicestack.net/img/whatsnew/v6.7/gallery-contacts.png","tags":[],"date":"\/Date(1678752000000-0000)\/","content":"The new AutoQueryGrid component is the last high-productivity component missing from the Vue Tailwind Component Library to reach feature parity with Blazor Tailwind Component Library.\n\nIt enables an Effortless CRUD UI without any external dependencies, tooling or build steps, generating a capability-based UI for the currently authenticated user, enabling full CRUD functionality through the App's auth-protected AutoQuery APIs, validated by the APIs Declarative Validation Rules utilizing optimal Form Inputs for each C# property type with contextual validation binding, that displays its results in a rich formatted data grid customized with APIs Declarative UI Attributes.","url":"https://docs.servicestack.net/releases/v6_07#autoquerygrid","wordCount":108,"lineCount":10,"group":"v6.7"},{"slug":"feature3","draft":false,"title":"New Vue 3 Locode, API Explorer & Admin UIs","image":"https://servicestack.net/img/whatsnew/v6.7/new-vue3-uis.png","tags":[],"date":"\/Date(1678752000000-0000)\/","content":"With access to all components needed, we've taken this opportunity to modernize all of ServiceStack's built-in UI's that were previously written with petite-vue and have rewritten them with Vue 3 and the Vue Components Library, which has become our preferred UI technology stack for all of ServiceStack's built-in UIs.\n\nUltimately the new Vue 3 UIs should appeal to a lot more use-cases with better reuse and customizability using the full Vue 3 framework and 3rd Party ecosystem for creating more compelling and interactive UIs.","url":"https://docs.servicestack.net/releases/v6_07#new-locode-api-explorer-admin-uis-now-in-vue-3","wordCount":100,"lineCount":9,"group":"v6.7"},{"slug":"feature4","draft":false,"title":"New API Index Page","image":"https://servicestack.net/img/whatsnew/v6.7/api-gallery.png","tags":[],"date":"\/Date(1678752000000-0000)\/","content":"The `/api` route is now being used as an opportunity to improve API Discovery by returning an App's public APIs grouped by user-defined tags with direct links to the API endpoint, viewing it in API Explorer and in Locode for AutoQuery APIs.","url":"https://docs.servicestack.net/releases/v6_07#api-index","wordCount":53,"lineCount":7,"group":"v6.7"},{"slug":"feature1","draft":false,"title":"New Tailwind Razor Pages & MVC Templates","image":"https://servicestack.net/img/whatsnew/v6.6/vue-mjs.png","tags":[],"date":"\/Date(1675814400000-0000)\/","content":"The new Tailwind Razor Pages & MVC Templates enable rapid development of Modern Tailwind Apps without the pitfalls plaguing SPA development:\n\n- **[vue-mjs](https://vue-mjs.web-templates.io)** - Flagship Vue.mjs template with OrmLite, AutoQuery, boosted htmx links & static pre-rendered blogs\n- **[razor-tailwind](https://razor-tailwind.web-templates.io)** - Simple Razor Pages Template without DB or pre-rendering\n- **[mvc-tailwind](https://mvc-tailwind.web-templates.io)** - Want to use MVC Identity Auth and Entity Framework\n- **[web-tailwind](https://web-tailwind.web-templates.io)** - Empty tailwind template with no web framework configured\n- **[vue-vite](https://vue-vite.jamstacks.net)** - Vite + TypeScript in a simpler JAMStack Vite SPA App\n- **[vue-ssg](https://vue-ssg.jamstacks.net)** - Vite + TypeScript in an advanced JAMStack Vite SSG App","url":"https://docs.servicestack.net/releases/v6_06","wordCount":135,"lineCount":14,"group":"v6.6"},{"slug":"feature2","draft":false,"title":"Vue 3 Tailwind Components","image":"https://servicestack.net/img/whatsnew/v6.6/vue-components.png","tags":[],"date":"\/Date(1675814400000-0000)\/","content":"To maximize productivity, all new Vue Tailwind templates are pre-configured to use the feature-rich [Vue 3 Taiwlind Library](https://docs.servicestack.net/vue/).\n\n**@servicestack/vue** is our growing Vue 3 Tailwind component library with a number of rich Tailwind components useful in .NET Web Apps, including DataGrids, Auto Forms, Modals, Slide Overs, Navigational Components, Formatters, standard HTML Form Input controls inc. FileInput, Autocomplete, TagInput - all with integrated contextual validation binding.\n\nIt's our cornerstone library for enabling a highly productive dev model across our Vue.js Tailwind Project templates that we'll be continuing to invest in to unlock even greater productivity - watch this space!","url":"https://docs.servicestack.net/vue/","wordCount":113,"lineCount":11,"group":"v6.6"},{"slug":"feature3","draft":false,"title":"ES6 JS Module Add ServiceStack Reference","image":"https://servicestack.net/img/whatsnew/v6.6/mjs-update-reference-rider.png","tags":[],"date":"\/Date(1675814400000-0000)\/","content":"The new ES6 classes provide a productive type-safe development model during development but can also be referenced as-is in JS Module scripts and run natively in browsers to enable instant typed API integrations without any build tools!\n\nTo achieve this the ES6 classes are annotated with JSDoc type hints in comments which enjoys broad support in IDEs and tools like TypeScript where it can be used to provide type information in JavaScript files.\n\nThey're now a first-class Add ServiceStack Reference language supported language complete with IDE integration in the latest ServiceStack Plugins for VS .NET and JetBrains IDEs.","url":"https://docs.servicestack.net/releases/v6_06#js-module-es6-class-dtos","wordCount":111,"lineCount":11,"group":"v6.6"},{"slug":"feature4","draft":false,"title":"Static prerendered Markdown Razor Pages","image":"https://servicestack.net/img/whatsnew/v6.6/razor-pages-prerendering.png","tags":[],"date":"\/Date(1675814400000-0000)\/","content":"Prerendering static content is a popular technique used by JAMStack Apps to improve the performance, reliability and scalability of Web Apps that's able to save unnecessary computation at runtime by generating static content at deployment which can be optionally hosted from a CDN for even greater performance.\n\nAs it's a valuable performance optimizing technique it's included in the [vue-mjs](https://vue-mjs.web-templates.io) template to show how it can be easily achieved within a Razor Pages App. Since prerendered content is only updated at deployment, it's primarily only useful for static content like markdown powered blogs.\n\nFor those interested in utilizing this optimization we've published details on how this works in the\n**[Prerendering Razor Pages](https://vue-mjs.web-templates.io/blog/prerendering)** blog post.","url":"https://vue-mjs.web-templates.io/posts/prerendering","wordCount":131,"lineCount":11,"group":"v6.6"}],"videos":[{"slug":"video5","draft":false,"title":"Stream processing of data with JSON Lines","tags":["serialization"," servicestack"," jsonl"],"date":"\/Date(1692057600000+0000)\/","content":"In this video, we explore the efficient JSON Lines (JSONL) data format, a favorite among developers and the AI community\nfor handling large datasets. We walk through working with JSON Lines data, including examples for streaming parsers,\nasynchronous parsing with ServiceStack, and integration with Typesense.","url":"https://youtu.be/m0tAfjvJaZg","wordCount":56,"lineCount":9,"group":"apis"},{"slug":"video1","draft":false,"title":"GitHub for Auto Deployments - Kubernetes Not Required","tags":["github-actions","deployment","hosting"],"date":"\/Date(1691452800000+0000)\/","content":"Step by step walkthrough for deploying your App via GitHub Actions and plain old SSH. \nCheap hardware is getting fast enough that a lot of Web Apps don't need sophisticated orchestration tools like Kubernetes, \nso we show how you can use fundamental tools like SSH, Docker Compose and GitHub Actions to do it yourself! \n\nLow traffic Apps & proof of concepts can easily share cost effective server running Linux, \nNginx Reverse Proxy with LetsEncrypt.","url":"https://youtu.be/7dardvqBFbE","wordCount":87,"lineCount":13,"group":"actions"},{"slug":"video4","draft":false,"title":"Load data fast with ADO.NET RDBMS Bulk Insert APIs","tags":["ormlite","db","performance"],"date":"\/Date(1690848000000+0000)\/","content":"OrmLite includes a Bulk Inserts API that encapsulates the most efficient ways for inserting large amounts of data \nin each supported RDBMS. We ran benchmarks across macOS on Apple M2 ARM, Intel Linux VM and Intel Windows 10 to measure \nhow fast they run across popular Operating System platforms.","url":"https://youtu.be/3gO_OEWIyPo","wordCount":64,"lineCount":10,"group":"features","order":4},{"slug":"video5","draft":false,"title":"GPT Agent Feature Plugin Updated with Semantic Kernel","tags":["gpt"],"date":"\/Date(1690848000000+0000)\/","content":"In this video, we delve into the integration of Microsoft's Semantic Kernel with our GPT Meeting Agent to simplify \nand enhance working with Large Language Models with a common abstraction library that allows for easy substitution\nand experimentation with different LLMs.","url":"https://youtu.be/smM-Bs7CxJ8","wordCount":54,"lineCount":11,"group":"features","order":5},{"slug":"video1","draft":false,"title":"Getting Started with OrmLite fast, code-first ORM for .NET","tags":["ormlite","db"],"date":"\/Date(1688428800000+0000)\/","content":"This video walks though getting started with OrmLite - a powerful, fast and easy to use ORM for .NET that \ncan be used in any .NET and .NET Framework App without the complexity of larger ORMs. \n\nIn this tutorial we'll demonstrate the best patterns to use to install, configure and use OrmLite in your Application, \ndefining code-first POCOs, using them to create RDBMS tables and explore how to Create, Query, Update and Delete them \nusing OrmLite's Typed APIs.","url":"https://youtu.be/vUbpwjfEYzg","wordCount":92,"lineCount":13,"group":"features","order":1},{"slug":"video2","draft":false,"title":"Getting Started with ServiceStack.Redis in .NET","tags":["redis"],"date":"\/Date(1687824000000+0000)\/","content":"In this tutorial we explore the basics of Redis, an in-memory database, and its integration in .NET using the ServiceStack.Redis library. \nThe video covers topics such as setting up a Redis server with Docker, understanding the ServiceStack.Redis library, and making \nthe most of Redis data structures in a .NET context. \n\nFurthermore, it also delves into utilizing the async capabilities of ServiceStack, all demonstrated through clear, practical examples.","url":"https://youtu.be/jBdOvTvjyqY","wordCount":82,"lineCount":13,"group":"features","order":2},{"slug":"custom-admin-uis","draft":false,"title":"Build beautiful custom .NET Admin UIs in minutes","tags":["vue","autoquery"],"date":"\/Date(1686700800000+0000)\/","content":"In this video we explore the Server Multi Razor Page and Client rendered Admin UI Pages in the latest .NET\n[vue-mjs](https://vue-mjs.web-templates.io) project template to see how to use the new SidebarLayout and AutoQueryGrid\nVue Tailwind components to build beautiful Admin UI Pages within minutes.","url":"https://youtu.be/wlRA4_owEsc","wordCount":59,"lineCount":10,"group":"vue-projects","order":4},{"slug":"video2","draft":false,"title":"New Disqus OSS self-host alternative for .NET Websites","tags":["creatorkit","posts","tailwind"],"date":"\/Date(1686268800000+0000)\/","content":"In this video we explore how we can use CreatorKit - a self-hosting alternative to Disqus to add comments, voting\nand moderation to any existing page or blog post.\n\nCreatorKit is especially useful for adding dynamic post comment and voting features to Jamstack and other\nstatically generated websites which can continually be statically pre-rendered and hosted on CDN's whilst its \ndynamic features are powered by an external CreatorKit instance.","url":"https://youtu.be/lgpl-VjxtdU","wordCount":79,"lineCount":12,"group":"creatorkit"},{"slug":"video1","draft":false,"title":"New Mailchimp self-host mail management alternative","tags":["creatorkit","mail","tailwind"],"date":"\/Date(1686182400000+0000)\/","content":"In this video we introduce CreatorKit an OSS self-hosting alternative to Mailchimp for managing mailing lists,\nnewsletter subscriptions, email templating, marketing campaigns & more whose tailwind components can be easily \nintegrated into any existing website.\n\nIt's an ideal companion for .NET Apps looking to manage their mailinglist and newsletter subscribers in an\nisolated customizable .NET App with support for creating custom email layouts, templates and mail campaigns.","url":"https://youtu.be/_qDVtfcHf14","wordCount":75,"lineCount":12,"group":"creatorkit"},{"slug":"video1","draft":false,"title":"Bring static Xkcd dataset to life with AutoQuery","tags":["autoquery"," razor-pages"," ssg"," tailwind"],"date":"\/Date(1683763200000+0000)\/","content":"In this video, we demonstrate how to use AutoQuery to turn a static XKCD comic dataset from Hugging Face into a Web API, \naddressing common issues of siloed data.\n\nBy creating well-defined AutoQuery APIs, we make the data more accessible and enable efficient data integrations \nfor rapid creation of production Web Apps which we demonstrate in new lightweight a Razor SSG Vue App.","url":"https://youtu.be/CrKtXVrPj8Q","wordCount":78,"lineCount":11,"group":"autoquery"},{"slug":"video1","draft":false,"title":"Using Razor SSG to Create Websites in GitHub Codespaces","tags":["razor-pages"," ssg"," tailwind"," codespaces"],"date":"\/Date(1680048000000+0000)\/","content":"This video takes an in-depth look at the [razor-ssg](https://razor-ssg.web-templates.io) ServiceStack template, a powerful tool that \nharnesses the power of .NET Razor Pages to provide seamless static site generation (SSG) capabilities \n\nWith GitHub Codespaces integration, you can develop, test, and manage your application all within your browser, eliminating the need \nfor a dedicated development environment and expediting your workflow, which can all be done on the go from an iPad","url":"https://youtu.be/MRQMBrXi5Sc","wordCount":88,"lineCount":12,"group":"projects"},{"slug":"razor-ssg","draft":false,"title":"Using Razor SSG to Create Websites in GitHub Codespaces","tags":["razor-pages","ssg","markdown","codespaces"],"date":"\/Date(1680048000000+0000)\/","content":"This video takes an in-depth look at the [razor-ssg](https://razor-ssg.web-templates.io) ServiceStack template, a powerful tool that \nharnesses the power of .NET Razor Pages to provide seamless static site generation (SSG) capabilities \n\nWith GitHub Codespaces integration, you can develop, test, and manage your application all within your browser, eliminating the need \nfor a dedicated development environment and expediting your workflow, which can all be done on the go from an iPad","url":"https://youtu.be/MRQMBrXi5Sc","wordCount":86,"lineCount":13,"group":"vue-projects","order":3},{"slug":"video1","draft":false,"title":"Fastest way to a working gRPC Server and Flutter solution","tags":["grpc","flutter","android"],"date":"\/Date(1679875200000+0000)\/","content":"In this video we'll walk through configuring Flutter and gRPC .NET Services with the `flutter-grpc` mix template\nto add a new Flutter application using your locally installed **Flutter SDK** to an existing ServiceStack `grpc` project\nthat has been configured to support gRPC services","url":"https://youtu.be/fgts6sQ2Ags","wordCount":55,"lineCount":9,"group":"flutter-grpc"},{"slug":"video1","draft":false,"title":"Flutter Todo App with .NET API, from Scratch in Minutes","tags":["flutter","android","api"],"date":"\/Date(1679875200000+0000)\/","content":"This video starts from scratch, walking through installing Flutter SDK, \nbefore adding a new native Flutter App to a new .NET Blazor Server project -\ngiving our existing TODO Blazor Web App new native iOS & Android native UIs\n\nNext, we'll demonstrate the iterative development workflow of making changes \nto backend .NET APIs that's easily kept in-sync with our clients Dart DTOs\nfrom within Android Studio or command-line","url":"https://youtu.be/t4WcXo4Vnio","wordCount":79,"lineCount":13,"group":"flutter"},{"slug":"video2","draft":false,"title":"Use Flutter to build a Bookings App Fast","tags":["flutter","android","api"],"date":"\/Date(1679875200000+0000)\/","content":"In this video, we'll show how we can rapidly develop a new Flutter Android Bookings App\nadded to a new [vue-mjs](https://vue-mjs.web-templates.io) .NET Project using `x mix flutter`\n\nNext, we'll dive into the development process, where we'll demonstrate the productivity\nof calling typed .NET APIs using typed Dart DTOs for end-to-end typed integrations\nthat can be effortlessly updated from within Android Studio","url":"https://youtu.be/eMbwaMuIk84","wordCount":72,"lineCount":13,"group":"flutter"},{"slug":"video1","draft":false,"title":"Instantly Manage your data using AutoQueryGrid Vue","tags":["vue","autoquery"],"date":"\/Date(1678924800000+0000)\/","content":"This walkthrough explores the ServiceStack Vue 3 library and the functionality of the AutoQueryGrid component. The AutoQueryGrid component simplifies the integration of AutoQuery services by generating a customizable UI. \n\nBy following this guide, you'll learn how to effectively utilize these tools to enhance your application's user interface and overall user experience.","url":"https://youtu.be/znCoC-Ct0Ps","wordCount":63,"lineCount":10,"group":"vue"},{"slug":"video1","draft":false,"title":"Preview APIs with the Auto Html API Page","tags":["ui","api"],"date":"\/Date(1678665600000+0000)\/","content":"The Auto HTML Page provides instant utility for API consumers in consuming your APIs with a built-in \nAPI Response Visualizer, JSON syntax highlighting, integrated Postman-like UI and API SDK integration all-in-one.\n\nPowered by Vue 3 and the ServiceStack [Vue library](https://docs.servicestack.net/vue/), it's also highly customizable.","url":"https://youtu.be/3gjisRVqhLo","wordCount":61,"lineCount":11,"group":"ui-autohtml"},{"slug":"video2","draft":false,"title":"Vue 3 Tailwind Components Library","tags":["vue","autoquery"],"date":"\/Date(1676332800000+0000)\/","content":"In this video, we demonstrate using the @servicestack/vue components library for Vue.js 3 Multipage Apps (MPAs) along with the `vue-mjs` template. \n\nThe template illustrates building content-heavy or complex sites while avoiding the intricacies of Single Page Apps (SPAs) through the use of JavaScript Modules, Tailwind, Vue.js, Razor Pages, and ServiceStack.","url":"https://youtu.be/YIa0w6whe2U","wordCount":61,"lineCount":9,"group":"vue"}],"posts":[{"slug":"cloud-value-between-architectures","draft":false,"title":"Should .NET Apps switch to ARM?","summary":"Evaluating the cost and performance of ARM vs x86 in AWS, Azure, and Hetzner","image":"https://images.unsplash.com/photo-1587845323226-bad89242c735?crop=entropy&fit=crop&h=1000&w=2000","author":"Darren Reid","tags":["dotnet"," hosting"," arm"," performance"],"date":"\/Date(1693180800000-0000)\/","url":"https://servicestack.net/posts/cloud-value-between-architectures","wordCount":3264,"lineCount":394},{"slug":"razor-ssg-new-blog-features","draft":false,"title":"New Blogging features in Razor SSG","summary":"Explore the new Blogging Features in Razor SSG","image":"https://images.unsplash.com/photo-1486312338219-ce68d2c6f44d?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["razor"," markdown"," blog"," dev"],"date":"\/Date(1692748800000-0000)\/","url":"https://servicestack.net/posts/razor-ssg-new-blog-features","wordCount":1296,"lineCount":337},{"slug":"jsonl-format","draft":false,"title":"Exploring the new streamable JSON Lines Format","summary":"A dive into the JSON Lines format and how to use it in ServiceStack","image":"https://images.unsplash.com/photo-1687042268541-5cc60ad9d3de?crop=entropy&fit=crop&h=1000&w=2000","author":"Darren Reid","tags":["serialization"," servicestack"," jsonl"],"date":"\/Date(1692057600000-0000)\/","url":"https://servicestack.net/posts/jsonl-format","wordCount":1656,"lineCount":217},{"slug":"kubernetes_not_required","draft":false,"title":"Using GitHub for Auto Deployments - Kubernetes Not Required","summary":"A cost-effective and straightforward web app deployment pattern using GitHub and a single Linux server","image":"https://images.unsplash.com/photo-1667372459510-55b5e2087cd0?crop=entropy&fit=crop&h=1000&w=2000","author":"Darren Reid","tags":["github-actions"," devops"," hosting"],"date":"\/Date(1691452800000-0000)\/","url":"https://servicestack.net/posts/kubernetes_not_required","wordCount":5292,"lineCount":693},{"slug":"bulk-insert-performance","draft":false,"title":"Which RDBMS has the fastest .NET Bulk Insert implementation?","summary":"Measuring the different performance of RDBMS Bulk Insert implementations","image":"https://images.unsplash.com/photo-1517026575980-3e1e2dedeab4?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["db"," dev"," dotnet"],"date":"\/Date(1690761600000-0000)\/","url":"https://servicestack.net/posts/bulk-insert-performance","wordCount":6965,"lineCount":1070},{"slug":"postgres-mysql-sqlserver-on-apple-silicon","draft":false,"title":"Install PostgreSQL, MySql and SQL Server on Apple Silicon","summary":"Easiest way to install PostgreSQL, MySql and SQL Server on macOS running Apple Silicon's M2","image":"https://images.unsplash.com/photo-1517663404855-6f96c7aa20e2?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["db"," dev"],"date":"\/Date(1690243200000-0000)\/","url":"https://servicestack.net/posts/postgres-mysql-sqlserver-on-apple-silicon","wordCount":1673,"lineCount":328},{"slug":"semantic-kernel-gptmeetngs","draft":false,"title":"Trying Microsoft's Semantic Kernel","summary":"Incorporating the Semantic Kernel into our GPT Meeting Agent gives developers more flexibility when working with LLMs","image":"https://images.unsplash.com/photo-1579548122080-c35fd6820ecb?crop=entropy&fit=crop&h=1000&w=2000","author":"Darren Reid","tags":["dotnet"," ai"," semantic-kernel"," gpt"],"date":"\/Date(1689638400000-0000)\/","url":"https://servicestack.net/posts/semantic-kernel-gptmeetngs","wordCount":834,"lineCount":54},{"slug":"razor-press","draft":false,"title":"Introducing Razor Press","summary":"Markdown & Razor Pages Static Site Generator for beautiful fast Content & Documentation","image":"https://images.unsplash.com/photo-1681301968680-fe46a0cd51be?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["razor"," markdown"," blog"," dev"],"date":"\/Date(1689552000000-0000)\/","url":"https://servicestack.net/posts/razor-press","wordCount":946,"lineCount":162},{"slug":"using-json-patch","draft":false,"title":"JSON Patch secrets into appsettings.json","summary":"Simplify managing App secrets by JSON patching them into your appsettings.json with during deployments","image":"https://images.unsplash.com/photo-1563089145-599997674d42?crop=entropy&fit=crop&h=1000&w=2000","author":"Darren Reid","tags":["devops"," github-actions"],"date":"\/Date(1689033600000-0000)\/","url":"https://servicestack.net/posts/using-json-patch","wordCount":670,"lineCount":135},{"slug":"new_razor_ssg_docs","draft":false,"title":"New Razor SSG generated docs.servicestack.net","summary":"The new docs.servicestack.net website is now generated with Razor SSG - now with Dark Mode!","image":"https://images.unsplash.com/photo-1526243741027-444d633d7365?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["razor"," ssg"," documentation"],"date":"\/Date(1688947200000-0000)\/","url":"https://servicestack.net/posts/new_razor_ssg_docs","wordCount":750,"lineCount":87},{"slug":"vue-stable-diffusion","draft":false,"title":"Vue Stable Diffusion","summary":"Rewriting Blazor Diffussion image generation & album catalog in Vue & Razor SSG","image":"https://images.unsplash.com/photo-1573490647695-2892d0bf89e7?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["vue"," tailwind"],"date":"\/Date(1686787200000-0000)\/","url":"https://servicestack.net/posts/vue-stable-diffusion","wordCount":1057,"lineCount":209},{"slug":"admin-uis","draft":false,"title":"Build Beautiful Admin UIs, Fast","summary":"Taking a look at the new features in Vue Razor Pages template to build Admin UIs, Fast","image":"https://images.unsplash.com/photo-1667906962043-a3e82dea23a3?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["vue"," tailwind"," admin"],"date":"\/Date(1686614400000-0000)\/","url":"https://servicestack.net/posts/admin-uis","wordCount":1879,"lineCount":364},{"slug":"creatorkit","draft":false,"title":"Introducing CreatorKit","summary":"Exploring CreatorKit - an OSS Self-Hosting alternative to Mailchimp and Disqus","image":"https://images.unsplash.com/photo-1493723843671-1d655e66ac1c?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["creatorkit"," marketing"," publishing"],"date":"\/Date(1686182400000-0000)\/","url":"https://servicestack.net/posts/creatorkit","wordCount":1348,"lineCount":209},{"slug":"chat-gpt-agents","draft":false,"title":"Creating ChatGPT Agents to call System APIs","summary":"A walkthrough of how to enable Large Language Model 'Agents' with access to your own ServiceStack APIs","image":"https://images.unsplash.com/photo-1675271591211-126ad94e495d?crop=entropy&fit=crop&h=1000&w=2000","author":"Darren Reid","tags":["servicestack"," gpt"," chatbot"," ai"],"date":"\/Date(1683849600000-0000)\/","url":"https://servicestack.net/posts/chat-gpt-agents","wordCount":1952,"lineCount":273},{"slug":"autoquery-xkcd","draft":false,"title":"Bringing xkcd static dataset to life with AutoQuery","summary":"Unsiloing data quickly with AutoQuery to make your datasets available from queryable Web APIs","image":"./img/posts/autoquery-xkcd/drawing-xkcd-upscaled.jpg","author":"Darren Reid","tags":["autoquery"," db"," dev"," huggingface"," vue"],"date":"\/Date(1681516800000-0000)\/","url":"https://servicestack.net/posts/autoquery-xkcd","wordCount":3352,"lineCount":551},{"slug":"razor-ssg","draft":false,"title":"Introducing Razor SSG","summary":"Create fast, beautiful statically rendered Razor Websites & Blogs","image":"https://images.unsplash.com/photo-1579767684138-a57e917d30aa?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["razor"," markdown"," blog"," dev"],"date":"\/Date(1680134400000-0000)\/","url":"https://servicestack.net/posts/razor-ssg","wordCount":3070,"lineCount":596},{"slug":"new_razor_ssg_website","draft":false,"title":"New Razor SSG generated servicestack.net","summary":"Celebrating 150M Downloads with a new Razor SSG generated Website","image":"https://images.unsplash.com/photo-1475669698648-2f144fcaaeb1?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["razor"," ssg"," website"],"date":"\/Date(1680048000000-0000)\/","url":"https://servicestack.net/posts/new_razor_ssg_website","wordCount":567,"lineCount":77},{"slug":"javascript","draft":false,"title":"Simple, Modern JavaScript","summary":"Learn about JS Modules, Vue 3 and available rich UI Components","image":"https://images.unsplash.com/photo-1497515114629-f71d768fd07c?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["js"," dev"],"date":"\/Date(1675209600000-0000)\/","url":"https://servicestack.net/posts/javascript","wordCount":3118,"lineCount":612},{"slug":"prerendering","draft":false,"title":"Prerendering Razor Pages","summary":"Improving Blog Performance with Prerendering","image":"https://images.unsplash.com/photo-1522526886914-6e8d4fd91399?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["c#"," dev"," markdown"],"date":"\/Date(1673395200000-0000)\/","url":"https://servicestack.net/posts/prerendering","wordCount":1160,"lineCount":235},{"slug":"rider","draft":false,"title":"Develop using JetBrains Rider","summary":"Setting up & exploring development workflow in Rider","image":"https://images.unsplash.com/photo-1472289065668-ce650ac443d2?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["c#"," dev"],"date":"\/Date(1673395200000-0000)\/","url":"https://servicestack.net/posts/rider","wordCount":472,"lineCount":77},{"slug":"vs","draft":false,"title":"Develop using Visual Studio","summary":"Exploring development workflow in VS Code and Visual Studio .NET","image":"https://images.unsplash.com/photo-1513542789411-b6a5d4f31634?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["c#"," dev"],"date":"\/Date(1673308800000-0000)\/","url":"https://servicestack.net/posts/vs","wordCount":1325,"lineCount":76},{"slug":"jamstacks_hosting","draft":false,"title":"Jamstack Hosting Costs @ $.40 /mo","summary":"Exploring cost & scalability benefits of hybrid CDN & .NET Apps","image":"https://images.unsplash.com/photo-1506399309177-3b43e99fead2?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["dev"," hosting"," devops"],"date":"\/Date(1672617600000-0000)\/","url":"https://servicestack.net/posts/jamstacks_hosting","wordCount":3054,"lineCount":83},{"slug":"deploy","draft":false,"title":"Deployment with GitHub Actions","summary":"Configuring your GitHub repo for SSH and CDN deployments","image":"https://images.unsplash.com/photo-1485841890310-6a055c88698a?crop=entropy&fit=crop&h=1000&w=2000","author":"Darren Reid","tags":["github-actions"," devops"," hosting"],"date":"\/Date(1672531200000-0000)\/","url":"https://servicestack.net/posts/deploy","wordCount":724,"lineCount":107}]} \ No newline at end of file diff --git a/meta/2023/pages.json b/meta/2023/pages.json index 8a42ceb2..428bdbe0 100644 --- a/meta/2023/pages.json +++ b/meta/2023/pages.json @@ -1 +1 @@ -[{"slug":"community-rules","draft":false,"title":"Community Rules","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/community-rules","wordCount":412,"lineCount":37},{"slug":"links","draft":false,"title":"Quick Shortcuts to ServiceStack Sites","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/links","wordCount":52,"lineCount":13},{"slug":"mail-preferences","draft":false,"title":"Manage your mail preferences","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/mail-preferences","wordCount":113,"lineCount":13},{"slug":"privacy","draft":false,"title":"Privacy Policy for ServiceStack, Inc","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/privacy","wordCount":1151,"lineCount":92},{"slug":"register","draft":false,"title":"License Registration","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/register","wordCount":327,"lineCount":76},{"slug":"signup-confirmed","draft":false,"title":"Welcome to ServiceStack Newsletter","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/signup-confirmed","wordCount":53,"lineCount":8},{"slug":"terms","draft":false,"title":"ServiceStack License Agreement","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/terms","wordCount":3036,"lineCount":136},{"slug":"creatorkit/about","draft":false,"title":"About","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/creatorkit/about","wordCount":597,"lineCount":100,"order":1},{"slug":"creatorkit/install","draft":false,"title":"Install","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/creatorkit/install","wordCount":1751,"lineCount":263,"order":2},{"slug":"creatorkit/customize","draft":false,"title":"Customize","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/creatorkit/customize","wordCount":463,"lineCount":125,"order":3},{"slug":"creatorkit/components","draft":false,"title":"Components","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/creatorkit/components","wordCount":855,"lineCount":195,"order":4},{"slug":"creatorkit/integrations","draft":false,"title":"Integrations","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/creatorkit/integrations","wordCount":107,"lineCount":29,"order":5},{"slug":"creatorkit/portal-overview","draft":false,"title":"Overview","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/creatorkit/portal-overview","wordCount":163,"lineCount":40,"group":"Portal","order":6},{"slug":"creatorkit/portal-messages","draft":false,"title":"Messages","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/creatorkit/portal-messages","wordCount":1047,"lineCount":250,"group":"Portal","order":7},{"slug":"creatorkit/portal-mailruns","draft":false,"title":"Mail Runs","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/creatorkit/portal-mailruns","wordCount":1303,"lineCount":277,"group":"Portal","order":8},{"slug":"creatorkit/portal-posts","draft":false,"title":"Posts","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/creatorkit/portal-posts","wordCount":180,"lineCount":28,"group":"Portal","order":9}] \ No newline at end of file +[{"slug":"community-rules","draft":false,"title":"Community Rules","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/community-rules","wordCount":412,"lineCount":37},{"slug":"links","draft":false,"title":"Quick Shortcuts to ServiceStack Sites","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/links","wordCount":52,"lineCount":13},{"slug":"mail-preferences","draft":false,"title":"Manage your mail preferences","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/mail-preferences","wordCount":113,"lineCount":13},{"slug":"privacy","draft":false,"title":"Privacy Policy for ServiceStack, Inc","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/privacy","wordCount":1151,"lineCount":92},{"slug":"register","draft":false,"title":"License Registration","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/register","wordCount":327,"lineCount":76},{"slug":"signup-confirmed","draft":false,"title":"Welcome to ServiceStack Newsletter","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/signup-confirmed","wordCount":53,"lineCount":8},{"slug":"terms","draft":false,"title":"ServiceStack License Agreement","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/terms","wordCount":3036,"lineCount":136},{"slug":"creatorkit/about","draft":false,"title":"About","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/creatorkit/about","wordCount":597,"lineCount":100,"order":1},{"slug":"creatorkit/install","draft":false,"title":"Install","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/creatorkit/install","wordCount":1751,"lineCount":263,"order":2},{"slug":"creatorkit/customize","draft":false,"title":"Customize","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/creatorkit/customize","wordCount":463,"lineCount":125,"order":3},{"slug":"creatorkit/components","draft":false,"title":"Components","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/creatorkit/components","wordCount":855,"lineCount":195,"order":4},{"slug":"creatorkit/integrations","draft":false,"title":"Integrations","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/creatorkit/integrations","wordCount":107,"lineCount":29,"order":5},{"slug":"creatorkit/portal-overview","draft":false,"title":"Overview","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/creatorkit/portal-overview","wordCount":163,"lineCount":40,"group":"Portal","order":6},{"slug":"creatorkit/portal-messages","draft":false,"title":"Messages","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/creatorkit/portal-messages","wordCount":1047,"lineCount":250,"group":"Portal","order":7},{"slug":"creatorkit/portal-mailruns","draft":false,"title":"Mail Runs","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/creatorkit/portal-mailruns","wordCount":1303,"lineCount":277,"group":"Portal","order":8},{"slug":"creatorkit/portal-posts","draft":false,"title":"Posts","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/creatorkit/portal-posts","wordCount":180,"lineCount":28,"group":"Portal","order":9}] \ No newline at end of file diff --git a/meta/all.json b/meta/all.json index d9ead7bc..0c9ef9cc 100644 --- a/meta/all.json +++ b/meta/all.json @@ -1 +1 @@ -{"pages":[{"slug":"community-rules","draft":false,"title":"Community Rules","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/community-rules","wordCount":412,"lineCount":37},{"slug":"links","draft":false,"title":"Quick Shortcuts to ServiceStack Sites","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/links","wordCount":52,"lineCount":13},{"slug":"mail-preferences","draft":false,"title":"Manage your mail preferences","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/mail-preferences","wordCount":113,"lineCount":13},{"slug":"privacy","draft":false,"title":"Privacy Policy for ServiceStack, Inc","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/privacy","wordCount":1151,"lineCount":92},{"slug":"register","draft":false,"title":"License Registration","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/register","wordCount":327,"lineCount":76},{"slug":"signup-confirmed","draft":false,"title":"Welcome to ServiceStack Newsletter","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/signup-confirmed","wordCount":53,"lineCount":8},{"slug":"terms","draft":false,"title":"ServiceStack License Agreement","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/terms","wordCount":3036,"lineCount":136},{"slug":"creatorkit/about","draft":false,"title":"About","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/creatorkit/about","wordCount":597,"lineCount":100,"order":1},{"slug":"creatorkit/install","draft":false,"title":"Install","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/creatorkit/install","wordCount":1751,"lineCount":263,"order":2},{"slug":"creatorkit/customize","draft":false,"title":"Customize","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/creatorkit/customize","wordCount":463,"lineCount":125,"order":3},{"slug":"creatorkit/components","draft":false,"title":"Components","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/creatorkit/components","wordCount":855,"lineCount":195,"order":4},{"slug":"creatorkit/integrations","draft":false,"title":"Integrations","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/creatorkit/integrations","wordCount":107,"lineCount":29,"order":5},{"slug":"creatorkit/portal-overview","draft":false,"title":"Overview","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/creatorkit/portal-overview","wordCount":163,"lineCount":40,"group":"Portal","order":6},{"slug":"creatorkit/portal-messages","draft":false,"title":"Messages","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/creatorkit/portal-messages","wordCount":1047,"lineCount":250,"group":"Portal","order":7},{"slug":"creatorkit/portal-mailruns","draft":false,"title":"Mail Runs","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/creatorkit/portal-mailruns","wordCount":1303,"lineCount":277,"group":"Portal","order":8},{"slug":"creatorkit/portal-posts","draft":false,"title":"Posts","tags":[],"date":"\/Date(1693384041954)\/","url":"https://servicestack.net/creatorkit/portal-posts","wordCount":180,"lineCount":28,"group":"Portal","order":9}],"whatsnew":[{"slug":"razor-press","draft":false,"title":"Introducing Razor Press","image":"https://servicestack.net/img/whatsnew/v6.10/razor-press.png","tags":[],"date":"\/Date(1690761600000-0000)\/","content":"Razor Press is a **Razor Pages** and **Markdown** powered alternative to Ruby's Jekyll & Vue's VitePress that's ideal for\ngenerating fast, static content-centric & documentation websites. Inspired by [VitePress](https://vitepress.dev),\nit's designed to effortlessly create documentation around content written in Markdown, rendered using C# Razor Pages\nthat's beautifully styled with [tailwindcss](https://tailwindcss.com) and [@tailwindcss/typography](https://tailwindcss.com/docs/typography-plugin).\n\nThe resulting statically generated HTML pages can be easily deployed anywhere, where it can be hosted by any HTTP Server or CDN.\nBy default it includes GitHub Actions to deploy it your GitHub Repo's **gh-pages** branch where it's hosted for FREE\non [GitHub Pages](https://pages.github.com) CDN which can be easily configured to use your\n[Custom Domain](https://docs.github.com/en/pages/configuring-a-custom-domain-for-your-github-pages-site).","url":"https://docs.servicestack.net/releases/v6_10","wordCount":127,"lineCount":16,"group":"v6.10","order":1},{"slug":"new-in-razor-ssg","draft":false,"title":"New in Razor SSG","image":"https://servicestack.net/img/whatsnew/v6.10/twitter-cards.png","tags":[],"date":"\/Date(1690761600000-0000)\/","content":"The Razor SSG template continues to see improvements for creating richer static websites and Blogs: \n\n - RSS Feed for Blog Posts\n - New Razor Press Markdown Containers\n - Support for Markdown Includes\n - Meta Headers support for Twitter cards and Improved SEO\n - Blog Posts can include rich Vue Components\n - Light and Dark Mode Query Params\n - Threads and Mastodon Links for Blog Authors","url":"https://docs.servicestack.net/releases/v6_10#new-in-razor-ssg","wordCount":77,"lineCount":16,"group":"v6.10","order":2},{"slug":"rdbms-bulk-inserts","draft":false,"title":"RDBMS Bulk Inserts","image":"https://servicestack.net/img/whatsnew/v6.10/bulk-inserts.png","tags":[],"date":"\/Date(1690761600000-0000)\/","content":"The latest release of OrmLite includes Bulk Inserts implementations for each supported RDBMS to support the most \nefficient ways for inserting large amounts of data, which is encapsulated behind OrmLite's new BulkInsert API\nwhich are up to **138x times faster** than traditional single INSERT statements.\n\nIn addition to an optimal default Bulk Insert implementation, it can also be configured to execute batched \nSQL Insert statements with configurable batch sizes which enjoys broad support across all RDBMS's.","url":"https://docs.servicestack.net/releases/v6_10#rdbms-bulk-inserts","wordCount":85,"lineCount":12,"group":"v6.10","order":3},{"slug":"jsonl-data-format","draft":false,"title":"JSON Lines Data Format","image":"https://servicestack.net/img/whatsnew/v6.10/jsonl.png","tags":[],"date":"\/Date(1690761600000-0000)\/","content":"JSON Lines is an efficient JSON data format parseable by streaming parsers and text processing tools like Unix \nshell pipelines, whose streamable properties is making it a popular data format for maintaining large datasets \nlike the large AI datasets maintained on [huggingface.co](https://huggingface.co) that's now accessible on \n[Auto HTML API pages](https://docs.servicestack.net/auto-html-api).\n\nThe JSON Lines data format behaves the same way as the CSV format where it will automatically serialize the \nfirst IEnumerable property, including for all AutoQuery APIs which now benefit from a streamable JSON data format.","url":"https://docs.servicestack.net/releases/v6_10#json-lines-data-format","wordCount":104,"lineCount":13,"group":"v6.10","order":4},{"slug":"creator-kit","draft":false,"title":"Introducing CreatorKit","image":"https://servicestack.net/img/whatsnew/v6.9/creatorkit-splash.png","tags":[],"date":"\/Date(1686009600000-0000)\/","content":"CreatorKit is a simple, customizable, self-hostable alternative solution to using Mailchimp for managing an organization's \nmailing lists, accepting newsletter subscriptions, defining customizable email layouts and templates and sending \nrich HTML emails to your Customers and subscribers using your preferred SMTP provider.\n\nIt also provides a private alternative to using Disqus to enhance websites with a threading and commenting system \non your preferred blog posts and website pages that you want to be able to connect with your community on.","url":"https://docs.servicestack.net/releases/v6_09","wordCount":88,"lineCount":12,"group":"v6.9","order":1},{"slug":"build-admin-uis-fast","draft":false,"title":"Build Admin UIs, Fast","image":"https://servicestack.net/img/whatsnew/v6.9/admin-ui.png","tags":[],"date":"\/Date(1686009600000-0000)\/","content":"The new `` is a high-productivity Vue Component that combined with the `` content\ncan save an invaluable amount of time in being able to rapidly create custom Admin UIs.\n\nThe [vue-mjs](https://vue-mjs.web-templates.io) now includes a [Client Admin UI](https://vue-mjs.web-templates.io/portal/)\nshowing how we can replicate most of Locode's Auto UI in a customizable Vue App from a single \n[index.html](https://github.com/NetCoreTemplates/vue-mjs/blob/main/MyApp/wwwroot/portal/index.html) page. It also includes\nan example of a [Server Rendered Admin UI](https://vue-mjs.web-templates.io/admin/) for those that prefer to develop\nMulti Page Apps with Razor Pages.","url":"https://docs.servicestack.net/releases/v6_09#build-admin-uis-fast","wordCount":103,"lineCount":14,"group":"v6.9","order":2},{"slug":"creating-gpt-agents","draft":false,"title":"Creating ChatGPT Agents to call System APIs","image":"https://servicestack.net/img/whatsnew/v6.9/gptmeetings.jpg","tags":[],"date":"\/Date(1686009600000-0000)\/","content":"We've been working on different patterns of development to enable ChatGPT to leverage an App's ServiceStack APIs \nto solve given tasks. This is done through various prompting techniques which allows the Agent to reason about the \ncontext of the conversation and make decisions to reach for different 'tools' (your APIs) when trying to achieve \na specific goal.\n\nFor anyone wishing to incorporate AI into their systems we've created a introductory video into the techniques \nof how to leverage Large Language Models (LLMs) like GPT so they can make informed decisions on which of your \ninternal APIs they should call to accomplish a given task described in natural language.","url":"https://docs.servicestack.net/releases/v6_09#creating-chatgpt-agents-to-call-system-apis","wordCount":122,"lineCount":14,"group":"v6.9","order":3},{"slug":"vue-stable-diffusion","draft":false,"title":"Vue Stable Diffusion","image":"https://servicestack.net/img/whatsnew/v6.9/vuediffusion.png","tags":[],"date":"\/Date(1686009600000-0000)\/","content":"Following [blazordiffusion.com](https://blazordiffusion.com) which was created to showcase ServiceStack's\nBlazor Server and Blazor WASM [project templates and components](https://servicestack.net/blazor), \nwe've rewritten a new Stable Diffusion App in Vue adopting a\n[Simple Modern JavaScript](https://razor-ssg.web-templates.io/posts/javascript) approach to showcase the **Razor SSG**\nProject Template and Tailwind [Vue Component Library](https://docs.servicestack.net/vue/) available at:\n\n

\n https://diffusion.works\n

\n\nVue Diffusion is built differently from other Razor SSG Apps as instead of being pre-rendered from static content \nlike Markdown documents, it's prerendered from https://blazordiffusion.com APIs to render its dynamic \n[Albums](https://diffusion.works/albums/), \n[Top](https://diffusion.works/top) and [Latest](https://diffusion.works/latest) pages at deployment which it does by \nconfiguring the App's Service Gateway to reference external Blazor Diffusion APIs.","url":"https://docs.servicestack.net/releases/v6_09#vue-stable-diffusion","wordCount":137,"lineCount":21,"group":"v6.9","order":4},{"slug":"feature1","draft":false,"title":"New statically generated Razor Pages & Vue website","image":"https://servicestack.net/img/whatsnew/v6.8/servicestack.net-home-1440.png","tags":[],"date":"\/Date(1680048000000-0000)\/","content":"We're celebrating reaching **150M Total Downloads** with a brand new website, rewritten from Ruby's Jekyll and jQuery with an exciting \nnew Razor SSG project template enhanced with Vue 3 components for client interactivity features.\n\nThe new Razor Pages & Markdown powered template takes advantage of the advances made in the last few releases with our npm \ndependency-free approach to [Simple, Modern JavaScript](/posts/javascript), the built-in support for \n[Prerendering Razor Pages](/posts/prerendering) and the rich Tailwind \n[Vue Component Library](https://docs.servicestack.net/vue/) to create an enjoyable experience for creating Fast, FREE, \nbeautiful, CDN-hostable static generated websites & blogs.","url":"https://docs.servicestack.net/releases/v6_08","wordCount":115,"lineCount":13,"group":"v6.8"},{"slug":"feature2","draft":false,"title":"New Razor Pages & Markdown powered static website","image":"https://servicestack.net/img/whatsnew/v6.8/razor-ssg.png","tags":[],"date":"\/Date(1680048000000-0000)\/","content":"We're excited to announce our new [razor-ssg](https://razor-ssg.web-templates.io) project template - a Razor Pages powered Markdown \nalternative to Ruby's Jekyll & Next.js that's ideal for generating static websites & blogs using C#, Razor Pages & Markdown.\n\nIt's now available FREE to all .NET Developers wanting to creating Fast, Beautiful Static Websites & Blogs with Razor Pages. \nIt's FREE to create, FREE to host on GitHub Pages CDN and also designed to support running FREE from any local .NET Installs \nor IDEs where it can be maintained in [GitHub Codespaces](https://github.com/features/codespaces) that you can do entirely from an iPad.","url":"https://docs.servicestack.net/releases/v6_08#razor-ssg","wordCount":117,"lineCount":12,"group":"v6.8"},{"slug":"feature3","draft":false,"title":"Streamlined Development for creating Flutter Apps","image":"https://servicestack.net/img/whatsnew/v6.8/flutter-todos.jpg","tags":[],"date":"\/Date(1680048000000-0000)\/","content":"We've greatly improved the end-to-end development experience of creating Flutter Mobile Apps that integrate with your ServiceStack APIs. \nTo demonstrate the seamless development experience, we've created a [video walk through](https://www.youtube.com/watch?v=t4WcXo4Vnio) \ncreating a new Blazor Server project that we use **mix flutter** to create a new Flutter App that we can use to quickly build \na Mobile App to call its existing Todo .NET APIs using the built-in [Typed Dart DTOs](https://docs.servicestack.net/dart-add-servicestack-reference) integration.\n\nThis release also includes improvements to generated Dart DTOs and servicestack Dart client library with new simplified APIs\nthat greatly improves usage in Reactive UIs by encapsulates Successful and Failed API Responses in a single `ApiResult` \nvalue which can be passed down and bound to reactive components without any inhibitive `try/catch` statements.","url":"https://docs.servicestack.net/releases/v6_08#flutter","wordCount":141,"lineCount":13,"group":"v6.8"},{"slug":"feature4","draft":false,"title":"Improved workflow for creating Flutter gRPC Apps","image":"https://servicestack.net/img/whatsnew/v6.8/flutter-grpc.jpg","tags":[],"date":"\/Date(1680048000000-0000)\/","content":"We've also improved the development experience for developers who prefer or have existing investments in gRPC will be able to \nbenefit from the improved development experience with **mix flutter-grpc** which works like **mix flutter** but instead \nadds a new Flutter gRPC App to an existing ServiceStack grpc project, with pre-configured gRPC integrations. \n\nTo demonstrate this productive workflow we've [created a new video](https://www.youtube.com/watch?v=fgts6sQ2Ags) which walks \nthrough the process of creating a new Flutter App from scratch, adding a Flutter gRPC App to an existing grpc .NET project, \nand using **mix flutter-grpc** to configure the Flutter App to work with ServiceStack's gRPC Services.","url":"https://docs.servicestack.net/releases/v6_08#flutter-grpc","wordCount":118,"lineCount":12,"group":"v6.8"},{"slug":"feature1","draft":false,"title":"New Auto API HTML Page for all APIs!","image":"https://servicestack.net/img/whatsnew/v6.7/autohtml-preview.png","tags":[],"date":"\/Date(1678752000000-0000)\/","content":"The new Auto HTML Page is the best way to visualize, inspect and integrate with your APIs which provides instant utility for API consumers in consuming your APIs with a built-in API Response Visualizer, JSON syntax highlighting, integrated Postman-like UI and API SDK integration all-in-one.\n\nA nice benefit of ServiceStack's API Design is that consuming APIs are fundamentally all done the same way in all languages, which just requires adding a dependency containing a generic ServiceClient which can be used to call any ServiceStack API using the typed DTOs copied directly from the API docs page to enable an end-to-end typed API without any external tooling or build steps.","url":"https://docs.servicestack.net/releases/v6_07","wordCount":125,"lineCount":9,"group":"v6.7"},{"slug":"feature2","draft":false,"title":"Vue AutoQueryGrid Component for Auto CRUD UIs","image":"https://servicestack.net/img/whatsnew/v6.7/gallery-contacts.png","tags":[],"date":"\/Date(1678752000000-0000)\/","content":"The new AutoQueryGrid component is the last high-productivity component missing from the Vue Tailwind Component Library to reach feature parity with Blazor Tailwind Component Library.\n\nIt enables an Effortless CRUD UI without any external dependencies, tooling or build steps, generating a capability-based UI for the currently authenticated user, enabling full CRUD functionality through the App's auth-protected AutoQuery APIs, validated by the APIs Declarative Validation Rules utilizing optimal Form Inputs for each C# property type with contextual validation binding, that displays its results in a rich formatted data grid customized with APIs Declarative UI Attributes.","url":"https://docs.servicestack.net/releases/v6_07#autoquerygrid","wordCount":108,"lineCount":10,"group":"v6.7"},{"slug":"feature3","draft":false,"title":"New Vue 3 Locode, API Explorer & Admin UIs","image":"https://servicestack.net/img/whatsnew/v6.7/new-vue3-uis.png","tags":[],"date":"\/Date(1678752000000-0000)\/","content":"With access to all components needed, we've taken this opportunity to modernize all of ServiceStack's built-in UI's that were previously written with petite-vue and have rewritten them with Vue 3 and the Vue Components Library, which has become our preferred UI technology stack for all of ServiceStack's built-in UIs.\n\nUltimately the new Vue 3 UIs should appeal to a lot more use-cases with better reuse and customizability using the full Vue 3 framework and 3rd Party ecosystem for creating more compelling and interactive UIs.","url":"https://docs.servicestack.net/releases/v6_07#new-locode-api-explorer-admin-uis-now-in-vue-3","wordCount":100,"lineCount":9,"group":"v6.7"},{"slug":"feature4","draft":false,"title":"New API Index Page","image":"https://servicestack.net/img/whatsnew/v6.7/api-gallery.png","tags":[],"date":"\/Date(1678752000000-0000)\/","content":"The `/api` route is now being used as an opportunity to improve API Discovery by returning an App's public APIs grouped by user-defined tags with direct links to the API endpoint, viewing it in API Explorer and in Locode for AutoQuery APIs.","url":"https://docs.servicestack.net/releases/v6_07#api-index","wordCount":53,"lineCount":7,"group":"v6.7"},{"slug":"feature1","draft":false,"title":"New Tailwind Razor Pages & MVC Templates","image":"https://servicestack.net/img/whatsnew/v6.6/vue-mjs.png","tags":[],"date":"\/Date(1675814400000-0000)\/","content":"The new Tailwind Razor Pages & MVC Templates enable rapid development of Modern Tailwind Apps without the pitfalls plaguing SPA development:\n\n- **[vue-mjs](https://vue-mjs.web-templates.io)** - Flagship Vue.mjs template with OrmLite, AutoQuery, boosted htmx links & static pre-rendered blogs\n- **[razor-tailwind](https://razor-tailwind.web-templates.io)** - Simple Razor Pages Template without DB or pre-rendering\n- **[mvc-tailwind](https://mvc-tailwind.web-templates.io)** - Want to use MVC Identity Auth and Entity Framework\n- **[web-tailwind](https://web-tailwind.web-templates.io)** - Empty tailwind template with no web framework configured\n- **[vue-vite](https://vue-vite.jamstacks.net)** - Vite + TypeScript in a simpler JAMStack Vite SPA App\n- **[vue-ssg](https://vue-ssg.jamstacks.net)** - Vite + TypeScript in an advanced JAMStack Vite SSG App","url":"https://docs.servicestack.net/releases/v6_06","wordCount":135,"lineCount":14,"group":"v6.6"},{"slug":"feature2","draft":false,"title":"Vue 3 Tailwind Components","image":"https://servicestack.net/img/whatsnew/v6.6/vue-components.png","tags":[],"date":"\/Date(1675814400000-0000)\/","content":"To maximize productivity, all new Vue Tailwind templates are pre-configured to use the feature-rich [Vue 3 Taiwlind Library](https://docs.servicestack.net/vue/).\n\n**@servicestack/vue** is our growing Vue 3 Tailwind component library with a number of rich Tailwind components useful in .NET Web Apps, including DataGrids, Auto Forms, Modals, Slide Overs, Navigational Components, Formatters, standard HTML Form Input controls inc. FileInput, Autocomplete, TagInput - all with integrated contextual validation binding.\n\nIt's our cornerstone library for enabling a highly productive dev model across our Vue.js Tailwind Project templates that we'll be continuing to invest in to unlock even greater productivity - watch this space!","url":"https://docs.servicestack.net/vue/","wordCount":113,"lineCount":11,"group":"v6.6"},{"slug":"feature3","draft":false,"title":"ES6 JS Module Add ServiceStack Reference","image":"https://servicestack.net/img/whatsnew/v6.6/mjs-update-reference-rider.png","tags":[],"date":"\/Date(1675814400000-0000)\/","content":"The new ES6 classes provide a productive type-safe development model during development but can also be referenced as-is in JS Module scripts and run natively in browsers to enable instant typed API integrations without any build tools!\n\nTo achieve this the ES6 classes are annotated with JSDoc type hints in comments which enjoys broad support in IDEs and tools like TypeScript where it can be used to provide type information in JavaScript files.\n\nThey're now a first-class Add ServiceStack Reference language supported language complete with IDE integration in the latest ServiceStack Plugins for VS .NET and JetBrains IDEs.","url":"https://docs.servicestack.net/releases/v6_06#js-module-es6-class-dtos","wordCount":111,"lineCount":11,"group":"v6.6"},{"slug":"feature4","draft":false,"title":"Static prerendered Markdown Razor Pages","image":"https://servicestack.net/img/whatsnew/v6.6/razor-pages-prerendering.png","tags":[],"date":"\/Date(1675814400000-0000)\/","content":"Prerendering static content is a popular technique used by JAMStack Apps to improve the performance, reliability and scalability of Web Apps that's able to save unnecessary computation at runtime by generating static content at deployment which can be optionally hosted from a CDN for even greater performance.\n\nAs it's a valuable performance optimizing technique it's included in the [vue-mjs](https://vue-mjs.web-templates.io) template to show how it can be easily achieved within a Razor Pages App. Since prerendered content is only updated at deployment, it's primarily only useful for static content like markdown powered blogs.\n\nFor those interested in utilizing this optimization we've published details on how this works in the\n**[Prerendering Razor Pages](https://vue-mjs.web-templates.io/blog/prerendering)** blog post.","url":"https://vue-mjs.web-templates.io/posts/prerendering","wordCount":131,"lineCount":11,"group":"v6.6"},{"slug":"feature1","draft":false,"title":"Blazor Dark Mode Everywhere","image":"https://servicestack.net/img/whatsnew/v6.5/dark-and-light-mode.png","tags":[],"date":"\/Date(1670630400000-0000)\/","content":"Tailwind has revolutionized how we style our Web Apps with its mobile first design system that's dramatically simplified creating maintainable responsive Web Apps. It also excels at adding support for Dark Mode with its first-class dark: modifier allowing the use of standard tailwind classes to specify what elements should look like when viewed in Dark Mode.\n\nWe're happy to announce that Dark Mode support has been added to **all ServiceStack.Blazor Tailwind components** and all Blazor Tailwind project templates where you'll be able to toggle on/off Dark Mode with the new **DarkModeToggle** component.","url":"https://docs.servicestack.net/releases/v6_05","wordCount":104,"lineCount":9,"group":"v6.5"},{"slug":"feature2","draft":false,"title":"New Blazor Components","image":"https://servicestack.net/img/whatsnew/v6.5/blazordiffusion-Autocomplete.png","tags":[],"date":"\/Date(1670630400000-0000)\/","content":"The ServiceStack.Blazor component library continues to expand with exciting new Components and improvements, including:\n\n- **Autocomplete** - Rich content Input to quickly search & select items\n- **TagInput** - UX friendly input for managing a list of strings like words or tags\n- **FormStyle.Card** - Render Auto Forms from POCO classes in a Card Layout\n- **NavList** - Beautiful Nav Links list component with Icons + Descriptions\n- **Colored Buttons** - Render buttons in different primary Tailwind colors\n- **SelectInput Expressions** - Declaratively define Select Input Options\n- **Custom Edit & Create Forms** - Use forms in custom AutoQueryGrids","url":"https://docs.servicestack.net/releases/v6_05#blazor-components","wordCount":103,"lineCount":15,"group":"v6.5"},{"slug":"feature3","draft":false,"title":"Blazor Diffusion","image":"https://servicestack.net/img/whatsnew/v6.5/blazordiffusion.com_splash.png","tags":[],"date":"\/Date(1670630400000-0000)\/","content":"The goal of our increasing Blazor investments is to enable a highly productive and capable platform for rapidly developing a majority of internal Apps CRUD functionality as well as enabling a hybrid development model where the management of Back office supporting tables can be quickly implemented using custom AutoQueryGrid components freeing up developers to be able to focus a majority of their efforts where they add the most value - in the bespoke Blazor UI's optimized customer-facing UX.\n\nTo best demonstrate its potential we've created [blazordiffusion.com](https://blazordiffusion.com) - a new ServiceStack.Blazor App front-end for Stable Diffusion - a deep learning text-to-image model that can generate quality images from a text prompt. It's a great example of Hybrid Development in action where the entire user-facing UI is a bespoke Blazor App that's optimized for creating, searching, cataloging and discovering Stable Diffusion generated images, whilst all its supporting admin tasks to manage the back office tables that power the UI were effortlessly implemented with custom AutoQueryGrid components.","url":"https://docs.servicestack.net/releases/v6_05#blazor-diffusion","wordCount":178,"lineCount":9,"group":"v6.5"},{"slug":"feature4","draft":false,"title":"Universal Blazor API Components","image":"https://servicestack.net/img/whatsnew/v6.5/blazor-universal-components.png","tags":[],"date":"\/Date(1670630400000-0000)\/","content":"The recommendation to access DB's directly in Blazor Server components encourages a more tightly-coupled and less reusable & testable architecture than the traditional well-defined API dev model used in client/server Mobile & Desktop Apps or Web SPA Apps like Blazor WASM.\n\nTo achieve the best of both worlds, we've enabled support for utilizing the In Process Service Gateway in Blazor Server Apps which lets you retain the traditional client/server dev model for invoking your Server APIs In Process - avoiding any serialization, HTTP networking or even Kestrel middleware overhead to invoke your APIs directly!\n\nThis enables using the exact same source code to call APIs in Blazor Server and WASM which allows us to develop reusable Blazor Components to invoke the same Server APIs that serve Web, Mobile and Desktop Apps in Blazor Server Apps.","url":"https://youtu.be/66DgLHExC9E","wordCount":145,"lineCount":11,"group":"v6.5"},{"slug":"feature1","draft":false,"title":"RAD Blazor","image":"https://servicestack.net/img/whatsnew/v6.4/blazor-components-youtube.jpg","tags":[],"date":"\/Date(1665446400000-0000)\/","content":"We're excited to announce exciting new Blazor Components enabling a compelling a Rapid Application Development platform for Blazor Apps delivering many of the productivity benefits previously limited to [locode.dev](https://www.locode.dev).\n\nOur new native Blazor Components allows for a beautiful progression story where you can start with a [Database-First Locode](/locode/database-first) solution to instantly [generate Data Models and CRUD APIs](/locode/database-first#exporting-to-code-first-types) around your existing databases that thanks to the new `AutoQueryGrid` Blazor component will be able to trivially implement both CRUD UI's and optimized Blazor UIs in the same Blazor App.","url":"https://docs.servicestack.net/releases/v6_04","wordCount":102,"lineCount":9,"group":"v6.4"},{"slug":"feature2","draft":false,"title":"Blazor Server Template","image":"https://servicestack.net/img/whatsnew/v6.4/blazor-server.png","tags":[],"date":"\/Date(1665446400000-0000)\/","content":"We're happy to announce our new Blazor Server App template offering a number compelling advantages over Blazor WASM, including:\n\n- A superior dev model and debugging experience\n- Improved live-reload and faster iterative dev cycles\n- Full access to .NET Server functionality\n- Better start times & UI responsiveness\n- Less complexity from unnecessary client project or pre-rendering solutions","url":"https://docs.servicestack.net/releases/v6_04#blazor-server","wordCount":63,"lineCount":13,"group":"v6.4"},{"slug":"feature3","draft":false,"title":"Blazor Component Gallery","image":"https://servicestack.net/img/whatsnew/v6.4/gallery-splash.png","tags":[],"date":"\/Date(1665446400000-0000)\/","content":"ServiceStack.Blazor Components gives you the ideal development workflow without compromise. Effortless, highly productive, API integrated Rich Blazor UI Components with 100% Server model reuse and integrated contextual validation.\n\nTo better showcase our growing Blazor functionality we've created new Blazor Gallery websites showcasing usage of available rich Blazor Components for rapidly develop beautiful Tailwind Web Apps available in both [Blazor Server](https://blazor-gallery.servicestack.net) and [Blazor WASM](https://blazor-gallery.jamstacks.net) Web Apps.","url":"https://docs.servicestack.net/releases/v6_04#blazor-gallery","wordCount":82,"lineCount":9,"group":"v6.4"},{"slug":"feature4","draft":false,"title":"Debug DB Migrations from IDE","image":"https://servicestack.net/img/whatsnew/v6.4/database-migrations-youtube.jpg","tags":[],"date":"\/Date(1665446400000-0000)\/","content":"We've continued improving our story around [Code-First DB Migrations](/ormlite/db-migrations) and have created a [new video](https://www.youtube.com/embed/NIVFqute7JQ) demonstrating how it can be used to maintain DB Schema migrations under a typical development workflow.\n\nAs they encourage a structured workflow for incremental development of new App features we've upgraded all modern [jamstacks.net](https://jamstacks.net)\ntemplates to adopt DB Migrations for creating and populating their App DB.\n\nA benefit of DB Migrations being implemented in a library instead of wrapped up behind an external tool, is that it's better integrated and more versatile in supporting more executable options like being able to run from code, a feature the new `MigrationTasks` Explicit TestFixture benefits from enabling DB Migrations to be run or debugged directly from within your IDE.","url":"https://docs.servicestack.net/releases/v6_04#db-migrations","wordCount":140,"lineCount":12,"group":"v6.4"},{"slug":"feature1","draft":false,"title":"Simple Code-First DB Migrations","image":"https://servicestack.net/img/whatsnew/v6.3/db-migrations.png","tags":[],"date":"\/Date(1661817600000-0000)\/","content":"We're excited to share the next release of ServiceStack which sees the introduction of our simple Database Migration solution with Code-First DB Migrations which advances OrmLite's light-weight code-first development approach with a simple change based migration solution that facilitates the code-first development workflow of OrmLite.\n\nStarting from a seamless quick install and supporting multiple running options from command-line tooling, IDE run npm scripts, run, debug & verify from unit tests and integrated with our GitHub Action deployments where only successful migrations are deployed.\n\nInstead of relying on generation by an opaque tool, this code-first approach treats DB Migrations like any other maintainable & logically structured code written by developers where it maintains a connected audit history in source control together with the feature that needs the schema changes.","url":"https://docs.servicestack.net/releases/v6_03#code-first-db-migrations","wordCount":139,"lineCount":11,"group":"v6.3"},{"slug":"feature2","draft":false,"title":"Manage App Redis Servers with Redis Admin","image":"https://servicestack.net/img/whatsnew/v6.3/admin-ui-redis.png","tags":[],"date":"\/Date(1661817600000-0000)\/","content":"The Redis Admin UI lets you manage your App's configured Redis Server with a user-friendly UX for managing core Redis data types, simple search functionality to quickly find Redis values, quick navigation between related values, first class support for JSON values and a flexible command interface and command history to inspect all previously run redis commands that's easily editable & rerun.","url":"https://docs.servicestack.net/releases/v6_03#redis-admin-ui","wordCount":75,"lineCount":7,"group":"v6.3"},{"slug":"feature3","draft":false,"title":"Browse App RDBMS Tables with Database Admin","image":"https://servicestack.net/img/whatsnew/v6.3/admin-ui-database.png","tags":[],"date":"\/Date(1661817600000-0000)\/","content":"The new built-in Database Admin UI lets you quickly browse your App's configured RDBMS schemas and tables, which without any additional configuration your App's configured databases, their schemas, tables and any registered [named connections](https://docs.servicestack.net/ormlite/getting-started#multiple-database-connections) will be navigable from the home page where they'll be browsable with a familiar tabular search results grid, similar in appearance and functionality to [Locode's Auto UI](https://locode.dev) where their resultsets can each be personalized with flexible query preferences and filtering options that's persisted across browser restarts.","url":"https://docs.servicestack.net/releases/v6_03#database-admin-ui","wordCount":99,"lineCount":7,"group":"v6.3"},{"slug":"feature1","draft":false,"title":"Beautiful Blazor Tailwind Template","image":"https://servicestack.net/img/whatsnew/v6.2/blazor-tailwind.png","tags":[],"date":"\/Date(1658707200000-0000)\/","content":"The feature-rich [Blazor WASM Tailwind](https://docs.servicestack.net/templates-blazor-tailwind) template us ideal for teams with strong C# skills building Line Of Business (LOB) applications who prefer utilizing Tailwind's modern utility-first CSS design system to create beautiful, instant-loading Blazor WASM Apps.\n\nAll Blazor WASM templates [incorporate prerendering](https://blazor-tailwind.jamstacks.net/docs/prerender) to achieve their [instant load times](https://blazor-tailwind.jamstacks.net) that greatly benefits the built-in markdown pages with great SEO","url":"https://docs.servicestack.net/releases/v6_02","wordCount":77,"lineCount":9,"group":"v6.2"},{"slug":"feature2","draft":false,"title":"Create Litestream Apps and Save 10x on Hosting","image":"https://servicestack.net/img/whatsnew/v6.2/litestream-costs.svg","tags":[],"date":"\/Date(1658707200000-0000)\/","content":"Having achieved the best architecture for delivering [max value](https://jamstacks.net/posts/hosting) and performance with our [jamstacks.net](https://jamstacks.net) templates, the last expensive vital component used in most Web Apps is hosting of their expensive managed databases. Despite most RDBMS's being OSS and free of licensing costs, major cloud companies continue to charge artificially high hosting costs to provide redundant hosting of App data.\n\n[Litestream](https://litestream.io) lets us avoid these expensive hosting costs by providing transparent per-second replica backups to inexpensive managed storage, enabling latency-free queries, simplified hosting architectures at vastly reduced hosting costs.","url":"https://docs.servicestack.net/releases/v6_02.html#litestream","wordCount":112,"lineCount":9,"group":"v6.2"},{"slug":"feature3","draft":false,"title":"Gain real-time insights with built-in Profiling","image":"https://servicestack.net/img/whatsnew/v6.2/profiling.png","tags":[],"date":"\/Date(1658707200000-0000)\/","content":"The new Request Logging & Profiling UIs bring an invaluable new level of observability into your App, from being able to quickly inspect and browse incoming requests, to tracing their behavior from their generated events in the new [Diagnostic Source](https://docs.microsoft.com/en-us/dotnet/api/system.diagnostics.diagnosticsource?view=net-6.0) capabilities added all throughout ServiceStack, which both power the new UIs and enables new introspectability from code where you can now to tap in to inspect & debug when each diagnostic event occurs.","url":"https://docs.servicestack.net/releases/v6_02.html#request-logging-profiling","wordCount":94,"lineCount":7,"group":"v6.2"},{"slug":"feature4","draft":false,"title":"Manage DB Validation Rules with Validation UI","image":"https://servicestack.net/img/whatsnew/v6.2/validation-video.png","tags":[],"date":"\/Date(1658707200000-0000)\/","content":"The DB Validation feature leverages the existing [Declarative Validation](https://docs.servicestack.net/declarative-validation) infrastructure where it enables dynamically managing Request DTO Type and Property Validators from a RDBMS data source which immediately takes effect at runtime that carries the same performance profile at runtime as they can be optionally cached where they'll only need to be re-hydrated from the database after modification.","url":"https://docs.servicestack.net/releases/v6_02.html#db-validation","wordCount":76,"lineCount":7,"group":"v6.2"},{"slug":"feature1","draft":false,"title":"Rapid Application Development with Locode","image":"https://servicestack.net/img/whatsnew/v6.1/locode-splash.png","tags":[],"date":"\/Date(1652659200000-0000)\/","content":"We're excited to announce [locode.dev](https://locode.dev), our **Rapid Application Development** solution to quickly develop\nbeautiful Full Stack CRUD Apps around **AutoQuery APIs**, suitable for a wide number of use-cases including:\n\n- Rapid prototyping by creating an instant UI around existing **Database-First** RDBMS tables\n- Declarative **Code-First** development model with unprecedented customizability (exportable from Database-First)\n- **Hybrid Apps** with a custom UI to optimize common workflows whilst using Locode's Auto UI to manage Back office tables\n\nAs Locode's UI is built on top of ServiceStack's industrial strength AutoQuery APIs, Hybrid Apps can benefit from its superior end-to-end typed development model for creating Web, Mobile & Desktop Apps.","url":"https://docs.servicestack.net/releases/v6_01","wordCount":117,"lineCount":14,"group":"v6.1"},{"slug":"feature2","draft":false,"title":"Database-First Development Model","image":"https://servicestack.net/img/whatsnew/v6.1/youtube-locode-intro.png","tags":[],"date":"\/Date(1652659200000-0000)\/","content":"Using [AutoQuery's AutoGen](https://docs.servicestack.net/autoquery-autogen) enables the quickest way to modernize an existing database by dynamically creating Data Models & AutoQuery CRUD APIs from RDBMS table schemas at runtime.\n\nLocode provides a highly functional UI out-of-the-box that doesn't rely on code-gen that allows you to only override the Custom UI or Custom API implementation when needed resulting in a significantly smaller code-base to maintain as reflected in the comparitive code-bases of a customized\nNorthwind Locode App vs the Northwind code-base of a popular RAD code-gen tool for .NET\n\n\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n
Locode NorthwindRadzen Northwind
~120 lines of C#~4500 lines of C# (generated)
29 lines custom Home Page10k+ lines of Angular HTML/TS (generated)
","url":"https://docs.servicestack.net/releases/v6_01#database-first","wordCount":134,"lineCount":29,"group":"v6.1"},{"slug":"feature3","draft":false,"title":"Code-First Development Model","image":"https://servicestack.net/img/whatsnew/v6.1/chinook-splash.png","tags":[],"date":"\/Date(1652659200000-0000)\/","content":"[Code-First](https://docs.servicestack.net/locode/code-first) is the natural development model of [AutoQuery Services](https://docs.servicestack.net/autoquery-rdbms) which facilitates the majority of a\nSystem and its UI can be developed from simple, declarative C# POCOs to define the underlying RDBMS Schema Data Models and the precise typed\nAPI DTO Contracts of their surrounding AutoQuery & CRUD APIs. The Data and Service models can be further enhanced by ServiceStack's vast\n[declarative attributes](https://docs.servicestack.net/locode/declarative) where a significant amount of behavior, functionality and customization can be defined, ranging from:\n\n- Customize how [Data Models map to DB Tables](https://docs.servicestack.net/locode/declarative.html#table-data-model-attributes) & enlist RDBMS features\n- [Customize Serialization & API behavior](https://docs.servicestack.net/locode/declarative.html#custom-serialization)\n- [Define AutoQuery & CRUD API behavior](https://docs.servicestack.net/locode/declarative.html#autoquery-attributes)\n- Define [Validation Rules](https://docs.servicestack.net/locode/declarative.html#type-validation-attributes) and [Authorization restrictions](https://docs.servicestack.net/locode/declarative.html#authentication-restrictions)\n- [Annotate & Document APIs](https://docs.servicestack.net/locode/declarative.html#annotate-apis)\n- [Customize UI Behavior & Appearance](https://docs.servicestack.net/locode/declarative.html#result-formatters)","url":"https://docs.servicestack.net/releases/v6_01#code-first","wordCount":165,"lineCount":17,"group":"v6.1"},{"slug":"feature4","draft":false,"title":"Hybrid Locode Apps with Blazor WASM","image":"https://servicestack.net/img/whatsnew/v6.1/talent-splash.png","tags":[],"date":"\/Date(1652659200000-0000)\/","content":"Locode's declarative dev model lets you focus on your new App's business requirements where its data model, API capabilities, input validation & multi-user Auth restrictions can be defined simply using annotated C# POCOs.\nThis provides immense value at the start of the development cycle where functional prototypes can be quickly iterated to gather business requirements\n\nOnce requirements have solidified, its typed AutoQuery APIs can easily be reused to develop custom UIs to optimize important workflows.\n\n[Talent Blazor](https://github.com/NetCoreApps/TalentBlazor) is a new App showcasing an example of this where its entire back-office functionality can be managed through Locode whilst an optimized **Blazor WASM App** is created to optimize its unique workflow requirements which also benefits from the superior productive dev model of its Typed APIs.","url":"https://docs.servicestack.net/releases/v6_01#hybrid-locode-apps","wordCount":138,"lineCount":12,"group":"v6.1"},{"slug":"feature1","draft":false,"title":"FREE Individual & OSS Licenses","image":"https://servicestack.net/img/whatsnew/v6/servicestack-100m-976w.png","tags":[],"date":"\/Date(1642723200000-0000)\/","content":"We're starting off 2022 eclipsing an impressive milestone having crossed\n[100M+ NuGet downloads](https://www.nuget.org/profiles/servicestack) which we're celebrating by making ServiceStack FREE for Individuals & collaborative OSS Projects.\n\nWe've also created 2 new community spaces for ServiceStack developers to engage with each other:\n\n- [ServiceStack/Discuss](https://github.com/ServiceStack/Discuss/discussions/)\n- [#ServiceStack channel on Discord](https://discord.gg/w4ayGbuYpA)\n\nThese new spaces are welcome to all users of the framework that we hope together with the new free licenses will encourage developers build and share their amazing creations with each other! 🎉","url":"https://docs.servicestack.net/releases/v6","wordCount":97,"lineCount":15,"group":"v6.0"},{"slug":"feature2","draft":false,"title":"API Explorer","image":"https://servicestack.net/img/whatsnew/v6/api-details-CreateBooking.png","tags":[],"date":"\/Date(1642723200000-0000)\/","content":"Now built into every ServiceStack v6 App is API Explorer - an instant integrated Postman and Swagger UI alternative to quickly Call and Explore your APIs.\n\nThe entire API Explorer UI is driven by the rich metadata around your APIs and AppHost's registered plugins capturing greater knowledge about your APIs and is able to provide a smarter, richer and more optimized UX than what would be possible going through lowest common denominator specs like Open API.\n\nWith envious performance and unmatched customizability, API Explorer lets you easily incorporate gorgeous, rich, interactive API Documentation API Consumers will love who'll be able to read its source code in their preferred programming language and easily call from their existing Client Apps.","url":"https://docs.servicestack.net/releases/v6#api-explorer","wordCount":126,"lineCount":11,"group":"v6.0"},{"slug":"feature3","draft":false,"title":"Blazor WebAssembly Jamstack Template","image":"https://servicestack.net/img/whatsnew/v6/blazor-wasm.png","tags":[],"date":"\/Date(1642723200000-0000)\/","content":"Our new Blazor WebAssembly (WASM) template is ideal for teams with strong C# skills building Line Of Business (LOB) applications. Utilizing an API First development model, the C# Blazor front-end is able to take advantage of the clean separation of ServiceStack APIs to enjoy instant frictionless 100% reuse of API Types as-is, without any reliance on any tooling or unproductive out-of-sync code-gen build steps interrupting developers workflow.\n\nTogether with new .NET Service Clients Apis it results in the ideal productive dev model to bind Blazor UIs to ServiceStack APIs.\n\nTemplates make use of **ServiceStack.Blazor** a new package of integrated functionality with ServiceStack, inc. JSON API HttpClient Factory, API-enabled base components & themable Bootstrap + Tailwind UI controls.\n\nIn addition to TODO MVC and CRUD UI examples demonstrating its productive dev model, it also includes pre-rendering solutions for instant load times & GitHub Actions for effortless optimal Jamstack CDN deployments.","url":"https://docs.servicestack.net/templates-blazor","wordCount":160,"lineCount":13,"group":"v6.0"},{"slug":"feature4","draft":false,"title":"C# Jamstack Templates","image":"https://servicestack.net/img/whatsnew/v6/jamstacks-net.png","tags":[],"date":"\/Date(1642723200000-0000)\/","content":"ServiceStack's new [jamstacks.net](https://jamstacks.net) templates encapsulates the latest technologies at the forefront of modern web development to deliver both a great developer experience and performant end-user UX.\n\nJamstack (JavaScript, APIs, and Markup) is a modern architecture pattern to build fast, secure and easy to scale web applications where pre-rendering content, enhancing with JavaScript and leveraging CDN static hosting results in a highly productive, flexible and performant system that takes advantage of CDN edge caches to deliver greater performance & efficiency at lower cost.\n\nIt's quickly becoming the preferred architecture for modern web apps with benefits extending beyond performance to improved Security, Scale, Maintainability, Portability, Developer Experience & lower costs with your App's pre-rendered static UI assets on Content Delivery Network (CDN) edge caches close to users locations.\n\nThese new templates represent the best-in class experiences for their respective React, Vue & Blazor WASM ecosystems each, packed with features & examples common in many websites including Integrated Auth, rich Markdown content as well as TODOs MVC and CRUD examples with built-in contextual validation binding. As such they're now recommended over our existing SPA and C# MVC Templates.","url":"https://docs.servicestack.net/releases/v6#jamstack","wordCount":197,"lineCount":13,"group":"v6.0"},{"slug":"feature1","draft":false,"title":".NET 6 is here!","image":"https://servicestack.net/img/whatsnew/net6-released.png","tags":[],"date":"\/Date(1637366400000-0000)\/","content":"We've cut this release cadence short to focus on putting out a quality release to take advantage of the newest and best .NET runtime yet!\n\nIn a lot of ways .NET 6 marks the start of a new era for .NET with the first LTS release after the end of the\n.NET Framework and .NET Standard with only 1 actively developed runtime going forward.\n\nWe're moving full-steam ahead and have standardized our new features onto .NET 6 with:\n\n- [All project templates upgraded to .NET 6](https://docs.servicestack.net/releases/v5_13#all-project-templates-upgraded-to-net-6)\n- [net6.0 TFM builds added to all packages](https://docs.servicestack.net/releases/v5_13#net6-0-tfm-builds-added-to-all-packages)\n- [Embracing .NET 6 new Hosting Model for mix](https://docs.servicestack.net/releases/v5_13#net-6-new-hosting-model)\n- [v4.5 .NET Framework Deprecation Notice](https://docs.servicestack.net/releases/v5_13#v4-5-net-framework-deprecation-notice)","url":"https://docs.servicestack.net/releases/v5_13","wordCount":133,"lineCount":17,"group":"v5.13"},{"slug":"feature2","draft":false,"title":"ServiceStackVS 2022 support","image":"https://servicestack.net/img/whatsnew/vs2022-splash.png","tags":[],"date":"\/Date(1637366400000-0000)\/","content":"Visual Studio 2022 now has support for Add ServiceStack reference for C#/F#/VBNET/TypeScript!\n\nServiceStackVS can be found in the Extension Marketplace, and is installable straight from Visual Studio 2022.","url":"https://docs.servicestack.net/releases/v5_13#servicestackvs-now-supports-visual-studio-2022","wordCount":37,"lineCount":9,"group":"v5.13"},{"slug":"feature3","draft":false,"title":".NET 6 Hosting Model migration guide","image":"https://i.ytimg.com/vi/WgsFl0AFUdo/maxresdefault.jpg","tags":[],"date":"\/Date(1637366400000-0000)\/","content":"We're now embracing .NET 6's idiom and have rewritten all our mix gist config files to adopt its HostingStartup which is better able to load modular Startup configuration without assembly scanning.\n\nThis video guide shows how you can migrate your existing startup modules to use .NET 6 Hosting Model.","url":"https://youtu.be/WgsFl0AFUdo","wordCount":62,"lineCount":9,"group":"v5.13"},{"slug":"feature1","draft":false,"title":"Python ServiceStack Reference","image":"https://servicestack.net/img/whatsnew/v5.12/python-reference.png","tags":[],"date":"\/Date(1629158400000-0000)\/","content":"[Python](https://python.org) is one of the worlds most popular programming languages which\nexcels in a number of industries thanks to its ease of use and comprehensive libraries.\n\nTo maximize the experience for calling ServiceStack APIs within these environments\nServiceStack now supports Python as a 1st class Add ServiceStack Reference supported language\nwhich gives Python developers an end-to-end typed API for consuming ServiceStack APIs,\ncomplete with IDE integration in [PyCharm](https://www.jetbrains.com/pycharm/) as well as\n[built-in support in x dotnet tool](https://docs.servicestack.net//dotnet-tool#addupdate-servicestack-references)\nto generate Python DTOs for a remote ServiceStack instance from a single command.","url":"https://docs.servicestack.net/releases/v5.12#python-servicestack-reference","wordCount":106,"lineCount":15,"group":"v5.12"},{"slug":"feature2","draft":false,"title":"Jupyter Notebooks","image":"https://servicestack.net/img/whatsnew/v5.12/jupyter-splash.png","tags":[],"date":"\/Date(1629158400000-0000)\/","content":"Python has solidified itself as a powerhouse in Data Science and Machine Learning thanks to its\nbest-in-class libraries as well as being at the forefront of Interactive Computing with its native\nsupport in [Jupyter Notebooks](https://jupyter.org/) - a popular realization of Donald Knuth’s\n[Literate Programming](https://en.wikipedia.org/wiki/Literate_programming)\nparadigm where executable code is interlaced in a live document with natural language\ndocumentation, rich markup and embedded media. It’s become an invaluable medium for data\nscience, scientists and researchers where it’s often used as an advanced REPL environment\nfor data and computation exploration whose resulting knowledge and insights are easily\ncaptured and shared.\n\nWe’re excited to be able to join the beautiful interactive world of Jupyter Notebooks with\nboth Simple UI and command-line tools for effortlessly generating customized Notebooks around\ntyped ServiceStack APIs for Jupyter’s premier support for **Python**.","url":"https://docs.servicestack.net/releases/v5.12#interactive-jupyter-notebooks","wordCount":141,"lineCount":19,"group":"v5.12"},{"slug":"feature3","draft":false,"title":"C# and F# Jupyter Notebooks","image":"https://servicestack.net/img/whatsnew/v5.12/jupyter-lab-visual-example.png","tags":[],"date":"\/Date(1629158400000-0000)\/","content":"In addition to Python we've also extended support for generating customized pre-populated\n**C#** and **F#** Jupyter Notebooks by leveraging dotnet/interactive Jupyter kernel’s which\nallows C# and F# .NET Developers to join Jupyter's interactive live programming paradigm\nwhich they can either choose to run locally in the next gen JupyterLab UI or directly within\nVS Code using .NET Interactive's VS Code extension.\n\nNotebooks have also become a popular medium for sharing institutional data and computational\nknowledge thanks to being able to capture and embed execution output and support for exporting\nin multiple popular document formats as used by GitHub with their Auto Preview support for\nNotebooks. We also simplify configuring a Notebook GitHub repo to support executing C# and\nF# Notebooks in [mybinder.org](https://mybinder.org) FREE cloud hosting services with our\n`docker-jupyter` mix template.","url":"https://docs.servicestack.net/releases/v5.12#generate-c-jupyter-notebooks","wordCount":138,"lineCount":18,"group":"v5.12"},{"slug":"feature1","draft":false,"title":"Instant Client Apps","image":"https://servicestack.net/img/whatsnew/v5.11/client-apps.png","tags":[],"date":"\/Date(1618963200000-0000)\/","content":"Building upon our native end-to-end typed solutions, we're excited to announce **Instant Client Apps** to\nprovide instant utility and value around your ServiceStack Services where your API consumers can use the\nAuto generated UI to craft API Requests in their preferred programming language:","url":"https://docs.servicestack.net/releases/v5.11#instant-client-apps","wordCount":51,"lineCount":9,"group":"v5.11"},{"slug":"feature2","draft":false,"title":"GitHub Actions Templates","image":"https://servicestack.net/img/whatsnew/v5.11/github-actions-header.png","tags":[],"date":"\/Date(1618963200000-0000)\/","content":"We've begun to fully embrace GitHub Actions from this release to help quickly setting up CI environments for\nnew and existing ServiceStack project templates by automating them into building and running tests on each **commit**\nbefore publishing, dockerizing & deploying them on each **GitHub Release**.\nThe templates leverage [mix](https://docs.servicestack.net/mix-tool) to work like lego pieces where they can be combined to achieve your\npreferred automation workflow.","url":"https://docs.servicestack.net/releases/v5.11#githubaction-templates","wordCount":76,"lineCount":11,"group":"v5.11"},{"slug":"feature3","draft":false,"title":"All Service Client Libraries Upgraded","image":"https://servicestack.net/img/whatsnew/v5.11/service-clients.png","tags":[],"date":"\/Date(1618963200000-0000)\/","content":"In addition to the Refresh Token support & built-in Inspect utils all ServiceStack’s generic Service Client libraries in all languages have received a number of updates to improve their consistency and overall development UX.","url":"https://docs.servicestack.net/releases/v5.11#all-service-client-libraries-upgraded","wordCount":47,"lineCount":7,"group":"v5.11"},{"slug":"feature1","draft":false,"title":"Booking System in minutes","image":"https://raw.githubusercontent.com/ServiceStack/docs/master/docs/images/studio/bookings-splash.png","tags":[],"date":"\/Date(1605052800000-0000)\/","content":"To see the rapid development of AutoQuery in action we've created a quick demo showing how to create a simple multi-user Booking System from an empty [web](https://github.com/NetCoreTemplates/web) project, [mixed in](https://docs.servicestack.net/mix-tool) with the preferred RDBMS & Auth layered functionality, before enabling [Validation](https://docs.servicestack.net/validation), [AutoQuery](https://docs.servicestack.net/autoquery-rdbms), Admin Users & [CRUD Event Log](https://docs.servicestack.net/autoquery-audit-log) plugins - to lay the foundational features before building our App by first defining its `Booking` data model & its surrounding **Query**, **Create**, **Update** and **Soft Delete** Typed CRUD APIs with rich validation enforced by declarative Validation attributes and multi-layer authorization rules & access permissions protected using Authorization attributes.","url":"https://docs.servicestack.net/releases/v5.10#creating-a-multi-user-net-core-booking-system-in-minutes","wordCount":126,"lineCount":7,"group":"v5.10"},{"slug":"feature2","draft":false,"title":"Studio User Admin","image":"https://raw.githubusercontent.com/ServiceStack/docs/master/docs/images/studio/studio-home.png","tags":[],"date":"\/Date(1605052800000-0000)\/","content":"We've caught a glimpse of the new User Admin Feature in the [Bookings CRUD demo](https://youtu.be/XpHAaCTV7jE) who utilizes it to create **Employee** and **Manager** users. The `AdminUsersFeature` provides Admin User Management APIs enabling remote programmatic access to your registered [User Auth Repository](https://docs.servicestack.net/authentication-and-authorization#user-auth-repository), featuring:\n\n- Works with existing `IUserAuthRepository` sync or async providers\n- Utilizes Progressive enhancement, e.g. search functionality utilizes `IQueryUserAuth` (if exists) performing a wildcard search over multiple fields, otherwise falls back to exact match on `UserName` or `Email`\n- Supports managing Auth Repositories utilizing custom `UserAuth` data models\n- Flexible UI options for customizing which fields to include in Search Results and Create/Edit UIs\n- Rich Metadata aggregating only App-specific Roles & Permissions defined in your App\n- User Events allow you to execute custom logic before & after each Created/Updated/Deleted User","url":"https://docs.servicestack.net/releases/v5.10#studio-user-management-ui","wordCount":145,"lineCount":14,"group":"v5.10"},{"slug":"feature3","draft":false,"title":"Sign In with Apple","image":"https://raw.githubusercontent.com/ServiceStack/docs/master/docs/images/dev/web-signin-with-apple-login.png","tags":[],"date":"\/Date(1605052800000-0000)\/","content":"As mobile Apps is a target use-case for ServiceStack, this release also includes 1st class integration with **Sign In with Apple** OAuth provider. To assist with adoption we've also developed Sign In with Apple Integration Examples for iOS, Android & Web with working implementations for Flutter iOS/Android & SwiftUI Apps.","url":"https://docs.servicestack.net/releases/v5.10#sign-in-with-apple","wordCount":63,"lineCount":7,"group":"v5.10"},{"slug":"feature1","draft":false,"title":"Introducing ServiceStack Studio","image":"https://raw.githubusercontent.com/ServiceStack/docs/master/docs/images/release-notes/v5.9/studio-home.png","tags":[],"date":"\/Date(1594252800000-0000)\/","content":"Another exciting development in this release is the successor to [Admin UI](https://github.com/ServiceStack/Admin):\n**ServiceStack Studio!** - a capability-based UI to manage multiple remote ServiceStack instances from either a Chromium Desktop App\nor cross-platform .NET Core Web App.\n\nThe richer metadata in ServiceStack Services allows Studio to logically group Services around Data Models, enabling its high-level\nsemantic features like its native data-grid like UX over all AutoQuery Services to quickly discover, search, create, update and\ndelete entities based on the available AutoQuery APIs and whether Authenticated Users have access to them.","url":"https://docs.servicestack.net/releases/v5.9#introducing-servicestack-studio","wordCount":102,"lineCount":13,"group":"v5.9"},{"slug":"feature2","draft":false,"title":"Instantly Servicify existing Systems!","image":"https://raw.githubusercontent.com/ServiceStack/docs/master/docs/images/svg/servicify.svg","tags":[],"date":"\/Date(1594252800000-0000)\/","content":"ServiceStack also reached maximum autonomy for a Services framework where in addition to **AutoQuery** automatically providing your Services implementations,\n**Studio** providing its instant UI, ServiceStack also gained the capability to **generate your entire API!** Including Typed API contracts,\ndata models, implementations & human-friendly pluralized HTTP API routes over an existing System RDBMS's tables!\n\nServiceStack's **AutoGen** enables a number of exciting possibilities, predominantly it's the fastest way to ServiceStack-ify an\nexisting systems RDBMS where it will serve as an invaluable tool for anyone wanting to quickly migrate to ServiceStack and access its\nfunctionality ecosystem around ServiceStack Services:","url":"https://docs.servicestack.net/releases/v5.9#instantly-servicify-existing-systems","wordCount":106,"lineCount":13,"group":"v5.9"},{"slug":"feature3","draft":false,"title":"Generate Types for RDBMS Tables","image":"https://raw.githubusercontent.com/ServiceStack/docs/master/docs/images/release-notes/v5.9/autodto-youtube.png","tags":[],"date":"\/Date(1594252800000-0000)\/","content":"generate-types-for-rdbms-tables\nimage: https://raw.githubusercontent.com/ServiceStack/docs/master/docs/images/release-notes/v5.9/autodto-youtube.png\n---\n\nAn unintended consequence of **AutoGen** that's potentially universally appealing to even non .NET developers is that it's also a way to instantly\ngenerate Types for all RDBMS tables in all of ServiceStack [supported client languages](https://docs.servicestack.net/add-servicestack-reference),\nwhich thanks to being configurable in a [Sharp App](https://sharpscript.net/docs/sharp-apps) can be executed from the command-line using\nthe [dotnet tools](https://docs.servicestack.net/dotnet-tool)","url":"https://docs.servicestack.net/releases/v5.9#autodtogenerate-types-for-rdbms-tables","wordCount":75,"lineCount":10,"group":"v5.9"},{"slug":"feature1","draft":false,"title":"Simple Code-First DB MigrationsServiceStack gRPC support","image":"https://raw.githubusercontent.com/ServiceStack/docs/master/docs/images/grpc/grpc-horizontal-color.svg","tags":[],"date":"\/Date(1578960000000-0000)\/","content":"We're super excited to open the year with the premier feature in this release **ServiceStack gRPC**, our highly-productive entry into the\n[gRPC](https://grpc.io) universe with a number of value-added additions that makes developing and consuming gRPC Services a joy with USPs\nthat leverages and preserves your existing knowledge and investments and maximizes the utility of your Services offering unprecedented value\nfor your development efforts.","url":"https://docs.servicestack.net/grpc","wordCount":77,"lineCount":10,"group":"v5.8"},{"slug":"feature2","draft":false,"title":"Updated Templates .NET Core 3.1","image":"https://raw.githubusercontent.com/ServiceStack/Assets/master/csharp-templates/vue-nuxt.png","tags":[],"date":"\/Date(1578960000000-0000)\/","content":"With the release of [.NET Core 3.1 LTS](https://devblogs.microsoft.com/dotnet/announcing-net-core-3-1/) we've standardized our Project Templates\nand tools to **.NET Core 3.1 LTS** whilst continuing to support existing **.NET Core 2.1+** and **.NET Framework** projects including\n[ASP.NET Core Apps on the .NET Framework](https://docs.servicestack.net/templates-corefx).","url":"https://docs.servicestack.net/releases/v5.8#net-core-31-lts-project-templates","wordCount":67,"lineCount":9,"group":"v5.8"},{"slug":"feature1","draft":false,"title":".NET Core 3 Updates","image":"https://raw.githubusercontent.com/ServiceStack/Assets/master/img/release-notes/netcore-banner.png?t","tags":[],"date":"\/Date(1569888000000-0000)\/","content":"Ordinarily we'd have a longer release cadence in between releases with more features, but with the recent release of .NET Core 3\nwe've cut this release cycle short so we can release a version of ServiceStack compatible with .NET Core 3+. Other than that the major focus\non this release was `#Script` with [many new features](https://docs.servicestack.net/releases/v5.7#script) we're excited to share after covering the ServiceStack changes.","url":"https://docs.servicestack.net/releases/v5.7#net-core-3","wordCount":81,"lineCount":9,"group":"v5.7"},{"slug":"feature2","draft":false,"title":"New #Script Updates","image":"https://sharpscript.net/assets/img/sandbox.svg","tags":[],"date":"\/Date(1569888000000-0000)\/","content":"We've seen great reception of [Gist Desktop Apps](https://docs.servicestack.net/releases/v5.6#gist-desktop-apps) from the last v5.6 release with a\nnice shoutout from [Jon Galloway](https://twitter.com/jongalloway) in the\n[ASP.NET Community August Stand up](https://www.youtube.com/watch?v=a2lq4yEfJpk&feature=youtu.be&t=1529),\na featured [blog post](https://www.hanselman.com/blog/SharpScriptFromServiceStackLetsYouRunNETAppsDirectlyFromAGitHubGist.aspx)\nfrom [Scott Hanselman](https://twitter.com/shanselman) as well features in Hacker News and Reddit.\n\nWe've since further enhanced `#Script` capabilities in this release making it more functional then ever, broadening its appeal\nin its growing list of use-cases.","url":"https://docs.servicestack.net/releases/v5.7#1st-class-script-code-and-lisp-language-support","wordCount":94,"lineCount":14,"group":"v5.7"},{"slug":"feature1","draft":false,"title":"Modular Startup","image":"https://raw.githubusercontent.com/ServiceStack/docs/master/docs/images/mix/feature-authrepo.png","tags":[],"date":"\/Date(1565568000000-0000)\/","content":"We want to dramatically simplify and improve the experience for configuring ASP.NET Core Apps and make them truly composable,\nwhere we can drop-in files that auto configures itself with both ASP.NET Core and ServiceStack's AppHost so they can\nencapsulate an entire feature and provide instant utility without needing to wade through different steps of how they\nshould be manually configured at different places in your Startup configuration class.","url":"https://docs.servicestack.net/releases/v5.6#modular-startup","wordCount":78,"lineCount":10,"group":"v5.6"},{"slug":"feature2","draft":false,"title":"Mix'n'Match .NET Core Apps","image":"https://raw.githubusercontent.com/ServiceStack/docs/master/docs/images/mix/example-validation-900.gif","tags":[],"date":"\/Date(1565568000000-0000)\/","content":"To complete the picture of making it easy as possible to compose ASP.NET Core Apps we've created the `mix` dotnet tool to easily\ninstall features which can be installed with:\n\n```bash\n$ dotnet tool install --global mix\n```\n\nThe `mix` tool is designed around applying ASP.NET Core features captured in GitHub gists to your local .NET Core projects.\n\nThen choosing which features you want to add to your project with `mix `, e.g:\n\n```bash\n$ mix redis\n```","url":"https://docs.servicestack.net/releases/v5.6#mix-n-match-net-core-apps","wordCount":85,"lineCount":20,"group":"v5.6"},{"slug":"feature3","draft":false,"title":"Single Page App Component Libraries","image":"https://raw.githubusercontent.com/ServiceStack/docs/master/docs/images/ssvs/spa-templates-overview.png","tags":[],"date":"\/Date(1565568000000-0000)\/","content":"To lay the foundation for richer and more tightly integrated UI controls, we've created UI and common component libraries for the\n3 most popular JS frameworks:\n\n\n- [@servicestack/vue](https://github.com/ServiceStack/servicestack-vue)\n- [@servicestack/react](https://github.com/ServiceStack/servicestack-react)\n- [@servicestack/angular](https://github.com/ServiceStack/servicestack-angular)\n\n\nAll new [Single Page App Project Templates](https://docs.servicestack.net/templates-single-page-apps) have been pre-configured to use these libraries which will make it\na lot easier to deliver new UI components and updates to existing SPA Apps with just an npm upgrade.","url":"https://docs.servicestack.net/releases/v5.6#spa-component-libraries","wordCount":89,"lineCount":17,"group":"v5.6"},{"slug":"feature1","draft":false,"title":"ServiceStack turns 10 🥳","image":"https://servicestack.net/img/whatsnew/v5.5/anniversary-10.png","tags":[],"date":"\/Date(1553990400000-0000)\/","content":"Before we get into unpacking this release we're happy to announce that we've now eclipsed **10 years** since our\n[first commit](https://github.com/ServiceStack/ServiceStack/commit/2a9cd0d10247ae1a679ac011d7bdef593937dba4)!\n\nI'd like to take this milestone to thank our thousands of Customers we've had the pleasure to serve and see our Software used which has amassed\nmore than **27,000,000+ total downloads** on NuGet and to see the uptick in adoption of some of our unique features like\n[Add ServiceStack Reference](https://docs.servicestack.net/add-servicestack-reference) which has been used more than **88,000 times**\nto generate native Typed DTOs amongst its [8 supported languages](https://docs.servicestack.net/add-servicestack-reference#supported-languages).","url":"https://docs.servicestack.net/releases/v5.5#servicestack-turns-10","wordCount":107,"lineCount":13,"group":"v5.5"},{"slug":"feature2","draft":false,"title":"Templates upgrades to #Script","image":"https://servicestack.net/img/whatsnew/v5.5/sharpscript.png","tags":[],"date":"\/Date(1553990400000-0000)\/","content":"As we continue enhancing ServiceStack's scripting support with exciting new features, it no longer made sense to call our dynamic scripting language\n\"Templates\" which is just one of the many use-cases `#Script` enables.\n\n[#Script](https://sharpscript.net) is typical of a popular dynamic template language you'd find in other platforms, using the ubiquitously familiar mix of\n[JavaScript Expressions](https://sharpscript.net/docs/expression-viewer) which for increased wrist-friendly readability can be easily composed\ntogether using the Unix `|` operator as embraced by [Vue.js filters](https://vuejs.org/v2/guide/syntax.html#header) and\n[Angular's Template Expressions](https://angular.io/guide/template-syntax#template-expression-operators)\nwhist the [Script Statement Blocks](https://sharpscript.net/docs/blocks) adopt the universally adopted Handlebars-like syntax that's ideal for\nrendering dynamic pages.","url":"https://docs.servicestack.net/releases/v5.5#script-fka-servicestack-templates","wordCount":118,"lineCount":15,"group":"v5.5"},{"slug":"feature1","draft":false,"title":".NET Core Windows Desktop Apps!","image":"https://raw.githubusercontent.com/ServiceStack/docs/master/docs/images/app/netcore-chromium-splash.png","tags":[],"date":"\/Date(1537315200000-0000)\/","content":"Our new [app](https://www.nuget.org/packages/app) build tool is packed with features for \"Chromitizing\" any\n.NET Core Web App into a **.NET Core Windows Desktop App** that's as easy as installing the `app` tool:\n\n```bash\n$ dotnet tool install -g app\n```\n\nand using it to run your .NET Core Web App's `.dll`, e.g:\n\n```bash\n$ app MyApp.dll\n```\n\nWhere it will run your .NET Core App and host it inside an Chromium Embedded Framework (CEF) browser.\n\nThis provides instant utility for being able to deploy .NET Core Apps end users can run locally using Chrome's leading and consistent rendering engine\nwithin a Windows Desktop Application.","url":"https://docs.servicestack.net/releases/v5.4#net-core-windows-desktop-apps","wordCount":116,"lineCount":23,"group":"v5.4"},{"slug":"feature1","draft":false,"title":"Spanified ServiceStack","image":"https://servicestack.net/img/logo-text.svg","tags":[],"date":"\/Date(1535414400000-0000)\/","content":"Major rework was performed across the ServiceStack.Text and ServiceStack.Common foundational libraries to replace its internal usage of `StringSegment`\nwith .NET's new high-performance\n[Span and Memory Types](https://www.codemag.com/article/1807051/Introducing-.NET-Core-2.1-Flagship-Types-Span-T-and-Memory-T) primitives\nwhich are now used for all JSON/JSV deserialization and many other String utilities.\n\nThe new `Span` and `ReadOnlyMemory` Types is the successor to `StringSegment` which are both allocation-free, but Span also enjoys additional runtime support as a JIT intrinsic for improved performance.\n\nThis change was primarily an internal refactor so there shouldn't be any user visible differences except for the addition of the\n[System.Memory](https://www.nuget.org/packages/System.Memory) dependency which contains the new Memory types. As a general rule we're averse to adopting\nnew dependencies but the added performance of these new primitives makes it a required dependency for maintaining high-performance libraries.","url":"https://docs.servicestack.net/releases/v5.2#spanified-servicestack","wordCount":142,"lineCount":15,"group":"v5.2"},{"slug":"feature1","draft":false,"title":"Dart and Flutter!","image":"https://raw.githubusercontent.com/ServiceStack/docs/master/docs/images/dart/dart.png","tags":[],"date":"\/Date(1524528000000-0000)\/","content":"We're super excited to announce first-class support for [Dart](https://www.dartlang.org) and [Flutter](https://flutter.io)! - Google’s premier new mobile UI framework for crafting high-quality native interfaces for iOS and Android from a single code-base in record time with a Reactive development model simplifying the effort for building Complex UIs in similar vein to development models pioneered in popular JavaScript frameworks like React, React Native, Vue and Angular. It's offers a beautiful blend of rapid development cycles with its built-in Hot Reloading giving you instant iterative feedback of changes to your Mobile App in milliseconds, whilst still offering high-performance native experiences at runtime where Dart code is AOT compiled into native ARM in iOS and Android.","url":"https://docs.servicestack.net/releases/v5.1.0#dart-and-flutter","wordCount":131,"lineCount":7,"group":"v5.1"},{"slug":"feature1","draft":false,"title":"Future Versioning Scheme","image":"https://servicestack.net/img/logo-text.svg","tags":[],"date":"\/Date(1514937600000-0000)\/","content":"Historically ServiceStack releases are focused around \"Major release schedules\" published along with detailed Release Notes describing new features and changes added in each release. All packages are published together in \"lockstep\" with the same version number so the effort to upgrade ServiceStack projects can be done all at same time, with low frequency.\n\nWhilst we want to minimize the effort for Customers to upgrade we also want to make any fixes or enhancements to the previous release available sooner as there are often fixes reported and resolved immediately after each release and made available in our [pre-release packages on MyGet](https://docs.servicestack.net/myget) that most Customers wont get until the next major Release on NuGet.","url":"https://docs.servicestack.net/releases/v5.0.0#future-versioning-scheme","wordCount":126,"lineCount":9,"group":"v5.0"},{"slug":"feature2","draft":false,"title":"ServiceStack Mobile and Desktop Apps","image":"https://raw.githubusercontent.com/ServiceStackApps/HelloMobile/master/screenshots/splash-900.png","tags":[],"date":"\/Date(1514937600000-0000)\/","content":"The [HelloMobile](https://github.com/ServiceStackApps/HelloMobile) project has been rewritten to use the latest v5 .NET Standard 2.0 and .NET Framework clients and contains multiple versions of the same App demonstrating a number of different calling conventions, service integrations and reuse possibilities for each of the following platforms:\n\n- WPF\n- UWP\n- Xamarin.Android\n- Xamarin.iOS\n- Xamarin.OSX\n- Xamarin.Forms\n - iOS\n - Android\n - UWP","url":"https://docs.servicestack.net/releases/v5.0.0#servicestack-mobile-and-desktop-apps","wordCount":77,"lineCount":17,"group":"v5.0"}],"videos":[{"slug":"video5","draft":false,"title":"Stream processing of data with JSON Lines","tags":["serialization"," servicestack"," jsonl"],"date":"\/Date(1692057600000+0000)\/","content":"In this video, we explore the efficient JSON Lines (JSONL) data format, a favorite among developers and the AI community\nfor handling large datasets. We walk through working with JSON Lines data, including examples for streaming parsers,\nasynchronous parsing with ServiceStack, and integration with Typesense.","url":"https://youtu.be/m0tAfjvJaZg","wordCount":56,"lineCount":9,"group":"apis"},{"slug":"video1","draft":false,"title":"GitHub for Auto Deployments - Kubernetes Not Required","tags":["github-actions","deployment","hosting"],"date":"\/Date(1691452800000+0000)\/","content":"Step by step walkthrough for deploying your App via GitHub Actions and plain old SSH. \nCheap hardware is getting fast enough that a lot of Web Apps don't need sophisticated orchestration tools like Kubernetes, \nso we show how you can use fundamental tools like SSH, Docker Compose and GitHub Actions to do it yourself! \n\nLow traffic Apps & proof of concepts can easily share cost effective server running Linux, \nNginx Reverse Proxy with LetsEncrypt.","url":"https://youtu.be/7dardvqBFbE","wordCount":87,"lineCount":13,"group":"actions"},{"slug":"video4","draft":false,"title":"Load data fast with ADO.NET RDBMS Bulk Insert APIs","tags":["ormlite","db","performance"],"date":"\/Date(1690848000000+0000)\/","content":"OrmLite includes a Bulk Inserts API that encapsulates the most efficient ways for inserting large amounts of data \nin each supported RDBMS. We ran benchmarks across macOS on Apple M2 ARM, Intel Linux VM and Intel Windows 10 to measure \nhow fast they run across popular Operating System platforms.","url":"https://youtu.be/3gO_OEWIyPo","wordCount":64,"lineCount":10,"group":"features","order":4},{"slug":"video5","draft":false,"title":"GPT Agent Feature Plugin Updated with Semantic Kernel","tags":["gpt"],"date":"\/Date(1690848000000+0000)\/","content":"In this video, we delve into the integration of Microsoft's Semantic Kernel with our GPT Meeting Agent to simplify \nand enhance working with Large Language Models with a common abstraction library that allows for easy substitution\nand experimentation with different LLMs.","url":"https://youtu.be/smM-Bs7CxJ8","wordCount":54,"lineCount":11,"group":"features","order":5},{"slug":"video1","draft":false,"title":"Getting Started with OrmLite fast, code-first ORM for .NET","tags":["ormlite","db"],"date":"\/Date(1688428800000+0000)\/","content":"This video walks though getting started with OrmLite - a powerful, fast and easy to use ORM for .NET that \ncan be used in any .NET and .NET Framework App without the complexity of larger ORMs. \n\nIn this tutorial we'll demonstrate the best patterns to use to install, configure and use OrmLite in your Application, \ndefining code-first POCOs, using them to create RDBMS tables and explore how to Create, Query, Update and Delete them \nusing OrmLite's Typed APIs.","url":"https://youtu.be/vUbpwjfEYzg","wordCount":92,"lineCount":13,"group":"features","order":1},{"slug":"video2","draft":false,"title":"Getting Started with ServiceStack.Redis in .NET","tags":["redis"],"date":"\/Date(1687824000000+0000)\/","content":"In this tutorial we explore the basics of Redis, an in-memory database, and its integration in .NET using the ServiceStack.Redis library. \nThe video covers topics such as setting up a Redis server with Docker, understanding the ServiceStack.Redis library, and making \nthe most of Redis data structures in a .NET context. \n\nFurthermore, it also delves into utilizing the async capabilities of ServiceStack, all demonstrated through clear, practical examples.","url":"https://youtu.be/jBdOvTvjyqY","wordCount":82,"lineCount":13,"group":"features","order":2},{"slug":"custom-admin-uis","draft":false,"title":"Build beautiful custom .NET Admin UIs in minutes","tags":["vue","autoquery"],"date":"\/Date(1686700800000+0000)\/","content":"In this video we explore the Server Multi Razor Page and Client rendered Admin UI Pages in the latest .NET\n[vue-mjs](https://vue-mjs.web-templates.io) project template to see how to use the new SidebarLayout and AutoQueryGrid\nVue Tailwind components to build beautiful Admin UI Pages within minutes.","url":"https://youtu.be/wlRA4_owEsc","wordCount":59,"lineCount":10,"group":"vue-projects","order":4},{"slug":"video2","draft":false,"title":"New Disqus OSS self-host alternative for .NET Websites","tags":["creatorkit","posts","tailwind"],"date":"\/Date(1686268800000+0000)\/","content":"In this video we explore how we can use CreatorKit - a self-hosting alternative to Disqus to add comments, voting\nand moderation to any existing page or blog post.\n\nCreatorKit is especially useful for adding dynamic post comment and voting features to Jamstack and other\nstatically generated websites which can continually be statically pre-rendered and hosted on CDN's whilst its \ndynamic features are powered by an external CreatorKit instance.","url":"https://youtu.be/lgpl-VjxtdU","wordCount":79,"lineCount":12,"group":"creatorkit"},{"slug":"video1","draft":false,"title":"New Mailchimp self-host mail management alternative","tags":["creatorkit","mail","tailwind"],"date":"\/Date(1686182400000+0000)\/","content":"In this video we introduce CreatorKit an OSS self-hosting alternative to Mailchimp for managing mailing lists,\nnewsletter subscriptions, email templating, marketing campaigns & more whose tailwind components can be easily \nintegrated into any existing website.\n\nIt's an ideal companion for .NET Apps looking to manage their mailinglist and newsletter subscribers in an\nisolated customizable .NET App with support for creating custom email layouts, templates and mail campaigns.","url":"https://youtu.be/_qDVtfcHf14","wordCount":75,"lineCount":12,"group":"creatorkit"},{"slug":"video1","draft":false,"title":"Bring static Xkcd dataset to life with AutoQuery","tags":["autoquery"," razor-pages"," ssg"," tailwind"],"date":"\/Date(1683763200000+0000)\/","content":"In this video, we demonstrate how to use AutoQuery to turn a static XKCD comic dataset from Hugging Face into a Web API, \naddressing common issues of siloed data.\n\nBy creating well-defined AutoQuery APIs, we make the data more accessible and enable efficient data integrations \nfor rapid creation of production Web Apps which we demonstrate in new lightweight a Razor SSG Vue App.","url":"https://youtu.be/CrKtXVrPj8Q","wordCount":78,"lineCount":11,"group":"autoquery"},{"slug":"video1","draft":false,"title":"Using Razor SSG to Create Websites in GitHub Codespaces","tags":["razor-pages"," ssg"," tailwind"," codespaces"],"date":"\/Date(1680048000000+0000)\/","content":"This video takes an in-depth look at the [razor-ssg](https://razor-ssg.web-templates.io) ServiceStack template, a powerful tool that \nharnesses the power of .NET Razor Pages to provide seamless static site generation (SSG) capabilities \n\nWith GitHub Codespaces integration, you can develop, test, and manage your application all within your browser, eliminating the need \nfor a dedicated development environment and expediting your workflow, which can all be done on the go from an iPad","url":"https://youtu.be/MRQMBrXi5Sc","wordCount":88,"lineCount":12,"group":"projects"},{"slug":"razor-ssg","draft":false,"title":"Using Razor SSG to Create Websites in GitHub Codespaces","tags":["razor-pages","ssg","markdown","codespaces"],"date":"\/Date(1680048000000+0000)\/","content":"This video takes an in-depth look at the [razor-ssg](https://razor-ssg.web-templates.io) ServiceStack template, a powerful tool that \nharnesses the power of .NET Razor Pages to provide seamless static site generation (SSG) capabilities \n\nWith GitHub Codespaces integration, you can develop, test, and manage your application all within your browser, eliminating the need \nfor a dedicated development environment and expediting your workflow, which can all be done on the go from an iPad","url":"https://youtu.be/MRQMBrXi5Sc","wordCount":86,"lineCount":13,"group":"vue-projects","order":3},{"slug":"video1","draft":false,"title":"Fastest way to a working gRPC Server and Flutter solution","tags":["grpc","flutter","android"],"date":"\/Date(1679875200000+0000)\/","content":"In this video we'll walk through configuring Flutter and gRPC .NET Services with the `flutter-grpc` mix template\nto add a new Flutter application using your locally installed **Flutter SDK** to an existing ServiceStack `grpc` project\nthat has been configured to support gRPC services","url":"https://youtu.be/fgts6sQ2Ags","wordCount":55,"lineCount":9,"group":"flutter-grpc"},{"slug":"video1","draft":false,"title":"Flutter Todo App with .NET API, from Scratch in Minutes","tags":["flutter","android","api"],"date":"\/Date(1679875200000+0000)\/","content":"This video starts from scratch, walking through installing Flutter SDK, \nbefore adding a new native Flutter App to a new .NET Blazor Server project -\ngiving our existing TODO Blazor Web App new native iOS & Android native UIs\n\nNext, we'll demonstrate the iterative development workflow of making changes \nto backend .NET APIs that's easily kept in-sync with our clients Dart DTOs\nfrom within Android Studio or command-line","url":"https://youtu.be/t4WcXo4Vnio","wordCount":79,"lineCount":13,"group":"flutter"},{"slug":"video2","draft":false,"title":"Use Flutter to build a Bookings App Fast","tags":["flutter","android","api"],"date":"\/Date(1679875200000+0000)\/","content":"In this video, we'll show how we can rapidly develop a new Flutter Android Bookings App\nadded to a new [vue-mjs](https://vue-mjs.web-templates.io) .NET Project using `x mix flutter`\n\nNext, we'll dive into the development process, where we'll demonstrate the productivity\nof calling typed .NET APIs using typed Dart DTOs for end-to-end typed integrations\nthat can be effortlessly updated from within Android Studio","url":"https://youtu.be/eMbwaMuIk84","wordCount":72,"lineCount":13,"group":"flutter"},{"slug":"video1","draft":false,"title":"Instantly Manage your data using AutoQueryGrid Vue","tags":["vue","autoquery"],"date":"\/Date(1678924800000+0000)\/","content":"This walkthrough explores the ServiceStack Vue 3 library and the functionality of the AutoQueryGrid component. The AutoQueryGrid component simplifies the integration of AutoQuery services by generating a customizable UI. \n\nBy following this guide, you'll learn how to effectively utilize these tools to enhance your application's user interface and overall user experience.","url":"https://youtu.be/znCoC-Ct0Ps","wordCount":63,"lineCount":10,"group":"vue"},{"slug":"video1","draft":false,"title":"Preview APIs with the Auto Html API Page","tags":["ui","api"],"date":"\/Date(1678665600000+0000)\/","content":"The Auto HTML Page provides instant utility for API consumers in consuming your APIs with a built-in \nAPI Response Visualizer, JSON syntax highlighting, integrated Postman-like UI and API SDK integration all-in-one.\n\nPowered by Vue 3 and the ServiceStack [Vue library](https://docs.servicestack.net/vue/), it's also highly customizable.","url":"https://youtu.be/3gjisRVqhLo","wordCount":61,"lineCount":11,"group":"ui-autohtml"},{"slug":"video2","draft":false,"title":"Vue 3 Tailwind Components Library","tags":["vue","autoquery"],"date":"\/Date(1676332800000+0000)\/","content":"In this video, we demonstrate using the @servicestack/vue components library for Vue.js 3 Multipage Apps (MPAs) along with the `vue-mjs` template. \n\nThe template illustrates building content-heavy or complex sites while avoiding the intricacies of Single Page Apps (SPAs) through the use of JavaScript Modules, Tailwind, Vue.js, Razor Pages, and ServiceStack.","url":"https://youtu.be/YIa0w6whe2U","wordCount":61,"lineCount":9,"group":"vue"},{"slug":"video3","draft":false,"title":"Create testable code-first RDBMS migrations in C#","tags":["ormlite","db","migrations"],"date":"\/Date(1665619200000+0000)\/","content":"In this video, we guide you through creating OrmLite DB Migrations, which enhance OrmLite's lightweight code-first development approach by offering a simple change-based migration solution. This solution supports the code-first development workflow of OrmLite, streamlining the process. \n\nBy following the video, you'll learn how to effectively manage database schema changes while leveraging OrmLite's capabilities.","url":"https://youtu.be/NIVFqute7JQ","wordCount":66,"lineCount":10,"group":"features","order":3},{"slug":"video3","draft":false,"title":"Using Database Admin UI to browse your App's databases","tags":["db","admin","ui"],"date":"\/Date(1662076800000+0000)\/","content":"Database Admin UI lets Admin Users quickly browse and navigate your App's configured RDBMS schemas and tables,\nwith support for browsing, querying, ordering and filtering data directly from your database without needing to create any APIs \n\nConfiguration is imported from your AppHost which can be easily added in shared development or testing environments \nfor developers and non-developers alike to troubleshoot data issues","url":"https://youtu.be/NZkeyuc_prg","wordCount":74,"lineCount":11,"group":"ui-admin"},{"slug":"video2","draft":false,"title":"Use Redis Admin UI to inspect your App's Redis usage","tags":["redis","admin","ui"],"date":"\/Date(1661904000000+0000)\/","content":"Redis Admin UI lets you manage your App's configured Redis Server with a UX-friendly UI for managing core Redis data types, \nsimple search to quickly find Redis values, quick navigation between related values, \nfirst class support for JSON values and a flexible command interface and command history to inspect all previously run redis \ncommands that's easily editable & rerun","url":"https://youtu.be/AACZtTOcQbg","wordCount":73,"lineCount":11,"group":"ui-admin"},{"slug":"video2","draft":false,"title":"Build a Bookings API with Auto Admin UI in minutes","tags":["autoquery"],"date":"\/Date(1660608000000+0000)\/","content":"From an empty web project, this video shows how to:\n- Add SQLite & Authentication support\n- Define code-first Data Model with Validation\n- Add User Management support\n- Enable Audit History support\n- Add Excel integration","url":"https://youtu.be/rSFiikDjGos","wordCount":46,"lineCount":12,"group":"autoquery"},{"slug":"video2","draft":false,"title":"Build a Bookings API with Auto Admin UI in minutes","tags":["razor-pages","mvc","tailwind","vue"],"date":"\/Date(1660608000000+0000)\/","content":"In this video tutorial, we demonstrate the steps required to create a bookings API that is designed to be easy to use for non-developers. \n\nTo achieve this, we make use of the ServiceStack Locode and Admin UI features.\nWith [Locode](/auto-ui#locode), developers can easily generate a fully functional APIs with CRUD functionality \nwhilst many App features like User Access, Logging, Profiling & DB Validation can be managed from the built-in [Admin UI](/auto-ui#admin).","url":"https://youtu.be/rSFiikDjGos","wordCount":89,"lineCount":12,"group":"apis"},{"slug":"video3","draft":false,"title":"File Upload services the Easy way","tags":["autoquery","files","locode"],"date":"\/Date(1660608000000+0000)\/","content":"The `FileUploadFeature` plugin in ServiceStack enables developers to add managed file uploads to their applications, \nproviding integration with any ServiceStack service, including AutoQuery services, as well as the Locode App UI. \n\nThe modular JavaScript used in this example provides a structured & organized way to write JavaScript code that \ncan be reused in multiple components, further simplifying the development process.","url":"https://youtu.be/xSUqAB0HQB4","wordCount":70,"lineCount":11,"group":"apis"},{"slug":"video1","draft":false,"title":"Real-time insights with Request Logging & Profiling UIs","tags":["logging","profiling","api","ui"],"date":"\/Date(1658707200000+0000)\/","content":"The new Request Logging & Profiling UIs bring an invaluable new level of observability into your App, \nfrom being able to quickly inspect and browse incoming requests, to tracing their behavior from their generated events \nin the new Diagnostic Source capabilities added all throughout ServiceStack, which both power the new UIs and \nenables new introspectability from code where you can tap in to inspect & debug when diagnostic events occurs","url":"https://youtu.be/LgQHTSHSk1g","wordCount":82,"lineCount":10,"group":"ui-admin"},{"slug":"video4","draft":false,"title":"Create API validation rules from the Validation Admin UI","tags":["db","validation","admin","ui"],"date":"\/Date(1658707200000+0000)\/","content":"With very little code, we walk through the steps required to setup AutoQuery APIs with dynamic validation in .NET. \nThis enables non-developers to manage data, user access and validation rules all from a friendly admin UI \n\nRules can be applied at runtime taking immediate effect, with custom messages, status codes and notes about each rule \nmaking them easy to manage in a team setting","url":"https://youtu.be/W5OJAlOxH98","wordCount":77,"lineCount":11,"group":"ui-admin"},{"slug":"video5","draft":false,"title":"Create Simple, Fast, Reliable Apps with Litestream","tags":["ormlite","db","litestream","hosting"],"date":"\/Date(1658448000000+0000)\/","content":"This guide introduces [Litestream](https://litestream.io) for SQLite and demonstrates using ServiceStack Litestream mix templates for efficient setup. The tutorial focuses on SQLite backup and restore procedures during deployment via SSH and docker-compose, utilizing GitHub Actions. \n\nBy following these steps, you can streamline your SQLite management tasks and enhance your overall deployment process.","url":"https://youtu.be/WXRwT7ayc1Y","wordCount":64,"lineCount":9,"group":"actions"},{"slug":"video4","draft":false,"title":"Managed File Uploads","tags":["files","blazor"],"date":"\/Date(1654560000000+0000)\/","content":"In this walkthrough, we explore the `FilesUploadFeature` plugin and a demo FileBlazor App's \n[Managed Files Uploads](https://docs.servicestack.net/locode/files) solution. \n\nThe plugin is a powerful tool that adds managed file uploads to your ServiceStack App, seamlessly integrating \nwith any ServiceStack service, including AutoQuery services and [Locode](/auto-ui#locode) built-in UI \nand [Vue AutoQueryGrid](https://docs.servicestack.net/vue//autoquerygrid) and \n[Blazor Component Library](https://blazor-gallery.servicestack.net/gallery).","url":"https://youtu.be/5sd00MzHpaU","wordCount":72,"lineCount":14,"group":"apis"},{"slug":"video1","draft":false,"title":"Database first development with Locode","tags":["autoquery","autogen","locode"],"date":"\/Date(1652659200000+0000)\/","content":"In this video we show a step by step process for start with an existing database and customizations without the need for code first models.\n\n[Locode](https://docs.servicestack.net/locode/) is a generated API driven by your APIs metadata. \nCombined with other high-level ServiceStack features, it becomes a way to rapidly develop web applications with robust service APIs \nthat can be later extended with custom UIs.","url":"https://youtu.be/NiTp5Z_5U2Y","wordCount":76,"lineCount":12,"group":"autogen"},{"slug":"video3","draft":false,"title":"Rapidly develop apps with Locode","tags":["autoquery","locode"],"date":"\/Date(1652659200000+0000)\/","content":"ServiceStack Locode App is a generated API driven by your service metadata. When combined with AutoQuery, \nit becomes a way to rapidly develop web applications with robust service APIs that can be later extended with custom UIs. \n\nIn this video we show 3 examples from generating everything from an existing database, making customizations to the Locode \nApp, and finally reusing all your services in a custom Blazor WASM App","url":"https://youtu.be/hkuO_DMFXmc","wordCount":78,"lineCount":12,"group":"autoquery"},{"slug":"video1","draft":false,"title":"Rapidly develop apps with Locode","tags":["ui","api"],"date":"\/Date(1652659200000+0000)\/","content":"Learn how to easily create customizable feature-rich UX-friendly RDBMS Web Apps with Locode's\ninstant CRUD UI driven by your AutoQuery APIs that can be further extended with custom UIs\n\nIn this video we show 3 examples from generating everything from an existing database, making customizations to the Locode App, \nand finally reusing all your services in a custom Blazor WASM App","url":"https://youtu.be/hkuO_DMFXmc","wordCount":68,"lineCount":12,"group":"ui-locode"},{"slug":"video2","draft":false,"title":"Database-first development with Locode","tags":["ui","api"],"date":"\/Date(1652659200000+0000)\/","content":"To demonstrate a database-first development workflow we've enabled\n[AutoGen](https://docs.servicestack.net/autoquery-autogen)\non the **Northwind** sample database to generate \n[AutoQuery](https://docs.servicestack.net/autoquery-rdbms) & \n[CRUD](https://docs.servicestack.net/autoquery-crud) \nAPIs whose capabilities are used to power the custom Northwind Locode App","url":"https://youtu.be/NiTp5Z_5U2Y","wordCount":50,"lineCount":13,"group":"ui-locode"},{"slug":"video3","draft":false,"title":"Quickly create a code-first API and CRUD App with Locode","tags":["autoquery","crud","ui"],"date":"\/Date(1652659200000+0000)\/","content":"To showcase greater customizability options, we've exported AutoGen APIs of the **Chinook** sample database into typed AutoQuery APIs \n& Data Models to unlock more flexible code-first declarative & programmatic dev models that includes Custom UI components \nto showcase potential enhancements in Locode Apps","url":"https://youtu.be/mFyMgg7c3vg","wordCount":57,"lineCount":9,"group":"ui-locode"},{"slug":"video1","draft":false,"title":"Fastest way to a working gRPC Server and Flutter solution","tags":["flutter","dart","grpc"],"date":"\/Date(1648771200000+0000)\/","content":"The video guides viewers through configuring a Flutter application with gRPC .NET services using the `flutter-grpc` mix template, starting with Flutter and gRPC services introduction and installation of the required SDK and template. \n\nIt demonstrates creating typed Dart DTOs for gRPC services, making typed requests, and keeping the Flutter app in sync with the .NET backend through automatic updates.","url":"https://youtu.be/fgts6sQ2Ags","wordCount":73,"lineCount":9,"group":"grpc"},{"slug":"video4","draft":false,"title":"Rapidly develop C# .NET Next.js JamStack Apps with Rider","tags":["nextjs","react","jamstack"],"date":"\/Date(1644278400000+0000)\/","content":"In this comprehensive walkthrough, we will guide you through the ServiceStack Next.js template, which offers an \nexceptional rapid development cycle when used with JetBrains Rider. \n\nThis template is specifically designed for Microsoft .NET developers seeking a seamless and efficient Next.js React \nsetup while employing the better performing Jamstack architecture.","url":"https://youtu.be/3pPLRyPsO5A","wordCount":66,"lineCount":12,"group":"projects"},{"slug":"video3","draft":false,"title":"Ultimate Vue SPA & SSG Jamstack templates for .NET","tags":["vue","vite","jamstack"],"date":"\/Date(1643673600000+0000)\/","content":"In this video tutorial, we introduce the `vue-ssg` template, a powerful combination of Vite, Vue3, and ServiceStack \nthat offers an unparalleled developer experience\n\nThis template is specifically designed for .NET developers seeking a seamless and efficient Vue.js setup \nwhile employing the Jamstack architecture leveraging capabilities of Vite, Vue & ServiceStack","url":"https://youtu.be/D-rU0lU_B4I","wordCount":63,"lineCount":12,"group":"projects"},{"slug":"ultimate-vue-spa-ssg","draft":false,"title":"Ultimate Vue SPA & SSG Jamstack templates for .NET","tags":["vue","vite","jamstack"],"date":"\/Date(1643673600000+0000)\/","content":"In this video tutorial, we introduce the `vue-ssg` template, a powerful combination of Vite, Vue3, and ServiceStack \nthat offers an unparalleled developer experience\n\nThis template is specifically designed for .NET developers seeking a seamless and efficient Vue.js setup \nwhile employing the Jamstack architecture leveraging capabilities of Vite, Vue & ServiceStack","url":"https://youtu.be/D-rU0lU_B4I","wordCount":64,"lineCount":13,"group":"vue-projects","order":4},{"slug":"video1","draft":false,"title":"API Explorer - a better Postman & Swagger UI","tags":["ui","api"],"date":"\/Date(1643068800000+0000)\/","content":"The entire API Explorer UI is driven by the rich metadata around your APIs typed Service Contracts and AppHost's registered plugins\n\nIt's built from the ground up with multiple levels of customizations, supporting both declarative & programmatic models\nwhilst also enabling rich interactive HTML Components to document each of your APIs & their Types","url":"https://youtu.be/lUDlTMq9DHU","wordCount":65,"lineCount":10,"group":"ui-explorer"},{"slug":"video2","draft":false,"title":"Add Typed C#, TypeScript, F# and VB.NET ServiceStack References from JetBrains Rider","tags":["rider","c#","f#","vb"],"date":"\/Date(1629936000000+0000)\/","content":"The ServiceStack plugin for Jetbrains Rider simplifies managing your C#, F# and VB.NET client integrations by automating the generation of typed DTOs, request and response models, and client libraries.\n\nIn this video, we demonstrate the process of installing and utilizing the JetBrains Rider plugin to manage your client integrations for your ServiceStack .NET clients.","url":"https://youtu.be/JKsgrstNnYY","wordCount":72,"lineCount":9,"group":"ss-ref"},{"slug":"video6","draft":false,"title":"Post Command line HTTP API tools","tags":["inspect","tool"],"date":"\/Date(1629676800000+0000)\/","content":"[Post Command](https://docs.servicestack.net/post-command) is a collection of command line utils that lets you easily discover,\ninspect and invoke ServiceStack endpoints from a single command.\n\nUse [inspect](https://docs.servicestack.net/post-command#inspect-command) to discover features and APIs available on a remote\nServiceStack endpoint including the version of ServiceStack running, the App’s registered Content Types, Plugins and Auth Providers\nas well as its public APIs, their routes and Response Types.","url":"https://youtu.be/FcXG4RnlVQk","wordCount":76,"lineCount":11,"group":"apis"},{"slug":"video1","draft":false,"title":"Call typed .NET APIs from Python","tags":["python","vscode","jupyter"],"date":"\/Date(1629158400000+0000)\/","content":"The video tutorial walks through how to leverage Add ServiceStack Reference for Python in different Python IDEs \nsuch as PyCharm, VSCode, and Jupyter Notebooks \n\nAdd ServiceStack Reference is a powerful tool that automatically generates typed Python DTOs for your \nServiceStack APIs, saving you time and effort. With this tool, you can access your web services with \nease and benefit from the productivity boost it provides.","url":"https://youtu.be/WjbhfH45i5k","wordCount":76,"lineCount":13,"group":"ss-ref"},{"slug":"video1","draft":false,"title":"Create Python Jupyter Notebooks for .NET APIs","tags":["jupyter","python"],"date":"\/Date(1629158400000+0000)\/","content":"The video demonstrates generating Jupyter Notebooks using ServiceStack **x** tool and [Instant Client Apps](https://apps.servicestack.net), which together provide an efficient and portable development experience. \n\nThis enables developers to use Jupyter Notebooks for tasks like data analysis, visualization, and machine learning in a transferable manner across environments.","url":"https://youtu.be/h6UwDuXt8MA","wordCount":61,"lineCount":10,"group":"jupyter"},{"slug":"video2","draft":false,"title":"Create C# Jupyter Notebooks to Inspect & Chart .NET APIs","tags":["jupyter","c#"],"date":"\/Date(1629158400000+0000)\/","content":"This video demonstrates integrating .NET Interactive and JupyterLab to enhance the development experience, creating a seamless workflow when working with ServiceStack services. \n\nIt guides viewers through generating working C# notebooks for any ServiceStack service, highlighting improved productivity through these tools which are FREE on [mybinder.org](https://mybinder.org).","url":"https://youtu.be/vt92pbet5bY","wordCount":64,"lineCount":11,"group":"jupyter"},{"slug":"video3","draft":false,"title":"Create F# Jupyter Notebooks to inspect .NET APIs & run FREE on Binder","tags":["jupyter","f#"],"date":"\/Date(1629158400000+0000)\/","content":"This video demonstrates integrating .NET Interactive and JupyterLab to enhance the development experience, creating a seamless workflow when working with ServiceStack services.\n\nIt guides viewers through generating working F# notebooks for any ServiceStack service, highlighting improved productivity through these tools which are FREE on [mybinder.org](https://mybinder.org).","url":"https://youtu.be/PxH3K5WIDx8","wordCount":66,"lineCount":10,"group":"jupyter"},{"slug":"razor-press","draft":false,"title":"VitePress and Jekyll alternative for SSG Docs","tags":["razor-pages","ssg","tailwind","markdown"],"date":"\/Date(1626134400000+0000)\/","content":"Introducing Razor Press, a powerful ServiceStack project template for creating documentation and content-centric websites \nusing .NET's Razor Pages, Markdown, Tailwind CSS, and Vue. \n\nLearn how Razor Press aids in the easy creation, and deployment of your statically generated sites that can be hosted for \nFREE on GitHub Pages CDN","url":"https://youtu.be/uqEa_DfFFDQ","wordCount":61,"lineCount":12,"group":"vue-projects","order":2},{"slug":"video2","draft":false,"title":"Modern Razor Pages & MVC .NET Tailwind templates","tags":["razor-pages","mvc","tailwind","vue"],"date":"\/Date(1625529600000+0000)\/","content":"ServiceStack templates provide a wide range of options when it comes to using Razor Pages in your .NET application\n\nThese templates come with Tailwind, JS Modules, and Vue components already built-in,\nmaking it easy to build hybrid apps containing both Server-Side Rendering (SSR) and static resources\n\n### Live Demos\n- https://razor-tailwind.web-templates.io\n- https://web-tailwind.web-templates.io\n- https://mvc-tailwind.web-templates.io\n- https://vue-mjs.web-templates.io\n- https://razor-pages.web-templates.io","url":"https://youtu.be/SyppvQB7IPs","wordCount":73,"lineCount":18,"group":"projects"},{"slug":"video1","draft":false,"title":"Intro to ServiceStack","tags":["apis"],"date":"\/Date(1625529600000+0000)\/","content":"In this introduction to ServiceStack, we will guide you through the framework's message-based design and its numerous benefits, \nwhich include promoting simplicity and enabling maximum reuse. \n\nBy utilizing a message-based design, ServiceStack encourages developers to focus on the core functionality of their services while \nabstracting away complexities, resulting in a more streamlined and efficient development process.","url":"https://youtu.be/Vae0ALalIP0","wordCount":64,"lineCount":12,"group":"apis"},{"slug":"modern-razor-tailwind","draft":false,"title":"Modern Razor Pages & MVC .NET Tailwind templates","tags":["razor-pages","mvc","tailwind","vue"],"date":"\/Date(1625529600000+0000)\/","content":"ServiceStack templates provide a wide range of options when it comes to using Razor Pages in your .NET application\n\nThese templates come with Tailwind, JS Modules, and Vue components already built-in,\nmaking it easy to build hybrid apps containing both Server-Side Rendering (SSR) and static resources","url":"https://youtu.be/SyppvQB7IPs","wordCount":57,"lineCount":12,"group":"vue-projects","order":1},{"slug":"video5","draft":false,"title":"Rapidly develop .NET Vue.js SPA Apps","tags":["vue"],"date":"\/Date(1621555200000+0000)\/","content":"In this video tutorial, we will guide you through the process of utilizing the vue-spa template, an exceptional project template \nthat combines the power of ServiceStack and Vue.js to create a seamless development experience. \n\nThis template is specifically designed to optimize rapid iterative dev cycles, allowing developers to quickly iterate on their \nfrontend and backend changes.","url":"https://youtu.be/4HphWPrKwb0","wordCount":68,"lineCount":11,"group":"projects"},{"slug":"rapid-vue-mjs","draft":false,"title":"Rapidly develop .NET Vue.js SPA Apps","tags":["vue"],"date":"\/Date(1621555200000+0000)\/","content":"In this video tutorial, we will guide you through the process of utilizing the vue-spa template, an exceptional project template \nthat combines the power of ServiceStack and Vue.js to create a seamless development experience. \n\nThis template is specifically designed to optimize rapid iterative dev cycles, allowing developers to quickly iterate on their \nfrontend and backend changes.","url":"https://youtu.be/4HphWPrKwb0","wordCount":69,"lineCount":12,"group":"vue-projects","order":5},{"slug":"video2","draft":false,"title":"Enabling Dart gRPC support to ServiceStack .NET Apps","tags":["dart","grpc"],"date":"\/Date(1620864000000+0000)\/","content":"This video tutorial explains how to easily transform ServiceStack services into gRPC services by generating the `.proto` file automatically from your service definitions.\n\nIt also showcases the [ServiceStack x tool](https://docs.servicestack.net/dotnet-tool)'s powerful features streamline integration, automate repetitive tasks, and support various languages, enabling the development of faster, more efficient, and scalable applications.","url":"https://youtu.be/UQlYodNS1xc","wordCount":68,"lineCount":9,"group":"grpc"},{"slug":"video2","draft":false,"title":"Enabling Dart gRPC support to ServiceStack .NET Apps","tags":["dart","grpc"],"date":"\/Date(1620864000000+0000)\/","content":"In this video we walk through how to enable gRPC endpoints for your existing ServiceStack services\nand how the [x dotnet tool](https://docs.servicestack.net/dotnet-tool) greatly\nsimplifies the development workflow of maintaining in-sync client integrations in a simple and consistent\nway across all gRPC languages","url":"https://youtu.be/UQlYodNS1xc","wordCount":54,"lineCount":10,"group":"flutter-grpc"},{"slug":"video1","draft":false,"title":"Call typed .NET APIs from Flutter Android Apps using Dart","tags":["flutter","dart","android"],"date":"\/Date(1619654400000+0000)\/","content":"In this video, we will demonstrate how you can swiftly set up and begin utilizing ServiceStack's Dart client library with your Flutter Android or iOS applications.\n\nThis also enables you to automate the generation native typed Dart Data Transfer Objects (DTOs) using the Add ServiceStack Reference feature, which simplifies the integration process and typed end-to-end communication between your Flutter Mobile Apps.","url":"https://youtu.be/ocH5L-CikQ0","wordCount":76,"lineCount":10,"group":"mobile"},{"slug":"video3","draft":false,"title":"Call .NET APIs from a Flutter Android App with native Dart","tags":["flutter","android","apis"],"date":"\/Date(1619654400000+0000)\/","content":"In this video we should how you can quickly get up and running using ServiceStack's \nDart client library with your Flutter Android or iOS Apps \nto generate native typed Dart DTOs with [Add ServiceStack Reference](https://docs.servicestack.net/dart-add-servicestack-reference)\nenabling end-to-end typed integrations to call .NET APIs from Flutter Mobile, Desktop and Dart Web Apps","url":"https://youtu.be/ocH5L-CikQ0","wordCount":69,"lineCount":11,"group":"flutter"},{"slug":"video2","draft":false,"title":"Using GitHub Actions for CI & .NET App Deployments","tags":["github-actions","deployment"],"date":"\/Date(1619049600000+0000)\/","content":"This tutorial demonstrates enabling continuous integration, deployment, hosting, and Let's Encrypt HTTPS configuration for an existing ServiceStack Project using the new mix support for GitHub Actions. \n\nWe'll guide you through the process of integrating these powerful features into your project. By following the tutorial, you'll streamline your workflow of your ServiceStack Project.","url":"https://youtu.be/0PvzcnxlBvc","wordCount":65,"lineCount":9,"group":"actions"},{"slug":"video2","draft":false,"title":"Servicify an existing RDBMS with AutoQuery","tags":["autoquery","autogen"],"date":"\/Date(1618963200000+0000)\/","content":"ServiceStack’s AutoGen enables a number of exciting possibilities, predominantly it’s the fastest way to ServiceStack-ify an existing systems \nRDBMS where it will serve as an invaluable tool for anyone wanting to quickly migrate to ServiceStack and access its functionality \necosystem around ServiceStack Services","url":"https://youtu.be/NaJ7TW-Q_pU","wordCount":53,"lineCount":11,"group":"autogen"},{"slug":"video3","draft":false,"title":"Deploy Docker .NET Apps to AWS ECS with GitHub Actions","tags":["github-actions","deployment","aws","ecs"],"date":"\/Date(1618963200000+0000)\/","content":"ServiceStack projects, enabling the configuration for building, testing, and deploying to a cost-efficient AWS ECS setup. By utilizing this approach, Docker Apps can be deployed on a single instance, automatically configured behind an NGINX proxy with Let's Encrypt SSL support. \n\nFollowing this tutorial will streamline your workflow of your ServiceStack projects.","url":"https://youtu.be/Eh4tvLN8i8g","wordCount":66,"lineCount":10,"group":"actions"},{"slug":"video3","draft":false,"title":"Create Instant Client Apps from C# .NET Web APIs","tags":["c#","f#","node.js","dart"],"date":"\/Date(1618963200000+0000)\/","content":"Generate working native client apps for your live ServiceStack services, in a variety of languages, instantly with our free managed service.\n\nThis tool enables your developers, and even your customers, to open a working example native application straight from the web to their favorite IDE.","url":"https://youtu.be/GTnuMhvUayg","wordCount":60,"lineCount":10,"group":"ss-ref"},{"slug":"video2","draft":false,"title":"Call typed .NET APIs from Xamarin.Android in C#","tags":["xamarin","android","c#"],"date":"\/Date(1618963200000+0000)\/","content":"ServiceStack framework and Add ServiceStack Reference tool can be utilized in mobile applications built with Xamarin.Android, enabling developers to create native Android applications using C# and .NET framework. \n\nAdd ServiceStack Reference simplifies the consumption of web services by generating your Request DTOs for easy API access. This saves time and effort, promoting faster mobile app development.","url":"https://youtu.be/cbYuem1b2tg","wordCount":70,"lineCount":9,"group":"mobile"},{"slug":"video4","draft":false,"title":"Run ServiceStack .NET Apps in AWS Lambda Containers","tags":["github-actions","deployment","aws","lambda"],"date":"\/Date(1612224000000+0000)\/","content":"This walkthrough demonstrates deploying a ServiceStack application to AWS Lambda using Docker containers through GitHub Actions. By following the guide, you'll learn the process of automating deployment and leveraging the advantages of containerization. \n\nThis approach simplifies the deployment process of your ServiceStack applications.\n\n - [Learn More](https://docs.servicestack.net/templates-aws)","url":"https://youtu.be/8mpGNTsSlvE","wordCount":62,"lineCount":11,"group":"actions"}],"posts":[{"slug":"cloud-value-between-architectures","draft":false,"title":"Should .NET Apps switch to ARM?","summary":"Evaluating the cost and performance of ARM vs x86 in AWS, Azure, and Hetzner","image":"https://images.unsplash.com/photo-1587845323226-bad89242c735?crop=entropy&fit=crop&h=1000&w=2000","author":"Darren Reid","tags":["dotnet"," hosting"," arm"," performance"],"date":"\/Date(1693180800000-0000)\/","url":"https://servicestack.net/posts/cloud-value-between-architectures","wordCount":3264,"lineCount":394},{"slug":"razor-ssg-new-blog-features","draft":false,"title":"New Blogging features in Razor SSG","summary":"Explore the new Blogging Features in Razor SSG","image":"https://images.unsplash.com/photo-1486312338219-ce68d2c6f44d?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["razor"," markdown"," blog"," dev"],"date":"\/Date(1692748800000-0000)\/","url":"https://servicestack.net/posts/razor-ssg-new-blog-features","wordCount":1296,"lineCount":337},{"slug":"jsonl-format","draft":false,"title":"Exploring the new streamable JSON Lines Format","summary":"A dive into the JSON Lines format and how to use it in ServiceStack","image":"https://images.unsplash.com/photo-1687042268541-5cc60ad9d3de?crop=entropy&fit=crop&h=1000&w=2000","author":"Darren Reid","tags":["serialization"," servicestack"," jsonl"],"date":"\/Date(1692057600000-0000)\/","url":"https://servicestack.net/posts/jsonl-format","wordCount":1656,"lineCount":217},{"slug":"kubernetes_not_required","draft":false,"title":"Using GitHub for Auto Deployments - Kubernetes Not Required","summary":"A cost-effective and straightforward web app deployment pattern using GitHub and a single Linux server","image":"https://images.unsplash.com/photo-1667372459510-55b5e2087cd0?crop=entropy&fit=crop&h=1000&w=2000","author":"Darren Reid","tags":["github-actions"," devops"," hosting"],"date":"\/Date(1691452800000-0000)\/","url":"https://servicestack.net/posts/kubernetes_not_required","wordCount":5292,"lineCount":693},{"slug":"bulk-insert-performance","draft":false,"title":"Which RDBMS has the fastest .NET Bulk Insert implementation?","summary":"Measuring the different performance of RDBMS Bulk Insert implementations","image":"https://images.unsplash.com/photo-1517026575980-3e1e2dedeab4?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["db"," dev"," dotnet"],"date":"\/Date(1690761600000-0000)\/","url":"https://servicestack.net/posts/bulk-insert-performance","wordCount":6965,"lineCount":1070},{"slug":"postgres-mysql-sqlserver-on-apple-silicon","draft":false,"title":"Install PostgreSQL, MySql and SQL Server on Apple Silicon","summary":"Easiest way to install PostgreSQL, MySql and SQL Server on macOS running Apple Silicon's M2","image":"https://images.unsplash.com/photo-1517663404855-6f96c7aa20e2?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["db"," dev"],"date":"\/Date(1690243200000-0000)\/","url":"https://servicestack.net/posts/postgres-mysql-sqlserver-on-apple-silicon","wordCount":1673,"lineCount":328},{"slug":"semantic-kernel-gptmeetngs","draft":false,"title":"Trying Microsoft's Semantic Kernel","summary":"Incorporating the Semantic Kernel into our GPT Meeting Agent gives developers more flexibility when working with LLMs","image":"https://images.unsplash.com/photo-1579548122080-c35fd6820ecb?crop=entropy&fit=crop&h=1000&w=2000","author":"Darren Reid","tags":["dotnet"," ai"," semantic-kernel"," gpt"],"date":"\/Date(1689638400000-0000)\/","url":"https://servicestack.net/posts/semantic-kernel-gptmeetngs","wordCount":834,"lineCount":54},{"slug":"razor-press","draft":false,"title":"Introducing Razor Press","summary":"Markdown & Razor Pages Static Site Generator for beautiful fast Content & Documentation","image":"https://images.unsplash.com/photo-1681301968680-fe46a0cd51be?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["razor"," markdown"," blog"," dev"],"date":"\/Date(1689552000000-0000)\/","url":"https://servicestack.net/posts/razor-press","wordCount":946,"lineCount":162},{"slug":"using-json-patch","draft":false,"title":"JSON Patch secrets into appsettings.json","summary":"Simplify managing App secrets by JSON patching them into your appsettings.json with during deployments","image":"https://images.unsplash.com/photo-1563089145-599997674d42?crop=entropy&fit=crop&h=1000&w=2000","author":"Darren Reid","tags":["devops"," github-actions"],"date":"\/Date(1689033600000-0000)\/","url":"https://servicestack.net/posts/using-json-patch","wordCount":670,"lineCount":135},{"slug":"new_razor_ssg_docs","draft":false,"title":"New Razor SSG generated docs.servicestack.net","summary":"The new docs.servicestack.net website is now generated with Razor SSG - now with Dark Mode!","image":"https://images.unsplash.com/photo-1526243741027-444d633d7365?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["razor"," ssg"," documentation"],"date":"\/Date(1688947200000-0000)\/","url":"https://servicestack.net/posts/new_razor_ssg_docs","wordCount":750,"lineCount":87},{"slug":"vue-stable-diffusion","draft":false,"title":"Vue Stable Diffusion","summary":"Rewriting Blazor Diffussion image generation & album catalog in Vue & Razor SSG","image":"https://images.unsplash.com/photo-1573490647695-2892d0bf89e7?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["vue"," tailwind"],"date":"\/Date(1686787200000-0000)\/","url":"https://servicestack.net/posts/vue-stable-diffusion","wordCount":1057,"lineCount":209},{"slug":"admin-uis","draft":false,"title":"Build Beautiful Admin UIs, Fast","summary":"Taking a look at the new features in Vue Razor Pages template to build Admin UIs, Fast","image":"https://images.unsplash.com/photo-1667906962043-a3e82dea23a3?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["vue"," tailwind"," admin"],"date":"\/Date(1686614400000-0000)\/","url":"https://servicestack.net/posts/admin-uis","wordCount":1879,"lineCount":364},{"slug":"creatorkit","draft":false,"title":"Introducing CreatorKit","summary":"Exploring CreatorKit - an OSS Self-Hosting alternative to Mailchimp and Disqus","image":"https://images.unsplash.com/photo-1493723843671-1d655e66ac1c?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["creatorkit"," marketing"," publishing"],"date":"\/Date(1686182400000-0000)\/","url":"https://servicestack.net/posts/creatorkit","wordCount":1348,"lineCount":209},{"slug":"chat-gpt-agents","draft":false,"title":"Creating ChatGPT Agents to call System APIs","summary":"A walkthrough of how to enable Large Language Model 'Agents' with access to your own ServiceStack APIs","image":"https://images.unsplash.com/photo-1675271591211-126ad94e495d?crop=entropy&fit=crop&h=1000&w=2000","author":"Darren Reid","tags":["servicestack"," gpt"," chatbot"," ai"],"date":"\/Date(1683849600000-0000)\/","url":"https://servicestack.net/posts/chat-gpt-agents","wordCount":1952,"lineCount":273},{"slug":"autoquery-xkcd","draft":false,"title":"Bringing xkcd static dataset to life with AutoQuery","summary":"Unsiloing data quickly with AutoQuery to make your datasets available from queryable Web APIs","image":"./img/posts/autoquery-xkcd/drawing-xkcd-upscaled.jpg","author":"Darren Reid","tags":["autoquery"," db"," dev"," huggingface"," vue"],"date":"\/Date(1681516800000-0000)\/","url":"https://servicestack.net/posts/autoquery-xkcd","wordCount":3352,"lineCount":551},{"slug":"razor-ssg","draft":false,"title":"Introducing Razor SSG","summary":"Create fast, beautiful statically rendered Razor Websites & Blogs","image":"https://images.unsplash.com/photo-1579767684138-a57e917d30aa?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["razor"," markdown"," blog"," dev"],"date":"\/Date(1680134400000-0000)\/","url":"https://servicestack.net/posts/razor-ssg","wordCount":3070,"lineCount":596},{"slug":"new_razor_ssg_website","draft":false,"title":"New Razor SSG generated servicestack.net","summary":"Celebrating 150M Downloads with a new Razor SSG generated Website","image":"https://images.unsplash.com/photo-1475669698648-2f144fcaaeb1?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["razor"," ssg"," website"],"date":"\/Date(1680048000000-0000)\/","url":"https://servicestack.net/posts/new_razor_ssg_website","wordCount":567,"lineCount":77},{"slug":"javascript","draft":false,"title":"Simple, Modern JavaScript","summary":"Learn about JS Modules, Vue 3 and available rich UI Components","image":"https://images.unsplash.com/photo-1497515114629-f71d768fd07c?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["js"," dev"],"date":"\/Date(1675209600000-0000)\/","url":"https://servicestack.net/posts/javascript","wordCount":3118,"lineCount":612},{"slug":"prerendering","draft":false,"title":"Prerendering Razor Pages","summary":"Improving Blog Performance with Prerendering","image":"https://images.unsplash.com/photo-1522526886914-6e8d4fd91399?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["c#"," dev"," markdown"],"date":"\/Date(1673395200000-0000)\/","url":"https://servicestack.net/posts/prerendering","wordCount":1160,"lineCount":235},{"slug":"rider","draft":false,"title":"Develop using JetBrains Rider","summary":"Setting up & exploring development workflow in Rider","image":"https://images.unsplash.com/photo-1472289065668-ce650ac443d2?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["c#"," dev"],"date":"\/Date(1673395200000-0000)\/","url":"https://servicestack.net/posts/rider","wordCount":472,"lineCount":77},{"slug":"vs","draft":false,"title":"Develop using Visual Studio","summary":"Exploring development workflow in VS Code and Visual Studio .NET","image":"https://images.unsplash.com/photo-1513542789411-b6a5d4f31634?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["c#"," dev"],"date":"\/Date(1673308800000-0000)\/","url":"https://servicestack.net/posts/vs","wordCount":1325,"lineCount":76},{"slug":"jamstacks_hosting","draft":false,"title":"Jamstack Hosting Costs @ $.40 /mo","summary":"Exploring cost & scalability benefits of hybrid CDN & .NET Apps","image":"https://images.unsplash.com/photo-1506399309177-3b43e99fead2?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["dev"," hosting"," devops"],"date":"\/Date(1672617600000-0000)\/","url":"https://servicestack.net/posts/jamstacks_hosting","wordCount":3054,"lineCount":83},{"slug":"deploy","draft":false,"title":"Deployment with GitHub Actions","summary":"Configuring your GitHub repo for SSH and CDN deployments","image":"https://images.unsplash.com/photo-1485841890310-6a055c88698a?crop=entropy&fit=crop&h=1000&w=2000","author":"Darren Reid","tags":["github-actions"," devops"," hosting"],"date":"\/Date(1672531200000-0000)\/","url":"https://servicestack.net/posts/deploy","wordCount":724,"lineCount":107},{"slug":"hetzner-cloud","draft":false,"title":"In pursuit of the best value US cloud provider","summary":"We've been using AWS at ServiceStack for 10+ years, it's served us well but suffers from complex & expensive pricing","image":"https://images.unsplash.com/photo-1451187580459-43490279c0fa?crop=entropy&fit=crop&h=1000&w=2000","author":"Darren Reid","tags":["dev"," hosting"," devops"],"date":"\/Date(1662422400000-0000)\/","url":"https://servicestack.net/posts/hetzner-cloud","wordCount":2702,"lineCount":227},{"slug":"typesense","draft":false,"title":"Real-time search with Typesense","summary":"As part of migrating docs to VitePress we've added UX improvements like instant search powered by Typesense!","image":"https://images.unsplash.com/photo-1473163928189-364b2c4e1135?crop=entropy&fit=crop&h=1000&w=2000","author":"Darren Reid","tags":["dev"," docs"],"date":"\/Date(1636329600000-0000)\/","url":"https://servicestack.net/posts/typesense","wordCount":4546,"lineCount":386},{"slug":"jekyll-to-vitepress","draft":false,"title":"Migrating from Jekyll to VitePress","summary":"Since Jekyll support has been officially sunset, we decided to migrate our docs site to VitePress","image":"https://images.unsplash.com/photo-1524668951403-d44b28200ce0?crop=entropy&fit=crop&h=1000&w=2000","author":"Darren Reid","tags":["docs"," markdown"],"date":"\/Date(1635724800000-0000)\/","url":"https://servicestack.net/posts/jekyll-to-vitepress","wordCount":2479,"lineCount":355}]} \ No newline at end of file +{"pages":[{"slug":"community-rules","draft":false,"title":"Community Rules","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/community-rules","wordCount":412,"lineCount":37},{"slug":"links","draft":false,"title":"Quick Shortcuts to ServiceStack Sites","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/links","wordCount":52,"lineCount":13},{"slug":"mail-preferences","draft":false,"title":"Manage your mail preferences","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/mail-preferences","wordCount":113,"lineCount":13},{"slug":"privacy","draft":false,"title":"Privacy Policy for ServiceStack, Inc","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/privacy","wordCount":1151,"lineCount":92},{"slug":"register","draft":false,"title":"License Registration","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/register","wordCount":327,"lineCount":76},{"slug":"signup-confirmed","draft":false,"title":"Welcome to ServiceStack Newsletter","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/signup-confirmed","wordCount":53,"lineCount":8},{"slug":"terms","draft":false,"title":"ServiceStack License Agreement","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/terms","wordCount":3036,"lineCount":136},{"slug":"creatorkit/about","draft":false,"title":"About","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/creatorkit/about","wordCount":597,"lineCount":100,"order":1},{"slug":"creatorkit/install","draft":false,"title":"Install","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/creatorkit/install","wordCount":1751,"lineCount":263,"order":2},{"slug":"creatorkit/customize","draft":false,"title":"Customize","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/creatorkit/customize","wordCount":463,"lineCount":125,"order":3},{"slug":"creatorkit/components","draft":false,"title":"Components","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/creatorkit/components","wordCount":855,"lineCount":195,"order":4},{"slug":"creatorkit/integrations","draft":false,"title":"Integrations","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/creatorkit/integrations","wordCount":107,"lineCount":29,"order":5},{"slug":"creatorkit/portal-overview","draft":false,"title":"Overview","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/creatorkit/portal-overview","wordCount":163,"lineCount":40,"group":"Portal","order":6},{"slug":"creatorkit/portal-messages","draft":false,"title":"Messages","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/creatorkit/portal-messages","wordCount":1047,"lineCount":250,"group":"Portal","order":7},{"slug":"creatorkit/portal-mailruns","draft":false,"title":"Mail Runs","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/creatorkit/portal-mailruns","wordCount":1303,"lineCount":277,"group":"Portal","order":8},{"slug":"creatorkit/portal-posts","draft":false,"title":"Posts","tags":[],"date":"\/Date(1693384476360)\/","url":"https://servicestack.net/creatorkit/portal-posts","wordCount":180,"lineCount":28,"group":"Portal","order":9}],"whatsnew":[{"slug":"razor-press","draft":false,"title":"Introducing Razor Press","image":"https://servicestack.net/img/whatsnew/v6.10/razor-press.png","tags":[],"date":"\/Date(1690761600000-0000)\/","content":"Razor Press is a **Razor Pages** and **Markdown** powered alternative to Ruby's Jekyll & Vue's VitePress that's ideal for\ngenerating fast, static content-centric & documentation websites. Inspired by [VitePress](https://vitepress.dev),\nit's designed to effortlessly create documentation around content written in Markdown, rendered using C# Razor Pages\nthat's beautifully styled with [tailwindcss](https://tailwindcss.com) and [@tailwindcss/typography](https://tailwindcss.com/docs/typography-plugin).\n\nThe resulting statically generated HTML pages can be easily deployed anywhere, where it can be hosted by any HTTP Server or CDN.\nBy default it includes GitHub Actions to deploy it your GitHub Repo's **gh-pages** branch where it's hosted for FREE\non [GitHub Pages](https://pages.github.com) CDN which can be easily configured to use your\n[Custom Domain](https://docs.github.com/en/pages/configuring-a-custom-domain-for-your-github-pages-site).","url":"https://docs.servicestack.net/releases/v6_10","wordCount":127,"lineCount":16,"group":"v6.10","order":1},{"slug":"new-in-razor-ssg","draft":false,"title":"New in Razor SSG","image":"https://servicestack.net/img/whatsnew/v6.10/twitter-cards.png","tags":[],"date":"\/Date(1690761600000-0000)\/","content":"The Razor SSG template continues to see improvements for creating richer static websites and Blogs: \n\n - RSS Feed for Blog Posts\n - New Razor Press Markdown Containers\n - Support for Markdown Includes\n - Meta Headers support for Twitter cards and Improved SEO\n - Blog Posts can include rich Vue Components\n - Light and Dark Mode Query Params\n - Threads and Mastodon Links for Blog Authors","url":"https://docs.servicestack.net/releases/v6_10#new-in-razor-ssg","wordCount":77,"lineCount":16,"group":"v6.10","order":2},{"slug":"rdbms-bulk-inserts","draft":false,"title":"RDBMS Bulk Inserts","image":"https://servicestack.net/img/whatsnew/v6.10/bulk-inserts.png","tags":[],"date":"\/Date(1690761600000-0000)\/","content":"The latest release of OrmLite includes Bulk Inserts implementations for each supported RDBMS to support the most \nefficient ways for inserting large amounts of data, which is encapsulated behind OrmLite's new BulkInsert API\nwhich are up to **138x times faster** than traditional single INSERT statements.\n\nIn addition to an optimal default Bulk Insert implementation, it can also be configured to execute batched \nSQL Insert statements with configurable batch sizes which enjoys broad support across all RDBMS's.","url":"https://docs.servicestack.net/releases/v6_10#rdbms-bulk-inserts","wordCount":85,"lineCount":12,"group":"v6.10","order":3},{"slug":"jsonl-data-format","draft":false,"title":"JSON Lines Data Format","image":"https://servicestack.net/img/whatsnew/v6.10/jsonl.png","tags":[],"date":"\/Date(1690761600000-0000)\/","content":"JSON Lines is an efficient JSON data format parseable by streaming parsers and text processing tools like Unix \nshell pipelines, whose streamable properties is making it a popular data format for maintaining large datasets \nlike the large AI datasets maintained on [huggingface.co](https://huggingface.co) that's now accessible on \n[Auto HTML API pages](https://docs.servicestack.net/auto-html-api).\n\nThe JSON Lines data format behaves the same way as the CSV format where it will automatically serialize the \nfirst IEnumerable property, including for all AutoQuery APIs which now benefit from a streamable JSON data format.","url":"https://docs.servicestack.net/releases/v6_10#json-lines-data-format","wordCount":104,"lineCount":13,"group":"v6.10","order":4},{"slug":"creator-kit","draft":false,"title":"Introducing CreatorKit","image":"https://servicestack.net/img/whatsnew/v6.9/creatorkit-splash.png","tags":[],"date":"\/Date(1686009600000-0000)\/","content":"CreatorKit is a simple, customizable, self-hostable alternative solution to using Mailchimp for managing an organization's \nmailing lists, accepting newsletter subscriptions, defining customizable email layouts and templates and sending \nrich HTML emails to your Customers and subscribers using your preferred SMTP provider.\n\nIt also provides a private alternative to using Disqus to enhance websites with a threading and commenting system \non your preferred blog posts and website pages that you want to be able to connect with your community on.","url":"https://docs.servicestack.net/releases/v6_09","wordCount":88,"lineCount":12,"group":"v6.9","order":1},{"slug":"build-admin-uis-fast","draft":false,"title":"Build Admin UIs, Fast","image":"https://servicestack.net/img/whatsnew/v6.9/admin-ui.png","tags":[],"date":"\/Date(1686009600000-0000)\/","content":"The new `` is a high-productivity Vue Component that combined with the `` content\ncan save an invaluable amount of time in being able to rapidly create custom Admin UIs.\n\nThe [vue-mjs](https://vue-mjs.web-templates.io) now includes a [Client Admin UI](https://vue-mjs.web-templates.io/portal/)\nshowing how we can replicate most of Locode's Auto UI in a customizable Vue App from a single \n[index.html](https://github.com/NetCoreTemplates/vue-mjs/blob/main/MyApp/wwwroot/portal/index.html) page. It also includes\nan example of a [Server Rendered Admin UI](https://vue-mjs.web-templates.io/admin/) for those that prefer to develop\nMulti Page Apps with Razor Pages.","url":"https://docs.servicestack.net/releases/v6_09#build-admin-uis-fast","wordCount":103,"lineCount":14,"group":"v6.9","order":2},{"slug":"creating-gpt-agents","draft":false,"title":"Creating ChatGPT Agents to call System APIs","image":"https://servicestack.net/img/whatsnew/v6.9/gptmeetings.jpg","tags":[],"date":"\/Date(1686009600000-0000)\/","content":"We've been working on different patterns of development to enable ChatGPT to leverage an App's ServiceStack APIs \nto solve given tasks. This is done through various prompting techniques which allows the Agent to reason about the \ncontext of the conversation and make decisions to reach for different 'tools' (your APIs) when trying to achieve \na specific goal.\n\nFor anyone wishing to incorporate AI into their systems we've created a introductory video into the techniques \nof how to leverage Large Language Models (LLMs) like GPT so they can make informed decisions on which of your \ninternal APIs they should call to accomplish a given task described in natural language.","url":"https://docs.servicestack.net/releases/v6_09#creating-chatgpt-agents-to-call-system-apis","wordCount":122,"lineCount":14,"group":"v6.9","order":3},{"slug":"vue-stable-diffusion","draft":false,"title":"Vue Stable Diffusion","image":"https://servicestack.net/img/whatsnew/v6.9/vuediffusion.png","tags":[],"date":"\/Date(1686009600000-0000)\/","content":"Following [blazordiffusion.com](https://blazordiffusion.com) which was created to showcase ServiceStack's\nBlazor Server and Blazor WASM [project templates and components](https://servicestack.net/blazor), \nwe've rewritten a new Stable Diffusion App in Vue adopting a\n[Simple Modern JavaScript](https://razor-ssg.web-templates.io/posts/javascript) approach to showcase the **Razor SSG**\nProject Template and Tailwind [Vue Component Library](https://docs.servicestack.net/vue/) available at:\n\n

\n https://diffusion.works\n

\n\nVue Diffusion is built differently from other Razor SSG Apps as instead of being pre-rendered from static content \nlike Markdown documents, it's prerendered from https://blazordiffusion.com APIs to render its dynamic \n[Albums](https://diffusion.works/albums/), \n[Top](https://diffusion.works/top) and [Latest](https://diffusion.works/latest) pages at deployment which it does by \nconfiguring the App's Service Gateway to reference external Blazor Diffusion APIs.","url":"https://docs.servicestack.net/releases/v6_09#vue-stable-diffusion","wordCount":137,"lineCount":21,"group":"v6.9","order":4},{"slug":"feature1","draft":false,"title":"New statically generated Razor Pages & Vue website","image":"https://servicestack.net/img/whatsnew/v6.8/servicestack.net-home-1440.png","tags":[],"date":"\/Date(1680048000000-0000)\/","content":"We're celebrating reaching **150M Total Downloads** with a brand new website, rewritten from Ruby's Jekyll and jQuery with an exciting \nnew Razor SSG project template enhanced with Vue 3 components for client interactivity features.\n\nThe new Razor Pages & Markdown powered template takes advantage of the advances made in the last few releases with our npm \ndependency-free approach to [Simple, Modern JavaScript](/posts/javascript), the built-in support for \n[Prerendering Razor Pages](/posts/prerendering) and the rich Tailwind \n[Vue Component Library](https://docs.servicestack.net/vue/) to create an enjoyable experience for creating Fast, FREE, \nbeautiful, CDN-hostable static generated websites & blogs.","url":"https://docs.servicestack.net/releases/v6_08","wordCount":115,"lineCount":13,"group":"v6.8"},{"slug":"feature2","draft":false,"title":"New Razor Pages & Markdown powered static website","image":"https://servicestack.net/img/whatsnew/v6.8/razor-ssg.png","tags":[],"date":"\/Date(1680048000000-0000)\/","content":"We're excited to announce our new [razor-ssg](https://razor-ssg.web-templates.io) project template - a Razor Pages powered Markdown \nalternative to Ruby's Jekyll & Next.js that's ideal for generating static websites & blogs using C#, Razor Pages & Markdown.\n\nIt's now available FREE to all .NET Developers wanting to creating Fast, Beautiful Static Websites & Blogs with Razor Pages. \nIt's FREE to create, FREE to host on GitHub Pages CDN and also designed to support running FREE from any local .NET Installs \nor IDEs where it can be maintained in [GitHub Codespaces](https://github.com/features/codespaces) that you can do entirely from an iPad.","url":"https://docs.servicestack.net/releases/v6_08#razor-ssg","wordCount":117,"lineCount":12,"group":"v6.8"},{"slug":"feature3","draft":false,"title":"Streamlined Development for creating Flutter Apps","image":"https://servicestack.net/img/whatsnew/v6.8/flutter-todos.jpg","tags":[],"date":"\/Date(1680048000000-0000)\/","content":"We've greatly improved the end-to-end development experience of creating Flutter Mobile Apps that integrate with your ServiceStack APIs. \nTo demonstrate the seamless development experience, we've created a [video walk through](https://www.youtube.com/watch?v=t4WcXo4Vnio) \ncreating a new Blazor Server project that we use **mix flutter** to create a new Flutter App that we can use to quickly build \na Mobile App to call its existing Todo .NET APIs using the built-in [Typed Dart DTOs](https://docs.servicestack.net/dart-add-servicestack-reference) integration.\n\nThis release also includes improvements to generated Dart DTOs and servicestack Dart client library with new simplified APIs\nthat greatly improves usage in Reactive UIs by encapsulates Successful and Failed API Responses in a single `ApiResult` \nvalue which can be passed down and bound to reactive components without any inhibitive `try/catch` statements.","url":"https://docs.servicestack.net/releases/v6_08#flutter","wordCount":141,"lineCount":13,"group":"v6.8"},{"slug":"feature4","draft":false,"title":"Improved workflow for creating Flutter gRPC Apps","image":"https://servicestack.net/img/whatsnew/v6.8/flutter-grpc.jpg","tags":[],"date":"\/Date(1680048000000-0000)\/","content":"We've also improved the development experience for developers who prefer or have existing investments in gRPC will be able to \nbenefit from the improved development experience with **mix flutter-grpc** which works like **mix flutter** but instead \nadds a new Flutter gRPC App to an existing ServiceStack grpc project, with pre-configured gRPC integrations. \n\nTo demonstrate this productive workflow we've [created a new video](https://www.youtube.com/watch?v=fgts6sQ2Ags) which walks \nthrough the process of creating a new Flutter App from scratch, adding a Flutter gRPC App to an existing grpc .NET project, \nand using **mix flutter-grpc** to configure the Flutter App to work with ServiceStack's gRPC Services.","url":"https://docs.servicestack.net/releases/v6_08#flutter-grpc","wordCount":118,"lineCount":12,"group":"v6.8"},{"slug":"feature1","draft":false,"title":"New Auto API HTML Page for all APIs!","image":"https://servicestack.net/img/whatsnew/v6.7/autohtml-preview.png","tags":[],"date":"\/Date(1678752000000-0000)\/","content":"The new Auto HTML Page is the best way to visualize, inspect and integrate with your APIs which provides instant utility for API consumers in consuming your APIs with a built-in API Response Visualizer, JSON syntax highlighting, integrated Postman-like UI and API SDK integration all-in-one.\n\nA nice benefit of ServiceStack's API Design is that consuming APIs are fundamentally all done the same way in all languages, which just requires adding a dependency containing a generic ServiceClient which can be used to call any ServiceStack API using the typed DTOs copied directly from the API docs page to enable an end-to-end typed API without any external tooling or build steps.","url":"https://docs.servicestack.net/releases/v6_07","wordCount":125,"lineCount":9,"group":"v6.7"},{"slug":"feature2","draft":false,"title":"Vue AutoQueryGrid Component for Auto CRUD UIs","image":"https://servicestack.net/img/whatsnew/v6.7/gallery-contacts.png","tags":[],"date":"\/Date(1678752000000-0000)\/","content":"The new AutoQueryGrid component is the last high-productivity component missing from the Vue Tailwind Component Library to reach feature parity with Blazor Tailwind Component Library.\n\nIt enables an Effortless CRUD UI without any external dependencies, tooling or build steps, generating a capability-based UI for the currently authenticated user, enabling full CRUD functionality through the App's auth-protected AutoQuery APIs, validated by the APIs Declarative Validation Rules utilizing optimal Form Inputs for each C# property type with contextual validation binding, that displays its results in a rich formatted data grid customized with APIs Declarative UI Attributes.","url":"https://docs.servicestack.net/releases/v6_07#autoquerygrid","wordCount":108,"lineCount":10,"group":"v6.7"},{"slug":"feature3","draft":false,"title":"New Vue 3 Locode, API Explorer & Admin UIs","image":"https://servicestack.net/img/whatsnew/v6.7/new-vue3-uis.png","tags":[],"date":"\/Date(1678752000000-0000)\/","content":"With access to all components needed, we've taken this opportunity to modernize all of ServiceStack's built-in UI's that were previously written with petite-vue and have rewritten them with Vue 3 and the Vue Components Library, which has become our preferred UI technology stack for all of ServiceStack's built-in UIs.\n\nUltimately the new Vue 3 UIs should appeal to a lot more use-cases with better reuse and customizability using the full Vue 3 framework and 3rd Party ecosystem for creating more compelling and interactive UIs.","url":"https://docs.servicestack.net/releases/v6_07#new-locode-api-explorer-admin-uis-now-in-vue-3","wordCount":100,"lineCount":9,"group":"v6.7"},{"slug":"feature4","draft":false,"title":"New API Index Page","image":"https://servicestack.net/img/whatsnew/v6.7/api-gallery.png","tags":[],"date":"\/Date(1678752000000-0000)\/","content":"The `/api` route is now being used as an opportunity to improve API Discovery by returning an App's public APIs grouped by user-defined tags with direct links to the API endpoint, viewing it in API Explorer and in Locode for AutoQuery APIs.","url":"https://docs.servicestack.net/releases/v6_07#api-index","wordCount":53,"lineCount":7,"group":"v6.7"},{"slug":"feature1","draft":false,"title":"New Tailwind Razor Pages & MVC Templates","image":"https://servicestack.net/img/whatsnew/v6.6/vue-mjs.png","tags":[],"date":"\/Date(1675814400000-0000)\/","content":"The new Tailwind Razor Pages & MVC Templates enable rapid development of Modern Tailwind Apps without the pitfalls plaguing SPA development:\n\n- **[vue-mjs](https://vue-mjs.web-templates.io)** - Flagship Vue.mjs template with OrmLite, AutoQuery, boosted htmx links & static pre-rendered blogs\n- **[razor-tailwind](https://razor-tailwind.web-templates.io)** - Simple Razor Pages Template without DB or pre-rendering\n- **[mvc-tailwind](https://mvc-tailwind.web-templates.io)** - Want to use MVC Identity Auth and Entity Framework\n- **[web-tailwind](https://web-tailwind.web-templates.io)** - Empty tailwind template with no web framework configured\n- **[vue-vite](https://vue-vite.jamstacks.net)** - Vite + TypeScript in a simpler JAMStack Vite SPA App\n- **[vue-ssg](https://vue-ssg.jamstacks.net)** - Vite + TypeScript in an advanced JAMStack Vite SSG App","url":"https://docs.servicestack.net/releases/v6_06","wordCount":135,"lineCount":14,"group":"v6.6"},{"slug":"feature2","draft":false,"title":"Vue 3 Tailwind Components","image":"https://servicestack.net/img/whatsnew/v6.6/vue-components.png","tags":[],"date":"\/Date(1675814400000-0000)\/","content":"To maximize productivity, all new Vue Tailwind templates are pre-configured to use the feature-rich [Vue 3 Taiwlind Library](https://docs.servicestack.net/vue/).\n\n**@servicestack/vue** is our growing Vue 3 Tailwind component library with a number of rich Tailwind components useful in .NET Web Apps, including DataGrids, Auto Forms, Modals, Slide Overs, Navigational Components, Formatters, standard HTML Form Input controls inc. FileInput, Autocomplete, TagInput - all with integrated contextual validation binding.\n\nIt's our cornerstone library for enabling a highly productive dev model across our Vue.js Tailwind Project templates that we'll be continuing to invest in to unlock even greater productivity - watch this space!","url":"https://docs.servicestack.net/vue/","wordCount":113,"lineCount":11,"group":"v6.6"},{"slug":"feature3","draft":false,"title":"ES6 JS Module Add ServiceStack Reference","image":"https://servicestack.net/img/whatsnew/v6.6/mjs-update-reference-rider.png","tags":[],"date":"\/Date(1675814400000-0000)\/","content":"The new ES6 classes provide a productive type-safe development model during development but can also be referenced as-is in JS Module scripts and run natively in browsers to enable instant typed API integrations without any build tools!\n\nTo achieve this the ES6 classes are annotated with JSDoc type hints in comments which enjoys broad support in IDEs and tools like TypeScript where it can be used to provide type information in JavaScript files.\n\nThey're now a first-class Add ServiceStack Reference language supported language complete with IDE integration in the latest ServiceStack Plugins for VS .NET and JetBrains IDEs.","url":"https://docs.servicestack.net/releases/v6_06#js-module-es6-class-dtos","wordCount":111,"lineCount":11,"group":"v6.6"},{"slug":"feature4","draft":false,"title":"Static prerendered Markdown Razor Pages","image":"https://servicestack.net/img/whatsnew/v6.6/razor-pages-prerendering.png","tags":[],"date":"\/Date(1675814400000-0000)\/","content":"Prerendering static content is a popular technique used by JAMStack Apps to improve the performance, reliability and scalability of Web Apps that's able to save unnecessary computation at runtime by generating static content at deployment which can be optionally hosted from a CDN for even greater performance.\n\nAs it's a valuable performance optimizing technique it's included in the [vue-mjs](https://vue-mjs.web-templates.io) template to show how it can be easily achieved within a Razor Pages App. Since prerendered content is only updated at deployment, it's primarily only useful for static content like markdown powered blogs.\n\nFor those interested in utilizing this optimization we've published details on how this works in the\n**[Prerendering Razor Pages](https://vue-mjs.web-templates.io/blog/prerendering)** blog post.","url":"https://vue-mjs.web-templates.io/posts/prerendering","wordCount":131,"lineCount":11,"group":"v6.6"},{"slug":"feature1","draft":false,"title":"Blazor Dark Mode Everywhere","image":"https://servicestack.net/img/whatsnew/v6.5/dark-and-light-mode.png","tags":[],"date":"\/Date(1670630400000-0000)\/","content":"Tailwind has revolutionized how we style our Web Apps with its mobile first design system that's dramatically simplified creating maintainable responsive Web Apps. It also excels at adding support for Dark Mode with its first-class dark: modifier allowing the use of standard tailwind classes to specify what elements should look like when viewed in Dark Mode.\n\nWe're happy to announce that Dark Mode support has been added to **all ServiceStack.Blazor Tailwind components** and all Blazor Tailwind project templates where you'll be able to toggle on/off Dark Mode with the new **DarkModeToggle** component.","url":"https://docs.servicestack.net/releases/v6_05","wordCount":104,"lineCount":9,"group":"v6.5"},{"slug":"feature2","draft":false,"title":"New Blazor Components","image":"https://servicestack.net/img/whatsnew/v6.5/blazordiffusion-Autocomplete.png","tags":[],"date":"\/Date(1670630400000-0000)\/","content":"The ServiceStack.Blazor component library continues to expand with exciting new Components and improvements, including:\n\n- **Autocomplete** - Rich content Input to quickly search & select items\n- **TagInput** - UX friendly input for managing a list of strings like words or tags\n- **FormStyle.Card** - Render Auto Forms from POCO classes in a Card Layout\n- **NavList** - Beautiful Nav Links list component with Icons + Descriptions\n- **Colored Buttons** - Render buttons in different primary Tailwind colors\n- **SelectInput Expressions** - Declaratively define Select Input Options\n- **Custom Edit & Create Forms** - Use forms in custom AutoQueryGrids","url":"https://docs.servicestack.net/releases/v6_05#blazor-components","wordCount":103,"lineCount":15,"group":"v6.5"},{"slug":"feature3","draft":false,"title":"Blazor Diffusion","image":"https://servicestack.net/img/whatsnew/v6.5/blazordiffusion.com_splash.png","tags":[],"date":"\/Date(1670630400000-0000)\/","content":"The goal of our increasing Blazor investments is to enable a highly productive and capable platform for rapidly developing a majority of internal Apps CRUD functionality as well as enabling a hybrid development model where the management of Back office supporting tables can be quickly implemented using custom AutoQueryGrid components freeing up developers to be able to focus a majority of their efforts where they add the most value - in the bespoke Blazor UI's optimized customer-facing UX.\n\nTo best demonstrate its potential we've created [blazordiffusion.com](https://blazordiffusion.com) - a new ServiceStack.Blazor App front-end for Stable Diffusion - a deep learning text-to-image model that can generate quality images from a text prompt. It's a great example of Hybrid Development in action where the entire user-facing UI is a bespoke Blazor App that's optimized for creating, searching, cataloging and discovering Stable Diffusion generated images, whilst all its supporting admin tasks to manage the back office tables that power the UI were effortlessly implemented with custom AutoQueryGrid components.","url":"https://docs.servicestack.net/releases/v6_05#blazor-diffusion","wordCount":178,"lineCount":9,"group":"v6.5"},{"slug":"feature4","draft":false,"title":"Universal Blazor API Components","image":"https://servicestack.net/img/whatsnew/v6.5/blazor-universal-components.png","tags":[],"date":"\/Date(1670630400000-0000)\/","content":"The recommendation to access DB's directly in Blazor Server components encourages a more tightly-coupled and less reusable & testable architecture than the traditional well-defined API dev model used in client/server Mobile & Desktop Apps or Web SPA Apps like Blazor WASM.\n\nTo achieve the best of both worlds, we've enabled support for utilizing the In Process Service Gateway in Blazor Server Apps which lets you retain the traditional client/server dev model for invoking your Server APIs In Process - avoiding any serialization, HTTP networking or even Kestrel middleware overhead to invoke your APIs directly!\n\nThis enables using the exact same source code to call APIs in Blazor Server and WASM which allows us to develop reusable Blazor Components to invoke the same Server APIs that serve Web, Mobile and Desktop Apps in Blazor Server Apps.","url":"https://youtu.be/66DgLHExC9E","wordCount":145,"lineCount":11,"group":"v6.5"},{"slug":"feature1","draft":false,"title":"RAD Blazor","image":"https://servicestack.net/img/whatsnew/v6.4/blazor-components-youtube.jpg","tags":[],"date":"\/Date(1665446400000-0000)\/","content":"We're excited to announce exciting new Blazor Components enabling a compelling a Rapid Application Development platform for Blazor Apps delivering many of the productivity benefits previously limited to [locode.dev](https://www.locode.dev).\n\nOur new native Blazor Components allows for a beautiful progression story where you can start with a [Database-First Locode](/locode/database-first) solution to instantly [generate Data Models and CRUD APIs](/locode/database-first#exporting-to-code-first-types) around your existing databases that thanks to the new `AutoQueryGrid` Blazor component will be able to trivially implement both CRUD UI's and optimized Blazor UIs in the same Blazor App.","url":"https://docs.servicestack.net/releases/v6_04","wordCount":102,"lineCount":9,"group":"v6.4"},{"slug":"feature2","draft":false,"title":"Blazor Server Template","image":"https://servicestack.net/img/whatsnew/v6.4/blazor-server.png","tags":[],"date":"\/Date(1665446400000-0000)\/","content":"We're happy to announce our new Blazor Server App template offering a number compelling advantages over Blazor WASM, including:\n\n- A superior dev model and debugging experience\n- Improved live-reload and faster iterative dev cycles\n- Full access to .NET Server functionality\n- Better start times & UI responsiveness\n- Less complexity from unnecessary client project or pre-rendering solutions","url":"https://docs.servicestack.net/releases/v6_04#blazor-server","wordCount":63,"lineCount":13,"group":"v6.4"},{"slug":"feature3","draft":false,"title":"Blazor Component Gallery","image":"https://servicestack.net/img/whatsnew/v6.4/gallery-splash.png","tags":[],"date":"\/Date(1665446400000-0000)\/","content":"ServiceStack.Blazor Components gives you the ideal development workflow without compromise. Effortless, highly productive, API integrated Rich Blazor UI Components with 100% Server model reuse and integrated contextual validation.\n\nTo better showcase our growing Blazor functionality we've created new Blazor Gallery websites showcasing usage of available rich Blazor Components for rapidly develop beautiful Tailwind Web Apps available in both [Blazor Server](https://blazor-gallery.servicestack.net) and [Blazor WASM](https://blazor-gallery.jamstacks.net) Web Apps.","url":"https://docs.servicestack.net/releases/v6_04#blazor-gallery","wordCount":82,"lineCount":9,"group":"v6.4"},{"slug":"feature4","draft":false,"title":"Debug DB Migrations from IDE","image":"https://servicestack.net/img/whatsnew/v6.4/database-migrations-youtube.jpg","tags":[],"date":"\/Date(1665446400000-0000)\/","content":"We've continued improving our story around [Code-First DB Migrations](/ormlite/db-migrations) and have created a [new video](https://www.youtube.com/embed/NIVFqute7JQ) demonstrating how it can be used to maintain DB Schema migrations under a typical development workflow.\n\nAs they encourage a structured workflow for incremental development of new App features we've upgraded all modern [jamstacks.net](https://jamstacks.net)\ntemplates to adopt DB Migrations for creating and populating their App DB.\n\nA benefit of DB Migrations being implemented in a library instead of wrapped up behind an external tool, is that it's better integrated and more versatile in supporting more executable options like being able to run from code, a feature the new `MigrationTasks` Explicit TestFixture benefits from enabling DB Migrations to be run or debugged directly from within your IDE.","url":"https://docs.servicestack.net/releases/v6_04#db-migrations","wordCount":140,"lineCount":12,"group":"v6.4"},{"slug":"feature1","draft":false,"title":"Simple Code-First DB Migrations","image":"https://servicestack.net/img/whatsnew/v6.3/db-migrations.png","tags":[],"date":"\/Date(1661817600000-0000)\/","content":"We're excited to share the next release of ServiceStack which sees the introduction of our simple Database Migration solution with Code-First DB Migrations which advances OrmLite's light-weight code-first development approach with a simple change based migration solution that facilitates the code-first development workflow of OrmLite.\n\nStarting from a seamless quick install and supporting multiple running options from command-line tooling, IDE run npm scripts, run, debug & verify from unit tests and integrated with our GitHub Action deployments where only successful migrations are deployed.\n\nInstead of relying on generation by an opaque tool, this code-first approach treats DB Migrations like any other maintainable & logically structured code written by developers where it maintains a connected audit history in source control together with the feature that needs the schema changes.","url":"https://docs.servicestack.net/releases/v6_03#code-first-db-migrations","wordCount":139,"lineCount":11,"group":"v6.3"},{"slug":"feature2","draft":false,"title":"Manage App Redis Servers with Redis Admin","image":"https://servicestack.net/img/whatsnew/v6.3/admin-ui-redis.png","tags":[],"date":"\/Date(1661817600000-0000)\/","content":"The Redis Admin UI lets you manage your App's configured Redis Server with a user-friendly UX for managing core Redis data types, simple search functionality to quickly find Redis values, quick navigation between related values, first class support for JSON values and a flexible command interface and command history to inspect all previously run redis commands that's easily editable & rerun.","url":"https://docs.servicestack.net/releases/v6_03#redis-admin-ui","wordCount":75,"lineCount":7,"group":"v6.3"},{"slug":"feature3","draft":false,"title":"Browse App RDBMS Tables with Database Admin","image":"https://servicestack.net/img/whatsnew/v6.3/admin-ui-database.png","tags":[],"date":"\/Date(1661817600000-0000)\/","content":"The new built-in Database Admin UI lets you quickly browse your App's configured RDBMS schemas and tables, which without any additional configuration your App's configured databases, their schemas, tables and any registered [named connections](https://docs.servicestack.net/ormlite/getting-started#multiple-database-connections) will be navigable from the home page where they'll be browsable with a familiar tabular search results grid, similar in appearance and functionality to [Locode's Auto UI](https://locode.dev) where their resultsets can each be personalized with flexible query preferences and filtering options that's persisted across browser restarts.","url":"https://docs.servicestack.net/releases/v6_03#database-admin-ui","wordCount":99,"lineCount":7,"group":"v6.3"},{"slug":"feature1","draft":false,"title":"Beautiful Blazor Tailwind Template","image":"https://servicestack.net/img/whatsnew/v6.2/blazor-tailwind.png","tags":[],"date":"\/Date(1658707200000-0000)\/","content":"The feature-rich [Blazor WASM Tailwind](https://docs.servicestack.net/templates-blazor-tailwind) template us ideal for teams with strong C# skills building Line Of Business (LOB) applications who prefer utilizing Tailwind's modern utility-first CSS design system to create beautiful, instant-loading Blazor WASM Apps.\n\nAll Blazor WASM templates [incorporate prerendering](https://blazor-tailwind.jamstacks.net/docs/prerender) to achieve their [instant load times](https://blazor-tailwind.jamstacks.net) that greatly benefits the built-in markdown pages with great SEO","url":"https://docs.servicestack.net/releases/v6_02","wordCount":77,"lineCount":9,"group":"v6.2"},{"slug":"feature2","draft":false,"title":"Create Litestream Apps and Save 10x on Hosting","image":"https://servicestack.net/img/whatsnew/v6.2/litestream-costs.svg","tags":[],"date":"\/Date(1658707200000-0000)\/","content":"Having achieved the best architecture for delivering [max value](https://jamstacks.net/posts/hosting) and performance with our [jamstacks.net](https://jamstacks.net) templates, the last expensive vital component used in most Web Apps is hosting of their expensive managed databases. Despite most RDBMS's being OSS and free of licensing costs, major cloud companies continue to charge artificially high hosting costs to provide redundant hosting of App data.\n\n[Litestream](https://litestream.io) lets us avoid these expensive hosting costs by providing transparent per-second replica backups to inexpensive managed storage, enabling latency-free queries, simplified hosting architectures at vastly reduced hosting costs.","url":"https://docs.servicestack.net/releases/v6_02.html#litestream","wordCount":112,"lineCount":9,"group":"v6.2"},{"slug":"feature3","draft":false,"title":"Gain real-time insights with built-in Profiling","image":"https://servicestack.net/img/whatsnew/v6.2/profiling.png","tags":[],"date":"\/Date(1658707200000-0000)\/","content":"The new Request Logging & Profiling UIs bring an invaluable new level of observability into your App, from being able to quickly inspect and browse incoming requests, to tracing their behavior from their generated events in the new [Diagnostic Source](https://docs.microsoft.com/en-us/dotnet/api/system.diagnostics.diagnosticsource?view=net-6.0) capabilities added all throughout ServiceStack, which both power the new UIs and enables new introspectability from code where you can now to tap in to inspect & debug when each diagnostic event occurs.","url":"https://docs.servicestack.net/releases/v6_02.html#request-logging-profiling","wordCount":94,"lineCount":7,"group":"v6.2"},{"slug":"feature4","draft":false,"title":"Manage DB Validation Rules with Validation UI","image":"https://servicestack.net/img/whatsnew/v6.2/validation-video.png","tags":[],"date":"\/Date(1658707200000-0000)\/","content":"The DB Validation feature leverages the existing [Declarative Validation](https://docs.servicestack.net/declarative-validation) infrastructure where it enables dynamically managing Request DTO Type and Property Validators from a RDBMS data source which immediately takes effect at runtime that carries the same performance profile at runtime as they can be optionally cached where they'll only need to be re-hydrated from the database after modification.","url":"https://docs.servicestack.net/releases/v6_02.html#db-validation","wordCount":76,"lineCount":7,"group":"v6.2"},{"slug":"feature1","draft":false,"title":"Rapid Application Development with Locode","image":"https://servicestack.net/img/whatsnew/v6.1/locode-splash.png","tags":[],"date":"\/Date(1652659200000-0000)\/","content":"We're excited to announce [locode.dev](https://locode.dev), our **Rapid Application Development** solution to quickly develop\nbeautiful Full Stack CRUD Apps around **AutoQuery APIs**, suitable for a wide number of use-cases including:\n\n- Rapid prototyping by creating an instant UI around existing **Database-First** RDBMS tables\n- Declarative **Code-First** development model with unprecedented customizability (exportable from Database-First)\n- **Hybrid Apps** with a custom UI to optimize common workflows whilst using Locode's Auto UI to manage Back office tables\n\nAs Locode's UI is built on top of ServiceStack's industrial strength AutoQuery APIs, Hybrid Apps can benefit from its superior end-to-end typed development model for creating Web, Mobile & Desktop Apps.","url":"https://docs.servicestack.net/releases/v6_01","wordCount":117,"lineCount":14,"group":"v6.1"},{"slug":"feature2","draft":false,"title":"Database-First Development Model","image":"https://servicestack.net/img/whatsnew/v6.1/youtube-locode-intro.png","tags":[],"date":"\/Date(1652659200000-0000)\/","content":"Using [AutoQuery's AutoGen](https://docs.servicestack.net/autoquery-autogen) enables the quickest way to modernize an existing database by dynamically creating Data Models & AutoQuery CRUD APIs from RDBMS table schemas at runtime.\n\nLocode provides a highly functional UI out-of-the-box that doesn't rely on code-gen that allows you to only override the Custom UI or Custom API implementation when needed resulting in a significantly smaller code-base to maintain as reflected in the comparitive code-bases of a customized\nNorthwind Locode App vs the Northwind code-base of a popular RAD code-gen tool for .NET\n\n\n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n \n
Locode NorthwindRadzen Northwind
~120 lines of C#~4500 lines of C# (generated)
29 lines custom Home Page10k+ lines of Angular HTML/TS (generated)
","url":"https://docs.servicestack.net/releases/v6_01#database-first","wordCount":134,"lineCount":29,"group":"v6.1"},{"slug":"feature3","draft":false,"title":"Code-First Development Model","image":"https://servicestack.net/img/whatsnew/v6.1/chinook-splash.png","tags":[],"date":"\/Date(1652659200000-0000)\/","content":"[Code-First](https://docs.servicestack.net/locode/code-first) is the natural development model of [AutoQuery Services](https://docs.servicestack.net/autoquery-rdbms) which facilitates the majority of a\nSystem and its UI can be developed from simple, declarative C# POCOs to define the underlying RDBMS Schema Data Models and the precise typed\nAPI DTO Contracts of their surrounding AutoQuery & CRUD APIs. The Data and Service models can be further enhanced by ServiceStack's vast\n[declarative attributes](https://docs.servicestack.net/locode/declarative) where a significant amount of behavior, functionality and customization can be defined, ranging from:\n\n- Customize how [Data Models map to DB Tables](https://docs.servicestack.net/locode/declarative.html#table-data-model-attributes) & enlist RDBMS features\n- [Customize Serialization & API behavior](https://docs.servicestack.net/locode/declarative.html#custom-serialization)\n- [Define AutoQuery & CRUD API behavior](https://docs.servicestack.net/locode/declarative.html#autoquery-attributes)\n- Define [Validation Rules](https://docs.servicestack.net/locode/declarative.html#type-validation-attributes) and [Authorization restrictions](https://docs.servicestack.net/locode/declarative.html#authentication-restrictions)\n- [Annotate & Document APIs](https://docs.servicestack.net/locode/declarative.html#annotate-apis)\n- [Customize UI Behavior & Appearance](https://docs.servicestack.net/locode/declarative.html#result-formatters)","url":"https://docs.servicestack.net/releases/v6_01#code-first","wordCount":165,"lineCount":17,"group":"v6.1"},{"slug":"feature4","draft":false,"title":"Hybrid Locode Apps with Blazor WASM","image":"https://servicestack.net/img/whatsnew/v6.1/talent-splash.png","tags":[],"date":"\/Date(1652659200000-0000)\/","content":"Locode's declarative dev model lets you focus on your new App's business requirements where its data model, API capabilities, input validation & multi-user Auth restrictions can be defined simply using annotated C# POCOs.\nThis provides immense value at the start of the development cycle where functional prototypes can be quickly iterated to gather business requirements\n\nOnce requirements have solidified, its typed AutoQuery APIs can easily be reused to develop custom UIs to optimize important workflows.\n\n[Talent Blazor](https://github.com/NetCoreApps/TalentBlazor) is a new App showcasing an example of this where its entire back-office functionality can be managed through Locode whilst an optimized **Blazor WASM App** is created to optimize its unique workflow requirements which also benefits from the superior productive dev model of its Typed APIs.","url":"https://docs.servicestack.net/releases/v6_01#hybrid-locode-apps","wordCount":138,"lineCount":12,"group":"v6.1"},{"slug":"feature1","draft":false,"title":"FREE Individual & OSS Licenses","image":"https://servicestack.net/img/whatsnew/v6/servicestack-100m-976w.png","tags":[],"date":"\/Date(1642723200000-0000)\/","content":"We're starting off 2022 eclipsing an impressive milestone having crossed\n[100M+ NuGet downloads](https://www.nuget.org/profiles/servicestack) which we're celebrating by making ServiceStack FREE for Individuals & collaborative OSS Projects.\n\nWe've also created 2 new community spaces for ServiceStack developers to engage with each other:\n\n- [ServiceStack/Discuss](https://github.com/ServiceStack/Discuss/discussions/)\n- [#ServiceStack channel on Discord](https://discord.gg/w4ayGbuYpA)\n\nThese new spaces are welcome to all users of the framework that we hope together with the new free licenses will encourage developers build and share their amazing creations with each other! 🎉","url":"https://docs.servicestack.net/releases/v6","wordCount":97,"lineCount":15,"group":"v6.0"},{"slug":"feature2","draft":false,"title":"API Explorer","image":"https://servicestack.net/img/whatsnew/v6/api-details-CreateBooking.png","tags":[],"date":"\/Date(1642723200000-0000)\/","content":"Now built into every ServiceStack v6 App is API Explorer - an instant integrated Postman and Swagger UI alternative to quickly Call and Explore your APIs.\n\nThe entire API Explorer UI is driven by the rich metadata around your APIs and AppHost's registered plugins capturing greater knowledge about your APIs and is able to provide a smarter, richer and more optimized UX than what would be possible going through lowest common denominator specs like Open API.\n\nWith envious performance and unmatched customizability, API Explorer lets you easily incorporate gorgeous, rich, interactive API Documentation API Consumers will love who'll be able to read its source code in their preferred programming language and easily call from their existing Client Apps.","url":"https://docs.servicestack.net/releases/v6#api-explorer","wordCount":126,"lineCount":11,"group":"v6.0"},{"slug":"feature3","draft":false,"title":"Blazor WebAssembly Jamstack Template","image":"https://servicestack.net/img/whatsnew/v6/blazor-wasm.png","tags":[],"date":"\/Date(1642723200000-0000)\/","content":"Our new Blazor WebAssembly (WASM) template is ideal for teams with strong C# skills building Line Of Business (LOB) applications. Utilizing an API First development model, the C# Blazor front-end is able to take advantage of the clean separation of ServiceStack APIs to enjoy instant frictionless 100% reuse of API Types as-is, without any reliance on any tooling or unproductive out-of-sync code-gen build steps interrupting developers workflow.\n\nTogether with new .NET Service Clients Apis it results in the ideal productive dev model to bind Blazor UIs to ServiceStack APIs.\n\nTemplates make use of **ServiceStack.Blazor** a new package of integrated functionality with ServiceStack, inc. JSON API HttpClient Factory, API-enabled base components & themable Bootstrap + Tailwind UI controls.\n\nIn addition to TODO MVC and CRUD UI examples demonstrating its productive dev model, it also includes pre-rendering solutions for instant load times & GitHub Actions for effortless optimal Jamstack CDN deployments.","url":"https://docs.servicestack.net/templates-blazor","wordCount":160,"lineCount":13,"group":"v6.0"},{"slug":"feature4","draft":false,"title":"C# Jamstack Templates","image":"https://servicestack.net/img/whatsnew/v6/jamstacks-net.png","tags":[],"date":"\/Date(1642723200000-0000)\/","content":"ServiceStack's new [jamstacks.net](https://jamstacks.net) templates encapsulates the latest technologies at the forefront of modern web development to deliver both a great developer experience and performant end-user UX.\n\nJamstack (JavaScript, APIs, and Markup) is a modern architecture pattern to build fast, secure and easy to scale web applications where pre-rendering content, enhancing with JavaScript and leveraging CDN static hosting results in a highly productive, flexible and performant system that takes advantage of CDN edge caches to deliver greater performance & efficiency at lower cost.\n\nIt's quickly becoming the preferred architecture for modern web apps with benefits extending beyond performance to improved Security, Scale, Maintainability, Portability, Developer Experience & lower costs with your App's pre-rendered static UI assets on Content Delivery Network (CDN) edge caches close to users locations.\n\nThese new templates represent the best-in class experiences for their respective React, Vue & Blazor WASM ecosystems each, packed with features & examples common in many websites including Integrated Auth, rich Markdown content as well as TODOs MVC and CRUD examples with built-in contextual validation binding. As such they're now recommended over our existing SPA and C# MVC Templates.","url":"https://docs.servicestack.net/releases/v6#jamstack","wordCount":197,"lineCount":13,"group":"v6.0"},{"slug":"feature1","draft":false,"title":".NET 6 is here!","image":"https://servicestack.net/img/whatsnew/net6-released.png","tags":[],"date":"\/Date(1637366400000-0000)\/","content":"We've cut this release cadence short to focus on putting out a quality release to take advantage of the newest and best .NET runtime yet!\n\nIn a lot of ways .NET 6 marks the start of a new era for .NET with the first LTS release after the end of the\n.NET Framework and .NET Standard with only 1 actively developed runtime going forward.\n\nWe're moving full-steam ahead and have standardized our new features onto .NET 6 with:\n\n- [All project templates upgraded to .NET 6](https://docs.servicestack.net/releases/v5_13#all-project-templates-upgraded-to-net-6)\n- [net6.0 TFM builds added to all packages](https://docs.servicestack.net/releases/v5_13#net6-0-tfm-builds-added-to-all-packages)\n- [Embracing .NET 6 new Hosting Model for mix](https://docs.servicestack.net/releases/v5_13#net-6-new-hosting-model)\n- [v4.5 .NET Framework Deprecation Notice](https://docs.servicestack.net/releases/v5_13#v4-5-net-framework-deprecation-notice)","url":"https://docs.servicestack.net/releases/v5_13","wordCount":133,"lineCount":17,"group":"v5.13"},{"slug":"feature2","draft":false,"title":"ServiceStackVS 2022 support","image":"https://servicestack.net/img/whatsnew/vs2022-splash.png","tags":[],"date":"\/Date(1637366400000-0000)\/","content":"Visual Studio 2022 now has support for Add ServiceStack reference for C#/F#/VBNET/TypeScript!\n\nServiceStackVS can be found in the Extension Marketplace, and is installable straight from Visual Studio 2022.","url":"https://docs.servicestack.net/releases/v5_13#servicestackvs-now-supports-visual-studio-2022","wordCount":37,"lineCount":9,"group":"v5.13"},{"slug":"feature3","draft":false,"title":".NET 6 Hosting Model migration guide","image":"https://i.ytimg.com/vi/WgsFl0AFUdo/maxresdefault.jpg","tags":[],"date":"\/Date(1637366400000-0000)\/","content":"We're now embracing .NET 6's idiom and have rewritten all our mix gist config files to adopt its HostingStartup which is better able to load modular Startup configuration without assembly scanning.\n\nThis video guide shows how you can migrate your existing startup modules to use .NET 6 Hosting Model.","url":"https://youtu.be/WgsFl0AFUdo","wordCount":62,"lineCount":9,"group":"v5.13"},{"slug":"feature1","draft":false,"title":"Python ServiceStack Reference","image":"https://servicestack.net/img/whatsnew/v5.12/python-reference.png","tags":[],"date":"\/Date(1629158400000-0000)\/","content":"[Python](https://python.org) is one of the worlds most popular programming languages which\nexcels in a number of industries thanks to its ease of use and comprehensive libraries.\n\nTo maximize the experience for calling ServiceStack APIs within these environments\nServiceStack now supports Python as a 1st class Add ServiceStack Reference supported language\nwhich gives Python developers an end-to-end typed API for consuming ServiceStack APIs,\ncomplete with IDE integration in [PyCharm](https://www.jetbrains.com/pycharm/) as well as\n[built-in support in x dotnet tool](https://docs.servicestack.net//dotnet-tool#addupdate-servicestack-references)\nto generate Python DTOs for a remote ServiceStack instance from a single command.","url":"https://docs.servicestack.net/releases/v5.12#python-servicestack-reference","wordCount":106,"lineCount":15,"group":"v5.12"},{"slug":"feature2","draft":false,"title":"Jupyter Notebooks","image":"https://servicestack.net/img/whatsnew/v5.12/jupyter-splash.png","tags":[],"date":"\/Date(1629158400000-0000)\/","content":"Python has solidified itself as a powerhouse in Data Science and Machine Learning thanks to its\nbest-in-class libraries as well as being at the forefront of Interactive Computing with its native\nsupport in [Jupyter Notebooks](https://jupyter.org/) - a popular realization of Donald Knuth’s\n[Literate Programming](https://en.wikipedia.org/wiki/Literate_programming)\nparadigm where executable code is interlaced in a live document with natural language\ndocumentation, rich markup and embedded media. It’s become an invaluable medium for data\nscience, scientists and researchers where it’s often used as an advanced REPL environment\nfor data and computation exploration whose resulting knowledge and insights are easily\ncaptured and shared.\n\nWe’re excited to be able to join the beautiful interactive world of Jupyter Notebooks with\nboth Simple UI and command-line tools for effortlessly generating customized Notebooks around\ntyped ServiceStack APIs for Jupyter’s premier support for **Python**.","url":"https://docs.servicestack.net/releases/v5.12#interactive-jupyter-notebooks","wordCount":141,"lineCount":19,"group":"v5.12"},{"slug":"feature3","draft":false,"title":"C# and F# Jupyter Notebooks","image":"https://servicestack.net/img/whatsnew/v5.12/jupyter-lab-visual-example.png","tags":[],"date":"\/Date(1629158400000-0000)\/","content":"In addition to Python we've also extended support for generating customized pre-populated\n**C#** and **F#** Jupyter Notebooks by leveraging dotnet/interactive Jupyter kernel’s which\nallows C# and F# .NET Developers to join Jupyter's interactive live programming paradigm\nwhich they can either choose to run locally in the next gen JupyterLab UI or directly within\nVS Code using .NET Interactive's VS Code extension.\n\nNotebooks have also become a popular medium for sharing institutional data and computational\nknowledge thanks to being able to capture and embed execution output and support for exporting\nin multiple popular document formats as used by GitHub with their Auto Preview support for\nNotebooks. We also simplify configuring a Notebook GitHub repo to support executing C# and\nF# Notebooks in [mybinder.org](https://mybinder.org) FREE cloud hosting services with our\n`docker-jupyter` mix template.","url":"https://docs.servicestack.net/releases/v5.12#generate-c-jupyter-notebooks","wordCount":138,"lineCount":18,"group":"v5.12"},{"slug":"feature1","draft":false,"title":"Instant Client Apps","image":"https://servicestack.net/img/whatsnew/v5.11/client-apps.png","tags":[],"date":"\/Date(1618963200000-0000)\/","content":"Building upon our native end-to-end typed solutions, we're excited to announce **Instant Client Apps** to\nprovide instant utility and value around your ServiceStack Services where your API consumers can use the\nAuto generated UI to craft API Requests in their preferred programming language:","url":"https://docs.servicestack.net/releases/v5.11#instant-client-apps","wordCount":51,"lineCount":9,"group":"v5.11"},{"slug":"feature2","draft":false,"title":"GitHub Actions Templates","image":"https://servicestack.net/img/whatsnew/v5.11/github-actions-header.png","tags":[],"date":"\/Date(1618963200000-0000)\/","content":"We've begun to fully embrace GitHub Actions from this release to help quickly setting up CI environments for\nnew and existing ServiceStack project templates by automating them into building and running tests on each **commit**\nbefore publishing, dockerizing & deploying them on each **GitHub Release**.\nThe templates leverage [mix](https://docs.servicestack.net/mix-tool) to work like lego pieces where they can be combined to achieve your\npreferred automation workflow.","url":"https://docs.servicestack.net/releases/v5.11#githubaction-templates","wordCount":76,"lineCount":11,"group":"v5.11"},{"slug":"feature3","draft":false,"title":"All Service Client Libraries Upgraded","image":"https://servicestack.net/img/whatsnew/v5.11/service-clients.png","tags":[],"date":"\/Date(1618963200000-0000)\/","content":"In addition to the Refresh Token support & built-in Inspect utils all ServiceStack’s generic Service Client libraries in all languages have received a number of updates to improve their consistency and overall development UX.","url":"https://docs.servicestack.net/releases/v5.11#all-service-client-libraries-upgraded","wordCount":47,"lineCount":7,"group":"v5.11"},{"slug":"feature1","draft":false,"title":"Booking System in minutes","image":"https://raw.githubusercontent.com/ServiceStack/docs/master/docs/images/studio/bookings-splash.png","tags":[],"date":"\/Date(1605052800000-0000)\/","content":"To see the rapid development of AutoQuery in action we've created a quick demo showing how to create a simple multi-user Booking System from an empty [web](https://github.com/NetCoreTemplates/web) project, [mixed in](https://docs.servicestack.net/mix-tool) with the preferred RDBMS & Auth layered functionality, before enabling [Validation](https://docs.servicestack.net/validation), [AutoQuery](https://docs.servicestack.net/autoquery-rdbms), Admin Users & [CRUD Event Log](https://docs.servicestack.net/autoquery-audit-log) plugins - to lay the foundational features before building our App by first defining its `Booking` data model & its surrounding **Query**, **Create**, **Update** and **Soft Delete** Typed CRUD APIs with rich validation enforced by declarative Validation attributes and multi-layer authorization rules & access permissions protected using Authorization attributes.","url":"https://docs.servicestack.net/releases/v5.10#creating-a-multi-user-net-core-booking-system-in-minutes","wordCount":126,"lineCount":7,"group":"v5.10"},{"slug":"feature2","draft":false,"title":"Studio User Admin","image":"https://raw.githubusercontent.com/ServiceStack/docs/master/docs/images/studio/studio-home.png","tags":[],"date":"\/Date(1605052800000-0000)\/","content":"We've caught a glimpse of the new User Admin Feature in the [Bookings CRUD demo](https://youtu.be/XpHAaCTV7jE) who utilizes it to create **Employee** and **Manager** users. The `AdminUsersFeature` provides Admin User Management APIs enabling remote programmatic access to your registered [User Auth Repository](https://docs.servicestack.net/authentication-and-authorization#user-auth-repository), featuring:\n\n- Works with existing `IUserAuthRepository` sync or async providers\n- Utilizes Progressive enhancement, e.g. search functionality utilizes `IQueryUserAuth` (if exists) performing a wildcard search over multiple fields, otherwise falls back to exact match on `UserName` or `Email`\n- Supports managing Auth Repositories utilizing custom `UserAuth` data models\n- Flexible UI options for customizing which fields to include in Search Results and Create/Edit UIs\n- Rich Metadata aggregating only App-specific Roles & Permissions defined in your App\n- User Events allow you to execute custom logic before & after each Created/Updated/Deleted User","url":"https://docs.servicestack.net/releases/v5.10#studio-user-management-ui","wordCount":145,"lineCount":14,"group":"v5.10"},{"slug":"feature3","draft":false,"title":"Sign In with Apple","image":"https://raw.githubusercontent.com/ServiceStack/docs/master/docs/images/dev/web-signin-with-apple-login.png","tags":[],"date":"\/Date(1605052800000-0000)\/","content":"As mobile Apps is a target use-case for ServiceStack, this release also includes 1st class integration with **Sign In with Apple** OAuth provider. To assist with adoption we've also developed Sign In with Apple Integration Examples for iOS, Android & Web with working implementations for Flutter iOS/Android & SwiftUI Apps.","url":"https://docs.servicestack.net/releases/v5.10#sign-in-with-apple","wordCount":63,"lineCount":7,"group":"v5.10"},{"slug":"feature1","draft":false,"title":"Introducing ServiceStack Studio","image":"https://raw.githubusercontent.com/ServiceStack/docs/master/docs/images/release-notes/v5.9/studio-home.png","tags":[],"date":"\/Date(1594252800000-0000)\/","content":"Another exciting development in this release is the successor to [Admin UI](https://github.com/ServiceStack/Admin):\n**ServiceStack Studio!** - a capability-based UI to manage multiple remote ServiceStack instances from either a Chromium Desktop App\nor cross-platform .NET Core Web App.\n\nThe richer metadata in ServiceStack Services allows Studio to logically group Services around Data Models, enabling its high-level\nsemantic features like its native data-grid like UX over all AutoQuery Services to quickly discover, search, create, update and\ndelete entities based on the available AutoQuery APIs and whether Authenticated Users have access to them.","url":"https://docs.servicestack.net/releases/v5.9#introducing-servicestack-studio","wordCount":102,"lineCount":13,"group":"v5.9"},{"slug":"feature2","draft":false,"title":"Instantly Servicify existing Systems!","image":"https://raw.githubusercontent.com/ServiceStack/docs/master/docs/images/svg/servicify.svg","tags":[],"date":"\/Date(1594252800000-0000)\/","content":"ServiceStack also reached maximum autonomy for a Services framework where in addition to **AutoQuery** automatically providing your Services implementations,\n**Studio** providing its instant UI, ServiceStack also gained the capability to **generate your entire API!** Including Typed API contracts,\ndata models, implementations & human-friendly pluralized HTTP API routes over an existing System RDBMS's tables!\n\nServiceStack's **AutoGen** enables a number of exciting possibilities, predominantly it's the fastest way to ServiceStack-ify an\nexisting systems RDBMS where it will serve as an invaluable tool for anyone wanting to quickly migrate to ServiceStack and access its\nfunctionality ecosystem around ServiceStack Services:","url":"https://docs.servicestack.net/releases/v5.9#instantly-servicify-existing-systems","wordCount":106,"lineCount":13,"group":"v5.9"},{"slug":"feature3","draft":false,"title":"Generate Types for RDBMS Tables","image":"https://raw.githubusercontent.com/ServiceStack/docs/master/docs/images/release-notes/v5.9/autodto-youtube.png","tags":[],"date":"\/Date(1594252800000-0000)\/","content":"generate-types-for-rdbms-tables\nimage: https://raw.githubusercontent.com/ServiceStack/docs/master/docs/images/release-notes/v5.9/autodto-youtube.png\n---\n\nAn unintended consequence of **AutoGen** that's potentially universally appealing to even non .NET developers is that it's also a way to instantly\ngenerate Types for all RDBMS tables in all of ServiceStack [supported client languages](https://docs.servicestack.net/add-servicestack-reference),\nwhich thanks to being configurable in a [Sharp App](https://sharpscript.net/docs/sharp-apps) can be executed from the command-line using\nthe [dotnet tools](https://docs.servicestack.net/dotnet-tool)","url":"https://docs.servicestack.net/releases/v5.9#autodtogenerate-types-for-rdbms-tables","wordCount":75,"lineCount":10,"group":"v5.9"},{"slug":"feature1","draft":false,"title":"Simple Code-First DB MigrationsServiceStack gRPC support","image":"https://raw.githubusercontent.com/ServiceStack/docs/master/docs/images/grpc/grpc-horizontal-color.svg","tags":[],"date":"\/Date(1578960000000-0000)\/","content":"We're super excited to open the year with the premier feature in this release **ServiceStack gRPC**, our highly-productive entry into the\n[gRPC](https://grpc.io) universe with a number of value-added additions that makes developing and consuming gRPC Services a joy with USPs\nthat leverages and preserves your existing knowledge and investments and maximizes the utility of your Services offering unprecedented value\nfor your development efforts.","url":"https://docs.servicestack.net/grpc","wordCount":77,"lineCount":10,"group":"v5.8"},{"slug":"feature2","draft":false,"title":"Updated Templates .NET Core 3.1","image":"https://raw.githubusercontent.com/ServiceStack/Assets/master/csharp-templates/vue-nuxt.png","tags":[],"date":"\/Date(1578960000000-0000)\/","content":"With the release of [.NET Core 3.1 LTS](https://devblogs.microsoft.com/dotnet/announcing-net-core-3-1/) we've standardized our Project Templates\nand tools to **.NET Core 3.1 LTS** whilst continuing to support existing **.NET Core 2.1+** and **.NET Framework** projects including\n[ASP.NET Core Apps on the .NET Framework](https://docs.servicestack.net/templates-corefx).","url":"https://docs.servicestack.net/releases/v5.8#net-core-31-lts-project-templates","wordCount":67,"lineCount":9,"group":"v5.8"},{"slug":"feature1","draft":false,"title":".NET Core 3 Updates","image":"https://raw.githubusercontent.com/ServiceStack/Assets/master/img/release-notes/netcore-banner.png?t","tags":[],"date":"\/Date(1569888000000-0000)\/","content":"Ordinarily we'd have a longer release cadence in between releases with more features, but with the recent release of .NET Core 3\nwe've cut this release cycle short so we can release a version of ServiceStack compatible with .NET Core 3+. Other than that the major focus\non this release was `#Script` with [many new features](https://docs.servicestack.net/releases/v5.7#script) we're excited to share after covering the ServiceStack changes.","url":"https://docs.servicestack.net/releases/v5.7#net-core-3","wordCount":81,"lineCount":9,"group":"v5.7"},{"slug":"feature2","draft":false,"title":"New #Script Updates","image":"https://sharpscript.net/assets/img/sandbox.svg","tags":[],"date":"\/Date(1569888000000-0000)\/","content":"We've seen great reception of [Gist Desktop Apps](https://docs.servicestack.net/releases/v5.6#gist-desktop-apps) from the last v5.6 release with a\nnice shoutout from [Jon Galloway](https://twitter.com/jongalloway) in the\n[ASP.NET Community August Stand up](https://www.youtube.com/watch?v=a2lq4yEfJpk&feature=youtu.be&t=1529),\na featured [blog post](https://www.hanselman.com/blog/SharpScriptFromServiceStackLetsYouRunNETAppsDirectlyFromAGitHubGist.aspx)\nfrom [Scott Hanselman](https://twitter.com/shanselman) as well features in Hacker News and Reddit.\n\nWe've since further enhanced `#Script` capabilities in this release making it more functional then ever, broadening its appeal\nin its growing list of use-cases.","url":"https://docs.servicestack.net/releases/v5.7#1st-class-script-code-and-lisp-language-support","wordCount":94,"lineCount":14,"group":"v5.7"},{"slug":"feature1","draft":false,"title":"Modular Startup","image":"https://raw.githubusercontent.com/ServiceStack/docs/master/docs/images/mix/feature-authrepo.png","tags":[],"date":"\/Date(1565568000000-0000)\/","content":"We want to dramatically simplify and improve the experience for configuring ASP.NET Core Apps and make them truly composable,\nwhere we can drop-in files that auto configures itself with both ASP.NET Core and ServiceStack's AppHost so they can\nencapsulate an entire feature and provide instant utility without needing to wade through different steps of how they\nshould be manually configured at different places in your Startup configuration class.","url":"https://docs.servicestack.net/releases/v5.6#modular-startup","wordCount":78,"lineCount":10,"group":"v5.6"},{"slug":"feature2","draft":false,"title":"Mix'n'Match .NET Core Apps","image":"https://raw.githubusercontent.com/ServiceStack/docs/master/docs/images/mix/example-validation-900.gif","tags":[],"date":"\/Date(1565568000000-0000)\/","content":"To complete the picture of making it easy as possible to compose ASP.NET Core Apps we've created the `mix` dotnet tool to easily\ninstall features which can be installed with:\n\n```bash\n$ dotnet tool install --global mix\n```\n\nThe `mix` tool is designed around applying ASP.NET Core features captured in GitHub gists to your local .NET Core projects.\n\nThen choosing which features you want to add to your project with `mix `, e.g:\n\n```bash\n$ mix redis\n```","url":"https://docs.servicestack.net/releases/v5.6#mix-n-match-net-core-apps","wordCount":85,"lineCount":20,"group":"v5.6"},{"slug":"feature3","draft":false,"title":"Single Page App Component Libraries","image":"https://raw.githubusercontent.com/ServiceStack/docs/master/docs/images/ssvs/spa-templates-overview.png","tags":[],"date":"\/Date(1565568000000-0000)\/","content":"To lay the foundation for richer and more tightly integrated UI controls, we've created UI and common component libraries for the\n3 most popular JS frameworks:\n\n\n- [@servicestack/vue](https://github.com/ServiceStack/servicestack-vue)\n- [@servicestack/react](https://github.com/ServiceStack/servicestack-react)\n- [@servicestack/angular](https://github.com/ServiceStack/servicestack-angular)\n\n\nAll new [Single Page App Project Templates](https://docs.servicestack.net/templates-single-page-apps) have been pre-configured to use these libraries which will make it\na lot easier to deliver new UI components and updates to existing SPA Apps with just an npm upgrade.","url":"https://docs.servicestack.net/releases/v5.6#spa-component-libraries","wordCount":89,"lineCount":17,"group":"v5.6"},{"slug":"feature1","draft":false,"title":"ServiceStack turns 10 🥳","image":"https://servicestack.net/img/whatsnew/v5.5/anniversary-10.png","tags":[],"date":"\/Date(1553990400000-0000)\/","content":"Before we get into unpacking this release we're happy to announce that we've now eclipsed **10 years** since our\n[first commit](https://github.com/ServiceStack/ServiceStack/commit/2a9cd0d10247ae1a679ac011d7bdef593937dba4)!\n\nI'd like to take this milestone to thank our thousands of Customers we've had the pleasure to serve and see our Software used which has amassed\nmore than **27,000,000+ total downloads** on NuGet and to see the uptick in adoption of some of our unique features like\n[Add ServiceStack Reference](https://docs.servicestack.net/add-servicestack-reference) which has been used more than **88,000 times**\nto generate native Typed DTOs amongst its [8 supported languages](https://docs.servicestack.net/add-servicestack-reference#supported-languages).","url":"https://docs.servicestack.net/releases/v5.5#servicestack-turns-10","wordCount":107,"lineCount":13,"group":"v5.5"},{"slug":"feature2","draft":false,"title":"Templates upgrades to #Script","image":"https://servicestack.net/img/whatsnew/v5.5/sharpscript.png","tags":[],"date":"\/Date(1553990400000-0000)\/","content":"As we continue enhancing ServiceStack's scripting support with exciting new features, it no longer made sense to call our dynamic scripting language\n\"Templates\" which is just one of the many use-cases `#Script` enables.\n\n[#Script](https://sharpscript.net) is typical of a popular dynamic template language you'd find in other platforms, using the ubiquitously familiar mix of\n[JavaScript Expressions](https://sharpscript.net/docs/expression-viewer) which for increased wrist-friendly readability can be easily composed\ntogether using the Unix `|` operator as embraced by [Vue.js filters](https://vuejs.org/v2/guide/syntax.html#header) and\n[Angular's Template Expressions](https://angular.io/guide/template-syntax#template-expression-operators)\nwhist the [Script Statement Blocks](https://sharpscript.net/docs/blocks) adopt the universally adopted Handlebars-like syntax that's ideal for\nrendering dynamic pages.","url":"https://docs.servicestack.net/releases/v5.5#script-fka-servicestack-templates","wordCount":118,"lineCount":15,"group":"v5.5"},{"slug":"feature1","draft":false,"title":".NET Core Windows Desktop Apps!","image":"https://raw.githubusercontent.com/ServiceStack/docs/master/docs/images/app/netcore-chromium-splash.png","tags":[],"date":"\/Date(1537315200000-0000)\/","content":"Our new [app](https://www.nuget.org/packages/app) build tool is packed with features for \"Chromitizing\" any\n.NET Core Web App into a **.NET Core Windows Desktop App** that's as easy as installing the `app` tool:\n\n```bash\n$ dotnet tool install -g app\n```\n\nand using it to run your .NET Core Web App's `.dll`, e.g:\n\n```bash\n$ app MyApp.dll\n```\n\nWhere it will run your .NET Core App and host it inside an Chromium Embedded Framework (CEF) browser.\n\nThis provides instant utility for being able to deploy .NET Core Apps end users can run locally using Chrome's leading and consistent rendering engine\nwithin a Windows Desktop Application.","url":"https://docs.servicestack.net/releases/v5.4#net-core-windows-desktop-apps","wordCount":116,"lineCount":23,"group":"v5.4"},{"slug":"feature1","draft":false,"title":"Spanified ServiceStack","image":"https://servicestack.net/img/logo-text.svg","tags":[],"date":"\/Date(1535414400000-0000)\/","content":"Major rework was performed across the ServiceStack.Text and ServiceStack.Common foundational libraries to replace its internal usage of `StringSegment`\nwith .NET's new high-performance\n[Span and Memory Types](https://www.codemag.com/article/1807051/Introducing-.NET-Core-2.1-Flagship-Types-Span-T-and-Memory-T) primitives\nwhich are now used for all JSON/JSV deserialization and many other String utilities.\n\nThe new `Span` and `ReadOnlyMemory` Types is the successor to `StringSegment` which are both allocation-free, but Span also enjoys additional runtime support as a JIT intrinsic for improved performance.\n\nThis change was primarily an internal refactor so there shouldn't be any user visible differences except for the addition of the\n[System.Memory](https://www.nuget.org/packages/System.Memory) dependency which contains the new Memory types. As a general rule we're averse to adopting\nnew dependencies but the added performance of these new primitives makes it a required dependency for maintaining high-performance libraries.","url":"https://docs.servicestack.net/releases/v5.2#spanified-servicestack","wordCount":142,"lineCount":15,"group":"v5.2"},{"slug":"feature1","draft":false,"title":"Dart and Flutter!","image":"https://raw.githubusercontent.com/ServiceStack/docs/master/docs/images/dart/dart.png","tags":[],"date":"\/Date(1524528000000-0000)\/","content":"We're super excited to announce first-class support for [Dart](https://www.dartlang.org) and [Flutter](https://flutter.io)! - Google’s premier new mobile UI framework for crafting high-quality native interfaces for iOS and Android from a single code-base in record time with a Reactive development model simplifying the effort for building Complex UIs in similar vein to development models pioneered in popular JavaScript frameworks like React, React Native, Vue and Angular. It's offers a beautiful blend of rapid development cycles with its built-in Hot Reloading giving you instant iterative feedback of changes to your Mobile App in milliseconds, whilst still offering high-performance native experiences at runtime where Dart code is AOT compiled into native ARM in iOS and Android.","url":"https://docs.servicestack.net/releases/v5.1.0#dart-and-flutter","wordCount":131,"lineCount":7,"group":"v5.1"},{"slug":"feature1","draft":false,"title":"Future Versioning Scheme","image":"https://servicestack.net/img/logo-text.svg","tags":[],"date":"\/Date(1514937600000-0000)\/","content":"Historically ServiceStack releases are focused around \"Major release schedules\" published along with detailed Release Notes describing new features and changes added in each release. All packages are published together in \"lockstep\" with the same version number so the effort to upgrade ServiceStack projects can be done all at same time, with low frequency.\n\nWhilst we want to minimize the effort for Customers to upgrade we also want to make any fixes or enhancements to the previous release available sooner as there are often fixes reported and resolved immediately after each release and made available in our [pre-release packages on MyGet](https://docs.servicestack.net/myget) that most Customers wont get until the next major Release on NuGet.","url":"https://docs.servicestack.net/releases/v5.0.0#future-versioning-scheme","wordCount":126,"lineCount":9,"group":"v5.0"},{"slug":"feature2","draft":false,"title":"ServiceStack Mobile and Desktop Apps","image":"https://raw.githubusercontent.com/ServiceStackApps/HelloMobile/master/screenshots/splash-900.png","tags":[],"date":"\/Date(1514937600000-0000)\/","content":"The [HelloMobile](https://github.com/ServiceStackApps/HelloMobile) project has been rewritten to use the latest v5 .NET Standard 2.0 and .NET Framework clients and contains multiple versions of the same App demonstrating a number of different calling conventions, service integrations and reuse possibilities for each of the following platforms:\n\n- WPF\n- UWP\n- Xamarin.Android\n- Xamarin.iOS\n- Xamarin.OSX\n- Xamarin.Forms\n - iOS\n - Android\n - UWP","url":"https://docs.servicestack.net/releases/v5.0.0#servicestack-mobile-and-desktop-apps","wordCount":77,"lineCount":17,"group":"v5.0"}],"videos":[{"slug":"video5","draft":false,"title":"Stream processing of data with JSON Lines","tags":["serialization"," servicestack"," jsonl"],"date":"\/Date(1692057600000+0000)\/","content":"In this video, we explore the efficient JSON Lines (JSONL) data format, a favorite among developers and the AI community\nfor handling large datasets. We walk through working with JSON Lines data, including examples for streaming parsers,\nasynchronous parsing with ServiceStack, and integration with Typesense.","url":"https://youtu.be/m0tAfjvJaZg","wordCount":56,"lineCount":9,"group":"apis"},{"slug":"video1","draft":false,"title":"GitHub for Auto Deployments - Kubernetes Not Required","tags":["github-actions","deployment","hosting"],"date":"\/Date(1691452800000+0000)\/","content":"Step by step walkthrough for deploying your App via GitHub Actions and plain old SSH. \nCheap hardware is getting fast enough that a lot of Web Apps don't need sophisticated orchestration tools like Kubernetes, \nso we show how you can use fundamental tools like SSH, Docker Compose and GitHub Actions to do it yourself! \n\nLow traffic Apps & proof of concepts can easily share cost effective server running Linux, \nNginx Reverse Proxy with LetsEncrypt.","url":"https://youtu.be/7dardvqBFbE","wordCount":87,"lineCount":13,"group":"actions"},{"slug":"video4","draft":false,"title":"Load data fast with ADO.NET RDBMS Bulk Insert APIs","tags":["ormlite","db","performance"],"date":"\/Date(1690848000000+0000)\/","content":"OrmLite includes a Bulk Inserts API that encapsulates the most efficient ways for inserting large amounts of data \nin each supported RDBMS. We ran benchmarks across macOS on Apple M2 ARM, Intel Linux VM and Intel Windows 10 to measure \nhow fast they run across popular Operating System platforms.","url":"https://youtu.be/3gO_OEWIyPo","wordCount":64,"lineCount":10,"group":"features","order":4},{"slug":"video5","draft":false,"title":"GPT Agent Feature Plugin Updated with Semantic Kernel","tags":["gpt"],"date":"\/Date(1690848000000+0000)\/","content":"In this video, we delve into the integration of Microsoft's Semantic Kernel with our GPT Meeting Agent to simplify \nand enhance working with Large Language Models with a common abstraction library that allows for easy substitution\nand experimentation with different LLMs.","url":"https://youtu.be/smM-Bs7CxJ8","wordCount":54,"lineCount":11,"group":"features","order":5},{"slug":"video1","draft":false,"title":"Getting Started with OrmLite fast, code-first ORM for .NET","tags":["ormlite","db"],"date":"\/Date(1688428800000+0000)\/","content":"This video walks though getting started with OrmLite - a powerful, fast and easy to use ORM for .NET that \ncan be used in any .NET and .NET Framework App without the complexity of larger ORMs. \n\nIn this tutorial we'll demonstrate the best patterns to use to install, configure and use OrmLite in your Application, \ndefining code-first POCOs, using them to create RDBMS tables and explore how to Create, Query, Update and Delete them \nusing OrmLite's Typed APIs.","url":"https://youtu.be/vUbpwjfEYzg","wordCount":92,"lineCount":13,"group":"features","order":1},{"slug":"video2","draft":false,"title":"Getting Started with ServiceStack.Redis in .NET","tags":["redis"],"date":"\/Date(1687824000000+0000)\/","content":"In this tutorial we explore the basics of Redis, an in-memory database, and its integration in .NET using the ServiceStack.Redis library. \nThe video covers topics such as setting up a Redis server with Docker, understanding the ServiceStack.Redis library, and making \nthe most of Redis data structures in a .NET context. \n\nFurthermore, it also delves into utilizing the async capabilities of ServiceStack, all demonstrated through clear, practical examples.","url":"https://youtu.be/jBdOvTvjyqY","wordCount":82,"lineCount":13,"group":"features","order":2},{"slug":"custom-admin-uis","draft":false,"title":"Build beautiful custom .NET Admin UIs in minutes","tags":["vue","autoquery"],"date":"\/Date(1686700800000+0000)\/","content":"In this video we explore the Server Multi Razor Page and Client rendered Admin UI Pages in the latest .NET\n[vue-mjs](https://vue-mjs.web-templates.io) project template to see how to use the new SidebarLayout and AutoQueryGrid\nVue Tailwind components to build beautiful Admin UI Pages within minutes.","url":"https://youtu.be/wlRA4_owEsc","wordCount":59,"lineCount":10,"group":"vue-projects","order":4},{"slug":"video2","draft":false,"title":"New Disqus OSS self-host alternative for .NET Websites","tags":["creatorkit","posts","tailwind"],"date":"\/Date(1686268800000+0000)\/","content":"In this video we explore how we can use CreatorKit - a self-hosting alternative to Disqus to add comments, voting\nand moderation to any existing page or blog post.\n\nCreatorKit is especially useful for adding dynamic post comment and voting features to Jamstack and other\nstatically generated websites which can continually be statically pre-rendered and hosted on CDN's whilst its \ndynamic features are powered by an external CreatorKit instance.","url":"https://youtu.be/lgpl-VjxtdU","wordCount":79,"lineCount":12,"group":"creatorkit"},{"slug":"video1","draft":false,"title":"New Mailchimp self-host mail management alternative","tags":["creatorkit","mail","tailwind"],"date":"\/Date(1686182400000+0000)\/","content":"In this video we introduce CreatorKit an OSS self-hosting alternative to Mailchimp for managing mailing lists,\nnewsletter subscriptions, email templating, marketing campaigns & more whose tailwind components can be easily \nintegrated into any existing website.\n\nIt's an ideal companion for .NET Apps looking to manage their mailinglist and newsletter subscribers in an\nisolated customizable .NET App with support for creating custom email layouts, templates and mail campaigns.","url":"https://youtu.be/_qDVtfcHf14","wordCount":75,"lineCount":12,"group":"creatorkit"},{"slug":"video1","draft":false,"title":"Bring static Xkcd dataset to life with AutoQuery","tags":["autoquery"," razor-pages"," ssg"," tailwind"],"date":"\/Date(1683763200000+0000)\/","content":"In this video, we demonstrate how to use AutoQuery to turn a static XKCD comic dataset from Hugging Face into a Web API, \naddressing common issues of siloed data.\n\nBy creating well-defined AutoQuery APIs, we make the data more accessible and enable efficient data integrations \nfor rapid creation of production Web Apps which we demonstrate in new lightweight a Razor SSG Vue App.","url":"https://youtu.be/CrKtXVrPj8Q","wordCount":78,"lineCount":11,"group":"autoquery"},{"slug":"video1","draft":false,"title":"Using Razor SSG to Create Websites in GitHub Codespaces","tags":["razor-pages"," ssg"," tailwind"," codespaces"],"date":"\/Date(1680048000000+0000)\/","content":"This video takes an in-depth look at the [razor-ssg](https://razor-ssg.web-templates.io) ServiceStack template, a powerful tool that \nharnesses the power of .NET Razor Pages to provide seamless static site generation (SSG) capabilities \n\nWith GitHub Codespaces integration, you can develop, test, and manage your application all within your browser, eliminating the need \nfor a dedicated development environment and expediting your workflow, which can all be done on the go from an iPad","url":"https://youtu.be/MRQMBrXi5Sc","wordCount":88,"lineCount":12,"group":"projects"},{"slug":"razor-ssg","draft":false,"title":"Using Razor SSG to Create Websites in GitHub Codespaces","tags":["razor-pages","ssg","markdown","codespaces"],"date":"\/Date(1680048000000+0000)\/","content":"This video takes an in-depth look at the [razor-ssg](https://razor-ssg.web-templates.io) ServiceStack template, a powerful tool that \nharnesses the power of .NET Razor Pages to provide seamless static site generation (SSG) capabilities \n\nWith GitHub Codespaces integration, you can develop, test, and manage your application all within your browser, eliminating the need \nfor a dedicated development environment and expediting your workflow, which can all be done on the go from an iPad","url":"https://youtu.be/MRQMBrXi5Sc","wordCount":86,"lineCount":13,"group":"vue-projects","order":3},{"slug":"video1","draft":false,"title":"Fastest way to a working gRPC Server and Flutter solution","tags":["grpc","flutter","android"],"date":"\/Date(1679875200000+0000)\/","content":"In this video we'll walk through configuring Flutter and gRPC .NET Services with the `flutter-grpc` mix template\nto add a new Flutter application using your locally installed **Flutter SDK** to an existing ServiceStack `grpc` project\nthat has been configured to support gRPC services","url":"https://youtu.be/fgts6sQ2Ags","wordCount":55,"lineCount":9,"group":"flutter-grpc"},{"slug":"video1","draft":false,"title":"Flutter Todo App with .NET API, from Scratch in Minutes","tags":["flutter","android","api"],"date":"\/Date(1679875200000+0000)\/","content":"This video starts from scratch, walking through installing Flutter SDK, \nbefore adding a new native Flutter App to a new .NET Blazor Server project -\ngiving our existing TODO Blazor Web App new native iOS & Android native UIs\n\nNext, we'll demonstrate the iterative development workflow of making changes \nto backend .NET APIs that's easily kept in-sync with our clients Dart DTOs\nfrom within Android Studio or command-line","url":"https://youtu.be/t4WcXo4Vnio","wordCount":79,"lineCount":13,"group":"flutter"},{"slug":"video2","draft":false,"title":"Use Flutter to build a Bookings App Fast","tags":["flutter","android","api"],"date":"\/Date(1679875200000+0000)\/","content":"In this video, we'll show how we can rapidly develop a new Flutter Android Bookings App\nadded to a new [vue-mjs](https://vue-mjs.web-templates.io) .NET Project using `x mix flutter`\n\nNext, we'll dive into the development process, where we'll demonstrate the productivity\nof calling typed .NET APIs using typed Dart DTOs for end-to-end typed integrations\nthat can be effortlessly updated from within Android Studio","url":"https://youtu.be/eMbwaMuIk84","wordCount":72,"lineCount":13,"group":"flutter"},{"slug":"video1","draft":false,"title":"Instantly Manage your data using AutoQueryGrid Vue","tags":["vue","autoquery"],"date":"\/Date(1678924800000+0000)\/","content":"This walkthrough explores the ServiceStack Vue 3 library and the functionality of the AutoQueryGrid component. The AutoQueryGrid component simplifies the integration of AutoQuery services by generating a customizable UI. \n\nBy following this guide, you'll learn how to effectively utilize these tools to enhance your application's user interface and overall user experience.","url":"https://youtu.be/znCoC-Ct0Ps","wordCount":63,"lineCount":10,"group":"vue"},{"slug":"video1","draft":false,"title":"Preview APIs with the Auto Html API Page","tags":["ui","api"],"date":"\/Date(1678665600000+0000)\/","content":"The Auto HTML Page provides instant utility for API consumers in consuming your APIs with a built-in \nAPI Response Visualizer, JSON syntax highlighting, integrated Postman-like UI and API SDK integration all-in-one.\n\nPowered by Vue 3 and the ServiceStack [Vue library](https://docs.servicestack.net/vue/), it's also highly customizable.","url":"https://youtu.be/3gjisRVqhLo","wordCount":61,"lineCount":11,"group":"ui-autohtml"},{"slug":"video2","draft":false,"title":"Vue 3 Tailwind Components Library","tags":["vue","autoquery"],"date":"\/Date(1676332800000+0000)\/","content":"In this video, we demonstrate using the @servicestack/vue components library for Vue.js 3 Multipage Apps (MPAs) along with the `vue-mjs` template. \n\nThe template illustrates building content-heavy or complex sites while avoiding the intricacies of Single Page Apps (SPAs) through the use of JavaScript Modules, Tailwind, Vue.js, Razor Pages, and ServiceStack.","url":"https://youtu.be/YIa0w6whe2U","wordCount":61,"lineCount":9,"group":"vue"},{"slug":"video3","draft":false,"title":"Create testable code-first RDBMS migrations in C#","tags":["ormlite","db","migrations"],"date":"\/Date(1665619200000+0000)\/","content":"In this video, we guide you through creating OrmLite DB Migrations, which enhance OrmLite's lightweight code-first development approach by offering a simple change-based migration solution. This solution supports the code-first development workflow of OrmLite, streamlining the process. \n\nBy following the video, you'll learn how to effectively manage database schema changes while leveraging OrmLite's capabilities.","url":"https://youtu.be/NIVFqute7JQ","wordCount":66,"lineCount":10,"group":"features","order":3},{"slug":"video3","draft":false,"title":"Using Database Admin UI to browse your App's databases","tags":["db","admin","ui"],"date":"\/Date(1662076800000+0000)\/","content":"Database Admin UI lets Admin Users quickly browse and navigate your App's configured RDBMS schemas and tables,\nwith support for browsing, querying, ordering and filtering data directly from your database without needing to create any APIs \n\nConfiguration is imported from your AppHost which can be easily added in shared development or testing environments \nfor developers and non-developers alike to troubleshoot data issues","url":"https://youtu.be/NZkeyuc_prg","wordCount":74,"lineCount":11,"group":"ui-admin"},{"slug":"video2","draft":false,"title":"Use Redis Admin UI to inspect your App's Redis usage","tags":["redis","admin","ui"],"date":"\/Date(1661904000000+0000)\/","content":"Redis Admin UI lets you manage your App's configured Redis Server with a UX-friendly UI for managing core Redis data types, \nsimple search to quickly find Redis values, quick navigation between related values, \nfirst class support for JSON values and a flexible command interface and command history to inspect all previously run redis \ncommands that's easily editable & rerun","url":"https://youtu.be/AACZtTOcQbg","wordCount":73,"lineCount":11,"group":"ui-admin"},{"slug":"video2","draft":false,"title":"Build a Bookings API with Auto Admin UI in minutes","tags":["autoquery"],"date":"\/Date(1660608000000+0000)\/","content":"From an empty web project, this video shows how to:\n- Add SQLite & Authentication support\n- Define code-first Data Model with Validation\n- Add User Management support\n- Enable Audit History support\n- Add Excel integration","url":"https://youtu.be/rSFiikDjGos","wordCount":46,"lineCount":12,"group":"autoquery"},{"slug":"video2","draft":false,"title":"Build a Bookings API with Auto Admin UI in minutes","tags":["razor-pages","mvc","tailwind","vue"],"date":"\/Date(1660608000000+0000)\/","content":"In this video tutorial, we demonstrate the steps required to create a bookings API that is designed to be easy to use for non-developers. \n\nTo achieve this, we make use of the ServiceStack Locode and Admin UI features.\nWith [Locode](/auto-ui#locode), developers can easily generate a fully functional APIs with CRUD functionality \nwhilst many App features like User Access, Logging, Profiling & DB Validation can be managed from the built-in [Admin UI](/auto-ui#admin).","url":"https://youtu.be/rSFiikDjGos","wordCount":89,"lineCount":12,"group":"apis"},{"slug":"video3","draft":false,"title":"File Upload services the Easy way","tags":["autoquery","files","locode"],"date":"\/Date(1660608000000+0000)\/","content":"The `FileUploadFeature` plugin in ServiceStack enables developers to add managed file uploads to their applications, \nproviding integration with any ServiceStack service, including AutoQuery services, as well as the Locode App UI. \n\nThe modular JavaScript used in this example provides a structured & organized way to write JavaScript code that \ncan be reused in multiple components, further simplifying the development process.","url":"https://youtu.be/xSUqAB0HQB4","wordCount":70,"lineCount":11,"group":"apis"},{"slug":"video1","draft":false,"title":"Real-time insights with Request Logging & Profiling UIs","tags":["logging","profiling","api","ui"],"date":"\/Date(1658707200000+0000)\/","content":"The new Request Logging & Profiling UIs bring an invaluable new level of observability into your App, \nfrom being able to quickly inspect and browse incoming requests, to tracing their behavior from their generated events \nin the new Diagnostic Source capabilities added all throughout ServiceStack, which both power the new UIs and \nenables new introspectability from code where you can tap in to inspect & debug when diagnostic events occurs","url":"https://youtu.be/LgQHTSHSk1g","wordCount":82,"lineCount":10,"group":"ui-admin"},{"slug":"video4","draft":false,"title":"Create API validation rules from the Validation Admin UI","tags":["db","validation","admin","ui"],"date":"\/Date(1658707200000+0000)\/","content":"With very little code, we walk through the steps required to setup AutoQuery APIs with dynamic validation in .NET. \nThis enables non-developers to manage data, user access and validation rules all from a friendly admin UI \n\nRules can be applied at runtime taking immediate effect, with custom messages, status codes and notes about each rule \nmaking them easy to manage in a team setting","url":"https://youtu.be/W5OJAlOxH98","wordCount":77,"lineCount":11,"group":"ui-admin"},{"slug":"video5","draft":false,"title":"Create Simple, Fast, Reliable Apps with Litestream","tags":["ormlite","db","litestream","hosting"],"date":"\/Date(1658448000000+0000)\/","content":"This guide introduces [Litestream](https://litestream.io) for SQLite and demonstrates using ServiceStack Litestream mix templates for efficient setup. The tutorial focuses on SQLite backup and restore procedures during deployment via SSH and docker-compose, utilizing GitHub Actions. \n\nBy following these steps, you can streamline your SQLite management tasks and enhance your overall deployment process.","url":"https://youtu.be/WXRwT7ayc1Y","wordCount":64,"lineCount":9,"group":"actions"},{"slug":"video4","draft":false,"title":"Managed File Uploads","tags":["files","blazor"],"date":"\/Date(1654560000000+0000)\/","content":"In this walkthrough, we explore the `FilesUploadFeature` plugin and a demo FileBlazor App's \n[Managed Files Uploads](https://docs.servicestack.net/locode/files) solution. \n\nThe plugin is a powerful tool that adds managed file uploads to your ServiceStack App, seamlessly integrating \nwith any ServiceStack service, including AutoQuery services and [Locode](/auto-ui#locode) built-in UI \nand [Vue AutoQueryGrid](https://docs.servicestack.net/vue//autoquerygrid) and \n[Blazor Component Library](https://blazor-gallery.servicestack.net/gallery).","url":"https://youtu.be/5sd00MzHpaU","wordCount":72,"lineCount":14,"group":"apis"},{"slug":"video1","draft":false,"title":"Database first development with Locode","tags":["autoquery","autogen","locode"],"date":"\/Date(1652659200000+0000)\/","content":"In this video we show a step by step process for start with an existing database and customizations without the need for code first models.\n\n[Locode](https://docs.servicestack.net/locode/) is a generated API driven by your APIs metadata. \nCombined with other high-level ServiceStack features, it becomes a way to rapidly develop web applications with robust service APIs \nthat can be later extended with custom UIs.","url":"https://youtu.be/NiTp5Z_5U2Y","wordCount":76,"lineCount":12,"group":"autogen"},{"slug":"video3","draft":false,"title":"Rapidly develop apps with Locode","tags":["autoquery","locode"],"date":"\/Date(1652659200000+0000)\/","content":"ServiceStack Locode App is a generated API driven by your service metadata. When combined with AutoQuery, \nit becomes a way to rapidly develop web applications with robust service APIs that can be later extended with custom UIs. \n\nIn this video we show 3 examples from generating everything from an existing database, making customizations to the Locode \nApp, and finally reusing all your services in a custom Blazor WASM App","url":"https://youtu.be/hkuO_DMFXmc","wordCount":78,"lineCount":12,"group":"autoquery"},{"slug":"video1","draft":false,"title":"Rapidly develop apps with Locode","tags":["ui","api"],"date":"\/Date(1652659200000+0000)\/","content":"Learn how to easily create customizable feature-rich UX-friendly RDBMS Web Apps with Locode's\ninstant CRUD UI driven by your AutoQuery APIs that can be further extended with custom UIs\n\nIn this video we show 3 examples from generating everything from an existing database, making customizations to the Locode App, \nand finally reusing all your services in a custom Blazor WASM App","url":"https://youtu.be/hkuO_DMFXmc","wordCount":68,"lineCount":12,"group":"ui-locode"},{"slug":"video2","draft":false,"title":"Database-first development with Locode","tags":["ui","api"],"date":"\/Date(1652659200000+0000)\/","content":"To demonstrate a database-first development workflow we've enabled\n[AutoGen](https://docs.servicestack.net/autoquery-autogen)\non the **Northwind** sample database to generate \n[AutoQuery](https://docs.servicestack.net/autoquery-rdbms) & \n[CRUD](https://docs.servicestack.net/autoquery-crud) \nAPIs whose capabilities are used to power the custom Northwind Locode App","url":"https://youtu.be/NiTp5Z_5U2Y","wordCount":50,"lineCount":13,"group":"ui-locode"},{"slug":"video3","draft":false,"title":"Quickly create a code-first API and CRUD App with Locode","tags":["autoquery","crud","ui"],"date":"\/Date(1652659200000+0000)\/","content":"To showcase greater customizability options, we've exported AutoGen APIs of the **Chinook** sample database into typed AutoQuery APIs \n& Data Models to unlock more flexible code-first declarative & programmatic dev models that includes Custom UI components \nto showcase potential enhancements in Locode Apps","url":"https://youtu.be/mFyMgg7c3vg","wordCount":57,"lineCount":9,"group":"ui-locode"},{"slug":"video1","draft":false,"title":"Fastest way to a working gRPC Server and Flutter solution","tags":["flutter","dart","grpc"],"date":"\/Date(1648771200000+0000)\/","content":"The video guides viewers through configuring a Flutter application with gRPC .NET services using the `flutter-grpc` mix template, starting with Flutter and gRPC services introduction and installation of the required SDK and template. \n\nIt demonstrates creating typed Dart DTOs for gRPC services, making typed requests, and keeping the Flutter app in sync with the .NET backend through automatic updates.","url":"https://youtu.be/fgts6sQ2Ags","wordCount":73,"lineCount":9,"group":"grpc"},{"slug":"video4","draft":false,"title":"Rapidly develop C# .NET Next.js JamStack Apps with Rider","tags":["nextjs","react","jamstack"],"date":"\/Date(1644278400000+0000)\/","content":"In this comprehensive walkthrough, we will guide you through the ServiceStack Next.js template, which offers an \nexceptional rapid development cycle when used with JetBrains Rider. \n\nThis template is specifically designed for Microsoft .NET developers seeking a seamless and efficient Next.js React \nsetup while employing the better performing Jamstack architecture.","url":"https://youtu.be/3pPLRyPsO5A","wordCount":66,"lineCount":12,"group":"projects"},{"slug":"video3","draft":false,"title":"Ultimate Vue SPA & SSG Jamstack templates for .NET","tags":["vue","vite","jamstack"],"date":"\/Date(1643673600000+0000)\/","content":"In this video tutorial, we introduce the `vue-ssg` template, a powerful combination of Vite, Vue3, and ServiceStack \nthat offers an unparalleled developer experience\n\nThis template is specifically designed for .NET developers seeking a seamless and efficient Vue.js setup \nwhile employing the Jamstack architecture leveraging capabilities of Vite, Vue & ServiceStack","url":"https://youtu.be/D-rU0lU_B4I","wordCount":63,"lineCount":12,"group":"projects"},{"slug":"ultimate-vue-spa-ssg","draft":false,"title":"Ultimate Vue SPA & SSG Jamstack templates for .NET","tags":["vue","vite","jamstack"],"date":"\/Date(1643673600000+0000)\/","content":"In this video tutorial, we introduce the `vue-ssg` template, a powerful combination of Vite, Vue3, and ServiceStack \nthat offers an unparalleled developer experience\n\nThis template is specifically designed for .NET developers seeking a seamless and efficient Vue.js setup \nwhile employing the Jamstack architecture leveraging capabilities of Vite, Vue & ServiceStack","url":"https://youtu.be/D-rU0lU_B4I","wordCount":64,"lineCount":13,"group":"vue-projects","order":4},{"slug":"video1","draft":false,"title":"API Explorer - a better Postman & Swagger UI","tags":["ui","api"],"date":"\/Date(1643068800000+0000)\/","content":"The entire API Explorer UI is driven by the rich metadata around your APIs typed Service Contracts and AppHost's registered plugins\n\nIt's built from the ground up with multiple levels of customizations, supporting both declarative & programmatic models\nwhilst also enabling rich interactive HTML Components to document each of your APIs & their Types","url":"https://youtu.be/lUDlTMq9DHU","wordCount":65,"lineCount":10,"group":"ui-explorer"},{"slug":"video2","draft":false,"title":"Add Typed C#, TypeScript, F# and VB.NET ServiceStack References from JetBrains Rider","tags":["rider","c#","f#","vb"],"date":"\/Date(1629936000000+0000)\/","content":"The ServiceStack plugin for Jetbrains Rider simplifies managing your C#, F# and VB.NET client integrations by automating the generation of typed DTOs, request and response models, and client libraries.\n\nIn this video, we demonstrate the process of installing and utilizing the JetBrains Rider plugin to manage your client integrations for your ServiceStack .NET clients.","url":"https://youtu.be/JKsgrstNnYY","wordCount":72,"lineCount":9,"group":"ss-ref"},{"slug":"video6","draft":false,"title":"Post Command line HTTP API tools","tags":["inspect","tool"],"date":"\/Date(1629676800000+0000)\/","content":"[Post Command](https://docs.servicestack.net/post-command) is a collection of command line utils that lets you easily discover,\ninspect and invoke ServiceStack endpoints from a single command.\n\nUse [inspect](https://docs.servicestack.net/post-command#inspect-command) to discover features and APIs available on a remote\nServiceStack endpoint including the version of ServiceStack running, the App’s registered Content Types, Plugins and Auth Providers\nas well as its public APIs, their routes and Response Types.","url":"https://youtu.be/FcXG4RnlVQk","wordCount":76,"lineCount":11,"group":"apis"},{"slug":"video1","draft":false,"title":"Call typed .NET APIs from Python","tags":["python","vscode","jupyter"],"date":"\/Date(1629158400000+0000)\/","content":"The video tutorial walks through how to leverage Add ServiceStack Reference for Python in different Python IDEs \nsuch as PyCharm, VSCode, and Jupyter Notebooks \n\nAdd ServiceStack Reference is a powerful tool that automatically generates typed Python DTOs for your \nServiceStack APIs, saving you time and effort. With this tool, you can access your web services with \nease and benefit from the productivity boost it provides.","url":"https://youtu.be/WjbhfH45i5k","wordCount":76,"lineCount":13,"group":"ss-ref"},{"slug":"video1","draft":false,"title":"Create Python Jupyter Notebooks for .NET APIs","tags":["jupyter","python"],"date":"\/Date(1629158400000+0000)\/","content":"The video demonstrates generating Jupyter Notebooks using ServiceStack **x** tool and [Instant Client Apps](https://apps.servicestack.net), which together provide an efficient and portable development experience. \n\nThis enables developers to use Jupyter Notebooks for tasks like data analysis, visualization, and machine learning in a transferable manner across environments.","url":"https://youtu.be/h6UwDuXt8MA","wordCount":61,"lineCount":10,"group":"jupyter"},{"slug":"video2","draft":false,"title":"Create C# Jupyter Notebooks to Inspect & Chart .NET APIs","tags":["jupyter","c#"],"date":"\/Date(1629158400000+0000)\/","content":"This video demonstrates integrating .NET Interactive and JupyterLab to enhance the development experience, creating a seamless workflow when working with ServiceStack services. \n\nIt guides viewers through generating working C# notebooks for any ServiceStack service, highlighting improved productivity through these tools which are FREE on [mybinder.org](https://mybinder.org).","url":"https://youtu.be/vt92pbet5bY","wordCount":64,"lineCount":11,"group":"jupyter"},{"slug":"video3","draft":false,"title":"Create F# Jupyter Notebooks to inspect .NET APIs & run FREE on Binder","tags":["jupyter","f#"],"date":"\/Date(1629158400000+0000)\/","content":"This video demonstrates integrating .NET Interactive and JupyterLab to enhance the development experience, creating a seamless workflow when working with ServiceStack services.\n\nIt guides viewers through generating working F# notebooks for any ServiceStack service, highlighting improved productivity through these tools which are FREE on [mybinder.org](https://mybinder.org).","url":"https://youtu.be/PxH3K5WIDx8","wordCount":66,"lineCount":10,"group":"jupyter"},{"slug":"razor-press","draft":false,"title":"VitePress and Jekyll alternative for SSG Docs","tags":["razor-pages","ssg","tailwind","markdown"],"date":"\/Date(1626134400000+0000)\/","content":"Introducing Razor Press, a powerful ServiceStack project template for creating documentation and content-centric websites \nusing .NET's Razor Pages, Markdown, Tailwind CSS, and Vue. \n\nLearn how Razor Press aids in the easy creation, and deployment of your statically generated sites that can be hosted for \nFREE on GitHub Pages CDN","url":"https://youtu.be/uqEa_DfFFDQ","wordCount":61,"lineCount":12,"group":"vue-projects","order":2},{"slug":"video2","draft":false,"title":"Modern Razor Pages & MVC .NET Tailwind templates","tags":["razor-pages","mvc","tailwind","vue"],"date":"\/Date(1625529600000+0000)\/","content":"ServiceStack templates provide a wide range of options when it comes to using Razor Pages in your .NET application\n\nThese templates come with Tailwind, JS Modules, and Vue components already built-in,\nmaking it easy to build hybrid apps containing both Server-Side Rendering (SSR) and static resources\n\n### Live Demos\n- https://razor-tailwind.web-templates.io\n- https://web-tailwind.web-templates.io\n- https://mvc-tailwind.web-templates.io\n- https://vue-mjs.web-templates.io\n- https://razor-pages.web-templates.io","url":"https://youtu.be/SyppvQB7IPs","wordCount":73,"lineCount":18,"group":"projects"},{"slug":"video1","draft":false,"title":"Intro to ServiceStack","tags":["apis"],"date":"\/Date(1625529600000+0000)\/","content":"In this introduction to ServiceStack, we will guide you through the framework's message-based design and its numerous benefits, \nwhich include promoting simplicity and enabling maximum reuse. \n\nBy utilizing a message-based design, ServiceStack encourages developers to focus on the core functionality of their services while \nabstracting away complexities, resulting in a more streamlined and efficient development process.","url":"https://youtu.be/Vae0ALalIP0","wordCount":64,"lineCount":12,"group":"apis"},{"slug":"modern-razor-tailwind","draft":false,"title":"Modern Razor Pages & MVC .NET Tailwind templates","tags":["razor-pages","mvc","tailwind","vue"],"date":"\/Date(1625529600000+0000)\/","content":"ServiceStack templates provide a wide range of options when it comes to using Razor Pages in your .NET application\n\nThese templates come with Tailwind, JS Modules, and Vue components already built-in,\nmaking it easy to build hybrid apps containing both Server-Side Rendering (SSR) and static resources","url":"https://youtu.be/SyppvQB7IPs","wordCount":57,"lineCount":12,"group":"vue-projects","order":1},{"slug":"video5","draft":false,"title":"Rapidly develop .NET Vue.js SPA Apps","tags":["vue"],"date":"\/Date(1621555200000+0000)\/","content":"In this video tutorial, we will guide you through the process of utilizing the vue-spa template, an exceptional project template \nthat combines the power of ServiceStack and Vue.js to create a seamless development experience. \n\nThis template is specifically designed to optimize rapid iterative dev cycles, allowing developers to quickly iterate on their \nfrontend and backend changes.","url":"https://youtu.be/4HphWPrKwb0","wordCount":68,"lineCount":11,"group":"projects"},{"slug":"rapid-vue-mjs","draft":false,"title":"Rapidly develop .NET Vue.js SPA Apps","tags":["vue"],"date":"\/Date(1621555200000+0000)\/","content":"In this video tutorial, we will guide you through the process of utilizing the vue-spa template, an exceptional project template \nthat combines the power of ServiceStack and Vue.js to create a seamless development experience. \n\nThis template is specifically designed to optimize rapid iterative dev cycles, allowing developers to quickly iterate on their \nfrontend and backend changes.","url":"https://youtu.be/4HphWPrKwb0","wordCount":69,"lineCount":12,"group":"vue-projects","order":5},{"slug":"video2","draft":false,"title":"Enabling Dart gRPC support to ServiceStack .NET Apps","tags":["dart","grpc"],"date":"\/Date(1620864000000+0000)\/","content":"This video tutorial explains how to easily transform ServiceStack services into gRPC services by generating the `.proto` file automatically from your service definitions.\n\nIt also showcases the [ServiceStack x tool](https://docs.servicestack.net/dotnet-tool)'s powerful features streamline integration, automate repetitive tasks, and support various languages, enabling the development of faster, more efficient, and scalable applications.","url":"https://youtu.be/UQlYodNS1xc","wordCount":68,"lineCount":9,"group":"grpc"},{"slug":"video2","draft":false,"title":"Enabling Dart gRPC support to ServiceStack .NET Apps","tags":["dart","grpc"],"date":"\/Date(1620864000000+0000)\/","content":"In this video we walk through how to enable gRPC endpoints for your existing ServiceStack services\nand how the [x dotnet tool](https://docs.servicestack.net/dotnet-tool) greatly\nsimplifies the development workflow of maintaining in-sync client integrations in a simple and consistent\nway across all gRPC languages","url":"https://youtu.be/UQlYodNS1xc","wordCount":54,"lineCount":10,"group":"flutter-grpc"},{"slug":"video1","draft":false,"title":"Call typed .NET APIs from Flutter Android Apps using Dart","tags":["flutter","dart","android"],"date":"\/Date(1619654400000+0000)\/","content":"In this video, we will demonstrate how you can swiftly set up and begin utilizing ServiceStack's Dart client library with your Flutter Android or iOS applications.\n\nThis also enables you to automate the generation native typed Dart Data Transfer Objects (DTOs) using the Add ServiceStack Reference feature, which simplifies the integration process and typed end-to-end communication between your Flutter Mobile Apps.","url":"https://youtu.be/ocH5L-CikQ0","wordCount":76,"lineCount":10,"group":"mobile"},{"slug":"video3","draft":false,"title":"Call .NET APIs from a Flutter Android App with native Dart","tags":["flutter","android","apis"],"date":"\/Date(1619654400000+0000)\/","content":"In this video we should how you can quickly get up and running using ServiceStack's \nDart client library with your Flutter Android or iOS Apps \nto generate native typed Dart DTOs with [Add ServiceStack Reference](https://docs.servicestack.net/dart-add-servicestack-reference)\nenabling end-to-end typed integrations to call .NET APIs from Flutter Mobile, Desktop and Dart Web Apps","url":"https://youtu.be/ocH5L-CikQ0","wordCount":69,"lineCount":11,"group":"flutter"},{"slug":"video2","draft":false,"title":"Using GitHub Actions for CI & .NET App Deployments","tags":["github-actions","deployment"],"date":"\/Date(1619049600000+0000)\/","content":"This tutorial demonstrates enabling continuous integration, deployment, hosting, and Let's Encrypt HTTPS configuration for an existing ServiceStack Project using the new mix support for GitHub Actions. \n\nWe'll guide you through the process of integrating these powerful features into your project. By following the tutorial, you'll streamline your workflow of your ServiceStack Project.","url":"https://youtu.be/0PvzcnxlBvc","wordCount":65,"lineCount":9,"group":"actions"},{"slug":"video2","draft":false,"title":"Servicify an existing RDBMS with AutoQuery","tags":["autoquery","autogen"],"date":"\/Date(1618963200000+0000)\/","content":"ServiceStack’s AutoGen enables a number of exciting possibilities, predominantly it’s the fastest way to ServiceStack-ify an existing systems \nRDBMS where it will serve as an invaluable tool for anyone wanting to quickly migrate to ServiceStack and access its functionality \necosystem around ServiceStack Services","url":"https://youtu.be/NaJ7TW-Q_pU","wordCount":53,"lineCount":11,"group":"autogen"},{"slug":"video3","draft":false,"title":"Deploy Docker .NET Apps to AWS ECS with GitHub Actions","tags":["github-actions","deployment","aws","ecs"],"date":"\/Date(1618963200000+0000)\/","content":"ServiceStack projects, enabling the configuration for building, testing, and deploying to a cost-efficient AWS ECS setup. By utilizing this approach, Docker Apps can be deployed on a single instance, automatically configured behind an NGINX proxy with Let's Encrypt SSL support. \n\nFollowing this tutorial will streamline your workflow of your ServiceStack projects.","url":"https://youtu.be/Eh4tvLN8i8g","wordCount":66,"lineCount":10,"group":"actions"},{"slug":"video3","draft":false,"title":"Create Instant Client Apps from C# .NET Web APIs","tags":["c#","f#","node.js","dart"],"date":"\/Date(1618963200000+0000)\/","content":"Generate working native client apps for your live ServiceStack services, in a variety of languages, instantly with our free managed service.\n\nThis tool enables your developers, and even your customers, to open a working example native application straight from the web to their favorite IDE.","url":"https://youtu.be/GTnuMhvUayg","wordCount":60,"lineCount":10,"group":"ss-ref"},{"slug":"video2","draft":false,"title":"Call typed .NET APIs from Xamarin.Android in C#","tags":["xamarin","android","c#"],"date":"\/Date(1618963200000+0000)\/","content":"ServiceStack framework and Add ServiceStack Reference tool can be utilized in mobile applications built with Xamarin.Android, enabling developers to create native Android applications using C# and .NET framework. \n\nAdd ServiceStack Reference simplifies the consumption of web services by generating your Request DTOs for easy API access. This saves time and effort, promoting faster mobile app development.","url":"https://youtu.be/cbYuem1b2tg","wordCount":70,"lineCount":9,"group":"mobile"},{"slug":"video4","draft":false,"title":"Run ServiceStack .NET Apps in AWS Lambda Containers","tags":["github-actions","deployment","aws","lambda"],"date":"\/Date(1612224000000+0000)\/","content":"This walkthrough demonstrates deploying a ServiceStack application to AWS Lambda using Docker containers through GitHub Actions. By following the guide, you'll learn the process of automating deployment and leveraging the advantages of containerization. \n\nThis approach simplifies the deployment process of your ServiceStack applications.\n\n - [Learn More](https://docs.servicestack.net/templates-aws)","url":"https://youtu.be/8mpGNTsSlvE","wordCount":62,"lineCount":11,"group":"actions"}],"posts":[{"slug":"cloud-value-between-architectures","draft":false,"title":"Should .NET Apps switch to ARM?","summary":"Evaluating the cost and performance of ARM vs x86 in AWS, Azure, and Hetzner","image":"https://images.unsplash.com/photo-1587845323226-bad89242c735?crop=entropy&fit=crop&h=1000&w=2000","author":"Darren Reid","tags":["dotnet"," hosting"," arm"," performance"],"date":"\/Date(1693180800000-0000)\/","url":"https://servicestack.net/posts/cloud-value-between-architectures","wordCount":3264,"lineCount":394},{"slug":"razor-ssg-new-blog-features","draft":false,"title":"New Blogging features in Razor SSG","summary":"Explore the new Blogging Features in Razor SSG","image":"https://images.unsplash.com/photo-1486312338219-ce68d2c6f44d?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["razor"," markdown"," blog"," dev"],"date":"\/Date(1692748800000-0000)\/","url":"https://servicestack.net/posts/razor-ssg-new-blog-features","wordCount":1296,"lineCount":337},{"slug":"jsonl-format","draft":false,"title":"Exploring the new streamable JSON Lines Format","summary":"A dive into the JSON Lines format and how to use it in ServiceStack","image":"https://images.unsplash.com/photo-1687042268541-5cc60ad9d3de?crop=entropy&fit=crop&h=1000&w=2000","author":"Darren Reid","tags":["serialization"," servicestack"," jsonl"],"date":"\/Date(1692057600000-0000)\/","url":"https://servicestack.net/posts/jsonl-format","wordCount":1656,"lineCount":217},{"slug":"kubernetes_not_required","draft":false,"title":"Using GitHub for Auto Deployments - Kubernetes Not Required","summary":"A cost-effective and straightforward web app deployment pattern using GitHub and a single Linux server","image":"https://images.unsplash.com/photo-1667372459510-55b5e2087cd0?crop=entropy&fit=crop&h=1000&w=2000","author":"Darren Reid","tags":["github-actions"," devops"," hosting"],"date":"\/Date(1691452800000-0000)\/","url":"https://servicestack.net/posts/kubernetes_not_required","wordCount":5292,"lineCount":693},{"slug":"bulk-insert-performance","draft":false,"title":"Which RDBMS has the fastest .NET Bulk Insert implementation?","summary":"Measuring the different performance of RDBMS Bulk Insert implementations","image":"https://images.unsplash.com/photo-1517026575980-3e1e2dedeab4?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["db"," dev"," dotnet"],"date":"\/Date(1690761600000-0000)\/","url":"https://servicestack.net/posts/bulk-insert-performance","wordCount":6965,"lineCount":1070},{"slug":"postgres-mysql-sqlserver-on-apple-silicon","draft":false,"title":"Install PostgreSQL, MySql and SQL Server on Apple Silicon","summary":"Easiest way to install PostgreSQL, MySql and SQL Server on macOS running Apple Silicon's M2","image":"https://images.unsplash.com/photo-1517663404855-6f96c7aa20e2?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["db"," dev"],"date":"\/Date(1690243200000-0000)\/","url":"https://servicestack.net/posts/postgres-mysql-sqlserver-on-apple-silicon","wordCount":1673,"lineCount":328},{"slug":"semantic-kernel-gptmeetngs","draft":false,"title":"Trying Microsoft's Semantic Kernel","summary":"Incorporating the Semantic Kernel into our GPT Meeting Agent gives developers more flexibility when working with LLMs","image":"https://images.unsplash.com/photo-1579548122080-c35fd6820ecb?crop=entropy&fit=crop&h=1000&w=2000","author":"Darren Reid","tags":["dotnet"," ai"," semantic-kernel"," gpt"],"date":"\/Date(1689638400000-0000)\/","url":"https://servicestack.net/posts/semantic-kernel-gptmeetngs","wordCount":834,"lineCount":54},{"slug":"razor-press","draft":false,"title":"Introducing Razor Press","summary":"Markdown & Razor Pages Static Site Generator for beautiful fast Content & Documentation","image":"https://images.unsplash.com/photo-1681301968680-fe46a0cd51be?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["razor"," markdown"," blog"," dev"],"date":"\/Date(1689552000000-0000)\/","url":"https://servicestack.net/posts/razor-press","wordCount":946,"lineCount":162},{"slug":"using-json-patch","draft":false,"title":"JSON Patch secrets into appsettings.json","summary":"Simplify managing App secrets by JSON patching them into your appsettings.json with during deployments","image":"https://images.unsplash.com/photo-1563089145-599997674d42?crop=entropy&fit=crop&h=1000&w=2000","author":"Darren Reid","tags":["devops"," github-actions"],"date":"\/Date(1689033600000-0000)\/","url":"https://servicestack.net/posts/using-json-patch","wordCount":670,"lineCount":135},{"slug":"new_razor_ssg_docs","draft":false,"title":"New Razor SSG generated docs.servicestack.net","summary":"The new docs.servicestack.net website is now generated with Razor SSG - now with Dark Mode!","image":"https://images.unsplash.com/photo-1526243741027-444d633d7365?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["razor"," ssg"," documentation"],"date":"\/Date(1688947200000-0000)\/","url":"https://servicestack.net/posts/new_razor_ssg_docs","wordCount":750,"lineCount":87},{"slug":"vue-stable-diffusion","draft":false,"title":"Vue Stable Diffusion","summary":"Rewriting Blazor Diffussion image generation & album catalog in Vue & Razor SSG","image":"https://images.unsplash.com/photo-1573490647695-2892d0bf89e7?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["vue"," tailwind"],"date":"\/Date(1686787200000-0000)\/","url":"https://servicestack.net/posts/vue-stable-diffusion","wordCount":1057,"lineCount":209},{"slug":"admin-uis","draft":false,"title":"Build Beautiful Admin UIs, Fast","summary":"Taking a look at the new features in Vue Razor Pages template to build Admin UIs, Fast","image":"https://images.unsplash.com/photo-1667906962043-a3e82dea23a3?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["vue"," tailwind"," admin"],"date":"\/Date(1686614400000-0000)\/","url":"https://servicestack.net/posts/admin-uis","wordCount":1879,"lineCount":364},{"slug":"creatorkit","draft":false,"title":"Introducing CreatorKit","summary":"Exploring CreatorKit - an OSS Self-Hosting alternative to Mailchimp and Disqus","image":"https://images.unsplash.com/photo-1493723843671-1d655e66ac1c?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["creatorkit"," marketing"," publishing"],"date":"\/Date(1686182400000-0000)\/","url":"https://servicestack.net/posts/creatorkit","wordCount":1348,"lineCount":209},{"slug":"chat-gpt-agents","draft":false,"title":"Creating ChatGPT Agents to call System APIs","summary":"A walkthrough of how to enable Large Language Model 'Agents' with access to your own ServiceStack APIs","image":"https://images.unsplash.com/photo-1675271591211-126ad94e495d?crop=entropy&fit=crop&h=1000&w=2000","author":"Darren Reid","tags":["servicestack"," gpt"," chatbot"," ai"],"date":"\/Date(1683849600000-0000)\/","url":"https://servicestack.net/posts/chat-gpt-agents","wordCount":1952,"lineCount":273},{"slug":"autoquery-xkcd","draft":false,"title":"Bringing xkcd static dataset to life with AutoQuery","summary":"Unsiloing data quickly with AutoQuery to make your datasets available from queryable Web APIs","image":"./img/posts/autoquery-xkcd/drawing-xkcd-upscaled.jpg","author":"Darren Reid","tags":["autoquery"," db"," dev"," huggingface"," vue"],"date":"\/Date(1681516800000-0000)\/","url":"https://servicestack.net/posts/autoquery-xkcd","wordCount":3352,"lineCount":551},{"slug":"razor-ssg","draft":false,"title":"Introducing Razor SSG","summary":"Create fast, beautiful statically rendered Razor Websites & Blogs","image":"https://images.unsplash.com/photo-1579767684138-a57e917d30aa?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["razor"," markdown"," blog"," dev"],"date":"\/Date(1680134400000-0000)\/","url":"https://servicestack.net/posts/razor-ssg","wordCount":3070,"lineCount":596},{"slug":"new_razor_ssg_website","draft":false,"title":"New Razor SSG generated servicestack.net","summary":"Celebrating 150M Downloads with a new Razor SSG generated Website","image":"https://images.unsplash.com/photo-1475669698648-2f144fcaaeb1?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["razor"," ssg"," website"],"date":"\/Date(1680048000000-0000)\/","url":"https://servicestack.net/posts/new_razor_ssg_website","wordCount":567,"lineCount":77},{"slug":"javascript","draft":false,"title":"Simple, Modern JavaScript","summary":"Learn about JS Modules, Vue 3 and available rich UI Components","image":"https://images.unsplash.com/photo-1497515114629-f71d768fd07c?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["js"," dev"],"date":"\/Date(1675209600000-0000)\/","url":"https://servicestack.net/posts/javascript","wordCount":3118,"lineCount":612},{"slug":"prerendering","draft":false,"title":"Prerendering Razor Pages","summary":"Improving Blog Performance with Prerendering","image":"https://images.unsplash.com/photo-1522526886914-6e8d4fd91399?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["c#"," dev"," markdown"],"date":"\/Date(1673395200000-0000)\/","url":"https://servicestack.net/posts/prerendering","wordCount":1160,"lineCount":235},{"slug":"rider","draft":false,"title":"Develop using JetBrains Rider","summary":"Setting up & exploring development workflow in Rider","image":"https://images.unsplash.com/photo-1472289065668-ce650ac443d2?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["c#"," dev"],"date":"\/Date(1673395200000-0000)\/","url":"https://servicestack.net/posts/rider","wordCount":472,"lineCount":77},{"slug":"vs","draft":false,"title":"Develop using Visual Studio","summary":"Exploring development workflow in VS Code and Visual Studio .NET","image":"https://images.unsplash.com/photo-1513542789411-b6a5d4f31634?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["c#"," dev"],"date":"\/Date(1673308800000-0000)\/","url":"https://servicestack.net/posts/vs","wordCount":1325,"lineCount":76},{"slug":"jamstacks_hosting","draft":false,"title":"Jamstack Hosting Costs @ $.40 /mo","summary":"Exploring cost & scalability benefits of hybrid CDN & .NET Apps","image":"https://images.unsplash.com/photo-1506399309177-3b43e99fead2?crop=entropy&fit=crop&h=1000&w=2000","author":"Demis Bellot","tags":["dev"," hosting"," devops"],"date":"\/Date(1672617600000-0000)\/","url":"https://servicestack.net/posts/jamstacks_hosting","wordCount":3054,"lineCount":83},{"slug":"deploy","draft":false,"title":"Deployment with GitHub Actions","summary":"Configuring your GitHub repo for SSH and CDN deployments","image":"https://images.unsplash.com/photo-1485841890310-6a055c88698a?crop=entropy&fit=crop&h=1000&w=2000","author":"Darren Reid","tags":["github-actions"," devops"," hosting"],"date":"\/Date(1672531200000-0000)\/","url":"https://servicestack.net/posts/deploy","wordCount":724,"lineCount":107},{"slug":"hetzner-cloud","draft":false,"title":"In pursuit of the best value US cloud provider","summary":"We've been using AWS at ServiceStack for 10+ years, it's served us well but suffers from complex & expensive pricing","image":"https://images.unsplash.com/photo-1451187580459-43490279c0fa?crop=entropy&fit=crop&h=1000&w=2000","author":"Darren Reid","tags":["dev"," hosting"," devops"],"date":"\/Date(1662422400000-0000)\/","url":"https://servicestack.net/posts/hetzner-cloud","wordCount":2702,"lineCount":227},{"slug":"typesense","draft":false,"title":"Real-time search with Typesense","summary":"As part of migrating docs to VitePress we've added UX improvements like instant search powered by Typesense!","image":"https://images.unsplash.com/photo-1473163928189-364b2c4e1135?crop=entropy&fit=crop&h=1000&w=2000","author":"Darren Reid","tags":["dev"," docs"],"date":"\/Date(1636329600000-0000)\/","url":"https://servicestack.net/posts/typesense","wordCount":4546,"lineCount":386},{"slug":"jekyll-to-vitepress","draft":false,"title":"Migrating from Jekyll to VitePress","summary":"Since Jekyll support has been officially sunset, we decided to migrate our docs site to VitePress","image":"https://images.unsplash.com/photo-1524668951403-d44b28200ce0?crop=entropy&fit=crop&h=1000&w=2000","author":"Darren Reid","tags":["docs"," markdown"],"date":"\/Date(1635724800000-0000)\/","url":"https://servicestack.net/posts/jekyll-to-vitepress","wordCount":2479,"lineCount":355}]} \ No newline at end of file diff --git a/posts/cloud-value-between-architectures.html b/posts/cloud-value-between-architectures.html index adbc9c74..78e6e1a4 100644 --- a/posts/cloud-value-between-architectures.html +++ b/posts/cloud-value-between-architectures.html @@ -196,7 +196,7 @@

In the ever-competitive landscape of cloud computing, choices abound for software developers seeking to harness the power of various providers and architectures. This blog post presents an insightful analysis comparing three major providers: Hetzner, AWS, and Azure. Focusing on cost efficiency and performance, I've explored different instance types utilizing both ARM and x86 architectures. The benchmarks used for this comparison include the Postgres benchmark (pgbench), a .NET HTTP load test, and Geekbench scores.

- +

Benchmarks and Tools