DeviceUpdateClient.StartImportUpdateAsync Método
Definição
Importante
Algumas informações se referem a produtos de pré-lançamento que podem ser substancialmente modificados antes do lançamento. A Microsoft não oferece garantias, expressas ou implícitas, das informações aqui fornecidas.
Importar nova versão de atualização. Essa é uma operação de execução prolongada; use Operation-Location valor do cabeçalho de resposta para marcar para status de operação.
public virtual System.Threading.Tasks.Task<Azure.Operation> StartImportUpdateAsync (Azure.WaitUntil waitUntil, Azure.Core.RequestContent content, Azure.RequestContext context = default);
abstract member StartImportUpdateAsync : Azure.WaitUntil * Azure.Core.RequestContent * Azure.RequestContext -> System.Threading.Tasks.Task<Azure.Operation>
override this.StartImportUpdateAsync : Azure.WaitUntil * Azure.Core.RequestContent * Azure.RequestContext -> System.Threading.Tasks.Task<Azure.Operation>
Public Overridable Function StartImportUpdateAsync (waitUntil As WaitUntil, content As RequestContent, Optional context As RequestContext = Nothing) As Task(Of Operation)
Parâmetros
- waitUntil
- WaitUntil
Completed se o método deve aguardar para retornar até que a operação de execução prolongada seja concluída no serviço; Started se ele deve retornar depois de iniciar a operação. Para obter mais informações sobre operações de execução prolongada, consulte Exemplos de operação de Long-Running do Azure.Core.
- content
- RequestContent
O conteúdo a ser enviado como o corpo da solicitação. Os detalhes do esquema do corpo da solicitação estão na seção Comentários abaixo.
- context
- RequestContext
O contexto de solicitação, que pode substituir os comportamentos padrão do pipeline do cliente por chamada.
Retornos
O Operation que representa uma operação assíncrona no serviço.
Exceções
content
é nulo.
O serviço retornou um código de status sem êxito.
Exemplos
Este exemplo mostra como chamar StartImportUpdateAsync com os parâmetros necessários e o conteúdo da solicitação.
var credential = new DefaultAzureCredential();
var endpoint = new Uri("<https://my-service.azure.com>");
var client = new DeviceUpdateClient(endpoint, "<instanceId>", credential);
var data = new[] {
new {
importManifest = new {
url = "<url>",
sizeInBytes = 1234L,
hashes = new {
key = "<String>",
},
},
friendlyName = "<friendlyName>",
files = new[] {
new {
filename = "<filename>",
url = "<url>",
}
},
}
};
var operation = await client.StartImportUpdateAsync(WaitUntil.Completed, RequestContent.Create(data));
var response = await operation.WaitForCompletionResponseAsync();
Console.WriteLine(response.Status)
Comentários
Abaixo está o esquema JSON para o conteúdo da solicitação.
Corpo da solicitação:
Esquema para ImportUpdateInputItem
:
{
importManifest: {
url: string, # Required. Azure Blob location from which the import manifest can be downloaded by Device Update for IoT Hub. This is typically a read-only SAS-protected blob URL with an expiration set to at least 4 hours.
sizeInBytes: number, # Required. File size in number of bytes.
hashes: Dictionary<string, string>, # Required. A JSON object containing the hash(es) of the file. At least SHA256 hash is required. This object can be thought of as a set of key-value pairs where the key is the hash algorithm, and the value is the hash of the file calculated using that algorithm.
}, # Required. Import manifest metadata like source URL, file size/hashes, etc.
friendlyName: string, # Optional. Friendly update name.
files: [
{
filename: string, # Required. Update file name as specified inside import manifest.
url: string, # Required. Azure Blob location from which the update file can be downloaded by Device Update for IoT Hub. This is typically a read-only SAS-protected blob URL with an expiration set to at least 4 hours.
}
], # Optional. One or more update file properties like filename and source URL.
}
Aplica-se a
Azure SDK for .NET