by Asa Kusuma
License: MIT
- About
- Installation
- Usage Example
- Notes
- get_note_attachment() Example
- set_note_attachment() Example
- PHP wrapper class for interacting with a SugarCRM REST API
- Creating, reading, and updating capability
- More info on SugarCRM: http://www.sugarcrm.com/
- API docs: http://developers.sugarcrm.com/
- Designed to work with SugarCRM v.6
- Configure by setting the $rest_url, $username, and $password class variables in the sugar_rest.php class file. The username and password of any SugarCRM user should work. It's recommended that you create a new SugarCRM user account to be exclusively used for authenticating API calls.
- Just import the class with
require("sugar_rest.php");
and code away!
require_once("sugar_rest.php");
$sugar = new Sugar_REST();
$results = $sugar->get("Accounts",array('id','name'));
print_r($results);
See example.php for another example.
- The
is_valid_id()
function may need to modify for different versions of SugarCRM. - Different versions of SugarCRM have different ID formats.
This example outputs the contents of a note's attachment, given the note ID. Assumes $note_id contains the ID of the note you wish to modify.
require_once("sugar_rest.php");
$sugar = new Sugar_REST();
$result = $sugar->get_note_attachment($note);
$filename = $result['note_attachment']['filename'];
$file = $result['note_attachment']['file'];
$file = base64_decode($file);
header("Cache-Control: no-cache private");
header("Content-Description: File Transfer");
header('Content-disposition: attachment; filename='.$filename);
header("Content-Type: application/vnd.ms-excel");
header("Content-Transfer-Encoding: binary");
header('Content-Length: '. strlen($file));
echo $file;
exit;
This example illustrates how to set a note's attachment from an html form. Assumes $note_id contains the ID of the note you wish to modify.
<form method="post" action="example.php" enctype="multipart/form-data">
<input name="note_file" type="file" />
<input type="submit" value="Go" />
</form>
require_once("sugar_rest.php");
$sugar = new Sugar_REST();
if ($_FILES["note_file"]["error"] > 0) {
// Error: $_FILES["file"]["error"]
} else if(isset($_FILES['note_file']['tmp_name']) && $_FILES['note_file']['tmp_name']!="") {
$handle = fopen($_FILES['note_file']['tmp_name'], "rb");
$filename = $_FILES['note_file']['name'];
$contents = fread($handle, filesize($_FILES['note_file']['tmp_name']));
$binary = base64_encode($contents);
$file_results = $sugar->set_note_attachment($note_id,$binary,$filename);
}
This example illustrates how to get the available modules in Sugar. All of them.
This is a handy function to use when building future proof sugarcrm plugins.
require_once("sugar_rest.php");
$sugar = new Sugar_REST();
$modules = $sugar->get_available_modules();
BAM! Now loop through the array that was returned and stored in $modules. You could use this to display a dropdown in the admin panel that displays all modules a user would want to connect your sugarcrm plugin to.