!C99Shell v. 2.1 [PHP 8 Update] [02.02.2022]!

Software: Apache/2.4.53 (Unix) OpenSSL/1.1.1o PHP/7.4.29 mod_perl/2.0.12 Perl/v5.34.1. PHP/7.4.29 

uname -a: Linux vps-2738122-x 4.15.0-213-generic #224-Ubuntu SMP Mon Jun 19 13:30:12 UTC 2023 x86_64 

uid=1(daemon) gid=1(daemon) grupos=1(daemon) 

Safe-mode: OFF (not secure)

/opt/apex_led/php/modelo/asistentes/   drwxrwxr-x
Free 14.56 GB of 61.93 GB (23.52%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Feedback    Self remove    Logout    


Viewing file:     toba_catalogo_asistentes.php (6.09 KB)      -rwxrwxr-x
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php

class toba_catalogo_asistentes
{
    
/**
    *    Carga un asistente a partir de un molde de generacion
    *     @return toba_asistente
    */
    
static function cargar_por_molde($id_molde_proyecto$id_molde$dr_molde)
    {
        
$tipo_molde self::get_asistente_molde($id_molde_proyecto$id_molde);
        
$datos toba_cargador::instancia()->get_metadatos_extendidos( array('proyecto'=>$id_molde_proyecto
                                                                
'componente' => $id_molde),
                                                                
$tipo_molde );
        
$clase $datos['molde']['clase'];
        return new 
$clase($datos$dr_molde);
    }
    
    static function 
cargar_por_tipo_operacion($tipo_operacion$dr_molde)
    {
        
$clase self::get_clase_asistente($tipo_operacion);
        return new 
$clase(null$dr_molde);
    }
    
    static function 
get_asistente_molde($id_molde_proyecto$id_molde)
    {
        
$id_molde quote($id_molde);
        
$id_molde_proyecto quote($id_molde_proyecto);
        
$sql "SELECT     t.clase             as asistente
                FROM     apex_molde_operacion o,
                        apex_molde_operacion_tipo t
                WHERE     o.operacion_tipo = t.operacion_tipo
                AND        proyecto = 
$id_molde_proyecto
                AND        molde = 
$id_molde;";
        
$temp consultar_fuente($sql);
        if(
$temp) {
            return 
$temp[0]['asistente'];
        } else {
            throw new 
toba_error('El molde solicitado no existe.');    
        }
    }

    static function 
get_ci_molde($id_molde_proyecto$id_molde)
    {
        
$id_molde quote($id_molde);
        
$id_molde_proyecto quote($id_molde_proyecto);
        
$sql "SELECT     t.ci                 as ci
                FROM     apex_molde_operacion o,
                        apex_molde_operacion_tipo t
                WHERE     o.operacion_tipo = t.operacion_tipo
                AND        proyecto = 
$id_molde_proyecto
                AND        molde = 
$id_molde;";
        
$temp consultar_fuente($sql);
        if(
$temp) {
            return 
$temp[0]['ci'];
        } else {
            throw new 
toba_error('El molde solicitado no existe.');    
        }
    }
    
    static function 
get_clase_asistente($tipo_operacion)
    {
        
$tipo_operacion quote($tipo_operacion);
        
$sql "SELECT     t.clase
                FROM apex_molde_operacion_tipo t
                WHERE     t.operacion_tipo = 
$tipo_operacion";
        
$temp consultar_fuente($sql);
        if(
$temp) {
            return 
$temp[0]['clase'];
        } else {
            throw new 
toba_error('El tipo de operación no existe');    
        }        
    }

    
//------------------------------------------------
    //---- Consultas
    //------------------------------------------------

    
static function get_lista_tipo_dato($mapeo_obligatorio=false)
    {
        
$where '';
        if (
$mapeo_obligatorio) {
            
$where 'WHERE dt_tipo_dato IS NOT NULL';
        }
        
$sql "SELECT 
                    tipo_dato,
                      descripcion_corta,
                      descripcion,
                      dt_tipo_dato,
                      elemento_formulario,
                    cuadro_estilo,
                      cuadro_formato,
                      filtro_operador
                FROM apex_molde_operacion_tipo_dato
                    
$where
                ORDER BY descripcion_corta
        "
;
        return 
toba_contexto_info::get_db()->consultar($sql);
    }
    
    static function 
tipo_dato_referencia()
    {
        return 
'1000008';
    }
    
    static function 
tipo_dato_caracter()
    {
        return 
'1000001';
    }    
    
    
//------------------------------------------------
    //---- Reflexión de de las tablas
    //------------------------------------------------    
    
    
static function get_campo_opciones_para_cuadro($tipo)
    {
        
$mapeo_tipos rs_convertir_asociativo(self::get_lista_tipo_dato(true), array('dt_tipo_dato'), 'tipo_dato');
        
$tipo_base = isset($mapeo_tipos[$tipo]) ? $mapeo_tipos[$tipo] : self::tipo_dato_caracter();
        
$datos self::get_fila_opciones_de_tipo($tipo_base);
        
$salida = array();
        
$salida['estilo'] = $datos['cuadro_estilo'];
        
$salida['formato'] = $datos['cuadro_formato'];
        return 
$salida;
    }
    
    
/**
     * Dado un tipo de dato del asistente retorna las opciones asociadas
     */
    
static function get_fila_opciones_de_tipo($tipo)
    {
        
$tipos self::get_lista_tipo_dato();
        
$tipo_datos rs_convertir_asociativo_matriz(self::get_lista_tipo_dato(true), array('tipo_dato'));
        if (
$tipo != self::tipo_dato_referencia()) {
            
$fila $tipo_datos[$tipo];
            
$fila['asistente_tipo_dato'] = $tipo;
        } else {
            
//-- El tipo referencia es especial
            
$fila['elemento_formulario'] = 'ef_combo';
            
$fila['dt_tipo_dato'] = 'C';
            
$fila['asistente_tipo_dato'] = self::tipo_dato_referencia();
            
$fila['cuadro_estilo'] = 4;
            
$fila['cuadro_formato'] = 1;
            
$fila['filtro_operador'] = '=';
        }
        return 
$fila;
    }
    
    
/**
     * Dada una tabla retorna los valores por defecto de cada fila para utilizar en un abm
     */
    
static function get_lista_filas_tabla($tabla$fuente)
    {
        
$db toba::db($fuentetoba_editor::get_proyecto_cargado());
        
$nuevas $db->get_definicion_columnas($tabla);
        
//-- Se busca un mapeo entre el tipo en la base y el tipo en el asistente
        
$mapeo_tipos rs_convertir_asociativo(self::get_lista_tipo_dato(true), array('dt_tipo_dato'), 'tipo_dato');
        
$salida = array();
        foreach (
$nuevas as $nueva) {
            
$fila = array();
            if (! isset(
$nueva['fk_tabla'])) {                
                
$tipo = isset($mapeo_tipos[$nueva['tipo']]) ? $mapeo_tipos[$nueva['tipo']] : self::tipo_dato_caracter();
                
$fila self::get_fila_opciones_de_tipo($tipo);
            } else {
                
$tipo self::tipo_dato_referencia();
                
$fila self::get_fila_opciones_de_tipo($tipo);
                
$datos_carga_sql $db->get_opciones_sql_campo_externo($nueva);
                
$fila['ef_carga_col_clave'] = $datos_carga_sql['clave'];
                
$fila['ef_carga_col_desc'] = $datos_carga_sql['descripcion'];
                
$fila['ef_carga_tabla'] = $datos_carga_sql['tabla'];
                
$fila['ef_carga_sql'] = $datos_carga_sql['sql'];
                
$fila['ef_carga_origen'] = 'datos_tabla';                
            }
            
$fila['dt_pk'] = $nueva['pk'];
            
$fila['dt_secuencia'] = $nueva['secuencia'];
            
$fila['columna'] = $nueva['nombre'];
            
$fila['etiqueta'] = ucwords(str_replace(array('_''_'), ' '$nueva['nombre']));
            
$fila['en_filtro'] = 0;
            
$fila['en_form'] = 1;            
            
$fila['en_cuadro'] = 1;            
            if (
$nueva['secuencia'] != '') {
                
$fila['en_form'] = 0;
                
$fila['en_cuadro'] = 0;
            }
            
$fila['ef_obligatorio'] = $fila['en_form'] && ($nueva['pk'] || $nueva['not_null']);            
            if (
$nueva['pk'] && $fila['en_form']) {
                
$nueva['ef_desactivar_modificacion'] = 1;
            }
            
$salida[] = $fila;
        }
        return 
$salida;
    }
    
    
}
?>

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ Read-Only ]

:: Make Dir ::
 
[ Read-Only ]
:: Make File ::
 
[ Read-Only ]

:: Go Dir ::
 
:: Go File ::
 

--[ c99shell v. 2.1 [PHP 8 Update] [02.02.2022] maintained byC99Shell Github | Generation time: 0.5944 ]--