<?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.