Documentación de Velneo
28
28
  • Introducción
  • Velneo
    • Requerimientos de Velneo
    • Notas de la versión
    • Funcionalidades comunes a los componentes de Velneo
      • Instalación
      • Conexión con Velneo vServer
      • Cambiar el estilo de visualización
      • Ver u ocultar barras de herramientas
      • Mensajería interna entre usuarios
      • Soporte de alta resolución (HighDPI)
      • Carpetas de trabajo de los componentes de Velneo
      • Numeración de versiones de Velneo
      • Certificado de firma digital para componentes de Windows
    • Tipos de archivo generados por Velneo
    • Velneo Web
      • Plataformas y navegadores compatibles
      • Acceso a recursos del sistema
      • Siempre https
      • Funcionamiento de vatp por websocket
      • CORS para llamadas xmlhttprequest
  • Velneo vDevelop
    • ¿Qué es Velneo vDevelop?
    • Interfaz de Velneo vDevelop
      • Menú Soluciones
      • Menú Proyectos
      • Menú Objetos
      • Menú Scripts
      • Menú Edición
      • Menú Ver
      • Menú Componentes
      • Menú Ayuda
    • Lista de teclas aceleradoras de Velneo vDevelop
    • Soluciones y proyectos
    • Control y edición de proyectos
    • Herencia
    • Inspectores
    • Proyectos objetos y editores
      • Proyecto de datos
      • Proyecto de aplicación
        • Crear CSS para aplicar a objetos en edición
      • Objeto
      • Objetos de proyecto de datos
        • Indice complejo
        • Tabla
          • Actualización
          • Campo
          • Enlace
          • Indice
          • Plural
          • Traspaso de campo
          • Trigger
        • Tabla estática
        • Variable
      • Objetos de proyecto de aplicación
        • Acción
        • Alternador de lista
        • Arbol visor de tablas
        • Bloc de formularios
        • Casillero
        • Cesta
        • ComboView
        • Control SVG
        • Dispositivo serie
        • Formulario
          • Controles de visualización
            • Texto estático
            • Nombre de campo
            • Visor HTML
            • Dibujo
            • Imagen SVG
            • Caja de grupo
            • Menú arbolado
            • Barra de progreso
            • Reloj
            • Manómetro
            • Termómetro
          • Controles de edición
            • Caja de texto
            • Caja de texto enriquecido
            • Data catcher edit
            • Edición alfabética
            • Edición fecha
            • Edición fecha/hora
            • Edición fórmula
            • Edición hora
            • Edición numérica
            • Edición senda fichero
            • Edición senda directorio
            • Objeto dibujo
          • Controles de entrada
            • Botón
            • Botón de check
            • Botón de radio
            • Calendario
            • ComboBox
            • Deslizador
            • Dial
            • ListBox
            • Rueda
          • Contenedores
            • Área de scroll
            • Caja de formularios
            • Pila de formularios
            • Separador de formularios
            • Splitter
            • Vista de datos
          • Layout
          • Tree widget
          • Controles SVG
          • Extensión de ficha
        • Formulario QML
        • Gráfico
        • Imagen SVG
        • Impresora lógica
        • Informe
          • Editor de informes
          • Agrupamiento
          • Sección
          • Cálculo
        • Informe personalizable
          • Diseñando un informe personalizable básico
          • Diseño avanzado
          • Diseñando un informe personalizable
          • Añadiendo orígenes de datos
          • Añadiendo elementos al informe
          • Características avanzadas
          • Etiquetas
          • Asistente de scripts
          • Impresión de gráficos
          • Opciones html
        • ListView
        • Lista QML
        • Localizador
        • Marco
        • Menú
        • Multivista
        • Protocolo TCP-IP
        • Reemplazo
        • Rejilla
          • Propiedades de columna de rejilla
        • Rejilla avanzada
          • Propiedades de columna de rejilla avanzada
        • Toolbar
        • ViewFlow
        • Sub-objetos de vistas de datos
          • Conexión de evento
          • Drop
          • Inserción
          • Manejador de evento
      • Objetos comunes a proyecto de datos y de aplicación
        • Búsqueda
        • Cola
        • Constante
        • Dibujo
        • Esquema de tablas
        • Fichero adjunto
        • Función
        • Librería externa
        • Lupa
        • Proceso
          • Indice de comandos de instrucción de proceso
          • Comandos de base de datos
            • API
            • Bases de datos externas
            • Búsquedas
            • Campos (grupo de comandos)
            • Cestas
            • Fichas
            • Fichas seleccionadas
            • Listas
            • Tablas
            • Tubos
          • Básicos
            • Controles de flujo
            • Debug
            • Ejecución
            • Salida/retornos
            • Scripts (grupo de comandos)
            • Transacciones (comandos)
            • Variables
          • Comunicación
            • Internet
            • Protocolo TCP
            • Puerto serie
            • SDV
          • Interfaz
            • Acciones (comandos)
            • Control
              • Ejemplo de CSS
            • Diálogos
            • Formularios - comandos
            • Localizadores
            • Objeto - grupo de comandos
            • Ventana principal
            • Vista de datos - comandos
          • Sistema
            • Comandos de Sistema
            • Configuración
            • Directorios
            • Ficheros
        • Tubo de ficha
        • Tubo de lista
        • Variable local
      • Editores
        • Asistente de fórmulas
          • Operadores
          • Funciones estándar
            • Funciones API
            • Funciones básicas
            • Funciones de cadenas
              • Expresiones regulares
            • Funciones científicas
            • Funciones de Cliente-servidor
            • Funciones de color
            • Funciones de códigos
            • Funciones de directorios
            • Funciones de fechas
            • Funciones de ficha en curso
            • Funciones de horas
            • Funciones JSON
            • Funciones de Internet
            • Funciones de juegos de caracteres
              • Codecs
            • Funciones numéricas
            • Funciones de sistema
            • Funciones de tiempo
            • Funciones trigonométricas
          • Funciones de dll
          • Funciones de proceso
          • Funciones de campo
          • Campos
          • Constantes
          • Variables globales
          • Variables locales
          • Variables del sistema
          • Verificador de fórmulas
          • Conversión automática de datos
          • Introducción de datos literales
          • Secuencias de escape en cadenas de caracteres
          • Composición de sendas en fórmulas
          • Operar con datos de tipo fecha, hora y tiempo
        • Editor de imágenes
        • Selector de fuentes
    • Scripts
      • Lenguajes
        • JavaScript
          • Procesos JavaScript
          • Fórmulas JavaScript
          • Clases
            • Funciones globales
            • Objetos
            • VAbstractBrowser
            • VAbstractDataView
            • VAbstractListDataView
            • VAdvandedGridListDataView
            • VAlternatorListDataView
            • VApp
            • VBoundFieldComboBox
            • VBoundFieldEdit
            • VBoundFieldEditBrowser
            • VBoundFieldListBox
            • VByteArray
            • VCheckBox
            • VClipboard
            • VClockWidget
            • VComboBox
            • VComboListDataView
            • VCoverFlowListDataView
            • VCWebView
            • VDataCatcherEdit
            • VDataCatcherEditBrowser
            • VDataViewDialog
            • VDateEdit
            • VDateEditBrowser
            • VDateTimeEdit
            • VDateTimeEditBrowser
            • VDial
            • VDir
            • VExtension
            • VFile
            • VFileInfo
            • VFilePathEditBrowser
            • VFinder
            • VFont
            • VFormBlockListDataView
            • VFormDataView
            • VFormulaEditBrowser
            • VGaugeWidget
            • VGridListDataView
            • VGroupBox
            • VImage
            • VImageEdit
            • VImageWidget
            • VInstancesList
            • VInstance
            • VInstances
            • VItemRegisterPattern
            • VLabel
            • VLineEdit
            • VLineEditBrowser
            • VListBox
            • VListDataView
            • VLogin
            • VMainWindow
            • VMdiView
            • VMimeData
            • VMultiDataView
            • VNumberSpinBox
            • VNumberSpinBoxBrowser
            • VObjectInfo
            • VObjectInstance
            • VProcess
            • VProgressBar
            • VProjectInfo
            • VPushButton
            • VQmlFormDataView
            • VQmlListDataView
            • VQmlListModel
            • VQuery
            • VRadioButton
            • VRegister
            • VRegisterList
            • VReportListDataView
            • VRequest
            • VResponse
            • VRoot
            • VScreen
            • VScrollArea
            • VServerAdmin
            • VSettings
            • VSlider
            • VSlotListDataView
            • VSolutionInfo
            • VSplitter
            • VSqlDatabase
            • VSSLCertificate
            • VSSLInfo
            • VSSLSessionCipher
            • VStackedWidget
            • VSvgButton
            • VSvgSlideSwitch
            • VSvgToggleSwitch
            • VSvgWidget
            • VSysInfo
            • VTableInfo
            • VTabWidget
            • VTextEdit
            • VTextFIle
            • VThermometerWidget
            • VThumbWheel
            • VTimeEdit
            • VTimeEditBrowser
            • VToolBox
            • VTreeItem
            • VTreeItemRegister
            • VTreeListDataView
            • VTreeMenu
            • VTreeMultiTableListDataView
            • VTreeWidget
            • VUser
            • VUserGroup
            • VUserGroupList
            • VUserList
            • VXmlReader
            • VXmlWriter
            • Widget
            • XMLHttpRequest
        • QML
          • Tipos QML
          • Funciones específicas de QML
    • Depuración
      • Depuración de procesos de Velneo
      • Depuración de procesos JavaScript
      • Monitor de vClient
    • Extensiones de Velneo vDevelop
    • Acceso directo a una solución desde vDevelop
    • Buenas prácticas
      • Buenas prácticas de organización
        • Proyectos
        • Organización de carpetas
        • Proyecto de datos
        • Proyecto de aplicación
      • Buenas prácticas de codificación
        • Identificadores
        • Teclas aceleradoras
        • Documenta
        • Diseña los formularios como si no existiesen los layouts
      • Buenas prácticas de rendimiento
        • Arquitectura
          • Listas de registros
          • Lista de resultados de una búsqueda
          • Las cestas
          • Las variables globales
          • La caché de fichas
          • Programa en cloud
        • Formularios
          • Condiciones de visible y activo
          • Carga de subformularios en pestaña, caja o pila
        • Base de datos
          • Campos
          • Indices
          • Actualizaciones
          • Eventos de tabla o triggers
          • Variables globales y constantes
          • Tablas en memoria vs tablas en disco
          • Optimizar migraciones de datos
          • Búsquedas en el servidor ¿Cuándo y Cómo?
          • Campos fórmula vs campos en disco
          • Indices condicionados vs búsquedas complejas
          • ¿Cuándo usar tablas de extensión?
          • Indices de trozos y palabras
          • ¿Cuándo usar cada tipo de campo alfa?
        • Procesos y funciones y eventos
          • 1º, 2º, 3º y 4º plano ¿Cuándo usar cada uno?
          • Bloqueo blando vs bloqueo duro
          • Pasar información del cliente al servidor
          • ¿Cómo optimizar transacciones grandes?
          • ¿Cómo gestionar las transacciones?
          • Grabaciones optimizadas para el usuario
        • Carga de registros en objetos de lista
          • Rejillas
            • Campos punteros a singular
            • Totales
            • Condiciones de activo, visible y color en columna
            • Campos de tipo objeto
        • Conoce los límites
      • Imágenes
      • Buenas prácticas para el desarrollo en equipo
    • Análisis de bases de datos para aplicaciones de Velneo
      • Un centro de enseñanza
      • Facturas de un cliente
      • Repartos de obras de teatro
      • Galería de arte
      • Gestión de un colegio
      • Instalación de lunas para vehículos
      • Libros y autores
      • Tienda de discos
      • Últimos pedidos de un proveedor
      • Existencias por almacén y precios por cliente
      • Generación de tickets para un quiosco
      • Navegación por facturas
  • Velneo vDevelop Web
  • Velneo vAdmin
    • ¿Qué es Velneo vAdmin?
    • Gestión de usuarios
    • Gestión de aplicaciones
      • Soluciones
      • Instancias
      • Disco
    • Monitorización
      • Lista de comandos
    • Tareas
    • Acceso directo
  • Velneo vClient
    • ¿Qué es Velneo vClient?
    • Movilidad
    • Funcionalidades de Velneo vClient
      • Accesos directos y VRL
      • Cambiar idioma
      • Panel de procesos en 2º plano
      • Manejo de rejillas
        • Submenú de filtros
      • Uso de la rejilla avanzada
      • Manejo de cestas
      • Refrescos
      • Caché local
      • Edición de campos enlazados a maestro
      • Edición de campos de tipo fecha
      • Capturar imagen desde una cámara
      • Asignar impresoras lógicas
      • Actualización automática
      • Personalización de la ventana de conexión de Velneo vClient
      • Instalador personalizado de Velneo vClient
      • Ordenación de listas
  • Velneo vServer
    • ¿Qué es Velneo vServer?
    • Instalación y configuración
      • Activación de la licencia
      • Línea de comandos de Velneo vServer
      • Parámetros configurables de Velneo vServer
      • Estructura de directorios
    • Iniciar y detener Velneo vServer
    • Funcionalidades
      • Protocolo VATP
      • Protocolo VATPS
      • Multi-hilo
      • Integridad referencial
      • Refrescos terciarios
      • Sistema transaccional
      • Sistema de bloqueos
      • Tecnología bigkey
      • Hilo de control
    • vPacker
  • Velneo vInstallBuilder
    • ¿Qué es Velneo vInstallBuilder?
    • Configurar una instalación
    • Probar una instalación
    • Crear el instalable
    • Accesos directos
  • Velneo vModApache
    • ¿Qué es Velneo vModApache?
    • Instalación y configuración
    • Nomenclatura de objetos en urls
    • Uso de ficheros adjuntos
    • Caché local de Velneo vModApache
  • Velneo vDataClient
    • ¿Qué es Velneo vDataClient?
    • Iniciar Velneo vDataClient
    • Interfaz de Velneo vDataClient
    • Procesos
    • Utilidades
    • Acceso directo a una instancia de datos
  • Velneo vTranslator
    • ¿Qué es Velneo vTranslator?
    • Importación y exportación basada en XLIFF
    • Acceso directo a una solución
  • Velneo ODBC Driver
    • ¿Qué es velneo ODBC Driver?
    • Referencia de comandos SQL
  • Velneo vVersion
    • ¿Qué es Velneo vVersion?
  • Velneo vERP
    • ¿Qué es Velneo vERP?
    • Manual del programador
    • Documentación de la ApiRest
    • Novedades de la versión
  • Velneo vTutor
    • ¿Qué es vTutor?
    • Tutores de objetos básicos
      • Tutor de árboles visores de tablas arboladas
      • Tutor de búsquedas
      • Tutor de cestas
      • Tutor de formularios
      • Tutor de informes
      • Tutor de localizador básico
      • Tutor de marcos
      • Tutor de rejillas
      • Tutor de rejillas avanzadas
    • Tutores de objetos avanzados
      • Tutor de alternadores de lista
      • Tutor de comboview
      • Tutor de drag and drop
      • Tutor de eventos
      • Tutor de tablas de extensión y extensiones de ficha
      • Tutor de grabación de fichas
      • Tutor de gráficos
      • Tutor de impresión de informes
      • Tutor de lupas
      • Tutor de protocolo TCP/IP
      • Tutor de reemplazo
    • Tutores de controles
      • Tutor de botones de menú
      • Tutor de controles SVG
      • Tutor de edición numérica
      • Tutor de visor html dinámico
      • Tutor de vistas de datos de lista
    • Tutores de procesos y manejadores de evento avanzados
      • Tutor de cambio de marco
      • Tutor de comandos de interfaz y acciones
      • Tutor de importación y exportación de ficheros ASCII
      • Tutor de portapapeles
      • Tutor de procesos
      • Tutor de SDV
    • Tutores de scripts
      • QML: hola mundo
      • QML: tutor básico
      • QML: tutor de vistas
      • Tutor de XMLHttpRequest (webServices)
  • Velneo cloud
    • ¿Qué es Velneo Cloud?
    • Panel de control vServer cloud
      • URC
      • vServer
      • Apache
      • SFTP
      • Usuarios
    • Copias de seguridad
    • Velneo cloud API
      • Uso de Velneo cloud API
    • Explorador de archivos cloud sFTP
    • TCP en Velneo cloud
    • Velneo vModApache en cloud
    • SLA
    • Hora de los servidores en el cloud de Velneo
    • ¿Qué puedo hacer si tengo una incidencia en mi servidor cloud?
Con tecnología de GitBook
En esta página
  • ¿Cómo se calcula ese valor?
  • Autenticación
  • vServer
  • Obtiene el estado de tu Velneo vServer
  • Inicia tu Velneo vServer
  • Detiene tu Velneo vServer
  • Establece las credenciales para poder acceder a tu Velneo vServer
  • Copia de seguridad de tu Velneo vServer
  • Groups
  • Agrega si no existe o modifica un grupo
  • Obtener los datos de un grupo
  • Obtener los datos de todos los grupos
  • Eliminar un grupo
  • Users
  • Agrega si no existe o modifica un usuario
  • Obtener los datos de un usuario
  • Obtener los datos de todos los usuarios
  • Eliminar un usuario
  • Folders
  • Agrega si no existe o modifica una carpeta compartida
  • Obtener los datos de una carpeta
  • Obtener los datos de todas las carpetas
  • Eliminar una carpeta
  • Instancias de aplicación
  • Agrega si no existe o modifica una instancia de aplicación
  • Obtener los datos de una instancia de aplicación
  • Obtener los datos de todas las instancias de aplicación
  • Eliminar una instancia de aplicación
  • Instancias de datos
  • Obtener los datos de una instancia de datos
  • Obtener los datos de todas las instancias de datos
  • Eliminar una instancia de datos
  • Cálculo del valor signed
  • php
  • bash
  • python

¿Te fue útil?

  1. Velneo cloud
  2. Velneo cloud API

Uso de Velneo cloud API

Última actualización hace 4 años

¿Te fue útil?

Se habilitan dos posibles formas de interactuar con Velneo Cloud API. Por un lado disponemos de un servicio REST y de un servicio RFC (usando funciones remotas de Velneo).El servicio REST consiste en una llamada HTTPS con una serie de parámetros. Los verbos soportados son POST, GET, PUT y DELETE.

Por ejemplo:

GET Obtiene el estado de tu Velneo vServer

El servicio RFC tiene un funcionamiento similar. Por ejemplo:

set status, rfc:vserver("vatp://cloudapi.velneo.com", "cloudapi_1", "cloudapi", "cloudapi", "GET" )
set result, rfc:users("vatp://cloudapi.velneo.com", "cloudapi_1", "cloudapi", "cloudapi", "POST", params.json )

Los parámetros necesarios se envían en un sola variable en formato JSON representado en el ejemplo anterior por params.json. Siempre se usan las mismas variables que en el caso del servicio REST salvo que se indique lo contrario, y siempre en minúsculas.

Un ejemplo es:

{"name":"Luis", "password":"xxx"}

Todas las respuestas vienen en JSON.

Para poder usar el servicio RFC necesitas una API Key que puedes conseguir a través de nuestro centro de soporte indicando el email asociado al Velneo vServer que quieres gestionar con la API. Este API Key es privada y NO debes compartirla con otras personas.

En la descripción de los parámetros se establecen varios criterios:

  • Si la variable va entre corchetes indica que es opcional.

  • Los posibles valores se separan por el carácter “|”.

  • Si alguno de los posibles valores está en negrita indica el valor por defecto si se omite esa variable.

Ten en cuenta que Velneo API Cloud puede usar diferentes versiones. Confirma que estás usando la versión correcta en la url en el caso de REST o en el nombre de instancia en el caso de RFC asociada a esta documentación.

Para utilizar cualquiera de las operaciones primero es necesario validarse en el servicio y obtener un identificador de sesión.

Salvo en el proceso de validación, en el resto de operaciones es necesario incluir el identificador de sesión, la hora actual (timestamp con zona horaria UTC) en formato número (por ejemplo en php: gmdate("U"); y en Velneo es currentUTCDateTime()) y un campo signed que representa el cifrado de sesión+timestamp+apikey. El cálculo sería:

signed=sha1(sesion+timestamp+apikey)

¿Cómo se calcula ese valor?

El valor de sesión (o email cuando se llama a iniciar sesión), el timestamp, el valor de signed y el método a usar son obligatorios en todas las llamadas y se omiten en la definición de los parámetros durante la documentación. Nos referiremos a ellos como "obligatorios".

En el caso de usar REST, ya depende del software que uses para las llamadas (php, python, etc.) el cómo debes calcular el valor de signed.

El valor de signed, al incluir el timestamp, hay que calcularlo antes de cada petición a la api cloud.

Autenticación

Todas las operaciones requieren autenticación. El primer paso para iniciar una sesión es una llamada POST.

Los parámetros son:

params={'email':'','timestamp': ,'signed':''}

Debemos tener en cuenta que sólo en esta llamada se incluye el email, tanto como parámetro como en el cálculo de signed (email+timestamp+apikey).

Usando REST sería:

POST https://cloudapi.velneo.com/v1/session

Retorna

  • status_code: 200 (si todo ok), 401 (si falló la autenticación).

  • session: identificador de la sesión creada,

Un ejemplo completo de obtener la sesión en Linux usando bash sería:

#!/bin/bash

email=ejemplo@gmail.com
timestamp=$(date +%s)
apikey=NyraFY6GMz8lu1fameMdrH0V
signed=$(echo -n "$email$timestamp$apikey" | sha1sum | awk '{print $1}')

curl -H 'Accept: application/json' \
-d method=POST \
--data-urlencode "params={'email': '$email', 'timestamp': $timestamp, 'signed': '$signed'}" \
https://cloudapi.velneo.com/v1/session

El código anterior retorna un JSON similar a este:

{ "status_code" : 200, "session": "796bcd1d-30da-433b-a36c-f0cf7737f73f"}

En el caso de usar el servicio RFC:

fun:SESSION_CREATE@vCloudApi.dat($EMAIL@vCloudApi.dat,$APIKEY@vCloudApi.dat)

Retorna

  • status_code: 200 (si todo ok), 401 (si falló la autenticación).

  • session: identificador de la sesión creada.

Como comentamos antes el identificador de sesión retornado por esta llamada debe usarse en el resto de llamadas a Velneo Cloud API. Esta variable session es única mientras dure la sesión del usuario. Si un usuario intenta autenticarse de nuevo, se le retornará el mismo identificador de sesión. Si un usuario quiere terminar la sesión definitivamente debe llamar a la URL o a la RFC session con el verbo DELETE. Tener en cuenta que si un usuario ha iniciado sesión en la API vía múltiples aplicaciones, cuando se termina la sesión se termina para todos.

curl -H 'Accept: application/json'\
-d method=DELETE \
--data-urlencode"params="{'session':'796bcd1d-30da-433b-a36c-f0cf7737f73f','timestamp': <timestamp>,'signed': '<signed>'}" \
https://cloudapi.velneo.com/v1/session

vServer

Tu Velneo vServer puede ser iniciado, parado y consultado su estado. Los parámetros son:

GET https://cloudapi.velneo.com/v1/vserver

Parámetros

  • session

  • timestamp

  • signed

Obtiene el estado de tu Velneo vServer

Parámetros

Retorna

  • status_code: 200 (si todo ok), 401 (si falló la autenticación), 403 (otro error).

  • status: puede tener los valores "running", "stopped".

  • vrl: la vrl completa de conexión a tu Velneo vServer Cloud. Por ejemplo, "vatp://c3.velneo.com:6676".

  • version: la versión en la que se está ejecutando tu Velneo vServer, por ejemplo, "7.8.0".

GET https://cloudapi.velneo.com/v1/vserver

Ejemplo curl desde línea de comandos:

curl -H 'Accept: application/json' \
-d method=GET \
--data-urlencode"params="{'session':'796bcd1d-30da-433b-a36c-f0cf7737f73f','timestamp': <timestamp>,'signed':'<signed>'" \
https://cloudapi.velneo.com/v1/vserver

Usando RFC sería:

fun:VSERVER_START@vCloudApi.dat($EMAIL@vCloudApi.dat)

Un ejemplo de la salida es:

{"status_code": 200, "status": "running", "vrl": "vatps://c3.velneo.com:6070", "version": "25.0.4"}

Inicia tu Velneo vServer

Parámetros

  • session

  • timestamp

  • signed

  • action: "start"

Retorna

  • status_code: 200 (si todo ok), 401 (si falló la autenticación), 403 (otro error).

Ejemplo curl desde línea de comandos:

curl -H 'Accept: application/json' \
-d method=PUT \
--data-urlencode"params="{'session':'796bcd1d-30da-433b-a36c-f0cf7737f73f','timestamp': <timestamp>,'signed':'<signed>','action':'start'}" \
https://cloudapi.velneo.com/v1/vserver

Usando RFC sería:

fun:VSERVER_START@vCloudApi.dat($EMAIL@vCloudApi.dat)

Un ejemplo de la salida es:

{"status_code": 200, "status": "running", "vrl": "vatps://c3.velneo.com:6070", "version": "25.0.4"}

Detiene tu Velneo vServer

Parámetros

  • session

  • timestamp

  • signed

  • action: "stop"

Retorna

  • status_code: 200 (si todo ok), 401 (si falló la autenticación), 403 (otro error).

PUT https://cloudapi.velneo.com/v1/vserver

Ejemplo curl desde línea de comandos:

curl -H 'Accept: application/json' \
-d method=PUT \
--data-urlencode"params="{'session':'796bcd1d-30da-433b-a36c-f0cf7737f73f','timestamp': <timestamp>,'signed':'<signed>','action':'stop'}" \
https://cloudapi.velneo.com/v1/vserver

Usando RFC sería:

fun:VSERVER_STOP@vCloudApi.dat($EMAIL@vCloudApi.dat)

Un ejemplo de la salida es:

{"status_code": 200}

Establece las credenciales para poder acceder a tu Velneo vServer

Parámetros

  • session

  • timestamp

  • username: nombre de un usuario supervisor de tu Velneo vServer.

  • password: contraseña del usuario indicado en el parámetro anterior.

Retorna

  • status_code: 200 (si todo ok), 401 (si falló la autenticación), 403 (otro error).

PUT https://cloudapi.velneo.com/v1/vserver

Ejemplo curl desde línea de comandos:

curl -H 'Accept: application/json' \
-d method=PUT \
--data-urlencode"params="{'session':'796bcd1d-30da-433b-a36c-f0cf7737f73f','timestamp': <timestamp>,'signed':'<signed>', 'username': 'web', 'password': 'adsas1'}" \
https://cloudapi.velneo.com/v1/vserver

Usando RFC sería:

fun:VSERVER_CREDENTIALS@vCloudApi.dat($EMAIL@vCloudApi.dat, "usuario", "pass")

Un ejemplo de la salida es:

{"status_code": 200}

Copia de seguridad de tu Velneo vServer

Parámetros

  • session

  • timestamp

  • signed

  • action: "backup".

Retorna

  • status_code: 200 (si todo ok), 401 (si falló la autenticación), 403 (otro error).

  • url: enlace para la descarga de la copia.

GET https://cloudapi.velneo.com/v1/vserver

Groups

Permite gestionar los grupos de usuarios en tu Velneo vServer.

PUT https://cloudapi.velneo.com/v1/group

Agrega si no existe o modifica un grupo

Parámetros

  • session

  • timestamp

  • signed

  • name: nombre del grupo.

  • [manageSolutions]: yes |no.

  • [addSolution]: "nombre". Indica el nombre de la solución a agregar al grupo.

  • [addAppInstance]: "identificador de la instancia de aplicación". Añade permisos a este grupo para acceder a la instancia de aplicación con el identificador indicado. El identificador es obtenido cuando se agrega la instancia.

Retorna

  • status_code: 200 (si todo ok), 401 (si falló la autenticación), 403 (otro error).

  • message: mensaje descriptivo del error.

Obtener los datos de un grupo

GET https://cloudapi.velneo.com/v1/group

Parámetros

  • session

  • timestamp

  • signed

  • name: nombre del grupo.

Retorna

  • Un JSON con la información del grupo.

Ejemplo curl desde línea de comandos:

curl -H 'Accept: application/json' \
-d method=GET \
--data-urlencode"params="{'session':'796bcd1d-30da-433b-a36c-f0cf7737f73f','timestamp': <timestamp>,'signed':'<signed>', ‘name': 'test'}" \
https://cloudapi.velneo.com/v1/group

Un ejemplo de la salida es: {"Name":"test","puedeBorrarSitios":false,"puedeCrearSitios":false}

Obtener los datos de todos los grupos

GET https://cloudapi.velneo.com/v1/groups

Parámetros

  • session

  • timestamp

  • signed

Retorna

  • Un JSON con la información de los grupos.

Ejemplo de salida:

{"groups":[{"Name":"admin","puedeBorrarSitios":true,"puedeCrearSitios":true},{"Name":"Constantes","puedeBorrarSitios":false,"puedeCrearSitios":false},{"Name":"test","puedeBorrarSitios":false,"puedeCrearSitios":false},{"Name":"test1","puedeBorrarSitios":false,"puedeCrearSitios":false},{"Name":"web","puedeBorrarSitios":false,"puedeCrearSitios":false},{"Name":"prueba180717","puedeBorrarSitios":true,"puedeCrearSitios":true},{"Name":"prueba","puedeBorrarSitios":false,"puedeCrearSitios":false}]}

Eliminar un grupo

DELETE https://cloudapi.velneo.com/v1/group

Parámetros

  • session

  • timestamp

  • signed

  • name: nombre del grupo.

Retorna

  • status_code: 200 (si todo ok), 401 (si falló la autenticación), 403 (otro error).

  • message: mensaje descriptivo del error.

Users

Permite gestionar los usuarios en tu Velneo vServer.

PUT https://cloudapi.velneo.com/v1/user

Agrega si no existe o modifica un usuario

Parámetros

  • session

  • timestamp

  • signed

  • username: nombre del usuario a agregar. No se puede modificar una vez creado.

  • password: password a establecer para este usuario.

  • [fullname]: nombre completo del usuario.

  • group: grupo en el que se incluirá al usuario.

  • [isSupervisor]: yes|no. Indica si el usuario añadido es supervisor de tu Velneo vServer.

  • [accountDisabled]: yes|no . Indica si la cuenta del usuario está deshabilitada o no.

  • [mustChangePassword]: yes|no. Indica si el usuario debe cambiar su contraseña en el siguiente inicio de sesión.

  • [passwordNeverExpires]: yes|no. Indica si la contraseña del usuario nunca caduca.

Retorna

  • status_code: 200 (si todo ok), 401 (si falló la autenticación), 403 (otro error).

  • message: mensaje descriptivo del error.

Obtener los datos de un usuario

GET https://cloudapi.velneo.com/v1/user

Parámetros

  • session

  • timestamp

  • signed

  • username: nombre del usuario.

Retorna

  • Un JSON con la información del usuario.

Ejemplo de salida:

{"FullName":"Prueba 2","Name":"prueba","bloqueado":false,"debeCambiarPassword":false,"desactivado":false,"passwordNuncaCaduca":false}

Obtener los datos de todos los usuarios

GET https://cloudapi.velneo.com/v1/users

Parámetros

  • session

  • timestamp

  • signed

  • groupname: si queremos todos los usuarios en esta propiedad hay que indicar "-all". Si queremos los usuarios de un determinado grupo, indicarlo como propiedad.

Retorna

  • Un JSON con la información de los usuarios.

Ejemplo curl desde línea de comandos:

curl -H 'Accept: application/json' \
-d method=GET \
--data-urlencode"params="{'session':'796bcd1d-30da-433b-a36c-f0cf7737f73f','timestamp': <timestamp>,'signed':'<signed>', ‘groupname': 'test'}" \
https://cloudapi.velneo.com/v1/users
Un ejemplo de la salida es:
{"users":[{"FullName":"Antonio Carmona","Name":"acarmona","bloqueado":false,"debeCambiarPassword":false,"desactivado":false,"passwordNuncaCaduca":false},{"FullName":"Isabel Molina","Name":"imolina","bloqueado":false,"debeCambiarPassword":false,"desactivado":false,"passwordNuncaCaduca":false},{"FullName":"Luís González","Name":"lgonzalez","bloqueado":false,"debeCambiarPassword":false,"desactivado":false,"passwordNuncaCaduca":false}]}

Si queremos obtener información de todos los usuarios de todos los grupos hacemos:

curl -H 'Accept: application/json' \
-d method=GET \
--data-urlencode"params="{'session':'796bcd1d-30da-433b-a36c-f0cf7737f73f','timestamp': <timestamp>,'signed':'<signed>', ‘groupname': '-all'}" \
https://cloudapi.velneo.com/v1/users

Un ejemplo de la salida es:

{"users":[{"FullName":"Antonio Carmona","Name":"acarmona","bloqueado":false,"debeCambiarPassword":false,"desactivado":false,"passwordNuncaCaduca":false},{"FullName":"","Name":"constantes","bloqueado":false,"debeCambiarPassword":false,"desactivado":false,"passwordNuncaCaduca":true},{"FullName":"Isabel Molina","Name":"imolina","bloqueado":false,"debeCambiarPassword":false,"desactivado":false,"passwordNuncaCaduca":false},{"FullName":"Luís González","Name":"lgonzalez","bloqueado":false,"debeCambiarPassword":false,"desactivado":false,"passwordNuncaCaduca":false},{"FullName":"Prueba 2","Name":"prueba","bloqueado":false,"debeCambiarPassword":false,"desactivado":false,"passwordNuncaCaduca":false},{"FullName":"","Name":"public","bloqueado":false,"debeCambiarPassword":false,"desactivado":false,"passwordNuncaCaduca":false},{"FullName":"","Name":"velneo","bloqueado":false,"debeCambiarPassword":false,"desactivado":false,"passwordNuncaCaduca":true},{"FullName":"","Name":"web","bloqueado":false,"debeCambiarPassword":false,"desactivado":false,"passwordNuncaCaduca":false}]}

Eliminar un usuario

DELETE https://cloudapi.velneo.com/v1/user

Parámetros

  • session

  • timestamp

  • signed

  • username: nombre del usuario.

Retorna

  • status_code: 200 (si todo ok), 401 (si falló la autenticación), 403 (otro error).

  • message: mensaje descriptivo del error.

Folders

Permite gestionar las carpetas compartidas en tu Velneo vServer.

PUT https://cloudapi.velneo.com/v1/folder

Agrega si no existe o modifica una carpeta compartida

Parámetros

  • session.

  • timestamp

  • signed

  • name: nombre de la carpeta. No se puede modificar una vez creada.

  • path: directorio relativo a tu HOME donde se creará la carpeta. Solo necesario cuando se crea la carpeta. Por ejemplo, clientes/cliente1 creará la carpeta compartida en HOME/clientes/clientes1. Es obligatorio usar la barra (/).

  • group: nombre del grupo al que se le darán permisos para acceder a esta carpeta. El grupo debe existir.

Retorna

  • status_code: 200 (si todo ok), 401 (si falló la autenticación), 403 (otro error)

  • message: mensaje descriptivo del error.

Obtener los datos de una carpeta

GET https://cloudapi.velneo.com/v1/folder

Parámetros

  • session

  • timestamp

  • signed

  • name: nombre de la carpeta.

Retorna

  • Un JSON con la información de la carpeta.

Un ejemplo de retorno es:

{"nombre":"testapi","path":"/home/ejemplo@gmail.com/Velneo/datos/test/1"}

Obtener los datos de todas las carpetas

GET https://cloudapi.velneo.com/v1/folders

Parámetros

  • session

  • timestamp

  • signed

Retorna

  • Un JSON con la información de las carpetas.

Un ejemplo de salida es:

{"folders":[{"nombre":"/","path":"/"},{"nombre":"datos","path":"/home/ejemplo@gmail.com/Velneo/datos"},{"nombre":"testapi","path":"/home/ejemplo@gmail.com/Velneo/datos/test/1"}]}

Eliminar una carpeta

DELETE https://cloudapi.velneo.com/v1/folder

Parámetros

  • session

  • timestamp

  • signed

  • name: nombre de la carpeta.

Retorna

  • status_code: 200 (si todo ok), 401 (si falló la autenticación), 403 (otro error).

  • message: mensaje descriptivo del error

Instancias de aplicación

Permite gestionar las instancias de aplicación en tu Velneo vServer.

PUT https://cloudapi.velneo.com/v1/instance

Agrega si no existe o modifica una instancia de aplicación

Parámetros

  • session

  • timestamp

  • signed

  • name: nombre de la instancia. No se puede modificar una vez creada.

  • project: nombre del proyecto a instanciar.

  • solution: nombre de la solución que contiene el proyecto.

  • folderShared: nombre de la carpeta compartida donde se creará la instancia.

    Si en este parámetro indicas el nombre de una carpeta seguido del nombre de un directorio, te creará el directorio si no existe y le asigna esa ruta. Por ejemplo, si folderShared puede recibir el valor "datos/cliente1", creará el directorio cliente1 dentro de la carpeta compartida "datos" y le asignará la ruta "datos/cliente1" a las instancias de datos.

Retorna

  • status_code: 200 (si todo ok), 401 (si falló la autenticación), 403 (otro error).

  • message: mensaje descriptivo del error.

  • id_instancia: identificador único de la instancia creada.

Obtener los datos de una instancia de aplicación

GET https://cloudapi.velneo.com/v1/instance

Parámetros

  • session

  • timestamp

  • signed

  • name: nombre de la carpeta.

  • tipo: "app".

Retorna

  • Un JSON con la información de la instancia.

Un ejemplo de salida es:

{"nombre":"Biblio","proyecto":"2ewlh1l5.vca","solucion":"Biblioteca"}

Obtener los datos de todas las instancias de aplicación

GET https://cloudapi.velneo.com/v1/instances

Parámetros

  • session

  • timestamp

  • signed

  • tipo: "app".

Retorna

  • Un JSON con la información de las instancias.

Ejemplo de salida es:

{"AppInstances":[{"nombre":"Biblio","proyecto":"2ewlh1l5.vca","solucion":"Biblioteca"},{"nombre":"Informes e impresoras logicas app","proyecto":"6vg5ikms.vca","solucion":"Informes e impresoras logicas"}]}

Eliminar una instancia de aplicación

DELETE https://cloudapi.velneo.com/v1/instance

Parámetros

  • session

  • timestamp

  • signed

  • name: nombre de la instancia.

  • tipo: "app".

Retorna

status_code: 200 (si todo ok), 401 (si falló la autenticación), 403 (otro error).

  • message: mensaje descriptivo del error.

Instancias de datos

Permite gestionar las instancias de datos en tu Velneo vServer.

PUT https://cloudapi.velneo.com/v1/instance

Obtener los datos de una instancia de datos

GET https://cloudapi.velneo.com/v1/instance

Parámetros

  • session

  • timestamp

  • signed

  • name: nombre de la carpeta.

  • tipo: "data".

Retorna

  • Un JSON con la información de la instancia.

Un ejemplo de salida es:

{"nombre":"Biblio_dBiblio","proyecto":"2ewlh1l5.vcd","ruta":"datos/Biblioteca","solucion":"Biblioteca"}

Obtener los datos de todas las instancias de datos

GET https://cloudapi.velneo.com/v1/instances

Parámetros

  • session

  • timestamp

  • signed

  • tipo: "data".

Retorna

  • Un JSON con la información de las instancias.

Un ejemplo de salida es:

{"dataInstances":[{"nombre":"Biblio_dBiblio","proyecto":"2ewlh1l5.vcd","ruta":"datos/Biblioteca","solucion":"Biblioteca"},{"nombre":"Informes e impresoras logicas app_Informes e impresoras logicas dat","proyecto":"6vg5ikms.vcd","ruta":"datos/ImpresorasLogicas","solucion":"Informes e impresoras logicas"}]}

Eliminar una instancia de datos

DELETE https://cloudapi.velneo.com/v1/instance

Parámetros

  • session

  • timestamp

  • signed

  • name: nombre de la instancia.

  • tipo: "data".

Retorna

  • status_code: 200 (si todo ok), 401 (si falló la autenticación), 403 (otro error)

  • message: mensaje descriptivo del error.

Cálculo del valor signed

Veamos varios ejemplos de cómo realizar ese cálculo en varios lenguajes.

php

$fecha = new DateTime();
$timestamp = $fecha->format("U");
// $session tiene el valor retornado por la llamada a post.Session 
$hash = sha1( $session . $timestamp . $apiKey );

bash

timestamp=$(date +%s)
# $session tiene el valor retornado por la llamada a post.Session
signed=$(echo -n "$session$timestamp$apikey" | shasum -a 1 | awk '{print $1}')

python

from datetime import datetime
import hashlib
ahora = datetime.now()
unixtime = int(time.mktime(ahora.timetuple()))
# session tiene el valor retornado por la llamada a post.Session
signed = hashlib.sha1( session + str(unixtime) + key ).hexdigest()

session: identificador de sesión retornada por la llamada a .

https://cloudapi.velneo.com/v1/vserver
POST.session