public $ontable; // string(32) not_null multiple_key
public $onid; // int(11) not_null
public $mimetype; // string(64) not_null
- public $filesize; // int(11) not_null
- public $created; // datetime(19) not_null binary
- public $created_by; // int(11) not_null
-
public $width; // int(11) not_null
public $height; // int(11) not_null
-
-
- public $imgtype; // string(32) not_null
+ public $filesize; // int(11) not_null
+ public $displayorder; // int(11) not_null
+ public $language; // string(6) not_null
public $parent_image_id; // int(11) not_null
+ public $created; // datetime(19) not_null binary
+ public $imgtype; // string(32) not_null
public $linkurl; // string(254) not_null
public $descript; // blob(65535) not_null blob
public $title; // string(128) not_null
- public $displayorder; // int(11) not_null
- public $language; // string(6) not_null
-
+
/* the code above is auto generated do not remove the tag below */
###END_AUTOCODE
+
+ function checkPerm($perm, $au)
+ {
+ // default permissons are to
+ // allow create / edit / if the user has
+ if (!$au) {
+
+
+
+ return false;
+ }
+
+
+
+ $o = $this->object();
+ //print_r($o);
+ if (method_exists($o, 'hasPerm')) {
+ // edit permissions on related object needed...
+ return $o->hasPerm( $perm == 'S' ? 'S' : 'E' , $au);
+
+ }
+
+ return true; //// ??? not really that safe...
+
+ }
+
+
+
+
+
+
/**
* create an email from file.
* these must have been set first.
$this->mimetype= strtolower($this->mimetype);
- if (array_shift(explode($this->mimetype)) == 'image') {
+ if (array_shift(explode('/', $this->mimetype)) == 'image') {
$imgs = @getimagesize($file);
$f = $this->getStoreName();
$dest = dirname($f);
if (!file_exists($dest)) {
-
+ // currently this is 0775 due to problems using shared hosing (FTP)
+ // it makes all the files unaccessable..
+ // you can normally solve this by giving the storedirectory better perms
+ // if needed on a dedicated server..
$oldumask = umask(0);
- mkdir($dest, 0770, true);
+ mkdir($dest, 0775, true);
umask($oldumask);
}
}
}
-
+ /**
+ * check mimetype against type
+ * - eg. img.is(#image#)
+ *
+ */
+ function is($type)
+ {
+ if (empty($this->mimetype)) {
+ return false;
+ }
+ return 0 === strcasecmp($type, array_shift(explode('/',$this->mimetype)));
+ }
/**
* onUpload (singlely attached image to a table)
/**
* return a list of images for an object, optionally with a mime regex.
* eg. '%/pdf' or 'image/%'
+ *
+ * usage:
+ *
+ * $i = DB_DataObject::factory('Images');
+ * $i->imgtype = 'LOGO';
+ * $ar = $i->gather($somedataobject, 'image/%');
+ *
+ * @param {DB_DataObject} dataobject = the object to gather data on.
+ * @param {String} mimelike LIKE query to use for search
+
*/
- function gather($obj, $mime_like='')
+ function gather($obj, $mime_like='', $opts=array())
{
//DB_DataObject::debugLevel(1);
if (empty($obj->id)) {
return array();
}
+
$c = clone($this);
$c->ontable = $obj->tableName();
$c->onid = $obj->id;
+ $c->autoJoin();
if (!empty($mime_like)) {
- $c->whereAdd("mimetype LIKE '". $c->escape($mime_like) ."'");
+ $c->whereAdd("Images.mimetype LIKE '". $c->escape($mime_like) ."'");
}
return $c->fetchAll();
}
+
+
/**
- * creation - associate this image with a dataobject
- * - currently assumes id is the key column
- * @param DB_DataObject $obj a dataobject
- */
- function associate($obj)
+ * set or get the dataobject this image is associated with
+ * @param DB_DataObject $obj An object to associate this image with
+ * (does not store it - you need to call update() to do that)
+ * @return DB_DataObject the dataobject this image is attached to.
+ */
+ function object($obj=false)
{
+ if ($obj === false) {
+ if (empty($this->ontable) || empty($this->onid)) {
+ return false;
+ }
+ $ret = DB_DataObject::factory($this->ontable);
+ $ret->get($this->onid);
+ return $ret;
+ }
+
+
$this->ontable = $obj->tableName();
$this->onid = $obj->id; /// assumes our nice standard of using ids..
-
+ return $obj;
}
// echo '<PRE>';print_r($req);exit;
$ret= $this->toArray();
-
+ static $ff = false;
+ if (!$ff) {
+ $ff = HTML_FlexyFramework::get();
+ }
+
+ $ret['public_baseURL'] = isset($ff->Pman_Images['public_baseURL']) ?
+ $ff->Pman_Images['public_baseURL'] : $ff->baseURL;
+
if (!empty($req['query']['imagesize'])) {
$baseURL = isset($req['query']['imageBaseURL']) ? $req['query']['imageBaseURL'] : false;
$ff = HTML_FlexyFramework::get();
$baseURL = $baseURL ? $baseURL : $ff->baseURL ;
+ if (preg_match('#^http[s]*://#', $provider)) {
+ $baseURL = '';
+ }
+
if ($size < 0) {
return $baseURL . $provider . "/{$this->id}/{$this->filename}";
}
$sz = explode('x', $size);
$sx = $sz[0];
//var_dump($sz);
- if (!$this->id) {
+ if (!$this->id || empty($this->width)) {
$this->height = $sx;
$this->width = empty($sz[1]) ? $sx : $sz[1];
$sy = $this->width ;
}
if (empty($sz[1])) {
- $ratio = $this->height/ ($this->width *1.0);
- $sy = $ration * $sx;
+ $ratio = empty($this->width) ? 1 : $this->height/ ($this->width *1.0);
+ $sy = $ratio * $sx;
} else {
$sy = $sz[1];
}
// create it?
-
-
+
return '<img src="' . $this->URL($size, $provider) . '" width="'. $sx . '" height="'. $sy . '">';
}
-
-
+
+ /**
+ * to Fileconvert object..
+ *
+ *
+ *
+ */
+ function toFileConvert()
+ {
+ require_once 'File/Convert.php';
+ $fc = new File_Convert($this->getStoreName(), $this->mimetype);
+ return $fc;
+
+ }
+ /**
+ *
+ *
+ *
+ */
function setFromRoo($ar, $roo)
{
// not sure why we do this..
+
+
+
+
// if imgtype starts with '-' ? then we set the 'old' (probably to delete later)
if (!empty($ar['imgtype']) && !empty($ar['ontable']) && !empty($ar['onid']) && ($ar['imgtype'][0] == '-')) {
$this->setFrom($ar);
if (!empty($ar['_copy_from'])) {
+
+ if (!$this->checkPerm( 'A' , $roo->authUser)) {
+ $roo->jerr("IMAGE UPLOAD PERMISSION DENIED");
+ }
+
$copy = DB_DataObject::factory('Images');
$copy->get($ar['_copy_from']);
$this->setFrom($copy->toArray());
// FIXME - we should be checking perms here...
- //if (method_exists($x, 'checkPerm') && !$x->checkPerm('E', $this->authUser)) {
- // $this->jerr("PERMISSION DENIED");
- // }
+
// this should be doign update
$this->setFrom($ar);
+
+ if (!$this->checkPerm($this->id ? 'A' : 'E', $roo->authUser)) {
+ $roo->jerr("IMAGE UPLOAD PERMISSION DENIED");
+ }
if (!isset($_FILES['imageUpload'])) {
return; // standard update...
}
if ( !$this->onUpload($this)) {
- $this->jerr("File upload failed");
+ $roo->jerr("File upload failed : ". $this->err);
}
+
$roo->addEvent("ADD", $this, $this->toEventString());
$r = DB_DataObject::factory($this->tableName());
$roo->jok($r->toArray());
}
+
function toEventString()
{