Enabled login
This commit is contained in:
parent
d03f675646
commit
2c15a4b40e
31
application/classes/auth/orm.php
Normal file
31
application/classes/auth/orm.php
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
<?php defined('SYSPATH') or die('No direct access allowed.');
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This class overrides Kohana's Auth so that we can login to TSM
|
||||||
|
*
|
||||||
|
* @package PTA
|
||||||
|
* @subpackage Auth
|
||||||
|
* @category Overrides
|
||||||
|
* @author Deon George
|
||||||
|
* @copyright (c) 2010 phpTSMadmin Development Team
|
||||||
|
* @license http://phptsmadmin.sf.net/license.html
|
||||||
|
*/
|
||||||
|
class Auth_ORM extends Kohana_Auth_ORM {
|
||||||
|
/**
|
||||||
|
* Attempt to log in a user by using an ORM object and plain-text password.
|
||||||
|
*
|
||||||
|
* @param string username to log in
|
||||||
|
* @param string password to check against
|
||||||
|
* @param boolean enable autologin
|
||||||
|
* @return boolean
|
||||||
|
*/
|
||||||
|
public function login($username, $password, $remember = FALSE) {
|
||||||
|
// With TSM, if we get this far, we are logged in
|
||||||
|
return $username->loaded();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function logged_in($role = NULL, $all_required = TRUE) {
|
||||||
|
return FALSE !== $this->get_user();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
?>
|
@ -1,10 +1,16 @@
|
|||||||
<?php defined('SYSPATH') or die('No direct script access.');
|
<?php defined('SYSPATH') or die('No direct access allowed.');
|
||||||
|
|
||||||
class Controller_Welcome extends Controller {
|
class Controller_Welcome extends Controller_TemplateDefault {
|
||||||
|
|
||||||
public function action_index()
|
public function action_index()
|
||||||
{
|
{
|
||||||
$this->request->response = 'hello, world!';
|
Block::add(array(
|
||||||
|
'title'=>sprintf('%s: %s (%s)',_('Server'),TSM::name(),TSM::version()),
|
||||||
|
'body'=>'hello, world!',
|
||||||
|
));
|
||||||
|
|
||||||
|
$this->template->content = Block::factory();
|
||||||
}
|
}
|
||||||
|
|
||||||
} // End Welcome
|
} // End Welcome
|
||||||
|
?>
|
||||||
|
13
application/classes/database/exception.php
Normal file
13
application/classes/database/exception.php
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
<?php defined('SYSPATH') or die('No direct access allowed.');
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @package PTA
|
||||||
|
* @subpackage TSM
|
||||||
|
* @category Exception
|
||||||
|
* @author Deon George
|
||||||
|
* @copyright (c) 2010 Deon George
|
||||||
|
* @license http://dev.leenooks.net/license.html
|
||||||
|
*/
|
||||||
|
class Database_Exception extends Kohana_Database_Exception {
|
||||||
|
}
|
||||||
|
?>
|
333
application/classes/database/tsm.php
Normal file
333
application/classes/database/tsm.php
Normal file
@ -0,0 +1,333 @@
|
|||||||
|
<?php defined('SYSPATH') or die('No direct access allowed.');
|
||||||
|
|
||||||
|
/**
|
||||||
|
* TSM database connection.
|
||||||
|
*
|
||||||
|
* @package PTA
|
||||||
|
* @subpackage TSM
|
||||||
|
* @category Drivers
|
||||||
|
* @author Deon George
|
||||||
|
* @copyright (c) 2010 phpTSMadmin Development Team
|
||||||
|
* @license http://phptsmadmin.sf.net/license.html
|
||||||
|
*/
|
||||||
|
class Database_TSM extends Database {
|
||||||
|
|
||||||
|
// Database in use by each connection
|
||||||
|
protected static $_current_databases = array();
|
||||||
|
|
||||||
|
// Use SET NAMES to set the character set
|
||||||
|
protected static $_set_names;
|
||||||
|
|
||||||
|
// Identifier for this connection within the PHP driver
|
||||||
|
protected $_connection_id;
|
||||||
|
|
||||||
|
// TSM does not use a backtick for identifiers
|
||||||
|
protected $_identifier = '';
|
||||||
|
|
||||||
|
// Our TSM Message Format
|
||||||
|
private $msg_format = '[A-Z]{3}[0-9]{4}[I|E|W|S]';
|
||||||
|
|
||||||
|
// Our Message Codes stored in the last query
|
||||||
|
private $_query_msg_codes = array();
|
||||||
|
|
||||||
|
// Our return code error messages we can ignore
|
||||||
|
private $ignore_codes = array(
|
||||||
|
'ANS8001I', // Return code %s.
|
||||||
|
);
|
||||||
|
// Our return code error messages we can ignore
|
||||||
|
private $nodata_codes = array(
|
||||||
|
'ANR2034E', // SELECT: No match found using this criteria.
|
||||||
|
);
|
||||||
|
|
||||||
|
public function connect()
|
||||||
|
{
|
||||||
|
if ($this->_connection)
|
||||||
|
return;
|
||||||
|
|
||||||
|
// Extract the connection parameters, adding required variabels
|
||||||
|
extract($this->_config['connection'] + array(
|
||||||
|
'database' => '',
|
||||||
|
'hostname' => '',
|
||||||
|
'username' => '',
|
||||||
|
'password' => '',
|
||||||
|
'persistent' => FALSE,
|
||||||
|
));
|
||||||
|
|
||||||
|
// Get user login details from user session - these are set by login
|
||||||
|
if (! $username)
|
||||||
|
$username = Session::instance()->get_once('admin_name');
|
||||||
|
if (! $password)
|
||||||
|
$password = Session::instance()->get_once('password');
|
||||||
|
|
||||||
|
// Prevent this information from showing up in traces
|
||||||
|
unset($this->_config['connection']['username'], $this->_config['connection']['password']);
|
||||||
|
|
||||||
|
if (! file_exists(Kohana::config('config.client'))) {
|
||||||
|
system_message(array('title'=>'Cant find DSMADMC',
|
||||||
|
'body'=>sprintf('Unable to find the dsmadmc at <b>%s</b>',Kohana::config('client.config')),
|
||||||
|
'type'=>'error'));
|
||||||
|
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (! $username OR ! $password)
|
||||||
|
Request::instance()->redirect('/login?need_login=1');
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
if ($persistent)
|
||||||
|
{
|
||||||
|
// Create a persistent connection
|
||||||
|
throw new Kohana_Exception('Cant do persistant connections');
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// Create a connection and force it to be a new link
|
||||||
|
$this->_connection = sprintf('%s -id=%s -password=%s -displ=list -dataonly=YES %s %s',
|
||||||
|
Kohana::config('config.client'),
|
||||||
|
$username,
|
||||||
|
$password,
|
||||||
|
Kohana::config('config.client_errorlogname') ? sprintf('-errorlogname=%s',Kohana::config('config.client_errorlogname')) : '',
|
||||||
|
Kohana::config('config.client_stanza') ? sprintf('-se=%s',Kohana::config('config.client_stanza')) : ''
|
||||||
|
);
|
||||||
|
|
||||||
|
$result = $this->query(Database::SELECT,'SELECT server_name,platform,version,release,level,sublevel FROM status');
|
||||||
|
|
||||||
|
//echo Kohana::debug($result);die();
|
||||||
|
if ($result)
|
||||||
|
return TSM::instance()->set($username,$password,$result);
|
||||||
|
else
|
||||||
|
Request::instance()->redirect(Request::instance()->uri());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch (ErrorException $e)
|
||||||
|
{
|
||||||
|
// No connection exists
|
||||||
|
$this->_connection = NULL;
|
||||||
|
|
||||||
|
throw new Database_Exception(':error', array(
|
||||||
|
':error' => sprintf('%s error in %s (%s)',$e->getMessage(),$e->getFile(),$e->getLine()),
|
||||||
|
),
|
||||||
|
$e->getCode());
|
||||||
|
}
|
||||||
|
|
||||||
|
// \xFF is a better delimiter, but the PHP driver uses underscore
|
||||||
|
$this->_connection_id = sha1($hostname.'_'.$username.'_'.$password);
|
||||||
|
|
||||||
|
if ( ! empty($this->_config['charset']))
|
||||||
|
{
|
||||||
|
// Set the character set
|
||||||
|
$this->set_charset($this->_config['charset']);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function disconnect()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
// Database is assumed disconnected
|
||||||
|
$status = TRUE;
|
||||||
|
|
||||||
|
if (is_resource($this->_connection))
|
||||||
|
{
|
||||||
|
if ($status = mysql_close($this->_connection))
|
||||||
|
{
|
||||||
|
// Clear the connection
|
||||||
|
$this->_connection = NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch (Exception $e)
|
||||||
|
{
|
||||||
|
// Database is probably not disconnected
|
||||||
|
$status = ! is_resource($this->_connection);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $status;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function set_charset($charset)
|
||||||
|
{
|
||||||
|
// Make sure the database is connected
|
||||||
|
$this->_connection or $this->connect();
|
||||||
|
|
||||||
|
// Nothing to do for TSM
|
||||||
|
$status = TRUE;
|
||||||
|
|
||||||
|
if ($status === FALSE)
|
||||||
|
{
|
||||||
|
throw new Database_Exception(':error',
|
||||||
|
array(':error' => mysql_error($this->_connection)),
|
||||||
|
mysql_errno($this->_connection));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function query($type, $sql, $as_object = FALSE, array $params = NULL)
|
||||||
|
{
|
||||||
|
// Make sure the database is connected
|
||||||
|
$this->_connection or $this->connect();
|
||||||
|
|
||||||
|
if ( ! empty($this->_config['profiling']))
|
||||||
|
{
|
||||||
|
// Benchmark this query for the current instance
|
||||||
|
$benchmark = Profiler::start("Database ({$this->_instance})", $sql);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Execute the query
|
||||||
|
$stderr = exec($this->_connection.'"'.$sql.'"',$stdout,$rc);
|
||||||
|
|
||||||
|
// Work out our message codes
|
||||||
|
$result = array();
|
||||||
|
foreach ($stdout as $line)
|
||||||
|
if (! preg_match('/^('.$this->msg_format.')\s+/',$line,$matches))
|
||||||
|
array_push($result,$line);
|
||||||
|
elseif (! in_array($matches[1],$this->ignore_codes))
|
||||||
|
array_push($this->_query_msg_codes,$matches[1]);
|
||||||
|
|
||||||
|
// If we got a no data code
|
||||||
|
if (array_intersect($this->_query_msg_codes,$this->nodata_codes)) {
|
||||||
|
$result = array(0);
|
||||||
|
$rc = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($stderr AND $rc) {
|
||||||
|
if (isset($benchmark))
|
||||||
|
{
|
||||||
|
// This benchmark is worthless
|
||||||
|
Profiler::delete($benchmark);
|
||||||
|
}
|
||||||
|
|
||||||
|
SystemMessage::TSM_Error($stdout,$sql);
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isset($benchmark))
|
||||||
|
{
|
||||||
|
Profiler::stop($benchmark);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Set the last query
|
||||||
|
$this->last_query = $sql;
|
||||||
|
|
||||||
|
if ($type === Database::SELECT)
|
||||||
|
{
|
||||||
|
// Return an iterator of results
|
||||||
|
return new Database_TSM_Result($result, $sql, $as_object, $params);
|
||||||
|
}
|
||||||
|
elseif ($type === Database::INSERT)
|
||||||
|
{
|
||||||
|
throw new Kohana_Exception('Database INSERTS are not supported');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function list_tables($like = NULL)
|
||||||
|
{
|
||||||
|
if (is_string($like))
|
||||||
|
{
|
||||||
|
// Search for table names
|
||||||
|
$result = $this->query(Database::SELECT, 'SHOW TABLES LIKE '.$this->quote($like), FALSE);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// Find all table names
|
||||||
|
$result = $this->query(Database::SELECT, 'SHOW TABLES', FALSE);
|
||||||
|
}
|
||||||
|
|
||||||
|
$tables = array();
|
||||||
|
foreach ($result as $row)
|
||||||
|
{
|
||||||
|
$tables[] = reset($row);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $tables;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function list_columns($table, $like = NULL, $add_prefix = TRUE)
|
||||||
|
{
|
||||||
|
// Quote the table name
|
||||||
|
$table = ($add_prefix === TRUE) ? $this->quote_table($table) : $table;
|
||||||
|
|
||||||
|
if (is_string($like))
|
||||||
|
{
|
||||||
|
// Search for column names
|
||||||
|
$result = $this->query(Database::SELECT, 'SHOW FULL COLUMNS FROM '.$table.' LIKE '.$this->quote($like), FALSE);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// Find all column names
|
||||||
|
$result = $this->query(Database::SELECT, sprintf('SELECT * FROM SYSCAT.COLUMNS WHERE TABNAME=\'%s\'',$table), FALSE);
|
||||||
|
}
|
||||||
|
|
||||||
|
$count = 0;
|
||||||
|
$columns = array();
|
||||||
|
foreach ($result as $row)
|
||||||
|
{
|
||||||
|
list($type, $length) = $this->_parse_type($row['TYPENAME']);
|
||||||
|
|
||||||
|
$column = $this->datatype($type);
|
||||||
|
|
||||||
|
$column['column_name'] = $row['COLNAME'];
|
||||||
|
// $column['column_default'] = $row['Default'];
|
||||||
|
$column['data_type'] = $type;
|
||||||
|
$column['is_nullable'] = ($row['NULLS'] == 'TRUE');
|
||||||
|
$column['ordinal_position'] = ++$count;
|
||||||
|
|
||||||
|
switch (strtolower($column['data_type']))
|
||||||
|
{
|
||||||
|
case 'float':
|
||||||
|
if (isset($length))
|
||||||
|
{
|
||||||
|
list($column['numeric_precision'], $column['numeric_scale']) = explode(',', $length);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 'int':
|
||||||
|
if (isset($length))
|
||||||
|
{
|
||||||
|
// MySQL attribute
|
||||||
|
$column['display'] = $length;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 'string':
|
||||||
|
switch ($column['data_type'])
|
||||||
|
{
|
||||||
|
case 'binary':
|
||||||
|
case 'varbinary':
|
||||||
|
$column['character_maximum_length'] = $length;
|
||||||
|
break;
|
||||||
|
case 'char':
|
||||||
|
case 'varchar':
|
||||||
|
$column['character_maximum_length'] = $length;
|
||||||
|
case 'text':
|
||||||
|
case 'tinytext':
|
||||||
|
case 'mediumtext':
|
||||||
|
case 'longtext':
|
||||||
|
$column['collation_name'] = $row['Collation'];
|
||||||
|
break;
|
||||||
|
case 'enum':
|
||||||
|
case 'set':
|
||||||
|
$column['collation_name'] = $row['Collation'];
|
||||||
|
$column['options'] = explode('\',\'', substr($length, 1, -1));
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
// TSM attributes
|
||||||
|
$column['comment'] = $row['REMARKS'];
|
||||||
|
|
||||||
|
$columns[$row['COLNAME']] = $column;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $columns;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function escape($value)
|
||||||
|
{
|
||||||
|
// Make sure the database is connected
|
||||||
|
$this->_connection or $this->connect();
|
||||||
|
|
||||||
|
// SQL standard is to use single-quotes for all values
|
||||||
|
return "'$value'";
|
||||||
|
}
|
||||||
|
|
||||||
|
} // End Database_TSM
|
85
application/classes/database/tsm/result.php
Normal file
85
application/classes/database/tsm/result.php
Normal file
@ -0,0 +1,85 @@
|
|||||||
|
<?php defined('SYSPATH') or die('No direct access allowed.');
|
||||||
|
|
||||||
|
/**
|
||||||
|
* TSM database result. See [Results](/database/results) for usage and examples.
|
||||||
|
*
|
||||||
|
* @package PTA
|
||||||
|
* @subpackage TSM
|
||||||
|
* @category Query/Result
|
||||||
|
* @author Deon George
|
||||||
|
* @copyright (c) 2010 phpTSMadmin Development Team
|
||||||
|
* @license http://phptsmadmin.sf.net/license.html
|
||||||
|
*/
|
||||||
|
class Database_TSM_Result extends Database_Result {
|
||||||
|
|
||||||
|
protected $_internal_row = 0;
|
||||||
|
private $_rows;
|
||||||
|
|
||||||
|
public function __construct($result, $sql, $as_object = FALSE, array $params = NULL)
|
||||||
|
{
|
||||||
|
parent::__construct($result, $sql, $as_object, $params);
|
||||||
|
|
||||||
|
foreach ($result as $line) {
|
||||||
|
if (! trim($line)) {
|
||||||
|
$this->_internal_row++;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
list($k,$v) = explode(':',$line,2);
|
||||||
|
|
||||||
|
$this->_rows[$this->_internal_row][trim($k)] = trim($v);
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->_total_rows = $this->_internal_row;
|
||||||
|
$this->_internal_row = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function __destruct()
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function seek($offset)
|
||||||
|
{
|
||||||
|
if ($this->offsetExists($offset))
|
||||||
|
{
|
||||||
|
// Set the current row to the offset
|
||||||
|
$this->_current_row = $this->_internal_row = $offset;
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function current()
|
||||||
|
{
|
||||||
|
if ($this->_current_row !== $this->_internal_row AND ! $this->seek($this->_current_row))
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
// Increment internal row for optimization assuming rows are fetched in order
|
||||||
|
$this->_internal_row++;
|
||||||
|
|
||||||
|
if ($this->_as_object === TRUE)
|
||||||
|
{
|
||||||
|
// Return an stdClass
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
elseif (is_string($this->_as_object))
|
||||||
|
{
|
||||||
|
// Return an object of given class name
|
||||||
|
$o = new $this->_as_object;
|
||||||
|
|
||||||
|
return $o->_load_values($this->_rows[$this->_current_row++]);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// Return an array of the row
|
||||||
|
return $this->_rows[$this->_current_row++];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
} // End Database_TSM_Result
|
||||||
|
?>
|
17
application/classes/model/account.php
Normal file
17
application/classes/model/account.php
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
<?php defined('SYSPATH') or die('No direct access allowed.');
|
||||||
|
|
||||||
|
/**
|
||||||
|
* TSM Administrator Model
|
||||||
|
*
|
||||||
|
* @package lnApp
|
||||||
|
* @subpackage Auth
|
||||||
|
* @category Models
|
||||||
|
* @author Deon George
|
||||||
|
* @copyright (c) 2010 Deon George
|
||||||
|
* @license http://dev.leenooks.net/license.html
|
||||||
|
*/
|
||||||
|
class Model_Account extends Model_Auth_UserDefault {
|
||||||
|
protected $_table_name = 'ADMINS';
|
||||||
|
protected $_primary_key = 'ADMIN_NAME';
|
||||||
|
}
|
||||||
|
?>
|
91
application/classes/model/auth/userdefault.php
Normal file
91
application/classes/model/auth/userdefault.php
Normal file
@ -0,0 +1,91 @@
|
|||||||
|
<?php defined('SYSPATH') or die('No direct access allowed.');
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @package PTA
|
||||||
|
* @subpackage Auth
|
||||||
|
* @category Models
|
||||||
|
* @author Deon George
|
||||||
|
* @copyright (c) 2010 Deon George
|
||||||
|
* @license http://dev.leenooks.net/license.html
|
||||||
|
*/
|
||||||
|
class Model_Auth_UserDefault extends Model_Auth_User {
|
||||||
|
protected $_table_names_plural = false;
|
||||||
|
|
||||||
|
// Validation rules
|
||||||
|
protected $_rules = array(
|
||||||
|
'admin_name' => array(
|
||||||
|
'not_empty' => NULL,
|
||||||
|
'min_length' => array(4),
|
||||||
|
'max_length' => array(8),
|
||||||
|
),
|
||||||
|
'password' => array(
|
||||||
|
'not_empty' => NULL,
|
||||||
|
'min_length' => array(5),
|
||||||
|
'max_length' => array(16),
|
||||||
|
),
|
||||||
|
'password_confirm' => array(
|
||||||
|
'matches_ifset' => array('password'),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
|
||||||
|
// Columns to ignore
|
||||||
|
protected $_ignored_columns = array('password_confirm');
|
||||||
|
|
||||||
|
// Field labels
|
||||||
|
protected $_labels = array(
|
||||||
|
'admin_name' => 'username',
|
||||||
|
'email' => 'email address',
|
||||||
|
'password' => 'password',
|
||||||
|
'password_confirm' => 'password confirmation',
|
||||||
|
);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Validates login information from an array, and optionally redirects
|
||||||
|
* after a successful login.
|
||||||
|
*
|
||||||
|
* @param array values to check
|
||||||
|
* @param string URI or URL to redirect to
|
||||||
|
* @return boolean
|
||||||
|
*/
|
||||||
|
public function login(array & $array, $redirect = FALSE) {
|
||||||
|
$fieldname = 'admin_name';
|
||||||
|
$array = Validate::factory($array)
|
||||||
|
->label('admin_name', $this->_labels[$fieldname])
|
||||||
|
->label('password', $this->_labels['password'])
|
||||||
|
->filter(TRUE, 'trim')
|
||||||
|
->filter('admin_name','strtoupper')
|
||||||
|
->rules('admin_name', $this->_rules[$fieldname])
|
||||||
|
->rules('password', $this->_rules['password']);
|
||||||
|
|
||||||
|
// Get the remember login option
|
||||||
|
$remember = isset($array['remember']);
|
||||||
|
|
||||||
|
// Login starts out invalid
|
||||||
|
$status = FALSE;
|
||||||
|
|
||||||
|
if ($array->check())
|
||||||
|
{
|
||||||
|
// Attempt to load the user
|
||||||
|
$this->where($fieldname, '=', $array['admin_name'])->find();
|
||||||
|
|
||||||
|
if ($this->loaded() AND Auth::instance()->login($this, $array['password'], $remember))
|
||||||
|
{
|
||||||
|
if (is_string($redirect))
|
||||||
|
{
|
||||||
|
// Redirect after a successful login
|
||||||
|
Request::instance()->redirect($redirect);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Login is successful
|
||||||
|
$status = TRUE;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$array->error('admin_name', 'invalid');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $status;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
?>
|
39
application/classes/orm.php
Normal file
39
application/classes/orm.php
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
<?php defined('SYSPATH') or die('No direct access allowed.');
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This class overrides the Kohana ORM for some TSM specific calls.
|
||||||
|
*
|
||||||
|
* @package PTA
|
||||||
|
* @subpackage ORM
|
||||||
|
* @category Overrides
|
||||||
|
* @author Deon George
|
||||||
|
* @copyright (c) 2010 phpTSMadmin Development Team
|
||||||
|
* @license http://phptsmadmin.sf.net/license.html
|
||||||
|
*/
|
||||||
|
class ORM extends Kohana_ORM {
|
||||||
|
/**
|
||||||
|
* Override Kohana's FIND to remove the LIMIT
|
||||||
|
*/
|
||||||
|
public function find($id = NULL) {
|
||||||
|
// Since TSM doesnt support LIMIT, we'll use find_all() but return the first record
|
||||||
|
foreach ($this->find_all() as $object) {
|
||||||
|
$this->_load_values($object->_object);
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* We need to call our own _load_values() to support find() and TSM::result()
|
||||||
|
*
|
||||||
|
* (Since _load_values is protected, we need to make it public here,
|
||||||
|
* so that it can be called in TSM::result().)
|
||||||
|
*
|
||||||
|
* @see TSM::result
|
||||||
|
* @see ORM::find
|
||||||
|
*/
|
||||||
|
public function _load_values(array $values) {
|
||||||
|
return parent::_load_values($values);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
?>
|
@ -1,4 +1,22 @@
|
|||||||
<?php defined('SYSPATH') or die('No direct access allowed.');
|
<?php defined('SYSPATH') or die('No direct access allowed.');
|
||||||
|
|
||||||
class SystemMessage extends lnApp_SystemMessage {}
|
/**
|
||||||
|
* PTA System Messages.
|
||||||
|
*
|
||||||
|
* @package PTA
|
||||||
|
* @subpackage TSM
|
||||||
|
* @category Helpers
|
||||||
|
* @author Deon George
|
||||||
|
* @copyright (c) 2010 phpTSMadmin Development Team
|
||||||
|
* @license http://phptsmadmin.sf.net/license.html
|
||||||
|
*/
|
||||||
|
class SystemMessage extends lnApp_SystemMessage {
|
||||||
|
static public function TSM_Error($error,$sql) {
|
||||||
|
SystemMessage::add(array(
|
||||||
|
'title'=>_('Error while talking to TSM'),
|
||||||
|
'body'=>_('Running SQL').': <b>'.$sql.'</b><br/><br/>'.implode('<br/>',$error),
|
||||||
|
'type'=>'error',
|
||||||
|
));
|
||||||
|
}
|
||||||
|
}
|
||||||
?>
|
?>
|
||||||
|
37
application/classes/tsm.php
Normal file
37
application/classes/tsm.php
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
<?php defined('SYSPATH') or die('No direct access allowed.');
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This class contains our TSM information
|
||||||
|
*
|
||||||
|
* @package PTA
|
||||||
|
* @subpackage Core
|
||||||
|
* @category Helpers
|
||||||
|
* @author Deon George
|
||||||
|
* @copyright (c) 2010 Deon George
|
||||||
|
* @license http://dev.leenooks.net/license.html
|
||||||
|
*/
|
||||||
|
class TSM {
|
||||||
|
public function set($username,$password,Database_TSM_Result $server) {
|
||||||
|
// @todo Consider encrypting this
|
||||||
|
Session::instance()->set('admin_name',$username);
|
||||||
|
Session::instance()->set('password',$password);
|
||||||
|
|
||||||
|
Session::instance()->set('SERVER',$server);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static function instance() {
|
||||||
|
return new TSM;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static function name() {
|
||||||
|
return Session::instance()->get('SERVER')->rewind()->get('SERVER_NAME');
|
||||||
|
}
|
||||||
|
|
||||||
|
public static function version() {
|
||||||
|
$s = Session::instance()->get('SERVER')->rewind()->as_array();
|
||||||
|
$s = array_pop($s);
|
||||||
|
|
||||||
|
return sprintf('%s.%s.%s.%s',$s['VERSION'],$s['RELEASE'],$s['LEVEL'],$s['SUBLEVEL']);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
?>
|
29
application/config/auth.php
Normal file
29
application/config/auth.php
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
<?php defined('SYSPATH') or die('No direct access allowed.');
|
||||||
|
|
||||||
|
/**
|
||||||
|
* PTA Configuration - Authentication Driver
|
||||||
|
*
|
||||||
|
* @package PTA
|
||||||
|
* @subpackage TSM
|
||||||
|
* @category Configuration
|
||||||
|
* @author Deon George
|
||||||
|
* @copyright (c) 2010 phpTSMadmin Development Team
|
||||||
|
* @license http://phptsmadmin.sf.net/license.html
|
||||||
|
*/
|
||||||
|
|
||||||
|
return array(
|
||||||
|
|
||||||
|
'driver' => 'ORM',
|
||||||
|
'hash_method' => 'sha1',
|
||||||
|
'salt_pattern' => '1, 3, 5, 9, 14, 15, 20, 21, 28, 30',
|
||||||
|
'lifetime' => 1209600,
|
||||||
|
'session_key' => 'admin_name',
|
||||||
|
'forced_key' => 'auth_forced',
|
||||||
|
|
||||||
|
// Username/password combinations for the Auth File driver
|
||||||
|
'users' => array(
|
||||||
|
// 'admin' => 'b3154acf3a344170077d11bdb5fff31532f679a1919e716a02',
|
||||||
|
),
|
||||||
|
|
||||||
|
);
|
||||||
|
?>
|
33
application/config/config.php
Normal file
33
application/config/config.php
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
<?php defined('SYSPATH') or die('No direct access allowed.');
|
||||||
|
|
||||||
|
/**
|
||||||
|
* PTA system default configurable items.
|
||||||
|
*
|
||||||
|
* @package PTA
|
||||||
|
* @category Configuration
|
||||||
|
* @author Deon George
|
||||||
|
* @copyright (c) 2010 phpTSMadmin Development Team
|
||||||
|
* @license http://phptsmadmin.sf.net/license.html
|
||||||
|
*/
|
||||||
|
|
||||||
|
return array(
|
||||||
|
'cache_type' => 'file',
|
||||||
|
'client' => '/opt/tivoli/tsm/client/ba/bin/dsmadmc',
|
||||||
|
'client_errorlogname' => '/tmp/pta-tsm-errorlog.log',
|
||||||
|
'date_format' => 'd-m-Y',
|
||||||
|
'email_admin_only'=> array(
|
||||||
|
'method'=>array('wurley@users.sf.net'=>'Deon George'),
|
||||||
|
),
|
||||||
|
'method_directory'=> array( // Out method paths for the different functions
|
||||||
|
),
|
||||||
|
'method_security' => TRUE, // Enables Method Security. Setting to false means any method can be run without authentication
|
||||||
|
'site' => array(
|
||||||
|
'172.31.9.4'=>1,
|
||||||
|
),
|
||||||
|
'site_debug' => FALSE,
|
||||||
|
'site_mode' => array(
|
||||||
|
'172.31.9.4'=>Kohana::DEVELOPMENT,
|
||||||
|
'phptsmadmin.sf.net'=>Kohana::PRODUCTION,
|
||||||
|
)
|
||||||
|
);
|
||||||
|
?>
|
43
application/config/database.php
Normal file
43
application/config/database.php
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
<?php defined('SYSPATH') or die('No direct access allowed.');
|
||||||
|
|
||||||
|
/**
|
||||||
|
* PTA Configuration - TSM Client
|
||||||
|
*
|
||||||
|
* @package PTA
|
||||||
|
* @subpackage TSM
|
||||||
|
* @category Configuration
|
||||||
|
* @author Deon George
|
||||||
|
* @copyright (c) 2010 phpTSMadmin Development Team
|
||||||
|
* @license http://phptsmadmin.sf.net/license.html
|
||||||
|
*/
|
||||||
|
|
||||||
|
return array
|
||||||
|
(
|
||||||
|
'default' => array
|
||||||
|
(
|
||||||
|
'type' => 'tsm',
|
||||||
|
'connection' => array(
|
||||||
|
/**
|
||||||
|
* The following options are available for MySQL:
|
||||||
|
*
|
||||||
|
* string hostname server hostname, or socket
|
||||||
|
* string database database name
|
||||||
|
* string username database username
|
||||||
|
* string password database password
|
||||||
|
* boolean persistent use persistent connections?
|
||||||
|
*
|
||||||
|
* Ports and sockets may be appended to the hostname.
|
||||||
|
*/
|
||||||
|
'hostname' => 'localhost',
|
||||||
|
'database' => 'kohana',
|
||||||
|
'username' => FALSE,
|
||||||
|
'password' => FALSE,
|
||||||
|
'persistent' => FALSE,
|
||||||
|
),
|
||||||
|
'table_prefix' => '',
|
||||||
|
'charset' => 'utf8',
|
||||||
|
'caching' => FALSE,
|
||||||
|
'profiling' => TRUE,
|
||||||
|
),
|
||||||
|
);
|
||||||
|
?>
|
Reference in New Issue
Block a user