mirror of
https://we.phorge.it/source/phorge.git
synced 2024-11-11 17:32:41 +01:00
39ca1e7e39
Summary: Allow user and arbitrary object lookup by PHID. Test Plan: Executed user.whoami, user.info, user.find and phid.info via Conduit console. Reviewers: jungejason, tuomaspelkonen, aran, nh Reviewed By: nh CC: skrul, aran, nh, jungejason, epriestley Differential Revision: 870
183 lines
4 KiB
PHP
183 lines
4 KiB
PHP
<?php
|
|
|
|
/*
|
|
* Copyright 2011 Facebook, Inc.
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
class PhabricatorObjectHandle {
|
|
|
|
private $uri;
|
|
private $phid;
|
|
private $type;
|
|
private $name;
|
|
private $email;
|
|
private $fullName;
|
|
private $imageURI;
|
|
private $timestamp;
|
|
private $alternateID;
|
|
private $status = 'open';
|
|
private $complete;
|
|
|
|
public function setURI($uri) {
|
|
$this->uri = $uri;
|
|
return $this;
|
|
}
|
|
|
|
public function getURI() {
|
|
return $this->uri;
|
|
}
|
|
|
|
public function setPHID($phid) {
|
|
$this->phid = $phid;
|
|
return $this;
|
|
}
|
|
|
|
public function getPHID() {
|
|
return $this->phid;
|
|
}
|
|
|
|
public function setName($name) {
|
|
$this->name = $name;
|
|
return $this;
|
|
}
|
|
|
|
public function getName() {
|
|
return $this->name;
|
|
}
|
|
|
|
public function setStatus($status) {
|
|
$this->status = $status;
|
|
return $this;
|
|
}
|
|
|
|
public function getStatus() {
|
|
return $this->status;
|
|
}
|
|
|
|
public function setFullName($full_name) {
|
|
$this->fullName = $full_name;
|
|
return $this;
|
|
}
|
|
|
|
public function getFullName() {
|
|
if ($this->fullName !== null) {
|
|
return $this->fullName;
|
|
}
|
|
return $this->getName();
|
|
}
|
|
|
|
public function setType($type) {
|
|
$this->type = $type;
|
|
return $this;
|
|
}
|
|
|
|
public function getType() {
|
|
return $this->type;
|
|
}
|
|
|
|
public function setEmail($email) {
|
|
$this->email = $email;
|
|
return $this;
|
|
}
|
|
|
|
public function getEmail() {
|
|
return $this->email;
|
|
}
|
|
|
|
public function setImageURI($uri) {
|
|
$this->imageURI = $uri;
|
|
return $this;
|
|
}
|
|
|
|
public function getImageURI() {
|
|
return $this->imageURI;
|
|
}
|
|
|
|
public function setTimestamp($timestamp) {
|
|
$this->timestamp = $timestamp;
|
|
return $this;
|
|
}
|
|
|
|
public function getTimestamp() {
|
|
return $this->timestamp;
|
|
}
|
|
|
|
public function setAlternateID($alternate_id) {
|
|
$this->alternateID = $alternate_id;
|
|
return $this;
|
|
}
|
|
|
|
public function getAlternateID() {
|
|
return $this->alternateID;
|
|
}
|
|
|
|
public function getTypeName() {
|
|
static $map = array(
|
|
PhabricatorPHIDConstants::PHID_TYPE_USER => 'User',
|
|
PhabricatorPHIDConstants::PHID_TYPE_TASK => 'Task',
|
|
PhabricatorPHIDConstants::PHID_TYPE_DREV => 'Revision',
|
|
PhabricatorPHIDConstants::PHID_TYPE_CMIT => 'Commit',
|
|
PhabricatorPHIDConstants::PHID_TYPE_WIKI => 'Phriction',
|
|
);
|
|
|
|
return idx($map, $this->getType());
|
|
}
|
|
|
|
public function setComplete($complete) {
|
|
$this->complete = $complete;
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Determine if the handle represents an object which was completely loaded
|
|
* (i.e., the underlying object exists) vs an object which could not be
|
|
* completely loaded (e.g., the type or data for the PHID could not be
|
|
* identified or located).
|
|
*
|
|
* Basically, @{class:PhabricatorObjectHandleData} gives you back a handle for
|
|
* any PHID you give it, but it gives you a complete handle only for valid
|
|
* PHIDs.
|
|
*
|
|
* @return bool True if the handle represents a complete object.
|
|
*/
|
|
public function isComplete() {
|
|
return $this->complete;
|
|
}
|
|
|
|
public function renderLink() {
|
|
|
|
switch ($this->getType()) {
|
|
case PhabricatorPHIDConstants::PHID_TYPE_USER:
|
|
$name = $this->getName();
|
|
break;
|
|
default:
|
|
$name = $this->getFullName();
|
|
}
|
|
|
|
$class = null;
|
|
if ($this->status != PhabricatorObjectHandleStatus::STATUS_OPEN) {
|
|
$class = 'handle-status-'.phutil_escape_html($this->status);
|
|
}
|
|
|
|
return phutil_render_tag(
|
|
'a',
|
|
array(
|
|
'href' => $this->getURI(),
|
|
'class' => $class,
|
|
),
|
|
phutil_escape_html($name));
|
|
}
|
|
|
|
}
|