Criar provedor de aceitação
Este tópico descreve os passos necessários para criar uma aceitação de encomenda no Microsoft Dynamics 365 Intelligent Order Management.
Criar nova definição de provedor
Para criar uma nova definição de provedor, siga estes passos.
- Aceda a Provedores > Catálogo.
- Selecione Nova Definição de Provedor.
- Para o Nome a Apresentar, introduza "IOMLabOrderIntakeProvider".
- Para o Nome Lógico, introduza "msdyn_IOMLabOrderIntakeProvider".
- Para Logótipo, selecione "IOMLab.png".
- Para o Tipo de Serviço, introduza "Aceitação de encomenda".
- Para a Descrição, introduza "Provedor de aceitação de encomenda do IOM Lab".
- Selecione Guardar e fechar.
Adicionar definição de provedor à solução
Para adicionar uma definição de provedor a uma solução, siga estes passos.
- Aceda ao Portal do Power App Maker e navegue até à solução recém-criada IOMLabProviders.
- Selecione Adicionar existente > Definição de Provedor IOM.
- Selecione IOMLabOrderIntakeProvider e, em seguida, selecione Adicionar para o adicionar à solução.
Adicionar transformação à definição de provedor
Para adicionar uma transformação à definição de provedor, siga estes passos.
- Aceda a Provedores > Catálogo.
- Selecione o recém-criado IOMLabOrderIntakeProvider.
- Selecione Editar na barra de menus.
- Selecione o separador Transformações.
- Selecione + Nova Transformação da Definição de Provedor IOM.
- Para o Nome a Apresentar, introduza "Pedido IOMLab para Pedido Dataverse".
- Para o Nome Lógico, introduza "msdyn_IOMLabOrderIntake_Order".
- Para Definição de Provedor, introduza ou selecione IOMLabOrderIntakeProvider.
- Para o Nome do Objeto de Origem, introduza "IOMLabOrderIntakeProvider".
- Para o Nome do Objeto de Destino, introduza "Pedido Dataverse".
- Para Transformação, cole o seguinte código de consulta M:
shared ImportMappingKey = [
account = {
[
ExternalRecordKey = [ProviderName = "IOMLabOrderIntakeProvider"],
SelectedFields = {"accountid"}
]
},
pricelevel = {
[
ExternalRecordKey = [ProviderName = "IOMLabOrderIntakeProvider"],
SelectedFields = {"pricelevelid"}
]
},
product = List.Distinct(List.Transform(Source[orderdetails], each
[
ExternalRecordKey = [sku = _[sku]],
SelectedFields = {"productid"}
])),
uom = List.Distinct(List.Transform(Source[orderdetails], each
[
ExternalRecordKey = [unit = _[unit]],
SelectedFields = {"uomid"}
]))
];
shared TransformSourceData =
let
orderProducts = Source[orderdetails],
account = IOM.MapRecord(IOM.MappingTables[account], [ProviderName = "IOMLabOrderIntakeProvider"]),
pricelevel = IOM.MapRecord(IOM.MappingTables[pricelevel], [ProviderName = "IOMLabOrderIntakeProvider"]),
orderheader = Record.FromTable
(
Table.SelectRows
(
Record.ToTable
(
[
ordernumber = Text.From(Source[ordernumber]),
name = ordernumber,
#"customerid_account@odata.bind" = "/accounts(" & Text.From(account[accountid]) & ")",
#"pricelevelid@odata.bind" = "/pricelevels(" & Text.From(pricelevel[pricelevelid]) & ")",
billto_city = Record.FieldOrDefault(Source, "billtocity"),
billto_stateorprovince = Record.FieldOrDefault(Source, "billtostateorprovince"),
billto_country = Record.FieldOrDefault(Source, "billtocountry"),
billto_postalcode = Record.FieldOrDefault(Source, "billtozip"),
shipto_city = Record.FieldOrDefault(Source, "shiptocity"),
shipto_stateorprovince = Record.FieldOrDefault(Source, "shiptostateorprovince"),
shipto_country = Record.FieldOrDefault(Source, "shiptocountry"),
shipto_postalcode = Record.FieldOrDefault(Source, "shiptozip")
]
), each [Value] <> null
)
),
orderlines = List.Transform(orderProducts, each
Record.FromTable
(
Table.SelectRows
(
Record.ToTable
(
[
ispriceoverridden = true,
#"productid@odata.bind" = "/products(" & IOM.MapRecord(IOM.MappingTables[product], [sku = Record.FieldOrDefault(_, "sku")])[productid] & ")",
#"uomid@odata.bind" = "/uoms(" & IOM.MapRecord(IOM.MappingTables[uom], [unit = Record.FieldOrDefault(_, "unit")])[uomid] & ")",
quantity = [quantity],
shipto_name = Record.FieldOrDefault(orderheader, "shipto_name"),
shipto_contactname = Record.FieldOrDefault(orderheader, "shipto_contactname"),
shipto_line1 = Record.FieldOrDefault(orderheader, "shipto_line1"),
shipto_line2 = Record.FieldOrDefault(orderheader, "shipto_line2"),
shipto_line3 = Record.FieldOrDefault(orderheader, "shipto_line3"),
shipto_city = Record.FieldOrDefault(orderheader, "shipto_city"),
shipto_stateorprovince = Record.FieldOrDefault(orderheader, "shipto_stateorprovince"),
shipto_country = Record.FieldOrDefault(orderheader, "shipto_country"),
shipto_postalcode = Record.FieldOrDefault(orderheader, "shipto_postalcode"),
shipto_telephone = Record.FieldOrDefault(orderheader, "shipto_telephone")
]
), each [Value] <> null
)
)
),
salesorder = Record.AddField(orderheader, "order_details", orderlines)
in Text.FromBinary(Json.FromValue(salesorder));
- Para Tipo de Origem de Transformação, introduza "JsonPayload".
- Selecione Guardar.
- Crie um ficheiro JSON, cole o código seguinte e guarde-o.
{
"ordernumber": "IOMLabOrder001",
"shiptocity": "BELLEVUE",
"shiptostateorprovince": "WA",
"shiptocountry": "US",
"shiptozip": "98007",
"billtocity": "BELLEVUE",
"billtostateorprovince": "WA",
"billtocountry": "US",
"billtozip": "98007",
"orderdetails": [
{
"sku": "883988211855",
"unit": "each",
"quantity": 11
}
]
}
- Ao lado do campo Dados de Amostra, selecione Escolher Ficheiro e carregue o ficheiro JSON que criou.
- Selecione Guardar e fechar.
Adicionar transformação de definição de provedor à solução
Para adicionar uma transformação de definição de provedor a uma solução, siga estes passos.
- Aceda ao Portal do Power App Maker e navegue até à solução recém-criada IOMLabProviders.
- Selecione Adicionar existente > Transformação de Definição de Provedor IOM.
- Selecione Pedido IOMLab para Pedido Dataverse e, em seguida, selecione Adicionar para o adicionar à solução.
Criar processador de mensagens do provedor
Para criar um processador de mensagens do provedor, siga estes passos.
Aceda ao Portal do Power App Maker navegue até Soluções e abra a Solução Predefinida.
Selecione Nova.
Selecione Fluxo de Cloud e nomeie-o de "Processador de Pedidos de Mensagem de Aceitação de Encomendas IOM Lab".
Selecione o tipo de acionador como Outlook.com – Quando um novo e-mail chegar (V2) e, em seguida, inicie sessão com as credenciais da sua conta outlook.com.
Em Pasta, selecione Caixa de Entrada.
Em Para, selecione Endereços de email do destinatário separados por ponto-e-vírgula.
Em CC, selecione Endereços de email do destinatário CC separados por ponto-e-vírgula.
Em Para ou CC, selecione Endereços de email do destinatário Para ou CC separados por ponto-e-vírgula.
Em Para, selecione Endereços de email do remetente separados por ponto-e-vírgula.
Para Incluir Anexos, selecione Sim.
Para Filtro de Assunto, selecione IOMLabOrderIntakeOrder.
Em Importância, selecione Qualquer.
Para Apenas com Anexo, selecione Sim.
Selecione Nova etapa e adicione "Analisar JSON".
Para Conteúdo, cole o seguinte código:
{ "ProviderId": "00000000-0000-0000-0000-000000000000" }
Cole diretamente no seguinte código de esquema de amostra:
{ "type": "object", "properties": { "ProviderId": { "type": "string" } } }
Selecione Concluído.
Selecione as reticências (...) e, em seguida, selecione Mudar o Nome.
Mude o nome da ação "Propriedades de Sistema IOM".
Selecione Guardar.
Selecione Nova etapa, adicione uma ação Analisar JSON e mude o nome para "Inicializar Variáveis do Provedor".
Para Conteúdo, cole o seguinte código:
{ "SourceObjectName": "IOMLabOrderIntakeProvider", "DestinationObjectName": "Dataverse Order" }
Selecione Guardar.
Selecione Nova etapa, adicione uma ação Inicializar variável e mude o nome para "Inicializar Resultado de Execução de Processamento".
Para o Nome, introduza "ExecutionResult".
Para o Tipo, selecione Booleano.
Para Valor, selecione verdadeiro.
Selecione Guardar.
Selecione Nova etapa, adicione "âmbito" e mude o nome para "Tentativa".
No âmbito Tentativa, selecione Adicionar uma opção.
Adicione "executar uma ação não vinculada" do conector Dataverse e mude o seu nome para "Reconhecer a Mensagem do Provedor no IOM".
Para o Nome da Ação, introduza "msdyn_CreateProviderMessageRequestExecution".
Para PowerAutomateWorkflowId, introduza
workflow()['tags']['xrmWorkflowId']
como uma expressão.Para PowerAutomateRunId, introduza
workflow()['run']?['name']
como uma expressão.Para ProviderExternalRequestId, introduza
guid()
como uma expressão.Selecione Guardar.
Selecione Adicionar uma ação e, em seguida, adicione um controlo Aplicar a cada.
Para Selecionar uma saída de etapas anteriores, selecione Anexos.
Selecione Adicionar uma ação dentro do ciclo Aplicar a cada, adicione Executar um fluxo subordinado a partir do conector Fluxo e mude o nome para "Transformar Mensagem com Power Query Online".
Selecione o fluxo subordinado Transformador do Provedor IOM.
Para ID de Provedor, selecione uma ProviderId .
Para Nome do Objeto de Origem, selecione a variável SourceObjectName .
Para Nome do Objeto de Destino, selecione a variável DestinationObjectName .
Para Payload, introduza
decodeBase64(items('Apply_to_each')?['ContentBytes'])
como uma expressão.Selecione Guardar.
Após a etapa de transformação, selecione Adicionar uma ação, adicione Executar um fluxo subordinado do conector Fluxo e mude-lhe o nome para "Criar Ordem".
Para Fluxo Subordinado, introduza "Criação de Ordem de Venda IOM".
Para Payload, introduza
string(json(outputs('Transform_Message_with_Power_Query_Online')?['Body']?['result'])?[0][0])
como uma expressão.Selecione Guardar.
Feche o âmbito Tentativa ao selecionar a sua barra de título.
Selecione Nova etapa e adicione um âmbito chamado "Captura".
No âmbito Captura, selecione as reticências ("...") e, em seguida, selecione Configurar executar após.
Selecione as caixas de verificação falhou e excedeu o limite de tempo e, em seguida, selecione Concluído.
No âmbito Captura, selecione Adicionar uma ação, adicione uma ação Definir variável e volte a nomeá-la como "Definir o resultado da execução como falha".
Para o Nome, introduza "Executioresult".
Para Valor, selecione Falso.
Selecione Guardar.
Feche o âmbito Captura ao selecionar a sua barra de título.
Selecione Nova etapa e adicione um âmbito chamado "Finalmente".
No âmbito Finalmente, selecione as reticências ("...") e, em seguida, selecione Configurar executar após.
Selecione as caixas de verificação com sucesso, falhou, foi ignorado e excedeu o limite de tempo e, em seguida, selecione Concluído.
No escopo Finalmente, selecione Adicionar uma ação, adicione uma ação Executar uma ação não vinculada e mude o nome para "Guardar resultado de execução de pedido de mensagem do provedor".
Para o Nome da Ação, introduza "msdyn_UpdateProviderMessageRequestStatus".
Para ProviderMessageRequestExecutionId, introduzir
@outputs('Acknowledge_the_Provider_Message_in_IOM')?["body/ProviderMessageRequestExecutionId']
.Selecione Guardar.
Adicionar definição lógica da definição de provedor à definição de provedor
Para adicionar uma definição lógica de definição de provedor à definição de provedor, siga estes passos.
- Na sua aplicação Intelligent Order Management, aceda a Provedores > Catálogo.
- Selecione o recém-criado IOMLabOrderIntakeProvider.
- Selecione Editar na barra de menus.
- Selecione o separador Definições lógicas.
- Selecione + Nova Definição Lógica de Definição de Provedor do IOM.
- Para Nome a Apresentar, introduza "Processador de Pedidos de Mensagem de Aceitação de Encomenda do IOM Lab".
- Para o Nome Lógico, introduza "msdyn_LabOrderIntakeMessageRequestHandler".
- Para Definição de Provedor, introduza o"IOMLabOrderIntakeProvider".
- Para Tipo de Lógica, digite "Fornecer Processador de Mensagens".
- Para Nome do Workflow, introduza "Processador de Pedidos de Mensagem de Aceitação de Encomenda do IOM Lab".
- Para os Minutos de Limite de Tempo, introduza "2".
- Para Número Máximo de Tentativas, introduza "3".
- Para Descrição, introduza "Processador de Pedidos de Mensagem de Aceitação de Encomenda do IOM Lab".
- Selecione Guardar. Isto gera uma representação JSON do fluxo de cloud do processador de mensagens e preenche o campo Dados do Cliente .
- Selecione Guardar e fechar.
- Selecione Ligações. Deve ver ambas as definições de referência de ligação do Microsoft Dataverse e do Outlook.com listadas.
Nota
Se encontrar definições de referência de ligações diferentes de Microsoft Dataverse e Outlook.com, isto significa que está a usar mais do que uma referência de ligação do Dataverse no seu fluxo de processador de mensagens de aceitação de encomendas. Para corrigir isto, aceda ao seu fluxo e verifique se todas as ações do Dataverse estão a usar a mesma referência de ligação.
Adicionar definição lógica de definição de provedor à solução IOMLabProviders
Para adicionar uma definição lógica de definição de provedor à solução IOMLabProviders, siga estes passos.
- Aceda ao Portal do Power App Maker e navegue até à solução recém-criada IOMLabProviders.
- Selecione Adicionar existente > Definição de Lógica de Definição de Provedor do IOM.
- Selecione Processador do Pedido de Mensagens de Aceitação de Encomenda do IOM Lab e, em seguida, selecione Adicionar para o adicionar à solução.
Adicionar referência de ligação da definição de provedor à solução IOMLabProviders
Para adicionar uma referência de ligação de definição de provedor à solução IOMLabProviders, siga estes passos.
- Aceda ao Portal do Power App Maker e navegue até à solução recém-criada IOMLabProviders.
- Selecione Adicionar existente > Referência de Ligação de Definição de Provedor do IOM.
- Selecione as definições de referência de ligação do Microsoft Dataverse e do Outlook.com e , em seguida, selecione Adicionar para as adicionar à solução.
Próxima etapa de laboratório de início rápido: Criar provedor de cumprimento