backoffice/html/mailing/admin/defaults.php
2011-06-21 13:28:10 +00:00

90 lines
2.6 KiB
PHP

<?php
require_once dirname(__FILE__).'/accesscheck.php';
$attributes = array();
ob_end_flush();
function readentry($file) {
if (ereg('\.\.',$file)) return;
if (!ereg('data/',$file)) return;
$fp = fopen($file,"r");
$found = "";
while (!feof ($fp)) {
$buffer = fgets($fp, 4096);
if (!ereg("#",$buffer)) {
$found = $buffer;
fclose($fp);
return $found;
}
}
fclose ($fp);
return "";
}
$dir = opendir("data");
while ($file = readdir($dir)) {
if (is_file("data/$file")) {
$entry = readentry("data/$file");
$attributes[$entry] = $file;
}
}
closedir($dir);
if (!empty($_POST['selected']) && is_array($_POST['selected'])) {
$selected = $_POST['selected'];
while(list($key,$val) = each($selected)) {
$entry = readentry("data/$val");
list($name,$desc) = explode(":",$entry);
print "<br/><br/>".$GLOBALS['I18N']->get('loading')." $desc<br>\n";
$lc_name = str_replace(" ","", strtolower(str_replace(".txt","",$val)));
$lc_name = ereg_replace("[^[:alnum:]]","",$lc_name);
if ($lc_name == "") Fatal_Error($GLOBALS['I18N']->get('name_empty')." $lc_name");
Sql_Query("select * from {$tables['attribute']} where tablename = \"$lc_name\"");
if (Sql_Affected_Rows()) Fatal_Error($GLOBALS['I18N']->get('name_not_unique'));
$query = sprintf('insert into %s (name,type,required,tablename) values("%s","%s",%d,"%s")',
$tables["attribute"],addslashes($name),"select",1,$lc_name);
Sql_Query($query);
$insertid = Sql_Insert_id();
$query = "create table $table_prefix"."listattr_$lc_name (id integer not null primary key auto_increment, name varchar(255) unique,listorder integer default 0)";
Sql_Query($query);
$fp = fopen("data/$val","r");
$header = "";
while (!feof ($fp)) {
$buffer = fgets($fp, 4096);
if (!ereg("#",$buffer)) {
if (!$header)
$header = $buffer;
else if (trim($buffer) != "")
Sql_Query(sprintf('insert into %slistattr_%s (name) values("%s")',$table_prefix,$lc_name,trim($buffer)));
}
}
fclose ($fp);
}
print $GLOBALS['I18N']->get('done')."<br/><br/>";
#@@@@ not sure about this one: print '<p>'.PageLink2("attributes",$GLOBALS['I18N']->get('continue')).'</p>';
} else {
?>
<?php echo formStart()?>
<?php
reset($attributes);
while (list($key,$attribute) = each ($attributes)) {
if (strstr($key,':')) {
list($name,$desc) = explode(":",$key);
if ($name && $desc) {
printf('<input type=checkbox name="selected[]" value="%s">%s<br>', $attribute,$desc);
}
}
}
print '<input type=submit value="'.$GLOBALS['I18N']->get('add').'"></form>';
}
?>