You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 

344 lines
13 KiB

<?php
/**
* Class provides connection to a-real redmine api.
* Use class_bitrix_to_redmine
*
* @package redmine_api
* @author Mikhail Grebenkin <mix@m14xa.ru>
*/
class class_redmine {
protected $redmine_key = '';
protected $redmine_url = '';
/**
* Uploads $filecontent and returns token.
*
* @param mixed $filecontent - content of file
* @return array 0 => http response, 1 => $token is object, string can be obtained in $token->upload->token
*/
function get_upload_token($filecontent) {
$upload_url = $this->redmine_url.'uploads.json?key='.$this->redmine_key;
$request['type'] = 'post';
$request['content_type'] = 'application/octet-stream';
return $this->curl_redmine($upload_url,$request,$filecontent);
}
/**
* Uploads an attachment, attaches it to an issue and returns json-decoded updated issue
*
* @param string $issue_id numeric id of issue to attach file
* @param string $filename name of file
* @param string $filetype type of content i.e. "image/png"
* @param mixed $filecontent content of file.
* @return array 0 => http response, 1 => $issue updated issue
*/
function upload_attachment(string $issue_id, string $filename, string $filetype, $filecontent){
$token = $this->get_upload_token($filecontent)[1];
if (!$token) {
return null;
}
$upload_token = $token->upload->token;
return $this->attach_to_issue($issue_id,$upload_token, $filename, $filetype);
}
/**
* Download an attachment or thumbnail
*
* @param string $attachment_id numeric id of attachment
* @param bool $thumbnail if true downloading thumbnail
*
* @return array 0 => http response, 1 => $filecontent - content of file
*/
function download_attachment(string $attachment_id, bool $thumbnail=false) {
if ($thumbnail) {
$file_url = $this->redmine_url.'attachments/thumbnail/'.$attachment_id.'?key='.$this->redmine_key;
return file_get_contents($file_url);
} else {
$at_url = $this->redmine_url.'attachments/'.$attachment_id.'.json?key='.$this->redmine_key;
$api_resp = $this->curl_redmine($at_url);
$at_descr = $api_resp[0];
if (!$at_descr) {
return null;
}
$file_url = $this->redmine_url.'attachments/download/'.
$attachment_id.'/'.$at_descr->attachment->filename.'?key='.$this->redmine_key;
return file_get_contents($file_url);
}
}
/**
* Create issue
*
* @param $post_data - string to post to redmine (needs to update)
* @return array 0 => http response, 1 => $issue - new data
*/
function create_issue($post_data) {
$issue_url = $this->redmine_url.'issues.json?key='.$this->redmine_key;
$request['type'] = 'post';
$request['content_type'] = 'application/json';
return $this->curl_redmine($issue_url,$request,$post_data);
}
/**
* get issue
*
* @param string $issue_id numeric issue id
* @param string $project_id numeric project id
* @param array $inc array of string with options to include. Example: array( 0 => "journals", 1 => "attachments" );
* possible options:
* *children
* *attachments
* *relations
* *changesets
* *journals
* *watchers
*
* @return array 0 => http response, 1 => $issue - json data of issue
*/
function get_issue(string $issue_id='',string $project_id='', array $inc=array()) {
if (count($inc) > 0) {
$inc = implode(",", $inc);
$inc = '&include='.$inc;
var_dump($inc);
} else {
$inc = '';
}
if($project_id!='') {
$issue_url = $this->redmine_url.'issues.json?key='.$this->redmine_key.'&project_id='.$project_id.$inc;
}else{
$issue_url = ($issue_id=='')
?$this->redmine_url.'issues.json?key='.$this->redmine_key.$inc
: $this->redmine_url.'issues/'.$issue_id.'.json?key='.$this->redmine_key.$inc;
}
return $this->curl_redmine($issue_url);
}
/**
* attach to issue
*
* @param string $issue_id digits only issue id
* @param string $upload_token digits only project id
* @param string $upload_token
* @param array $inc array of string with options to include. Example: array( 0 => "journals", 1 => "attachments" );
* @return array 0 => http responce; 1 => issue - new data
*/
function attach_to_issue(string $issue_id,string $upload_token, string $filename, string $filetype) {
$issue_url = $this->redmine_url.'issues/'.$issue_id.'.json?key='.$this->redmine_key;
$update = array( "issue" => array( "uploads"=> array( 0 => array("token" => $upload_token,
"filename" => $filename,
"content_type"=> $filetype )
)
)
);
$request['type'] = 'put';
$request['content_type'] = 'application/json';
$post_data = json_encode($update);
return $this->curl_redmine($issue_url, $request , $post_data);
}
/**
* add comment to issue
*
* @param string $issue_id digits only issue id
* @param string $comment comment to add to the issue
* @return mixed array 0 => http response, 1 => $issue - new data
*/
function post_issue_comment(string $issue_id,string $comment) {
$issue_url = $this->redmine_url.'issues/'.$issue_id.'.json?key='.$this->redmine_key;
$update = array( "issue" => array(
"notes"=> $comment,
)
);
$request['type'] = 'put';
$request['content_type'] = 'application/json';
$post_data = json_encode($update);
return $this->curl_redmine($issue_url, $request , $post_data);
}
//Projects, nowadays we don't use it.
function get_projects($project_id='') {
$proj_url = ($project_id=='')?$this->redmine_url.'projects.json?key='.$this->redmine_key : $this->redmine_url.'projects/'.$project_id.'.json?key='.$this->redmine_key;
return $this->curl_redmine($proj_url);
}
//Contacts
/**
* returns json structure with all contacts
*
* @return mixed array 0 => http response, 1 => $contacts - data
*/
function get_contacts() {
$cont_url = $this->redmine_url.'contacts.json?key='.$this->redmine_key;
return $this->curl_redmine($cont_url);
}
/**
* search contacts by string. Returns contacts.
*
* @param string $search_str string to search by
* @return mixed array 0 => http response, 1 => $contacts - new data
*/
function search_contacts_str(string $search_str) {
$cont_url = $this->redmine_url.'contacts.json?key='.$this->redmine_key.'&search='.$search_str;
return $this->curl_redmine($cont_url);
}
/**
* search contacts by id. Returns one contact.
*
* @param string $id digits only contact id
* @param bool $issues if true, includes issues, connected to contact
* @return mixed array 0 => http response, 1 => $contact - data
*/
function get_contact_id(string $id, bool $issues) {
$cont_url = ($issues)
? $this->redmine_url."contacts/$id.json?key=".$this->redmine_key.'&include=issues'
: $this->redmine_url."contacts/$id.json?key=".$this->redmine_key;
echo($cont_url);
return $this->curl_redmine($cont_url);
}
/**
* Creates contact from array.
*
* @param array $contact array with all needed contact fields
* @return mixed array 0 => http response, 1 => $contact - data
*/
function create_contact(array $contact) {
$cont_url = $this->redmine_url.'contacts.json?key='.$this->redmine_key;
$request['type'] = 'post';
$request['content_type'] = 'application/json';
$post_data = json_encode($contact);
return $this->curl_redmine($cont_url,$request,$post_data);
}
/**
* attach contact to issue
*
* @param string $issue_id digits only issue id
* @param string $contact_id digits only contact id
* @return mixed array 0 => http response, 1 => $issue - new data
*/
function attach_issue_to_contact(string $issue_id,string $contact_id) {
$contact_url = $this->redmine_url."contacts/".$contact_id."?key=".$this->redmine_key;
$update = array( "contact" => array(
"issues"=> array( 0=> array("id" => $issue_id))
)
);
$request['type'] = 'put';
$request['content_type'] = 'application/json';
$post_data = json_encode($update);
return $this->curl_redmine($contact_url, $request , $post_data);
}
/**
* create_ticket creates issue with connected contact. Needs contact email.
*
* @param string $issue_id digits only issue id
* @param string $contact_email contact email
* @return mixed array 0 => http response, 1 => $issue - new data
*/
function create_ticket(string $contact_email, string $subject, string $description) {
$issue_url = $this->redmine_url."helpdesk/create_ticket.xml?key=".$this->redmine_key;
$issue_xml = "<?xml version=\"1.0\"?>
<ticket>
<issue>
<project_id>14</project_id>
<tracker_id>3</tracker_id>
<subject>$subject</subject>
<description>$description</description>
</issue>
<contact>
<email>$contact_email</email>
</contact>
</ticket>";
$request['type'] = 'post';
$request['content_type'] = 'application/xml';
return $this->curl_redmine($issue_url, $request, $issue_xml );
}
//Curl
function curl_redmine(string $redmine_url,array $request=array(),string $post_data='') {
if(!isset($request['type'])){ $request['type']=null; }
if(!isset($request['content_type'])){ $request['content_type']=null; }
//Create a curl object
$ch = curl_init();
//Set the useragent
//$agent = $_SERVER["HTTP_USER_AGENT"];
//curl_setopt($ch, CURLOPT_USERAGENT, $agent);
//Set the URL
curl_setopt($ch, CURLOPT_URL, $redmine_url );
if($request['type'] == 'post'){
//This is a POST query
curl_setopt($ch, CURLOPT_POST,1);
curl_setopt($ch, CURLOPT_POSTFIELDS,$post_data);
curl_setopt($ch, CURLOPT_HTTPHEADER, array(
'Content-Type: '.$request['content_type'],
'Content-Length: ' . strlen($post_data))
);
} elseif ($request['type'] == 'put') {
//This is a PUT query
curl_setopt($ch, CURLOPT_CUSTOMREQUEST, 'PUT');
curl_setopt($ch, CURLOPT_POSTFIELDS,$post_data);
curl_setopt($ch, CURLOPT_HTTPHEADER, array(
'Content-Type: '.$request['content_type'],
'Content-Length: ' . strlen($post_data))
);
}
//We want the content after the query
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
//Follow Location redirects
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 1);
//curl_setopt($ch, CURLOPT_HEADER, true);
/*
Set the cookie storing files
Cookie files are necessary since we are logging and session data needs to be saved
*/
//curl_setopt($ch, CURLOPT_COOKIEJAR, 'cookie.txt');
//curl_setopt($ch, CURLOPT_COOKIEFILE, 'cookie.txt');
//Execute the action to login
$postResult = curl_exec($ch);
// echo(curl_getinfo($ch, CURLINFO_HTTP_CODE));
// for debug purposes
// if($postResult == false){ return $info = curl_getinfo($ch);}
$response = array( 0 => curl_getinfo($ch, CURLINFO_HTTP_CODE),
1 => json_decode($postResult));
return $response;
}
}//class_redmine
class class_bitrix_to_redmine extends class_redmine {
protected $redmine_key = '68692662158cb38c8fddb8e084b6dfd55d77b85c';
protected $redmine_url = 'https://tracker.a-real.ru/';
function send_contact($data){
$contact = array("contact" => array("first_name" => $data['last_name'],
"project_id" => "managers",
"phone" => $data["phone_work"],
"email" => $data['webtolead_email1']
)
);
return $this->create_contact($contact);
}
}
?>

Powered by TurnKey Linux.