Búsqueda avanzada de usuarios
Usar directamente la Management API para aprovechar las condiciones avanzadas de búsqueda de usuarios.
Realizar una solicitud de búsqueda
Usa GET /api/users
para buscar usuarios. Ten en cuenta que es una Management API que requiere autenticación como las demás. Consulta Interactuar con Management API para la receta de interacción.
Ejemplo
Solicitud
curl \
--location \
--request GET \
'http://<your-logto-endpoint>/api/users?search=%25alice%25'
Respuesta
Un array de entidades User
.
[
{
"id": "MgUzzDsyX0iB",
"username": "alice_123",
"primaryEmail": "alice@some.email.domain",
"primaryPhone": null,
"name": null,
"avatar": null
// ...
}
]
Parámetros
Una solicitud de búsqueda consta de las siguientes claves de parámetros:
- Palabras clave de búsqueda:
search
,search.*
- Modo de búsqueda para campos:
mode
,mode.*
(valor predeterminado'like'
, disponibles['exact', 'like', 'similar_to', 'posix']
) - Modo conjunto:
joint
ojointMode
(valor predeterminado'or'
, disponibles['or', 'and']
) - Es sensible a mayúsculas y minúsculas:
isCaseSensitive
(valor predeterminadofalse
)
Esta API tiene paginación habilitada.
Vamos a revisarlos a través de algunos ejemplos. Todos los parámetros de búsqueda se formatearán como un constructor de URLSearchParams
.
El modo de búsqueda está configurado en like
por defecto, que utiliza coincidencia aproximada de cadenas ("búsqueda difusa").
Todos los modos de búsqueda difusa solo admiten la coincidencia de un valor por campo. Si necesitas coincidir múltiples valores para un solo campo, debes usar el modo "exacto". Consulta Coincidencia exacta y sensibilidad a mayúsculas y minúsculas para más detalles.
Búsqueda difusa básica
Si deseas realizar una búsqueda difusa en todos los campos disponibles, simplemente proporciona un valor para la clave search
. Utilizará el operador like
internamente:
new URLSearchParams([['search', '%foo%']]);
Esta búsqueda iterará sobre todos los campos disponibles en una búsqueda de usuario, es decir, id
, primaryEmail
, primaryPhone
, username
, name
.
Especificar campos
¿Qué pasa si deseas limitar la búsqueda solo en name
? Para buscar a alguien que incluya foo
en su nombre, simplemente usa el símbolo .
para especificar el campo:
new URLSearchParams([['search.name', '%foo%']]);
Recuerda que los campos anidados no son compatibles, por ejemplo, search.name.first
resultará en un error.
También puedes especificar múltiples campos al mismo tiempo:
new URLSearchParams([
['search.name', '%foo%'],
['search.primaryEmail', '%@gmail.com'],
]);
Significa buscar usuarios que tengan foo
en el nombre O su correo electrónico termine con @gmail.com
.
Cambiar el modo conjunto
Si deseas que la API solo devuelva el resultado que satisfaga TODAS las condiciones, establece el modo conjunto en and
:
new URLSearchParams([
['search.name', '%foo%'],
['search.primaryEmail', '%@gmail.com'],
['joint', 'and'],
]);
Significa buscar usuarios que tengan foo
en el nombre Y su correo electrónico termine con @gmail.com
.
Coincidencia exacta y sensibilidad a mayúsculas y minúsculas
Supongamos que deseas buscar cuyo nombre sea exactamente "Alice". Puedes establecer mode.name
para usar coincidencia exacta.
new URLSearchParams([
['search.name', 'Alice'],
['mode.name', 'exact'],
]);
Puedes encontrar que tiene el mismo efecto al usar el modo like
(predeterminado) vs. especificar exact
. Una diferencia es que el modo exact
utiliza =
para comparar mientras que like
utiliza like
o ilike
. Teóricamente =
debería tener un mejor rendimiento.
Además, en el modo exact
, puedes pasar múltiples valores para la coincidencia, y se conectarán con or
:
new URLSearchParams([
['search.name', 'Alice'],
['search.name', 'Bob'],
['mode.name', 'exact'],
]);
Coincidirá con los usuarios con nombre "Alice" O "Bob".
Por defecto, la búsqueda no distingue entre mayúsculas y minúsculas. Para ser más preciso, establece la búsqueda como sensible a mayúsculas y minúsculas:
new URLSearchParams([
['search.name', 'Alice'],
['search.name', 'Bob'],
['mode.name', 'exact'],
['isCaseSensitive', 'true'],
]);
Ten en cuenta que isCaseSensitive
es una configuración global. Por lo tanto, TODOS los campos la seguirán.
Expresión regular (RegEx)
PostgreSQL admite dos tipos de expresiones regulares, similar a y posix. Establece mode
en similar_to
o posix
para buscar por expresiones regulares:
new URLSearchParams([
['search', '^T.?m Scot+$'],
['mode', 'posix'],
]);
Nota: El modo similar_to solo funciona en búsquedas sensibles a mayúsculas y minúsculas.
Sobrescribir el modo de coincidencia
Por defecto, todas las palabras clave heredarán el modo de coincidencia de la búsqueda general:
new URLSearchParams([
['search', '^T.?m Scot+$'],
['mode', 'posix'],
['search.primaryEmail', 'tom%'], // Modo Posix
['joint', 'and'],
]);
Para sobrescribir un campo específico:
new URLSearchParams([
['search', '^T.?m Scot+$'],
['mode', 'posix'],
['search.primaryEmail', 'tom%'], // Modo Like
['mode.primaryEmail', 'like'],
['search.phone', '0{3,}'], // Modo Posix
['joint', 'and'],
]);