forked from friendica/friendica-addons
		
	
		
			
				
	
	
		
			206 lines
		
	
	
	
		
			6.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			206 lines
		
	
	
	
		
			6.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 	class BufferApp {
 | |
| 		private $client_id;
 | |
| 		private $client_secret;
 | |
| 		private $code;
 | |
| 		public $access_token;
 | |
| 
 | |
| 		private $callback_url;
 | |
| 		private $authorize_url = 'https://bufferapp.com/oauth2/authorize';
 | |
| 		private $access_token_url = 'https://api.bufferapp.com/1/oauth2/token.json';
 | |
| 		private $buffer_url = 'https://api.bufferapp.com/1';
 | |
| 
 | |
| 		public $ok = false;
 | |
| 
 | |
| 		private $endpoints = [
 | |
| 			'/user' => 'get',
 | |
| 
 | |
| 			'/profiles' => 'get',
 | |
| 			'/profiles/:id' => 'get',
 | |
| 			'/profiles/:id/schedules' => 'get',
 | |
| 			'/profiles/:id/schedules/update' => 'post',	// Array schedules [0][days][]=mon, [0][times][]=12:00
 | |
| 
 | |
| 			'/updates/:id' => 'get',
 | |
| 			'/profiles/:id/updates/pending' => 'get',
 | |
| 			'/profiles/:id/updates/sent' => 'get',
 | |
| 			'/updates/:id/interactions' => 'get',
 | |
| 
 | |
| 			'/profiles/:id/updates/reorder' => 'post',	// Array order, int offset, bool utc
 | |
| 			'/profiles/:id/updates/shuffle' => 'post',
 | |
| 			'/updates/create' => 'post',								// String text, Array profile_ids, Aool shorten, Bool now, Array media ['link'], ['description'], ['picture']
 | |
| 			'/updates/:id/update' => 'post',						// String text, Bool now, Array media ['link'], ['description'], ['picture'], Bool utc
 | |
| 			'/updates/:id/share' => 'post',
 | |
| 			'/updates/:id/destroy' => 'post',
 | |
| 			'/updates/:id/move_to_top' => 'post',
 | |
| 
 | |
| 			'/links/shares' => 'get',
 | |
| 
 | |
| 			'/info/configuration' => 'get',
 | |
| 
 | |
| 		];
 | |
| 
 | |
| 		public $errors = [
 | |
| 			'invalid-endpoint' => 'The endpoint you supplied does not appear to be valid.',
 | |
| 
 | |
| 			'403' => 'Permission denied.',
 | |
| 			'404' => 'Endpoint not found.',
 | |
| 			'405' => 'Method not allowed.',
 | |
| 			'504' => 'Gateway timeout server response timeout.',
 | |
| 			'1000' => 'An unknown error occurred.',
 | |
| 			'1001' => 'Access token required.',
 | |
| 			'1002' => 'Not within application scope.',
 | |
| 			'1003' => 'Parameter not recognized.',
 | |
| 			'1004' => 'Required parameter missing.',
 | |
| 			'1005' => 'Unsupported response format.',
 | |
| 			'1006' => 'Parameter value not within bounds.',
 | |
| 			'1010' => 'Profile could not be found.',
 | |
| 			'1011' => 'No authorization to access profile.',
 | |
| 			'1012' => 'Profile did not save successfully.',
 | |
| 			'1013' => 'Profile schedule limit reached.',
 | |
| 			'1014' => 'Profile limit for user has been reached.',
 | |
| 			'1015' => 'Profile could not be destroyed.',
 | |
| 			'1016' => 'Profile buffer could not be emptied.',
 | |
| 			'1020' => 'Update could not be found.',
 | |
| 			'1021' => 'No authorization to access update.',
 | |
| 			'1022' => 'Update did not save successfully.',
 | |
| 			'1023' => 'Update limit for profile has been reached.',
 | |
| 			'1024' => 'Update limit for team profile has been reached.',
 | |
| 			'1025' => "Update was recently posted, can't post duplicate content.",
 | |
| 			'1026' => 'Update must be in error status to requeue.',
 | |
| 			'1027' => 'Update must be in buffer and not custom scheduled in order to move to top.',
 | |
| 			'1028' => 'Update soft limit for profile reached.',
 | |
| 			'1029' => 'Event type not supported.',
 | |
| 			'1030' => 'Media filetype not supported.',
 | |
| 			'1031' => 'Media filesize out of acceptable range.',
 | |
| 			'1032' => 'Unable to post image to LinkedIn group(s).',
 | |
| 			'1033' => 'Comments can only be posted to Facebook at this time.',
 | |
| 			'1034' => 'Cannot schedule updates in the past.',
 | |
| 			'1042' => 'User did not save successfully.',
 | |
| 			'1050' => 'Client could not be found.',
 | |
| 			'1051' => 'No authorization to access client.',
 | |
| 		];
 | |
| 
 | |
| 		function __construct($client_id = '', $client_secret = '', $callback_url = '', $access_token = '') {
 | |
| 			if ($client_id) $this->set_client_id($client_id);
 | |
| 			if ($client_secret) $this->set_client_secret($client_secret);
 | |
| 			if ($callback_url) $this->set_callback_url($callback_url);
 | |
| 			if ($access_token) $this->access_token = $access_token;
 | |
| 
 | |
| 			if (isset($_GET['code']) && $_GET['code']) {
 | |
| 				$this->code = $_GET['code'];
 | |
| 				$this->create_access_token_url();
 | |
| 			}
 | |
| 
 | |
| 			if (!$access_token)
 | |
| 				$this->retrieve_access_token();
 | |
| 		}
 | |
| 
 | |
| 		function go($endpoint = '', $data = '') {
 | |
| 			if (in_array($endpoint, array_keys($this->endpoints))) {
 | |
| 				$done_endpoint = $endpoint;
 | |
| 			} else {
 | |
| 				$ok = false;
 | |
| 
 | |
| 				foreach (array_keys($this->endpoints) as $done_endpoint) {
 | |
| 					if (preg_match('/' . preg_replace('/(\:\w+)/i', '(\w+)', str_replace('/', '\/', $done_endpoint)) . '/i', $endpoint, $match)) {
 | |
| 						$ok = true;
 | |
| 						break;
 | |
| 					}
 | |
| 				}
 | |
| 
 | |
| 				if (!$ok) return $this->error('invalid-endpoint');
 | |
| 			}
 | |
| 
 | |
| 			if (!$data || !is_array($data)) $data = [];
 | |
| 			$data['access_token'] = $this->access_token;
 | |
| 
 | |
| 			$method = $this->endpoints[$done_endpoint]; //get() or post()
 | |
| 			return $this->$method($this->buffer_url . $endpoint . '.json', $data);
 | |
| 		}
 | |
| 
 | |
| 		function store_access_token() {
 | |
| 			$_SESSION['oauth']['buffer']['access_token'] = $this->access_token;
 | |
| 		}
 | |
| 
 | |
| 		function retrieve_access_token() {
 | |
| 			$this->access_token = $_SESSION['oauth']['buffer']['access_token'];
 | |
| 
 | |
| 			if ($this->access_token) {
 | |
| 				$this->ok = true;
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		function error($error) {
 | |
| 			return (object) ['error' => $this->errors[$error]];
 | |
| 		}
 | |
| 
 | |
| 		function create_access_token_url() {
 | |
| 			$data = [
 | |
| 				'code' => $this->code,
 | |
| 				'grant_type' => 'authorization_code',
 | |
| 				'client_id' => $this->client_id,
 | |
| 				'client_secret' => $this->client_secret,
 | |
| 				'redirect_uri' => $this->callback_url,
 | |
| 			];
 | |
| 
 | |
| 			$obj = $this->post($this->access_token_url, $data);
 | |
| 			$this->access_token = $obj->access_token;
 | |
| 
 | |
| 			$this->store_access_token();
 | |
| 		}
 | |
| 
 | |
| 		function req($url = '', $data = '', $post = true) {
 | |
| 			if (!$url) return false;
 | |
| 			if (!$data || !is_array($data)) $data = [];
 | |
| 
 | |
| 			$options = [CURLOPT_RETURNTRANSFER => true, CURLOPT_HEADER => false];
 | |
| 
 | |
| 			if ($post) {
 | |
| 				$options += [
 | |
| 					CURLOPT_POST => $post,
 | |
| 					CURLOPT_POSTFIELDS => $data
 | |
| 				];
 | |
| 			} else {
 | |
| 				$url .= '?' . http_build_query($data);
 | |
| 			}
 | |
| 
 | |
| 			$ch = curl_init($url);
 | |
| 			curl_setopt_array($ch, $options);
 | |
| 			$rs = curl_exec($ch);
 | |
| 
 | |
| 			$code = curl_getinfo($ch, CURLINFO_HTTP_CODE);
 | |
| 			if ($code >= 400) {
 | |
| 				return $this->error($code);
 | |
| 			}
 | |
| 
 | |
| 			return json_decode($rs);
 | |
| 		}
 | |
| 
 | |
| 		function get($url = '', $data = '') {
 | |
| 			return $this->req($url, $data, false);
 | |
| 		}
 | |
| 
 | |
| 		function post($url = '', $data = '') {
 | |
| 			return $this->req($url, $data, true);
 | |
| 		}
 | |
| 
 | |
| 		function get_login_url() {
 | |
| 			return $this->authorize_url . '?'
 | |
|     		. 'client_id=' . $this->client_id
 | |
|     		. '&redirect_uri=' . urlencode($this->callback_url)
 | |
|     		. '&response_type=code';
 | |
| 		}
 | |
| 
 | |
| 		function set_client_id($client_id) {
 | |
| 			$this->client_id = $client_id;
 | |
| 		}
 | |
| 
 | |
| 		function set_client_secret($client_secret) {
 | |
| 			$this->client_secret = $client_secret;
 | |
| 		}
 | |
| 
 | |
| 		function set_callback_url($callback_url) {
 | |
| 			$this->callback_url = $callback_url;
 | |
| 		}
 | |
| 	}
 | |
| ?>
 |