private bool Create_VM_Opportunity_AsOnPrem_Model()

in src/Assessment/Processor/ProcessDatasets.cs [2140:2212]


        private bool Create_VM_Opportunity_AsOnPrem_Model(List<VM_Opportunity_AsOnPrem> VM_Opportunity_AsOnPrem_List, HashSet<string> AzureVM_Opportunity_AsOnPrem)
        {
            if (AzureVMAsOnPremMachinesData == null)
            {
                UserInputObj.LoggerObj.LogWarning("Not creating excel model for VM_Opportunity_AsOnPrem as Azure VM AsOnPrem dataset is null");
                return false;
            }
            if (AzureVMAsOnPremMachinesData.Count <= 0)
            {
                UserInputObj.LoggerObj.LogWarning("Not creating excel model for VM_Opportunity_AsOnPrem as Azure VM AsOnPrem dataset is empty");
                return false;
            }

            UserInputObj.LoggerObj.LogInformation("Creating excel model for VM_Opportunity_AsOnPrem");

            if (VM_Opportunity_AsOnPrem_List == null)
                VM_Opportunity_AsOnPrem_List = new List<VM_Opportunity_AsOnPrem>();
            
            foreach (var discoveredMachineId in AzureVM_Opportunity_AsOnPrem)
            {
                if (!AzureVMAsOnPremMachinesData.ContainsKey(discoveredMachineId))
                {
                    UserInputObj.LoggerObj.LogWarning($"Discovered Machine ID: {discoveredMachineId} does not exist in Azure VM AsOnPrem dataset, skipping");
                    continue;
                }

                var value = AzureVMAsOnPremMachinesData[discoveredMachineId];

                VM_Opportunity_AsOnPrem obj = new VM_Opportunity_AsOnPrem();

                obj.MachineName = value.DisplayName;
                obj.Environment = value.Environment;
                obj.AzureVMReadiness = new EnumDescriptionHelper().GetEnumDescription(value.Suitability);
                obj.RecommendedVMSize = value.RecommendedVMSize;
                obj.MonthlyComputeCostEstimate = value.MonthlyComputeCostEstimate;
                obj.MonthlyStorageCostEstimate = value.StorageMonthlyCost;
                obj.MonthlySecurityCostEstimate = value.MonthlySecurityCost;
                obj.OperatingSystem = UtilityFunctions.GetStringValue(value.OperatingSystem);
                obj.SupportStatus = value.SupportStatus;
                obj.VMHost = UtilityFunctions.GetStringValue(value.DatacenterManagementServerName);
                obj.BootType = UtilityFunctions.GetStringValue(value.BootType);
                obj.Cores = value.NumberOfCores;
                obj.MemoryInMB = value.MegabytesOfMemory;
                obj.StorageInGB = UtilityFunctions.GetTotalStorage(value.Disks);
                obj.NetworkAdapters = value.NetworkAdapters;

                var macIpKvp = UtilityFunctions.ParseMacIpAddress(value.NetworkAdapterList);
                obj.MacAddresses = macIpKvp.Key;
                obj.IpAddresses = macIpKvp.Value;

                obj.DiskNames = UtilityFunctions.GetDiskNames(value.Disks);
                obj.AzureDiskReadiness = UtilityFunctions.GetDiskReadiness(value.Disks);
                obj.RecommendedDiskSKUs = UtilityFunctions.GetRecommendedDiskSKUs(value.Disks);

                obj.StandardHddDisks = UtilityFunctions.GetDiskTypeCount(value.Disks, RecommendedDiskTypes.Standard);
                obj.StandardSsdDisks = UtilityFunctions.GetDiskTypeCount(value.Disks, RecommendedDiskTypes.StandardSSD);
                obj.PremiumDisks = UtilityFunctions.GetDiskTypeCount(value.Disks, RecommendedDiskTypes.Premium);
                obj.UltraDisks = UtilityFunctions.GetDiskTypeCount(value.Disks, RecommendedDiskTypes.Ultra);

                obj.MonthlyStorageCostForStandardHddDisks = UtilityFunctions.GetDiskTypeStorageCost(value.Disks, RecommendedDiskTypes.Standard);
                obj.MonthlyStorageCostForStandardSsdDisks = UtilityFunctions.GetDiskTypeStorageCost(value.Disks, RecommendedDiskTypes.StandardSSD);
                obj.MonthlyStorageCostForPremiumDisks = UtilityFunctions.GetDiskTypeStorageCost(value.Disks, RecommendedDiskTypes.Premium);
                obj.MonthlyStorageCostForUltraDisks = UtilityFunctions.GetDiskTypeStorageCost(value.Disks, RecommendedDiskTypes.Ultra);

                obj.GroupName = value.GroupName;
                obj.MachineId = value.DatacenterMachineArmId;

                VM_Opportunity_AsOnPrem_List.Add(obj);
            }

            UserInputObj.LoggerObj.LogInformation($"Updated VM_Opportunity_AsOnPrem excel model with data of {VM_Opportunity_AsOnPrem_List.Count} machines");
            return true;
        }