Compartir vía


Usar API de programación de proyectos V2 con Power Automate

Se aplica a: Project Operations para escenarios basados en recursos/no mantenidos, implementación lite: del acuerdo a la factura proforma

Este artículo describe un flujo de ejemplo que muestra cómo crear un plan de proyecto completo usando Microsoft Power Automate, cómo crear un conjunto de operaciones y cómo actualizar una entidad. El ejemplo muestra cómo crear un proyecto, un miembro del equipo del proyecto, conjuntos de operaciones, tareas del proyecto y asignaciones de recursos. Este artículo también explica cómo actualizar una entidad y ejecutar un conjunto de operaciones.

El ejemplo de este artículo utiliza la API PssCreateV2. Para ver un ejemplo que utiliza la API PssCreateV1, consulte Usar API de programación de proyectos V1 con Power Automate.

La siguiente es una lista completa de los pasos que están documentados en el flujo de muestra en este artículo:

  1. Crear un desencadenador de PowerApps
  2. Crear un proyecto
  3. Inicializar una variable para el miembro del equipo
  4. Crear un miembro del equipo genérico
  5. Crear un conjunto de opciones
  6. Crear un cubo de proyecto
  7. Inicializar una variable para el número de tareas
  8. Inicializar una variable para el id. de tarea de proyecto
  9. Inicializar una matriz
  10. Hacer hasta
  11. Establecer una tarea de proyecto
  12. Agregar una tarea a la matriz
  13. Crear una asignación de recurso
  14. Decrementar una variable
  15. Agregar tareas y asignaciones al conjunto de operaciones
  16. Ejecutar un conjunto de opciones

Supuestos

Este artículo asume que tiene un conocimiento básico de la plataforma de Dataverse, flujos en la nube y la API de la programación del proyecto. Para obtener más información, consulte la sección Referencias más adelante en este artículo.

Creación de un flujo

Seleccionar un entorno

Puede crear el flujo de Power Automate en su entorno.

  1. Vaya a https://flow.microsoft.com e inicie sesión con sus credenciales de administrador.
  2. En la esquina superior derecha, seleccione Entornos .
  3. En la lista, seleccione el entorno donde esté instalado Dynamics 365 Project Operations.

Crear una solución

Siga estos pasos para crear un flujo compatible con la solución. Al crear un flujo compatible con la solución, puede exportar más fácilmente el flujo para usarlo más tarde.

  1. En el panel de navegación, seleccione Soluciones.
  2. En la página Soluciones, seleccione Nueva solución.
  3. En el cuadro de diálogo nueva solución, establezca los campos requeridos y, a continuación, seleccione Crear.

Paso 1: crear un desencadenador de PowerApps

  1. En la página Soluciones, seleccione la solución que creó y, a continuación Nuevo.
  2. En el panel izquierdo, seleccione Flujos de nube>Automatización>Flujo de nube>Instantáneo.
  3. En el campo Nombre de flujo, introduzca Programar flujo de demostración de API.
  4. En la lista Elegir cómo desencadenar este flujo, seleccione Power Apps. Cuando cree un desencadenador de Power Apps, la lógica depende de usted como autor. Por ejemplo, en este artículo, deje los parámetros de entrada en blanco con fines de prueba.
  5. Seleccione Crear.

Paso 2: crear un proyecto

Siga estos pasos para crear una estimación de proyecto.

  1. En el flujo que creó, seleccione Nuevo paso.

    Adición de un nuevo paso.

  2. En el cuadro de diálogo Elegir una operación, en el campo de búsqueda, introduzca Realizar una acción no enlazada. Entonces, en la pestaña Acciones, seleccione la operación en la lista de resultados.

    Selección de una operación.

  3. En el nuevo paso, selecciones los puntos suspensivos () y luego elija Renombrar.

    Cambio de nombre de un paso.

  4. Cambie el nombre del paso Crear proyecto.

  5. En el campo Nombre de acción, seleccione msdyn_CreateProjectV1.

  6. En el campo msdyn_subject, seleccione Agregar contenido dinámico.

  7. En la pestaña Expresión, en el campo de función, introduzca concat('Nombre de proyecto - ',utcNow()).

  8. Seleccione Aceptar.

Paso 3: inicializar una variable para el miembro del equipo

  1. En el flujo, seleccione Nuevo paso.
  2. En el cuadro de diálogo Elegir una operación, en el campo de búsqueda, introduzca Inicializar variable. Entonces, en la pestaña Acciones, seleccione la operación en la lista de resultados.
  3. En el nuevo paso, selecciones los puntos suspensivos () y luego elija Renombrar.
  4. Cambie el nombre del paso Inicializar miembro del equipo.
  5. En el campo Nombre, escriba TeamMemberAction.
  6. En el campo Tipo, seleccione Cadena.
  7. En el campo Valor, introduzca msdyn_CreateTeamMemberV1.

Paso 4: crear un miembro del equipo genérico

  1. En el flujo, seleccione Nuevo paso.

  2. En el cuadro de diálogo Elegir una operación, en el campo de búsqueda, introduzca Realizar una acción no enlazada. Entonces, en la pestaña Acciones, seleccione la operación en la lista de resultados.

  3. En el nuevo paso, selecciones los puntos suspensivos () y luego elija Renombrar.

  4. Cambie el nombre del paso Crear miembro del equipo.

  5. Para el campo Nombre de la acción, seleccione TeamMemberAction en el cuadro de diálogo Contenido dinámico .

  6. En el campo Parámetros de acción, introduzca la siguiente información del parámetro.

    {
        "TeamMember": {
            "@@odata.type": "Microsoft.Dynamics.CRM.msdyn_projectteam",
            "msdyn_projectteamid": "@{guid()}",
            "msdyn_project@odata.bind": "/msdyn_projects(@{outputs('Create_Project')?['body/ProjectId']})",
            "msdyn_name": "ScheduleAPIDemoTM1"
        }
    } 
    

    A continuación se ofrece una explicación de los parámetros:

    • @@odata.type: nombre de entidad. Por ejemplo, introduzca "Microsoft.Dynamics.CRM.msdyn_projectteam".
    • msdyn_projectteamid: la clave principal del id. del equipo del proyecto. El valor es una expresión de identificador único global (GUID). El id. se genera desde la pestaña de Expresión.
    • msdyn_project@odata.bind: Id. del calendario del proyecto. El valor es contenido dinámico que provenga de la respuesta del paso "Crear proyecto". Asegúrese de introducir la ruta completa y agregue contenido dinámico entre paréntesis. Se requieren comillas. Por ejemplo, introduzca "/msdyn_projects(ADD DYNAMIC CONTENT)".
    • msdyn_name: nombre para mostrar del miembro del equipo. Por ejemplo, escriba "ScheduleAPIDemoTM1".

Paso 5: crear un conjunto de opciones

  1. En el flujo, seleccione Nuevo paso.
  2. En el cuadro de diálogo Elegir una operación, en el campo de búsqueda, introduzca Realizar una acción no enlazada. Entonces, en la pestaña Acciones, seleccione la operación en la lista de resultados.
  3. En el nuevo paso, selecciones los puntos suspensivos () y luego elija Renombrar.
  4. Cambie el nombre del paso Crear conjunto de operaciones.
  5. En el campo Nombre de la acción, seleccione la acción de Dataverse personalizada msdyn_CreateOperationSetV1.
  6. En el campo Descripción, introduzca ScheduleAPIDemoOperationSet".
  7. En el campo Proyecto, seleccione msdyn_CreateProjectV1Response ProjectId en el cuadro de diálogo Contenido dinámico.

Paso 6: crear un cubo de proyecto

  1. En el flujo, seleccione Nuevo paso.
  2. En el cuadro de diálogo Elegir una operación, en el campo de búsqueda, introduzca Agregar nueva fila. Entonces, en la pestaña Acciones, seleccione la operación en la lista de resultados.
  3. En el nuevo paso, selecciones los puntos suspensivos () y luego elija Renombrar.
  4. Cambie el nombre del paso Crear cubo.
  5. En el campo Nombre de tabla, seleccione Cubos de proyecto.
  6. En el campo Nombre, escriba ScheduleAPIDemoBucket1.
  7. En el campo Proyecto, introduzca /msdyn_projects(.
  8. En el cuadro de diálogo Contenido dinámico, seleccione msdyn_CreateProjectV1Response ProjectId.
  9. En el campo Proyecto, introduzca ).

Paso 7: inicializar una variable para el número de tareas

  1. En el flujo, seleccione Nuevo paso.
  2. En el cuadro de diálogo Elegir una operación, en el campo de búsqueda, introduzca Inicializar variable. Entonces, en la pestaña Acciones, seleccione la operación en la lista de resultados.
  3. En el nuevo paso, selecciones los puntos suspensivos () y luego elija Renombrar.
  4. Cambie el nombre del paso Inicializar número de tareas.
  5. En el campo Nombre, escriba Número de tareas.
  6. En el campo Tipo, seleccione Entero.
  7. En el campo Valor, introduzca 5.

Paso 8: inicializar una variable para el id. de tarea de proyecto

  1. En el flujo, seleccione Nuevo paso.
  2. En el cuadro de diálogo Elegir una operación, en el campo de búsqueda, introduzca Inicializar variable. Entonces, en la pestaña Acciones, seleccione la operación en la lista de resultados.
  3. En el nuevo paso, selecciones los puntos suspensivos () y luego elija Renombrar.
  4. Cambie el nombre del paso Init ProjectTaskID.
  5. En el campo Nombre, escriba msdyn_projecttaskid.
  6. En el campo Tipo, seleccione Cadena.
  7. Para el campo Valor, introduzca guid() en el generador de expresiones.

Paso 9: Inicializar una matriz

  1. En el flujo, seleccione Nuevo paso.
  2. En el cuadro de diálogo Elegir una operación, en el campo de búsqueda, introduzca Inicializar variable. Entonces, en la pestaña Acciones, seleccione la operación en la lista de resultados.
  3. En el nuevo paso, selecciones los puntos suspensivos () y luego elija Renombrar.
  4. Cambie el nombre del paso Inicializar matriz.
  5. En el campo Nombre, escriba Tareas y asignaciones.
  6. En el campo Tipo, seleccione Matriz.

Paso 10: hacer hasta

  1. En el flujo, seleccione Nuevo paso.
  2. En el cuadro de diálogo Elegir una operación, en el campo de búsqueda, introduzca Hacer hasta. Entonces, en la pestaña Acciones, seleccione la operación en la lista de resultados.
  3. Establezca el primer valor de la declaración condicional en la variable Número de tareas del cuadro de diálogo Contenido dinámico.
  4. Establezca la condición de menor o igual que.
  5. Establezca el segundo valor de la declaración condicional en 0.

Paso 11: establecer una tarea de proyecto

  1. En el flujo, seleccione Agregar una acción.
  2. En el cuadro de diálogo Elegir una operación, en el campo de búsqueda, introduzca Establecer variable. Entonces, en la pestaña Acciones, seleccione la operación en la lista de resultados.
  3. En el nuevo paso, selecciones los puntos suspensivos () y luego elija Renombrar.
  4. Cambie el nombre del paso Establecer tarea de proyecto.
  5. En el campo Nombre, seleccione msdyn_projecttaskid.
  6. Para el campo Valor, introduzca guid() en el generador de expresiones.

Paso 12: Agregar una tarea a la matriz

  1. En el flujo, seleccione Agregar una acción.

  2. En el cuadro de diálogo Elegir una operación, en el campo de búsqueda, introduzca Anexar a matriz.

  3. En el paso, selecciones los puntos suspensivos () y luego elija Renombrar.

  4. Cambie el nombre del paso a Agregar tarea a matriz.

  5. En el campo Nombre, seleccione Tareas y asignaciones.

  6. En el campo Valor, introduzca la siguiente información del parámetro.

    {
        "@@odata.type": "Microsoft.Dynamics.CRM.msdyn_projecttask",
        "msdyn_projecttaskid": "@{variables('msdyn_projecttaskid')}",
        "msdyn_project@odata.bind": "/msdyn_projects(@{outputs('Create_Project')?['body/ProjectId']})",
        "msdyn_subject": "ScheduleAPIDemoTask1",
        "msdyn_projectbucket@odata.bind": "/msdyn_projectbuckets(@{outputs('Create_Bucket')?['body/msdyn_projectbucketid']})",
        "msdyn_start": "@{addDays(utcNow(), 1)}",
        "msdyn_scheduledstart": "@{utcNow()}",
        "msdyn_scheduledend": "@{addDays(utcNow(), 5)}",
        "msdyn_LinkStatus": "192350000"
    }
    

    A continuación se ofrece una explicación de los parámetros:

    • @@odata.type: nombre de entidad. Por ejemplo, introduzca "Microsoft.Dynamics.CRM.msdyn_projecttask".
    • msdyn_projecttaskid: el id. único de la tarea. El valor debe establecerse en una variable dinámica de msdyn_projecttaskid.
    • msdyn_project@odata.bind: Id. del calendario del proyecto. El valor es contenido dinámico que provenga de la respuesta del paso "Crear proyecto". Asegúrese de introducir la ruta completa y agregue contenido dinámico entre paréntesis. Se requieren comillas. Por ejemplo, introduzca "/msdyn_projects(ADD DYNAMIC CONTENT)".
    • msdyn_subject: cualquier nombre de tarea.
    • msdyn_projectbucket@odata.bind: el cubo del proyecto que contiene las tareas. El valor es contenido dinámico que provenga de la respuesta del paso "Crear cubo". Asegúrese de introducir la ruta completa y agregue contenido dinámico entre paréntesis. Se requieren comillas. Por ejemplo, introduzca "/msdyn_projectbuckets(ADD DYNAMIC CONTENT)".
    • msdyn_start: contenido dinámico para la fecha de inicio. Por ejemplo, mañana se representa como "addDays(utcNow(), 1)".
    • msdyn_scheduledstart: la fecha inicial programada. Por ejemplo, mañana se representa como "addDays(utcNow(), 1)".
    • msdyn_scheduleend: la fecha de finalización programada. Seleccione una fecha futura. Por ejemplo, especifique "addDays(utcNow(), 5)".
    • msdyn_LinkStatus: el vínculo a la configuración de facturación. Por ejemplo, introduzca "192350000" si no hay un vínculo a la configuración de facturación o "192350001" si la configuración de la facturación está vinculada.

Paso 13: crear una asignación de recursos

  1. En el flujo, seleccione Agregar una acción.

  2. En el cuadro de diálogo Elegir una operación, en el campo de búsqueda, introduzca Anexar a matriz.

  3. En el paso, selecciones los puntos suspensivos () y luego elija Renombrar.

  4. Cambie el nombre del paso a Agregar asignación a matriz.

  5. En el campo Nombre, seleccione Tareas y asignaciones.

  6. En el campo Valor, introduzca la siguiente información del parámetro.

    {
        "@@odata.type": "Microsoft.Dynamics.CRM.msdyn_resourceassignment",
        "msdyn_resourceassignmentid": "@{guid()}",
        "msdyn_name": "ScheduleAPIDemoAssign1",
        "msdyn_taskid@odata.bind": "/msdyn_projecttasks(@{variables('msdyn_projecttaskid')})",
        "msdyn_projectteamid@odata.bind": "/msdyn_projectteams(@{outputs('Create_Team_Member')?['body/TeamMemberId']})",
        "msdyn_projectid@odata.bind": "/msdyn_projects(@{outputs('Create_Project')?['body/ProjectId']})"
    }
    

Paso 14: decrementar una variable

  1. En el flujo, seleccione Agregar una acción.
  2. En el cuadro de diálogo Elegir una operación, en el campo de búsqueda, introduzca Decrementar variable. Entonces, en la pestaña Acciones, seleccione la operación en la lista de resultados.
  3. En el campo Nombre, seleccione Número de tareas.
  4. En el campo Valor, introduzca 1.

Paso 15: Agregar tareas y asignaciones al conjunto de operaciones

  1. En el flujo, seleccione Nuevo paso.
  2. En el cuadro de diálogo Elegir una operación, en el campo de búsqueda, introduzca Realizar una acción no enlazada. Entonces, en la pestaña Acciones, seleccione la operación en la lista de resultados.
  3. En el paso, selecciones los puntos suspensivos () y luego elija Renombrar.
  4. Cambie el nombre del paso a Agregar tareas y asignaciones al conjunto de operaciones.
  5. En el campo Nombre de acción, seleccione msdyn_PssCreateV2.
  6. En el campo OperationSetId, seleccione msdyn_CreateOperationSetV1Response OperationSetId en el cuadro de diálogo Contenido dinámico.
  7. En el campo EntityCollection, seleccione Cambiar entrada a toda la matriz.
  8. En el campo EntityCollection, seleccione Tareas y asignacionesen el cuadro de diálogo Contenido dinámico.

Paso 16: ejecutar un conjunto de opciones

  1. En el flujo, seleccione Nuevo paso.
  2. En el cuadro de diálogo Elegir una operación, en el campo de búsqueda, introduzca Realizar una acción no enlazada. Entonces, en la pestaña Acciones, seleccione la operación en la lista de resultados.
  3. En el paso, selecciones los puntos suspensivos () y luego elija Renombrar.
  4. Cambie el nombre del paso Ejecutar conjunto de operaciones.
  5. En el campo Nombre de acción, seleccione msdyn_ExecuteOperationSetV1.
  6. En el campo OperationSetId, seleccione msdyn_CreateOperationSetV1Response OperationSetId en el cuadro de diálogo Contenido dinámico.

Referencias