Currently I have a class called user that I want to create with different variables, but I think I’m doing it wrong.
Currently I have a class “Unit” with these two functions
public function __construct($table, $id) {
require_once('database.php');
require_once('app.php');
require_once("postmark.php");
$this->table = $table;
$this->valid = true;
if(!$id) {
$this->valid = false;
}
$this->populate($id);
}
public function populate($id) {
$db = new DB();
$q = $db->where('id', $id)->get($this->table);
$resp = $q->fetchAll();
foreach ($resp as $row) {
foreach ($row as $key=>$value) {
if(!is_int($key))
$this->$key = html_entity_decode($value, ENT_QUOTES);
if(is_null($value)) {
$this->$key = null;
}
}
}
if(count($resp) <= 0) $this->valid = false;
$verdict = !$db->error;
$db = null;
unset($db);
return $verdict;
}
And then my “User” class extends it like so
public function __construct($id, $hash = null, $verify = null, $api = null) {
if($api)
$value = $this->apiToId($api);
else if($verify)
$value = $this->verifyToId($verify);
else if($hash)
$value = $this->hashToId($hash);
else
$value = $id;
parent::__construct("users", $value);
}
But I can’t help but think this is poor in design. A few things I have seen in the past are the use of ampersands, possibly making it so I could do
$user = new User()->fromId($id);
Or
$user = new User()->withHash($hash);
Instead of passing it a long list of null params. That or I could improve the way inheritance works. While I like to think I know what I’m doing with PHP, I’d really like some help looking in the right direction. PHP’s docs are so cumbersome, that I never no where to look, but always find cool useful tools. I’m wondering how I can improve this for more flexibility and structure.
allocreally should be a static function defined inUser. Code snippet at bottom.initfunctions should be declared as static and return a new instance of the class. Defining an instance of the class to re-instantiate the class is just a bad idea.Post your full code and comment on this answer if you’d like some help implementing all of this.