odoo-go-client
Cliente en Go para conectarse a Odoo utilizando XML-RPC. Esta librería permite realizar operaciones CRUD, mapear datos a estructuras Go y procesar grandes volúmenes de datos utilizando goroutines.
Tabla de Contenidos
Características
- Conexión a Odoo mediante XML-RPC.
- Autenticación y manejo de sesiones.
- Operaciones CRUD (Crear, Leer, Actualizar, Eliminar).
- Mapeo de datos a estructuras Go.
- Procesamiento paralelo utilizando goroutines y canales.
- Manejo de errores personalizado.
Requisitos
- Go 1.13 o superior.
- Acceso a una instancia de Odoo con las credenciales adecuadas.
- Las siguientes dependencias de Go:
github.com/kolo/xmlrpc
github.com/joho/godotenv
github.com/mitchellh/mapstructure
Instalación
Clona este repositorio o copia los archivos necesarios en tu proyecto.
git clone https://github.com/tuusuario/odoo-go-client.git
cd odoo-go-client
Instala las dependencias:
go get github.com/kolo/xmlrpc
go get github.com/joho/godotenv
go get github.com/mitchellh/mapstructure
Configuración
Crea un archivo .env
en el directorio raíz del proyecto con las siguientes variables:
DATABASE=nombre_de_tu_base_de_datos
USERNAME=tu_usuario
PASSWORD=tu_contraseña
URL=http://tu_dominio_odoo.com
Asegúrate de reemplazar los valores con tus credenciales y URL de Odoo.
Uso
Inicializar el Cliente
Importa los paquetes necesarios y crea una instancia de OdooClient
:
package main
import (
"fmt"
"odoo-go-client" // Importa tu paquete adecuadamente
)
func main() {
client, err := NewOdooClient(".env")
if err != nil {
fmt.Println("Error al inicializar el cliente Odoo:", err)
return
}
// Ahora puedes usar el cliente para realizar operaciones
}
Operaciones CRUD
Crear un Registro
data := map[string]interface{}{
"name": "Nuevo Cliente",
"email": "cliente@example.com",
}
id, err := client.Create("res.partner", data)
if err != nil {
fmt.Println("Error al crear el registro:", err)
return
}
fmt.Println("Registro creado con ID:", id)
Leer Registros
domain := []interface{}{[]interface{}{"is_company", "=", true}}
fields := []string{"id", "name", "email"}
records, err := client.SearchRead("res.partner", domain, fields)
if err != nil {
fmt.Println("Error al leer los registros:", err)
return
}
for _, record := range records {
fmt.Println("Registro:", record)
}
Actualizar un Registro
updateData := map[string]interface{}{
"email": "nuevo.email@example.com",
}
success, err := client.Update("res.partner", []int{id}, updateData)
if err != nil || !success {
fmt.Println("Error al actualizar el registro:", err)
return
}
fmt.Println("Registro actualizado exitosamente")
Eliminar un Registro
success, err := client.Delete("res.partner", []int{id})
if err != nil || !success {
fmt.Println("Error al eliminar el registro:", err)
return
}
fmt.Println("Registro eliminado exitosamente")
Mapeo de Modelos
Define estructuras que representen tus modelos de Odoo y utiliza la función MapToStruct
para mapear los datos.
Definir una Estructura
type ResPartner struct {
ID int `json:"id"`
Name string `json:"name"`
Email string `json:"email"`
IsCompany bool `json:"is_company"`
}
Mapear Datos a la Estructura
for _, record := range records {
var partner ResPartner
if err := MapToStruct(record, &partner); err != nil {
fmt.Println("Error al mapear el registro:", err)
continue
}
fmt.Println("Partner:", partner)
}
Procesamiento en Paralelo con Goroutines
Si necesitas procesar muchos datos, puedes utilizar goroutines y canales para mejorar el rendimiento.
Ejemplo de Procesamiento en Paralelo
import (
"sync"
)
func main() {
// ... Inicializar cliente ...
// Obtener IDs de los registros
domain := []interface{}{}
ids, err := client.Search("res.partner", domain)
if err != nil {
fmt.Println("Error al obtener IDs:", err)
return
}
// Procesar en lotes
batchSize := 100
var batches [][]int
for batchSize < len(ids) {
ids, batches = ids[batchSize:], append(batches, ids[0:batchSize:batchSize])
}
batches = append(batches, ids)
var wg sync.WaitGroup
partnersChannel := make(chan ResPartner, len(ids))
for _, batch := range batches {
wg.Add(1)
go func(batch []int) {
defer wg.Done()
domain := []interface{}{[]interface{}{"id", "in", batch}}
fields := []string{"id", "name", "email", "is_company"}
records, err := client.SearchRead("res.partner", domain, fields)
if err != nil {
fmt.Println("Error al obtener registros:", err)
return
}
for _, record := range records {
var partner ResPartner
if err := MapToStruct(record, &partner); err != nil {
fmt.Println("Error al mapear el registro:", err)
continue
}
partnersChannel <- partner
}
}(batch)
}
go func() {
wg.Wait()
close(partnersChannel)
}()
for partner := range partnersChannel {
fmt.Println("Partner:", partner)
}
}
Ejemplos
Consulta el archivo main.go
para ver ejemplos completos de cómo utilizar la librería, incluyendo operaciones CRUD y procesamiento paralelo.
Estructura del Proyecto
odoo-go-client/
├── client.go // Contiene OdooClient y métodos
├── errors.go // Tipos de error personalizados
├── models.go // Definiciones de modelos y mapeadores
├── utils.go // Funciones utilitarias
├── main.go // Uso de ejemplo
├── .env // Variables de entorno (no incluir en control de versiones)
└── README.md // Instrucciones de uso (este archivo)
Notas Importantes
- Manejo de Errores: Siempre maneja los errores devueltos por las funciones para evitar comportamientos inesperados.
- Tipos de Datos: Verifica los tipos de datos al mapear los resultados. Algunos campos pueden ser
int64
, float64
, etc.
- Campos Nulos: Ten cuidado con los campos que pueden ser
nil
o no estar presentes en los datos retornados.
- Concurrencia: Al utilizar goroutines, asegúrate de manejar adecuadamente la sincronización y los recursos compartidos.
- Variables de Entorno: No incluyas el archivo
.env
en tu control de versiones ya que contiene información sensible.
Contribuciones
Las contribuciones son bienvenidas. Si deseas mejorar la librería o agregar nuevas funcionalidades, por favor:
- Haz un fork del proyecto.
- Crea una rama para tu nueva funcionalidad (
git checkout -b nueva-funcionalidad
).
- Realiza tus cambios y haz commit (
git commit -am 'Agregar nueva funcionalidad'
).
- Envía tus cambios a GitHub (
git push origin nueva-funcionalidad
).
- Crea un Pull Request.
Licencia
Este proyecto está bajo la Licencia MIT. Consulta el archivo LICENSE
para más detalles.