blob: ef7fbe5dffbcd2bb4e597999e9f47db5f3b0784a (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
|
<?php
/**
* Base class for Management of Liberty Content
*
* @package liberty
* @version $Header: /cvsroot/bitweaver/_bit_liberty/LibertyBase.php,v 1.12 2006/09/06 16:02:55 spiderr Exp $
* @author spider <spider@steelsun.com>
*/
// +----------------------------------------------------------------------+
// | Copyright (c) 2004, bitweaver.org
// +----------------------------------------------------------------------+
// | All Rights Reserved. See copyright.txt for details and a complete list of authors.
// | Licensed under the GNU LESSER GENERAL PUBLIC LICENSE. See license.txt for details
// |
// | For comments, please use phpdocu.sourceforge.net documentation standards!!!
// | -> see http://phpdocu.sourceforge.net/
// +----------------------------------------------------------------------+
// | Authors: spider <spider@steelsun.com>
// +----------------------------------------------------------------------+
/**
* required setup
*/
require_once( KERNEL_PKG_PATH.'BitBase.php' );
/**
* Virtual base class (as much as one can have such things in PHP) for all
* derived bitweaver classes that manage content.
*
* @package liberty
*/
class LibertyBase extends BitBase {
/**
* Constructor building on BitBase object
*
* Object need to init the database connection early
* Database will be linked via a previously activated BitDb object
* which will provide the mDb pointer to that database
*/
function LibertyBase () {
BitBase::BitBase();
}
/**
* Given a content_id, this will return and object of the proper type
*
* @param integer content_id of the object to be returned
* @param string optional content_type_guid of pConId. This will save a select if you happen to have this info. If not, this method will look it up for you.
* @returns object of the appropriate content type class
*/
function getLibertyObject( $pContentId, $pContentGuid=NULL ) {
$ret = NULL;
global $gLibertySystem, $gBitUser, $gBitSystem;
if( BitBase::verifyId( $pContentId ) ) {
// remove non integer bits from structure_id and content_id requests
// can happen with period's at the end of url's that are email'ed around
$pContentId = preg_replace( '/[\D]/', '', $pContentId );
if( empty( $pContentGuid ) ) {
$pContentGuid = $gLibertySystem->mDb->getOne( "SELECT `content_type_guid` FROM `".BIT_DB_PREFIX."liberty_content` WHERE `content_id`=?", array( $pContentId ) );
}
if( !empty( $pContentGuid ) && isset( $gLibertySystem->mContentTypes[$pContentGuid] ) ) {
$type = $gLibertySystem->mContentTypes[$pContentGuid];
require_once( constant( strtoupper( $type['handler_package'] ).'_PKG_PATH' ).$type['handler_file'] );
$ret = new $type['handler_class']( NULL, $pContentId );
$ret->load();
}
}
return $ret;
}
}
?>
|