aboutsummaryrefslogblamecommitdiffstats
path: root/Zotlabs/Module/Rate.php
blob: d29c370fc1b16f85ad8f0c6e2484ad4f9911aebc (plain) (tree)
1
2
3
4
5
6
7
8
9
10



                         
                       

                                            
 
                                     
 
                                               
 

                                              
 
                                                
 
















                                                                                                        
 
                       
 
         
 
                         
 
                                     
 
                                           
 
                                          
 
                                               
 



                                                   
 
                                                                           
 
                                                                                     

                                                                                          


                                                                                                                         
 

























                                                                                                                                                                                                        
 
                             
                                                                                            
                 
 
         
 
                        
 


                                                               
 


                                                           
 
                                                                        

                                                                     
 
                                               
 



                                                                                                                 
                                                     





                                                                  
 
                                     






                                                                                                
 












                                                                                                                                                                                                                   
 
                          
 
         
<?php
namespace Zotlabs\Module;



use Zotlabs\Lib\Crypto;

class Rate extends \Zotlabs\Web\Controller {

	function init() {

		if(! local_channel())
			return;

		$channel = \App::get_channel();

		$target = $_REQUEST['target'];
		if(! $target)
			return;

		\App::$data['target'] = $target;

		if($target) {
			$r = q("SELECT * FROM xchan where xchan_hash like '%s' LIMIT 1",
				dbesc($target)
			);
			if($r) {
				\App::$poi = $r[0];
			}
			else {
				$r = q("select * from site where site_url like '%s' and site_type = %d",
					dbesc('%' . $target),
					intval(SITE_TYPE_ZOT)
				);
				if($r) {
					\App::$data['site'] = $r[0];
					\App::$data['site']['site_url'] = strtolower($r[0]['site_url']);
				}
			}
		}


		return;

	}


	function post() {

		if(! local_channel())
			return;

		if(! \App::$data['target'])
			return;

		if(! $_REQUEST['execute'])
			return;

		$channel = \App::get_channel();

		$rating = intval($_POST['rating']);
		if($rating < (-10))
			$rating = (-10);
		if($rating > 10)
			$rating = 10;

		$rating_text = trim(escape_tags($_REQUEST['rating_text']));

		$signed = \App::$data['target'] . '.' . $rating . '.' . $rating_text;

		$sig = base64url_encode(Crypto::sign($signed,$channel['channel_prvkey']));

		$z = q("select * from xlink where xlink_xchan = '%s' and xlink_link = '%s' and xlink_static = 1 limit 1",
			dbesc($channel['channel_hash']),
			dbesc(\App::$data['target'])
		);

		if($z) {
			$record = $z[0]['xlink_id'];
			$w = q("update xlink set xlink_rating = '%d', xlink_rating_text = '%s', xlink_sig = '%s', xlink_updated = '%s'
				where xlink_id = %d",
				intval($rating),
				dbesc($rating_text),
				dbesc($sig),
				dbesc(datetime_convert()),
				intval($record)
			);
		}
		else {
			$w = q("insert into xlink ( xlink_xchan, xlink_link, xlink_rating, xlink_rating_text, xlink_sig, xlink_updated, xlink_static ) values ( '%s', '%s', %d, '%s', '%s', '%s', 1 ) ",
				dbesc($channel['channel_hash']),
				dbesc(\App::$data['target']),
				intval($rating),
				dbesc($rating_text),
				dbesc($sig),
				dbesc(datetime_convert())
			);
			$z = q("select * from xlink where xlink_xchan = '%s' and xlink_link = '%s' and xlink_static = 1 limit 1",
				dbesc($channel['channel_hash']),
				dbesc(\App::$data['target'])
			);
			if($z)
				$record = $z[0]['xlink_id'];
		}

		if($record) {
			\Zotlabs\Daemon\Master::Summon(array('Ratenotif','rating',$record));
		}

	}

	function get() {

		if(! local_channel()) {
			notice( t('Permission denied.') . EOL);
			return;
		}

	//	if(! \App::$data['target']) {
	//		notice( t('No recipients.') . EOL);
	//		return;
	//	}

		$rating_enabled = get_config('system','rating_enabled');
		if(! $rating_enabled) {
			notice('Ratings are disabled on this site.');
			return;
		}

		$channel = \App::get_channel();

		$r = q("select * from xlink where xlink_xchan = '%s' and xlink_link = '%s' and xlink_static = 1",
			dbesc($channel['channel_hash']),
			dbesc(\App::$data['target'])
		);
		if($r) {
			\App::$data['xlink'] = $r[0];
			$rating_val = $r[0]['xlink_rating'];
			$rating_text = $r[0]['xlink_rating_text'];
		}
		else {
			$rating_val = 0;
			$rating_text = '';
		}

		if($rating_enabled) {
			$rating = replace_macros(get_markup_template('rating_slider.tpl'),array(
				'$min' => -10,
				'$val' => $rating_val
			));
		}
		else {
			$rating = false;
		}

		$o = replace_macros(get_markup_template('rating_form.tpl'),array(
			'$header' => t('Rating'),
			'$website' => t('Website:'),
			'$site' => ((\App::$data['site']) ? '<a href="' . \App::$data['site']['site_url'] . '" >' . \App::$data['site']['site_url'] . '</a>' : ''),
			'target' => \App::$data['target'],
			'$tgt_name' => ((\App::$poi && \App::$poi['xchan_name']) ? \App::$poi['xchan_name'] : sprintf( t('Remote Channel [%s] (not yet known on this site)'), substr(\App::$data['target'],0,16))),
			'$lbl_rating'     => t('Rating (this information is public)'),
			'$lbl_rating_txt' => t('Optionally explain your rating (this information is public)'),
			'$rating_txt'     => $rating_text,
			'$rating'         => $rating,
			'$rating_val'     => $rating_val,
			'$slide'          => $slide,
			'$submit' => t('Submit')
		));

		return $o;

	}
}