%PDF- %PDF-
Mini Shell

Mini Shell

Direktori : /home/dopla/www/wp-content/plugins/kingcomposer/includes/frontend/helpers/
Upload File :
Create Path :
Current File : /home/dopla/www/wp-content/plugins/kingcomposer/includes/frontend/helpers/kc.ajax.php

<?php
/**
*
*	KC ajax front end
*	(c) KingComposer.com
*
*/

if(!defined('KC_FILE')) {
	header('HTTP/1.0 403 Forbidden');
	exit;
}

class kc_ajax_front{

	public function __construct(){

		$ajax_events = array(
			'instagrams_feed' 		=> true,
			'twitter_timeline' 		=> true,
			'facebook_recent_post' 	=> true
		);

		foreach ( $ajax_events as $ajax_event => $nopriv ) {

			add_action( 'wp_ajax_kc_' . $ajax_event, array( &$this, esc_attr( $ajax_event ) ) );

			if ( $nopriv ) {
				add_action( 'wp_ajax_nopriv_kc_' . $ajax_event, array( &$this, esc_attr( $ajax_event ) ) );
			}
		}
	}

	function facebook_recent_post(){
	
		global $kc;
		
		$output = $header_html = $fb_cover = '';

		if( !isset( $_POST['cfg'] ) || empty( $_POST['cfg'] ) ){

			wp_send_json( array(
				'html' => '',
				'header_data' => '',
				'message' => __('Fail', 'kingcomposer')
			));
			
			exit;
				
		}

		$atts = (array) json_decode( base64_decode( $_POST['cfg'] ) );
		
		$fb_app_id = $fb_page_id = $fb_app_secret = $number_post_show = '';
		
		extract( $atts );

		$fb_input_data = array(
			'fb_page_id' => $fb_page_id,
			'fb_app_id' => $kc->secrect_storage( $fb_app_id ),
			'fb_app_secret' => $kc->secrect_storage( $fb_app_secret ),
			'number_post_show' => $number_post_show
		);
        
		$fb_page_info = $this->get_facebook_page_feed( $fb_input_data, true );

		if(isset($fb_page_info->id)){
			if(isset($fb_page_info->cover->source)){
				$fb_cover = 'background-image: url('. $fb_page_info->cover->source. ');';
			}

			$header_html .= '<div class="fb-header" style="'. esc_attr($fb_cover) .'">
				<div class="overlay"></div>
				<div class="fb-line-1">
					<img class="img-profile" src="https://graph.facebook.com/'. $fb_page_id .'/picture?width=200" />
					<span class="username">'. $fb_page_info->username .'</span>
					<span class="likes">'. number_format( $fb_page_info->likes ) .' likes</span>
				</div>
				<div class="fb-line-2">
					<a class="like_page" href="'. $fb_page_info->link .'" target="_blank"><i class="fa fa-facebook-square"></i> Like page</a>
					<a class="share_page" href="http://www.facebook.com/sharer/sharer.php?u='. $fb_page_info->link .'" target="_blank"><i class="fa fa-share"></i> Share</a>
				</div>
			</div>';
		}else{
			$header_html .= __('Can not get page id', 'kingcomposer');
		}

		$fb_page_posts = $this->get_facebook_page_feed( $fb_input_data );

		if ( isset( $open_link_new_window ) && $open_link_new_window == 'yes' ) {
			$link_target = ' target="_blank"';
		} else {
			$link_target = '';
		}

		if($fb_page_posts){
			foreach($fb_page_posts as $data => $value){

				$fb_post_id = explode('_', $value->id);
				$post_id = $fb_post_id[1];

				$output .= '<li>';

				if( isset( $show_image ) && $show_image == 'yes' ){
					$a_end = '';
					if( isset( $value->link ) ){
						$output .= '<a href="'. esc_url($value->link) .'" '. $link_target .'>';
						$a_end = '</a>';
					}

					if ( isset( $value->name ) ){
						$alt = $value->name;
					}

					if( isset( $value->full_picture ) ){
						$output .= '<img src="'. esc_url( $value->full_picture ) .'" alt="'. $alt .'">';
					}

					$output .= $a_end;

				}

				if( isset( $value->message ) ){
					// remove emoji's
					$_message = preg_replace( '/[\x{1F600}-\x{1F64F}]|[\x{1F300}-\x{1F5FF}]|[\x{1F680}-\x{1F6FF}]|[\x{1F1E0}-\x{1F1FF}]/u', '', $value->message );
					$_message = sanitize_text_field( $_message ); // sanitize content

					if(!empty($number_of_des) && $number_of_des > 0){
						$_message = wp_trim_words( $_message, $number_of_des, $more = null );
					}

					$output .= '<div class="fb-message">'. $_message .'</div>';
				}

				if( !empty( $show_time ) || !empty( $show_like_count ) || !empty( $show_comment_count ) ){
					$output .= '<div class="fb-post-info">';
					$output .= '<a href="https://www.facebook.com/'. $fb_page_id .'/posts/'. $post_id .'" '. $link_target .'>';

					if( isset( $show_like_count ) && $show_like_count == 'yes' ){
						$output .= '<span class="fb-like"><i class="fa fa-thumbs-o-up"></i> '. ( isset( $value->likes->summary->total_count ) ? $value->likes->summary->total_count : 0) .'</span>';
					}

					if( isset( $show_comment_count ) && $show_comment_count == 'yes' ){
						$output .= '<span class="fb-comment"><i class="fa fa-comment-o"></i> '. ( isset( $value->comments->summary->total_count ) ? $value->comments->summary->total_count : 0) .'</span>';
					}

					if( isset( $show_time ) && $show_time == 'yes' ){
						$_time = strtotime( $value->created_time );
						$output .= '<span class="fb-time">'. $this->time_ago( $_time ) .'</span>';
					}

					$output .= '</a>';
					$output .= '</div>';
				}

				$output .= '</li>';
			}
		}else{
			$output .= __('Warning: Fill correct facebook infomation to show new feed.', 'kingcomposer');
		}

		$data = array(
			'html' => $output,
			'header_html' => $header_html,
			'message' => __('ok', 'kingcomposer')
		);

		wp_send_json( $data );
	}


	function get_facebook_page_feed( $args = array(), $only_info = false ) {
		
		global $kc; 
		
		$defaults = array(
			'fb_page_id' => 'wordpress',
			'number_post_show' => 10
		);

		$args = wp_parse_args( $args, $defaults );

		$fb_page_id 		= $args['fb_page_id'];
		$fb_app_id 			= !empty( $args['fb_app_id'] ) ?  $args['fb_app_id'] : '301439076655535';
		$fb_app_secret 		= !empty( $args['fb_app_secret'] ) ? $args['fb_app_secret'] : 'afddd33dc09cb364c79e8f0a46e7dff6';
		$number_post_show 	= $args['number_post_show'];

		if ( isset( $fb_page_id ) && isset( $fb_app_id ) && isset( $fb_app_secret ) && isset( $number_post_show ) ) {

			$facebook_page_info_url = 'https://graph.facebook.com/'. $fb_page_id .'/?access_token='. $fb_app_id .'|'. $fb_app_secret;

			$facebook_api_url = 'https://graph.facebook.com/' . $fb_page_id . '/posts?&access_token=' . $fb_app_id . '|' . $fb_app_secret . '&fields=id,picture,full_picture,actions,type,from,message,status_type,object_id,name,caption,description,link,created_time,comments.limit(1).summary(true),likes.limit(1).summary(true)&limit=' . $number_post_show;

			if($only_info == true){
				$result_data = json_decode( $this->file_get_contents( $facebook_page_info_url ) );
			}else{
				$facebook_data = json_decode( $this->file_get_contents( $facebook_api_url ) );
				if( isset( $facebook_data ) && isset( $facebook_data->data ) )
					$result_data = $facebook_data->data;
			}

			if ( isset( $result_data ) ) {
				return $result_data;
			} else {
				return '';
			}
		} else {
			return '';
		}
	}


	function instagrams_feed(){
        global $kc;
        
		$html = '';
		$count = 1;

		if( !isset( $_POST['cfg'] ) || empty( $_POST['cfg'] ) ){

			wp_send_json( array(
				'html' => '',
				'header_data' => '',
				'message' => __('Fail', 'kingcomposer')
			));
			
			exit;
				
		}

		$atts = (array) json_decode( base64_decode( $_POST['cfg'] ) );
		
		$access_token = $username = '';
		
		extract( $atts );
      
		$access_token = $kc->secrect_storage( $access_token );

		$ins_feed_data = $this->get_instagrams_feed( $username, $access_token );

		if($ins_feed_data)
		{
			foreach ( $ins_feed_data as $key => $value )
			{
				switch ($count%$columns_style) {
					case '1':
						$li_class = 'el-start';
						break;
					case '0':
						$li_class = 'el-end';
						break;
					default:
						$li_class = '';
						break;
				}

				$html 	.= '<li class="'. esc_attr($li_class) .' loaded">'
						.'<a href="'. esc_url( $value->link ) .'" target="_blank">'
						.'<img src="'. esc_url( $value->images->$image_size->url ) .'" />'
						.'</a></li>';

				if($count >= $number_show){
					break;
				}

				$count++;
			}
		}else{
			$html .= __('Warning: Fill correct instagram infomation to show new feed.', 'kingcomposer');
		}

		$data = array(
			'html' => $html,
			'message' => __('ok', 'kingcomposer')
		);

		wp_send_json( $data );
	}

	/*
	 * twitter_timeline
	 * Add this function to wp_ajax_kc_twitter_timeline hook
	 * Get new tweets update from user
	 */
	function twitter_timeline() {

		global $kc;
		
		if( !isset( $_POST['cfg'] ) || empty( $_POST['cfg'] ) ){

			wp_send_json( array(
				'html' => '',
				'header_data' => '',
				'message' => __('Fail', 'kingcomposer')
			));
			
			exit;
				
		}

		$atts = (array) json_decode( base64_decode( $_POST['cfg'] ) );

		extract( $atts );

		$output = $css_class = $rand_class = '';
		$display_style = (!empty($display_style)) ? $display_style : 1;
		$twitter_feed_data = array();

		$consumer_key = !empty($consumer_key) ? $kc->secrect_storage( $consumer_key ) : 'tHWsp0yQQioooQZJfXJdGP3d4';
		$consumer_secret = !empty($consumer_secret) ? $kc->secrect_storage( $consumer_secret ) : 'bl1kN9xH6nf167d0SJXnv9V5ZXuGXSShr5CeimLXaIGcUEQnsp';
		$access_token = !empty($access_token) ? $kc->secrect_storage( $access_token ) : '120290116-vmLx4sPp5O3hjhRxjpl28i0APJkCpg04YVsoZyb7';
		$access_token_secrect = !empty($access_token_secrect) ? $kc->secrect_storage( $access_token_secrect ) : 'B9mAhgZhQG0cspt1doF2cxDky40OEatjftRI5NCmQh1pE';

		$number_tweet = (!empty( $number_tweet )) ? $number_tweet : 5;

		switch ($display_style) {
			case '1':
				$el_in_start = '<ul>';
				$el_in_end = '</ul>';
				$el_item_start = '<li>';
				$el_item_end = '</li>';
				break;

			case '2':
				$el_in_start = '<div class="kc-tweet-owl owl-carousel owl-theme">';
				$el_in_end = '</div>';
				$el_item_start = '<div class="item">';
				$el_item_end = '</div>';
				break;

			default:
				# code...
				break;
		}

		if (
			isset( $username )
			&& isset( $consumer_key )
			&& isset( $consumer_secret )
			&& isset( $access_token )
			&& isset( $access_token_secrect )
			&& isset( $number_tweet )
		){
			$twitter_feed_data = $this->get_tweets_feed_data(
				$consumer_key,
				$consumer_secret,
				$access_token,
				$access_token_secrect,
				$number_tweet,
				$username
			);

			$header_data = '';

			if( isset( $show_follow_button ) && $show_follow_button == 'yes' && $display_style == 1  ){
				$header_data .= '<div class="tweet_user user_twitter">
				<img src="https://twitter.com/' . esc_attr( $username ) . '/profile_image?size=normal" class="twitter_profile_avatar"/>
				<a class="kc_twitter_follow" href="https://twitter.com/intent/user?screen_name='. esc_attr( $username ) .'" target="_blank"><i class="fa fa-twitter"></i>Follow Us</a>
				<span class="screen_name">@'. esc_html( $username ). '</span>
				</div>';
			}

			if(isset($twitter_feed_data)){
				$output .= $el_in_start;

				foreach($twitter_feed_data as $tweet){
					if( empty( $tweet['text'] ) )
						continue;
					$latestTweet = $tweet['text'];
					//Convert plain text URLs into HTML hyperlinks
					$latestTweet = preg_replace('@(https?://([-\w\.]+[-\w])+(:\d+)?(/([\w/_\.#-]*(\?\S+)?[^\.\s])?)?)@', '<a href="$1" target="_blank">$1</a>', $latestTweet);

					//Convert @username twiter to link clickable
					$latestTweet = preg_replace('/(^|\s)@([a-z0-9_]+)/i', '&nbsp;<a href="http://twitter.com/$2" target="_blank">@$2</a>&nbsp;', $latestTweet);

					//Automatically create email link from a static text
					$latestTweet = preg_replace('/(\S+@\S+\.\S+)/', '&nbsp;<a href="mailto:$1">$1</a>&nbsp;', $latestTweet);

					$twitterTime = strtotime( $tweet['created_at'] );
					$timeAgo 	 = $this->time_ago( $twitterTime );

					$output .= $el_item_start;
						if(!empty( $latestTweet )){
							$avatar = '';
							$has_avatar = '';
							if ( isset( $show_avatar ) && $show_avatar == 'yes' ){
								//$avatar = '<span class="kc_tweet_icon"><i class="fa fa-twitter"></i></span>';
								if(isset($tweet['user']['profile_image_url'])){
									$avatar = '<span class="user_twitter"><img src="'. esc_url($tweet['user']['profile_image_url']) .'" /></span>';
									$has_avatar = ' show_avatar';
								}

							}
							if($display_style == 1){
								$output .= '<div class="tweet_desc' . $has_avatar . '">'. $avatar. '
								<span class="name">'. esc_html($tweet['user']['name']) .'</span>
								<span class="screen_name">@'. esc_html($tweet['user']['screen_name']) .'</span>
								<span class="description">' . $latestTweet . '</span></div>';
							}else {
								$output .= '<div class="tweet_desc">
								<span class="description">' . $latestTweet . '</span></div>';
							}


						}

						$output .= '<div class="twitter-footer' . $has_avatar . '">';

						if( isset( $show_time ) && $show_time == 'yes' ){
							$output .= '<span class="tweet_date">'. $timeAgo .'</span>';
						}

						if( isset( $show_reply ) && $show_reply == 'yes' ){
							$output .= '<span class="tweet_reply"><a href="https://twitter.com/intent/tweet?in_reply_to='. esc_attr( $tweet['id_str'] ) .'" title="Reply"><i class="fa fa-reply"></i></a></span>';
						}

						if( isset( $show_retweet ) && $show_retweet == 'yes' ){
							$output .= '<span class="tweet_retweet"><a href="https://twitter.com/intent/retweet?tweet_id='. esc_attr( $tweet['id_str'] ) .'" title="Retweet"><i class="fa fa-retweet"></i></a></span>';
						}

						$output .= '</div>';

					$output .= $el_item_end;
				}

				$output .= $el_in_end;
				if( isset( $show_follow_button ) && $show_follow_button == 'yes' && $display_style == 2  ){
					$output .= '<div class="tweet_user user_twitter">
					<a class="kc_twitter_follow" href="https://twitter.com/intent/user?screen_name='. esc_attr( $username ) .'" target="_blank"><i class="fa fa-twitter"></i>Follow Us</a>
					</div>';
				}
			}

		}

		$data = array(
			'html' => $output,
			'header_data' => $header_data,
			'message' => __('Ok', 'kingcomposer')
		);

		wp_send_json( $data );
	}


	/*
	 * get_tweets_feed_data
	 * @ $consumer_key
	 * @ $consumer_secret
	 * @ $access_token
	 * @ $access_token_secret
	 * @ $number_tweet
	 * @ $username
	 * Get new tweets update from user
	 */
	function get_tweets_feed_data( $consumer_key, $consumer_secret, $access_token, $access_token_secret, $number_tweet, $username ) {
		$rd_twitter = kc_random_string( 20 );
		$trans_name = 'list_tweets_'.$rd_twitter;
		$twitter_cache_time = 10;

		if(false === ($twitter_twitter_data = get_transient($trans_name))) {

			$twitter_token = get_option('cfTwitterToken_'.$rd_twitter);

			// get a new token anyways
			delete_option('cfTwitterToken_'.$rd_twitter);

			// getting new auth bearer only if we don't have one
			if(!$twitter_token) {
				// preparing credentials
				$twitter_credentials = $consumer_key . ':' . $consumer_secret;
				$twitter_to_send = base64_encode( $twitter_credentials );

				// http post arguments
				$twitter_args = array(
					'method' => 'POST',
					'httpversion' => '1.1',
					'blocking' => true,
					'headers' => array(
						'Authorization' => 'Basic ' . $twitter_to_send,
						'Content-Type' => 'application/x-www-form-urlencoded;charset=UTF-8'
					),
					'body' => array( 'grant_type' => 'client_credentials' )
				);

				add_filter('https_ssl_verify', '__return_false');
				$twitter_response = wp_remote_post('https://api.twitter.com/oauth2/token', $twitter_args);

				$twitter_keys = json_decode(wp_remote_retrieve_body($twitter_response));

				if($twitter_keys) {
					// saving token to wp_options table
					update_option('cfTwitterToken_'.$rd_twitter, $twitter_keys->access_token);
					$twitter_token = $twitter_keys->access_token;
				}
			}

			// we have bearer token wether we obtained it from API or from options
			$twitter_args = array(
				'httpversion' => '1.1',
				'blocking' => true,
				'headers' => array(
					'Authorization' => "Bearer ".$twitter_token
				)
			);

			add_filter('https_ssl_verify', '__return_false');
			$twitter_api_url = 'https://api.twitter.com/1.1/statuses/user_timeline.json?screen_name='.$username.'&count='.$number_tweet;
			$twitter_response = wp_remote_get($twitter_api_url, $twitter_args);

			set_transient($trans_name, wp_remote_retrieve_body($twitter_response), 60 * $twitter_cache_time);
		}
		@$twitter_feed_data = json_decode(get_transient($trans_name), true);

		return $twitter_feed_data;
	}

	function time_ago($time) {
		$periods = array(
			__( 'second', 'kingcomposer' ),
			__( 'minute', 'kingcomposer' ),
			__( 'hour', 'kingcomposer' ),
			__( 'day', 'kingcomposer' ),
			__( 'week', 'kingcomposer' ),
			__( 'month', 'kingcomposer' ),
			__( 'year', 'kingcomposer' ),
			__( 'decade', 'kingcomposer' )
		);

		$periods_plural = array(
			__( 'seconds', 'kingcomposer' ),
			__( 'minutes', 'kingcomposer' ),
			__( 'hours', 'kingcomposer' ),
			__( 'days', 'kingcomposer' ),
			__( 'weeks', 'kingcomposer' ),
			__( 'months', 'kingcomposer' ),
			__( 'years', 'kingcomposer' ),
			__( 'decades', 'kingcomposer' )
		);

		$lengths = array( '60', '60', '24', '7', '4.35', '12', '10' );
		$now = time();
		$difference = $now - $time;
		$tense = __( 'ago', 'kingcomposer' );

		for( $j = 0; $difference >= $lengths[$j] && $j < count( $lengths )-1; $j++ ) {
			$difference /= $lengths[$j];
		}

		$difference = round( $difference );

		if( $difference != 1 ) {
			$periods[$j] = $periods_plural[$j];
		}

		return sprintf('%s %s %s', $difference, $periods[$j], $tense);
	}

	function get_instagrams_feed( $username, $access_token ) {
		
		
        $ins_url = 'https://api.instagram.com/v1/users/self/?access_token=' . $access_token;

        $ins_ch = curl_init();
        curl_setopt($ins_ch, CURLOPT_URL, $ins_url);
        curl_setopt($ins_ch, CURLOPT_RETURNTRANSFER, 1);
        curl_setopt($ins_ch, CURLOPT_TIMEOUT, 20);
        curl_setopt($ins_ch, CURLOPT_SSL_VERIFYPEER, true);
        curl_setopt($ins_ch, CURLOPT_SSL_VERIFYHOST, 2);
        curl_setopt($ins_ch, CURLOPT_CAINFO, KC_PATH . KDS . "includes/frontend/helpers/DigiCertHighAssuranceEVRootCA.cer");

        curl_setopt($ins_ch, CURLOPT_FOLLOWLOCATION, 3);
        $ins_json_data = curl_exec($ins_ch);
        $ins_json_data = json_decode($ins_json_data);

        if (isset($ins_json_data->data->username) && ($ins_json_data->data->username == strtolower($username))) {
            $ins_user_id = $ins_json_data->data->id;
        } else {
            $ins_user_id = 0;
        }

        if ($ins_user_id) {
			$ins_api_url = 'https://api.instagram.com/v1/users/' . $ins_user_id . '/media/recent?access_token=' . $access_token;

			$ins_ch = curl_init();
			curl_setopt($ins_ch, CURLOPT_URL, $ins_api_url);
			curl_setopt($ins_ch, CURLOPT_RETURNTRANSFER, 1);
			curl_setopt($ins_ch, CURLOPT_TIMEOUT, 20);
			curl_setopt($ins_ch, CURLOPT_SSL_VERIFYPEER, true);
            curl_setopt($ins_ch, CURLOPT_SSL_VERIFYHOST, 2);
            curl_setopt($ins_ch, CURLOPT_CAINFO, KC_PATH. KDS . "includes/frontend/helpers/DigiCertHighAssuranceEVRootCA.cer");
            curl_setopt($ins_ch, CURLOPT_FOLLOWLOCATION, 3);
			$ins_data = curl_exec($ins_ch);
			curl_close($ins_ch);

			$ins_data = json_decode($ins_data);
			return $ins_data->data;
		} else {
			return 0;
		}
	}

	function get_instagram_user_id($username, $access_token) {
        $ins_url = 'https://api.instagram.com/v1/users/self/?access_token=' . $access_token;

        $ins_ch = curl_init();
        curl_setopt($ins_ch, CURLOPT_URL, $ins_url);
        curl_setopt($ins_ch, CURLOPT_RETURNTRANSFER, 1);
        curl_setopt($ins_ch, CURLOPT_TIMEOUT, 20);
        curl_setopt($ins_ch, CURLOPT_SSL_VERIFYPEER, true);
        curl_setopt($ins_ch, CURLOPT_SSL_VERIFYHOST, 2);
        curl_setopt($ins_ch, CURLOPT_CAINFO, KC_PATH. DS . "includes/frontend/helpers/DigiCertHighAssuranceEVRootCA.cer");

        curl_setopt($ins_ch, CURLOPT_FOLLOWLOCATION, 3);
        $ins_json_data = curl_exec($ins_ch);
        $ins_json_data = json_decode($ins_json_data);

        if (isset($ins_json_data->data->username) && ($ins_json_data->data->username == $username)) {
            return $ins_json_data->data->id;
        } else {
            return 0;
        }
    }

    function file_get_contents( $url ){
		$url_ch = curl_init();
		curl_setopt( $url_ch, CURLOPT_URL, $url );
		curl_setopt( $url_ch, CURLOPT_RETURNTRANSFER, 1 );
		curl_setopt( $url_ch, CURLOPT_TIMEOUT, 20 );
		curl_setopt( $url_ch, CURLOPT_SSL_VERIFYPEER, false );
		curl_setopt( $url_ch, CURLOPT_SSL_VERIFYHOST, false );
		$_return = curl_exec( $url_ch );
		curl_close( $url_ch );

		return $_return;
	}

}

#Start kc_ajax_front
new kc_ajax_front();

Zerion Mini Shell 1.0