cdcd486a0a
MeteredTriggerJob failing due to Unhandled exception |
||
---|---|---|
.github | ||
deployment | ||
docs | ||
src | ||
.gitignore | ||
CODE_OF_CONDUCT.md | ||
LICENSE | ||
README.md | ||
SECURITY.md | ||
global.json |
README.md
The SaaS Accelerator is offered under the MIT License as open source software and is <ins>not supported</ins> by Microsoft. If you need help with the accelerator or would like to report defects or feature requests, use the Issues feature on this GitHub repository.
Microsoft Commercial Marketplace - Community Code for SaaS Applications
- Introduction
- Intended Use
- Installation
- Commercial Marketplace Documentation
- SaaS Accelerator Overview
- Projects
- Technology and Versions
- Security
- Prerequisites
- Contributing
- Developers
- FAQs
- License
📝 Please leave us your ideas and feedback on the SaaS Accelerator in this brief, anonymous survey.
Introduction
The SaaS Accelerator is a production-ready solution designed to make it easier for Microsoft partners to sell their SaaS solutions via Microsoft Commercial Marketplace. Microsoft partners can use SaaS Accelerator to simplify the process of bringing their SaaS solutions to the Marketplace. It is a ready-to-use, community-supported solution providing the following capabilities:
🚀 Quick & Easy Deployment: Go live in under 15 minutes with our low-code, production-ready solution.
🔧 Turnkey Solution: Meets all technical prerequisites for your SaaS offers.
💼 Subscriptions Simplified: A streamlined interface to optimize your subscription workflow.
💲 Flexible Billing: Advanced capabilities for custom billing and pricing models.
🛠️ Stay in Control: A dedicated adminstrative portal for managing all your customer subscriptions.
Transform your SaaS game. Leverage SaaS Accelerator now!
Description
The project is implemented in .NET and uses the commercial marketplace billing system, including the SaaS Fulfillment API (v2) and Marketplace Metering Service API. The SaaS Accelerator models how a typical SaaS platform interacts with the marketplace APIs to provision subscriptions for customers, enable logging, and manage commercial marketplace subscriptions. The SaaS Accelerator may be installed as-is or may be customized to support your requirements.
Stay current with the latest updates!
The SaaS Accelerator project team releases regularly releases new versions. Please see the release notes page for updates. We recommend keeping up to date with latest releases to stay current on security patches, bug fixes, and new features.
To update your SaaS Accelerator installation, use the Update script documented here.
Intended Use
This code is a reference implementation of required components of a commercial marketplace SaaS offer and complements the existing commercial marketplace documentation.
This project accelerates the SaaS offer onboarding experience for those building SaaS solutions for the Microsoft commercial marketplace. Whether installed and used as-is or customized for your particular requirements, this reference implementation provides all main components required by a commercial marketplace SaaS offer.
NOTE: Support for this project is community-based and contributions are welcome. Details on contributing can be found below.. This is not an officially supported Microsoft product.
Installation
Installation instructions are here, as well as documents detailing architecture and scaled installation considerations are also available. Following these instructions will typically have the SaaS Accelerator installed in 20 minutes or less.
Advanced Installation instructions are here. These are detailed instructions to address different deployment scenarios such as how-to run it locally or deploy it from Visual Studio.
Video instructions Additionally, there is a quick video on the installation process. Installing the SaaS Accelerator with the Azure portal cloud shell available through Mastering the Marketplace.
Upgrade to newer version Follow these instructions to move your release to the current version.
Additional technical documents
- Enterprise reference architectures
- Single region architectures
- Multi-region architectures
- Advanced installation checklist
Monitoring
The following documents provide how-tos for setting up Azure Monitoring and Alerting for the resources deployed by the SaaS Accelerator:
- Web App Monitoring and Alerting instructions
- SQL Server Monitoring and Alerting instructions
- App Registration Credentials Monitoring and Alerting instructions
Commercial Marketplace Documentation
Before using this project, please review the commercial marketplace documentation resources below to understand the important concepts, account setup, and offer configuration requirements for publishing SaaS SaaS application offers.
- Mastering the Marketplace - SaaS Offers. Zero-to-Hero Training on Azure Marketplace SaaS offers using the Accelerator.
- Commercial marketplace documentation. Getting started and top articles
- SaaS applications in the commercial marketplace. Overview of the SaaS application business policies, plus step-by step offer creation and configuration requirements.
- SaaS fulfillment API (v2). API details for SaaS application subscription creation and management.
- Marketplace metering service API. API details for the Marketplace Metering Service which, when used in conjunction with the SaaS Fulfillment API, enables event-based billing.
- SaaS fulfillment API FAQ. Frequently asked questions about the SaaS Fulfillment APIs.
SaaS Accelerator Overview
Projects
The source /src
directory contains the following Visual Studio projects.
Project | Description | Directory Name |
---|---|---|
Customer portal - Sample web application | Demonstrates how to register, provision, and activate the marketplace subscription. Implemented using ASP.Net Core 8.0, the sample web application uses the Services client library and data access library to invoke and persist API interactions and provides an example user interface to demonstrate how a customer would manage their subscriptions and plans. | CustomerSite |
Publisher portal - Sample web application | Demonstrates how to generate usage events used in metered billing transactions, and how to emit these events to the Marketplace Metering Service API. | AdminSite |
Client data access library | Demonstrates how to persist plans, marketplace subscriptions, and related transaction attributes when using the SaaS Fulfillment API (v2) and Marketplace Metering Service API. | DataAccess |
Services client library | Contains the services used by the Customer and Publisher portals, including the POCO classes to orchestrate calls to the marketplace APIs on client library / database. | Services |
Unit tests project | Helps validate and test the codebase. | ServicesTest |
The sample code in this repository runs in the publisher's environment as illustrated below. The metering SDK (.NET class library) and a sample web application to report usage events for subscriptions against those plans that support metering (have the dimensions defined and enabled) and correlate to SaaS Metering and SaaS Service blocks in the below image, respectively.
Technology and Versions
This project has been developed using the following technologies and versions:
Security
The accelerator code has been scanned for vulnerabilities and use secure configurations. Versions have been reviewed to ensure compatibility with the latest security guidelines. To enhance the best practices please see Security best practices.
Prerequisites
Ensure the following prerequisites are met before getting started:
- You must have an active Azure subscription for development and testing purposes. Create an Azure subscription here.
- You must have a Partner Center account enabled for use with the commercial marketplace. Create an account here.
- We recommend using an Integrated Development Environment (IDE): Visual Studio Code, Visual Studio 2019 / 2022, etc...
- The SaaS Accelerator has been implemented using .NET 8
- For data persistence we are using Azure SQL Database and Entity Framework. However, feel free to use any data repository you are comfortable with.
Contributing
This project welcomes contributions and suggestions. Most contributions require you to agree to a Contributor License Agreement (CLA) declaring that you have the right to, and actually do, grant us the rights to use your contribution. For details, visit https://cla.opensource.microsoft.com.
When you submit a pull request, a CLA bot will automatically determine whether you need to provide a CLA and decorate the PR appropriately (e.g., status check, comment). Simply follow the instructions provided by the bot. You will only need to do this once across all repos using our CLA.
This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact opencode@microsoft.com with any additional questions or comments.
Developers
Code contributed should follow the C# specifications and best practices as documented here.
FAQs
There is a list of the Frequent Asked Questions here.
License
This project is released under the MIT License.