Host multiple sites with the same codebase
This is the beginning of the code for status.net and related status farms. It will read basic information about a site from a shared, central database and use the data stored there to switch on the hostname.
This commit is contained in:
parent
95bb1c6a99
commit
60861760fc
61
classes/Status_network.php
Executable file
61
classes/Status_network.php
Executable file
|
@ -0,0 +1,61 @@
|
|||
<?php
|
||||
/**
|
||||
* Table Definition for status_network
|
||||
*/
|
||||
|
||||
class Status_network extends DB_DataObject
|
||||
{
|
||||
###START_AUTOCODE
|
||||
/* the code below is auto generated do not remove the above tag */
|
||||
|
||||
public $__table = 'status_network'; // table name
|
||||
public $nickname; // varchar(64) primary_key not_null
|
||||
public $hostname; // varchar(255) unique_key
|
||||
public $pathname; // varchar(255) unique_key
|
||||
public $sitename; // varchar(255)
|
||||
public $dbhost; // varchar(255)
|
||||
public $dbuser; // varchar(255)
|
||||
public $dbpass; // varchar(255)
|
||||
public $dbname; // varchar(255)
|
||||
public $created; // datetime() not_null
|
||||
public $modified; // timestamp() not_null default_CURRENT_TIMESTAMP
|
||||
|
||||
/* Static get */
|
||||
function staticGet($k,$v=NULL) { return DB_DataObject::staticGet('Status_network',$k,$v); }
|
||||
|
||||
/* the code above is auto generated do not remove the tag below */
|
||||
###END_AUTOCODE
|
||||
|
||||
static function setupDB($dbhost, $dbuser, $dbpass, $dbname)
|
||||
{
|
||||
global $config;
|
||||
|
||||
$config['db']['database_'.$dbname] = "mysqli://$dbuser:$dbpass@$dbhost/$dbname";
|
||||
$config['db']['ini_'.$dbname] = INSTALLDIR.'/classes/statusnet.ini';
|
||||
$config['db']['table_status_network'] = $dbname;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
static function setupSite($servername, $pathname)
|
||||
{
|
||||
global $config;
|
||||
|
||||
$parts = explode('.', $servername);
|
||||
|
||||
$sn = Status_network::staticGet('nickname', $parts[0]);
|
||||
|
||||
if (!empty($sn)) {
|
||||
$dbhost = (empty($sn->dbhost)) ? 'localhost' : $sn->dbhost;
|
||||
$dbuser = (empty($sn->dbuser)) ? $sn->nickname : $sn->dbuser;
|
||||
$dbpass = $sn->dbpass;
|
||||
$dbname = (empty($sn->dbname)) ? $sn->nickname : $sn->dbname;
|
||||
|
||||
$config['db']['database'] = "mysqli://$dbuser:$dbpass@$dbhost/$dbname";
|
||||
$config['site']['name'] = $sn->sitename;
|
||||
return true;
|
||||
} else {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
}
|
17
classes/statusnet.ini
Executable file
17
classes/statusnet.ini
Executable file
|
@ -0,0 +1,17 @@
|
|||
|
||||
[status_network]
|
||||
nickname = 130
|
||||
hostname = 2
|
||||
pathname = 2
|
||||
sitename = 2
|
||||
dbhost = 2
|
||||
dbuser = 2
|
||||
dbpass = 2
|
||||
dbname = 2
|
||||
created = 142
|
||||
modified = 384
|
||||
|
||||
[status_network__keys]
|
||||
nickname = K
|
||||
hostname = U
|
||||
pathname = U
|
|
@ -192,3 +192,11 @@ $config['sphinx']['port'] = 3312;
|
|||
|
||||
#Use a different hostname for SSL-encrypted pages
|
||||
#$config['site']['sslserver'] = 'secure.example.org';
|
||||
|
||||
#If you have a lot of status networks on the same server, you can
|
||||
#store the site data in a database and switch as follows
|
||||
#Status_network::setupDB('localhost', 'statusnet', 'statuspass', 'statusnet');
|
||||
#if (!Status_network::setupSite($_server, $_path)) {
|
||||
# print "Error\n";
|
||||
# exit(1);
|
||||
#}
|
||||
|
|
17
db/site.sql
Normal file
17
db/site.sql
Normal file
|
@ -0,0 +1,17 @@
|
|||
/* For managing multiple sites */
|
||||
|
||||
create table status_network (
|
||||
|
||||
nickname varchar(64) primary key comment 'nickname',
|
||||
hostname varchar(255) unique key comment 'alternate hostname if any',
|
||||
pathname varchar(255) unique key comment 'alternate pathname if any',
|
||||
sitename varchar(255) comment 'display name',
|
||||
dbhost varchar(255) comment 'database host',
|
||||
dbuser varchar(255) comment 'database username',
|
||||
dbpass varchar(255) comment 'database password',
|
||||
dbname varchar(255) comment 'database name',
|
||||
|
||||
created datetime not null comment 'date this record was created',
|
||||
modified timestamp comment 'date this record was modified'
|
||||
|
||||
) ENGINE=InnoDB CHARACTER SET utf8 COLLATE utf8_general_ci;
|
Loading…
Reference in New Issue
Block a user