API Web Services para Integración Talana – Documentación de Web Sevices Control de Versiones Fecha Autor Observaciones 20/04/2018 José Antonio Akel Versión Inicial 25/04/2018 José Antonio Akel Formatos de Serialización 4/05/2018 José Antonio Akel Actualización de ausentismos 8/05/2018 José Antonio Akel We Service Centralización Contable 11/05/2018 Maximiliano Opitz Actualización servicios de persona, personaEmpresa y ausentismos 31/08/2018 Maximiliano Opitz Se agrego es especificación del detalle de persona para la creación de persona 11/10/2018 José Antonio Akel Servicios de Marcas de asistencia 12/10/2018 Sebastián Díaz Servicio de Asignación de Items a Persona 19/10/2018 Sebastián Díaz Servicio de creación de documentos para personas 15/11/2018 José Antonio Akel Ejemplos de código 30/11/2018 Alexander Gonzalez Servicios resumidos para contratos, ausencias, vacaciones y días administrativos 17/12/2018 Sebastián Díaz Filtros para servicios de contratos 17/12/2018 José Antonio Akel “empresa” como parámetro en los servicios 18/12/2018 Sebastián Díaz Filtros empleado en vacaciones, ausentismo, días administrativos 21/12/2018 José Antonio Akel Actualización de método de contratos resumidos 26/12/2018 Maximiliano Opitz Se agrego un ejemplo de la inserción de marcas 26/12/2018 Sebastián Díaz Filtros de empleados para vacaciones, ausentismos y contratos resumidos 27/12/2018 Maximiliano Opitz Ejemplo del uso de los filtros en el servicio que devuelve las marcas 08/01/2019 Alexander Gonzalez “rolPrivado” como parámetro en servicio contratos resumido 05/02/2019 José Antonio Akel Método Dïas Trabajados 19/03/2019 Maximiliano Opitz Filtros de “rut” y “nombre” en el servicio de “persona” Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 2 de 47 Talana – Documentación de Web Sevices Tabla de Contenidos Antecedentes...................................................................................................................................... 5 Autenticación...................................................................................................................................... 6 Formatos de salida............................................................................................................................. 7 Filtros.................................................................................................................................................. 8 EndPoints........................................................................................................................................... 8 Empresas con acceso.................................................................................................................. 8 Persona........................................................................................................................................ 9 Contratos.................................................................................................................................... 12 Filtros.......................................................................................................................................... 17 Los siguientes parámetros pueden ser pasados por url para filtrar la lista de contratos:............17 modificado_desde (fecha formato “YYYY-MM-DD”): contratos creados o modificados superiores a la fecha.................................................................................................................................... 17 modificado_hasta (fecha formato “YYYY-MM-DD”): contratos creados o modificados inferiores a la fecha....................................................................................................................................... 17 Ejemplo:..................................................................................................................................... 17 https://talana.com/es/api/contratos/?modificado_desde=2018-10-25.........................................17 Contratos Resumido................................................................................................................... 18 Vacaciones................................................................................................................................. 19 Filtros.......................................................................................................................................... 19 Los siguientes parámetros pueden ser pasados por url para filtrar la lista de contratos:............19 empleado (id del empleado): solo las vacaciones del empleado especificado............................19 Ejemplo:..................................................................................................................................... 19 https://talana/es/api/vacacionesSolicitud/?empleado=1..............................................................19 Vacaciones Resumido................................................................................................................ 20 Ausentismo................................................................................................................................. 21 Filtros.......................................................................................................................................... 23 Los siguientes parámetros pueden ser pasados por url para filtrar la lista de contratos:............23 empleado (id del empleado): solo las ausencias del empleado especificado.............................23 Ejemplo:..................................................................................................................................... 23 https://talana/es/api/personaAusencia/?empleado=1.................................................................23 Ausentismo Resumido................................................................................................................ 24 Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 3 de 47 Talana – Documentación de Web Sevices Centralización Contable.............................................................................................................. 25 Asignación de Items de pago......................................................................................................26 Creación de documentos par personas......................................................................................28 Días Administrativos................................................................................................................... 29 Filtros.......................................................................................................................................... 29 Los siguientes parámetros pueden ser pasados por url para filtrar la lista de contratos:............29 empleado (id del empleado): solo los días administrativos del empleado especificado..............29 Ejemplo:..................................................................................................................................... 29 https://talana/es/api/diaAdministrativoSolicitud/?empleado=1....................................................29 Días Administrativos Resumido..................................................................................................30 Turno.......................................................................................................................................... 31 Días de Turno Semanal.............................................................................................................. 32 Días de Turno Manual................................................................................................................ 33 Asignación de Personas a Turnos..............................................................................................34 Inyección (y visualización) de marcas........................................................................................35 Asignación de tarjetas a personas..............................................................................................36 Turnos y horarios asignados por Trabajador...............................................................................37 Otros Modelos............................................................................................................................ 38 Ejemplos de Código.......................................................................................................................... 40 Python........................................................................................................................................ 40 Java............................................................................................................................................ 41 PHP............................................................................................................................................ 44 Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 4 de 47 Talana – Documentación de Web Sevices Antecedentes Talana, dadas sus características como SaaS, no ofrece como opción la conexión directa a base de datos, que es el mecanismo que se utilizaba con el proveedor anterior. En su lugar, se utilizan Web Services REST, con mensajes serializados en formato Json, tanto para la lectura como para la escritura de objetos. El objetivo de este documento es entregar los antecedentes necesarios que permitan construir interfaces de integración entre sistemas de información de nuestros clientes y los web services de Talana. Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 5 de 47 Talana – Documentación de Web Sevices Autenticación Los WebServices son servicios REST con los cuales se pueden gestionar las solicitudes de días libres para los empleados, ya sea para consultar, crear, modificar o eliminar datos. Esta información necesita estar estructurada en formato JSON y los métodos que permite son: • Listar (GET) • Crear (POST) • Modificar (PUT / PATCH) • Eliminar (DELETE) Para utilizar cualquiera de los métodos previamente listados es necesario enviar un “token” de autenticación en cada “request” que se realice hacia la plataforma. Para obtener este “token” de autenticación debemos realizar una petición como en el siguiente ejemplo: URL: https://talana.com/es/api/api-token-auth/ MÉTODO: POST BODY: {“username”: “[email protected]”, “password”: “demo”} Donde: “[email protected]” es el nombre de usuario de la persona a autenticar. “demo” es la clave de la persona a autenticar. El formato del contenido del BODY, es JSON. La respuesta de la anterior consulta es un “String” en formato JSON que contiene el “token”: {“token”: “ehe657583hgyydt565729g0ddjdg65585hgyyd65”} Finalmente para su uso, es necesario agregar el “token” en el encabezado de cada consulta: Authorization: Token ehe657583hgyydt565729g0ddjdg65585hgyyd65 Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 6 de 47 Talana – Documentación de Web Sevices Formatos de salida La librería utilizada para la construcción de los servicios permite generar datos en múltiples formatos. El serializador se selecciona por defecto en base al content-type de la solicitud. De esta forma, si se visitan mediante un navegador web, los servicios entregar HTML. Pero si se consumen con un cliente de WS como Postman, que solicita datos en text/json, escoge el serializador de manera acorde. Es posible también “forzar” el formato de salida, enviando como parámetro en la URL el formato. Por ejemplo, para descargar el listado de bancos desde Talana en formato XML, se puede consumir la siguiente URL: https://talana.com/es/api/banco/?format=xml Los formatos soportados en estos momentos son: • json • jsonp • xml • api Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 7 de 47 Talana – Documentación de Web Sevices Filtros Algunos de los servicios aceptan filtros como parámetros GET. Los servicios que entrega colecciones de objetos asociados a una empresa en específica (como los de “contratos” y “personas”, en contraposición con el de “bancos”, que es común a todas las empresas) aceptan como parámetro el ID de la empresa de la cual se requieren datos. El servicio devolverá los datos de esa empresa, siempre y cuando el usuario cuente con los permisos para acceder a esa empresa. Ejemplo: https://talana.com/es/api/persona/?empresa=1 y https://talana.com/es/api/persona/?empresa=5 entregarán las personas de las empresas con ID 1 y 5 respectivamente EndPoints Si bien Talana expone muchísimos servicios, para efectos de las integraciones típicas basta con considerar los que se exponen a continuación: Empresas con acceso https://talana.com/es/api/empresas-que-puedo-administrar Entrega el listado de las empresas a las cuales el usuario actual tiene acceso Métodos aceptados: GET Devuelve un listado de empresas y sus razones sociales de acuerdo a la siguiente estructura: Propiedad Tipo Get Descripción id integer ID único nombre string Nombre de la empresa vigente boolean Si la empresa está o no vigente url string URL de la empresa Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 8 de 47 Talana – Documentación de Web Sevices logo string URL del logo de la empresa, para utilizar en los documentos firma string URL de la firma del representante legal de la empresa, para utilizar en los documentos razones_sociales list[razonSocial] Listado de objetos [razonSocial] Persona https://talana.com/es/api/persona/{id} El maestro de personas. Cada persona puede tener uno o más contratos a lo largo de la relación laboral con una empresa, pero sólo tendrá una ficha. Métodos aceptados: GET, POST, PUT Para los métodos PUT y POST, la información a enviar deber estar en el “body” del “request” en formato JSON. Filtros Se puede ffiltrar por “rut” y/o por “nombre” Ej: https://talana.com/es/api/persona/?rut=17798529-5&nombre=Maximiliano Los objetos de persona tienen las siguientes propiedades: Propiedad Tipo Get id integer fechaCreacion datetime GET Si Fecha y hora de creación fechaModificacion datetime GET Si Fecha y hora de creación GET, POST, No Rut, sin puntos, con guión y DV No Nombre No Apellido Paterno No Apellido Materno rut string Tipo POST, PUT Uso Opcional Descripción ID único string PUT nombre string string GET, POST, PUT apellidoPaterno string string GET, POST, PUT apellidoMaterno string string GET, POST, Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 9 de 47 Talana – Documentación de Web Sevices PUT sexo char(1) char(1) GET, POST, Si M/F Si Fecha de Nacimiento Si País, como código ISO PUT fechaNacimiento date date GET, POST, PUT nacionalidad string string GET, POST, PUT username string string permisos list[permisos] email string string Nombre de usuario GET Si Lista de permisos adicionales GET, POST, Si Email principal GET, POST Si Detalles personales GET Si Lista de Identificadores PUT detalles list[detalles] externalReference list[externalRef erence] Objeto "Detalle" que se usara en la creación de personas Propiedad Tipo POST Uso Opcional id Descripción ID único fechaCreacion date GET, POST Si Fecha y hora de creación validoDesde date GET, POST No Fecha desde la cual es valido el detalle email string GET, POST No Email principal del detalle telefono string GET, POST No El teléfono del detalle de la persona celular string GET, POST, No Celular del detalle de la persona PUT direccionCalle string GET, POST Si Calle del domicilio direccionNumero String GET, POST No Numero del domicilio Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 10 de 47 Talana – Documentación de Web Sevices direccionDepartamento String GET, POST No Numero del departamento estadoCivil String GET, POST No Estado civil de la persona nivelEducacional String GET, POST No Nivel educacional de la persona colegio String GET, POST No Colegio de la persona InstitucionEstudiosSuperi String ores GET, POST No Institución superior de la profesion String GET, POST No Profesión de la persona observaciones String GET, POST No Agregar cualquier observación persona sobre la persona contratosDeEmergencia String GET, POST No Agregar cualquier contrato de emergencia de la persona Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 11 de 47 Talana – Documentación de Web Sevices Contratos https://talana.com/es/api/contrato/{id} El o los contratos de los trabajadores, y sus condiciones contractuales. Muestra los contratos y condiciones activas al día de hoy. Métodos aceptados: GET, POST, PUT. Para los métodos PUT y POST, la información a enviar deber estar en el “body” del “request” en formato JSON. Los objetos de tipo contrato tienen las siguientes propiedades: Propiedad Tipo GET id integer empleado integer POST, PUT integer Uso Opcional Descripción GET No Id único GET, POST, No Puntero a objeto [persona] Si Código del contrato Si Fecha de Creación original de estas PUT codigo string string GET, POST, PUT fechaCreacion datetime GET condiciones contractuales tipoContrato integer integer GET, POST, Si especifican detalles en tipoContratoDetails PUT empleadorRazonSoc integer integer ial cargo GET, POST, Puntero a objeto [tipoContrato]. Se No Puntero a objeto [razonSocial] PUT string string GET, POST, Si PUT fechaContratacion date date GET, POST, Si Fecha de contratación original del trabajador No Desde cuándo rigen estas condiciones PUT desde date date GET, POST, contractuales PUT hasta date date GET, POST, Si Puede estar vacío PUT unidadOrganizacion Hasta cuándo rigen estas condiciones. integer POST, PUT Si Puntero a objeto [unidadOrganizacional] integer GET, POST, Si Objeto sucursal al sucursal [sucursal] Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 12 de 47 Talana – Documentación de Web Sevices PUT grupos list[grupo] list[integer] GET, POST, Si persona PUT anexo string string GET, POST, Lista de los grupos al cual pertenece la Si PUT centroCosto jornada [centroCosto integer GET, POST, ] PUT integer integer GET, POST, Si Objeto centroCosto Si Puntero a objeto [jornada] Si Cantidad de horas semanales de trabajo PUT horasDeLaJornada integer integer GET, POST, PUT codigoFranquiciaSe integer integer nce nivelSence GET, POST, Si PUT string string GET, POST, Si PUT sindicato integer integer GET, POST, Si Puntero a objeto [sindicato] Si Puntero a objeto [persona] Si N=No | S=Si | C=Si, pero cotiza | A = Activo > PUT jefe integer integer GET, POST, PUT esPensionado char(1) char(1) GET, POST, 65 años | X = Expatriado PUT tramoAsignacionPre integer integer visional Si Puntero a objeto [tramoAsignacionFamiliar] Si Puntero a objeto [ubicacionGeografica] Si Si es que tiene asignación maternal Si Puntero a objeto [prevision] PUT zonaAsignacionPrevi integer integer sional GET, POST, PUT correspondeAsignaci boolean boolean onMaternal isapre GET, POST, GET, POST, PUT integer integer GET, POST, PUT Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 13 de 47 Talana – Documentación de Web Sevices montoPactadoIsapre float float GET, POST, Si asume 7% PUT montoPactadoIsapre string string Moneda GET, POST, Monto Pactado con Isapre. Si está vacío, se Si Moneda monto pactado. UF=UF | $=Pesos | 7+GES=7%+Ges en UF | 7+GES$=7% + PUT GES en pesos afp integer integer GET, POST, Si Puntero a objeto [afp] No Si el trabajador está contratado con fecha PUT adscribeASeguroCe boolean GET santiaParaContratos anterior al 2002, si adscribe o no al seguro PreviosA2002 de cesantía apvMonto float GET Si Monto primer APV apvMoneda string GET Si Moneda APV: UF | $ apvInstitucion integer GET Si Puntero a [institucionAPV] apvTipo char(1) GET Si Tipo de APV: “A” | “B” apvCuentaDos float GET Si Monto cuenta dos GET Si Moneda cuenta dos float GET Si Monto Depósito Convenido string GET Si Moneda Depósito Convenido: UF | $ retencionJuducialDe string GET Si Nombre de persona destinatario de retención apvCuentaDosMone string da depositoConvenido Monto depositoConvenido Moneda stinatario sueldoPatronal judicial boolean GET Si ¿Es sueldo patronal? Sólo para socios de la empresa sueldoBase integer integer GET, POST, Si Sueldo Base mensual en $ Si Forma de pago de sueldo. Si Puntero a [banco] PUT sueldoFormaPago string string GET, POST, PUT sueldoBanco id id GET, POST, PUT Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 14 de 47 Talana – Documentación de Web Sevices sueldoCuentaCorrie string string nte sueldoCuentaCorrie Si Número de cuenta corriente para depósito Si Tipo de cuenta corriente: Cuenta Vista | PUT, string string nteTipo sueldoTipoPago GET, POST, GET, POST, Cuenta de Ahorro | Cuenta Corriente PUT string string GET, POST, Si hora PUT valorHoraExtraPacta float float da GET, POST, Forma de cálculo sueldo: mensual | diario | Si PUT mesesImponiblesrec integer integer onocidos GET, POST, Si "Meses que se reconocen como trabajados de antes de contratar a la persona. Se usan PUT para los días progresivos mesesImponiblesRe date date conocidosDesde Si PUT vacacionesReconoci date date doDesde GET, POST, Si integer on GET, POST, Beneficio. Fecha de contratación utilizada para cálculo de vacaciones progresivas PUT asignacionMovilizaci integer asignacionColacion GET, POST, Si Movilización mensual en $ Si Colación mensual en $ PUT integer integer GET, POST, PUT anticipoPactado integer integer GET, POST, Si PUT fechaDeContratacio date date nReconocidaParaAn GET, POST, Si Beneficio. Fecha de Contratación a utilizar para cálculo de años de servicio PUT osDeServicio pagaTresPrimerosDi boolean boolean asLicencia mantieneRentaLiqui Si boolean boolean GET, POST, Si integer GET, POST, PUT Beneficio. ¿Mantiene la renta líquida durante las licencias? PUT integer Beneficio. ¿Se subsidian los 3 primeros días de licencia? PUT daLicencia diasAdministrativos GET, POST, Si Beneficio. Días administrativos por trabajador durante el periodo Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 15 de 47 Talana – Documentación de Web Sevices beneficiosInfoAdicio string string GET Si String con beneficios adicionales boolean boolean GET, POST, Si Beneficio. Al calcular la indemnización por nal indemnizacionSinTo peAnos años de servicio al finiquitar, ¿se quita el PUT tope de años? indemnizacionSinTo boolean boolean peRenta GET, POST, Si Beneficio. Al calcular la indemnización por años de servicio al finiquitar, ¿se quita el PUT tope de renta? diasAdicionalesVaca integer integer ciones creadoPor GET, POST, Si por año. PUT integer descripcionDelCargo string string Beneficio. Días adicionales de vacaciones GET Si Creador del contrato. Puntero a [persona] GET, POST, Si Descripción en texto del cargo PUT clausulasAdicionales string string GET, POST, Si PUT detalleAnexoContrat string string o string toOAnexo rolPrivado Si PUT documentoEsContra string claseSalarial GET, POST, GET, POST, No PUT [claseSalaria integer GET, POST, l] PUT boolean boolean GET, POST, Si Si PUT, PATCH asignacionZonaExtr float GET Si ema Factor de asignación adicional por zona extrema unidadOrganizacion [unidadOrga alDetails nizacional] tipoContratoDetails [tipoContrato GET Si Objeto detallado [unidadOrganizacional] GET Si Objeto detallado [tipoContrato] GET Si Objeto detallado con los Ids de este contrato ] externalReference list[externalR eference] en otros sistemas Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 16 de 47 Talana – Documentación de Web Sevices finiquitado boolean boolean GET, POST, Si ¿Fue finiquitado? Si Motivo de término de contrato (si fue PUT, PATCH motivoEgreso [motivoEgres integer GET o] INE [codigoIne] finiquitado) integer GET, POST, Si trabajador PUT, PATCH userDefinedFields list[userDefin GET, POST, edField] PUT, PATCH Objeto detallado con el código INE del Si Listado con campos personalizados Filtros Los siguientes parámetros pueden ser pasados por url para filtrar la lista de contratos: modificado_desde (fecha formato “YYYY-MM-DD”): contratos creados o modificados superiores a la fecha modificado_hasta (fecha formato “YYYY-MM-DD”): contratos creados o modificados inferiores a la fecha Ejemplo: https://talana.com/es/api/contratos/?modificado_desde=2018-10-25 Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 17 de 47 Talana – Documentación de Web Sevices Contratos Resumido https://talana.com/es/api/contracts-resumed/ Los contratos de los trabajadores y sus condiciones contractuales. Muestra los contratos y condiciones activas al día de hoy. Métodos aceptados: GET Los objetos de tipo contrato tienen las siguientes propiedades: Propiedad Tipo GET Uso Opcional Descripción id integer GET No Id único empleado integer GET No Puntero a objeto [persona] codigo string GET Si Código del contrato fechaCreacion datetime GET Si Fecha de Creación original de estas condiciones contractuales tipoContrato integer GET Si Puntero a objeto [tipoContrato]. Se especifican detalles en tipoContratoDetails empleadorRazonSocial integer GET No Puntero a objeto [razonSocial] cargo string GET Si fechaContratacion date GET Si Fecha de contratación original del trabajador hasta date GET Si Hasta cuándo rigen estas condiciones. Puede estar vacío finiquitado boolean GET Si ¿Fue finiquitado? rolPrivado boolean GET Si ¿Manejar como Rol Privado? GET Si Puntero a objeto [unidadOrganizacional] unidadOrganizacional sucursal [sucursal] GET Si Objeto sucursal jornada integer GET Si Puntero a objeto [jornada] horasDeLaJornada integer GET Si Cantidad de horas semanales de trabajo centroCosto [centroCosto] GET Si Objeto centroCosto personaDetails list[detalles] GET Si Detalles personales userDefinedFields list[userDefinedField] GET Si Listado con campos personalizados activo boolean GET (calculado) Si el contrato está activo al Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 18 de 47 Talana – Documentación de Web Sevices momento de consumir el servicio Filtros aceptados: Solo-activos=1 : sólo devuelve los contratos activos al día de hoy since=<fecha>: devuelve los contratos existentes desde la fecha indicada en adelante, donde <fecha> se especifica en el formato "%Y%m%d%H%M%S"; por ejemplo “20181224000001” empleado (id del empleado): solo los contratos del empleado especificado Vacaciones https://talana.com/es/api/vacacionesSolicitud/ Las solicitudes de vacaciones de los trabajadores, aprobadas o pendientes de aprobación. Propiedad Tipo Descripción id integer ID único empleado integer Puntero a [persona] vacacionesDesde date Fecha inicio de vacaciones numeroDias float Cantidad de días solicitados jornada char(1) M=Mañana | T=Tarde (para medios días) mediosDias boolean ¿Sólo medio día? vacacionesHasta date Último día de vacaciones solicitado vacacionesRetorno date Fecha de reincorporación aprobada char(1) ¿Aprobada?: A=Aprobada | P=Pendiente | R=Rechazada aprobadaPor integer Puntero a [persona] creadaPor integer Puntero a [persona] fechaAprobacion datetime Fecha de Aprobación detallesTrabajador [persona] Datos detallados del trabajador externalReference list[externalReference] Objeto detallado con los Ids de este contrato en otros sistemas fechaCreacion datetime Fecha de Creación Filtros Los siguientes parámetros pueden ser pasados por url para filtrar la lista de contratos: Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 19 de 47 Talana – Documentación de Web Sevices empleado (id del empleado): solo las vacaciones del empleado especificado Ejemplo: https://talana.com/es/api/vacacionesSolicitud/?empleado=1 Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 20 de 47 Talana – Documentación de Web Sevices Vacaciones Resumido https://talana/es/api/vacations-resumed/ Las solicitudes de vacaciones de los trabajadores, aprobadas o pendientes de aprobación. Propiedad Tipo Descripción id integer ID único empleado integer Puntero a [persona] vacacionesDesde date Fecha inicio de vacaciones numeroDias float Cantidad de días solicitados mediosDias boolean ¿Sólo medio día? vacacionesHasta date Último día de vacaciones solicitado vacacionesRetorno date Fecha de reincorporación fechaAprobacion datetime Fecha de Aprobación fechaCreacion datetime Fecha de Creación Filtros Los siguientes parámetros pueden ser pasados por url para filtrar la lista de contratos: empleado (id del empleado): solo las vacaciones del empleado especificado Ejemplo: https://talana/es/api/vacations-resumed/?empleado=1 Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 21 de 47 Talana – Documentación de Web Sevices Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 22 de 47 Talana – Documentación de Web Sevices Ausentismo https://talana.com/es/api/personaAusencia/{id} Ausencias por licencias médicas, permisos con o sin goce, etc. Este endpoint es de Lectura y Escritura. Métodos aceptados: GET, POST, PUT Para los métodos PUT y POST, la información a enviar deber estar en el “body” del “request” en formato JSON. Propiedad Tipo GET Tipo POST, Uso Opcional Descripción GET Si ID único GET, POST, No Puntero a [persona] No Fecha inicio de ausencia No Cantidad de días solicitados GET Si M=Mañana | T=Tarde (para medios días) GET, POST, Si ¿Sólo medio día? PUT id integer empleado integer integer PUT fechaDesde date date GET, POST, PUT numeroDias float float GET, POST, PUT jornada char(1) mediosDias boolean boolean PUT fechaHasta date GET Si Último día de ausencia fechaRetorno date GET Si Fecha de reincorporación aprobada char(1) GET Si ¿Aprobada?: A=Aprobada | P=Pendiente | R=Rechazada aprobadaPor integer creadoPor fechaAprobaci integer GET Si Puntero a [persona] integer GET Si Puntero a [persona] datetime GET Si Fecha de Aprobación GET Si Datos detallados del trabajador GET Si Objeto detallado con los Ids de este contrato en on detallesTrabaja [persona] dor externalRefere list[externalR nce eference] otros sistemas Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 23 de 47 Talana – Documentación de Web Sevices fechaCreacion datetime numeroLicenci string string a GET Si Fecha de Creación GET, POST, Si Número de Licencia médica (opcional) Si Nombre del médico que emitió la licencia PUT medicoLicencia string string GET, POST, PUT tipoAusencia string string (opcional) GET, POST, No Tipo de ausencia. Puntero a [tipoAusencia] Si Documentación adicional presentada por el PUT documentacion string string GET trabajador (opcional) esContinuacion boolean boolean GET, POST, Si ¿es continuación de una licencia anterior? PUT Este método permite la creación de ausencias, al consumirlo con los métodos POST o PUT con un payload con una estructura como la siguiente: { "mediosDias": true, "tipoAusencia": "string", "empleado": "string", "numeroLicencia": "string", "fechaDesde": "string", "medicoLicencia": "string", "motivo": "string", "numeroDias": 0, "esContinuacion": true } Bajo este esquema, sólo se acepta el siguiente subset de propiedades: Propiedad Tipo Descripción empleado integer Puntero a [persona] fechaDesde date Fecha inicio de ausencia numeroDias float Cantidad de días solicitados Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 24 de 47 Talana – Documentación de Web Sevices mediosDias boolean ¿Sólo medio día? numeroLicencia string Número de Licencia médica (opcional) medicoLicencia string Nombre del médico que emitió la licencia (opcional) tipoAusencia string Tipo de ausencia. Puntero a [tipoAusencia] esContinuacion boolean ¿es continuación de una licencia anterior? Filtros Los siguientes parámetros pueden ser pasados por url para filtrar la lista de contratos: empleado (id del empleado): solo las ausencias del empleado especificado Ejemplo: https://talana/es/api/personaAusencia/?empleado=1 Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 25 de 47 Talana – Documentación de Web Sevices Ausentismo Resumido https://talana.com/es/api/absentism-resumed Ausencias por licencias médicas, permisos con o sin goce, etc. Este endpoint es de Lectura. Métodos aceptados: GET Propiedad Tipo GET Uso Opcional Descripción id integer GET Si ID único empleado integer GET No Puntero a [persona] fechaDesde date GET No Fecha inicio de ausencia numeroDias float GET No Cantidad de días solicitados fechaHasta date GET Si Último día de ausencia fechaRetorno date GET Si Fecha de reincorporación fechaAprobacion datetime GET Si Fecha de Aprobación fechaHoraAprobacion datetime GET Si Fecha y hora de Aprobación fechaCreacion datetime GET Si Fecha de Creación tipoAusencia string GET No Tipo de ausencia. Puntero a [tipoAusencia] Filtros Los siguientes parámetros pueden ser pasados por url para filtrar la lista de contratos: empleado (id del empleado): solo las ausencias del empleado especificado Ejemplo: https://talana.com/es/api/absentism-resumed/?empleado=1 Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 26 de 47 Talana – Documentación de Web Sevices Centralización Contable https://talana.com/es/api/centralizacion-contable-generica?ano=<ano>&mes=<mes>&empresa=<id_empresa> Este servicio permite descargar la centralización contable, pero desagregado a nivel de datos. Recibe los siguientes parámetros como argumentos GET: • ano: El número del año a centralizar (obligatorio) • mes: El número del mes a centralizar (obligatorio) • format: El formato de salida (json , xml) (opcional; default json) • empresa: El ID de la empresa (opcional) (sólo si la cuenta de acceso es multiempresa) Este endpoint se basa en los mismos módulos de centralización contable que generan los archivos en formato csv o excel, por lo que son susceptibles de ser parametrizados hasta cierto punto. Es posible, por ejemplo, parametrizar las columnas y criterios que se usan para consolidar (“aggregation”) las filas. Propiedad Tipo Descripción razonSocial__nombre String Razón social del empleador razonSocial String Rut de la razón social del empleador nombreTrabajador String Nombre del Trabajador (para ítems desglosados por trabajador) rutTrabajador String Rut del Trabajador (para ítems desglosados por trabajador) sucursal__codigo String Sucursal asignada al trabajador (código) sucursal__nombre String Sucursal asignada al trabajador (nombre) item String El nómbre del ítem (ej: sueldo base) item__codigo String Código asignado al ítem item__nombreParametro String Cödigo de ítem asignado por Talana year Integer Año del periodo centralizado month Integer Mes del periodo centralizado centroCosto__nombre String Nombre del centro de costo asignado a esa línea centroCosto__codigo String Código del centro de costo asignado a esa línea debe Integer Valor del “debe” haber Integer Valor del “haber” cuentaContable__codigo String Código cuenta Contable asignada cuentaContable__nombre String Nombre cuenta Contable asignada Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 27 de 47 Talana – Documentación de Web Sevices Asignación de Items de pago https://talana.com/es/api/remuneraciones/item-pago/asignacion/ Servicio para agregar o actualizar el valor de un ítem de pago para un contrato en el periodo actual, basándose en el rut del empleado o el id del contrato. Métodos aceptados: POST Propiedad POST Uso Opcional Descripción tipo_item string POST No Nombre del item de pago valorFijo float POST No Valor a insertar o actualizar id_contrato integer POST Si Id del contrato rut_empleado string POST Si Rut del empleado Ejemplo de request { "tipo_item": “bonoDeProduccion”, "valorFijo": 123456, “id_contrato”: 367 } ó { "tipo_item": “bonoDeProduccion”, "valorFijo": 123456, “rut_empleado”: “10253930-3” } https://talana.com/es/api/remuneraciones/item-pago/asignacion/<id_persona>/<tipo_item>/ Servicio para leer el valor de una asignación de un item de pago. Métodos aceptados: GET Propiedad GET Uso Opcional Descripción valorFijo float GET No Valor del item de pago Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 28 de 47 Talana – Documentación de Web Sevices Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 29 de 47 Talana – Documentación de Web Sevices Creación de documentos par personas https://talana.com/es/api/remuneraciones/documentos/ Servicio para agregar documentos a la carpeta de una persona. Métodos aceptados: POST Propiedad POST Uso Opcional Descripción empleado integer POST Si (si Id persona existe rut) rut string POST Si (si Rut de la persona existe empleado) adjunto multipart POST No El documento nombre string POST No Id del contrato categoria string POST Si Nombre de la categoría POST Si Visibilidad del documento para el puedeVerloElTrabajador boolean dueño de éste Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 30 de 47 Talana – Documentación de Web Sevices Días Administrativos https://talana.com/es/api/diaAdministrativoSolicitud/ Días administrativos solicitados por el trabajador Propiedad Tipo Descripción id integer ID único empleado integer Puntero a [persona] desde date Fecha inicio de solicitud numeroDias float Cantidad de días solicitados jornada char(1) M=Mañana | T=Tarde (para medios días) mediosDias boolean ¿Sólo medio día? hasta date Último día solicitado retorno date Fecha de reincorporación aprobada char(1) ¿Aprobada?: A=Aprobada | P=Pendiente | R=Rechazada aprobadaPor integer Puntero a [persona] creadaPor integer Puntero a [persona] detallesTrabajador [persona] Datos detallados del trabajador fechaCreacion datetime Fecha de Creación Filtros Los siguientes parámetros pueden ser pasados por url para filtrar la lista de contratos: empleado (id del empleado): solo los días administrativos del empleado especificado Ejemplo: https://talana.com/es/api/diaAdministrativoSolicitud/?empleado=1 Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 31 de 47 Talana – Documentación de Web Sevices Días Trabajados https://talana.com/es/api/dias-trabajados/ Los días trabajados en el mes y año actual de cada contrato. Si un trabajador tuvo dos contrataciones distintas, aparecerá dos veces. Propiedad Tipo Descripción codigo string Código del Contrato fechaContratacion date Fecha de contratación, en formato “YYYY-mm-dd” hasta date Fecha de término del contrato, en formato “YYYY-mm-dd” dias_trabajados float Días trabajados empleado integer ID del empleado detallesTrabajador struct Estructura con detalles del trabajador Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 32 de 47 Talana – Documentación de Web Sevices Días Administrativos Resumido https://talana.com/es/api/administrative-leaves-resumed/ Días administrativos solicitados por el trabajador Propiedad Tipo Descripción id integer ID único empleado integer Puntero a [persona] desde date Fecha inicio de solicitud numeroDias float Cantidad de días solicitados mediosDias boolean ¿Sólo medio día? hasta date Último día solicitado retorno date Fecha de reincorporación fechaCreacion datetime Fecha de Creación fechaAprobacion datetime Fecha de Aprobación Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 33 de 47 Talana – Documentación de Web Sevices Turno https://talana.com/es/api/workShift/ La definición de los turnos. Propiedad Tipo Descripción id integer ID único name string Nombre asignado holidaysConsider boolean ¿Considera trabajar los días festivos? tolerance float Tolerancia en minutos respecto a atrasos y adelantos workShiftType char(1) Tipo de rotación: W=Semanal | M=Manual schedule string Resumen de horarios considerados (ej: “09:00 : 19:00”) publicId integer ID correlativo sólo para la empresa Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 34 de 47 Talana – Documentación de Web Sevices Días de Turno Semanal https://talana.com/es/api/rotativeDay/ El detalle de los días asociados a un turno con rotación semanal Propiedad Tipo Descripción id integer ID único name string Nombre del día numberSnackMinutes integer Duración de la colación, en minutos startWorkingHours string Hora de inicio, en formato “HH:MM:SS” numberWorkingMinutes integer Duración en minutos workingDay boolean Ese día de la semana ¿se trabaja en este turno? numberWorkingDay integer Día de la semana (en base 0) workShift integer Puntero a [workShift] Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 35 de 47 Talana – Documentación de Web Sevices Días de Turno Manual https://talana.com/es/api/specificDay/ El detalle de los días asociados a un turno de construcción “manual” Propiedad Tipo Descripción id integer ID único date string Fecha del día, en formato “YYYY-mm-dd” startWorkingHours string Hora de inicio, en formato “HH:MM:SS” numberWorkingMinutes integer Duración en minutos workingDay boolean Ese día ¿se trabaja en este turno? workShift integer Puntero a [workShift] Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 36 de 47 Talana – Documentación de Web Sevices Asignación de Personas a Turnos https://talana.com/es/api/workShiftPersonRange/ Asignación de personas a turnos por rango de fechas. Una persona puede tener más de un turno asignado el mismo día. Propiedad Tipo Descripción id integer ID único fromDate string Fecha de inicio de asignación, en formato “YYYY-mm-dd” toDate string Fecha de fin de asignación, en formato “YYYY-mm-dd” person integer Persona asignada. Puntero a [persona] workShift integer El turno asignado. Puntero a [workShift] Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 37 de 47 Talana – Documentación de Web Sevices Inyección (y visualización) de marcas http://talana.com/es/api/mark/ Métodos aceptados: GET, POST, Para el método POST, la información a enviar deber estar en el “body” del “request” en formato JSON. Para la cración de marcas, se debe recibir rut o card_id Los objetos de persona tienen las siguientes propiedades: Propiedad Tipo GET Tipo POST Uso Opcional Descripción id integer person [persona] - GET - Detalles de la persona que marcó rut - string POST Si Rut, sin puntos, con guión y DV card_id - string POST Si El código de tarjeta asignado office integer integer GET, POST Si ID en Talana de la sucursal direction char(1) char(1) GET, POST Si Dirección de la marca. (Tipo ID único Marca) “E” = Enter “X” = Exit TS timestamp timestamp GET, POST No Fceha y Hora real de marca. Formato "2018-07-13T17:22:21" sourceMark string string GET, POST Si Fuente de la marca (usar como Tipo de Actualización de Registro) received_datetime timestamp timestamp GET, POST No Fecha y hora de recepción de marca Formato "2018-07-13T17:22:21" Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 38 de 47 Talana – Documentación de Web Sevices Ejemplo: Este JSON debe ir en el cuerpo del request. Es importante destacar que ante cualquier error, el servicio entregara el detalle de este. { } “rut": "17798529-5", "direction": "E", "TS": "2019-01-01T00:00:00" También es posible aplicar filtros a la llamada de las marcas que son realizadas con el método GET: • desde(YYYY-MM-DD): Fecha desde la cual se obtendrán las marcas hacia adelante. • hasta(YYYY-MM-DD): Fecha hasta la cual se obtendrán las marcas hacia atrás. • person(Numero): Id de a persona a obtener sus macas Ejemplo de URL: https://dev.talana.com/es/api/mark/?desde=2018-11-01&hasta=2018-11-01 ** Importante: para la realización de la consulta debe estar el Token ingresado en los headers. Dependiendo de los permisos del usuario, también entregara solo las marcas que tiene permitido ver. Asignación de tarjetas a personas. https://talana.com/es/api/zkcard/ Se entiende que se asigna la tarjeta con el código indicado de ahora en adelante. Si es que la tarjeta ya está asignada a otra persona, el sistema no lo permite y arroja un error. Para desasignar una tarjeta a una persona se le debe asignar el número null,”” o no enviando el valor de “card_id” Métodos aceptados: GET, POST Para el método POST, la información a enviar deber estar en el “body” del “request” en formato JSON. Los objetos de tipo contrato tienen las siguientes propiedades: Propiedad Tipo GET POST Uso Opcional Descripción rut string string GET, POST No Rut, sin puntos, con guión y DV card_id string string GET, POST Si Código de la tarjeta, o null para desasignar Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 39 de 47 Talana – Documentación de Web Sevices Turnos y horarios asignados por Trabajador https://talana.com/es/api/workShiftPersonRange/getAssignationsDays/ Este servicio entrega la obligación de marcar y los horarios asociados a cada trabajador en el rango de fecha indicados. Recibe como parámetros la fecha de inicio y de fin del periodo a revisar, en las variables: fromDate: fecha de inicio del periodo a revisar toDate: fecha de fin del periodo a revisar Ejemplo: https://talana.com/es/api/workShiftPersonRange/getAssignationsDays/?fromDate=2018-04-01&toDate=2018-04-09 Métodos aceptados: GET Los objetos de tipo contrato tienen las siguientes propiedades: Propiedad Tipo Descripción person integer Id de persona personName string Nombre y apellidos de la persona rut string Rut de la persona days [ asignacion ] Lista de objetos de tipo “asignacion” Cada objeto de tipo “asignación” tiene las siguientes propiedades: Propiedad Tipo Descripción workshift string Nombre del turno asignado card string Código de la tarjeta asignado para ese día entranceTime timestamp Fecha y hora de entrada del trabajador exitTime timestamp Fecha y hora de salida del trabajador hasToMark boolean ¿debe marcar ese día? reason string La razón por la cual no debe marcar ese día Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 40 de 47 Talana – Documentación de Web Sevices Otros Modelos A continuación enumeramos varios servicios que exponen otros modelos que pueden ser relevantes: Paises / Nacionalidades: https://talana.com/es/api/pais/ Bancos: https://talana.com/es/api/banco/ Formas de Pago: https://talana.com/es/api/formas-de-pago/ Tipos de Jornada Laboral: https://talana.com/es/api/jornadaLaboral/ Tipos de Contrato: https://talana.com/es/api/tipoContrato/ Árbol de Ubicaciones geográficas: https://talana.com/es/api/ubicacionGeografica/ Instituciones Previsionales (Isapres / Fonasa): https://talana.com/es/api/prevision/ AFPs: https://talana.com/es/api/afp/ Instituciones de APV: https://talana.com/es/api/institucionAPV/ Cajas de Compensación: https://talana.com/es/api/cajaCompensacion/ Mutuales de Seguridad: https://talana.com/es/api/mutualSeguridad/ Razones Sociales de la empresa: https://talana.com/es/api/razonSocial/ Tipos de Ausencia https://talana.com/es/api/tipoAusencia/ Fecha del servidor: https://talana.com/es/api/fechaserver/ Hora del Servidor: https://talana.com/es/api/fechaserver/ Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 41 de 47 Talana – Documentación de Web Sevices Unidades Organizacionales de la empresa: https://talana.com/es/api/unidadOrganizacional/ Sindicatos de la empresa: https://talana.com/es/api/sindicatoEmpresa/ Sucursales de la empresa: https://talana.com/es/api/sucursal/ Centros de costo de la empresa: https://talana.com/es/api/centroCosto/ Cuentas contables de la empresa: https://talana.com/es/api/cuentaContable/ Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 42 de 47 Talana – Documentación de Web Sevices Ejemplos de Código Python #!/usr/bin/python import requests # 1 - Obtenemos el token url = "https://dev.talana.com/es/api/api-token-auth/" user = "[email protected]" password = "PasswordDePrueba" response = requests.post(url, json={"username" : user, "password": password}) token = response.json()["token"] # 2 - con ese token, consumimos el servicio de personas url_personas = "https://dev.talana.com/es/api/persona" response = requests.get(url_personas, headers={"Authorization": "Token {}".format(token)}) for p in response.json(): print "Persona:", p # 3 - Inyectar una marca de asistencia para la 1a persona from datetime import datetime as dt url_marcas = "http://dev.talana.com/es/api/mark/" persona = response.json()[0] persona_id = persona["id"] persona_rut = persona["rut"] response = requests.post( url_marcas, json={ "rut" : persona_rut, "direction" : "E", "TS" : dt.now().strftime("%Y-%m-%dT%H:%M:%S"), "sourceMark": "Ej. Script de Integracion"}, headers={"Authorization": "Token {}".format(token)} ) print response Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 43 de 47 Talana – Documentación de Web Sevices Java Puede descargar una copia completa de este mini-proyecto aquí: https://git.linq.cl/kziete/ejemplo-consumo-api/ ApiClient.java: package com.talana; import import import import import import java.io.BufferedReader; java.io.IOException; java.io.InputStreamReader; java.net.HttpURLConnection; java.net.MalformedURLException; java.net.URL; public class APIClient { private static final String API_URL = "https://talana.com/es/api/"; private static final String TOKEN = "INSERTAR_AUTH_TOKEN_AQUI"; public String get(String path){ URL url = null; try { url = new URL(API_URL + path); HttpURLConnection conn = (HttpURLConnection)url.openConnection(); setHeaders(conn); conn.setRequestMethod("GET"); conn.setUseCaches(false); conn.setDoInput(true); return responseToString(conn); } } catch (MalformedURLException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } return null; private String responseToString(HttpURLConnection conn) throws IOException { BufferedReader br = null; try { br = new BufferedReader(new InputStreamReader((conn.getInputStream()))); } catch (IOException e) { e.printStackTrace(); } StringBuilder sb = new StringBuilder(); String output; while ((output = br.readLine()) != null) { sb.append(output); } return sb.toString(); } } private void setHeaders(HttpURLConnection conn) { conn.setRequestProperty("Authorization", "Token " + TOKEN); conn.setRequestProperty("Accept", "application/json"); conn.setRequestProperty("Content-Type", "application/json;charset=utf-8"); } Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 44 de 47 Talana – Documentación de Web Sevices parser.java: package com.talana; import import import import import com.talana.models.Person; org.json.simple.JSONArray; org.json.simple.JSONObject; org.json.simple.parser.JSONParser; org.json.simple.parser.ParseException; import java.util.ArrayList; import java.util.List; public class Parser { public static List<Person> getPersonList(String json) { List<Person> persons = new ArrayList<>(); JSONParser parser = new JSONParser(); Object obj = null; try { obj = parser.parse(json); } catch (ParseException e) { e.printStackTrace(); } JSONArray array = (JSONArray)obj; for(Object per: array){ JSONObject object = (JSONObject)per; persons.add(getPerson(object)); } return persons; } public static Person getPerson(JSONObject object){ Person person = new Person(); person.rut = (String)object.get("rut"); person.apellidoPaterno = (String)object.get("apellidoPaterno"); person.apellidoMaterno = (String)object.get("apellidoMaterno"); person.nombre = (String)object.get("nombre"); person.detalles = new ArrayList<>(); JSONArray details = (JSONArray)object.get("detalles"); for(Object det: details){ JSONObject obj = (JSONObject)det; Person.PersonDetail detail = new Person.PersonDetail(); detail.foto = (String)obj.get("foto"); } person.detalles.add(detail); return person; } } Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 45 de 47 Talana – Documentación de Web Sevices main.java: package com.talana; import com.talana.models.Person; import java.util.List; public class Main { public static void main(String[] args) { APIClient client = new APIClient(); String jsonResponse = client.get("persona/"); List<Person> persons = Parser.getPersonList(jsonResponse); for(Person per:persons){ System.out.println(per.toString()); } } } models/person.java: package com.talana.models; import java.util.List; public class Person { public String rut; public String apellidoPaterno; public String apellidoMaterno; public String nombre; public List<PersonDetail> detalles; public static class PersonDetail{ public String foto; } } @Override public String toString() { return "PersonDetail{" + "foto='" + foto + '\'' + '}'; } @Override public String toString() { return "Person{" + "rut='" + rut + '\'' + ", apellidoPaterno='" + apellidoPaterno + '\'' + ", apellidoMaterno='" + apellidoMaterno + '\'' + ", nombre='" + nombre + '\'' + ", detalles=" + detalles + '}'; } Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 46 de 47 Talana – Documentación de Web Sevices PHP <?php # 1.- Obtencion del Token # Username $username = "[email protected]"; # Contraseña $password = "PasswordDeIntegracion"; #URL para obtener el Token $url_solicitud_token = 'https://talana.com/es/api/api-token-auth/'; # Creamos un "stream context" que contiene la peticion y los encabezados $solicitud_token = json_encode( array("username" => $username, "password" => $password)); $context = stream_context_create(array( "http" => array( "method" => "POST", "content" => $solicitud_token, 'header'=> "Content-type: application/json" ) )); # Realizamos la llamada $response = file_get_contents('https://talana.com/es/api/api-token-auth/', FALSE, $context); # Y obtenemos el token $token = json_decode($response)->token; print "Token obtenido:" . $token . "\n"; # 2.- Consumo de servicio # La URL del servicio para obtener los paises $url_paises = "https://talana.com/es/api/pais/"; #Creamos un stream context, que incluye los encabezados con el Token $context = stream_context_create(array( "http" => array( "method" => "GET", 'header'=> "Content-type: application/json\nAuthorization: Token $token"))); #Hacemos la llamada $response = file_get_contents($url_paises , FALSE, $context); # Interpretamos el Json para obtener los datos como un arreglo $paises = json_decode($response); print_r($paises); # 3.- Inyección de items de pago $url_inyeccion_items_pago = "https://talana.com/es/api/remuneraciones/item-pago/asignacion/"; $datos = array( "tipo_item" => "BonoporServicio", "rut_empleado" => "9538055-5", "valorFijo" => "101"); $payload = json_encode($datos); $context = stream_context_create( array( "http" => array( "method" => "POST", "content" => $payload, 'header'=> "Content-type: application/json\nAuthorization: Token $token"))); $response = file_get_contents($url_inyeccion_items_pago, FALSE, $context ); print_r($response); Sistemas de Gestión de Recursos Humanos | www.talana.com | Página 47 de 47