mirror of
https://github.com/ckaczor/azuredatastudio.git
synced 2026-02-16 10:58:30 -05:00
Added a dynamic Cost Summary section to SQL MIAA Deployment Wizard (#17420)
* Added valueprovider for pricing. Pushing this for troubleshooting help. * Committing changes for troubleshooting help. Moved InputValueType to typings file. * Add readonly inputs to list * Fixed ordering of package.json merge items * Estimated cost moved to input page, ValueProvider only takes in a triggerfields[] and not a single string, fixed pricing logic. * Removed pricingModel.ts * Reverted some comments and code changes that were used in debugging. * Changed some values from localizedConstants to single-quote constants' * Changed some values from localizedConstants to single-quote constants' * Added copyright header to pricingUtils.ts * Removed try catch in extension.ts valueproviders, made some values in PricingUtils.ts top-level instead of exporting. * Minor changes, added some comments and localized USD. * Changes pricingutils classes to be constants, and added disposable to Hookupvalueprovider Co-authored-by: Candice Ye <canye@microsoft.com> Co-authored-by: chgagnon <chgagnon@microsoft.com>
This commit is contained in:
117
extensions/arc/src/common/pricingUtils.ts
Normal file
117
extensions/arc/src/common/pricingUtils.ts
Normal file
@@ -0,0 +1,117 @@
|
||||
/*---------------------------------------------------------------------------------------------
|
||||
* Copyright (c) Microsoft Corporation. All rights reserved.
|
||||
* Licensed under the Source EULA. See License.txt in the project root for license information.
|
||||
*--------------------------------------------------------------------------------------------*/
|
||||
|
||||
import { InputValueType } from 'resource-deployment';
|
||||
import * as loc from '../localizedConstants';
|
||||
|
||||
export const SqlManagedInstanceGeneralPurpose = {
|
||||
tierName: loc.generalPurposeLabel,
|
||||
basePricePerCore: 80,
|
||||
licenseIncludedPricePerCore: 153,
|
||||
maxMemorySize: 128,
|
||||
maxVCores: 24,
|
||||
|
||||
replicaOptions: [
|
||||
{
|
||||
text: loc.replicaOne,
|
||||
value: 1,
|
||||
}
|
||||
],
|
||||
|
||||
defaultReplicaValue: 1
|
||||
};
|
||||
|
||||
const SqlManagedInstanceBusinessCritical = {
|
||||
tierName: loc.businessCriticalLabel,
|
||||
|
||||
// Set to real values when BC is ready
|
||||
basePricePerCore: 0,
|
||||
licenseIncludedPricePerCore: 0,
|
||||
|
||||
replicaOptions: [
|
||||
{
|
||||
text: loc.replicaTwo,
|
||||
value: 2,
|
||||
},
|
||||
{
|
||||
text: loc.replicaThree,
|
||||
value: 3,
|
||||
}
|
||||
],
|
||||
|
||||
defaultReplicaValue: 3
|
||||
};
|
||||
|
||||
export const SqlManagedInstancePricingLink: string = 'https://aka.ms/ArcSQLBilling';
|
||||
|
||||
export const serviceTierVarName = 'AZDATA_NB_VAR_SQL_SERVICE_TIER';
|
||||
export const devUseVarName = 'AZDATA_NB_VAR_SQL_DEV_USE';
|
||||
export const vcoresLimitVarName = 'AZDATA_NB_VAR_SQL_CORES_LIMIT';
|
||||
export const licenseTypeVarName = 'AZDATA_NB_VAR_SQL_LICENSE_TYPE';
|
||||
|
||||
// Estimated base price for one vCore.
|
||||
export function estimatedBasePriceForOneVCore(mapping: { [key: string]: InputValueType }): number {
|
||||
let price = 0;
|
||||
if (mapping[devUseVarName] === 'true') {
|
||||
price = 0;
|
||||
} else if (mapping[devUseVarName] === 'false') {
|
||||
if (mapping[serviceTierVarName] === SqlManagedInstanceGeneralPurpose.tierName) {
|
||||
price = SqlManagedInstanceGeneralPurpose.basePricePerCore;
|
||||
} else if (mapping[serviceTierVarName] === SqlManagedInstanceBusinessCritical.tierName) {
|
||||
price = SqlManagedInstanceBusinessCritical.basePricePerCore;
|
||||
}
|
||||
}
|
||||
return price;
|
||||
}
|
||||
|
||||
// Estimated SQL server license price for one vCore.
|
||||
export function estimatedSqlServerLicensePriceForOneVCore(mapping: { [key: string]: InputValueType }): number {
|
||||
let price = 0;
|
||||
if (mapping[devUseVarName] === 'true') {
|
||||
price = 0;
|
||||
} else if (mapping[devUseVarName] === 'false') {
|
||||
if (mapping[serviceTierVarName] === SqlManagedInstanceGeneralPurpose.tierName) {
|
||||
price = SqlManagedInstanceGeneralPurpose.licenseIncludedPricePerCore - SqlManagedInstanceGeneralPurpose.basePricePerCore;
|
||||
} else if (mapping[serviceTierVarName] === SqlManagedInstanceBusinessCritical.tierName) {
|
||||
price = SqlManagedInstanceBusinessCritical.licenseIncludedPricePerCore - SqlManagedInstanceBusinessCritical.basePricePerCore;
|
||||
}
|
||||
}
|
||||
return price;
|
||||
}
|
||||
|
||||
// Full price for one vCore. This is shown on the cost summary card.
|
||||
export function fullPriceForOneVCore(mapping: { [key: string]: InputValueType }): number {
|
||||
return estimatedBasePriceForOneVCore(mapping) + estimatedSqlServerLicensePriceForOneVCore(mapping);
|
||||
}
|
||||
|
||||
// Gets number of vCores limit specified
|
||||
export function numCores(mapping: { [key: string]: InputValueType }): number {
|
||||
return mapping[vcoresLimitVarName] ? <number>mapping[vcoresLimitVarName] : 0;
|
||||
}
|
||||
|
||||
// Full price for all selected vCores.
|
||||
export function vCoreFullPriceForAllCores(mapping: { [key: string]: InputValueType }): number {
|
||||
return fullPriceForOneVCore(mapping) * numCores(mapping);
|
||||
}
|
||||
|
||||
// SQL Server License price for all vCores. This is shown on the cost summary card if customer has SQL server license.
|
||||
export function vCoreSqlServerLicensePriceForAllCores(mapping: { [key: string]: InputValueType }): number {
|
||||
return estimatedSqlServerLicensePriceForOneVCore(mapping) * numCores(mapping);
|
||||
}
|
||||
|
||||
// If the customer doesn't already have SQL Server License, AHB discount is set to zero because the price will be included
|
||||
// in the total cost. If they already have it (they checked the box), then a discount will be applied.
|
||||
export function azureHybridBenefitDiscount(mapping: { [key: string]: InputValueType }): number {
|
||||
if (mapping[licenseTypeVarName] === 'true') {
|
||||
return vCoreSqlServerLicensePriceForAllCores(mapping);
|
||||
} else {
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
|
||||
// Total price that will be charged to a customer. Is shown on the cost summary card.
|
||||
export function total(mapping: { [key: string]: InputValueType }): number {
|
||||
return vCoreFullPriceForAllCores(mapping) - azureHybridBenefitDiscount(mapping);
|
||||
}
|
||||
Reference in New Issue
Block a user