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

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 c5ce04c was 09907c1, checked in by alonso <alonso@…>, 16 years ago

primeros archivos de administración

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

  • Property mode set to 100644
File size: 10.6 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 )
110
111int HIDRAVER;   // Versión de la apliación de Administración
112int TPAR ;      // Tamaño de la particin
113       
114SOCKET sock;    // Socket
115
116struct s_CabMnu {
117        char resolucion[2];                      // Resolucin de pantalla
118        char titulo[LONSTDC];                                           // Titulo del menu
119        char coorx[4];                                  // Coordenada x
120        char coory[4];                                  // Coordenada y
121        char modalidad[2];              // modalidad ( numero de items por linea )
122        char scoorx[4];                         // Coordenada x // Menu privado
123        char scoory[4];                         // Coordenada y
124        char smodalidad[LONSTDC];               // modalidad ( numero de items por linea )
125        char htmmenupub[64];    // Nombre del fichero que contiene el html del menu (público)
126        char htmmenupri[64];            // Nombre del fichero que contiene el html del menu (privado)
127} CabMnu;  // Estructura con los datos de los menús
128       
129BOOL swmnu=false; // Indicador de menu asignado
130       
131struct s_Item{
132        char idaccionmenu[16];  // Identificador del item a ejecutar
133        char urlimg[64];        // Nombre de la imagen de fonfo del botn
134        char literal[LONSTDC];  // Literal del item
135        char tipoitem[2];       // Tipo de otem ( público o privado)
136        char tipoaccion[2];     // Tipo de accin que ejecuta el item
137} ;
138       
139struct s_Propiedades {
140        char idordenador[16];                            // Identificador del ordenador
141        char nombreordenador[64];                // Nombre del ordenador
142        char idaula[16];                                                                // Identificador del aula
143        char servidorhidra[64];                         // IP  del servidor HUDRA
144        char puerto[16];                                                                // Puerto
145        char iprepo[16];                                                                // Direción IP repositorio     
146        char puertorepo[16];                                                            // Puerto       
147        char idperfilhard[16];                                  // Identificador del perfil hardware
148        char IPlocal[16];                                               // Ip local
149} Propiedades;    // Estructura con los datos del odenador
150       
151struct s_Particiones{
152        char tiposo[64];                                // Tipo de sistema operativo
153        char tipopart[16];                      // Tipo de particin
154        char tamapart[16];              // Tamao de la particin
155        char numpart[5];                // Nmero de la particin
156        char nombreso[64];    // Nombre del S.O.
157};
158       
159struct s_Hardware{
160        char nemonico[4];                               // Tipo de sistema operativo
161        char tipo[45];                  // Tipo de hardware
162        char codigovalor[256];                  // Codigo o descripcion
163}
164;       
165struct tiposo {
166  char *tipopart;
167  char *tiposo;
168  char *nombreso; 
169};     
170struct tiposo tiposos[] = {
171                {"BIGDOS", "MsDos","MsDos"},
172                {"NTFS","Windows NT Platafom","Windows 2000,XP,2003"},
173                {"FAT32","Windows","Windos 98,SE,Millenium"},                   
174                {"EXT","Extendida","Extendida"},
175                {"EXT3","Linux","Linux"},
176                {"EXT2","Linux","Linux"},       
177                {"VFAT","VFAT","VFAT"},
178                {"CACHE","CACHE","CACHE"},                     
179                {"UNKNOWN","UNKNOWN","UNKNOWN"},                       
180                {"EMPTY","Libre","Libre"},
181                {"LINUX-SWAP","","Linux-swap"}};
182               
183int ntiposo = sizeof (tiposos) / sizeof (struct tiposo);
184
185struct s_Item tbMenu[MAXITEMS];                 // Tabla con los items del menu
186int contitems;                  // Contador items del menu
187       
188BOOL PRCCMD;            // Indicador de comandos interactivos
189BOOL CMDPTES;   // Indicador de comandos pendientes
190       
191//char modulo[64];      // Nombre de la funcin donde se produce el error
192
193BOOL aut = false; // Variable para controlar el acceso al menu de administracion
194
195
196char* tbErrores[]={"000-Se han generado errores. No se puede continuar la ejecución de este módulo",\
197                "001-No hay memoria suficiente para el buffer",\
198                "002-No se puede establecer conexión con el servidor de administración",\
199                "003-El fichero especificado no existe o bien no puede crearse o abrirse",\
200                "004-Comando Error",\
201                "005-El fichero est vacio",\
202                "006-Error en la ejecución del fichero autoexec",\
203                "007-Error en la recuperacion del Menu principal",\
204                "008-No hay espacio reservado para la cache en este disco",\
205                "009-Ha ocurrido algún error generando el perfil software",\
206                "010-IPlocal, NO se ha definido este parámetro",\
207                "011-IPhidra, NO se ha definido este parámetro",\
208                "012-Puerto, NO se ha definido este parámetro",\
209                "013-NO existe fichero de configuración o contiene un error de sintaxis",\
210                "014-Fallo de sintaxis en los parámetros: Debe especificar -f nombre_del_fichero_de_configuración",\
211                "015-No se ha podido crear socket para comunicación con el repositorio",\
212                "016-No se ha podido comunicar con el repositorio",\
213                "017-No existe Menu principal",\
214                "018-No se ha podido recuperar la configuración hardware del ordenador",\
215                "019-El cliente no se ha podido incluir en el sistema por un fallo en la conexión con el Servidor de Administración",\
216                "020-No se ha podido crear la carpeta en el repositorio",\
217                "021-Error en el envío de tramas al Servidor de Administración",\
218                "022-Error en la recepción de tramas desde el Servidor de Administración",\
219                "023-Error desconocido",\
220                };             
221                #define MAXERROR 22             // Error máximo cometido
222
223char* tbErroresScripts[]={"000-Se han generado errores. No se puede continuar la ejecución de este módulo",\
224                "001-Formato de ejecución incorrecto.",\
225                "002-Fichero o dispositivo no encontrado",\
226                "003-Error en partición de disco",\
227                "004- Partición o fichero bloqueado",\
228                "005-Error al crear o restaurar una imagen",\
229                "006-Sin sistema operativo",\
230                "007- Programa o función no ejecutable",\
231                "008-Error desconocido",\
232                };             
233        #define MAXERRORSCRIPT 7                // Error máximo cometido
234
235// Prototipos de funciones
236char* Desencriptar(char *);
237char* Encriptar(char *);
238int ValidacionParametros(int,char**);
239int CrearArchivoLog(char*);
240int LeeFileConfiguracion();
241void Log(char*);
242void UltimoError(int,char*);
243void UltimoErrorScript(int,char*);
244
245void INTROaFINCAD(char*);
246char* TomaParametro(char*,char*);
247int SplitParametros(char**,char*, char*);
248
249int EjecutarScript (char*,char* ,char*,int);
250char* ReservaMemoria(int);
251
252SOCKET TCPConnect(char *,char* );
253void TCPClose(SOCKET);
254int AbreConexionTCP(void);
255void CierraConexionTCP(void);
256int EnviaTramasHidra(SOCKET,TRAMA*);
257int RecibeTramasHidra(SOCKET,TRAMA*);
258int TCPWrite(SOCKET ,TRAMA*);
259int TCPRead(SOCKET ,TRAMA*);
260SOCKET UDPConnect();
261int EnviaTramaRepo(SOCKET,TRAMA*,char*,char*);
262int RecibeTramaRepo(SOCKET);
263
264long CreateTextFile(char*,char*);
265int ExisteFichero(char*);
266int RemoveFile(char *);
267int LoadTextFile(char *);
268
269int ProcesaComandos();
270int DisponibilidadComandos(int);
271int GestionTramas(TRAMA *);
272
273int Cortesia();
274int NoComandosPtes();
275int TomaIPlocal();
276int InclusionCliente();
277int RESPUESTA_InclusionCliente(TRAMA*);
278int ComandosPendientes(void);
279int Arrancar(TRAMA *,TRAMA *);
280int Apagar(TRAMA*,TRAMA*);
281int Reiniciar(TRAMA*,TRAMA*);
282int Actualizar();
283int CrearPerfilSoftware(TRAMA*,TRAMA*);
284int CrearPerfil(char*,char*,char*,char*,char*);
285int Nemonico(char*);
286int RestaurarImagen(TRAMA*,TRAMA*);
287int RestaurandoImagen(char*,char*,char*,char*,char*,char*,char*);
288int ParticionaryFormatear(TRAMA*,TRAMA*);
289int Particionar(char*,char*,char* );
290int Particionando(char*,char*,char*);
291int Formatear(char*,char*);
292int SetCachePartitionSize(int);
293int AutoexecClienteHidra(void);
294char* LeeConfiguracion(char*);
295char* TomaNomSO(char*,int);
296int InventarioHardware(TRAMA *,TRAMA *);
297int InventarioSoftware(TRAMA *,TRAMA *);
298int TomaConfiguracion(TRAMA *,TRAMA *);
299int RespuestaEjecucionComando(TRAMA* , TRAMA *, int);
300int ExecShell(TRAMA *,TRAMA *);
301char* URLDecode(char*);
Note: See TracBrowser for help on using the repository browser.