Pos StandAlone

Operaciones
Operativo-v1 (Basic Auth)
POST /v1/activate
POST /v1/deactivate
Vincular
POST /v1/activate

Authentication

Basic Auth

Este método permitirá vincular un terminal

Request body

Examples

Ejemplo de request de vinculación

{
    "fullSerialNumber": "6G356108",
    "activationCode": "880310"
}

Responses

200 OK

Vinculación correcta

Body
Examples

Ejemplo de respuesta sin credenciales de recargas servicios

{
    "data": {
        "X-Authentication-ApiKey": "utOqJyBoaoRp9IvoDqoSv4snu8oj6YdWoHEy0hW2LwQ4Bpb9D5560hVfmFEv7HJm",
        "X-Authentication-Token": "dt_3714522654c60f807c66dbade0e70d31c9cdde28",
        "subMerchantId": "840270777",
        "subMerchantName": "Mi Bodega",
        "qpos": "0",
        "qposAmount": "1"
    }
}

Ejemplo de respuesta con credenciales de recargas servicios

{
    "data": {
        "X-Authentication-ApiKey": "utOqJyBoaoRp9IvoDqoSv4snu8oj6YdWoHEy0hW2LwQ4Bpb9D5560hVfmFEv7HJm",
        "X-Authentication-Token": "dt_3714522654c60f807c66dbade0e70d31c9cdde28",
        "subMerchantId": "840270777",
        "subMerchantName": "Mi Bodega",
        "qpos": "0",
        "qposAmount": "1",
        "credentials": {
            "codigoRecargas": "2sTzVv34sdf",
            "accountId": "3DFXEg7wU2fdsf2423dgQ1Im96Pu7nJBaynG",
            "terminalId": "5ZJIm9768dfhg",
            "acceptorId": "WxZSbdshgtxddsfA",
            "ownerId": "yJIof2T9bfdsfs423xcJwN4pL"
        }
    }
}
200 OK

Vinculación errada

Body
Object
error
string

Descripcion de error

Example:
errors.activation_code_invalid
response
Object
code
integer

Codigo de error geopagos asociado a apis internas

Example:
400
message
string

Descripción del error

Example:
Codigo de activacion invalido
Examples

Ejemplo de respuesta de “Código de activación inválido” (el código de activación es incorrecto o ha expirado

{
    "error": "errors.activation_code_invalid",
    "response": {
        "code": 400,
        "message": "Codigo de activacion invalido"
    }
}

Ejemplo de respuesta de “Terminal no disponible” (está vinculado a otro comercio)

{
	"error": "errors.terminal_not_available",
	"response": {
		"code": 400,
		"message": "Terminal no disponible"
	}
}
Desvincular
POST /v1/deactivate

Authentication

Basic Auth

Este método permitirá desvincular un terminal

Request headers

X-Authentication-ApiKey:
string required

Api key devuelto en el objeto ObjVinculacionResponse.data.X-Authentication-ApiKey (dicho valor debe estar almacenado en el dispositivo)

Example:
dsfdsiiRDR7TlFk2ebKvdu8uaJD5FfVbw4thdM79bFX5iKbuH8yFfgAvyYFtdxjQ4me3
X-Authentication-Token
string optional

Api token devuelto en el objeto ObjVinculacionResponse.data.X-Authentication-Token (dicho valor debe estar almacenado en el dispositivo)

Example:
dt_8gfdghfd7027e70e73f8fe223acfbdfad3e76adfbd7cc55

Request body

Examples

Ejemplo de request de desvinculación

{
    "fullSerialNumber": "6G051173",
    "codigoNBO": "046555489"
}

Responses

200 OK

Desvinculación completada (no tiene body)

200 Ok pero no vinculó

Desvinculación no se realizó

Body
Examples

Ejemplo de que se envió el valor del terminal en blanco

{
    "error": "errors.unauthorized",
    "response": {
        "code": 401,
        "message": "TERMINAL O CODIGO VACIO"
    }
}
Obtener credenciales recargas-servicios
POST /v1/getCredentials

Authentication

Basic Auth

Este método permite obtener las credenciales

Request body

Examples

Ejemplo de request para obtener credenciales

{
    "codigoNbo": "046310489"
}

Responses

200 OK
Body
Examples

Ejemplo de respuesta con credenciales correctas

{
    "credentials": {
        "codigoRecargas": "2sTzV432vpaCA",
        "accountId": "3DFXEg7wU452xNWzcDRnQ1Im96Pu7nJBaynG423",
        "terminalId": "5ZJ5425Im9ni",
        "acceptorId": "WxZSbtwIb52MjY5dA",
        "ownerId": "yJIof2T9bSTyxcJwN4pL52352"
    },
    "responseCode": "00"
}
Operativo-v2 (Auth2)
POST /v2/activate
POST /v2/deactivate
Vincular v2
POST /v2/activate

Authentication

Auth2

Este método permitirá vincular un terminal

Request body

Examples

Ejemplo de request de vinculación

{
    "fullSerialNumber": "6G356108",
    "type":"2",
    "activationCode": "880310"
}

Responses

200 OK

Vinculación correcta

Body
Examples

Ejemplo de respuesta sin credenciales de recargas servicios

{
    "data": {
        "X-Authentication-ApiKey": "utOqJyBoaoRp9IvoDqoSv4snu8oj6YdWoHEy0hW2LwQ4Bpb9D5560hVfmFEv7HJm",
        "X-Authentication-Token": "dt_3714522654c60f807c66dbade0e70d31c9cdde28",
        "subMerchantId": "840270777",
        "subMerchantName": "Mi Bodega",
        "qpos": "0",
        "qposAmount": "1"
    }
}

Ejemplo de respuesta con credenciales de recargas servicios

{
    "data": {
        "X-Authentication-ApiKey": "utOqJyBoaoRp9IvoDqoSv4snu8oj6YdWoHEy0hW2LwQ4Bpb9D5560hVfmFEv7HJm",
        "X-Authentication-Token": "dt_3714522654c60f807c66dbade0e70d31c9cdde28",
        "subMerchantId": "840270777",
        "subMerchantName": "Mi Bodega",
        "qpos": "0",
        "qposAmount": "1",
        "credentials": {
            "codigoRecargas": "2sTzVv34sdf",
            "accountId": "3DFXEg7wU2fdsf2423dgQ1Im96Pu7nJBaynG",
            "terminalId": "5ZJIm9768dfhg",
            "acceptorId": "WxZSbdshgtxddsfA",
            "ownerId": "yJIof2T9bfdsfs423xcJwN4pL"
        }
    }
}
200 OK

Vinculación errada

Body
Object
error
string

Descripcion de error

Example:
errors.activation_code_invalid
response
Object
code
integer

Codigo de error geopagos asociado a apis internas

Example:
400
message
string

Descripción del error

Example:
Codigo de activacion invalido
Examples

Ejemplo de respuesta de “Código de activación inválido” (el código de activación es incorrecto o ha expirado

{
    "error": "errors.activation_code_invalid",
    "response": {
        "code": 400,
        "message": "Codigo de activacion invalido"
    }
}

Ejemplo de respuesta de “Terminal no disponible” (está vinculado a otro comercio)

{
	"error": "errors.terminal_not_available",
	"response": {
		"code": 400,
		"message": "Terminal no disponible"
	}
}
Desvincular v2
POST /v2/deactivate

Authentication

Auth2

Este método permitirá desvincular un terminal. La desvinculacion correcta son 2 pasos

1.- Intentar desvincular, esto mandará un correo al representante legal para que acepte en una web externa
2.- Intentar desvincular luego de aceptar en la web externa, esto si desvinculará solo con un HTTP responsecode de respuesta, sin body

Request headers

X-Authentication-ApiKey:
string required

Api key devuelto en el objeto ObjVinculacionResponse.data.X-Authentication-ApiKey (dicho valor debe estar almacenado en el dispositivo)

Example:
dsfdsiiRDR7TlFk2ebKvdu8uaJD5FfVbw4thdM79bFX5iKbuH8yFfgAvyYFtdxjQ4me3
X-Authentication-Token
string optional

Api token devuelto en el objeto ObjVinculacionResponse.data.X-Authentication-Token (dicho valor debe estar almacenado en el dispositivo)

Example:
dt_8gfdghfd7027e70e73f8fe223acfbdfad3e76adfbd7cc55

Request body

Examples

Ejemplo de request de desvinculación

{
    "fullSerialNumber": "6G051173",
    "type":"2",
    "codigoNBO": "046555489"
}

Responses

200 OK

Desvinculación completada (no tiene body)

200 Ok pero no vinculó

Desvinculación no se realizó

Body
Examples

Ejemplo de que se ejecutó el primer paso, el cual es enviar correo al rep legal

{
    "error": "Generic Error Message",
    "response": {
        "code": 401,
        "message": "REVISE SU CORREO"
    }
}

Ejemplo de que se envió el valor del terminal en blanco

{
    "error": "errors.unauthorized",
    "response": {
        "code": 401,
        "message": "TERMINAL O CODIGO VACIO"
    }
}
Obtener credenciales recargas-servicios v2
POST /v2/getCredentials

Authentication

Auth2

Este método permite obtener las credenciales

Request body

Examples

Ejemplo de request para obtener credenciales

{
    "codigoNbo": "046310489"
}

Responses

200 OK
Body
Examples

Ejemplo de respuesta con credenciales correctas

{
    "credentials": {
        "codigoRecargas": "2sTzV432vpaCA",
        "accountId": "3DFXEg7wU452xNWzcDRnQ1Im96Pu7nJBaynG423",
        "terminalId": "5ZJ5425Im9ni",
        "acceptorId": "WxZSbtwIb52MjY5dA",
        "ownerId": "yJIof2T9bSTyxcJwN4pL52352"
    },
    "responseCode": "00"
}
Firma Voucher
POST /confirm
Guardar Firma
POST /confirm

Authentication

Basic Auth

Api para guardar firma Digital

Request body

Object
referenceNumber
string required

Número de referencia de la transacción

Example:
154758649862
dni
string required

Dni de la persona que firma

Example:
46310482
nameCommerce
string required

Nombre del comercio

Example:
Antonio Consulting
submerchantId
string required

Código del comercio

Example:
341198324
signatureImage
string required

Hash de la imagen en base 64 en PNG

Example:
...........................
Examples

Ejemplo de trama de firma

{
    "referenceNumber": "154758649862",
    "dni": "46310482",
    "nameCommerce": "Antonio Consulting",
    "submerchantId": "341198324",
    "signatureImage": ""
}

Responses

200 OK

Respuesta incorrecta

Body
Object
state
string
Example:
0
seqSignature
string
Example:
0000
desState
string
Example:
ERROR
Estructuras de Entrada y Salida
ObjVinculacionRequest

Estructura de petición para vinculación

Object
fullSerialNumber
string required

Últimos 8 caracteres de la serie del equipo (poket pro y full)

Max length: 8
Example:
6G356108
activationCode
string required

Código generado por App Vendemas o por Dashboard

Max length: 6
Example:
880310

Examples

{
    "fullSerialNumber": "6G356108",
    "activationCode": "880310"
}
ObjVinculacionResponse

Respuesta de la petición de vinculación

Object
data
Object
X-Authentication-ApiKey
string required

Llave de autenticacion Geopagos

Example:
utOqJyBoaoRp9IvoDqoSv4snu8oj6YdWoHEy0hW2LwQ4Bpb9D5560hVfmFEv7HJm
X-Authentication-Token
string required

Token de autenticacion Geopagos

Example:
dt_3714522654c60f807c66dbade0e70d31c9cdde28
subMerchantId
string required

Código NBO del comercio en Vendemas

Example:
840270777
subMerchantName
string required

Nombre del comercio

Example:
Mi Bodega
qpos
string required

Flag de pago rápido

Example:
0
qposAmount
string required

Flag de monto pago rápido

Example:
1
credentials
Object nullable

Objeto que contiene los códigos para realizar recargas (en caso el comercio no pueda realizar recargas, esta entrada no se devuelve)

codigoRecargas
string required
Example:
2sTzVv34sdf
accountId
string required
Example:
3DFXEg7wU2fdsf2423dgQ1Im96Pu7nJBaynG
terminalId
string required
Example:
5ZJIm9768dfhg
acceptorId
string required
Example:
WxZSbdshgtxddsfA
ownerId
string required
Example:
yJIof2T9bfdsfs423xcJwN4pL
ObjDesvinculacionRequest

Estructura de petición para desvinculación

Object
fullSerialNumber
string required

últimos 8 caracteres de la serie del equipo

Example:
6G051173
codigoNBO
string required

Código del comercio en Vendemas

Example:
046555489
ObjDesvinculaciónResponseError

Cuando la desvinculación es incorrecta, devuelve una estructura de error, de lo contrario el cuerpo no devuelve ningún texto

Object
error
string
Example:
errors.unauthorized
response
Object
code
integer
Example:
401
message
string
Example:
TERMINAL O CODIGO VACIO
ObjObtenerCredencialesRequest

Estructura de petición para obtener credenciales de recargas-servicios

Object
codigoNbo
string required

Código del comercio en Vendemas

Example:
046310489
ObjObtenerCredencialesResponse

Estructura de respuesta al obtener credenciales

Object
credentials
Object

Objeto con datos de credenciales para recargas-servicios

codigoRecargas
string
Example:
2sTzV432vpaCA
accountId
string
Example:
3DFXEg7wU452xNWzcDRnQ1Im96Pu7nJBaynG423
terminalId
string
Example:
5ZJ5425Im9ni
acceptorId
string
Example:
WxZSbtwIb52MjY5dA
ownerId
string
Example:
yJIof2T9bSTyxcJwN4pL52352
responseCode
string
Enumeration:
00

Correcto

96

Error al obtener credenciales

ObjDesvinculacionOTPRequest

Estructura de petición para desvinculación

Object
fullSerialNumber
string required

últimos 8 caracteres de la serie del equipo

Example:
6G051173
codigoNBO
string required

Código del comercio en Vendemas

Example:
046555489
codigoOTP
string required

Código enviado al usuario para desvincular

Max length: 6
Example:
534534
ObjDesvinculacionOTPResponse

Estructura de respuesta de la desvinculación por OTP

Object
codigoRespuesta
string required

Código de respuesta de la desvinculacion

Enumeration:
00

Desvinculacion exitosa

10

Error interno

11

No autorizado

12

Error desvinculacion en Geopagos

13

Error desvinculacion en Invenio

mensajeRespuesta
string required

Detalle del resultado de la desvinculación

Example:
EXITO
mensajeFront
string required

Texto a usar en el front

Example:
Desvinculacion Exitosa
ObjSolicitarOTPRequest

Estructura de petición para el envio de OTP

Object
fullSerialNumber
string required

Ultimos 8 caracteres del terminal (poket pro y full)

Example:
6G356108
codigoNbo
string required

Código Nbo del comercio en Vendemas

Example:
046555489
tipoEnvio
string required

Tipo de envio del OTP

Enumeration:
01

Sms

02

Email

10

Ambos

ObjSolicitarOTPResponse

Estructura de respuesta de la solicitud de envio de OTP

Object
codigoRespuesta
string required

Código de respuesta de la desvinculacion

Enumeration:
00

Envio completado

10

Error interno

11

No autorizado

mensajeRespuesta
string required

Detalle del resultado de la desvinculación

Example:
EXITO
mensajeFront
string required

Texto a usar en el front

Example:
Envío completado
solicitudesRestantes
string required

Cantidad de solicitudes restantes para pedir OTP durante el periodo definido (actualmente por dia)

Example:
2
ObjVinculacionRequest-v2

Estructura de petición para vinculación

Object
fullSerialNumber
string required

Últimos 8 caracteres de la serie del equipo (poket pro y full)

Max length: 8
Example:
6G356108
type
string

Tipo de terminal

Enumeration:
2

Poket Pro (D190)

4

Full (S920)

7

C680

8

IWL220

9

IWL250

11

Android A910

activationCode
string required

Código generado por App Vendemas o por Dashboard

Max length: 6
Example:
880310

Examples

{
    "fullSerialNumber": "6G356108",
    "activationCode": "880310"
}
ObjDesvinculacionRequest-v2

Estructura de petición para desvinculación

Object
fullSerialNumber
string required

últimos 8 caracteres de la serie del equipo

Example:
6G051173
type
string

Tipo de terminal

Enumeration:
2

Poket Pro

4

Full

7

C680

8

IWL220

9

IWL250

11

Android A910

codigoNBO
string required

Código del comercio en Vendemas

Example:
046555489