Implementación de Búsqueda de Posts con Servicios en Rails
Clase 17 de 33 • Curso de Creación de APIs con Ruby on Rails
Contenido del curso
Proyecto
- 3

Creación de APIs con Rails: Proyecto Blog API paso a paso
04:37 min - 4

Configuración de Gemas para Pruebas en Proyectos Rails
06:26 min - 5

Configuración de Gemas en Proyectos Rails: Arspec, Factory Bot y Database Cleaner
07:25 min - 6

Implementación de un Health Check Endpoint en API con RSpec
12:28 min - 7

Diseño de Casos de Uso y Diagramas de Entidad para Aplicaciones
03:16 min - 8

Diagrama entidad relación: usuario y post
01:41 min - 9

Modelado de Aplicaciones con TDD en Rails
05:59 min - 10

Validaciones y Pruebas TDD en Rails: Modelos USR y Post
07:07 min - 11

Implementación de Endpoints para Listar y Mostrar Posts con TDD
15:12 min - 12

Implementar controlador Posts con TDD
10:34 min - 13

Pruebas TDD para crear y actualizar posts
10:12 min - 14

Implementación de Métodos y Manejo de Excepciones en Rails API
10:23 min - 15

Active Model serializers: control total de JSON en Rails
06:03 min - 16

Búsqueda y Filtrado de Posts por Título con TDD
05:57 min - 17

Implementación de Búsqueda de Posts con Servicios en Rails
Viendo ahora - 18

Problema N+1 en Rails: Detección y Solución Eficaz
04:40 min - 19

Identificación y solución del problema N+1 en Rails
06:20 min - 20

Flujo de Autenticación en APIs con Tokens y Proveedores
05:29 min - 21

Tests con RSpec para autenticación de tokens
12:17 min - 22

Autenticación con Tokens: Implementación en Rails API
05:53 min - 23

Autenticación de Usuarios en Controladores Rails
09:19 min - 24

Autenticación y Seguridad en CRUD de Posts en Rails
09:17 min - 25

Pruebas de Creación y Actualización con Autenticación en Rails
14:21 min - 26

Probando API Ruby on Rails con Postman
10:43 min - 27

Caching en Aplicaciones Web: Funciones y Niveles
07:15 min - 28

Aceleración de Búsquedas en Rails con Caching
08:23 min - 29

Background Jobs en Rails: Conceptos y Funcionalidades
05:45 min - 30

Procesamiento en Background y Envío de Correos con Rails
09:45 min - 31

Envío de Correos en Rails con ActionMailer y Background Jobs
11:06 min - 32
Autenticación y Autorización con JWT y Auth0 en Aplicaciones Web
03:48 min
Cierre
Implementa una búsqueda de posts en Rails que pase pruebas y mantenga un controlador ligero. Aquí verás cómo filtrar solo publicaciones publicadas, delegar la lógica a un service y usar SQL con comodines para lograr coincidencias flexibles, dejando la puerta abierta a la escalabilidad.
¿Cómo se implementa la búsqueda de posts publicados en Rails?
Para iniciar, la lógica vive en el método index del controlador. Primero se filtran los posts publicados. Luego, se toma el parámetro search de la petición y se valida que no sea nil y que esté present?. Si hay búsqueda, se delega al servicio.
# app/controllers/posts_controller.rb
class PostsController < ApplicationController
def index
posts = Post.published
query = params[:search]
if !query.nil? && query.present?
posts = PostSearchService.search(posts, query)
end
@posts = posts
end
end
- Filtrar siempre por publicados primero.
- Validar
nilypresent?antes de buscar. - Delegar la lógica al service para mantener el controller limpio.
- Asegurar que las pruebas pasen antes de continuar.
¿Cómo se construye el filtro con SQL LIKE?
La búsqueda compara el title con el query usando LIKE y comodines %. La forma %consulta% indica: cualquier texto antes, la consulta en medio y cualquier texto después.
# app/servicios/post_search_service.rb
class PostSearchService
def self.search(current_posts, query)
current_posts.where("title LIKE '%#{query}%' ")
end
end
LIKEpermite coincidencias parciales en el título.%funciona como comodín de búsqueda.- La consulta se aplica sobre el conjunto ya filtrado por publicados.
¿Por qué mover la lógica a un servicio de búsqueda?
Centralizar la lógica en un servicio simplifica el controller y encapsula la lógica de negocio. Esto facilita el mantenimiento y futuras modificaciones sin tocar el controlador.
¿Qué ventajas aporta esta arquitectura?
- Controlador ligero y fácil de leer.
- Lógica de búsqueda encapsulada en una sola clase.
- Cambios futuros se aplican en un único lugar.
- Mejora la organización del código y las pruebas automatizadas.
¿Qué hace el método search del servicio?
Recibe la colección actual de posts (ya filtrada por publicados) y el query. Devuelve los registros cuyo title coincide parcialmente con la cadena de búsqueda gracias a LIKE y %.
- Método de clase:
self.search. - Parámetros:
current_postsyquery. - Retorno: relación filtrada lista para el controller.
¿Cómo escalar la búsqueda y evitar problemas futuros?
Si el volumen de peticiones crece, conviene sustituir la búsqueda basada en base de datos por un servicio especializado como Elasticsearch. Las bases de datos relacionales no están diseñadas para queries de texto a gran escala, y migrar será sencillo porque la lógica está aislada en el service.
- Sustitución transparente del motor de búsqueda.
- Mejor rendimiento con alto tráfico.
- Próximo tema: el problema de n más uno y su impacto en consultas.
¿Te gustaría ver variantes del service o casos de prueba para esta búsqueda? Cuéntame qué escenario quieres cubrir y lo trabajamos juntos.