source: admin/Services/ogAdmClient/sources/ogAdmClient.h @ ebbbf900

918-git-images-111dconfigfileconfigure-oglivegit-imageslgromero-new-oglivemainmaint-cronmount-efivarfsmultivmmultivm-ogboot-installerogClonningEngineogboot-installer-jenkinsoglive-ipv6test-python-scriptsticket-301ticket-50ticket-50-oldticket-577ticket-585ticket-611ticket-612ticket-693ticket-700ubu24tplunification2use-local-agent-oglivevarios-instalacionwebconsole3
Last change on this file since ebbbf900 was 9182fd9, checked in by alonso <alonso@…>, 15 years ago

git-svn-id: https://opengnsys.es/svn/trunk@979 a21b9725-9963-47de-94b9-378ad31fedc9

  • Property mode set to 100644
File size: 10.2 KB
Line 
1//****************************************************************************************************************************************************
2//      Aplicación OpenGNSys
3//      Autor: José Manuel Alonso.
4//      Licencia: Open Source
5//      Fichero: ogAdmClient.cpp
6//      Descripción:
7//              Este módulo de la aplicación OpenGNSys implementa las comunicaciones con el Cliente.
8// ****************************************************************************************************************************************************
9#include <sys/types.h>
10#include <sys/wait.h>
11#include <arpa/inet.h>
12#include <stdio.h>
13#include <stdlib.h>
14#include <string.h>
15#include <errno.h>
16#include <unistd.h>
17#include <ctype.h>
18#include <time.h>
19#include <signal.h>
20#include "ogAdmLib.h"
21
22
23#define LONGITUD_SCRIPTSALIDA 4064      // Longitud máxima de la informacin devuelta por un script
24#define LONGITUD_PARAMETROS_TRAMA 4024  // Longitud máxima de la información de la trama (parametros)
25
26#define LONGITUD_CONFIGURACION 1024     // Longitud máxima de las configuraciones de partición
27
28
29#define MAXITEMS 100
30#define MAXHTMLMNU 4000
31#define MAXPARTICIONES 24
32#define MAXINFOSO 5 // Numero máximo de nemónicos enla inforamción del S.O. de una partición
33#define MAXARGS 16 // Numero máximo de argumentos enviados a un scripts
34#define LONSTD 512 // Longitud de memoria estandar
35#define LONSTDC 256 // Longitud de memoria estandar corta
36
37
38
39TRAMA trama[1];
40
41char IPlocal[20];               // Ip local
42char Servidorhidra[20]; // IP servidor de Administración
43char Puerto[20];                // Puerto Unicode
44
45
46
47//___________________________________________________________________________________________________
48// Variables y estructuras
49//___________________________________________________________________________________________________
50
51char cmdshell[LONSTD];
52char parametros[LONSTD];
53char* argumentos[MAXARGS];
54char msglog[LONSTD];
55char msgcon[LONSTD];
56char filecmdshell[LONSTDC];
57char urlpag[LONSTDC];
58char fileini[LONSTDC];
59char filecmd[LONSTDC];
60
61struct excepcion {
62        int herror;
63        char msg[LONSTDC];
64        char modulo[LONSTDC];   
65};
66struct excepcion e;
67
68int ndebug=1; // Nivel de debuger por defecto
69
70// Nemónicos
71int MsDos=1;
72int Win98=2;
73int Win2K=3;
74int WinXP=4;
75int Linux=5;
76               
77BOOLEAN PROCESO=true;                   // Indicador de la actividad del proceso principal
78BOOLEAN CACHEEXISTS;                    // Indica si existe cache
79
80char HIDRACHEIMAGENES[LONSTDC]; // Path al directorio donde están las imágenes (en la caché)
81char HIDRASRVIMAGENES[LONSTDC]; // Path al directorio donde están las imágenes (en el repositorio)
82char HIDRASRVCMD[LONSTDC];      // Path del directorio del repositorio donde se depositan los comandos para el cliente
83char HIDRASCRIPTS[LONSTDC];     // Path al directorio donde están los scripts de la interface con la APi de funciones de OpenGnsys (en el cliente )
84char URLMENU[LONSTDC]; // Url de la pagina de menu para el browser
85char URLMSG[LONSTDC]; // Url de la página de mensajed para el browser
86
87
88int HIDRAVER;   // Versión de la apliación de Administración
89int TPAR ;      // Tamaño de la partición
90       
91SOCKET sock;    // Socket
92
93struct s_CabMnu {
94        char resolucion[2];                      // Resolución de pantalla
95        char titulo[LONSTDC];                                           // Título del menú
96        char coorx[4];                                  // Coordenada x
97        char coory[4];                                  // Coordenada y
98        char modalidad[2];              // modalidad ( número de items por línea )
99        char scoorx[4];                         // Coordenada x // Menú privado
100        char scoory[4];                         // Coordenada y
101        char smodalidad[LONSTDC];               // modalidad ( número de items por línea )
102        char htmmenupub[64];    // Nombre del fichero que contiene el html del menú (público)
103        char htmmenupri[64];            // Nombre del fichero que contiene el html del menú (privado)
104} CabMnu;  // Estructura con los datos de los menús
105       
106BOOLEAN swmnu=false; // Indicador de menú asignado
107       
108struct s_Item{
109        char idaccionmenu[16];  // Identificador del item a ejecutar
110        char urlimg[64];        // Nombre de la imagen de fondo del botón
111        char literal[LONSTDC];  // Literal del item
112        char tipoitem[2];       // Tipo de item ( público o privado)
113        char tipoaccion[2];     // Tipo de acción que ejecuta el item
114} ;
115       
116struct s_Propiedades {
117        char idordenador[16];                            // Identificador del ordenador
118        char nombreordenador[64];                // Nombre del ordenador
119        char idaula[16];                                                                // Identificador del aula
120        char servidorhidra[64];                         // IP  del servidor HUDRA
121        char puerto[16];                                                                // Puerto
122        char iprepo[16];                                                                // Dirección IP repositorio
123        char puertorepo[16];                                                            // Puerto       
124        char idperfilhard[16];                                  // Identificador del perfil hardware
125        char IPlocal[16];
126        char cache[16];                                         // Tamaño de la cache
127} Propiedades;    // Estructura con los datos del odenador
128       
129struct s_Particiones{
130        char tiposo[64];                                // Tipo de sistema operativo
131        char tipopart[16];                      // Tipo de partición
132        char tamapart[16];              // Tamao de la partición
133        char numpart[5];                // Nmero de la partición
134        char nombreso[64];    // Nombre del S.O.
135};
136       
137struct s_Hardware{
138        char nemonico[4];                               // Tipo de sistema operativo
139        char tipo[45];                  // Tipo de hardware
140        char codigovalor[256];                  // Código o descripción
141}
142;       
143struct tiposo {
144  char *tipopart;
145  char *tiposo;
146  char *nombreso; 
147};     
148
149char* tbPathImg[]={"CLIEN","CACHE","REPO"};
150
151struct tiposo tiposos[] = {
152                {"BIGDOS", "MsDos","MsDos"},
153                {"NTFS","Windows NT Platafom","Windows 2000,XP,2003"},
154                {"FAT32","Windows","Windos 98,SE,Millenium"},                   
155                {"EXT","Extendida","Extendida"},
156                {"EXT3","Linux","Linux"},
157                {"EXT2","Linux","Linux"},       
158                {"VFAT","VFAT","VFAT"},
159                {"CACHE","CACHE","CACHE"},                     
160                {"UNKNOWN","UNKNOWN","UNKNOWN"},                       
161                {"EMPTY","Libre","Libre"},
162                {"LINUX-SWAP","","Linux-swap"}};
163               
164int ntiposo = sizeof (tiposos) / sizeof (struct tiposo);
165
166struct s_Item tbMenu[MAXITEMS];                 // Tabla con los items del menu
167int contitems;                  // Contador items del menu
168       
169BOOLEAN PRCCMD;         // Indicador de comandos interactivos
170BOOLEAN CMDPTES;        // Indicador de comandos pendientes
171       
172//char modulo[64];      // Nombre de la función donde se produce el error
173
174BOOLEAN aut = false; // Variable para controlar el acceso al menú de administración
175
176pid_t  pidmenu;
177
178char* tbErrores[]={"000-Se han generado errores. No se puede continuar la ejecución de este módulo",\
179                "001-No hay memoria suficiente para el buffer",\
180                "002-No se puede establecer conexión con el servidor de administración",\
181                "003-El fichero especificado no existe o bien no puede crearse o abrirse",\
182                "004-Comando Error",\
183                "005-El fichero est vacio",\
184                "006-Error en la ejecución del fichero autoexec",\
185                "007-Error en la recuperacion del Menu principal",\
186                "008-No hay espacio reservado para la cache en este disco",\
187                "009-Ha ocurrido algún error generando el perfil software",\
188                "010-IPlocal, NO se ha definido este parámetro",\
189                "011-IPhidra, NO se ha definido este parámetro",\
190                "012-Puerto, NO se ha definido este parámetro",\
191                "013-NO existe fichero de configuración o contiene un error de sintaxis",\
192                "014-Fallo de sintaxis en los parámetros: Debe especificar -f nombre_del_fichero_de_configuración",\
193                "015-No se ha podido crear socket para comunicación con el repositorio",\
194                "016-No se ha podido comunicar con el repositorio",\
195                "017-No existe Menu principal",\
196                "018-No se ha podido recuperar la configuración hardware del ordenador",\
197                "019-El cliente no se ha podido incluir en el sistema por un fallo en la conexión con el Servidor de Administración",\
198                "020-No se ha podido crear la carpeta en el repositorio",\
199                "021-Error en el envío de tramas al Servidor de Administración",\
200                "022-Error en la recepción de tramas desde el Servidor de Administración",\
201                "023-Error al crear Proceso Hijo para  mostrar Menú",\
202                "024-Error desconocido",\
203                };             
204                #define MAXERROR 24             // Error máximo cometido
205
206char* tbErroresScripts[]={"000-Se han generado errores. No se puede continuar la ejecución de este módulo",\
207                "001-Formato de ejecución incorrecto.",\
208                "002-Fichero o dispositivo no encontrado",\
209                "003-Error en partición de disco",\
210                "004- Partición o fichero bloqueado",\
211                "005-Error al crear o restaurar una imagen",\
212                "006-Sin sistema operativo",\
213                "007-Programa o función no ejecutable",\
214                "008-Error en la eliminación del archivo temporal de intercambio",\
215                "009-Error en la lectura del archivo temporal de intercambio",\
216                "010-Error al ejecutar código de la shell",\
217                "011-Error desconocido",       
218                };             
219        #define MAXERRORSCRIPT 11               // Error máximo cometido
220
221// Prototipos de funciones
222char* Desencriptar(char *);
223char* Encriptar(char *);
224int ValidacionParametros(int,char**);
225int CrearArchivoLog(char*);
226int LeeFileConfiguracion();
227void Log(char*);
228void UltimoError(int,char*);
229void UltimoErrorScript(int,char*);
230
231int EjecutarScript (char*,char* ,char*,int);
232char* ReservaMemoria(int);
233int EjecutarCodigo (char*,char* ,char*,int);
234
235SOCKET TCPConnect(char *,char* );
236void TCPClose(SOCKET);
237int AbreConexionTCP(void);
238void CierraConexionTCP(void);
239int EnviaTramasHidra(SOCKET,TRAMA*);
240
241int TCPWrite(SOCKET ,TRAMA*);
242
243SOCKET UDPConnect();
244int EnviaTramaRepo(SOCKET,TRAMA*,char*,char*);
245int RecibeTramaRepo(SOCKET,int);
246
247long CreateTextFile(char*,char*);
248int ExisteFichero(char*);
249int RemoveFile(char *);
250int LoadTextFile(char *);
251
252int ProcesaComandos();
253int DisponibilidadComandos(int);
254int GestionTramas(TRAMA *);
255
256int Cortesia();
257int NoComandosPtes();
258int TomaIPlocal();
259int InclusionCliente();
260int RESPUESTA_InclusionCliente(TRAMA*);
261int ComandosPendientes(void);
262int Arrancar(TRAMA *,TRAMA *);
263int Apagar(TRAMA*,TRAMA*);
264int Reiniciar(TRAMA*,TRAMA*);
265int IniciarSesion(TRAMA*,TRAMA*);
266int Actualizar();
267int CrearPerfilSoftware(TRAMA*,TRAMA*);
268int CrearPerfil(char*,char*,char*,char*,char*);
269int Nemonico(char*);
270int RestaurarImagen(TRAMA*,TRAMA*);
271int RestaurandoImagen(char* ,char *,char* ,char *,char *,char *,char*);
272
273int ParticionaryFormatear(TRAMA*,TRAMA*);
274int Particionar(char*,char*,char* );
275int Particionando(char*,char*,char*);
276int Formatear(char*,char*);
277int SetCachePartitionSize(int);
278int AutoexecClienteHidra(void);
279char* LeeConfiguracion(char*);
280char* TomaNomSO(char*,int);
281int InventarioHardware(TRAMA *,TRAMA *);
282int InventarioSoftware(TRAMA *,TRAMA *);
283int TomaConfiguracion(TRAMA *,TRAMA *);
284int RespuestaEjecucionComando(TRAMA* , TRAMA *, int);
285int ExecShell(TRAMA *,TRAMA *);
286int ConsolaRemota(TRAMA *,TRAMA *);
287int ExecBash(char*);
288char* URLDecode(char*);
289char* URLEncode(char *);
290int MuestraMenu(char*);
291void MuestraMensaje(int,char*);
292int cuestionCache(char*);
Note: See TracBrowser for help on using the repository browser.