2011-03-28 14:21:28 +00:00
< ?
authorize ();
2013-04-20 08:01:01 +00:00
$P = array ();
$P = db_array ( $_POST );
2011-03-28 14:21:28 +00:00
include ( SERVER_ROOT . '/classes/class_validate.php' );
$Val = new VALIDATE ;
$Val -> SetFields ( 'title' , '1' , 'string' , 'The title must be between 3 and 100 characters' , array ( 'maxlength' => 100 , 'minlength' => 3 ));
//$Val->SetFields('alias', '1','string','Please include at least 1 alias, the entire string should be between 2 and 100 characters.',array('maxlength'=>100, 'minlength'=>2));
$Err = $Val -> ValidateForm ( $_POST );
2013-04-20 08:01:01 +00:00
if ( ! $Err ) {
2011-03-28 14:21:28 +00:00
$DB -> query ( " SELECT ID FROM wiki_articles WHERE Title=' $P[title] ' " );
2013-04-20 08:01:01 +00:00
if ( $DB -> record_count () > 0 ) {
2011-03-28 14:21:28 +00:00
list ( $ID ) = $DB -> next_record ();
2012-09-09 08:00:26 +00:00
$Err = 'An article with that name already exists <a href="wiki.php?action=article&id=' . $ID . '">here</a>.' ;
2011-03-28 14:21:28 +00:00
}
}
2013-04-20 08:01:01 +00:00
if ( $Err ) {
2011-03-28 14:21:28 +00:00
error ( $Err );
}
2013-04-20 08:01:01 +00:00
if ( check_perms ( 'admin_manage_wiki' )) {
$Read = $_POST [ 'minclassread' ];
$Edit = $_POST [ 'minclassedit' ];
if ( ! is_number ( $Read )) {
error ( 0 ); //int?
}
if ( ! is_number ( $Edit )) {
error ( 0 );
}
if ( $Edit > $LoggedUser [ 'EffectiveClass' ]) {
error ( 'You can\'t restrict articles above your own level' );
}
if ( $Edit < $Read ) {
$Edit = $Read ; //Human error fix.
}
2011-03-28 14:21:28 +00:00
} else {
$Read = 100 ;
$Edit = 100 ;
}
2013-02-22 08:00:24 +00:00
$DB -> query ( " INSERT INTO wiki_articles
2011-03-28 14:21:28 +00:00
( Revision , Title , Body , MinClassRead , MinClassEdit , Date , Author ) VALUES
( '1' , '$P[title]' , '$P[body]' , '$Read' , '$Edit' , '".sqltime()."' , '$LoggedUser[ID]' ) " );
$ArticleID = $DB -> inserted_id ();
//$NewAlias = $Alias->convert($_POST['alias']);
2013-04-20 08:01:01 +00:00
//if ($NewAlias != '') {
2011-03-28 14:21:28 +00:00
// $DB->query("INSERT INTO wiki_aliases (Alias, ArticleID) VALUES ('$NewAlias', '$ArticleID')");
//}
2013-02-07 08:00:47 +00:00
$TitleAlias = $Alias -> convert ( $_POST [ 'title' ]);
2013-04-20 08:01:01 +00:00
if ( $TitleAlias != $Alias ) {
2011-03-28 14:21:28 +00:00
$DB -> query ( " INSERT INTO wiki_aliases (Alias, ArticleID) VALUES (' " . db_string ( $TitleAlias ) . " ', ' $ArticleID ') " );
}
$Alias -> flush ();
2012-10-11 08:00:15 +00:00
Misc :: write_log ( " Wiki article " . $ArticleID . " ( " . $_POST [ 'title' ] . " ) was created by " . $LoggedUser [ 'Username' ]);
2011-03-28 14:21:28 +00:00
header ( 'Location: wiki.php?action=article&id=' . $ArticleID );
?>