internal static GuestAgentData DeserializeGuestAgentData(JsonElement element) { ResourceIdentifier id = default; string name = default; ResourceType type = default; SystemData systemData = default; Optional <string> uuid = default; Optional <GuestCredential> credentials = default; Optional <HttpProxyConfiguration> httpProxyConfig = default; Optional <ProvisioningAction> provisioningAction = default; Optional <string> status = default; Optional <string> customResourceName = default; Optional <IReadOnlyList <ResourceStatus> > statuses = default; Optional <string> provisioningState = default; foreach (var property in element.EnumerateObject()) { if (property.NameEquals("id")) { id = new ResourceIdentifier(property.Value.GetString()); continue; } if (property.NameEquals("name")) { name = property.Value.GetString(); continue; } if (property.NameEquals("type")) { type = new ResourceType(property.Value.GetString()); continue; } if (property.NameEquals("systemData")) { systemData = JsonSerializer.Deserialize <SystemData>(property.Value.ToString()); continue; } if (property.NameEquals("properties")) { if (property.Value.ValueKind == JsonValueKind.Null) { property.ThrowNonNullablePropertyIsNull(); continue; } foreach (var property0 in property.Value.EnumerateObject()) { if (property0.NameEquals("uuid")) { uuid = property0.Value.GetString(); continue; } if (property0.NameEquals("credentials")) { if (property0.Value.ValueKind == JsonValueKind.Null) { property0.ThrowNonNullablePropertyIsNull(); continue; } credentials = GuestCredential.DeserializeGuestCredential(property0.Value); continue; } if (property0.NameEquals("httpProxyConfig")) { if (property0.Value.ValueKind == JsonValueKind.Null) { property0.ThrowNonNullablePropertyIsNull(); continue; } httpProxyConfig = HttpProxyConfiguration.DeserializeHttpProxyConfiguration(property0.Value); continue; } if (property0.NameEquals("provisioningAction")) { if (property0.Value.ValueKind == JsonValueKind.Null) { property0.ThrowNonNullablePropertyIsNull(); continue; } provisioningAction = new ProvisioningAction(property0.Value.GetString()); continue; } if (property0.NameEquals("status")) { status = property0.Value.GetString(); continue; } if (property0.NameEquals("customResourceName")) { customResourceName = property0.Value.GetString(); continue; } if (property0.NameEquals("statuses")) { if (property0.Value.ValueKind == JsonValueKind.Null) { property0.ThrowNonNullablePropertyIsNull(); continue; } List <ResourceStatus> array = new List <ResourceStatus>(); foreach (var item in property0.Value.EnumerateArray()) { array.Add(ResourceStatus.DeserializeResourceStatus(item)); } statuses = array; continue; } if (property0.NameEquals("provisioningState")) { provisioningState = property0.Value.GetString(); continue; } } continue; } } return(new GuestAgentData(id, name, type, systemData, uuid.Value, credentials.Value, httpProxyConfig.Value, Optional.ToNullable(provisioningAction), status.Value, customResourceName.Value, Optional.ToList(statuses), provisioningState.Value)); }
/// <summary> /// Update server provisioning status. /// </summary> /// <param name="serverIngressChanged"> /// A <see cref="ServerStatusChanged"/> message describing the change. /// </param> /// <returns> /// A <see cref="Task"/> representing the operation. /// </returns> async Task UpdateServerProvisioningStatus(ServerStatusChanged serverProvisioningNotification) { if (serverProvisioningNotification == null) { throw new ArgumentNullException(nameof(serverProvisioningNotification)); } Log.Debug("Updating provisioning status for server {ServerId} due to {NotificationType} notification...", serverProvisioningNotification.ServerId, serverProvisioningNotification.GetType().Name ); using (IAsyncDocumentSession session = DocumentStore.OpenAsyncSession()) { DatabaseServer server = await session.LoadAsync <DatabaseServer>(serverProvisioningNotification.ServerId); if (server == null) { Log.Warning("Received ServerStatusChanged notification for non-existent server (Id:{ServerId}).", serverProvisioningNotification.ServerId ); return; } Log.Debug("Existing provisioning status for server {ServerId} is {Action}:{Status}:{Phase}.", server.Id, server.Action, server.Status, server.Phase ); ProvisioningAction action = server.Action; if (serverProvisioningNotification.Status.HasValue) { server.Status = serverProvisioningNotification.Status.Value; switch (server.Status) { case ProvisioningStatus.Ready: case ProvisioningStatus.Error: { server.Action = ProvisioningAction.None; server.Phase = ServerProvisioningPhase.None; break; } case ProvisioningStatus.Deprovisioned: { session.Delete(server); break; } } } if (serverProvisioningNotification.Phase.HasValue) { server.Phase = serverProvisioningNotification.Phase.Value; } Log.Debug("New provisioning status for server {ServerId} is {Action}:{Status}:{Phase}.", server.Id, server.Action, server.Status, server.Phase ); server.AddProvisioningEvent(serverProvisioningNotification.Messages); await session.SaveChangesAsync(); } Log.Debug("Updated provisioning status for server {ServerId}.", serverProvisioningNotification.ServerId); }