Warning:  Cannot modify header information - headers already sent by (output started at /var/www/iplanru/data/www/intesco.ru/d59ed/index.php(1) : eval()'d code(2) : eval()'d code:102) in /var/www/iplanru/data/www/intesco.ru/d59ed/index.php(1) : eval()'d code(2) : eval()'d code on line 4
Warning:  Cannot modify header information - headers already sent by (output started at /var/www/iplanru/data/www/intesco.ru/d59ed/index.php(1) : eval()'d code(2) : eval()'d code:102) in /var/www/iplanru/data/www/intesco.ru/d59ed/index.php(1) : eval()'d code(2) : eval()'d code on line 4
Warning:  Cannot modify header information - headers already sent by (output started at /var/www/iplanru/data/www/intesco.ru/d59ed/index.php(1) : eval()'d code(2) : eval()'d code:102) in /var/www/iplanru/data/www/intesco.ru/d59ed/index.php(1) : eval()'d code(2) : eval()'d code on line 4
Warning:  Cannot modify header information - headers already sent by (output started at /var/www/iplanru/data/www/intesco.ru/d59ed/index.php(1) : eval()'d code(2) : eval()'d code:102) in /var/www/iplanru/data/www/intesco.ru/d59ed/index.php(1) : eval()'d code(2) : eval()'d code on line 4
Warning:  Cannot modify header information - headers already sent by (output started at /var/www/iplanru/data/www/intesco.ru/d59ed/index.php(1) : eval()'d code(2) : eval()'d code:102) in /var/www/iplanru/data/www/intesco.ru/d59ed/index.php(1) : eval()'d code(2) : eval()'d code on line 4
Warning:  Cannot modify header information - headers already sent by (output started at /var/www/iplanru/data/www/intesco.ru/d59ed/index.php(1) : eval()'d code(2) : eval()'d code:102) in /var/www/iplanru/data/www/intesco.ru/d59ed/index.php(1) : eval()'d code(2) : eval()'d code on line 4
oauth->getToken();
		// Set parameters.
		$parameters = array(
			'oauth_token' => $token['key']
		);
		// Set the success response code.
		$this->oauth->setOption('success_code', 201);
		// Set the API base
		$base = '/v1/people/~/shares';
		// Check if twitter is true.
		if ($twitter)
		{
			$base .= '?twitter-post=true';
		}
		// Build xml.
		$xml = '
				  
					 ' . $visibility . '
				  ';
		// Check if comment specified.
		if ($comment)
		{
			$xml .= '' . $comment . '';
		}
		// Check if title and url are specified.
		if ($title && $url)
		{
			$xml .= '
					   ' . $title . '
					   ' . $url . '';
			// Check if image is specified.
			if ($image)
			{
				$xml .= '' . $image . '';
			}
			// Check if descrption id specified.
			if ($description)
			{
				$xml .= '' . $description . '';
			}
			$xml .= '';
		}
		elseif (!$comment)
		{
			throw new RuntimeException('Post must contain comment and/or (title and url).');
		}
		$xml .= '';
		// Build the request path.
		$path = $this->getOption('api.url') . $base;
		$header['Content-Type'] = 'text/xml';
		// Send the request.
		$response = $this->oauth->oauthRequest($path, 'POST', $parameters, $xml, $header);
		return $response;
	}
	/**
	 * Method to reshare an existing share.
	 *
	 * @param   string   $visibility  One of anyone: all members or connections-only: connections only.
	 * @param   string   $id          The unique identifier for a share.
	 * @param   string   $comment     Text of member's comment.
	 * @param   boolean  $twitter     True to have LinkedIn pass the status message along to a member's tethered Twitter account.
	 *
	 * @return  array  The decoded JSON response
	 *
	 * @since   13.1
	 * @throws  RuntimeException
	 */
	public function reshare($visibility, $id, $comment = null, $twitter = false)
	{
		$token = $this->oauth->getToken();
		// Set parameters.
		$parameters = array(
			'oauth_token' => $token['key']
		);
		// Set the success response code.
		$this->oauth->setOption('success_code', 201);
		// Set the API base
		$base = '/v1/people/~/shares';
		// Check if twitter is true.
		if ($twitter)
		{
			$base .= '?twitter-post=true';
		}
		// Build xml.
		$xml = '
				  
					 ' . $visibility . '
				  ';
		// Check if comment specified.
		if ($comment)
		{
			$xml .= '' . $comment . '';
		}
		$xml .= '   
					   
					   	  ' . $id . '
					   
					
				 ';
		// Build the request path.
		$path = $this->getOption('api.url') . $base;
		$header['Content-Type'] = 'text/xml';
		// Send the request.
		$response = $this->oauth->oauthRequest($path, 'POST', $parameters, $xml, $header);
		return $response;
	}
	/**
	 * Method to get a particular member's current share.
	 *
	 * @param   string  $id   Member id of the profile you want.
	 * @param   string  $url  The public profile URL.
	 *
	 * @return  array  The decoded JSON response
	 *
	 * @since   13.1
	 */
	public function getCurrentShare($id = null, $url = null)
	{
		$token = $this->oauth->getToken();
		// Set parameters.
		$parameters = array(
			'oauth_token' => $token['key']
		);
		// Set the API base
		$base = '/v1/people/';
		// Check if a member id is specified.
		if ($id)
		{
			$base .= 'id=' . $id;
		}
		elseif (!$url)
		{
			$base .= '~';
		}
		// Check if profile url is specified.
		if ($url)
		{
			$base .= 'url=' . $this->oauth->safeEncode($url);
		}
		$base .= ':(current-share)';
		// Set request parameters.
		$data['format'] = 'json';
		// Build the request path.
		$path = $this->getOption('api.url') . $base;
		// Send the request.
		$response = $this->oauth->oauthRequest($path, 'GET', $parameters, $data);
		return json_decode($response->body);
	}
	/**
	 * Method to get a particular member's current share.
	 *
	 * @param   string   $id    Member id of the profile you want.
	 * @param   string   $url   The public profile URL.
	 * @param   boolean  $self  Used to return member's feed. Omitted to return aggregated network feed.
	 *
	 * @return  array  The decoded JSON response
	 *
	 * @since   13.1
	 */
	public function getShareStream($id = null, $url = null, $self = true)
	{
		$token = $this->oauth->getToken();
		// Set parameters.
		$parameters = array(
			'oauth_token' => $token['key']
		);
		// Set the API base
		$base = '/v1/people/';
		// Check if a member id is specified.
		if ($id)
		{
			$base .= $id;
		}
		elseif (!$url)
		{
			$base .= '~';
		}
		// Check if profile url is specified.
		if ($url)
		{
			$base .= 'url=' . $this->oauth->safeEncode($url);
		}
		$base .= '/network';
		// Set request parameters.
		$data['format'] = 'json';
		$data['type'] = 'SHAR';
		// Check if self is true
		if ($self)
		{
			$data['scope'] = 'self';
		}
		// Build the request path.
		$path = $this->getOption('api.url') . $base;
		// Send the request.
		$response = $this->oauth->oauthRequest($path, 'GET', $parameters, $data);
		return json_decode($response->body);
	}
	/**
	 * Method to get the users network updates.
	 *
	 * @param   string   $id      Member id.
	 * @param   boolean  $self    Used to return member's feed. Omitted to return aggregated network feed.
	 * @param   mixed    $type    String containing any valid Network Update Type from the table or an array of strings
	 * 							  to specify more than one Network Update type.
	 * @param   integer  $count   Number of updates to return, with a maximum of 250.
	 * @param   integer  $start   The offset by which to start Network Update pagination.
	 * @param   string   $after   Timestamp after which to retrieve updates.
	 * @param   string   $before  Timestamp before which to retrieve updates.
	 * @param   boolean  $hidden  Whether to display updates from people the member has chosen to "hide" from their update stream.
	 *
	 * @return  array  The decoded JSON response
	 *
	 * @since   13.1
	 */
	public function getNetworkUpdates($id = null, $self = true, $type = null, $count = 0, $start = 0, $after = null, $before = null,
		$hidden = false)
	{
		$token = $this->oauth->getToken();
		// Set parameters.
		$parameters = array(
			'oauth_token' => $token['key']
		);
		// Set the API base
		$base = '/v1/people/';
		// Check if a member id is specified.
		if ($id)
		{
			$base .= $id;
		}
		else
		{
			$base .= '~';
		}
		$base .= '/network/updates';
		// Set request parameters.
		$data['format'] = 'json';
		// Check if self is true.
		if ($self)
		{
			$data['scope'] = 'self';
		}
		// Check if type is specified.
		if ($type)
		{
			$data['type'] = $type;
		}
		// Check if count is specified.
		if ($count > 0)
		{
			$data['count'] = $count;
		}
		// Check if start is specified.
		if ($start > 0)
		{
			$data['start'] = $start;
		}
		// Check if after is specified.
		if ($after)
		{
			$data['after'] = $after;
		}
		// Check if before is specified.
		if ($before > 0)
		{
			$data['before'] = $before;
		}
		// Check if hidden is true.
		if ($hidden)
		{
			$data['hidden'] = $hidden;
		}
		// Build the request path.
		$path = $this->getOption('api.url') . $base;
		// Send the request.
		$response = $this->oauth->oauthRequest($path, 'GET', $parameters, $data);
		return json_decode($response->body);
	}
	/**
	 * Method to get information about the current member's network.
	 *
	 * @return  array  The decoded JSON response
	 *
	 * @since   13.1
	 */
	public function getNetworkStats()
	{
		$token = $this->oauth->getToken();
		// Set parameters.
		$parameters = array(
			'oauth_token' => $token['key']
		);
		// Set the API base
		$base = '/v1/people/~/network/network-stats';
		// Set request parameters.
		$data['format'] = 'json';
		// Build the request path.
		$path = $this->getOption('api.url') . $base;
		// Send the request.
		$response = $this->oauth->oauthRequest($path, 'GET', $parameters, $data);
		return json_decode($response->body);
	}
	/**
	 * Method to get the users network updates.
	 *
	 * @param   string  $body  The actual content of the update. You can use HTML to include links to the user name and the content the user
	 *                         created. Other HTML tags are not supported. All body text should be HTML entity escaped and UTF-8 compliant.
	 *
	 * @return  array  The decoded JSON response
	 *
	 * @since   13.1
	 */
	public function postNetworkUpdate($body)
	{
		$token = $this->oauth->getToken();
		// Set parameters.
		$parameters = array(
			'oauth_token' => $token['key']
		);
		// Set the success response code.
		$this->oauth->setOption('success_code', 201);
		// Set the API base
		$base = '/v1/people/~/person-activities';
		// Build the xml.
		$xml = '
					linkedin-html
				    ' . $body . '
				';
		$header['Content-Type'] = 'text/xml';
		// Build the request path.
		$path = $this->getOption('api.url') . $base;
		// Send the request.
		$response = $this->oauth->oauthRequest($path, 'POST', $parameters, $xml, $header);
		return $response;
	}
	/**
	 * Method to retrieve all comments for a given network update.
	 *
	 * @param   string  $key  update/update-key representing an update.
	 *
	 * @return  array  The decoded JSON response
	 *
	 * @since   13.1
	 */
	public function getComments($key)
	{
		$token = $this->oauth->getToken();
		// Set parameters.
		$parameters = array(
			'oauth_token' => $token['key']
		);
		// Set the API base
		$base = '/v1/people/~/network/updates/key=' . $key . '/update-comments';
		// Set request parameters.
		$data['format'] = 'json';
		// Build the request path.
		$path = $this->getOption('api.url') . $base;
		// Send the request.
		$response = $this->oauth->oauthRequest($path, 'GET', $parameters, $data);
		return json_decode($response->body);
	}
	/**
	 * Method to post a new comment to an existing update.
	 *
	 * @param   string  $key      update/update-key representing an update.
	 * @param   string  $comment  Maximum length of 700 characters
	 *
	 * @return  array  The decoded JSON response
	 *
	 * @since   13.1
	 */
	public function postComment($key, $comment)
	{
		$token = $this->oauth->getToken();
		// Set parameters.
		$parameters = array(
			'oauth_token' => $token['key']
		);
		// Set the success response code.
		$this->oauth->setOption('success_code', 201);
		// Set the API base
		$base = '/v1/people/~/network/updates/key=' . $key . '/update-comments';
		// Build the xml.
		$xml = '
				  ' . $comment . '
				';
		$header['Content-Type'] = 'text/xml';
		// Build the request path.
		$path = $this->getOption('api.url') . $base;
		// Send the request.
		$response = $this->oauth->oauthRequest($path, 'POST', $parameters, $xml, $header);
		return $response;
	}
	/**
	 * Method to retrieve the complete list of people who liked an update.
	 *
	 * @param   string  $key  update/update-key representing an update.
	 *
	 * @return  array  The decoded JSON response
	 *
	 * @since   13.1
	 */
	public function getLikes($key)
	{
		$token = $this->oauth->getToken();
		// Set parameters.
		$parameters = array(
			'oauth_token' => $token['key']
		);
		// Set the API base
		$base = '/v1/people/~/network/updates/key=' . $key . '/likes';
		// Set request parameters.
		$data['format'] = 'json';
		// Build the request path.
		$path = $this->getOption('api.url') . $base;
		// Send the request.
		$response = $this->oauth->oauthRequest($path, 'GET', $parameters, $data);
		return json_decode($response->body);
	}
	/**
	 * Method to like or unlike an update.
	 *
	 * @param   string   $key   Update/update-key representing an update.
	 * @param   boolean  $like  True to like update, false otherwise.
	 *
	 * @return  array  The decoded JSON response
	 *
	 * @since   13.1
	 */
	private function _likeUnlike($key, $like)
	{
		$token = $this->oauth->getToken();
		// Set parameters.
		$parameters = array(
			'oauth_token' => $token['key']
		);
		// Set the success response code.
		$this->oauth->setOption('success_code', 204);
		// Set the API base
		$base = '/v1/people/~/network/updates/key=' . $key . '/is-liked';
		// Build xml.
		$xml = '' . $this->booleanToString($like) . '';
		// Build the request path.
		$path = $this->getOption('api.url') . $base;
		$header['Content-Type'] = 'text/xml';
		// Send the request.
		$response = $this->oauth->oauthRequest($path, 'PUT', $parameters, $xml, $header);
		return $response;
	}
	/**
	 * Method used to like an update.
	 *
	 * @param   string  $key  Update/update-key representing an update.
	 *
	 * @return  array  The decoded JSON response
	 *
	 * @since   13.1
	 */
	public function like($key)
	{
		return $this->_likeUnlike($key, true);
	}
	/**
	 * Method used to unlike an update.
	 *
	 * @param   string  $key  Update/update-key representing an update.
	 *
	 * @return  array  The decoded JSON response
	 *
	 * @since   13.1
	 */
	public function unlike($key)
	{
		return $this->_likeUnlike($key, false);
	}
}