Merge branch 'master' into tres
Conflicts: view/css/mod_events.css view/theme/redbasic/css/style.css
This commit is contained in:
		
							
								
								
									
										7
									
								
								boot.php
									
									
									
									
									
								
							
							
						
						
									
										7
									
								
								boot.php
									
									
									
									
									
								
							| @@ -2154,6 +2154,13 @@ function get_directory_realm() { | ||||
|  * @return string | ||||
|  */ | ||||
| function get_directory_primary() { | ||||
|  | ||||
|    $dirmode = intval(get_config('system','directory_mode')); | ||||
|  | ||||
|     if($dirmode == DIRECTORY_MODE_STANDALONE || $dirmode == DIRECTORY_MODE_PRIMARY) { | ||||
| 		return z_root(); | ||||
|     } | ||||
|  | ||||
| 	if($x = get_config('system', 'directory_primary')) | ||||
| 		return $x; | ||||
|  | ||||
|   | ||||
| @@ -970,6 +970,30 @@ function file_activity($channel_id, $object, $allow_cid, $allow_gid, $deny_cid, | ||||
|  | ||||
| 	$poster = get_app()->get_observer(); | ||||
|  | ||||
| 	//if we got no object something went wrong | ||||
| 	if(!$object) | ||||
| 		return; | ||||
|  | ||||
| 	$is_dir = (($object['flags'] & ATTACH_FLAG_DIR) ? true : false); | ||||
|  | ||||
| 	//do not send activity for folders for now | ||||
| 	if($is_dir) | ||||
| 		return; | ||||
|  | ||||
| 	//check for recursive perms if we are in a folder | ||||
| 	if($object['folder']) { | ||||
|  | ||||
| 		$folder_hash = $object['folder']; | ||||
|  | ||||
| 		$r_perms = recursive_activity_recipients($allow_cid, $allow_gid, $deny_cid, $deny_gid, $folder_hash); | ||||
|  | ||||
| 		$allow_cid = perms2str($r_perms['allow_cid']); | ||||
| 		$allow_gid = perms2str($r_perms['allow_gid']); | ||||
| 		$deny_cid = perms2str($r_perms['deny_cid']); | ||||
| 		$deny_gid = perms2str($r_perms['deny_gid']); | ||||
|  | ||||
| 	} | ||||
|  | ||||
| 	$mid = item_message_id(); | ||||
|  | ||||
| 	$arr = array(); | ||||
| @@ -1124,7 +1148,132 @@ function get_file_activity_object($channel_id, $hash, $cloudpath) { | ||||
| 		'created'	=> $x[0]['created'], | ||||
| 		'edited'	=> $x[0]['edited'] | ||||
| 	); | ||||
|  | ||||
| 	return $object; | ||||
|  | ||||
| } | ||||
|  | ||||
| function recursive_activity_recipients($allow_cid, $allow_gid, $deny_cid, $deny_gid, $folder_hash) { | ||||
|  | ||||
| 	$poster = get_app()->get_observer(); | ||||
|  | ||||
| 	$arr_allow_cid = expand_acl($allow_cid); | ||||
| 	$arr_allow_gid = expand_acl($allow_gid); | ||||
| 	$arr_deny_cid = expand_acl($deny_cid); | ||||
| 	$arr_deny_gid = expand_acl($deny_gid); | ||||
|  | ||||
| 	$count = 0; | ||||
| 	while($folder_hash) { | ||||
| 		$x = q("SELECT allow_cid, allow_gid, deny_cid, deny_gid, folder FROM attach WHERE hash = '%s' LIMIT 1", | ||||
| 			dbesc($folder_hash) | ||||
| 		); | ||||
|  | ||||
| 		//only process private folders | ||||
| 		if($x[0]['allow_cid'] || $x[0]['allow_gid'] || $x[0]['deny_cid'] || $x[0]['deny_gid']) { | ||||
|  | ||||
| 			$parent_arr['allow_cid'][] = expand_acl($x[0]['allow_cid']); | ||||
| 			$parent_arr['allow_gid'][] = expand_acl($x[0]['allow_gid']); | ||||
|  | ||||
| 			//TODO: should find a much better solution for the allow_cid <-> allow_gid problem. | ||||
| 			//Do not use allow_gid for now. Instead lookup the members of the group directly and add them to allow_cid. | ||||
| 			if($parent_arr['allow_gid']) { | ||||
| 				foreach($parent_arr['allow_gid'][$count] as $gid) { | ||||
| 					$in_group = in_group($gid); | ||||
| 					$parent_arr['allow_cid'][$count] = array_unique(array_merge($parent_arr['allow_cid'][$count], $in_group)); | ||||
| 				} | ||||
| 			} | ||||
|  | ||||
| 			$parent_arr['deny_cid'][] = expand_acl($x[0]['deny_cid']); | ||||
| 			$parent_arr['deny_gid'][] = expand_acl($x[0]['deny_gid']); | ||||
|  | ||||
| 			$count++; | ||||
|  | ||||
| 		} | ||||
|  | ||||
| 		$folder_hash = $x[0]['folder']; | ||||
|  | ||||
| 	} | ||||
|  | ||||
| 	//if none of the parent folders is private just return file perms | ||||
| 	if(!$parent_arr['allow_cid'] && !$parent_arr['allow_gid'] && !$parent_arr['deny_cid'] && !$parent_arr['deny_gid']) { | ||||
| 		$ret['allow_gid'] = $arr_allow_gid; | ||||
| 		$ret['allow_cid'] = $arr_allow_cid; | ||||
| 		$ret['deny_gid'] = $arr_deny_gid; | ||||
| 		$ret['deny_cid'] = $arr_deny_cid; | ||||
|  | ||||
| 		return $ret; | ||||
| 	} | ||||
|  | ||||
| 	//if there are no perms on the file we get them from the first parent folder | ||||
| 	if(!$arr_allow_cid && !$arr_allow_gid && !$arr_deny_cid && !$arr_deny_gid) { | ||||
| 		$arr_allow_cid = $parent_arr['allow_cid'][0]; | ||||
| 		$arr_allow_gid = $parent_arr['allow_gid'][0]; | ||||
| 		$arr_deny_cid = $parent_arr['deny_cid'][0]; | ||||
| 		$arr_deny_gid = $parent_arr['deny_gid'][0]; | ||||
| 	} | ||||
|  | ||||
| 	//allow_cid | ||||
| 	$r_arr_allow_cid = false; | ||||
| 	foreach ($parent_arr['allow_cid'] as $folder_arr_allow_cid) { | ||||
| 		foreach ($folder_arr_allow_cid as $ac_hash) { | ||||
| 			$count_values[$ac_hash]++; | ||||
| 		} | ||||
| 	} | ||||
| 	foreach ($arr_allow_cid as $fac_hash) { | ||||
| 		if($count_values[$fac_hash] == $count) | ||||
| 			$r_arr_allow_cid[] = $fac_hash; | ||||
| 	} | ||||
|  | ||||
| 	//allow_gid | ||||
| 	$r_arr_allow_gid = false; | ||||
| 	foreach ($parent_arr['allow_gid'] as $folder_arr_allow_gid) { | ||||
| 		foreach ($folder_arr_allow_gid as $ag_hash) { | ||||
| 			$count_values[$ag_hash]++; | ||||
| 		} | ||||
| 	} | ||||
| 	foreach ($arr_allow_gid as $fag_hash) { | ||||
| 		if($count_values[$fag_hash] == $count) | ||||
| 			$r_arr_allow_gid[] = $fag_hash; | ||||
| 	} | ||||
|  | ||||
| 	//deny_gid | ||||
| 	foreach($parent_arr['deny_gid'] as $folder_arr_deny_gid) { | ||||
| 		$r_arr_deny_gid = array_merge($arr_deny_gid, $folder_arr_deny_gid); | ||||
| 	} | ||||
| 	$r_arr_deny_gid = array_unique($r_arr_deny_gid); | ||||
|  | ||||
| 	//deny_cid | ||||
| 	foreach($parent_arr['deny_cid'] as $folder_arr_deny_cid) { | ||||
| 		$r_arr_deny_cid = array_merge($arr_deny_cid, $folder_arr_deny_cid); | ||||
| 	} | ||||
| 	$r_arr_deny_cid = array_unique($r_arr_deny_cid); | ||||
|  | ||||
| 	//if none is allowed restrict to self | ||||
| 	if(($r_arr_allow_gid === false) && ($r_arr_allow_cid === false)) { | ||||
| 		$ret['allow_cid'] = $poster['xchan_hash']; | ||||
| 	} else { | ||||
| 		$ret['allow_gid'] = $r_arr_allow_gid; | ||||
| 		$ret['allow_cid'] = $r_arr_allow_cid; | ||||
| 		$ret['deny_gid'] = $r_arr_deny_gid; | ||||
| 		$ret['deny_cid'] = $r_arr_deny_cid; | ||||
| 	} | ||||
|  | ||||
| 	return $ret; | ||||
|  | ||||
| } | ||||
|  | ||||
| function in_group($group_id) { | ||||
| 	//TODO: make these two queries one with a join. | ||||
| 	$x = q("SELECT id FROM groups WHERE hash = '%s'", | ||||
| 		dbesc($group_id) | ||||
| 	); | ||||
|  | ||||
| 	$r = q("SELECT xchan FROM group_member WHERE gid = %d", | ||||
| 		intval($x[0]['id']) | ||||
| 	); | ||||
|  | ||||
| 	foreach($r as $ig) { | ||||
| 		$group_members[] = $ig['xchan']; | ||||
| 	} | ||||
|  | ||||
| 	return $group_members; | ||||
| } | ||||
|   | ||||
| @@ -216,7 +216,7 @@ function bb_ShareAttributes($match) { | ||||
| 	$headline = '<div class="shared_container"> <div class="shared_header">'; | ||||
|  | ||||
| 	if ($avatar != "") | ||||
| 		$headline .= '<img src="' . $avatar . '" alt="' . $author . '" height="32" width="32" />'; | ||||
| 		$headline .= '<a href="' . zid($profile) . '" ><img src="' . $avatar . '" alt="' . $author . '" height="32" width="32" /></a>'; | ||||
|  | ||||
| 	// Bob Smith wrote the following post 2 hours ago | ||||
|  | ||||
|   | ||||
| @@ -610,10 +610,6 @@ function conversation(&$a, $items, $mode, $update, $page_mode = 'traditional', $ | ||||
| 					$profile_link = zid($profile_link); | ||||
|  | ||||
| 				$normalised = normalise_link((strlen($item['author-link'])) ? $item['author-link'] : $item['url']); | ||||
| 				if(x($a->contacts,$normalised)) | ||||
| 					$profile_avatar = $a->contacts[$normalised]['thumb']; | ||||
| 				else | ||||
| 					$profile_avatar = ((strlen($item['author-avatar'])) ? $a->get_cached_avatar_image($item['author-avatar']) : $item['thumb']); | ||||
|  | ||||
| 				$profile_name = $item['author']['xchan_name']; | ||||
| 				$profile_link = $item['author']['xchan_url']; | ||||
| @@ -1129,6 +1125,9 @@ function status_editor($a,$x,$popup=false) { | ||||
| 	if(x($x,'nopreview')) | ||||
| 		$preview = ''; | ||||
|  | ||||
| 	$defexpire = ((($z = get_pconfig($x['profile_uid'],'system','default_post_expire')) && (! $webpage)) ? $z : ''); | ||||
|  | ||||
|  | ||||
| 	$cipher = get_pconfig($x['profile_uid'],'system','default_cipher'); | ||||
| 	if(! $cipher) | ||||
| 		$cipher = 'aes256'; | ||||
| @@ -1186,7 +1185,7 @@ function status_editor($a,$x,$popup=false) { | ||||
| 		'$preview' => $preview, | ||||
| 		'$source' => ((x($x,'source')) ? $x['source'] : ''), | ||||
| 		'$jotplugins' => $jotplugins, | ||||
| 		'$defexpire' => '', | ||||
| 		'$defexpire' => $defexpire, | ||||
| 		'$feature_expire' => ((feature_enabled($x['profile_uid'],'content_expire') && (! $webpage)) ? true : false), | ||||
| 		'$expires' => t('Set expiration date'), | ||||
| 		'$feature_encrypt' => ((feature_enabled($x['profile_uid'],'content_encrypt') && (! $webpage)) ? true : false), | ||||
|   | ||||
| @@ -35,19 +35,28 @@ function diaspora_dispatch_public($msg) { | ||||
| 			logger('diaspora_public: delivering to: ' . $rr['channel_name'] . ' (' . $rr['channel_address'] . ') '); | ||||
| 			diaspora_dispatch($rr,$msg); | ||||
| 		} | ||||
| 		if($sys) | ||||
| 			diaspora_dispatch($sys,$msg); | ||||
| 	} | ||||
| 	else | ||||
| 		logger('diaspora_public: no subscribers'); | ||||
| 	else { | ||||
| 		if(! $sys) | ||||
| 			logger('diaspora_public: no subscribers'); | ||||
| 	} | ||||
|  | ||||
| 	if($sys) { | ||||
| 		$sys['system'] = true; | ||||
| 		logger('diaspora_public: delivering to sys.'); | ||||
| 		diaspora_dispatch($sys,$msg); | ||||
| 	} | ||||
| } | ||||
|  | ||||
|  | ||||
|  | ||||
| function diaspora_dispatch($importer,$msg,$attempt=1) { | ||||
| function diaspora_dispatch($importer,$msg) { | ||||
|  | ||||
| 	$ret = 0; | ||||
|  | ||||
| 	if(! array_key_exists('system',$importer)) | ||||
| 		$importer['system'] = false; | ||||
|  | ||||
| 	$enabled = intval(get_config('system','diaspora_enabled')); | ||||
| 	if(! $enabled) { | ||||
| 		logger('mod-diaspora: disabled'); | ||||
| @@ -100,7 +109,7 @@ function diaspora_dispatch($importer,$msg,$attempt=1) { | ||||
| 		$ret = diaspora_signed_retraction($importer,$xmlbase->relayable_retraction,$msg); | ||||
| 	} | ||||
| 	elseif($xmlbase->photo) { | ||||
| 		$ret = diaspora_photo($importer,$xmlbase->photo,$msg,$attempt); | ||||
| 		$ret = diaspora_photo($importer,$xmlbase->photo,$msg); | ||||
| 	} | ||||
| 	elseif($xmlbase->conversation) { | ||||
| 		$ret = diaspora_conversation($importer,$xmlbase->conversation,$msg); | ||||
| @@ -267,8 +276,6 @@ function diaspora_process_outbound($arr) { | ||||
| } | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| function diaspora_handle_from_contact($contact_hash) { | ||||
|  | ||||
| 	logger("diaspora_handle_from_contact: contact id is " . $contact_hash, LOGGER_DEBUG); | ||||
| @@ -286,11 +293,21 @@ function diaspora_get_contact_by_handle($uid,$handle) { | ||||
|  | ||||
| 	if(diaspora_is_blacklisted($handle)) | ||||
| 		return false; | ||||
| 	require_once('include/identity.php'); | ||||
|  | ||||
| 	$sys = get_sys_channel(); | ||||
| 	if(($sys) && ($sys['channel_id'] == $uid)) { | ||||
| 		$r = q("SELECT * FROM xchan where xchan_addr = '%s' limit 1", | ||||
| 			dbesc($handle) | ||||
| 		); | ||||
| 	} | ||||
| 	else { | ||||
| 		$r = q("SELECT * FROM abook left join xchan on xchan_hash = abook_xchan where xchan_addr = '%s' and abook_channel = %d limit 1", | ||||
| 			dbesc($handle), | ||||
| 			intval($uid) | ||||
| 		); | ||||
| 	} | ||||
|  | ||||
| 	$r = q("SELECT * FROM abook left join xchan on xchan_hash = abook_xchan where xchan_addr = '%s' and abook_channel = %d limit 1", | ||||
| 		dbesc($handle), | ||||
| 		intval($uid) | ||||
| 	); | ||||
| 	return (($r) ? $r[0] : false); | ||||
| } | ||||
|  | ||||
| @@ -783,7 +800,7 @@ function diaspora_post($importer,$xml,$msg) { | ||||
| 	} | ||||
|  | ||||
|  | ||||
| 	if(! perm_is_allowed($importer['channel_id'],$contact['xchan_hash'],'send_stream')) { | ||||
| 	if((! $importer['system']) && (! perm_is_allowed($importer['channel_id'],$contact['xchan_hash'],'send_stream'))) { | ||||
| 		logger('diaspora_post: Ignoring this author.'); | ||||
| 		return 202; | ||||
| 	} | ||||
| @@ -970,7 +987,7 @@ function diaspora_reshare($importer,$xml,$msg) { | ||||
| 	if(! $contact) | ||||
| 		return; | ||||
|  | ||||
| 	if(! perm_is_allowed($importer['channel_id'],$contact['xchan_hash'],'send_stream')) { | ||||
| 	if((! $importer['system']) && (! perm_is_allowed($importer['channel_id'],$contact['xchan_hash'],'send_stream'))) { | ||||
| 		logger('diaspora_reshare: Ignoring this author: ' . $diaspora_handle . ' ' . print_r($xml,true)); | ||||
| 		return 202; | ||||
| 	} | ||||
| @@ -1137,7 +1154,7 @@ function diaspora_asphoto($importer,$xml,$msg) { | ||||
| 	if(! $contact) | ||||
| 		return; | ||||
|  | ||||
| 	if(! perm_is_allowed($importer['channel_id'],$contact['xchan_hash'],'send_stream')) { | ||||
| 	if((! $importer['system']) && (! perm_is_allowed($importer['channel_id'],$contact['xchan_hash'],'send_stream'))) { | ||||
| 		logger('diaspora_asphoto: Ignoring this author.'); | ||||
| 		return 202; | ||||
| 	} | ||||
| @@ -1242,7 +1259,7 @@ function diaspora_comment($importer,$xml,$msg) { | ||||
| 		return; | ||||
| 	} | ||||
|  | ||||
| 	if(! perm_is_allowed($importer['channel_id'],$contact['xchan_hash'],'post_comments')) { | ||||
| 	if((! $importer['system']) && (! perm_is_allowed($importer['channel_id'],$contact['xchan_hash'],'post_comments'))) { | ||||
| 		logger('diaspora_comment: Ignoring this author.'); | ||||
| 		return 202; | ||||
| 	} | ||||
| @@ -1719,7 +1736,7 @@ function diaspora_message($importer,$xml,$msg) { | ||||
| } | ||||
|  | ||||
|  | ||||
| function diaspora_photo($importer,$xml,$msg,$attempt=1) { | ||||
| function diaspora_photo($importer,$xml,$msg) { | ||||
|  | ||||
| 	$a = get_app(); | ||||
|  | ||||
| @@ -1747,7 +1764,7 @@ function diaspora_photo($importer,$xml,$msg,$attempt=1) { | ||||
| 		return; | ||||
| 	} | ||||
|  | ||||
| 	if(! perm_is_allowed($importer['channel_id'],$contact['xchan_hash'],'send_stream')) { | ||||
| 	if((! $importer['system']) && (! perm_is_allowed($importer['channel_id'],$contact['xchan_hash'],'send_stream'))) { | ||||
| 		logger('diaspora_photo: Ignoring this author.'); | ||||
| 		return 202; | ||||
| 	} | ||||
| @@ -1806,7 +1823,7 @@ function diaspora_like($importer,$xml,$msg) { | ||||
| 	} | ||||
|  | ||||
|  | ||||
| 	if(! perm_is_allowed($importer['channel_id'],$contact['xchan_hash'],'post_comments')) { | ||||
| 	if((! $importer['system']) && (! perm_is_allowed($importer['channel_id'],$contact['xchan_hash'],'post_comments'))) { | ||||
| 		logger('diaspora_like: Ignoring this author.'); | ||||
| 		return 202; | ||||
| 	} | ||||
|   | ||||
| @@ -216,6 +216,49 @@ function sync_directories($dirmode) { | ||||
| 				); | ||||
| 			} | ||||
| 		} | ||||
| 		if(count($j['ratings'])) { | ||||
| 			foreach($j['ratings'] as $rr) {		 | ||||
| 				$x = q("select * from xlink where xlink_xchan = '%s' and xlink_link = '%s' and xlink_static = 1", | ||||
| 					dbesc($rr['channel']), | ||||
| 					dbesc($rr['target']) | ||||
| 				); | ||||
| 				if($x && $x[0]['xlink_updated'] >= $rr['edited']) | ||||
| 					continue; | ||||
| 				$y = q("select xchan_pubkey from xchan where xchan_hash = '%s' limit 1", | ||||
| 					dbesc($rr['channel']) | ||||
| 				); | ||||
| 				if(! $y) { | ||||
| 					logger('key unavailable on this site for ' . $rr['channel']); | ||||
| 					continue; | ||||
| 				} | ||||
| 				if(! rsa_verify($rr['target'] . '.' . $rr['rating'] . '.' . $rr['rating_text'], base64url_decode($rr['signature']),$y[0]['xchan_pubkey'])) { | ||||
| 			        logger('failed to verify rating'); | ||||
| 					continue; | ||||
| 				} | ||||
|  | ||||
| 				if($x) { | ||||
| 					$z = q("update xlink set xlink_rating = %d, xlink_rating_text = '%s', xlink_sig = '%s', xlink_updated = '%s' where xlink_id = %d", | ||||
| 						intval($rr['rating']), | ||||
| 						dbesc($rr['rating_text']), | ||||
| 						dbesc($rr['signature']), | ||||
| 						dbesc(datetime_convert()), | ||||
| 						intval($x[0]['xlink_id']) | ||||
| 	        		); | ||||
| 			        logger('rating updated'); | ||||
|     			} | ||||
|     			else { | ||||
|         			$z = 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', 1 ) ", | ||||
| 						dbesc($rr['channel']), | ||||
| 						dbesc($rr['target']), | ||||
| 						intval($rr['rating']), | ||||
| 						dbesc($rr['rating_text']), | ||||
| 						dbesc($rr['signature']), | ||||
| 						dbesc(datetime_convert()) | ||||
| 					); | ||||
| 					logger('rating created'); | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -941,6 +941,9 @@ logger('online: ' . $profile['online']); | ||||
|  | ||||
| 	$tpl = get_markup_template('profile_vcard.tpl'); | ||||
|  | ||||
| 	require_once('include/widgets.php'); | ||||
| 	$z = widget_rating(array('target' => $profile['channel_hash'])); | ||||
|  | ||||
| 	$o .= replace_macros($tpl, array( | ||||
| 		'$profile'       => $profile, | ||||
| 		'$connect'       => $connect, | ||||
| @@ -952,6 +955,7 @@ logger('online: ' . $profile['online']); | ||||
| 		'$homepage'      => $homepage, | ||||
| 		'$chanmenu'      => $channel_menu, | ||||
| 		'$diaspora'      => $diaspora, | ||||
| 		'$rating'        => $z, | ||||
| 		'$contact_block' => $contact_block, | ||||
| 	)); | ||||
|  | ||||
|   | ||||
| @@ -4746,6 +4746,7 @@ function item_remove_cid($xchan_hash,$mid,$uid) { | ||||
| // Set item permissions based on results obtained from linkify_tags() | ||||
| function set_linkified_perms($linkified, &$str_contact_allow, &$str_group_allow, $profile_uid, $parent_item = false) { | ||||
| 	$first_access_tag = true; | ||||
|  | ||||
| 	foreach($linkified as $x) { | ||||
| 		$access_tag = $x['access_tag']; | ||||
| 		if(($access_tag) && (! $parent_item)) { | ||||
|   | ||||
| @@ -16,6 +16,10 @@ function js_strings() { | ||||
| 		'$permschange' => t('Notice: Permissions have changed but have not yet been submitted.'), | ||||
| 		'$closeAll'    => t('close all'), | ||||
| 		'$nothingnew'  => t('Nothing new here'), | ||||
| 		'$rating_desc' => t('Rate This Channel (this is public)'), | ||||
| 		'$rating_val'  => t('Rating'), | ||||
| 		'$rating_text' => t('Describe (optional)'), | ||||
| 		'$submit'      => t('Submit'), | ||||
|  | ||||
| 		'$t01' => ((t('timeago.prefixAgo') != 'timeago.prefixAgo') ? t('timeago.prefixAgo') : ''), | ||||
| 		'$t02' => ((t('timeago.prefixFromNow') != 'timeago.prefixFromNow') ? t('timeago.prefixFromNow') : ''), | ||||
|   | ||||
| @@ -295,15 +295,6 @@ function notifier_run($argv, $argc){ | ||||
| 		$private = false; | ||||
| 		$packet_type = 'purge'; | ||||
| 	} | ||||
| 	elseif($cmd === 'rating') { | ||||
| 		$r = q("select * from xlink where xlink_id = %d and xlink_static = 1 limit 1", | ||||
| 			intval($item_id) | ||||
| 		); | ||||
| 		if($r) { | ||||
| 			logger('rating message: ' . print_r($r[0],true)); | ||||
| 			return; | ||||
| 		} | ||||
| 	} | ||||
| 	else { | ||||
|  | ||||
| 		// Normal items | ||||
| @@ -483,11 +474,6 @@ function notifier_run($argv, $argc){ | ||||
| 	// Now we have collected recipients (except for external mentions, FIXME) | ||||
| 	// Let's reduce this to a set of hubs. | ||||
|  | ||||
| 	 | ||||
| 	// for public posts always include our own hub | ||||
| // this shouldn't be needed any more. collect_recipients should take care of it. | ||||
| //	$sql_extra = (($private) ? "" : " or hubloc_url = '" . dbesc(z_root()) . "' "); | ||||
|  | ||||
| 	logger('notifier: hub choice: ' . intval($relay_to_owner) . ' ' . intval($private) . ' ' . $cmd, LOGGER_DEBUG); | ||||
|  | ||||
| 	if($relay_to_owner && (! $private) && ($cmd !== 'relay')) { | ||||
|   | ||||
							
								
								
									
										124
									
								
								include/ratenotif.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										124
									
								
								include/ratenotif.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,124 @@ | ||||
| <?php | ||||
|  | ||||
| require_once('include/cli_startup.php'); | ||||
| require_once('include/zot.php'); | ||||
| require_once('include/queue_fn.php'); | ||||
|  | ||||
|  | ||||
| function ratenotif_run($argv, $argc){ | ||||
|  | ||||
| 	cli_startup(); | ||||
|  | ||||
| 	$a = get_app(); | ||||
|  | ||||
| 	require_once("session.php"); | ||||
| 	require_once("datetime.php"); | ||||
| 	require_once('include/items.php'); | ||||
| 	require_once('include/Contact.php'); | ||||
|  | ||||
| 	if($argc < 3) | ||||
| 		return; | ||||
|  | ||||
|  | ||||
| 	logger('ratenotif: invoked: ' . print_r($argv,true), LOGGER_DEBUG); | ||||
|  | ||||
| 	$cmd = $argv[1]; | ||||
|  | ||||
| 	$item_id = $argv[2]; | ||||
|  | ||||
|  | ||||
| 	if($cmd === 'rating') { | ||||
| 		$r = q("select * from xlink where xlink_id = %d and xlink_static = 1 limit 1", | ||||
| 			intval($item_id) | ||||
| 		); | ||||
| 		if(! $r) { | ||||
| 			logger('rating not found'); | ||||
| 			return; | ||||
| 		} | ||||
|  | ||||
| 		$encoded_item = array( | ||||
| 			'type' => 'rating',  | ||||
| 			'encoding' => 'zot', | ||||
| 			'target' => $r[0]['xlink_link'], | ||||
| 			'rating' => intval($r[0]['xlink_rating']), | ||||
| 			'rating_text' => $r[0]['xlink_rating_text'], | ||||
| 			'signature' => $r[0]['xlink_sig'], | ||||
| 			'edited' => $r[0]['xlink_updated'] | ||||
| 		); | ||||
| 	} | ||||
|  | ||||
| 	$channel = channelx_by_hash($r[0]['xlink_xchan']); | ||||
| 	if(! $channel) { | ||||
| 		logger('no channel'); | ||||
| 		return; | ||||
| 	} | ||||
|  | ||||
|  | ||||
| 	$primary = get_directory_primary(); | ||||
|  | ||||
| 	if(! $primary) | ||||
| 		return; | ||||
|  | ||||
|  | ||||
| 	$interval = ((get_config('system','delivery_interval') !== false)  | ||||
| 		? intval(get_config('system','delivery_interval')) : 2 ); | ||||
|  | ||||
| 	$deliveries_per_process = intval(get_config('system','delivery_batch_count')); | ||||
|  | ||||
| 	if($deliveries_per_process <= 0) | ||||
| 		$deliveries_per_process = 1; | ||||
|  | ||||
| 	$deliver = array(); | ||||
|  | ||||
| 	$x = z_fetch_url($primary . '/regdir'); | ||||
| 	if($x['success']) { | ||||
| 		$j = json_decode($x['body'],true); | ||||
| 		if($j && $j['success'] && is_array($j['directories'])) { | ||||
|  | ||||
| 			foreach($j['directories'] as $h) { | ||||
| //				if($h == z_root()) | ||||
| //					continue; | ||||
|  | ||||
| 				$hash = random_string(); | ||||
| 				$n = zot_build_packet($channel,'notify',null,null,$hash); | ||||
|  | ||||
| 				q("insert into outq ( outq_hash, outq_account, outq_channel, outq_driver, outq_posturl, outq_async, outq_created, outq_updated, outq_notify, outq_msg ) values ( '%s', %d, %d, '%s', '%s', %d, '%s', '%s', '%s', '%s' )", | ||||
| 					dbesc($hash), | ||||
| 					intval($channel['channel_account_id']), | ||||
| 					intval($channel['channel_id']), | ||||
| 					dbesc('zot'), | ||||
| 					dbesc($h . '/post'), | ||||
| 					intval(1), | ||||
| 					dbesc(datetime_convert()), | ||||
| 					dbesc(datetime_convert()), | ||||
| 					dbesc($n), | ||||
| 					dbesc(json_encode($encoded_item)) | ||||
| 				); | ||||
| 			} | ||||
| 			$deliver[] = $hash; | ||||
|  | ||||
| 			if(count($deliver) >= $deliveries_per_process) { | ||||
| 				proc_run('php','include/deliver.php',$deliver); | ||||
| 				$deliver = array(); | ||||
| 				if($interval) | ||||
| 					@time_sleep_until(microtime(true) + (float) $interval); | ||||
| 			} | ||||
|  | ||||
|  | ||||
| 			// catch any stragglers | ||||
|  | ||||
| 			if(count($deliver)) { | ||||
| 			proc_run('php','include/deliver.php',$deliver); | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 		 | ||||
| 	logger('ratenotif: complete.'); | ||||
| 	return; | ||||
|  | ||||
| } | ||||
|  | ||||
| if (array_search(__file__,get_included_files())===0){ | ||||
|   ratenotif_run($argv,$argc); | ||||
|   killme(); | ||||
| } | ||||
| @@ -1945,9 +1945,9 @@ function find_xchan_in_array($xchan,$arr) { | ||||
| } | ||||
|  | ||||
| function get_rel_link($j,$rel) { | ||||
| 	if(count($j)) | ||||
| 	if(is_array($j) && ($j)) | ||||
| 		foreach($j as $l) | ||||
| 			if($l['rel'] === $rel) | ||||
| 			if(array_key_exists('rel',$j) && $l['rel'] === $rel && array_key_exists('href',$l)) | ||||
| 				return $l['href']; | ||||
|  | ||||
| 	return ''; | ||||
| @@ -2296,6 +2296,7 @@ function handle_tag($a, &$body, &$access_tag, &$str_tags, $profile_uid, $tag) { | ||||
| 			} | ||||
| 		} | ||||
| 		else { | ||||
|  | ||||
| 			// check for a group/collection exclusion tag			 | ||||
|  | ||||
| 			// note that we aren't setting $replaced even though we're replacing text. | ||||
| @@ -2356,6 +2357,8 @@ function linkify_tags($a, &$body, $uid) { | ||||
| 	$tags = get_tags($body); | ||||
| 	if(count($tags)) { | ||||
| 		foreach($tags as $tag) { | ||||
| 			$access_tag = ''; | ||||
|  | ||||
| 			// If we already tagged 'Robert Johnson', don't try and tag 'Robert'. | ||||
| 			// Robert Johnson should be first in the $tags array | ||||
|  | ||||
|   | ||||
| @@ -903,3 +903,63 @@ function widget_random_block($arr) { | ||||
|  | ||||
| 	return $o; | ||||
| } | ||||
|  | ||||
|  | ||||
| function widget_rating($arr) { | ||||
| 	$a = get_app(); | ||||
|  | ||||
| 	$poco_rating = get_config('system','poco_rating_enable'); | ||||
| 	if((! $poco_rating) && ($poco_rating !== false)) { | ||||
| 		return; | ||||
| 	} | ||||
|  | ||||
| 	if($arr['target']) | ||||
| 		$hash = $arr['target']; | ||||
| 	else | ||||
| 		$hash = $a->poi['xchan_hash']; | ||||
|  | ||||
| 	if(! $hash) | ||||
| 		return; | ||||
|  | ||||
| 	$url = ''; | ||||
| 	$remote = false; | ||||
|  | ||||
| 	if(remote_channel() && ! local_channel()) { | ||||
| 		$ob = $a->get_observer(); | ||||
| 		if($ob && $ob['xchan_url']) { | ||||
| 			$p = parse_url($ob['xchan_url']); | ||||
| 			if($p) { | ||||
| 				$url = $p['scheme'] . '://' . $p['host'] . (($p['port']) ? ':' . $p['port'] : ''); | ||||
| 				$url .= '/rate?f=&target=' . urlencode($hash); | ||||
| 			} | ||||
| 			$remote = true; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	$self = false; | ||||
|  | ||||
| 	if(local_channel()) { | ||||
| 		$channel = $a->get_channel(); | ||||
|  | ||||
| 		if($hash == $channel['channel_hash']) | ||||
| 			$self = true; | ||||
|  | ||||
| 		head_add_js('ratings.js'); | ||||
|  | ||||
| 	} | ||||
|  | ||||
| 	if((($remote) || (local_channel())) && (! $self)) { | ||||
| 		$o = '<div class="widget rateme">'; | ||||
| 		if($remote) | ||||
| 			$o .= '<a class="rateme" href="' . $url . '"><i class="icon-pencil"></i> ' . t('Rate Me') . '</a>'; | ||||
| 		else | ||||
| 			$o .= '<div class="rateme fakelink" onclick="doRatings(\'' . $hash . '\'); return false;"><i class="icon-pencil"></i> ' . t('Rate Me') . '</div>'; | ||||
| 		$o .= '</div>'; | ||||
| 	} | ||||
|  | ||||
| 	$o .= '<div class="widget rateme"><a class="rateme" href="ratings/' . $hash . '"><i class="icon-eye-open"></i> ' . t('View Ratings') . '</a>'; | ||||
| 	$o .= '</div>'; | ||||
|  | ||||
| 	return $o; | ||||
|  | ||||
| } | ||||
|   | ||||
| @@ -418,7 +418,7 @@ function zot_refresh($them,$channel = null, $force = false) { | ||||
| 					where abook_xchan = '%s' and abook_channel = %d  | ||||
| 					and not (abook_flags & %d) > 0 ", | ||||
| 					intval($their_perms), | ||||
| 					dbesc($next_birthday), | ||||
| 					dbescdate($next_birthday), | ||||
| 					dbesc($x['hash']), | ||||
| 					intval($channel['channel_id']), | ||||
| 					intval(ABOOK_FLAG_SELF) | ||||
| @@ -1067,6 +1067,11 @@ function zot_import($arr, $sender_url) { | ||||
|  | ||||
| 	if(is_array($incoming)) { | ||||
| 		foreach($incoming as $i) { | ||||
| 			if(! is_array($i)) { | ||||
| 				logger('incoming is not an array'); | ||||
| 				continue; | ||||
| 			} | ||||
|  | ||||
| 			$result = null; | ||||
|  | ||||
| 			if(array_key_exists('iv',$i['notify'])) { | ||||
| @@ -1091,7 +1096,8 @@ function zot_import($arr, $sender_url) { | ||||
| 			if(array_key_exists('message',$i) && array_key_exists('type',$i['message']) && $i['message']['type'] === 'rating') { | ||||
| 				// rating messages are processed only by directory servers | ||||
| 				logger('Rating received: ' . print_r($arr,true), LOGGER_DATA); | ||||
| 				$result = process_rating_delivery($i['notify']['sender'],$arr); | ||||
| 				$result = process_rating_delivery($i['notify']['sender'],$i['message']); | ||||
| 				continue; | ||||
| 			} | ||||
|  | ||||
| 			if(array_key_exists('recipients',$i['notify']) && count($i['notify']['recipients'])) { | ||||
| @@ -1793,34 +1799,52 @@ function process_mail_delivery($sender,$arr,$deliveries) { | ||||
|  | ||||
| function process_rating_delivery($sender,$arr) { | ||||
|  | ||||
| 	$dirmode = intval(get_config('system','directory_mode')); | ||||
| 	if($dirmode == DIRECTORY_MODE_NORMAL) | ||||
| 		return; | ||||
| 	logger('process_rating_delivery: ' . print_r($arr,true)); | ||||
|  | ||||
| 	if(! $arr['target']) | ||||
| 		return; | ||||
|  | ||||
| 	$r = q("select * from xlink where xlink_xchan = '%s' and xlink_target = '%s' limit 1", | ||||
| 	$z = q("select xchan_pubkey from xchan where xchan_hash = '%s' limit 1", | ||||
| 		dbesc($sender['hash']) | ||||
| 	); | ||||
|  | ||||
|  | ||||
| 	if((! $z) || (! rsa_verify($arr['target'] . '.' . $arr['rating'] . '.' . $arr['rating_text'], base64url_decode($arr['signature']),$z[0]['xchan_pubkey']))) { | ||||
| 		logger('failed to verify rating'); | ||||
| 		return; | ||||
| 	} | ||||
|  | ||||
| 	$r = q("select * from xlink where xlink_xchan = '%s' and xlink_link = '%s' and xlink_static = 1 limit 1", | ||||
| 		dbesc($sender['hash']), | ||||
| 		dbesc($arr['target']) | ||||
| 	);	 | ||||
| 	 | ||||
| 	if($r) { | ||||
| 		$x = q("update xlink set xlink_rating = %d, xlink_rating_text = '%s', xlink_updated = '%s' where xlink_id = %d", | ||||
| 		if($r[0]['xlink_updated'] >= $arr['edited']) { | ||||
| 			logger('rating message duplicate'); | ||||
| 			return; | ||||
| 		} | ||||
|  | ||||
| 		$x = q("update xlink set xlink_rating = %d, xlink_rating_text = '%s', xlink_sig = '%s', xlink_updated = '%s' where xlink_id = %d", | ||||
| 			intval($arr['rating']), | ||||
| 			intval($arr['rating_text']), | ||||
| 			dbesc($arr['rating_text']), | ||||
| 			dbesc($arr['signature']), | ||||
| 			dbesc(datetime_convert()), | ||||
| 			intval($r[0]['xlink_id']) | ||||
| 		); | ||||
| 		logger('rating updated'); | ||||
| 	} | ||||
| 	else { | ||||
| 		$x = q("insert into xlink ( xlink_xchan, xlink_link, xlink_rating, xlink_rating_text, xlink_updated, xlink_static ) | ||||
| 		$x = 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', 1 ) ", | ||||
| 			dbesc($sender['hash']), | ||||
| 			dbesc($arr['target']), | ||||
| 			intval($arr['rating']), | ||||
| 			intval($arr['rating_text']), | ||||
| 			dbesc($arr['rating_text']), | ||||
| 			dbesc($arr['signature']), | ||||
| 			dbesc(datetime_convert()) | ||||
| 		); | ||||
| 		logger('rating created'); | ||||
| 	} | ||||
| 	return; | ||||
| } | ||||
|   | ||||
| @@ -1515,10 +1515,11 @@ function update_r1133() { | ||||
| 			xp_client varchar( 20 ) NOT NULL DEFAULT '', | ||||
| 			xp_channel bigint NOT NULL DEFAULT '0', | ||||
| 			xp_perm varchar( 64 ) NOT NULL DEFAULT '', | ||||
| 			PRIMARY KEY (\"xp_id\") )"); | ||||
| 		$r2 = q("create index \"xp_client\" on xperm (\"xp_client\",  | ||||
| 			create index \"xp_channel\" on xperm (\"xp_channel\"), | ||||
| 			create index \"xp_perm\" on xperm (\"xp_perm\") "); | ||||
| 			PRIMARY KEY (xp_id) )"); | ||||
| 		$r2 = 0; | ||||
| 		foreach(array('xp_client', 'xp_channel', 'xp_perm') as $fld) | ||||
| 			$r2 += (empty(q("create index $fld on xperm ($fld)")) ? 0 : 1); | ||||
| 			 | ||||
| 		$r = (($r1 && $r2) ? true : false); | ||||
| 	} | ||||
| 	else { | ||||
|   | ||||
| @@ -117,7 +117,7 @@ function connedit_post(&$a) { | ||||
| 	if($rating > 10) | ||||
| 		$rating = 10; | ||||
|  | ||||
| 	$rating_text = escape_tags($_REQUEST['rating_text']); | ||||
| 	$rating_text = trim(escape_tags($_REQUEST['rating_text'])); | ||||
|  | ||||
| 	$abook_my_perms = 0; | ||||
|  | ||||
| @@ -131,26 +131,35 @@ function connedit_post(&$a) { | ||||
| 	$new_friend = false; | ||||
|  | ||||
| 	if(! $is_self) { | ||||
| 		$z = q("select * from xlink where xlink_xchan = '%s' and xlink_xlink = '%s' and xlink_static = 1 limit 1", | ||||
|  | ||||
| 		$signed = $orig_record[0]['abook_xchan'] . '.' . $rating . '.' . $rating_text; | ||||
|  | ||||
| 		$sig = base64url_encode(rsa_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($orig_record[0]['abook_xchan']) | ||||
| 		); | ||||
|  | ||||
|  | ||||
| 		if($z) { | ||||
| 			$record = $z[0]['xlink_id']; | ||||
| 			$w = q("update xlink set xlink_rating = '%d', xlink_rating_text = '%s', xlink_updated = '%s'  | ||||
| 			$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_updated, xlink_static ) values ( '%s', '%s', %d, '%s', '%s', 1 ) ", | ||||
| 			$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($orig_record[0]['abook_xchan']), | ||||
| 				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", | ||||
| @@ -161,7 +170,7 @@ function connedit_post(&$a) { | ||||
| 				$record = $z[0]['xlink_id']; | ||||
| 		} | ||||
| 		if($record) { | ||||
| 			proc_run('php','include/notifier.php','rating',$record); | ||||
| 			proc_run('php','include/ratenotif.php','rating',$record); | ||||
| 		}	 | ||||
| 	} | ||||
|  | ||||
| @@ -171,13 +180,11 @@ function connedit_post(&$a) { | ||||
|  | ||||
| 	} | ||||
|  | ||||
| 	$r = q("UPDATE abook SET abook_profile = '%s', abook_my_perms = %d , abook_closeness = %d, abook_rating = %d, abook_rating_text = '%s', abook_flags = %d | ||||
| 	$r = q("UPDATE abook SET abook_profile = '%s', abook_my_perms = %d , abook_closeness = %d, abook_flags = %d | ||||
| 		where abook_id = %d AND abook_channel = %d", | ||||
| 		dbesc($profile_id), | ||||
| 		intval($abook_my_perms), | ||||
| 		intval($closeness), | ||||
| 		intval($rating), | ||||
| 		dbesc($rating_text), | ||||
| 		intval($abook_flags), | ||||
| 		intval($contact_id), | ||||
| 		intval(local_channel()) | ||||
| @@ -317,6 +324,7 @@ function connedit_content(&$a) { | ||||
| 		return login(); | ||||
| 	} | ||||
|  | ||||
| 	$channel = $a->get_channel(); | ||||
| 	$my_perms = get_channel_default_perms(local_channel()); | ||||
| 	$role = get_pconfig(local_channel(),'system','permissions_role'); | ||||
| 	if($role) { | ||||
| @@ -565,8 +573,22 @@ function connedit_content(&$a) { | ||||
| 			)); | ||||
| 		} | ||||
|  | ||||
| 		$rating_val = 0; | ||||
| 		$rating_text = ''; | ||||
|  | ||||
| 		$xl = q("select * from xlink where xlink_xchan = '%s' and xlink_link = '%s' and xlink_static = 1", | ||||
| 			dbesc($channel['channel_hash']), | ||||
| 			dbesc($contact['xchan_hash']) | ||||
| 		); | ||||
|  | ||||
| 		if($xl) { | ||||
| 			$rating_val = intval($xl[0]['xlink_rating']); | ||||
| 			$rating_text = $xl[0]['xlink_rating_text']; | ||||
| 		} | ||||
|  | ||||
|  | ||||
| 		$poco_rating = get_config('system','poco_rating_enable'); | ||||
| 		$poco_rating = 0; | ||||
|  | ||||
| 		// if unset default to enabled | ||||
| 		if($poco_rating === false) | ||||
| 			$poco_rating = true; | ||||
| @@ -574,7 +596,7 @@ function connedit_content(&$a) { | ||||
| 		if($poco_rating) { | ||||
| 			$rating = replace_macros(get_markup_template('rating_slider.tpl'),array( | ||||
| 				'$min' => -10, | ||||
| 				'$val' => (($contact['abook_rating']) ? $contact['abook_rating'] : 0), | ||||
| 				'$val' => $rating_val | ||||
| 			)); | ||||
| 		} | ||||
| 		else { | ||||
| @@ -614,11 +636,11 @@ function connedit_content(&$a) { | ||||
| 			'$viewprof'       => t('View Profile'), | ||||
| 			'$clickme'        => t('Click to open/close'), | ||||
| 			'$lbl_slider'     => t('Slide to adjust your degree of friendship'), | ||||
| 			'$lbl_rating'     => t('Rating (this information may be public)'), | ||||
| 			'$lbl_rating_txt' => t('Optionally explain your rating (this information may be public)'), | ||||
| 			'$rating_txt'     => $contact['abook_rating_text'], | ||||
| 			'$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'     => $contact['abook_rating'], | ||||
| 			'$rating_val'     => $rating_val, | ||||
| 			'$slide'          => $slide, | ||||
| 			'$tabs'           => $t, | ||||
| 			'$tab_str'        => $tab_str, | ||||
|   | ||||
| @@ -190,6 +190,11 @@ function directory_content(&$a) { | ||||
|  | ||||
| 						$page_type = ''; | ||||
|  | ||||
| 						if($rr['total_ratings']) | ||||
| 							$total_ratings = sprintf( tt("%d rating", "%d ratings", $rr['total_ratings']), $rr['total_ratings']); | ||||
| 						else | ||||
| 							$total_ratings = ''; | ||||
|  | ||||
| 						$profile = $rr; | ||||
|  | ||||
| 						if ((x($profile,'locale') == 1) | ||||
| @@ -247,7 +252,7 @@ function directory_content(&$a) { | ||||
| 							'public_forum' => $rr['public_forum'], | ||||
| 							'photo' => $rr['photo'], | ||||
| 							'hash' => $rr['hash'], | ||||
| 							'alttext' => $rr['name'] . ' ' . $rr['address'], | ||||
| 							'alttext' => $rr['name'] . ((local_channel() || remote_channel()) ? ' ' . $rr['address'] : ''), | ||||
| 							'name' => $rr['name'], | ||||
| 							'details' => $pdesc . $details, | ||||
| 							'profile' => $profile, | ||||
| @@ -255,6 +260,9 @@ function directory_content(&$a) { | ||||
| 							'nickname' => substr($rr['address'],0,strpos($rr['address'],'@')), | ||||
| 							'location' => $location, | ||||
| 							'gender'   => $gender, | ||||
| 							'total_ratings' => $total_ratings, | ||||
| 							'viewrate' => true, | ||||
| 							'canrate' => ((local_channel()) ? true : false), | ||||
| 							'pdesc'	=> $pdesc, | ||||
| 							'marital'  => $marital, | ||||
| 							'homepage' => $homepage, | ||||
| @@ -269,6 +277,7 @@ function directory_content(&$a) { | ||||
| 							'keywords' => $out, | ||||
| 							'ignlink' => $suggest ? $a->get_baseurl() . '/directory?ignore=' . $rr['hash'] : '', | ||||
| 							'ignore_label' => "Don't suggest", | ||||
| 							'safe' => $safe_mode | ||||
| 						); | ||||
|  | ||||
| 						$arr = array('contact' => $rr, 'entry' => $entry); | ||||
|   | ||||
| @@ -12,7 +12,6 @@ function dirsearch_content(&$a) { | ||||
|  | ||||
| 	$ret = array('success' => false); | ||||
|  | ||||
| 	// If you've got a public directory server, you probably shouldn't block public access | ||||
|  | ||||
|  | ||||
| 	$dirmode = intval(get_config('system','directory_mode')); | ||||
| @@ -206,6 +205,24 @@ function dirsearch_content(&$a) { | ||||
| 				); | ||||
| 			} | ||||
| 		} | ||||
| 		$r = q("select * from xlink where xlink_static = 1 and xlink_updated >= '%s' ", | ||||
| 			dbesc($sync) | ||||
| 		); | ||||
| 		if($r) { | ||||
| 			$spkt['ratings'] = array(); | ||||
| 			foreach($r as $rr) { | ||||
| 				$spkt['ratings'][] = array( | ||||
| 					'type' => 'rating',  | ||||
| 					'encoding' => 'zot', | ||||
| 					'channel' => $rr['xlink_xchan'], | ||||
| 					'target' => $rr['xlink_link'], | ||||
| 					'rating' => intval($rr['xlink_rating']), | ||||
| 					'rating_text' => $rr['xlink_rating_text'], | ||||
| 					'signature' => $rr['xlink_sig'], | ||||
| 					'edited' => $rr['xlink_updated'] | ||||
| 				); | ||||
| 			} | ||||
| 		} | ||||
| 		json_return_and_die($spkt); | ||||
| 	} | ||||
| 	else { | ||||
|   | ||||
| @@ -1,13 +1,35 @@ | ||||
| <?php | ||||
|  | ||||
| function prate_init(&$a) { | ||||
| 	if($_SERVER['REQUEST_METHOD'] === 'post') | ||||
| 		return; | ||||
|  | ||||
| function prate_post(&$a) { | ||||
| 	if(! local_channel()) | ||||
| 		return; | ||||
|  | ||||
| 	$channel = $a->get_channel(); | ||||
|  | ||||
| 	$target = $_REQUEST['target']; | ||||
| 	$target = argv(1); | ||||
| 	if(! $target) | ||||
| 		return; | ||||
|  | ||||
| 	$r = q("select * from xlink where xlink_xchan = '%s' and xlink_link = '%s' and xlink_static = 1", | ||||
| 		dbesc($channel['channel_hash']), | ||||
| 		dbesc($target) | ||||
| 	); | ||||
| 	if($r) | ||||
| 		json_return_and_die(array('rating' => $r[0]['xlink_rating'],'rating_text' => $r[0]['xlink_rating_text'])); | ||||
| 	killme(); | ||||
| } | ||||
|  | ||||
| function prate_post(&$a) { | ||||
|  | ||||
| 	if(! local_channel()) | ||||
| 		return; | ||||
|  | ||||
| 	$channel = $a->get_channel(); | ||||
|  | ||||
| 	$target = trim($_REQUEST['target']); | ||||
| 	if(! $target) | ||||
| 		return; | ||||
|  | ||||
| @@ -20,28 +42,35 @@ function prate_post(&$a) { | ||||
| 	if($rating > 10) | ||||
| 		$rating = 10; | ||||
|  | ||||
| 	$rating_text = escape_tags($_REQUEST['rating_text']); | ||||
| 	$rating_text = trim(escape_tags($_REQUEST['rating_text'])); | ||||
|  | ||||
| 	$z = q("select * from xlink where xlink_xchan = '%s' and xlink_xlink = '%s' and xlink_static = 1 limit 1", | ||||
| 	$signed = $target . '.' . $rating . '.' . $rating_text; | ||||
|  | ||||
| 	$sig = base64url_encode(rsa_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($target) | ||||
| 	); | ||||
| 	if($z) { | ||||
| 		$record = $z[0]['xlink_id']; | ||||
| 		$w = q("update xlink set xlink_rating = '%d', xlink_rating_text = '%s', xlink_updated = '%s' | ||||
| 		$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_updated, xlink_static ) values ( '%s', '%s', %d, '%s', '%s', 1 ) ", | ||||
| 		$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($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", | ||||
| @@ -52,32 +81,10 @@ function prate_post(&$a) { | ||||
| 			$record = $z[0]['xlink_id']; | ||||
| 	} | ||||
| 	if($record) { | ||||
| 		proc_run('php','include/notifier.php','rating',$record); | ||||
| 		proc_run('php','include/ratenotif.php','rating',$record); | ||||
| 	} | ||||
|  | ||||
| 	$x = q("select abook_id from abook where abook_xchan = '%s' and abook_channel = %d limit 1", | ||||
| 		dbesc($target), | ||||
| 		intval($local_channel()) | ||||
| 	); | ||||
| 	if($x) { | ||||
| 		$w = q("update abook set abook_rating = %d, abook_rating_text = '%s' where abook_xchan = '%s' and abook_channel = %d", | ||||
| 			intval($rating), | ||||
| 			dbesc($rating_text), | ||||
| 			dbesc($target), | ||||
| 			intval(local_channel()) | ||||
| 		); | ||||
| 		$x = q("select * from abook where abook_xchan = '%s' and abook_channel = %d limit 1", | ||||
| 			dbesc($target), | ||||
| 			intval($local_channel()) | ||||
| 		); | ||||
| 		if($x) { | ||||
| 			unset($x[0]['abook_id']); | ||||
| 			unset($x[0]['abook_account']); | ||||
| 			unset($x[0]['abook_channel']); | ||||
| 			build_sync_packet(0, array('abook' => array($x[0]))); | ||||
| 		} | ||||
| 	} | ||||
| 	return; | ||||
| 	json_return_and_die(array('result' => true));; | ||||
| } | ||||
| 			 | ||||
|  | ||||
| @@ -89,3 +96,4 @@ function prate_post(&$a) { | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|   | ||||
							
								
								
									
										75
									
								
								mod/prep.php
									
									
									
									
									
								
							
							
						
						
									
										75
									
								
								mod/prep.php
									
									
									
									
									
								
							| @@ -1,75 +0,0 @@ | ||||
| <?php | ||||
|  | ||||
|  | ||||
| function prep_init(&$a) { | ||||
|  | ||||
| 	$poco_rating = get_config('system','poco_rating_enable'); | ||||
| 	// if unset default to enabled | ||||
| 	if($poco_rating === false) | ||||
| 		$poco_rating = true; | ||||
|  | ||||
| 	if(! $poco_rating) | ||||
| 		return; | ||||
|  | ||||
| 	if(argc() > 1) | ||||
| 		$hash = argv(1); | ||||
|  | ||||
| 	if(! $hash) { | ||||
| 		notice('Must supply a channel identififier.'); | ||||
| 		return; | ||||
| 	} | ||||
|  | ||||
| 	if(strpos($hash,'@')) { | ||||
| 		$r = q("select * from hubloc where hubloc_addr = '%s' limit 1", | ||||
| 			dbesc($hash) | ||||
| 		); | ||||
| 		if($r) | ||||
| 			$hash = $r[0]['hubloc_hash']; | ||||
| 	}  | ||||
|  | ||||
| 	$p = q("select * from xchan where xchan_hash like '%s'", | ||||
| 		dbesc($hash . '%') | ||||
| 	); | ||||
|  | ||||
| 	if($p) | ||||
| 		$a->poi = $p[0]; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| function prep_content(&$a) { | ||||
|  | ||||
|  | ||||
| 	$poco_rating = get_config('system','poco_rating_enable'); | ||||
| 	// if unset default to enabled | ||||
| 	if($poco_rating === false) | ||||
| 		$poco_rating = true; | ||||
|  | ||||
| 	if(! $poco_rating) | ||||
| 		return; | ||||
|  | ||||
| 	if(! $a->poi) | ||||
| 		return; | ||||
|  | ||||
| 	$r = q("select * from xlink left join xchan on xlink_xchan = xchan_hash where xlink_link like '%s' and xlink_rating != 0", | ||||
| 		dbesc($a->poi['xchan_hash']) | ||||
| 	); | ||||
|  | ||||
| 	if(! $r) | ||||
| 		notice( t('No ratings available') . EOL); | ||||
|  | ||||
|  | ||||
| 	$o = replace_macros(get_markup_template('prep.tpl'),array( | ||||
| 		'$header' => t('Ratings'), | ||||
| 		'$rating_lbl' => t('Rating: ' ), | ||||
| 		'$rating_text_lbl' => t('Description: '), | ||||
| 		'$raters' => $r | ||||
| 	)); | ||||
|  | ||||
| 	return $o; | ||||
| } | ||||
|  | ||||
| 			 | ||||
							
								
								
									
										158
									
								
								mod/rate.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										158
									
								
								mod/rate.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,158 @@ | ||||
| <?php | ||||
|  | ||||
|  | ||||
| function rate_init(&$a) { | ||||
|  | ||||
| 	if(! local_channel()) | ||||
| 		return; | ||||
|  | ||||
| 	$channel = $a->get_channel(); | ||||
|  | ||||
| 	$target = $_REQUEST['target']; | ||||
| 	if(! $target) | ||||
| 		return; | ||||
|  | ||||
| 	$a->data['target'] = $target; | ||||
|  | ||||
| 	if($target) { | ||||
| 		$r = q("SELECT * FROM xchan where xchan_hash like '%s' LIMIT 1", | ||||
| 			dbesc($target) | ||||
| 		); | ||||
| 		if($r) { | ||||
| 			$a->poi = $r[0]; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
|  | ||||
| 	return; | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| function rate_post(&$a) { | ||||
|  | ||||
| 	if(! local_channel()) | ||||
| 		return; | ||||
|  | ||||
| 	if(! $a->data['target']) | ||||
| 		return; | ||||
|  | ||||
| 	if(! $_REQUEST['execute']) | ||||
| 		return; | ||||
|  | ||||
| 	$channel = $a->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 = $a->data['target'] . '.' . $rating . '.' . $rating_text; | ||||
|  | ||||
| 	$sig = base64url_encode(rsa_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($a->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($a->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($a->data['target']) | ||||
| 		); | ||||
| 		if($z) | ||||
| 			$record = $z[0]['xlink_id']; | ||||
| 	} | ||||
|  | ||||
| 	if($record) { | ||||
| 		proc_run('php','include/ratenotif.php','rating',$record); | ||||
| 	} | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
|  | ||||
| function rate_content(&$a) { | ||||
|  | ||||
| 	if(! local_channel()) { | ||||
| 		notice( t('Permission denied.') . EOL); | ||||
| 		return; | ||||
| 	} | ||||
|  | ||||
| //	if(! $a->data['target']) { | ||||
| //		notice( t('No recipients.') . EOL); | ||||
| //		return; | ||||
| //	} | ||||
|  | ||||
| 	$poco_rating = get_config('system','poco_rating_enable'); | ||||
| 	if((! $poco_rating) && ($poco_rating !== false)) { | ||||
| 		notice('Ratings are disabled on this site.'); | ||||
| 		return; | ||||
| 	} | ||||
|  | ||||
| 	$channel = $a->get_channel(); | ||||
|  | ||||
| 	$r = q("select * from xlink where xlink_xchan = '%s' and xlink_link = '%s' and xlink_static = 1", | ||||
| 		dbesc($channel['channel_hash']), | ||||
| 		dbesc($a->data['target']) | ||||
| 	); | ||||
| 	if($r) | ||||
| 		$a->data['xlink'] = $r[0];				 | ||||
|  | ||||
| 	$rating_val = $r[0]['xlink_rating']; | ||||
| 	$rating_text = $r[0]['xlink_rating_text']; | ||||
|  | ||||
|  | ||||
| 	// if unset default to enabled | ||||
| 	if($poco_rating === false) | ||||
| 		$poco_rating = true; | ||||
|  | ||||
| 	if($poco_rating) { | ||||
| 		$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'), | ||||
| 		'target' => $a->data['target'], | ||||
| 		'$tgt_name' => (($a->poi && $a->poi['xchan_name']) ? $a->poi['xchan_name'] : sprintf( t('Remote Channel [%s] (not yet known on this site)'), substr($a->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; | ||||
|  | ||||
| } | ||||
							
								
								
									
										103
									
								
								mod/ratings.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										103
									
								
								mod/ratings.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,103 @@ | ||||
| <?php | ||||
|  | ||||
| require_once('include/dir_fns.php'); | ||||
|  | ||||
| function ratings_init(&$a) { | ||||
|  | ||||
| 	if((get_config('system','block_public')) && (! local_channel()) && (! remote_channel())) { | ||||
| 		return; | ||||
| 	} | ||||
|  | ||||
| 	if(local_channel()) | ||||
| 		load_contact_links(local_channel()); | ||||
|  | ||||
| 	$dirmode = intval(get_config('system','directory_mode')); | ||||
|  | ||||
| 	$x = find_upstream_directory($dirmode); | ||||
| 	if($x) | ||||
| 		$url = $x['url']; | ||||
|  | ||||
| 	$poco_rating = get_config('system','poco_rating_enable'); | ||||
| 	// if unset default to enabled | ||||
| 	if($poco_rating === false) | ||||
| 		$poco_rating = true; | ||||
|  | ||||
| 	if(! $poco_rating) | ||||
| 		return; | ||||
|  | ||||
| 	if(argc() > 1) | ||||
| 		$hash = argv(1); | ||||
|  | ||||
| 	if(! $hash) { | ||||
| 		notice('Must supply a channel identififier.'); | ||||
| 		return; | ||||
| 	} | ||||
|  | ||||
| 	$results = false; | ||||
|  | ||||
| 	$x = z_fetch_url($url . '/ratingsearch/' . $hash); | ||||
|  | ||||
|  | ||||
| 	if($x['success']) | ||||
| 		$results = json_decode($x['body'],true); | ||||
|  | ||||
|  | ||||
| 	if((! $results) || (! $results['success'])) { | ||||
|  | ||||
| 		notice('No results.'); | ||||
| 		return; | ||||
| 	}  | ||||
|  | ||||
| 	$a->poi = $results['target']; | ||||
|  | ||||
| 	$friends = array(); | ||||
| 	$others = array(); | ||||
|  | ||||
| 	if($results['ratings']) { | ||||
| 		foreach($results['ratings'] as $n) { | ||||
| 			if(is_array($a->contacts) && array_key_exists($n['xchan_hash'],$a->contacts)) | ||||
| 				$friends[] = $n; | ||||
| 			else | ||||
| 				$others[] = $n; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	$a->data = array_merge($friends,$others); | ||||
|  | ||||
| 	if(! $a->data) { | ||||
| 		notice( t('No ratings') . EOL); | ||||
| 	} | ||||
|  | ||||
| 	return; | ||||
| } | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| function ratings_content(&$a) { | ||||
|  | ||||
| 	if((get_config('system','block_public')) && (! local_channel()) && (! remote_channel())) { | ||||
| 		notice( t('Public access denied.') . EOL); | ||||
| 		return; | ||||
| 	} | ||||
|  | ||||
| 	$poco_rating = get_config('system','poco_rating_enable'); | ||||
| 	// if unset default to enabled | ||||
| 	if($poco_rating === false) | ||||
| 		$poco_rating = true; | ||||
|  | ||||
| 	if(! $poco_rating) | ||||
| 		return; | ||||
|  | ||||
| 	$o = replace_macros(get_markup_template('prep.tpl'),array( | ||||
| 		'$header' => t('Ratings'), | ||||
| 		'$rating_lbl' => t('Rating: ' ), | ||||
| 		'$rating_text_lbl' => t('Description: '), | ||||
| 		'$raters' => $a->data | ||||
| 	)); | ||||
|  | ||||
| 	return $o; | ||||
| } | ||||
|  | ||||
| 			 | ||||
							
								
								
									
										58
									
								
								mod/ratingsearch.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										58
									
								
								mod/ratingsearch.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,58 @@ | ||||
| <?php | ||||
|  | ||||
|  | ||||
| function ratingsearch_init(&$a) { | ||||
|  | ||||
| 	$ret = array('success' => false); | ||||
|  | ||||
| 	$dirmode = intval(get_config('system','directory_mode')); | ||||
|  | ||||
| 	if($dirmode == DIRECTORY_MODE_NORMAL) { | ||||
| 		$ret['message'] = 'This site is not a directory server.'; | ||||
| 		json_return_and_die($ret); | ||||
| 	} | ||||
|  | ||||
| 	if(argc() > 1) | ||||
| 		$hash = argv(1); | ||||
|  | ||||
| 	if(! $hash) { | ||||
| 		$ret['message'] = 'No channel identifier'; | ||||
| 		json_return_and_die($ret); | ||||
| 	} | ||||
|  | ||||
| 	if(strpos($hash,'@')) { | ||||
| 		$r = q("select * from hubloc where hubloc_addr = '%s' limit 1", | ||||
| 			dbesc($hash) | ||||
| 		); | ||||
| 		if($r) | ||||
| 			$hash = $r[0]['hubloc_hash']; | ||||
| 	}  | ||||
|  | ||||
| 	$p = q("select * from xchan where xchan_hash like '%s'", | ||||
| 		dbesc($hash . '%') | ||||
| 	); | ||||
|  | ||||
| 	if($p) | ||||
| 		$ret['target']  = $p[0]; | ||||
| 	else { | ||||
| 		$ret['message'] = 'channel not found'; | ||||
| 		json_return_and_die($ret); | ||||
| 	} | ||||
|  | ||||
| 	$ret['success'] = true; | ||||
|  | ||||
| 	$r = q("select * from xlink left join xchan on xlink_xchan = xchan_hash  | ||||
| 		where xlink_link = '%s' and xlink_rating != 0 and xlink_static = 1 order by xchan_name asc", | ||||
| 		dbesc($p[0]['xchan_hash']) | ||||
| 	); | ||||
|  | ||||
| 	if($r) { | ||||
| 		$ret['ratings'] = $r; | ||||
| 	} | ||||
| 	else | ||||
| 		$ret['ratings'] = array(); | ||||
| 		 | ||||
| 	json_return_and_die($ret); | ||||
|  | ||||
| } | ||||
|  | ||||
| @@ -47,9 +47,14 @@ function regdir_init(&$a) { | ||||
| 		json_return_and_die($result); | ||||
| 	} | ||||
| 	else { | ||||
| 		$r = q("select site_url from site where site_flags in ( 1, 2 ) and site_realm = '%s'", | ||||
| 			dbesc(get_directory_realm()) | ||||
| 		); | ||||
| 		if($dirmode == DIRECTORY_MODE_STANDALONE) { | ||||
| 			$r = array(array('site_url' => z_root())); | ||||
| 		} | ||||
| 		else { | ||||
| 			$r = q("select site_url from site where site_flags in ( 1, 2 ) and site_realm = '%s'", | ||||
| 				dbesc(get_directory_realm()) | ||||
| 			); | ||||
| 		} | ||||
| 		if($r) { | ||||
| 			$result['success'] = true; | ||||
| 			$result['directories'] = array(); | ||||
|   | ||||
| @@ -1 +1 @@ | ||||
| 2015-02-01.934 | ||||
| 2015-02-05.936 | ||||
|   | ||||
| @@ -3,8 +3,10 @@ | ||||
| 	clear: both; | ||||
| } | ||||
| .directory-name { | ||||
| 	text-align: center; | ||||
| 	float: left; | ||||
| 	width: 250px; | ||||
| } | ||||
|  | ||||
| .directory-photo { | ||||
| 	margin-left: 25px; | ||||
| } | ||||
|   | ||||
| @@ -12,11 +12,16 @@ | ||||
| 	float: left; | ||||
| } | ||||
|  | ||||
| #event-category-wrap { | ||||
| 	margin-top: 15px; | ||||
| } | ||||
|  | ||||
| .event-cats { | ||||
| 	margin-top: 15px; | ||||
| 	width: 400px; | ||||
| } | ||||
|  | ||||
|  | ||||
| .required { | ||||
| 	float: left; | ||||
| } | ||||
| @@ -27,3 +32,4 @@ | ||||
| #event-nofinish-break { | ||||
| 	margin-bottom: 10px; | ||||
| } | ||||
|  | ||||
|   | ||||
							
								
								
									
										8
									
								
								view/css/mod_rate.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								view/css/mod_rate.css
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | ||||
| #rating-slider { | ||||
|     width: 600px !important; | ||||
| } | ||||
|  | ||||
| #rating-text { | ||||
|     width: 400px; | ||||
|     height: 60px; | ||||
| } | ||||
| @@ -10,3 +10,12 @@ | ||||
| .directory-item { | ||||
| 	margin: 10px; | ||||
| } | ||||
| 
 | ||||
| .rating-value { | ||||
| 	margin-top: 10px; | ||||
| } | ||||
| 
 | ||||
| .prep-rating-value { | ||||
| 	margin-left: 10px; | ||||
| 	font-size: 1.5rem; | ||||
| } | ||||
| @@ -104,3 +104,27 @@ li:hover .group-edit-icon { | ||||
| .chatroomlist td { | ||||
| 	padding: 0 5px 0; | ||||
| } | ||||
|  | ||||
| /* ratings */ | ||||
|  | ||||
| .directory-rating { | ||||
| 	float: right; | ||||
| 	margin-right: 5px; | ||||
| } | ||||
|  | ||||
| .slider-container { | ||||
| 	padding: 15px; | ||||
| } | ||||
|  | ||||
| .rating-text-label { | ||||
| 	margin-top: 30px; | ||||
| } | ||||
|  | ||||
| .directory-rating-text { | ||||
| 	width: 90%; | ||||
| 	margin-left: 5%; | ||||
| } | ||||
|  | ||||
| .directory-rating-submit { | ||||
| 	margin-top: 15px; | ||||
| } | ||||
|   | ||||
| @@ -3,7 +3,40 @@ function dirdetails(hash) { | ||||
| 	$.get('dirprofile' + '?f=&hash=' + hash, function( data ) { | ||||
| 		$.colorbox({ maxWidth: "50%", maxHeight: "75%", html: data }); | ||||
| 	}); | ||||
| } | ||||
|  | ||||
|  | ||||
| var ratingVal = 0; | ||||
| var ratingText = ''; | ||||
| var currentHash = ''; | ||||
|  | ||||
| function fetchRatings(hash) { | ||||
| 	$.get('prate/'+hash, function(data) { | ||||
| 		if(typeof(data.rating) !== 'undefined') { | ||||
| 			ratingVal = data.rating; | ||||
| 			ratingText = data.rating_text; | ||||
| 		} | ||||
| 		buildRatingForm(hash); | ||||
| 	}); | ||||
| } | ||||
|  | ||||
|  | ||||
| function doRatings(hash) { | ||||
| 	fetchRatings(hash); | ||||
| } | ||||
|  | ||||
| function buildRatingForm(hash) { | ||||
| 	var html = '<form id="ratings_form" action="prate" method="post"><input type="hidden" name="target" value="'+hash+'" /><div class="rating-desc">'+aStr['rating_desc']+'</div><input id="dir-rating-range" class="directory-slider" type="text" value="'+ratingVal+'" name="rating" style="display: none;" /><div class="rating-text-label">'+aStr['rating_text']+'<input type="text" name="rating_text" class="directory-rating-text" value="'+ratingText+'" /><br /><input name="submit" class="directory-rating-submit" type="submit" value="'+aStr['submit']+'" onclick="postRatings(); return false;"></form><div class="clear"></div><script>$("#dir-rating-range").jRange({ from: -10, to: 10, step: 1, showLabels: false, showScale: true, scale : [ "-10","-5","0","5","10" ], onstatechange: function(v) { $("#dir-rating-range").val(v); } });</script>'; | ||||
|  | ||||
| 	$.colorbox({maxwidth: "50%", maxHeight: "50%", html: html, close: 'X' }); | ||||
| 	currentHash = hash; | ||||
| } | ||||
|  | ||||
| function postRatings() { | ||||
| 	$.post('prate',$('#ratings_form').serialize(),function(data) { | ||||
| 		$.colorbox.remove(); | ||||
| 		$('#edited-'+currentHash).show(); | ||||
| 	},'json'); | ||||
| } | ||||
|  | ||||
| $(document).ready(function() { | ||||
|   | ||||
							
								
								
									
										4
									
								
								view/js/mod_ratings.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								view/js/mod_ratings.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,4 @@ | ||||
|  | ||||
| $(document).ready(function() { | ||||
| 	collapseHeight(); | ||||
| }); | ||||
							
								
								
									
										34
									
								
								view/js/ratings.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										34
									
								
								view/js/ratings.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,34 @@ | ||||
|  | ||||
| var ratingVal = 0; | ||||
| var ratingText = ''; | ||||
| var currentHash = ''; | ||||
|  | ||||
| function fetchRatings(hash) { | ||||
| 	$.get('prate/'+hash, function(data) { | ||||
| 		if(typeof(data.rating) !== 'undefined') { | ||||
| 			ratingVal = data.rating; | ||||
| 			ratingText = data.rating_text; | ||||
| 		} | ||||
| 		buildRatingForm(hash); | ||||
| 	}); | ||||
| } | ||||
|  | ||||
|  | ||||
| function doRatings(hash) { | ||||
| 	fetchRatings(hash); | ||||
| } | ||||
|  | ||||
| function buildRatingForm(hash) { | ||||
| 	var html = '<form id="ratings_form" action="prate" method="post"><input type="hidden" name="target" value="'+hash+'" /><div class="rating-desc">'+aStr['rating_desc']+'</div><input id="dir-rating-range" class="directory-slider" type="text" value="'+ratingVal+'" name="rating" style="display: none;" /><div class="rating-text-label">'+aStr['rating_text']+'<input type="text" name="rating_text" class="directory-rating-text" value="'+ratingText+'" /><br /><input name="submit" class="directory-rating-submit" type="submit" value="'+aStr['submit']+'" onclick="postRatings(); return false;"></form><div class="clear"></div><script>$("#dir-rating-range").jRange({ from: -10, to: 10, step: 1, showLabels: false, showScale: true, scale : [ "-10","-5","0","5","10" ], onstatechange: function(v) { $("#dir-rating-range").val(v); } });</script>'; | ||||
|  | ||||
| 	$.colorbox({maxwidth: "50%", maxHeight: "50%", html: html, close: 'X' }); | ||||
| 	currentHash = hash; | ||||
| } | ||||
|  | ||||
| function postRatings() { | ||||
| 	$.post('prate',$('#ratings_form').serialize(),function(data) { | ||||
| 		$.colorbox.remove(); | ||||
| 		$('#edited-'+currentHash).show(); | ||||
| 	},'json'); | ||||
| } | ||||
|  | ||||
							
								
								
									
										11275
									
								
								view/nl/messages.po
									
									
									
									
									
								
							
							
						
						
									
										11275
									
								
								view/nl/messages.po
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										2048
									
								
								view/nl/strings.php
									
									
									
									
									
								
							
							
						
						
									
										2048
									
								
								view/nl/strings.php
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										3
									
								
								view/pdl/mod_rate.pdl
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								view/pdl/mod_rate.pdl
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,3 @@ | ||||
| [region=aside] | ||||
| [widget=vcard][/widget] | ||||
| [/region] | ||||
| @@ -1,5 +1,6 @@ | ||||
| [region=aside] | ||||
| [widget=vcard][/widget] | ||||
| [widget=rating][/widget] | ||||
| [widget=suggestions][/widget] | ||||
| [widget=findpeople][/widget] | ||||
| [/region] | ||||
| @@ -575,6 +575,15 @@ footer { | ||||
|  | ||||
| #cboxContent { | ||||
|     color: $dirpopup_txtcol; | ||||
| 	margin: 5px; | ||||
| } | ||||
|  | ||||
| #cboxClose { | ||||
| 	margin: 10px; | ||||
| } | ||||
|  | ||||
| #colorbox { | ||||
| 	margin: 5px; | ||||
| } | ||||
|  | ||||
| #cboxContent a { | ||||
| @@ -762,6 +771,19 @@ footer { | ||||
| 	clear: both; | ||||
| } | ||||
|  | ||||
| a.rateme, div.rateme { | ||||
| 	display: block; | ||||
| 	color: $nav_active_icon_colour; | ||||
| 	background-color: $nav_bg; | ||||
| 	-webkit-border-radius: $radiuspx ; | ||||
| 	-moz-border-radius: $radiuspx; | ||||
| 	border-radius: $radiuspx; | ||||
| 	border: 1px solid $nav_bd; | ||||
| 	padding: 5px; | ||||
| 	font-weight: bold; | ||||
| 	clear: both; | ||||
| } | ||||
|  | ||||
| #pause { | ||||
|   position: fixed; | ||||
|   bottom: 5px; | ||||
| @@ -1176,11 +1198,12 @@ nav .acpopup { | ||||
|  | ||||
|  | ||||
| .required { | ||||
| 	color: #FF0000; | ||||
| 	font-size: 200%; | ||||
| 	color: #ff0000; | ||||
| 	font-size: 1.8rem; | ||||
| 	margin-left: 5px; | ||||
| } | ||||
|  | ||||
|  | ||||
| #event-start-text, #event-finish-text { | ||||
| 	margin-top: 10px; | ||||
| 	margin-bottom: 5px; | ||||
| @@ -1432,16 +1455,22 @@ div.jGrowl div.jGrowl-notification { | ||||
| 	width: 90%; | ||||
| } | ||||
|  | ||||
| a.rconnect { | ||||
| a.rconnect, a.rateme, div.rateme { | ||||
|   color: $nav_active_icon_colour; | ||||
|   text-decoration: none; | ||||
|   font-weight: normal; | ||||
|   outline: none; | ||||
| } | ||||
|  | ||||
| a.rconnect:hover { | ||||
| a.rconnect:hover, a.rateme:hover, div.rateme:hover { | ||||
| 	color: #0080FF; | ||||
| 	text-decoration: none; | ||||
| } | ||||
|  | ||||
| .widget.rateme { | ||||
| 	margin-top: 15px; | ||||
| 	padding: 0; | ||||
| } | ||||
|  | ||||
| /* header */ | ||||
| header { | ||||
| @@ -2080,6 +2109,13 @@ nav .dropdown-menu>li>a:hover,nav .dropdown-menu>li>a:focus{ | ||||
| 	background-color: $item_colour; | ||||
| } | ||||
|  | ||||
| nav ul li .undefined,  | ||||
| nav ul li .notify-seen, | ||||
| nav ul li .notify-unseen | ||||
|  { | ||||
|     max-height: 3rem; | ||||
| } | ||||
|  | ||||
| /* bootstrap overrides */ | ||||
|  | ||||
| blockquote { | ||||
|   | ||||
| @@ -22,11 +22,13 @@ | ||||
| 			</label> | ||||
| 		</div> | ||||
| 		{{/if}} | ||||
| 		{{if !$isadir}} | ||||
| 		<div id="attach-edit-activity" class="btn-group" data-toggle="buttons"> | ||||
| 			<label class="btn btn-default btn-xs" title="{{$activity_btn_title}}"> | ||||
| 				<input type="checkbox" autocomplete="off" name="no_activity" value="1"><i class="icon-ban-circle jot-icons"></i> | ||||
| 			</label> | ||||
| 		</div> | ||||
| 		{{/if}} | ||||
| 		<div id="attach-edit-perms" class="btn-group"> | ||||
| 			<button id="dbtn-acl" class="btn btn-default btn-xs" data-toggle="modal" data-target="#aclModal" title="{{$permset}}" onclick="return false;"> | ||||
| 				<i id="jot-perms-icon" class="icon-{{$lockstate}} jot-icons"></i> | ||||
|   | ||||
| @@ -1,8 +1,8 @@ | ||||
| <div class="directory-item lframe" id="directory-item-{{$entry.id}}" > | ||||
| <div class="directory-item lframe{{if $entry.safe}} safe{{/if}}" id="directory-item-{{$entry.hash}}" > | ||||
|  | ||||
| <div class="contact-photo-wrapper" id="directory-photo-wrapper-{{$entry.id}}" > | ||||
| <div class="contact-photo" id="directory-photo-{{$entry.id}}" > | ||||
| <a href="{{$entry.profile_link}}" class="directory-profile-link" id="directory-profile-link-{{$entry.id}}" ><img class="directory-photo-img" src="{{$entry.photo}}" alt="{{$entry.alttext}}" title="{{$entry.alttext}}" /></a> | ||||
| <div class="contact-photo-wrapper" id="directory-photo-wrapper-{{$entry.hash}}" > | ||||
| <div class="contact-photo" id="directory-photo-{{$entry.hash}}" > | ||||
| <a href="{{$entry.profile_link}}" class="directory-profile-link" id="directory-profile-link-{{$entry.hash}}" ><img class="directory-photo-img" src="{{$entry.photo}}" alt="{{$entry.alttext}}" title="{{$entry.alttext}}" /></a> | ||||
| {{if $entry.connect}} | ||||
| <div class="directory-connect btn btn-default"><a href="{{$entry.connect}}"><i class="icon-plus connect-icon"></i> {{$entry.conn_label}}</a></div> | ||||
| {{/if}} | ||||
| @@ -13,19 +13,12 @@ | ||||
| </div> | ||||
|  | ||||
| <div class='contact-info'> | ||||
| <div class="contact-name" id="directory-name-{{$entry.id}}"  ><a href='{{$entry.profile_link}}' >{{$entry.name}}</a>{{if $entry.online}} <i class="icon-asterisk online-now" title="{{$entry.online}}"></i>{{/if}}</div> | ||||
| <div class="contact-name" id="directory-name-{{$entry.hash}}"  ><a href='{{$entry.profile_link}}' >{{$entry.name}}</a>{{if $entry.online}} <i class="icon-asterisk online-now" title="{{$entry.online}}"></i>{{/if}}</div> | ||||
|  | ||||
| {{if $entry.rateme}} | ||||
| <div id="dir-rating-wrapper-{{$entry.id}}" style="float:right; width: 20%;"> | ||||
| 62 ratings<br /> | ||||
| <div id="dir-rating-slider-{{$entry.id}}" class="dir-slider" style="height: 32px; margin-right:10px;"> | ||||
| <input id="dir-rating-range-{{$entry.id}}" type="text" value="0" name="fake-rating-{{$entry.id}}" style="display: none;"> | ||||
| {{if $entry.viewrate}} | ||||
| <div id="dir-rating-wrapper-{{$entry.hash}}" class="directory-rating" >{{if $entry.total_ratings}}<a href="ratings/{{$entry.hash}}"><button class="btn btn-default">{{$entry.total_ratings}}</button></a>{{/if}} | ||||
| {{if $entry.canrate}}<button class="btn btn-default" onclick="doRatings('{{$entry.hash}}'); return false;" ><i class="icon-pencil"></i></button><span class="required" id="edited-{{$entry.hash}}" style="display: none;" >*</span>{{/if}} | ||||
| </div> | ||||
| </div> | ||||
| <div class="clear"></div> | ||||
| <script> | ||||
| $("#dir-rating-range-{{$entry.id}}").jRange({ from: -10, to: 10, step: 1, width:'100%', showLabels: false, showScale: true, scale : [ '-10','-5','0','5','10' ], onstatechange: function(v) { $("#contact-rating-mirror").val(v); } }); | ||||
| </script> | ||||
| {{/if}} | ||||
| {{if $entry.public_forum}} | ||||
| <div class="contact-forum"> | ||||
|   | ||||
| @@ -16,6 +16,10 @@ | ||||
| 		'permschange' : "{{$permschange}}", | ||||
| 		'closeAll'    : "{{$closeAll}}", | ||||
| 		'nothingnew'  : "{{$nothingnew}}", | ||||
| 		'rating_desc' : "{{$rating_desc}}", | ||||
| 		'rating_val'  : "{{$rating_val}}", | ||||
| 		'rating_text' : "{{$rating_text}}", | ||||
| 		'submit'      : "{{$submit}}", | ||||
|  | ||||
| 		't01' : "{{$t01}}", | ||||
| 		't02' : "{{$t02}}", | ||||
|   | ||||
| @@ -10,11 +10,12 @@ | ||||
| <a href="{{$r.xchan_url}}" class="directory-profile-link" id="directory-profile-link-{{$r.xchan_hash}}" ><img class="directory-photo-img" src="{{$r.xchan_photo_m}}" alt="{{$r.xchan_addr}}" title="{{$r.xchan_addr}}" /></a> | ||||
| </div> | ||||
| </div> | ||||
| <div class="prep-details"> | ||||
| <div class="prep-details contact-info"> | ||||
| <a href="{{$r.xchan_url}}" class="directory-profile-link" id="directory-profile-link-{{$r.xchan_hash}}" ><div class="contact-name">{{$r.xchan_name}}</div></a> | ||||
| {{$rating_lbl}} {{$r.xlink_rating}} | ||||
| <div class="rating-value">{{$rating_lbl}} <span class="prep-rating-value">{{$r.xlink_rating}}</span></div> | ||||
| {{if $r.xlink_rating_text}} | ||||
| {{$rating_text_label}} {{$r.xlink_rating_text}} | ||||
| <div class="rating-text">{{$rating_text_label}} {{$r.xlink_rating_text}} | ||||
| </div> | ||||
| {{/if}} | ||||
| </div> | ||||
| <div class="clear"></div> | ||||
|   | ||||
| @@ -51,9 +51,12 @@ | ||||
| <a href="{{$connect_url}}" class="rconnect"><i class="icon-plus connect-icon"></i> {{$connect}}</a> | ||||
| {{/if}} | ||||
|  | ||||
| {{$rating}} | ||||
|  | ||||
| </div> | ||||
| <div id="vcard-end"></div> | ||||
|  | ||||
|  | ||||
| {{$chanmenu}} | ||||
|  | ||||
| {{$contact_block}} | ||||
|   | ||||
							
								
								
									
										22
									
								
								view/tpl/rating_form.tpl
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								view/tpl/rating_form.tpl
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,22 @@ | ||||
| <h3>{{$header}}</h3> | ||||
|  | ||||
| <div class="rating-target-name">{{$tgt_name}}</div> | ||||
|  | ||||
| <h3>{{$lbl_rating}}</h3> | ||||
|  | ||||
| <form action="rate" method="post"> | ||||
|  | ||||
| {{$rating}} | ||||
|  | ||||
| <input type="hidden" name="execute" value="1" /> | ||||
| <input type="hidden" name="target" value="{{$target}}" /> | ||||
|  | ||||
| <input id="contact-rating-mirror" type="hidden" name="rating" value="{{$rating_val}}" /> | ||||
| <h3 class="abook-rating-text-desc">{{$lbl_rating_txt}}</h3> | ||||
| <textarea name="rating_text" id="rating-text" >{{$rating_txt}}</textarea> | ||||
|  | ||||
| <div class="clear"></div> | ||||
|  | ||||
| <input class="contact-edit-submit" type="submit" name="done" value="{{$submit}}" /> | ||||
|  | ||||
| </form> | ||||
| @@ -5,16 +5,7 @@ | ||||
|  | ||||
|  | ||||
| {{if $mode != 'mail'}}	 | ||||
| <div id="profile-extra-links"> | ||||
| <ul> | ||||
| {{if $connect}} | ||||
| 	<li><a id="follow-link" href="follow?f=&url={{$follow}}">{{$connect}}</a></li> | ||||
| 	<a href="follow?f=&url={{$follow}}" class="rconnect"><i class="icon-plus connect-icon"></i> {{$connect}}</a> | ||||
| {{/if}} | ||||
| {{if $newwin}} | ||||
| 	<li><a id="visit-chan-link" href="{{$url}}" title="{{$newtit}}" target="_blank" >{{$newwin}}</a></li> | ||||
| {{/if}} | ||||
| </ul> | ||||
|  | ||||
|  | ||||
| </div> | ||||
| {{/if}} | ||||
|   | ||||
		Reference in New Issue
	
	Block a user