2007-07-23 15:23:42 +00:00
< ? php
$trigger_time = array ( " BEFORE " , " AFTER " );
$trigger_event = array ( " INSERT " , " UPDATE " , " DELETE " );
2007-08-04 19:39:18 +00:00
$dropped = false ;
2007-07-23 15:23:42 +00:00
if ( $_POST && ! $error ) {
2008-09-02 12:39:04 +00:00
if ( strlen ( $_GET [ " name " ])) {
$dropped = query_redirect ( " DROP TRIGGER " . idf_escape ( $_GET [ " name " ]), $SELF . " table= " . urlencode ( $_GET [ " trigger " ]), lang ( 'Trigger has been dropped.' ), $_POST [ " drop " ], ! $_POST [ " dropped " ]);
2007-07-23 15:23:42 +00:00
}
if ( ! $_POST [ " drop " ]) {
2008-09-02 08:42:14 +00:00
if ( in_array ( $_POST [ " Timing " ], $trigger_time ) && in_array ( $_POST [ " Event " ], $trigger_event )) {
query_redirect ( " CREATE TRIGGER " . idf_escape ( $_POST [ " Trigger " ]) . " $_POST[Timing] $_POST[Event] ON " . idf_escape ( $_GET [ " trigger " ]) . " FOR EACH ROW $_POST[Statement] " , $SELF . " table= " . urlencode ( $_GET [ " trigger " ]), ( strlen ( $_GET [ " name " ]) ? lang ( 'Trigger has been altered.' ) : lang ( 'Trigger has been created.' )));
2007-07-23 15:23:42 +00:00
}
}
}
2008-04-10 14:37:10 +00:00
page_header (( strlen ( $_GET [ " name " ]) ? lang ( 'Alter trigger' ) . " : " . htmlspecialchars ( $_GET [ " name " ]) : lang ( 'Create trigger' )), $error , array ( " table " => $_GET [ " trigger " ]));
2007-07-23 15:23:42 +00:00
2008-07-10 15:39:24 +00:00
$row = array ( " Trigger " => " $_GET[trigger] _bi " );
2007-07-23 15:23:42 +00:00
if ( $_POST ) {
$row = $_POST ;
} elseif ( strlen ( $_GET [ " name " ])) {
$result = $mysql -> query ( " SHOW TRIGGERS LIKE ' " . $mysql -> escape_string ( addcslashes ( $_GET [ " trigger " ], " %_ " )) . " ' " );
while ( $row = $result -> fetch_assoc ()) {
if ( $row [ " Trigger " ] === $_GET [ " name " ]) {
break ;
}
}
$result -> free ();
}
?>
< form action = " " method = " post " id = " form " >
< table border = " 0 " cellspacing = " 0 " cellpadding = " 2 " >
2008-06-30 11:57:47 +00:00
< tr >< th >< ? php echo lang ( 'Time' ); ?> </th><td><select name="Timing" onchange="if (/^<?php echo htmlspecialchars(preg_quote($_GET["trigger"], "/")); ?>_[ba][iud]$/.test(this.form['Trigger'].value)) this.form['Trigger'].value = '<?php echo htmlspecialchars(addcslashes($_GET["trigger"], "\r\n'\\")); ?>_' + this.value.charAt(0).toLowerCase() + this.form['Event'].value.charAt(0).toLowerCase();"><?php echo optionlist($trigger_time, $row["Timing"]); ?></select></td></tr>
< tr >< th >< ? php echo lang ( 'Event' ); ?> </th><td><select name="Event" onchange="this.form['Timing'].onchange();"><?php echo optionlist($trigger_event, $row["Event"]); ?></select></td></tr>
2007-07-23 15:23:42 +00:00
< tr >< th >< ? php echo lang ( 'Name' ); ?> </th><td><input name="Trigger" value="<?php echo htmlspecialchars($row["Trigger"]); ?>" maxlength="64" /></td></tr>
</ table >
< p >< textarea name = " Statement " rows = " 10 " cols = " 80 " style = " width: 98%; " >< ? php echo htmlspecialchars ( $row [ " Statement " ]); ?> </textarea></p>
< p >
< input type = " hidden " name = " token " value = " <?php echo $token ; ?> " />
2007-08-04 19:39:18 +00:00
< ? php if ( $dropped ) { ?> <input type="hidden" name="dropped" value="1" /><?php } ?>
2007-07-23 15:23:42 +00:00
< input type = " submit " value = " <?php echo lang('Save'); ?> " />
2008-10-09 14:13:17 +00:00
< ? php if ( strlen ( $_GET [ " name " ])) { ?> <input type="submit" name="drop" value="<?php echo lang('Drop'); ?>"<?php echo $confirm; ?> /><?php } ?>
2007-07-23 15:23:42 +00:00
</ p >
</ form >