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

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 ecdc8ec was 044cd96, checked in by ramon <ramongomez@…>, 16 years ago

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

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