function __construct($asistente) { $this->id = $this->asistente->get_id_elemento(); $this->proyecto = $this->asistente->get_proyecto(); //Busco el datos relacion correspondientes al componente $id = toba_info_editores::get_dr_de_clase($this->clase); $componente = array('proyecto' => $id[0], 'componente' => $id[1]); $this->datos = toba_constructor::get_runtime($componente); $this->datos->inicializar(); $datos = array('nombre' => $this->clase . ' generado automaticamente', 'proyecto' => $this->proyecto); $this->ini(); }
function __construct($asistente) { $this->asistente = $asistente; $this->asistente->registrar_molde($this); $this->id = $this->asistente->get_id_elemento(); $this->proyecto = $this->asistente->get_proyecto(); //Busco el datos relacion correspondientes al componente $id = toba_info_editores::get_dr_de_clase($this->clase); $componente = array('proyecto' => $id[0], 'componente' => $id[1]); $this->datos = toba_constructor::get_runtime($componente); $this->datos->inicializar(); $datos = array('nombre' => $this->clase . ' generado automaticamente', 'proyecto' => $this->proyecto); if ($this->asistente->tiene_fuente_definida()) { $datos['fuente_datos_proyecto'] = $this->proyecto; $datos['fuente_datos'] = $this->asistente->get_fuente(); } $this->datos->tabla('base')->set($datos); $this->ini(); }
/** * Elimina opcionalmente un conjunto de componentes pertencientes a la operación * * @param boolean $borrar_item Debe borrar el item una vez borradas sus dependencias * @param array $opciones Arreglo 'id_componente' => array('eliminar'=>true/false, 'eliminar_archivo'=>true/false) * @param boolean $con_transaccion Debe enmarcar la eliminación en una transaccion */ function eliminar($borrar_item, $opciones, $con_transaccion = true) { $item = toba::zona()->get_info(); $db = toba_contexto_info::get_db(); $arbol_componentes = array_slice($this->arbol, 1); //--- Se eliminan metadatos if ($con_transaccion) { $db->abrir_transaccion(); } foreach ($arbol_componentes as $comp) { $opcion = $opciones[$comp['componente']]; if ($opcion['eliminar']) { //--- Elimina metadatos $id_dr = toba_info_editores::get_dr_de_clase($comp['tipo']); $componente = array('proyecto' => $id_dr[0], 'componente' => $id_dr[1]); $dr = toba_constructor::get_runtime($componente, 'toba_datos_relacion', false); $dr->inicializar(); $dr->persistidor()->desactivar_transaccion(); $dr->resetear(); $dr->cargar(array('proyecto' => $this->id_proyecto, 'objeto' => $comp['componente'])); $dr->eliminar_todo(); } } //--Borro el item if ($borrar_item) { $id_dr = toba_info_editores::get_dr_de_clase('toba_item'); $componente = array('proyecto' => $id_dr[0], 'componente' => $id_dr[1]); $dr = toba_constructor::get_runtime($componente, 'toba_datos_relacion', false); $dr->inicializar(); $dr->persistidor()->desactivar_transaccion(); $dr->resetear(); $dr->cargar(array('proyecto' => $this->id_proyecto, 'item' => $this->id_item)); $dr->eliminar_todo(); } if ($con_transaccion) { $db->cerrar_transaccion(); } //--- Se eliminan subclases foreach ($arbol_componentes as $comp) { $opcion = $opciones[$comp['componente']]; if ($opcion['eliminar'] && $opcion['eliminar_archivo']) { $archivo = $this->get_path_archivo($comp); unlink($archivo); } } }
/** * Duplica un objeto y sus dependencias recursivamente * * @param array $nuevos_datos Datos a modificar en la base del objeto. Para anexar algo al nombre se utiliza el campo 'anexo_nombre' * @param boolean/string $dir_subclases Si el componente tiene subclases clona los archivos, en caso afirmativo indicar la ruta destino (relativa) * @param boolean $con_transaccion Indica si la clonación se debe incluír en una transaccion * @return array Clave del objeto que resulta del clonado */ function clonar($nuevos_datos, $dir_subclases = false, $con_transaccion = true) { //Se busca el id del datos_relacion de la clase $id_dr = toba_info_editores::get_dr_de_clase($this->datos['_info']['clase']); //Se construye el objeto datos_relacion $componente = array('proyecto' => $id_dr[0], 'componente' => $id_dr[1]); $dr = toba_constructor::get_runtime($componente); $dr->inicializar(); //Se carga con el id_origen $dr->cargar(array('proyecto' => $this->proyecto, 'objeto' => $this->id)); foreach ($nuevos_datos as $campo => $valor) { if ($campo == 'anexo_nombre') { $campo = 'nombre'; $valor = $valor . $dr->tabla('base')->get_fila_columna(0, $campo); } $dr->tabla('base')->set_fila_columna_valor(0, $campo, $valor); } //Se le fuerza una inserción a los datos_tabla //Como la clave de los objetos son secuencias, esto garantiza claves nuevas $dr->forzar_insercion(); if (!$con_transaccion) { $dr->persistidor()->desactivar_transaccion(); } //--- Si tiene subclase, se copia el archivo y se cambia if ($dir_subclases !== false) { $proyecto_dest = isset($nuevos_datos['proyecto']) ? $nuevos_datos['proyecto'] : null; $this->clonar_subclase($dr, $dir_subclases, $proyecto_dest); } //--- Se reemplazan los datos y se clonan los hijos foreach ($this->subelementos as $hijo) { //-- Si se especifico un proyecto, se propaga $datos_objeto = array(); if (isset($nuevos_datos['proyecto'])) { $datos_objeto['proyecto'] = $nuevos_datos['proyecto']; } //-- Si se especifica un anexo de nombre, se propaga if (isset($nuevos_datos['anexo_nombre'])) { $datos_objeto['anexo_nombre'] = $nuevos_datos['anexo_nombre']; } //-- La fuente tambien se propaga if (isset($nuevos_datos['fuente_datos_proyecto'])) { $datos_objeto['fuente_datos_proyecto'] = $nuevos_datos['fuente_datos_proyecto']; } if (isset($nuevos_datos['fuente_datos'])) { $datos_objeto['fuente_datos'] = $nuevos_datos['fuente_datos']; } //-- Punto de montaje tambien se propaga if (isset($nuevos_datos['punto_montaje'])) { $datos_objeto['punto_montaje'] = $nuevos_datos['punto_montaje']; } //-- SE CLONA $id_clon = $hijo->clonar($datos_objeto, $dir_subclases, $con_transaccion); //--- En el componente actual se reemplaza la dependencia por el clon $id_fila = $dr->tabla('dependencias')->get_id_fila_condicion(array('identificador' => $hijo->rol_en_consumidor())); $dr->tabla('dependencias')->modificar_fila(current($id_fila), array('objeto_proveedor' => $id_clon['componente'])); } //Se intenta acceder a las pantallas/db_registros para pasarle el nuevo punto de montaje if (isset($nuevos_datos['punto_montaje'])) { //Trato de setear el punto de montaje para las pantallas try { $dr->tabla('pantallas')->set_columna_valor('punto_montaje', $nuevos_datos['punto_montaje']); } catch (Exception $e) { } //Trato de setear el punto de montaje para las propiedades basicas try { $dr->tabla('prop_basicas')->set_columna_valor('punto_montaje', $nuevos_datos['punto_montaje']); } catch (Exception $e) { } //Trato de setear el punto de montaje para los efs try { $dr->tabla('efs')->set_columna_valor('punto_montaje', $nuevos_datos['punto_montaje']); } catch (Exception $e) { } //Trato de setear el punto de montaje para las columnas del filtro try { $dr->tabla('cols')->set_columna_valor('punto_montaje', $nuevos_datos['punto_montaje']); } catch (Exception $e) { } //Trato de setear el punto de montaje para las columnas externas del datos tabla try { $dr->tabla('externas')->set_columna_valor('punto_montaje', $nuevos_datos['punto_montaje']); } catch (Exception $e) { } } $dr->sincronizar(); //Se busca la clave del nuevo objeto $clave = $dr->tabla('base')->get_clave_valor(0); $clave['componente'] = $clave['objeto']; return $clave; }
/** * Duplica un objeto y sus dependencias recursivamente * * @param array $nuevos_datos Datos a modificar en la base del objeto. Para anexar algo al nombre se utiliza el campo 'anexo_nombre' * @param boolean/string $dir_subclases Si el componente tiene subclases clona los archivos, en caso afirmativo indicar la ruta destino (relativa) * @param boolean $con_transaccion Indica si la clonación se debe incluír en una transaccion * @return array Clave del objeto que resulta del clonado */ function clonar($nuevos_datos, $dir_subclases = false, $con_transaccion = true) { //Se busca el id del datos_relacion de la clase $id_dr = toba_info_editores::get_dr_de_clase($this->datos['_info']['clase']); //Se construye el objeto datos_relacion $componente = array('proyecto' => $id_dr[0], 'componente' => $id_dr[1]); $dr = toba_constructor::get_runtime($componente); $dr->inicializar(); //Se carga con el id_origen $dr->cargar(array('proyecto' => $this->proyecto, 'objeto' => $this->id)); foreach ($nuevos_datos as $campo => $valor) { if ($campo == 'anexo_nombre') { $campo = 'nombre'; $valor = $valor . $dr->tabla('base')->get_fila_columna(0, $campo); } $dr->tabla('base')->set_fila_columna_valor(0, $campo, $valor); } //Se le fuerza una inserción a los datos_tabla //Como la clave de los objetos son secuencias, esto garantiza claves nuevas $dr->forzar_insercion(); if (!$con_transaccion) { $dr->persistidor()->desactivar_transaccion(); } //-- Punto de montaje tambien se propaga if (isset($nuevos_datos['punto_montaje'])) { $dr->tabla('prop_basicas')->set_columna_valor('punto_montaje', $nuevos_datos['punto_montaje']); } //--- Si tiene subclase, se copia el archivo y se cambia if ($dir_subclases !== false) { $proyecto_dest = isset($nuevos_datos['proyecto']) ? $nuevos_datos['proyecto'] : null; $this->clonar_subclase($dr, $dir_subclases, $proyecto_dest); } $dep_nuevas = array(); $dep_viejas = array(); //--- Se reemplazan los datos y se clonan los hijos foreach ($this->subelementos as $hijo) { //-- Si se especifico un proyecto, se propaga $datos_objeto = array(); if (isset($nuevos_datos['proyecto'])) { $datos_objeto['proyecto'] = $nuevos_datos['proyecto']; } //-- Si se especifica un anexo de nombre, se propaga if (isset($nuevos_datos['anexo_nombre'])) { $datos_objeto['anexo_nombre'] = $nuevos_datos['anexo_nombre']; } //-- La fuente tambien se propaga if (isset($nuevos_datos['fuente_datos_proyecto'])) { $datos_objeto['fuente_datos_proyecto'] = $nuevos_datos['fuente_datos_proyecto']; } if (isset($nuevos_datos['fuente_datos'])) { $datos_objeto['fuente_datos'] = $nuevos_datos['fuente_datos']; } //-- Punto de montaje tambien se propaga if (isset($nuevos_datos['punto_montaje'])) { $datos_objeto['punto_montaje'] = $nuevos_datos['punto_montaje']; } //-- SE CLONA $id_clon = $hijo->clonar($datos_objeto, $dir_subclases, $con_transaccion); //--- En el componente actual se reemplaza la dependencia por el clon $id_fila = $dr->tabla('dependencias')->get_id_fila_condicion(array('identificador' => $hijo->rol_en_consumidor())); $dr->tabla('dependencias')->modificar_fila(current($id_fila), array('objeto_proveedor' => $id_clon['componente'])); //Aca obtengo la informacion de metadatos de la tabla recien clonada y guardo tambien //la info de la tabla actual. $index = $hijo->get_id(); $dep_nuevas[$index] = toba_constructor::get_info($id_clon, $hijo->get_clase_nombre()); $dep_viejas[$index] = $hijo; } //Si hay dependencias clonadas entonces regenero las relaciones entre tablas y entre columnas. if (!empty($dep_nuevas)) { $this->clonar_relacion_tablas($dep_nuevas, $dr->tabla('relaciones')); $this->clonar_relacion_columnas($dep_nuevas, $dep_viejas, $dr->tabla('columnas_relacion')); } $dr->sincronizar(); //Se busca la clave del nuevo objeto $clave = $dr->tabla('base')->get_clave_valor(0); $clave['componente'] = $clave['objeto']; return $clave; }
/** * Duplica un item y sus dependencias recursivamente * * @param array $nuevos_datos Datos a modificar en la base del item. Para anexar algo al nombre se utiliza el campo 'anexo_nombre' * @param boolean/string $dir_subclases Si el componente tiene subclases clona los archivos, en caso afirmativo indicar la ruta destino (relativa) * @param boolean $con_transaccion Indica si la clonación se debe incluír en una transaccion * @return array Clave del item que resulta del clonado */ function clonar($nuevos_datos, $dir_subclases = false, $con_transaccion = true) { $campos_extra = array('fuente_datos', 'fuente_datos_proyecto'); //-- Cargo el DR asociado $id_dr = toba_info_editores::get_dr_de_clase('toba_item'); $componente = array('proyecto' => $id_dr[0], 'componente' => $id_dr[1]); $dr = toba_constructor::get_runtime($componente); $dr->inicializar(); $dr->cargar(array('proyecto' => $this->proyecto, 'item' => $this->id)); foreach ($nuevos_datos as $campo => $valor) { if ($campo == 'anexo_nombre') { $campo = 'nombre'; $valor = $valor . $dr->tabla('base')->get_fila_columna(0, $campo); } if (!in_array($campo, $campos_extra)) { $dr->tabla('base')->set_fila_columna_valor(0, $campo, $valor); } } //Se le fuerza una inserción a los datos_tabla //Como la clave de los objetos son secuencias, esto garantiza claves nuevas $dr->forzar_insercion(); $dr->persistidor()->desactivar_transaccion(); if ($con_transaccion) { abrir_transaccion('instancia'); } if (isset($nuevos_datos['fuente_datos'])) { $dr->tabla('permisos_tablas')->set_columna_valor('fuente_datos', $nuevos_datos['fuente_datos']); } //--- Se clonan los hijos y se agregan como dependencias $dr->tabla('objetos')->eliminar_filas(); $i = 0; foreach ($this->subelementos as $hijo) { //-- Si se especifico un proyecto, se propaga $datos_objeto = array(); if (isset($nuevos_datos['proyecto'])) { $datos_objeto['proyecto'] = $nuevos_datos['proyecto']; } //-- Si se especifica un anexo de nombre, se propaga if (isset($nuevos_datos['anexo_nombre'])) { $datos_objeto['anexo_nombre'] = $nuevos_datos['anexo_nombre']; } //-- La fuente tambien se propaga if (isset($nuevos_datos['fuente_datos_proyecto'])) { $datos_objeto['fuente_datos_proyecto'] = $nuevos_datos['fuente_datos_proyecto']; } if (isset($nuevos_datos['fuente_datos'])) { $datos_objeto['fuente_datos'] = $nuevos_datos['fuente_datos']; } //-- Punto de montaje tambien se propaga if (isset($nuevos_datos['punto_montaje'])) { $datos_objeto['punto_montaje'] = $nuevos_datos['punto_montaje']; } $nuevo_hijo = $hijo->clonar($datos_objeto, $dir_subclases, false); $fila = array('objeto' => $nuevo_hijo['componente'], 'proyecto' => $nuevo_hijo['proyecto'], 'orden' => $i); $dr->tabla('objetos')->nueva_fila($fila); $i++; } //--- GRABA $dr->sincronizar(); if ($con_transaccion) { cerrar_transaccion('instancia'); } //Se busca la clave del nuevo objeto $clave = $dr->tabla('base')->get_clave_valor(0); $clave['componente'] = $clave['item']; return $clave; }
function confirmar_acciones($tabla_nombre) { //Creo el datos relacion para editar la tabla. $id = toba_info_editores::get_dr_de_clase('toba_datos_tabla'); $componente = array('proyecto' => $id[0], 'componente' => $id[1]); $dr_sincro = toba_constructor::get_runtime($componente); $dr_sincro->inicializar(); //Veo donde esta la tabla if (isset($this->_tablas_actualizables[$tabla_nombre])) { //Tengo que actualizar el DT $id_dt = $this->get_id_objeto($tabla_nombre); $dr_sincro->cargar(array('proyecto' => $this->_proyecto, 'objeto' => $id_dt)); $dr_sincro->actualizar_campos(); $dr_sincro->tabla('prop_basicas')->set_fila_columna_valor(0, 'esquema', $this->_tabla_x_schema[$tabla_nombre]); //Aca aun falta quitar las columnas if (isset($this->_tablas_actualizables[$tabla_nombre]['B'])) { foreach (array_keys($this->_tablas_actualizables[$tabla_nombre]['B']) as $borrable) { $id_interno = $dr_sincro->tabla('columnas')->get_id_fila_condicion(array('columna' => $borrable)); $dr_sincro->tabla('columnas')->eliminar_fila(current($id_interno)); } } } else { //Es un DT nuevo $pms_proyecto = toba_info_editores::get_pms(toba_editor::get_proyecto_cargado()); $pm_default = current($pms_proyecto); $datos = array('nombre' => $tabla_nombre, 'proyecto' => $this->_proyecto, 'clase_proyecto' => 'toba', 'clase' => 'toba_datos_tabla', 'fuente_datos_proyecto' => $this->_proyecto, 'fuente_datos' => $this->_fuente, 'punto_montaje' => $pm_default['id']); $dr_sincro->tabla('base')->set($datos); $dr_sincro->tabla('prop_basicas')->set(array('ap' => 1, 'permite_actualizacion_automatica' => '1', 'punto_montaje' => $pm_default['id'])); $dr_sincro->tabla('prop_basicas')->set_fila_columna_valor(0, 'tabla', $tabla_nombre); $dr_sincro->tabla('prop_basicas')->set_fila_columna_valor(0, 'esquema', $this->_tabla_x_schema[$tabla_nombre]); $columnas = $this->get_columnas_base($tabla_nombre); foreach ($columnas as $col) { $datos_col = array(); $datos_col['columna'] = $col['nombre']; $datos_col['no_nulo_db'] = (int) $col['not_null']; $datos_col['pk'] = (int) $col['pk']; $datos_col['tipo'] = $col['tipo']; if ($col['secuencia'] != '') { $datos_col['secuencia'] = $col['secuencia']; } if ($col['tipo'] == 'C' && $col['longitud'] > 0) { $datos_col['largo'] = $col['longitud']; } $dr_sincro->tabla('columnas')->nueva_fila($datos_col); } } $dr_sincro->sincronizar(); unset($dr_sincro); }