Administración de usuarios managing-users

Los ejemplos de este documento solo son para AEM Forms en un entorno JEE.

Acerca de la administración de usuarios

Puede utilizar la API de administración de usuarios para crear aplicaciones cliente que puedan administrar roles, permisos y principales (que pueden ser usuarios o grupos) y autenticar usuarios. La API de administración de usuarios consta de las siguientes API de AEM Forms:

  • API de servicio de Directory Manager
  • API del servicio Administrador de autenticación
  • API del servicio Administrador de autorización

Administración de usuarios permite asignar, quitar y determinar funciones y permisos. También permite asignar, quitar y consultar dominios, usuarios y grupos. Por último, puede utilizar Administración de usuarios para autenticar a los usuarios.

Entrada Adición de usuarios comprenderá cómo agregar usuarios mediante programación. Esta sección utiliza la API del servicio de Directory Manager.

Entrada Eliminación de usuarios comprenderá cómo eliminar usuarios mediante programación. Esta sección utiliza la API del servicio de Directory Manager.

Entrada Administración de usuarios y grupos comprenderá la diferencia entre un usuario local y un usuario de directorio y verá ejemplos de cómo utilizar las API de Java y de servicio web para administrar usuarios y grupos mediante programación. Esta sección utiliza la API del servicio de Directory Manager.

Entrada Administración de funciones y permisos obtendrá información sobre las funciones y los permisos del sistema y lo que puede hacer mediante programación para aumentarlos. Consulte ejemplos de cómo utilizar las API de Java y de servicios web para administrar funciones y permisos mediante programación. Esta sección utiliza tanto la API del servicio de Directory Manager como la API del servicio de Authorization Manager.

Entrada Autenticar usuarios verá ejemplos de cómo utilizar las API de Java y de servicios web para autenticar a los usuarios mediante programación. Esta sección utiliza la API del servicio Administrador de autorización.

Explicación del proceso de autenticación

Administración de usuarios proporciona funcionalidad de autenticación integrada y la capacidad de conectarse con su propio proveedor de autenticación. Cuando Administración de usuarios recibe una solicitud de autenticación (por ejemplo, un usuario intenta iniciar sesión), pasa la información del usuario al proveedor de autenticación para que se autentique. Administración de usuarios recibe los resultados del proveedor de autenticación después de autenticar al usuario.

En el diagrama siguiente se muestra la interacción entre un usuario final que intenta iniciar sesión, Administración de usuarios y el proveedor de autenticación.

mu_mu_umauth_process

En la tabla siguiente se describe cada paso del proceso de autenticación.

Paso
Descripción
1
Un usuario intenta iniciar sesión en un servicio que invoca la administración de usuarios. El usuario especifica un nombre de usuario y una contraseña.
2
Administración de usuarios envía el nombre de usuario y la contraseña, así como la información de configuración, al proveedor de autenticación.
3
El proveedor de autenticación se conecta al almacén de usuarios y autentica al usuario.
4
El proveedor de autenticación devuelve los resultados a Administración de usuarios.
5
Administración de usuarios permite que el usuario inicie sesión o deniega el acceso al producto.
NOTE
Si la zona horaria del servidor es diferente de la del cliente, al consumir el WSDL para el servicio AEM Forms Generate PDF en una pila SOAP nativa con un cliente .NET en un clúster de servidores de aplicaciones de WebSphere, puede producirse el siguiente error de autenticación de User Management:

[com.adobe.idp.um.webservices.WSSecurityHandler] errorCode:12803 errorCodeHEX:0x3203 message:WSSecurityHandler: UM authenticate returns exception : An error was discovered processing the <wsse:Security> header. (WSSecurityEngine: Invalid timestamp The security semantics of message have expired).

Explicación de la administración de directorios

La Administración de usuarios está empaquetada con un proveedor de servicios de directorio (DirectoryManagerService) que admite conexiones a directorios LDAP. Si su organización utiliza un repositorio que no sea LDAP para almacenar registros de usuario, puede crear su propio proveedor de servicios de directorio que trabaje con el repositorio.

Los proveedores de servicios de directorio recuperan registros de un almacén de usuarios a petición de Administración de usuarios. Administración de usuarios almacena en caché regularmente los registros de usuarios y grupos en la base de datos para mejorar el rendimiento.

El proveedor de servicios de directorio se puede utilizar para sincronizar la base de datos de Administración de usuarios con el almacén de usuarios. Este paso garantiza que toda la información del directorio de usuario y todos los registros de usuario y grupo estén actualizados.

Además, DirectoryManagerService permite crear y administrar dominios. Los dominios definen diferentes bases de usuario. El límite de un dominio suele definirse según la forma en que esté estructurada su organización o la configuración de su almacén de usuarios. Los dominios de administración de usuarios proporcionan opciones de configuración que utilizan los proveedores de autenticación y los proveedores de servicios de directorio.

En el XML de configuración que exporta Administración de usuarios, el nodo raíz que tiene el valor de atributo de Domains contiene un elemento XML para cada dominio definido para la administración de usuarios. Cada uno de estos elementos contiene otros elementos que definen aspectos del dominio asociado con proveedores de servicios específicos.

Explicación de los valores objectSID

Al utilizar Active Directory, es importante comprender que una objectSID El valor de no es un atributo único en varios dominios. Este valor almacena el identificador de seguridad de un objeto. En un entorno de varios dominios (por ejemplo, un árbol de dominios), la variable objectSID el valor puede ser diferente.

Un objectSID cambiaría si un objeto se mueve de un dominio de Active Directory a otro dominio. Algunos objetos tienen el mismo objectSID valor en cualquier lugar del dominio. Por ejemplo, los grupos BUILTIN\Administradores, BUILTIN\Usuarios avanzados, etc., tendrían el mismo objectSID independientemente de los dominios. Estos objectSID Los valores de son bien conocidos.

Adición de usuarios adding-users

Puede utilizar la API del servicio Directory Manager (Java y servicio web) para agregar usuarios a AEM Forms mediante programación. Después de agregar un usuario, puede utilizarlo cuando realice una operación de servicio que requiera un usuario. Por ejemplo, puede asignar una tarea al nuevo usuario.

Resumen de los pasos summary-of-steps

Para agregar un usuario, realice los siguientes pasos:

  1. Incluir archivos de proyecto.
  2. Cree un cliente DirectoryManagerService.
  3. Definir información de usuario.
  4. Añada el usuario a AEM Forms.
  5. Compruebe que se ha agregado el usuario.

Incluir archivos de proyecto

Incluya los archivos necesarios en el proyecto de desarrollo. Si está creando una aplicación cliente mediante Java, incluya los archivos JAR necesarios. Si utiliza servicios web, incluya los archivos proxy.

Crear un cliente de DirectoryManagerService

Para poder realizar mediante programación una operación de servicio de Directory Manager, cree un cliente de API de servicio de Directory Manager.

Definir información de usuario

Cuando agregue un nuevo usuario mediante la API del servicio de Directory Manager, defina la información para ese usuario. Normalmente, cuando se agrega un nuevo usuario, se definen los siguientes valores:

  • Nombre de dominio: dominio al que pertenece el usuario (por ejemplo, DefaultDom).
  • Valor del identificador de usuario: el valor del identificador del usuario (por ejemplo, wblue).
  • Tipo principal: el tipo de usuario (por ejemplo, puede especificar USER).
  • Nombre dado: un nombre determinado para el usuario (por ejemplo, Wendy).
  • Apellido familiar: el nombre de la familia del usuario (por ejemplo, Blue).
  • Configuración regional: Información de configuración regional del usuario.

Añadir el usuario a AEM Forms

Después de definir la información del usuario, puede agregarlo a AEM Forms. Para agregar un usuario, invoque el DirectoryManagerServiceClient del objeto createLocalUser método.

Compruebe que se ha agregado el usuario

Puede comprobar que se agregó el usuario para asegurarse de que no se produjeron problemas. Busque el nuevo usuario utilizando el valor identificador de usuario.

Consulte también

Añadir usuarios mediante la API de Java

Agregar usuarios mediante la API de servicio web

Incluir archivos de biblioteca Java de AEM Forms

Estableciendo propiedades de conexión

Eliminación de usuarios

Añadir usuarios mediante la API de Java add-users-using-the-java-api

Agregar usuarios mediante la API del servicio de Directory Manager (Java):

  1. Incluir archivos de proyecto.

    Incluya archivos JAR de cliente, como adobe-usermanager-client.jar, en la ruta de clase del proyecto Java.

  2. Cree un cliente de DirectoryManagerServices.

    Crear un DirectoryManagerServiceClient mediante su constructor y pasando un objeto ServiceClientFactory que contiene las propiedades de conexión.

  3. Definir información de usuario.

    • Crear un UserImpl mediante su constructor.
    • Configure el nombre del dominio invocando la variable UserImpl del objeto setDomainName método. Pase un valor de cadena que especifique el nombre de dominio.
    • Establezca el tipo principal invocando el UserImpl del objeto setPrincipalType método. Pase un valor de cadena que especifique el tipo de usuario. Por ejemplo, puede especificar USER.
    • Establezca el valor del identificador de usuario invocando el UserImpl del objeto setUserid método. Pase un valor de cadena que especifique el valor del identificador de usuario. Por ejemplo, puede especificar wblue.
    • Establezca el nombre canónico invocando el UserImpl del objeto setCanonicalName método. Pase un valor de cadena que especifique el nombre canónico del usuario. Por ejemplo, puede especificar wblue.
    • Configure el nombre dado invocando el UserImpl del objeto setGivenName método. Pase un valor de cadena que especifique el nombre de pila del usuario. Por ejemplo, puede especificar Wendy.
    • Configure el nombre de la familia invocando el UserImpl del objeto setFamilyName método. Pase un valor de cadena que especifique el nombre familiar del usuario. Por ejemplo, puede especificar Blue.
    note note
    NOTE
    Invoque un método que pertenezca a UserImpl para establecer otros valores. Por ejemplo, puede establecer el valor de configuración regional invocando la variable UserImpl del objeto setLocale método.
  4. Añada el usuario a AEM Forms.

    Invoque el DirectoryManagerServiceClient del objeto createLocalUser y pasar los siguientes valores:

    • El UserImpl objeto que representa al nuevo usuario
    • Valor de cadena que representa la contraseña del usuario

    El createLocalUser devuelve un valor de cadena que especifica el valor del identificador de usuario local.

  5. Compruebe que se ha agregado el usuario.

    • Crear un PrincipalSearchFilter mediante su constructor.
    • Establezca el valor del identificador de usuario invocando el PrincipalSearchFilter del objeto setUserId método. Pase un valor de cadena que represente el valor del identificador de usuario.
    • Invoque el DirectoryManagerServiceClient del objeto findPrincipals y pase el PrincipalSearchFilter objeto. Este método devuelve un java.util.List instancia, donde cada elemento es una User objeto. Itere a través de java.util.List para localizar al usuario.

Consulte también

Resumen de los pasos

Inicio rápido (modo SOAP): Añadir usuarios mediante la API de Java

Incluir archivos de biblioteca Java de AEM Forms

Estableciendo propiedades de conexión

Agregar usuarios mediante la API de servicio web add-users-using-the-web-service-api

Agregar usuarios mediante la API del servicio Directory Manager Service (servicio web):

  1. Incluir archivos de proyecto.

    Cree un proyecto de Microsoft .NET que utilice MTOM. Asegúrese de utilizar la siguiente definición de WSDL para la referencia del servicio: http://localhost:8080/soap/services/DirectoryManagerService?WSDL&lc_version=9.0.1.

    note note
    NOTE
    Reemplazar localhost con la dirección IP del servidor que aloja AEM Forms.
  2. Cree un cliente DirectoryManagerService.

    • Crear un DirectoryManagerServiceClient mediante su constructor predeterminado.

    • Crear un DirectoryManagerServiceClient.Endpoint.Address mediante el uso del objeto System.ServiceModel.EndpointAddress constructor. Pase un valor de cadena que especifique el WSDL al servicio AEM Forms (por ejemplo, http://localhost:8080/soap/services/DirectoryManagerService?blob=mtom). No es necesario que utilice el lc_version atributo. Este atributo se utiliza al crear una referencia de servicio. Asegúrese de especificar lo siguiente ?blob=mtom.

    • Crear un System.ServiceModel.BasicHttpBinding al obtener el valor de la variable DirectoryManagerServiceClient.Endpoint.Binding field. Convierta el valor devuelto en BasicHttpBinding.

    • Configure las variables System.ServiceModel.BasicHttpBinding del objeto MessageEncoding field a WSMessageEncoding.Mtom. Este valor garantiza que se utiliza MTOM.

    • Habilite la autenticación HTTP básica realizando las siguientes tareas:

      • AEM Asigne el nombre de usuario del formulario de la al campo DirectoryManagerServiceClient.ClientCredentials.UserName.UserName.
      • Asigne el valor de contraseña correspondiente al campo DirectoryManagerServiceClient.ClientCredentials.UserName.Password.
      • Asignar el valor constante HttpClientCredentialType.Basic al campo BasicHttpBindingSecurity.Transport.ClientCredentialType.
      • Asignar el valor constante BasicHttpSecurityMode.TransportCredentialOnly al campo BasicHttpBindingSecurity.Security.Mode.
  3. Definir información de usuario.

    • Crear un UserImpl mediante su constructor.
    • Establezca el nombre de dominio asignando un valor de cadena al UserImpl del objeto domainName field.
    • Establezca el tipo principal asignando un valor de cadena al UserImpl del objeto principalType field. Por ejemplo, puede especificar USER.
    • Establezca el valor del identificador de usuario asignando un valor de cadena al UserImpl del objeto userid field.
    • Establezca el valor del nombre canónico asignando un valor de cadena al UserImpl del objeto canonicalName field.
    • Establezca el valor del nombre dado asignando un valor de cadena al UserImpl del objeto givenName field.
    • Establezca el valor del nombre de familia asignando un valor de cadena a la variable UserImpl del objeto familyName field.
  4. Añada el usuario a AEM Forms.

    Invoque el DirectoryManagerServiceClient del objeto createLocalUser y pasar los siguientes valores:

    • El UserImpl objeto que representa al nuevo usuario
    • Valor de cadena que representa la contraseña del usuario

    El createLocalUser devuelve un valor de cadena que especifica el valor del identificador de usuario local.

  5. Compruebe que se ha agregado el usuario.

    • Crear un PrincipalSearchFilter mediante su constructor.
    • Establezca el valor del identificador de usuario del usuario asignando un valor de cadena que represente el valor del identificador de usuario al PrincipalSearchFilter del objeto userId field.
    • Invoque el DirectoryManagerServiceClient del objeto findPrincipals y pase el PrincipalSearchFilter objeto. Este método devuelve un MyArrayOfUser objeto de colección, donde cada elemento es un User objeto. Itere a través de MyArrayOfUser para localizar al usuario.

Consulte también

Resumen de los pasos

Invocar AEM Forms mediante MTOM

Invocar AEM Forms mediante SwaRef

Eliminación de usuarios deleting-users

Puede utilizar la API del servicio Directory Manager (Java y servicio web) para eliminar usuarios de AEM Forms mediante programación. Una vez eliminado un usuario, ya no se puede utilizarlo para realizar una operación de servicio que requiera un usuario. Por ejemplo, no puede asignar una tarea a un usuario eliminado.

Resumen de los pasos summary_of_steps-1

Para eliminar un usuario, realice los siguientes pasos:

  1. Incluir archivos de proyecto.
  2. Cree un cliente DirectoryManagerService.
  3. Especifique el usuario que desea eliminar.
  4. Elimine el usuario de AEM Forms.

Incluir archivos de proyecto

Incluya los archivos necesarios en el proyecto de desarrollo. Si está creando una aplicación cliente con Java, incluya los archivos JAR necesarios. Si utiliza servicios web, incluya los archivos proxy.

Crear un cliente de DirectoryManagerService

Para poder realizar mediante programación una operación de API del servicio Directory Manager, cree un cliente de servicio Directory Manager.

Especifique el usuario que desea eliminar

Puede especificar un usuario para eliminarlo utilizando el valor del identificador del usuario.

Eliminar el usuario de AEM Forms

Para eliminar un usuario, invoque el DirectoryManagerServiceClient del objeto deleteLocalUser método.

Consulte también

Eliminar usuarios mediante la API de Java

Eliminar usuarios mediante la API de servicio web

Incluir archivos de biblioteca Java de AEM Forms

Estableciendo propiedades de conexión

Adición de usuarios

Eliminar usuarios mediante la API de Java delete-users-using-the-java-api

Eliminar usuarios mediante la API del servicio de Directory Manager (Java):

  1. Incluir archivos de proyecto.

    Incluya archivos JAR de cliente, como adobe-usermanager-client.jar, en la ruta de clase del proyecto Java.

  2. Cree un cliente DirectoryManagerService.

    Crear un DirectoryManagerServiceClient mediante su constructor y pasando un objeto ServiceClientFactory que contiene las propiedades de conexión.

  3. Especifique el usuario que desea eliminar.

    • Crear un PrincipalSearchFilter mediante su constructor.
    • Establezca el valor del identificador de usuario invocando el PrincipalSearchFilter del objeto setUserId método. Pase un valor de cadena que represente el valor del identificador de usuario.
    • Invoque el DirectoryManagerServiceClient del objeto findPrincipals y pase el PrincipalSearchFilter objeto. Este método devuelve un java.util.List instancia, donde cada elemento es una User objeto. Itere a través de java.util.List instancia para localizar el usuario que se va a eliminar.
  4. Elimine el usuario de AEM Forms.

    Invoque el DirectoryManagerServiceClient del objeto deleteLocalUser y pasar el valor del método User del objeto oid field. Invoque el User del objeto getOid método. Utilice el User objeto recuperado del java.util.List ejemplo.

Consulte también

Resumen de los pasos

Inicio rápido (modo EJB): Eliminación de usuarios mediante la API de Java

Inicio rápido (modo SOAP): Eliminación de usuarios mediante la API de Java

Incluir archivos de biblioteca Java de AEM Forms

Estableciendo propiedades de conexión

Eliminar usuarios mediante la API de servicio web delete-users-using-the-web-service-api

Eliminar usuarios mediante la API del servicio Directory Manager Service (servicio Web):

  1. Incluir archivos de proyecto.

    Incluya archivos JAR de cliente, como adobe-usermanager-client.jar, en la ruta de clase del proyecto Java.

  2. Cree un cliente DirectoryManagerService.

    • Crear un DirectoryManagerServiceClient mediante su constructor predeterminado.

    • Crear un DirectoryManagerServiceClient.Endpoint.Address mediante el uso del objeto System.ServiceModel.EndpointAddress constructor. Pase un valor de cadena que especifique el WSDL al servicio AEM Forms (por ejemplo, http://localhost:8080/soap/services/DirectoryManagerService?blob=mtom). No es necesario que utilice el lc_version atributo. Este atributo se utiliza al crear una referencia de servicio. Asegúrese de especificar lo siguiente blob=mtom.

    • Crear un System.ServiceModel.BasicHttpBinding al obtener el valor de la variable DirectoryManagerServiceClient.Endpoint.Binding field. Convierta el valor devuelto en BasicHttpBinding.

    • Configure las variables System.ServiceModel.BasicHttpBinding del objeto MessageEncoding field a WSMessageEncoding.Mtom. Este valor garantiza que se utiliza MTOM.

    • Habilite la autenticación HTTP básica realizando las siguientes tareas:

      • AEM Asigne el nombre de usuario del formulario de la al campo DirectoryManagerServiceClient.ClientCredentials.UserName.UserName.
      • Asigne el valor de contraseña correspondiente al campo DirectoryManagerServiceClient.ClientCredentials.UserName.Password.
      • Asignar el valor constante HttpClientCredentialType.Basic al campo BasicHttpBindingSecurity.Transport.ClientCredentialType.
      • Asignar el valor constante BasicHttpSecurityMode.TransportCredentialOnly al campo BasicHttpBindingSecurity.Security.Mode.
  3. Especifique el usuario que desea eliminar.

    • Crear un PrincipalSearchFilter mediante su constructor.
    • Establezca el valor del identificador de usuario asignando un valor de cadena al PrincipalSearchFilter del objeto userId field.
    • Invoque el DirectoryManagerServiceClient del objeto findPrincipals y pase el PrincipalSearchFilter objeto. Este método devuelve un MyArrayOfUser objeto de colección, donde cada elemento es un User objeto. Itere a través de MyArrayOfUser para localizar al usuario. El User objeto recuperado del MyArrayOfUser El objeto de colección se utiliza para eliminar al usuario.
  4. Elimine el usuario de AEM Forms.

    Elimine el usuario pasando el User del objeto oid valor de campo a DirectoryManagerServiceClient del objeto deleteLocalUser método.

Consulte también

Resumen de los pasos

Invocar AEM Forms mediante MTOM

Invocar AEM Forms mediante SwaRef

Creación de grupos creating-groups

Puede utilizar la API del servicio Directory Manager (Java y servicio web) para crear grupos de AEM Forms mediante programación. Después de crear un grupo, puede utilizarlo para realizar una operación de servicio que requiera un grupo. Por ejemplo, puede asignar un usuario al nuevo grupo. (Consulte Administración de usuarios y grupos.)

Resumen de los pasos summary_of_steps-2

Para crear un grupo, realice los siguientes pasos:

  1. Incluir archivos de proyecto.
  2. Cree un cliente DirectoryManagerService.
  3. Determine que el grupo no existe.
  4. Cree el grupo.
  5. Realice una acción con el grupo.

Incluir archivos de proyecto

Incluya los archivos necesarios en el proyecto de desarrollo. Si está creando una aplicación cliente mediante Java, incluya los archivos JAR necesarios.

Los siguientes archivos JAR deben agregarse a la ruta de clase del proyecto:

  • adobe-livecycle-client.jar
  • adobe-usermanager-client.jar
  • adobe-utilities.jar (obligatorio si AEM Forms está implementado en JBoss)
  • jbossall-client.jar (requerido si AEM Forms está implementado en JBoss)

Para obtener información sobre la ubicación de estos archivos JAR, consulte Incluir archivos de biblioteca Java de AEM Forms.

Crear un cliente de DirectoryManagerService

Para poder realizar mediante programación una operación de servicio de Directory Manager, cree un cliente de API de servicio de Directory Manager.

Determinar si el grupo existe

Cuando cree un grupo, asegúrese de que el grupo no existe en el mismo dominio. Es decir, dos grupos no pueden tener el mismo nombre dentro del mismo dominio. Para realizar esta tarea, realice una búsqueda y filtre los resultados de búsqueda en función de dos valores. Establezca el tipo principal en com.adobe.idp.um.api.infomodel.Principal.PRINCIPALTYPE_GROUP para asegurarse de que solo se devuelven los grupos. Además, asegúrese de especificar el nombre de dominio.

Crear el grupo

Después de determinar que el grupo no existe en el dominio, cree el grupo y especifique los atributos siguientes:

  • CommonName: nombre del grupo.
  • Dominio: Dominio en el que se agrega el grupo.
  • Descripción: una descripción del grupo.

Realizar una acción con el grupo

Después de crear un grupo, puede realizar una acción con el grupo. Por ejemplo, puede agregar un usuario al grupo. Para añadir un usuario a un grupo, recupere el valor del identificador único del usuario y del grupo. Pase estos valores a addPrincipalToLocalGroup método.

Consulte también

Creación de grupos mediante la API de Java

Incluir archivos de biblioteca Java de AEM Forms

Estableciendo propiedades de conexión

Adición de usuarios

Eliminación de usuarios

Creación de grupos mediante la API de Java create-groups-using-the-java-api

Cree un grupo mediante la API de servicio de Directory Manager (Java):

  1. Incluir archivos de proyecto.

    Incluya archivos JAR de cliente, como adobe-usermanager-client.jar, en la ruta de clase del proyecto Java.

  2. Cree un cliente DirectoryManagerService.

    Crear un DirectoryManagerServiceClient mediante su constructor y pasando un objeto ServiceClientFactory que contiene las propiedades de conexión.

  3. Determine si el grupo existe.

    • Crear un PrincipalSearchFilter mediante su constructor.
    • Establezca el tipo principal invocando el PrincipalSearchFilter del objeto setPrincipalType objeto. Pasar el valor com.adobe.idp.um.api.infomodel.Principal.PRINCIPALTYPE_GROUP.
    • Configure el dominio invocando el PrincipalSearchFilter del objeto setSpecificDomainName objeto. Pase un valor de cadena que especifique el nombre de dominio.
    • Para buscar un grupo, invoque el DirectoryManagerServiceClient del objeto findPrincipals método (un principal puede ser un grupo). Pase el PrincipalSearchFilter que especifica el tipo principal y el nombre de dominio. Este método devuelve un java.util.List instancia en la que cada elemento es una Group ejemplo. Cada instancia de grupo se ajusta al filtro especificado mediante el uso del PrincipalSearchFilter objeto.
    • Itere a través de java.util.List ejemplo. Para cada elemento, recupere el nombre del grupo. Asegúrese de que el nombre del grupo no coincide con el nuevo nombre de grupo.
  4. Cree el grupo.

    • Si el grupo no existe, invoque el Group del objeto setCommonName y pasar un valor de cadena que especifique el nombre del grupo.
    • Invoque el Group del objeto setDescription y pasar un valor de cadena que especifique la descripción del grupo.
    • Invoque el Group del objeto setDomainName y pasar un valor de cadena que especifique el nombre de dominio.
    • Invoque el DirectoryManagerServiceClient del objeto createLocalGroup y pase el Group ejemplo.

    El createLocalUser devuelve un valor de cadena que especifica el valor del identificador de usuario local.

  5. Realice una acción con el grupo.

    • Crear un PrincipalSearchFilter mediante su constructor.
    • Establezca el valor del identificador de usuario invocando el PrincipalSearchFilter del objeto setUserId método. Pase un valor de cadena que represente el valor del identificador de usuario.
    • Invoque el DirectoryManagerServiceClient del objeto findPrincipals y pase el PrincipalSearchFilter objeto. Este método devuelve un java.util.List instancia, donde cada elemento es una User objeto. Itere a través de java.util.List para localizar al usuario.
    • Agregue un usuario al grupo invocando el DirectoryManagerServiceClient del objeto addPrincipalToLocalGroup método. Pasar el valor devuelto del User del objeto getOid método. Pasar el valor devuelto del Group de objetos getOid método (utilice el Group que representa el nuevo grupo).

Consulte también

Resumen de los pasos

Incluir archivos de biblioteca Java de AEM Forms

Estableciendo propiedades de conexión

Administración de usuarios y grupos managing-users-and-groups

En este tema se describe cómo puede utilizar (Java) para asignar, quitar y consultar dominios, usuarios y grupos mediante programación.

NOTE
Al configurar un dominio, debe establecer el identificador único de grupos y usuarios. El atributo elegido no sólo debe ser único dentro del entorno LDAP, sino que también debe ser inmutable y no cambiará dentro del directorio. Este atributo también debe ser de un tipo de datos de cadena simple (la única excepción actualmente permitida para Active Directory 2000/2003 es "objectsid", que es un valor binario). Atributo de Novell eDirectory "GUID", por ejemplo, no es un tipo de datos de cadena simple y, por lo tanto, no funcionará.
  • Para Active Directory, utilice "objectsid".
  • Para SunOne, utilice "nsuniqueid".
NOTE
No se admite la creación de varios usuarios y grupos locales mientras la sincronización de directorios LDAP está en curso. Si se intenta este proceso, pueden producirse errores.

Resumen de los pasos summary_of_steps-3

Para administrar usuarios y grupos, realice los siguientes pasos:

  1. Incluir archivos de proyecto.
  2. Cree un cliente DirectoryManagerService.
  3. Invoque las operaciones de usuario o grupo adecuadas.

Incluir archivos de proyecto

Incluya los archivos necesarios en el proyecto de desarrollo. Si está creando una aplicación cliente mediante Java, incluya los archivos JAR necesarios. Si utiliza servicios web, asegúrese de incluir los archivos proxy.

Crear un cliente de DirectoryManagerService

Para poder realizar mediante programación una operación de servicio de Directory Manager, debe crear un cliente de servicio de Directory Manager. Con la API de Java, esto se consigue creando un DirectoryManagerServiceClient objeto. Con la API del servicio web, esto se consigue creando un DirectoryManagerServiceService objeto.

Invocar las operaciones de usuario o grupo apropiadas

Una vez creado el cliente de servicios, puede invocar las operaciones de administración de usuarios o grupos. El cliente de servicio permite asignar, quitar y consultar dominios, usuarios y grupos. Tenga en cuenta que es posible agregar un principal de directorio o un principal local a un grupo local, pero no es posible agregar un principal local a un grupo de directorios.

Consulte también

Administración de usuarios y grupos mediante la API de Java

Administración de usuarios y grupos mediante la API de servicio web

Incluir archivos de biblioteca Java de AEM Forms

Estableciendo propiedades de conexión

Inicios rápidos de API de User Manager

Administración de usuarios y grupos mediante la API de Java managing-users-and-groups-using-the-java-api

Para administrar mediante programación usuarios, grupos y dominios mediante (Java), realice las siguientes tareas:

  1. Incluir archivos de proyecto.

    Incluya archivos JAR de cliente, como adobe-usermanager-client.jar, en la ruta de clase del proyecto Java. Para obtener información acerca de la ubicación de estos archivos, consulte Incluir archivos de biblioteca Java de AEM Forms.

  2. Cree un cliente DirectoryManagerService.

    Crear un DirectoryManagerServiceClient mediante su constructor y pasando un objeto ServiceClientFactory que contiene las propiedades de conexión. Para obtener más información, consulte Estableciendo propiedades de conexión.

  3. Invoque las operaciones de usuario o grupo adecuadas.

    Para buscar un usuario o grupo, invoque uno de los DirectoryManagerServiceClient métodos del objeto para buscar principales (ya que un principal puede ser un usuario o un grupo). En el ejemplo siguiente, la variable findPrincipals método se llama mediante un filtro de búsqueda (a) PrincipalSearchFilter objeto).

    Dado que el valor devuelto en este caso es un java.util.List conteniendo Principal objetos, iterar por el resultado y convertir el Principal objetos a User o Group objetos.

    Uso del resultante User o Group objeto (que heredan del objeto Principal interfaz), recupere la información que necesite en los flujos de trabajo. Por ejemplo, los valores de nombre de dominio y nombre canónico, en combinación, identifican de forma exclusiva un principal. Se recuperan invocando el método Principal del objeto getDomainName y getCanonicalName métodos, respectivamente.

    Para eliminar un usuario local, invoque el DirectoryManagerServiceClient del objeto deleteLocalUser y pasar el identificador del usuario.

    Para eliminar un grupo local, invoque el DirectoryManagerServiceClient del objeto deleteLocalGroup y pasar el identificador del grupo.

Consulte también

Resumen de los pasos

Incluir archivos de biblioteca Java de AEM Forms

Estableciendo propiedades de conexión

Administración de usuarios y grupos mediante la API de servicio web managing-users-and-groups-using-the-web-service-api

Para administrar mediante programación usuarios, grupos y dominios mediante la API del servicio Directory Manager Service (servicio Web), realice las siguientes tareas:

  1. Incluir archivos de proyecto.

  2. Cree un cliente DirectoryManagerService.

    Crear un DirectoryManagerServiceService mediante el constructor de la clase de proxy.

  3. Invoque las operaciones de usuario o grupo adecuadas.

    Para buscar un usuario o grupo, invoque uno de los DirectoryManagerServiceService métodos del objeto para buscar principales (ya que un principal puede ser un usuario o un grupo). En el ejemplo siguiente, la variable findPrincipalsWithFilter método se llama mediante un filtro de búsqueda (a) PrincipalSearchFilter objeto). Cuando se utiliza un PrincipalSearchFilter objeto, las identidades locales solo se devuelven si la variable isLocal La propiedad se establece en true. Este comportamiento es diferente al que se produciría con la API de Java.

    note note
    NOTE
    Si no se especifica el número máximo de resultados en el filtro de búsqueda (a través del PrincipalSearchFilter.resultsMax ), se devuelve un máximo de 1000 resultados. Este comportamiento es diferente al que se produce con la API de Java, en la que 10 resultados es el máximo predeterminado. Además, los métodos de búsqueda como findGroupMembers no dará ningún resultado a menos que se especifique el número máximo de resultados en el filtro de búsqueda (por ejemplo, a través de la variable GroupMembershipSearchFilter.resultsMax field). Esto se aplica a todos los filtros de búsqueda que heredan de GenericSearchFilter clase. Para obtener más información, consulte Referencia de API de AEM Forms.

    Dado que el valor devuelto en este caso es un object[] conteniendo Principal objetos, iterar por el resultado y convertir el Principal objetos a User o Group objetos.

    Uso del resultante User o Group objeto (que heredan del objeto Principal interfaz), recupere la información que necesite en los flujos de trabajo. Por ejemplo, los valores de nombre de dominio y nombre canónico, en combinación, identifican de forma exclusiva un principal. Se recuperan invocando el método Principal del objeto domainName y canonicalName Campos, respectivamente.

    Para eliminar un usuario local, invoque el DirectoryManagerServiceService del objeto deleteLocalUser y pasar el identificador del usuario.

    Para eliminar un grupo local, invoque el DirectoryManagerServiceService del objeto deleteLocalGroup y pasar el identificador del grupo.

Consulte también

Resumen de los pasos

Invocar AEM Forms mediante MTOM

Administración de funciones y permisos managing-roles-and-permissions

En este tema se describe cómo puede utilizar la API del servicio Administrador de autorización (Java) para asignar, quitar y determinar funciones y permisos mediante programación.

En AEM Forms, una función es un grupo de permisos para acceder a uno o varios recursos de nivel del sistema. Estos permisos se crean mediante Administración de usuarios y los aplican los componentes del servicio. Por ejemplo, un administrador podría asignar la función "Autor del conjunto de directivas" a un grupo de usuarios. El Rights Management permitiría a los usuarios de ese grupo con esa función crear conjuntos de directivas a través de la consola de administración.

Existen dos tipos de funciones: funciones predeterminadas y funciones personalizadas. Funciones predeterminadas (roles del sistema) ya residen en AEM Forms. Se da por hecho que el administrador no puede eliminar ni modificar las funciones predeterminadas y que, por lo tanto, son inmutables. Por lo tanto, las funciones personalizadas creadas por el administrador, que posteriormente puede modificarlas o eliminarlas, son mutables.

Las funciones facilitan la administración de permisos. Cuando se asigna una función a un principal, se asigna automáticamente un conjunto de permisos a ese principal y todas las decisiones específicas relacionadas con el acceso para el principal se basan en ese conjunto general de permisos asignados.

Resumen de los pasos summary_of_steps-4

Para administrar funciones y permisos, realice los siguientes pasos:

  1. Incluir archivos de proyecto.
  2. Cree un cliente AuthorizationManagerService.
  3. Invoque las operaciones de rol o permiso correspondientes.

Incluir archivos de proyecto

Incluya los archivos necesarios en el proyecto de desarrollo. Si está creando una aplicación cliente mediante Java, incluya los archivos JAR necesarios. Si utiliza servicios web, asegúrese de incluir los archivos proxy.

Crear un cliente de AuthorizationManagerService

Antes de poder realizar mediante programación una operación AuthorizationManagerService de User Management, debe crear un cliente AuthorizationManagerService. Con la API de Java esto se logra creando un AuthorizationManagerServiceClient objeto.

Invocar las operaciones de rol o permiso adecuadas

Una vez creado el cliente de servicios, puede invocar las operaciones de rol o permiso. El cliente de servicio permite asignar, quitar y determinar funciones y permisos.

Consulte también

Administración de funciones y permisos mediante la API de Java

Administración de funciones y permisos mediante la API de servicio web

Incluir archivos de biblioteca Java de AEM Forms

Estableciendo propiedades de conexión

Inicios rápidos de API de User Manager

Administración de funciones y permisos mediante la API de Java managing-roles-and-permissions-using-the-java-api

Para administrar roles y permisos mediante la API del servicio Administrador de autorización (Java), realice las siguientes tareas:

  1. Incluir archivos de proyecto.

    Incluya archivos JAR de cliente, como adobe-usermanager-client.jar, en la ruta de clase del proyecto Java.

  2. Cree un cliente AuthorizationManagerService.

    Crear un AuthorizationManagerServiceClient mediante su constructor y pasando un objeto ServiceClientFactory que contiene las propiedades de conexión.

  3. Invoque las operaciones de rol o permiso correspondientes.

    Para asignar una función a un principal, invoque el AuthorizationManagerServiceClient del objeto assignRole y pasar los siguientes valores:

    • A java.lang.String objeto que contiene el identificador de rol
    • Una matriz de java.lang.String objetos que contienen los identificadores principales.

    Para quitar una función de una entidad de seguridad, invoque el AuthorizationManagerServiceClient del objeto unassignRole y pasar los siguientes valores:

    • A java.lang.String que contiene el identificador de rol.
    • Una matriz de java.lang.String objetos que contienen los identificadores principales.

Consulte también

Resumen de los pasos

Inicio rápido (modo SOAP): Administración de funciones y permisos mediante la API de Java

Incluir archivos de biblioteca Java de AEM Forms

Estableciendo propiedades de conexión

Administración de funciones y permisos mediante la API de servicio web managing-roles-and-permissions-using-the-web-service-api

Administre funciones y permisos mediante la API del servicio Administrador de autorización (servicio web):

  1. Incluir archivos de proyecto.

    Cree un proyecto de Microsoft .NET que utilice MTOM. Asegúrese de utilizar la siguiente definición de WSDL: http://localhost:8080/soap/services/AuthorizationManagerService?WSDL&lc_version=9.0.1.

    note note
    NOTE
    Reemplazar localhost con la dirección IP del servidor que aloja AEM Forms.
  2. Cree un cliente AuthorizationManagerService.

    • Crear un AuthorizationManagerServiceClient mediante su constructor predeterminado.

    • Crear un AuthorizationManagerServiceClient.Endpoint.Address mediante el uso del objeto System.ServiceModel.EndpointAddress constructor. Pase un valor de cadena que especifique el WSDL al servicio AEM Forms (por ejemplo, http://localhost:8080/soap/services/AuthorizationManagerService?blob=mtom.) No es necesario que utilice el lc_version atributo. Este atributo se utiliza al crear una referencia de servicio.

    • Crear un System.ServiceModel.BasicHttpBinding al obtener el valor de la variable AuthorizationManagerServiceClient.Endpoint.Binding field. Convierta el valor devuelto en BasicHttpBinding.

    • Configure las variables System.ServiceModel.BasicHttpBinding del objeto MessageEncoding field a WSMessageEncoding.Mtom. Este valor garantiza que se utiliza MTOM.

    • Habilite la autenticación HTTP básica realizando las siguientes tareas:

      • AEM Asigne el nombre de usuario del formulario de la al campo AuthorizationManagerServiceClient.ClientCredentials.UserName.UserName.
      • Asigne el valor de contraseña correspondiente al campo AuthorizationManagerServiceClient.ClientCredentials.UserName.Password.
      • Asignar el valor constante HttpClientCredentialType.Basic al campo BasicHttpBindingSecurity.Transport.ClientCredentialType.
      • Asignar el valor constante BasicHttpSecurityMode.TransportCredentialOnly al campo BasicHttpBindingSecurity.Security.Mode.
  3. Invoque las operaciones de rol o permiso correspondientes.

    Para asignar una función a un principal, invoque el AuthorizationManagerServiceClient del objeto assignRole y pasar los siguientes valores:

    • A string objeto que contiene el identificador de rol
    • A MyArrayOf_xsd_string que contiene los identificadores principales.

    Para quitar una función de una entidad de seguridad, invoque el AuthorizationManagerServiceService del objeto unassignRole y pasar los siguientes valores:

    • A string que contiene el identificador de rol.
    • Una matriz de string objetos que contienen los identificadores principales.

Consulte también

Resumen de los pasos

Invocar AEM Forms mediante MTOM

Autenticar usuarios authenticating-users

En este tema se describe cómo puede utilizar la API del servicio Administrador de autenticación (Java) para permitir que las aplicaciones cliente autentiquen a los usuarios mediante programación.

Es posible que se requiera autenticación de usuario para interactuar con una base de datos empresarial u otros repositorios empresariales que almacenen datos seguros.

Considere, por ejemplo, un escenario en el que un usuario introduce un nombre de usuario y una contraseña en una página web y envía los valores a un servidor de aplicaciones J2EE que aloja Forms. Una aplicación personalizada de Forms puede autenticar al usuario con el servicio Administrador de autenticación.

Si la autenticación se realiza correctamente, la aplicación tiene acceso a una base de datos empresarial segura. De lo contrario, se envía un mensaje al usuario para informarle de que no es un usuario autorizado.

El diagrama siguiente muestra el flujo lógico de la aplicación.

au_au_umauth_process

En la tabla siguiente se describen los pasos de este diagrama

Paso
Descripción
1
El usuario tiene acceso a un sitio web y especifica un nombre de usuario y una contraseña. Esta información se envía a un servidor de aplicaciones J2EE que aloja AEM Forms.
2
Las credenciales de usuario se autentican con el servicio Administrador de autenticación. Si las credenciales de usuario son válidas, el flujo de trabajo continúa con el paso 3. De lo contrario, se envía un mensaje al usuario para informarle de que no es un usuario autorizado.
3
La información del usuario y el diseño de un formulario se recuperan de una base de datos empresarial segura.
4
La información del usuario se combina con un diseño de formulario y este se procesa para el usuario.

Resumen de los pasos summary_of_steps-5

Para autenticar mediante programación a un usuario, realice los siguientes pasos:

  1. Incluir archivos de proyecto.
  2. Cree un cliente AuthenticationManagerService.
  3. Invoque la operación de autenticación.
  4. Si es necesario, recupere el contexto para que la aplicación cliente pueda reenviarlo a otro servicio de AEM Forms para la autenticación.

Incluir archivos de proyecto

Incluya los archivos necesarios en el proyecto de desarrollo. Si está creando una aplicación cliente mediante Java, incluya los archivos JAR necesarios. Si utiliza servicios web, asegúrese de incluir los archivos proxy.

Crear un cliente de AuthenticationManagerService

Para poder autenticar a un usuario mediante programación, debe crear un cliente AuthenticationManagerService. Al utilizar la API de Java de, cree un AuthenticationManagerServiceClient objeto.

Invocar la operación de autenticación

Una vez creado el cliente de servicios, puede invocar la operación de autenticación. Esta operación necesita información sobre el usuario, como su nombre y contraseña. Si el usuario no se autentica, se genera una excepción.

Recuperación del contexto de autenticación

Una vez autenticado el usuario, puede crear un contexto basado en el usuario autenticado. A continuación, puede utilizar el contenido para invocar otros servicios de AEM Forms. Por ejemplo, puede utilizar el contexto para crear una EncryptionServiceClient y cifrar un documento de PDF con una contraseña. Asegúrese de que el usuario autenticado tenga la función denominada Services User que es necesario para invocar un servicio de AEM Forms.

Consulte también

Incluir archivos de biblioteca Java de AEM Forms

Estableciendo propiedades de conexión

Inicios rápidos de API de User Manager

Cifrar documentos de PDF con una contraseña

Autenticar a un usuario mediante la API de Java authenticate-a-user-using-the-java-api

Autenticar a un usuario mediante la API del servicio Administrador de autenticación (Java):

  1. Incluir archivos de proyecto.

    Incluya archivos JAR de cliente, como adobe-usermanager-client.jar, en la ruta de clase del proyecto Java.

  2. Cree un cliente AuthenticationManagerServices.

    Crear un AuthenticationManagerServiceClient mediante su constructor y pasando un objeto ServiceClientFactory que contiene las propiedades de conexión.

  3. Invoque la operación de autenticación.

    Invoque el AuthenticationManagerServiceClient del objeto authenticate y pasar los siguientes valores:

    • A java.lang.String que contiene el nombre del usuario.
    • Una matriz de bytes (a) byte[] ) que contiene la contraseña del usuario. Puede obtener la byte[] invocando el objeto de java.lang.String del objeto getBytes método.

    El método authenticate devuelve un AuthResult , que contiene información sobre el usuario autenticado.

  4. Recupere el contexto de autenticación.

    Invoque el ServiceClientFactory del objeto getContext método, que devolverá un Context objeto.

    A continuación, invoque el Context del objeto initPrincipal y pase el AuthResult.

Autenticar a un usuario mediante la API de servicio web authenticate-a-user-using-the-web-service-api

Autenticar a un usuario mediante la API del servicio Administrador de autenticación (servicio web):

  1. Incluir archivos de proyecto.

  2. Cree un cliente AuthenticationManagerService.

    Crear un AuthenticationManagerServiceService mediante el constructor de la clase de proxy.

  3. Invoque la operación de autenticación.

    Invoque el AuthenticationManagerServiceClient del objeto authenticate y pasar los siguientes valores:

    • A string que contiene el nombre del usuario
    • Una matriz de bytes (a) byte[] ) que contiene la contraseña del usuario. Puede obtener la byte[] mediante la conversión de un string objeto que contiene la contraseña de byte[] utilizando la lógica que se muestra en el ejemplo siguiente.
    • El valor devuelto será un AuthResult , que se puede utilizar para recuperar información sobre el usuario. En el siguiente ejemplo, la información del usuario se recupera obteniendo primero el AuthResult del objeto authenticatedUser y, posteriormente, obteniendo el resultado User del objeto canonicalName y domainName campos.

Consulte también

Invocar AEM Forms mediante MTOM

Invocar AEM Forms mediante SwaRef

Sincronización de usuarios mediante programación programmatically-synchronizing-users

Puede sincronizar usuarios mediante programación utilizando la API de administración de usuarios. Al sincronizar usuarios, está actualizando AEM Forms con los datos de usuario que se encuentran en su repositorio de usuarios. Por ejemplo, supongamos que agrega nuevos usuarios al repositorio de usuarios. AEM Después de realizar una operación de sincronización, los nuevos usuarios se convierten en usuarios de formularios de la aplicación de la aplicación de la manera más rápida. Además, los usuarios que ya no estén en su repositorio de usuarios se eliminarán de AEM Forms.

El diagrama siguiente muestra la sincronización de AEM Forms con un repositorio de usuario.

ps_ps_umauth_sync

En la tabla siguiente se describen los pasos de este diagrama

Paso
Descripción
1
Una aplicación cliente solicita que AEM Forms realice una operación de sincronización.
2
AEM Forms realiza una operación de sincronización.
3
Se ha actualizado la información del usuario.
4
Un usuario puede ver la información actualizada del usuario.

Resumen de los pasos summary_of_steps-6

Para sincronizar usuarios mediante programación, realice los siguientes pasos:

  1. Incluir archivos de proyecto.
  2. Cree un cliente UserManagerUtilServiceClient.
  3. Especifique el dominio de empresa.
  4. Invoque la operación de autenticación.
  5. Determine si la operación de sincronización ha finalizado

Incluir archivos de proyecto

Incluya los archivos necesarios en el proyecto de desarrollo. Si está creando una aplicación cliente mediante Java, incluya los archivos JAR necesarios. Si utiliza servicios web, asegúrese de incluir los archivos proxy.

Crear un cliente de UserManagerUtilServiceClient

Para poder sincronizar usuarios mediante programación, debe crear un UserManagerUtilServiceClient objeto.

Especificar el dominio de empresa

Antes de realizar una operación de sincronización mediante la API de administración de usuarios, debe especificar el dominio de empresa al que pertenecen los usuarios. Puede especificar uno o varios dominios de empresa. Para poder realizar mediante programación una operación de sincronización, debe configurar un dominio de empresa mediante la consola de administración. (Consulte ayuda de administración.)

Invocar la operación de sincronización

Después de especificar uno o varios dominios de empresa, puede realizar la operación de sincronización. El tiempo que se tarda en realizar esta operación depende del número de registros de usuario que hay en el repositorio de usuario.

Determine si la operación de sincronización ha finalizado

Después de realizar mediante programación una operación de sincronización, puede determinar si la operación ha finalizado.

Consulte también

Incluir archivos de biblioteca Java de AEM Forms

Estableciendo propiedades de conexión

Inicios rápidos de API de User Manager

Cifrar documentos de PDF con una contraseña

Sincronización mediante programación de usuarios mediante la API de Java programmatically-synchronizing-users-using-the-java-api

Sincronizar usuarios mediante la API de administración de usuarios (Java):

  1. Incluir archivos de proyecto.

    Incluya archivos JAR de cliente, como adobe-usermanager-client.jar y adobe-usermanager-util-client.jar, en la ruta de clase del proyecto Java.

  2. Cree un cliente UserManagerUtilServiceClient.

    Crear un UserManagerUtilServiceClient mediante su constructor y pasando un objeto ServiceClientFactory que contiene las propiedades de conexión.

  3. Especifique el dominio de empresa.

    • Invoque el UserManagerUtilServiceClient del objeto scheduleSynchronization para iniciar la operación de sincronización de usuarios.
    • Crear un java.util.Set mediante el uso de una HashSet constructor. Asegúrese de especificar lo siguiente String como el tipo de datos. Esta Java.util.Set almacena los nombres de dominio a los que se aplica la operación de sincronización.
    • Para que se agregue cada nombre de dominio, invoque el java.util.Set método add del objeto y pase el nombre de dominio.
  4. Invoque la operación de sincronización.

    Invoque el ServiceClientFactory del objeto getContext método, que devolverá un Context objeto.

    A continuación, invoque el Context del objeto initPrincipal y pase el AuthResult.

Consulte también

Sincronización de usuarios mediante programación

Incluir archivos de biblioteca Java de AEM Forms

Estableciendo propiedades de conexión

recommendation-more-help
19ffd973-7af2-44d0-84b5-d547b0dffee2