Version Description
Download this release
Release Info
Developer | nsinelnikov |
Plugin | Ultimate Member – User Profile & Membership Plugin |
Version | 2.0.12 |
Comparing to | |
See all releases |
Code changes from version 2.0.17 to 2.0.12
- assets/css/um-profile.css +12 -24
- assets/css/um-responsive.css +0 -8
- assets/js/um-gdpr.js +0 -22
- assets/js/um-gdpr.min.js +0 -1
- assets/js/um-scripts.js +0 -4
- includes/admin/class-admin.php +0 -24
- includes/admin/core/class-admin-gdpr.php +0 -316
- includes/admin/core/class-admin-menu.php +0 -15
- includes/admin/core/class-admin-notices.php +2 -33
- includes/admin/core/class-admin-settings.php +3 -5
- includes/admin/core/class-admin-upgrade.php +6 -34
- includes/admin/core/packages/2.0-beta1/email_templates.php +2 -2
- includes/admin/core/packages/2.0-beta1/menus.php +1 -7
- includes/admin/templates/dashboard/cache.php +7 -6
- includes/admin/templates/dashboard/upgrade-request.php +0 -6
- includes/admin/templates/form/login_customize.php +1 -1
- includes/admin/templates/form/profile_customize.php +1 -1
- includes/admin/templates/form/register_customize.php +1 -1
- includes/admin/templates/form/register_gdpr.php +0 -71
- includes/admin/templates/gdpr.php +0 -40
- includes/class-dependencies.php +0 -1
- includes/class-init.php +43 -49
- includes/core/class-access.php +1 -62
- includes/core/class-account.php +3 -2
- includes/core/class-builtin.php +1 -1
- includes/core/class-enqueue.php +1 -3
- includes/core/class-fields.php +36 -91
- includes/core/class-form.php +14 -2
- includes/core/class-gdpr.php +0 -86
- includes/core/class-mail.php +18 -6
- includes/core/class-permalinks.php +18 -4
- includes/core/class-profile.php +0 -7
- includes/core/class-rest-api.php +9 -9
- includes/core/class-user.php +63 -104
- includes/core/um-actions-core.php +1 -3
- includes/core/um-actions-form.php +5 -6
- includes/core/um-actions-password.php +19 -0
- includes/core/um-actions-profile.php +23 -34
- includes/core/um-actions-register.php +6 -45
- includes/core/um-filters-avatars.php +59 -0
- includes/core/um-filters-fields.php +11 -63
- includes/core/um-navmenu.php +2 -3
- includes/um-short-functions.php +146 -168
- readme.txt +1 -50
- templates/gdpr-register.php +0 -44
- ultimate-member.php +1 -1
assets/css/um-profile.css
CHANGED
@@ -393,31 +393,13 @@ font-weight: normal;
|
|
393 |
border-bottom: 0 !important;
|
394 |
}
|
395 |
|
396 |
-
.um-profile-nav-item.without-icon a {
|
397 |
-
|
398 |
-
}
|
399 |
-
.um-profile-nav-item.without-icon span.title {
|
400 |
-
padding-left: 0;
|
401 |
-
}
|
402 |
-
.um-profile-nav-item.without-icon i {
|
403 |
-
display: none;
|
404 |
-
}
|
405 |
|
406 |
-
.um-profile-nav-item a:hover {
|
407 |
-
|
408 |
-
}
|
409 |
-
.um-profile-nav-item i {
|
410 |
-
font-size: 18px;
|
411 |
-
height: 18px;
|
412 |
-
line-height: 18px;
|
413 |
-
position: absolute;
|
414 |
-
display: block;
|
415 |
-
top: 8px;
|
416 |
-
left: 10px;
|
417 |
-
}
|
418 |
-
.um-profile-nav-item span.title {
|
419 |
-
padding-left: 5px;
|
420 |
-
}
|
421 |
.um-profile-nav-item span.count {
|
422 |
font-size: 12px;
|
423 |
font-weight: 300;
|
@@ -563,4 +545,10 @@ font-weight: normal;
|
|
563 |
|
564 |
.um-profile.um-viewing .um-field-checkbox, .um-profile.um-viewing .um-field-radio{
|
565 |
cursor: default !important;
|
|
|
|
|
|
|
|
|
|
|
|
|
566 |
}
|
393 |
border-bottom: 0 !important;
|
394 |
}
|
395 |
|
396 |
+
.um-profile-nav-item.without-icon a {padding-left: 10px}
|
397 |
+
.um-profile-nav-item.without-icon span.title {padding-left: 0}
|
398 |
+
.um-profile-nav-item.without-icon i {display: none}
|
|
|
|
|
|
|
|
|
|
|
|
|
399 |
|
400 |
+
.um-profile-nav-item a:hover {background: #555}
|
401 |
+
.um-profile-nav-item i {font-size: 18px;height: 18px;line-height: 18px;position: absolute;display: block;top: 8px;left: 10px}
|
402 |
+
.um-profile-nav-item span.title {padding-left: 5px}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
403 |
.um-profile-nav-item span.count {
|
404 |
font-size: 12px;
|
405 |
font-weight: 300;
|
545 |
|
546 |
.um-profile.um-viewing .um-field-checkbox, .um-profile.um-viewing .um-field-radio{
|
547 |
cursor: default !important;
|
548 |
+
}
|
549 |
+
|
550 |
+
@media (min-width: 880px) {
|
551 |
+
.um-profile-nav-item .um-tip-n {
|
552 |
+
display: none !important;
|
553 |
+
}
|
554 |
}
|
assets/css/um-responsive.css
CHANGED
@@ -6,14 +6,6 @@
|
|
6 |
display: none;
|
7 |
}
|
8 |
|
9 |
-
.um-profile-nav-item a.uimob340-show,
|
10 |
-
.um-profile-nav-item a.uimob500-show,
|
11 |
-
.um-profile-nav-item a.uimob800-show,
|
12 |
-
.um-profile-nav-item a.uimob960-show
|
13 |
-
{
|
14 |
-
display: none;
|
15 |
-
}
|
16 |
-
|
17 |
div.uimob340 .uimob340-show,
|
18 |
div.uimob500 .uimob500-show,
|
19 |
div.uimob800 .uimob800-show,
|
6 |
display: none;
|
7 |
}
|
8 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
9 |
div.uimob340 .uimob340-show,
|
10 |
div.uimob500 .uimob500-show,
|
11 |
div.uimob800 .uimob800-show,
|
assets/js/um-gdpr.js
DELETED
@@ -1,22 +0,0 @@
|
|
1 |
-
(function( $ ) {
|
2 |
-
'use strict';
|
3 |
-
|
4 |
-
$(document).on('click', "a.um-toggle-gdpr" ,function() {
|
5 |
-
|
6 |
-
var me = jQuery(this);
|
7 |
-
|
8 |
-
$( ".um-gdpr-content" ).toggle( "fast", function() {
|
9 |
-
if( $( ".um-gdpr-content" ).is(':visible') ){
|
10 |
-
me.text( me.data('toggle-hide') );
|
11 |
-
}
|
12 |
-
|
13 |
-
if( $( ".um-gdpr-content" ).is(':hidden') ){
|
14 |
-
me.text( me.data('toggle-show') );
|
15 |
-
}
|
16 |
-
|
17 |
-
});
|
18 |
-
|
19 |
-
});
|
20 |
-
|
21 |
-
|
22 |
-
})( jQuery );
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
assets/js/um-gdpr.min.js
DELETED
@@ -1 +0,0 @@
|
|
1 |
-
!function(t){"use strict";t(document).on("click","a.um-toggle-gdpr",function(){var e=jQuery(this);t(".um-gdpr-content").toggle("fast",function(){t(".um-gdpr-content").is(":visible")&&e.text(e.data("toggle-hide")),t(".um-gdpr-content").is(":hidden")&&e.text(e.data("toggle-show"))})})}(jQuery);
|
|
assets/js/um-scripts.js
CHANGED
@@ -1,7 +1,3 @@
|
|
1 |
-
/*jQuery('body').on('error', '.um-avatar', function() {
|
2 |
-
if( jQuery(this).data('load-error') != undefined ) return;
|
3 |
-
jQuery(this).data('load-error', '1').attr('src', jQuery(this).data('default'));
|
4 |
-
});*/
|
5 |
jQuery(document).ready(function() {
|
6 |
|
7 |
jQuery(document).on('click', '.um-dropdown a', function(e){
|
|
|
|
|
|
|
|
|
1 |
jQuery(document).ready(function() {
|
2 |
|
3 |
jQuery(document).on('click', '.um-dropdown a', function(e){
|
includes/admin/class-admin.php
CHANGED
@@ -35,7 +35,6 @@ if ( ! class_exists( 'um\admin\Admin' ) ) {
|
|
35 |
|
36 |
add_action( 'um_admin_do_action__user_cache', array( &$this, 'user_cache' ) );
|
37 |
add_action( 'um_admin_do_action__purge_temp', array( &$this, 'purge_temp' ) );
|
38 |
-
add_action( 'um_admin_do_action__manual_upgrades_request', array( &$this, 'manual_upgrades_request' ) );
|
39 |
add_action( 'um_admin_do_action__duplicate_form', array( &$this, 'duplicate_form' ) );
|
40 |
add_action( 'um_admin_do_action__um_language_downloader', array( &$this, 'um_language_downloader' ) );
|
41 |
add_action( 'um_admin_do_action__um_hide_locale_notice', array( &$this, 'um_hide_notice' ) );
|
@@ -49,29 +48,6 @@ if ( ! class_exists( 'um\admin\Admin' ) ) {
|
|
49 |
}
|
50 |
|
51 |
|
52 |
-
function manual_upgrades_request() {
|
53 |
-
if ( ! is_admin() || ! current_user_can( 'manage_options' ) ) {
|
54 |
-
die();
|
55 |
-
}
|
56 |
-
|
57 |
-
$last_request = get_option( 'um_last_manual_upgrades_request', false );
|
58 |
-
|
59 |
-
if ( empty( $last_request ) || time() > $last_request + DAY_IN_SECONDS ) {
|
60 |
-
|
61 |
-
delete_transient( 'update_plugins' );
|
62 |
-
delete_site_transient( 'update_plugins' );
|
63 |
-
|
64 |
-
UM()->plugin_updater()->um_checklicenses();
|
65 |
-
|
66 |
-
update_option( 'um_last_manual_upgrades_request', time() );
|
67 |
-
|
68 |
-
$url = add_query_arg( array( 'page' => 'ultimatemember', 'update' => 'got_updates' ), admin_url( 'admin.php' ) );
|
69 |
-
} else {
|
70 |
-
$url = add_query_arg( array( 'page' => 'ultimatemember', 'update' => 'often_updates' ), admin_url( 'admin.php' ) );
|
71 |
-
}
|
72 |
-
exit( wp_redirect( $url ) );
|
73 |
-
}
|
74 |
-
|
75 |
|
76 |
/**
|
77 |
* Clear all users cache
|
35 |
|
36 |
add_action( 'um_admin_do_action__user_cache', array( &$this, 'user_cache' ) );
|
37 |
add_action( 'um_admin_do_action__purge_temp', array( &$this, 'purge_temp' ) );
|
|
|
38 |
add_action( 'um_admin_do_action__duplicate_form', array( &$this, 'duplicate_form' ) );
|
39 |
add_action( 'um_admin_do_action__um_language_downloader', array( &$this, 'um_language_downloader' ) );
|
40 |
add_action( 'um_admin_do_action__um_hide_locale_notice', array( &$this, 'um_hide_notice' ) );
|
48 |
}
|
49 |
|
50 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
51 |
|
52 |
/**
|
53 |
* Clear all users cache
|
includes/admin/core/class-admin-gdpr.php
DELETED
@@ -1,316 +0,0 @@
|
|
1 |
-
<?php
|
2 |
-
namespace um\admin\core;
|
3 |
-
|
4 |
-
// Exit if accessed directly.
|
5 |
-
if ( ! defined( 'ABSPATH' ) ) exit;
|
6 |
-
|
7 |
-
|
8 |
-
if ( ! class_exists( 'um\admin\core\Admin_GDPR' ) ) {
|
9 |
-
|
10 |
-
|
11 |
-
/**
|
12 |
-
* Class Admin_GDPR
|
13 |
-
* @package um\admin\core
|
14 |
-
*/
|
15 |
-
class Admin_GDPR {
|
16 |
-
|
17 |
-
/**
|
18 |
-
* @var array
|
19 |
-
*/
|
20 |
-
var $meta_associations = array();
|
21 |
-
|
22 |
-
|
23 |
-
/**
|
24 |
-
* Admin_GDPR constructor.
|
25 |
-
*/
|
26 |
-
function __construct() {
|
27 |
-
add_action( 'init', array( &$this, 'init_fields' ), 10 );
|
28 |
-
add_action( 'admin_init', array( &$this, 'plugin_add_suggested_privacy_content' ), 20 );
|
29 |
-
add_filter( 'wp_privacy_personal_data_exporters', array( &$this, 'plugin_register_exporters' ) );
|
30 |
-
add_filter( 'wp_privacy_personal_data_erasers', array( &$this, 'plugin_register_erasers' ) );
|
31 |
-
|
32 |
-
add_action( 'um_admin_custom_register_metaboxes', array( &$this, 'add_metabox_register' ) );
|
33 |
-
}
|
34 |
-
|
35 |
-
|
36 |
-
/**
|
37 |
-
*
|
38 |
-
*/
|
39 |
-
function add_metabox_register() {
|
40 |
-
add_meta_box(
|
41 |
-
"um-admin-form-register_gdpr",
|
42 |
-
__( 'Privacy Policy', 'ultimate-member' ),
|
43 |
-
array( UM()->metabox(), 'load_metabox_form' ),
|
44 |
-
'um_form',
|
45 |
-
'side',
|
46 |
-
'default'
|
47 |
-
);
|
48 |
-
}
|
49 |
-
|
50 |
-
|
51 |
-
/**
|
52 |
-
*
|
53 |
-
*/
|
54 |
-
function init_fields() {
|
55 |
-
$this->meta_associations = array(
|
56 |
-
|
57 |
-
'account_status' => __( 'Account Status', 'ultimate-member' ),
|
58 |
-
'submitted' => __( 'Submitted data on Registration', 'ultimate-member' ),
|
59 |
-
'form_id' => __( 'Registration Form ID', 'ultimate-member' ),
|
60 |
-
'timestamp' => __( 'Registration Timestamp', 'ultimate-member' ),
|
61 |
-
'request' => __( 'Registration Request', 'ultimate-member' ),
|
62 |
-
'_wpnonce' => __( 'Registration Nonce', 'ultimate-member' ),
|
63 |
-
'_wp_http_referer' => __( 'Registration HTTP referer', 'ultimate-member' ),
|
64 |
-
'role' => __( 'Community Role', 'ultimate-member' ),
|
65 |
-
'um_user_profile_url_slug_user_login' => __( 'Profile Slug "Username"', 'ultimate-member' ),
|
66 |
-
'um_user_profile_url_slug_name' => __( 'Profile Slug "First and Last Name with \'.\'"', 'ultimate-member' ),
|
67 |
-
'um_user_profile_url_slug_name_dash' => __( 'Profile Slug "First and Last Name with \'-\'"', 'ultimate-member' ),
|
68 |
-
'um_user_profile_url_slug_name_plus' => __( 'Profile Slug "First and Last Name with \'+\'"', 'ultimate-member' ),
|
69 |
-
'um_user_profile_url_slug_user_id' => __( 'Profile Slug "User ID"', 'ultimate-member' ),
|
70 |
-
'_um_last_login' => __( 'Last Login Timestamp', 'ultimate-member' ),
|
71 |
-
|
72 |
-
//Private content extension
|
73 |
-
'_um_private_content_post_id' => __( 'Private Content Post ID', 'ultimate-member' ),
|
74 |
-
|
75 |
-
//Verified Users extension
|
76 |
-
'_um_verified' => __( 'Verified Account', 'ultimate-member' ),
|
77 |
-
|
78 |
-
//Terms & Conditions extension
|
79 |
-
'use_terms_conditions_agreement' => __( 'Terms&Conditions Agreement', 'ultimate-member' ),
|
80 |
-
|
81 |
-
//GDPR extension
|
82 |
-
'use_gdpr_agreement' => __( 'Privacy Policy Agreement', 'ultimate-member' ),
|
83 |
-
|
84 |
-
|
85 |
-
);
|
86 |
-
|
87 |
-
$all_fields = UM()->builtin()->all_user_fields( null, true );
|
88 |
-
unset( $all_fields[0] );
|
89 |
-
|
90 |
-
$all_fields = array_map( function( $value ) {
|
91 |
-
return $value['title'];
|
92 |
-
}, $all_fields );
|
93 |
-
|
94 |
-
$this->meta_associations = array_merge( $this->meta_associations, $all_fields );
|
95 |
-
|
96 |
-
/**
|
97 |
-
* UM hook
|
98 |
-
*
|
99 |
-
* @type filter
|
100 |
-
* @title um_gdpr_meta_associations
|
101 |
-
* @description Exclude taxonomies for UM
|
102 |
-
* @input_vars
|
103 |
-
* [{"var":"$meta_associations","type":"array","desc":"Meta Keys Titles"}]
|
104 |
-
* @change_log
|
105 |
-
* ["Since: 2.0.14"]
|
106 |
-
* @usage
|
107 |
-
* <?php add_filter( 'um_gdpr_meta_associations', 'function_name', 10, 1 ); ?>
|
108 |
-
* @example
|
109 |
-
* <?php
|
110 |
-
* add_filter( 'um_gdpr_meta_associations', 'my_gdpr_meta_associations', 10, 1 );
|
111 |
-
* function my_gdpr_meta_associations( $meta_associations ) {
|
112 |
-
* // your code here
|
113 |
-
* return $meta_associations;
|
114 |
-
* }
|
115 |
-
* ?>
|
116 |
-
*/
|
117 |
-
$this->meta_associations = apply_filters( 'um_gdpr_meta_associations', $this->meta_associations );
|
118 |
-
}
|
119 |
-
|
120 |
-
|
121 |
-
/**
|
122 |
-
* Return the default suggested privacy policy content.
|
123 |
-
*
|
124 |
-
* @return string The default policy content.
|
125 |
-
*/
|
126 |
-
function plugin_get_default_privacy_content() {
|
127 |
-
ob_start();
|
128 |
-
|
129 |
-
include UM()->admin()->templates_path . 'gdpr.php';
|
130 |
-
|
131 |
-
return ob_get_clean();
|
132 |
-
}
|
133 |
-
|
134 |
-
|
135 |
-
/**
|
136 |
-
* Add the suggested privacy policy text to the policy postbox.
|
137 |
-
*/
|
138 |
-
function plugin_add_suggested_privacy_content() {
|
139 |
-
$content = $this->plugin_get_default_privacy_content();
|
140 |
-
wp_add_privacy_policy_content( ultimatemember_plugin_name, $content );
|
141 |
-
}
|
142 |
-
|
143 |
-
|
144 |
-
/**
|
145 |
-
* Register exporter for Plugin user data.
|
146 |
-
*
|
147 |
-
* @see https://github.com/allendav/wp-privacy-requests/blob/master/EXPORT.md
|
148 |
-
*
|
149 |
-
* @param $exporters
|
150 |
-
*
|
151 |
-
* @return array
|
152 |
-
*/
|
153 |
-
function plugin_register_exporters( $exporters ) {
|
154 |
-
$exporters[] = array(
|
155 |
-
'exporter_friendly_name' => ultimatemember_plugin_name,
|
156 |
-
'callback' => array( &$this, 'data_exporter' )
|
157 |
-
);
|
158 |
-
return $exporters;
|
159 |
-
}
|
160 |
-
|
161 |
-
|
162 |
-
/**
|
163 |
-
* Get user metadata in key => value array
|
164 |
-
*
|
165 |
-
*
|
166 |
-
* @param $user_id
|
167 |
-
*
|
168 |
-
* @return array
|
169 |
-
*/
|
170 |
-
function get_metadata( $user_id ) {
|
171 |
-
global $wpdb;
|
172 |
-
|
173 |
-
$metadata = $wpdb->get_results( $wpdb->prepare(
|
174 |
-
"SELECT meta_key, meta_value
|
175 |
-
FROM {$wpdb->usermeta}
|
176 |
-
WHERE user_id = %d",
|
177 |
-
$user_id
|
178 |
-
), ARRAY_A );
|
179 |
-
|
180 |
-
$filtered = array();
|
181 |
-
foreach ( $metadata as $data ) {
|
182 |
-
if ( in_array( $data['meta_key'], array_keys( $this->meta_associations ) ) ) {
|
183 |
-
$filtered[] = array(
|
184 |
-
'key' => $data['meta_key'],
|
185 |
-
'name' => $this->meta_associations[ $data['meta_key'] ],
|
186 |
-
//'value' => maybe_unserialize( $data['meta_value'] ),
|
187 |
-
'value' => $data['meta_value'],
|
188 |
-
);
|
189 |
-
}
|
190 |
-
}
|
191 |
-
|
192 |
-
return $filtered;
|
193 |
-
}
|
194 |
-
|
195 |
-
|
196 |
-
/**
|
197 |
-
* Exporter for Plugin user data.
|
198 |
-
*
|
199 |
-
* @see https://github.com/allendav/wp-privacy-requests/blob/master/EXPORT.md
|
200 |
-
*
|
201 |
-
* @param $email_address
|
202 |
-
* @param int $page
|
203 |
-
*
|
204 |
-
* @return array
|
205 |
-
*/
|
206 |
-
function data_exporter( $email_address, $page = 1 ) {
|
207 |
-
$export_items = array();
|
208 |
-
$user = get_user_by( 'email', $email_address );
|
209 |
-
|
210 |
-
if ( $user && $user->ID ) {
|
211 |
-
// Most item IDs should look like postType-postID
|
212 |
-
// If you don't have a post, comment or other ID to work with,
|
213 |
-
// use a unique value to avoid having this item's export
|
214 |
-
// combined in the final report with other items of the same id
|
215 |
-
$item_id = "ultimate-member-{$user->ID}";
|
216 |
-
|
217 |
-
// Core group IDs include 'comments', 'posts', etc.
|
218 |
-
// But you can add your own group IDs as needed
|
219 |
-
$group_id = 'ultimate-member';
|
220 |
-
|
221 |
-
// Optional group label. Core provides these for core groups.
|
222 |
-
// If you define your own group, the first exporter to
|
223 |
-
// include a label will be used as the group label in the
|
224 |
-
// final exported report
|
225 |
-
$group_label = ultimatemember_plugin_name;
|
226 |
-
|
227 |
-
// Plugins can add as many items in the item data array as they want
|
228 |
-
//$data = array();
|
229 |
-
|
230 |
-
$data = $this->get_metadata( $user->ID );
|
231 |
-
|
232 |
-
if ( ! empty( $data ) ) {
|
233 |
-
// Add this group of items to the exporters data array.
|
234 |
-
$export_items[] = array(
|
235 |
-
'group_id' => $group_id,
|
236 |
-
'group_label' => $group_label,
|
237 |
-
'item_id' => $item_id,
|
238 |
-
'data' => $data,
|
239 |
-
);
|
240 |
-
}
|
241 |
-
}
|
242 |
-
// Returns an array of exported items for this pass, but also a boolean whether this exporter is finished.
|
243 |
-
//If not it will be called again with $page increased by 1.
|
244 |
-
return array(
|
245 |
-
'data' => $export_items,
|
246 |
-
'done' => true,
|
247 |
-
);
|
248 |
-
}
|
249 |
-
|
250 |
-
|
251 |
-
/**
|
252 |
-
* Register eraser for Plugin user data.
|
253 |
-
*
|
254 |
-
* @param array $erasers
|
255 |
-
*
|
256 |
-
* @return array
|
257 |
-
*/
|
258 |
-
function plugin_register_erasers( $erasers = array() ) {
|
259 |
-
$erasers[] = array(
|
260 |
-
'eraser_friendly_name' => ultimatemember_plugin_name,
|
261 |
-
'callback' => array( &$this, 'data_eraser' )
|
262 |
-
);
|
263 |
-
return $erasers;
|
264 |
-
}
|
265 |
-
|
266 |
-
|
267 |
-
/**
|
268 |
-
* Eraser for Plugin user data.
|
269 |
-
*
|
270 |
-
* @param $email_address
|
271 |
-
* @param int $page
|
272 |
-
*
|
273 |
-
* @return array
|
274 |
-
*/
|
275 |
-
function data_eraser( $email_address, $page = 1 ) {
|
276 |
-
if ( empty( $email_address ) ) {
|
277 |
-
return array(
|
278 |
-
'items_removed' => false,
|
279 |
-
'items_retained' => false,
|
280 |
-
'messages' => array(),
|
281 |
-
'done' => true,
|
282 |
-
);
|
283 |
-
}
|
284 |
-
|
285 |
-
$user = get_user_by( 'email', $email_address );
|
286 |
-
$messages = array();
|
287 |
-
$items_removed = false;
|
288 |
-
$items_retained = false;
|
289 |
-
|
290 |
-
if ( $user && $user->ID ) {
|
291 |
-
$data = $this->get_metadata( $user->ID );
|
292 |
-
|
293 |
-
foreach ( $data as $metadata ) {
|
294 |
-
$deleted = delete_user_meta( $user->ID, $metadata['key'] );
|
295 |
-
if ( $deleted ) {
|
296 |
-
$items_removed = true;
|
297 |
-
} else {
|
298 |
-
$messages[] = sprintf( __( 'Your %s was unable to be removed at this time.', 'ultimate-member' ), $metadata['name'] );
|
299 |
-
$items_retained = true;
|
300 |
-
}
|
301 |
-
}
|
302 |
-
}
|
303 |
-
|
304 |
-
// Returns an array of exported items for this pass, but also a boolean whether this exporter is finished.
|
305 |
-
//If not it will be called again with $page increased by 1.
|
306 |
-
return array(
|
307 |
-
'items_removed' => $items_removed,
|
308 |
-
'items_retained' => $items_retained,
|
309 |
-
'messages' => $messages,
|
310 |
-
'done' => true,
|
311 |
-
);
|
312 |
-
}
|
313 |
-
|
314 |
-
}
|
315 |
-
|
316 |
-
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
includes/admin/core/class-admin-menu.php
CHANGED
@@ -206,7 +206,6 @@ if ( ! class_exists( 'um\admin\core\Admin_Menu' ) ) {
|
|
206 |
add_meta_box( 'um-metaboxes-mainbox-1', __( 'Latest from our blog', 'ultimate-member' ), array( &$this, 'um_news' ), $this->pagehook, 'normal', 'core' );
|
207 |
|
208 |
add_meta_box( 'um-metaboxes-sidebox-1', __( 'Purge Temp Files', 'ultimate-member' ), array( &$this, 'purge_temp' ), $this->pagehook, 'side', 'core' );
|
209 |
-
|
210 |
add_meta_box( 'um-metaboxes-sidebox-2', __( 'User Cache', 'ultimate-member' ), array( &$this, 'user_cache' ), $this->pagehook, 'side', 'core' );
|
211 |
|
212 |
if ( $this->language_avaialable_not_installed() ) {
|
@@ -216,12 +215,6 @@ if ( ! class_exists( 'um\admin\core\Admin_Menu' ) ) {
|
|
216 |
} else if ( $this->language_not_available() ) {
|
217 |
add_meta_box( 'um-metaboxes-sidebox-2', __( 'Language', 'ultimate-member' ), array( &$this, 'ct_language' ), $this->pagehook, 'side', 'core' );
|
218 |
}
|
219 |
-
|
220 |
-
//If there are active and licensed extensions - show metabox for upgrade it
|
221 |
-
$exts = UM()->plugin_updater()->um_get_active_plugins();
|
222 |
-
if ( 0 < count( $exts ) ) {
|
223 |
-
add_meta_box( 'um-metaboxes-sidebox-3', __( 'Upgrade\'s Manual Request', 'ultimate-member' ), array( &$this, 'upgrade_request' ), $this->pagehook, 'side', 'core' );
|
224 |
-
}
|
225 |
}
|
226 |
|
227 |
|
@@ -276,14 +269,6 @@ if ( ! class_exists( 'um\admin\core\Admin_Menu' ) ) {
|
|
276 |
}
|
277 |
|
278 |
|
279 |
-
/**
|
280 |
-
*
|
281 |
-
*/
|
282 |
-
function upgrade_request() {
|
283 |
-
include_once UM()->admin()->templates_path . 'dashboard/upgrade-request.php';
|
284 |
-
}
|
285 |
-
|
286 |
-
|
287 |
/**
|
288 |
*
|
289 |
*/
|
206 |
add_meta_box( 'um-metaboxes-mainbox-1', __( 'Latest from our blog', 'ultimate-member' ), array( &$this, 'um_news' ), $this->pagehook, 'normal', 'core' );
|
207 |
|
208 |
add_meta_box( 'um-metaboxes-sidebox-1', __( 'Purge Temp Files', 'ultimate-member' ), array( &$this, 'purge_temp' ), $this->pagehook, 'side', 'core' );
|
|
|
209 |
add_meta_box( 'um-metaboxes-sidebox-2', __( 'User Cache', 'ultimate-member' ), array( &$this, 'user_cache' ), $this->pagehook, 'side', 'core' );
|
210 |
|
211 |
if ( $this->language_avaialable_not_installed() ) {
|
215 |
} else if ( $this->language_not_available() ) {
|
216 |
add_meta_box( 'um-metaboxes-sidebox-2', __( 'Language', 'ultimate-member' ), array( &$this, 'ct_language' ), $this->pagehook, 'side', 'core' );
|
217 |
}
|
|
|
|
|
|
|
|
|
|
|
|
|
218 |
}
|
219 |
|
220 |
|
269 |
}
|
270 |
|
271 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
272 |
/**
|
273 |
*
|
274 |
*/
|
includes/admin/core/class-admin-notices.php
CHANGED
@@ -38,7 +38,7 @@ if ( ! class_exists( 'um\admin\core\Admin_Notices' ) ) {
|
|
38 |
$this->localize_note();
|
39 |
$this->show_update_messages();
|
40 |
$this->check_wrong_install_folder();
|
41 |
-
|
42 |
$this->need_upgrade();
|
43 |
$this->check_wrong_licenses();
|
44 |
|
@@ -225,32 +225,9 @@ if ( ! class_exists( 'um\admin\core\Admin_Notices' ) ) {
|
|
225 |
function old_extensions_notice() {
|
226 |
$show = false;
|
227 |
|
228 |
-
$old_extensions = array(
|
229 |
-
'bbpress',
|
230 |
-
'followers',
|
231 |
-
'friends',
|
232 |
-
'instagram',
|
233 |
-
'mailchimp',
|
234 |
-
'messaging',
|
235 |
-
'mycred',
|
236 |
-
'notices',
|
237 |
-
'notifications',
|
238 |
-
'online',
|
239 |
-
'private-content',
|
240 |
-
'profile-completeness',
|
241 |
-
'recaptcha',
|
242 |
-
'reviews',
|
243 |
-
'social-activity',
|
244 |
-
'social-login',
|
245 |
-
'terms-conditions',
|
246 |
-
'user-tags',
|
247 |
-
'verified-users',
|
248 |
-
'woocommerce',
|
249 |
-
);
|
250 |
-
|
251 |
$slugs = array_map( function( $item ) {
|
252 |
return 'um-' . $item . '/um-' . $item . '.php';
|
253 |
-
},
|
254 |
|
255 |
$active_plugins = UM()->dependencies()->get_active_plugins();
|
256 |
foreach ( $slugs as $slug ) {
|
@@ -420,14 +397,6 @@ if ( ! class_exists( 'um\admin\core\Admin_Notices' ) ) {
|
|
420 |
$messages[0]['content'] = __( 'Your user cache is now removed.', 'ultimate-member' );
|
421 |
break;
|
422 |
|
423 |
-
case 'got_updates':
|
424 |
-
$messages[0]['content'] = __( 'You got the latest upgrades.', 'ultimate-member' );
|
425 |
-
break;
|
426 |
-
|
427 |
-
case 'often_updates':
|
428 |
-
$messages[0]['err_content'] = __( 'Try again later. You can run this action once daily.', 'ultimate-member' );
|
429 |
-
break;
|
430 |
-
|
431 |
case 'form_duplicated':
|
432 |
$messages[0]['content'] = __( 'The form has been duplicated successfully.', 'ultimate-member' );
|
433 |
break;
|
38 |
$this->localize_note();
|
39 |
$this->show_update_messages();
|
40 |
$this->check_wrong_install_folder();
|
41 |
+
$this->admin_notice_tracking();
|
42 |
$this->need_upgrade();
|
43 |
$this->check_wrong_licenses();
|
44 |
|
225 |
function old_extensions_notice() {
|
226 |
$show = false;
|
227 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
228 |
$slugs = array_map( function( $item ) {
|
229 |
return 'um-' . $item . '/um-' . $item . '.php';
|
230 |
+
}, array_keys( UM()->dependencies()->ext_required_version ) );
|
231 |
|
232 |
$active_plugins = UM()->dependencies()->get_active_plugins();
|
233 |
foreach ( $slugs as $slug ) {
|
397 |
$messages[0]['content'] = __( 'Your user cache is now removed.', 'ultimate-member' );
|
398 |
break;
|
399 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
400 |
case 'form_duplicated':
|
401 |
$messages[0]['content'] = __( 'The form has been duplicated successfully.', 'ultimate-member' );
|
402 |
break;
|
includes/admin/core/class-admin-settings.php
CHANGED
@@ -1197,14 +1197,12 @@ if ( ! class_exists( 'um\admin\core\Admin_Settings' ) ) {
|
|
1197 |
do_action( "um_settings_page_" . $current_tab . "_" . $current_subtab . "_before_section" );
|
1198 |
|
1199 |
$section_fields = $this->get_section_fields( $current_tab, $current_subtab );
|
1200 |
-
$settings_section = $this->render_settings_section( $section_fields, $current_tab, $current_subtab );
|
1201 |
|
1202 |
/**
|
1203 |
* UM hook
|
1204 |
*
|
1205 |
* @type filter
|
1206 |
* @title um_settings_section_{$current_tab}_{$current_subtab}_content
|
1207 |
-
*
|
1208 |
* @description Render settings section
|
1209 |
* @input_vars
|
1210 |
* [{"var":"$content","type":"string","desc":"Section content"},
|
@@ -1222,7 +1220,7 @@ if ( ! class_exists( 'um\admin\core\Admin_Settings' ) ) {
|
|
1222 |
* ?>
|
1223 |
*/
|
1224 |
echo apply_filters( 'um_settings_section_' . $current_tab . '_' . $current_subtab . '_content',
|
1225 |
-
$
|
1226 |
$section_fields
|
1227 |
);
|
1228 |
|
@@ -1260,7 +1258,6 @@ if ( ! class_exists( 'um\admin\core\Admin_Settings' ) ) {
|
|
1260 |
do_action( "um_settings_page_" . $current_tab . "_" . $current_subtab . "_before_section" );
|
1261 |
|
1262 |
$section_fields = $this->get_section_fields( $current_tab, $current_subtab );
|
1263 |
-
$settings_section = $this->render_settings_section( $section_fields, $current_tab, $current_subtab );
|
1264 |
|
1265 |
/**
|
1266 |
* UM hook
|
@@ -1284,7 +1281,7 @@ if ( ! class_exists( 'um\admin\core\Admin_Settings' ) ) {
|
|
1284 |
* ?>
|
1285 |
*/
|
1286 |
echo apply_filters( 'um_settings_section_' . $current_tab . '_' . $current_subtab . '_content',
|
1287 |
-
$
|
1288 |
$section_fields
|
1289 |
);
|
1290 |
?>
|
@@ -2184,6 +2181,7 @@ Cache User Profile: <?php if( UM()->options()->get( 'um_profile_object_cache_s
|
|
2184 |
Generate Slugs on Directories: <?php if( UM()->options()->get( 'um_generate_slug_in_directory' ) == 1 ){ echo "No"; }else{ echo "Yes"; } echo "\n"; ?>
|
2185 |
Rewrite Rules: <?php if( UM()->options()->get( 'um_flush_stop' ) == 1 ){ echo "No"; }else{ echo "Yes"; } echo "\n"; ?>
|
2186 |
Force UTF-8 Encoding: <?php if( UM()->options()->get( 'um_force_utf8_strings' ) == 1 ){ echo "Yes"; }else{ echo "No"; } echo "\n"; ?>
|
|
|
2187 |
JS/CSS Compression: <?php if ( defined('SCRIPT_DEBUG' ) && SCRIPT_DEBUG ) { echo "Yes"; }else{ echo "No"; } echo "\n"; ?>
|
2188 |
<?php if( is_multisite() ): ?>
|
2189 |
Network Structure: <?php echo UM()->options()->get( 'network_permalink_structure' ). "\n"; ?>
|
1197 |
do_action( "um_settings_page_" . $current_tab . "_" . $current_subtab . "_before_section" );
|
1198 |
|
1199 |
$section_fields = $this->get_section_fields( $current_tab, $current_subtab );
|
|
|
1200 |
|
1201 |
/**
|
1202 |
* UM hook
|
1203 |
*
|
1204 |
* @type filter
|
1205 |
* @title um_settings_section_{$current_tab}_{$current_subtab}_content
|
|
|
1206 |
* @description Render settings section
|
1207 |
* @input_vars
|
1208 |
* [{"var":"$content","type":"string","desc":"Section content"},
|
1220 |
* ?>
|
1221 |
*/
|
1222 |
echo apply_filters( 'um_settings_section_' . $current_tab . '_' . $current_subtab . '_content',
|
1223 |
+
$this->render_settings_section( $section_fields, $current_tab, $current_subtab ),
|
1224 |
$section_fields
|
1225 |
);
|
1226 |
|
1258 |
do_action( "um_settings_page_" . $current_tab . "_" . $current_subtab . "_before_section" );
|
1259 |
|
1260 |
$section_fields = $this->get_section_fields( $current_tab, $current_subtab );
|
|
|
1261 |
|
1262 |
/**
|
1263 |
* UM hook
|
1281 |
* ?>
|
1282 |
*/
|
1283 |
echo apply_filters( 'um_settings_section_' . $current_tab . '_' . $current_subtab . '_content',
|
1284 |
+
$this->render_settings_section( $section_fields, $current_tab, $current_subtab ),
|
1285 |
$section_fields
|
1286 |
);
|
1287 |
?>
|
2181 |
Generate Slugs on Directories: <?php if( UM()->options()->get( 'um_generate_slug_in_directory' ) == 1 ){ echo "No"; }else{ echo "Yes"; } echo "\n"; ?>
|
2182 |
Rewrite Rules: <?php if( UM()->options()->get( 'um_flush_stop' ) == 1 ){ echo "No"; }else{ echo "Yes"; } echo "\n"; ?>
|
2183 |
Force UTF-8 Encoding: <?php if( UM()->options()->get( 'um_force_utf8_strings' ) == 1 ){ echo "Yes"; }else{ echo "No"; } echo "\n"; ?>
|
2184 |
+
Time Check Security: <?php if( UM()->options()->get( 'enable_timebot' ) == 1 ){ echo "Yes"; }else{ echo "No"; } echo "\n"; ?>
|
2185 |
JS/CSS Compression: <?php if ( defined('SCRIPT_DEBUG' ) && SCRIPT_DEBUG ) { echo "Yes"; }else{ echo "No"; } echo "\n"; ?>
|
2186 |
<?php if( is_multisite() ): ?>
|
2187 |
Network Structure: <?php echo UM()->options()->get( 'network_permalink_structure' ). "\n"; ?>
|
includes/admin/core/class-admin-upgrade.php
CHANGED
@@ -17,12 +17,6 @@ if ( ! class_exists( 'um\admin\core\Admin_Upgrade' ) ) {
|
|
17 |
class Admin_Upgrade {
|
18 |
|
19 |
|
20 |
-
/**
|
21 |
-
* @var null
|
22 |
-
*/
|
23 |
-
protected static $instance = null;
|
24 |
-
|
25 |
-
|
26 |
/**
|
27 |
* @var
|
28 |
*/
|
@@ -37,25 +31,6 @@ if ( ! class_exists( 'um\admin\core\Admin_Upgrade' ) ) {
|
|
37 |
var $packages_dir;
|
38 |
|
39 |
|
40 |
-
/**
|
41 |
-
* Main Admin_Upgrade Instance
|
42 |
-
*
|
43 |
-
* Ensures only one instance of UM is loaded or can be loaded.
|
44 |
-
*
|
45 |
-
* @since 1.0
|
46 |
-
* @static
|
47 |
-
* @see UM()
|
48 |
-
* @return Admin_Upgrade - Main instance
|
49 |
-
*/
|
50 |
-
static public function instance() {
|
51 |
-
if ( is_null( self::$instance ) ) {
|
52 |
-
self::$instance = new self();
|
53 |
-
}
|
54 |
-
|
55 |
-
return self::$instance;
|
56 |
-
}
|
57 |
-
|
58 |
-
|
59 |
/**
|
60 |
* Admin_Upgrade constructor.
|
61 |
*/
|
@@ -64,14 +39,11 @@ if ( ! class_exists( 'um\admin\core\Admin_Upgrade' ) ) {
|
|
64 |
$this->necessary_packages = $this->need_run_upgrades();
|
65 |
|
66 |
if ( ! empty( $this->necessary_packages ) ) {
|
|
|
67 |
add_action( 'admin_menu', array( $this, 'admin_menu' ), 0 );
|
68 |
|
69 |
-
|
70 |
-
|
71 |
-
|
72 |
-
add_action( 'wp_ajax_um_run_package', array( $this, 'ajax_run_package' ) );
|
73 |
-
add_action( 'wp_ajax_um_get_packages', array( $this, 'ajax_get_packages' ) );
|
74 |
-
}
|
75 |
}
|
76 |
|
77 |
//add_action( 'in_plugin_update_message-' . um_plugin, array( $this, 'in_plugin_update_message' ) );
|
@@ -171,7 +143,7 @@ if ( ! class_exists( 'um\admin\core\Admin_Upgrade' ) ) {
|
|
171 |
foreach ( $this->necessary_packages as $package ) {
|
172 |
$hooks_file = $this->packages_dir . DIRECTORY_SEPARATOR . $package . DIRECTORY_SEPARATOR . 'hooks.php';
|
173 |
if ( file_exists( $hooks_file ) ) {
|
174 |
-
$pack_ajax_hooks =
|
175 |
|
176 |
foreach ( $pack_ajax_hooks as $action => $function ) {
|
177 |
add_action( 'wp_ajax_um_' . $action, "um_upgrade_$function" );
|
@@ -188,7 +160,7 @@ if ( ! class_exists( 'um\admin\core\Admin_Upgrade' ) ) {
|
|
188 |
foreach ( $this->necessary_packages as $package ) {
|
189 |
$handlers_file = $this->packages_dir . DIRECTORY_SEPARATOR . $package . DIRECTORY_SEPARATOR . 'functions.php';
|
190 |
if ( file_exists( $handlers_file ) ) {
|
191 |
-
|
192 |
}
|
193 |
}
|
194 |
}
|
@@ -318,7 +290,7 @@ if ( ! class_exists( 'um\admin\core\Admin_Upgrade' ) ) {
|
|
318 |
exit('');
|
319 |
} else {
|
320 |
ob_start();
|
321 |
-
|
322 |
ob_get_flush();
|
323 |
exit;
|
324 |
}
|
17 |
class Admin_Upgrade {
|
18 |
|
19 |
|
|
|
|
|
|
|
|
|
|
|
|
|
20 |
/**
|
21 |
* @var
|
22 |
*/
|
31 |
var $packages_dir;
|
32 |
|
33 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
34 |
/**
|
35 |
* Admin_Upgrade constructor.
|
36 |
*/
|
39 |
$this->necessary_packages = $this->need_run_upgrades();
|
40 |
|
41 |
if ( ! empty( $this->necessary_packages ) ) {
|
42 |
+
$this->init_packages_ajax();
|
43 |
add_action( 'admin_menu', array( $this, 'admin_menu' ), 0 );
|
44 |
|
45 |
+
add_action( 'wp_ajax_um_run_package', array( $this, 'ajax_run_package' ) );
|
46 |
+
add_action( 'wp_ajax_um_get_packages', array( $this, 'ajax_get_packages' ) );
|
|
|
|
|
|
|
|
|
47 |
}
|
48 |
|
49 |
//add_action( 'in_plugin_update_message-' . um_plugin, array( $this, 'in_plugin_update_message' ) );
|
143 |
foreach ( $this->necessary_packages as $package ) {
|
144 |
$hooks_file = $this->packages_dir . DIRECTORY_SEPARATOR . $package . DIRECTORY_SEPARATOR . 'hooks.php';
|
145 |
if ( file_exists( $hooks_file ) ) {
|
146 |
+
$pack_ajax_hooks = include $hooks_file;
|
147 |
|
148 |
foreach ( $pack_ajax_hooks as $action => $function ) {
|
149 |
add_action( 'wp_ajax_um_' . $action, "um_upgrade_$function" );
|
160 |
foreach ( $this->necessary_packages as $package ) {
|
161 |
$handlers_file = $this->packages_dir . DIRECTORY_SEPARATOR . $package . DIRECTORY_SEPARATOR . 'functions.php';
|
162 |
if ( file_exists( $handlers_file ) ) {
|
163 |
+
include $handlers_file;
|
164 |
}
|
165 |
}
|
166 |
}
|
290 |
exit('');
|
291 |
} else {
|
292 |
ob_start();
|
293 |
+
include $this->packages_dir . DIRECTORY_SEPARATOR . $_POST['pack'] . DIRECTORY_SEPARATOR . 'init.php';
|
294 |
ob_get_flush();
|
295 |
exit;
|
296 |
}
|
includes/admin/core/packages/2.0-beta1/email_templates.php
CHANGED
@@ -25,8 +25,8 @@ foreach ( $emails as $email_key => $value ) {
|
|
25 |
} else {
|
26 |
$setting_value = UM()->options()->get( $email_key );
|
27 |
|
28 |
-
$fp =
|
29 |
-
$result =
|
30 |
fclose( $fp );
|
31 |
}
|
32 |
} else {
|
25 |
} else {
|
26 |
$setting_value = UM()->options()->get( $email_key );
|
27 |
|
28 |
+
$fp = fopen( $theme_template_path, "w" );
|
29 |
+
$result = fputs( $fp, $setting_value );
|
30 |
fclose( $fp );
|
31 |
}
|
32 |
} else {
|
includes/admin/core/packages/2.0-beta1/menus.php
CHANGED
@@ -18,15 +18,9 @@ $menus = get_posts( array(
|
|
18 |
foreach ( $menus as $menu ) {
|
19 |
$menu_roles = get_post_meta( $menu->ID, 'menu-item-um_nav_roles', true );
|
20 |
|
21 |
-
if( !is_array( $menu_roles ) ) {
|
22 |
-
$menu_roles = array();
|
23 |
-
}
|
24 |
foreach ( $menu_roles as $i => $role_k ) {
|
25 |
-
|
26 |
-
$menu_roles[ $i ] = $roles_associations[ $role_k ];
|
27 |
-
}
|
28 |
}
|
29 |
|
30 |
-
|
31 |
update_post_meta( $menu->ID, 'menu-item-um_nav_roles', $menu_roles );
|
32 |
}
|
18 |
foreach ( $menus as $menu ) {
|
19 |
$menu_roles = get_post_meta( $menu->ID, 'menu-item-um_nav_roles', true );
|
20 |
|
|
|
|
|
|
|
21 |
foreach ( $menu_roles as $i => $role_k ) {
|
22 |
+
$menu_roles[ $i ] = $roles_associations[ $role_k ];
|
|
|
|
|
23 |
}
|
24 |
|
|
|
25 |
update_post_meta( $menu->ID, 'menu-item-um_nav_roles', $menu_roles );
|
26 |
}
|
includes/admin/templates/dashboard/cache.php
CHANGED
@@ -1,10 +1,11 @@
|
|
1 |
-
<?php
|
2 |
|
3 |
-
$count =
|
4 |
-
|
5 |
-
|
6 |
-
|
7 |
-
|
|
|
8 |
|
9 |
<p><?php _e( 'Run this task from time to time to keep your DB clean.', 'ultimate-member' ) ?></p>
|
10 |
<p>
|
1 |
+
<?php $all_options = wp_load_alloptions();
|
2 |
|
3 |
+
$count = 0;
|
4 |
+
foreach ( $all_options as $k => $v ) {
|
5 |
+
if ( strstr( $k, 'um_cache_userdata_' ) !== false ) {
|
6 |
+
$count++;
|
7 |
+
}
|
8 |
+
} ?>
|
9 |
|
10 |
<p><?php _e( 'Run this task from time to time to keep your DB clean.', 'ultimate-member' ) ?></p>
|
11 |
<p>
|
includes/admin/templates/dashboard/upgrade-request.php
DELETED
@@ -1,6 +0,0 @@
|
|
1 |
-
<p><?php _e( 'Run this task from time to time if you have issues with WP Cron and need to get UM extension updates.', 'ultimate-member' ) ?></p>
|
2 |
-
<p>
|
3 |
-
<a href="<?php echo add_query_arg( 'um_adm_action', 'manual_upgrades_request' ); ?>" class="button">
|
4 |
-
<?php _e( 'Get latest versions', 'ultimate-member' ) ?>
|
5 |
-
</a>
|
6 |
-
</p>
|
|
|
|
|
|
|
|
|
|
|
|
includes/admin/templates/form/login_customize.php
CHANGED
@@ -65,7 +65,7 @@
|
|
65 |
array(
|
66 |
'id' => '_um_login_secondary_btn_word',
|
67 |
'type' => 'text',
|
68 |
-
'label' => __( '
|
69 |
'tooltip' => __( 'Customize the button text', 'ultimate-member' ),
|
70 |
'value' => UM()->query()->get_meta_value( '_um_login_secondary_btn_word', null, UM()->options()->get( 'login_secondary_btn_word' ) ),
|
71 |
'conditional' => array( '_um_login_secondary_btn', '=', 1 )
|
65 |
array(
|
66 |
'id' => '_um_login_secondary_btn_word',
|
67 |
'type' => 'text',
|
68 |
+
'label' => __( 'Primary Button Text', 'ultimate-member' ),
|
69 |
'tooltip' => __( 'Customize the button text', 'ultimate-member' ),
|
70 |
'value' => UM()->query()->get_meta_value( '_um_login_secondary_btn_word', null, UM()->options()->get( 'login_secondary_btn_word' ) ),
|
71 |
'conditional' => array( '_um_login_secondary_btn', '=', 1 )
|
includes/admin/templates/form/profile_customize.php
CHANGED
@@ -90,7 +90,7 @@
|
|
90 |
array(
|
91 |
'id' => '_um_profile_secondary_btn_word',
|
92 |
'type' => 'text',
|
93 |
-
'label' => __( '
|
94 |
'tooltip' => __( 'Customize the button text', 'ultimate-member' ),
|
95 |
'value' => UM()->query()->get_meta_value( '_um_profile_secondary_btn_word', null, UM()->options()->get( 'profile_secondary_btn_word' ) ),
|
96 |
'conditional' => array( '_um_profile_secondary_btn', '=', 1 )
|
90 |
array(
|
91 |
'id' => '_um_profile_secondary_btn_word',
|
92 |
'type' => 'text',
|
93 |
+
'label' => __( 'Primary Button Text', 'ultimate-member' ),
|
94 |
'tooltip' => __( 'Customize the button text', 'ultimate-member' ),
|
95 |
'value' => UM()->query()->get_meta_value( '_um_profile_secondary_btn_word', null, UM()->options()->get( 'profile_secondary_btn_word' ) ),
|
96 |
'conditional' => array( '_um_profile_secondary_btn', '=', 1 )
|
includes/admin/templates/form/register_customize.php
CHANGED
@@ -80,7 +80,7 @@
|
|
80 |
array(
|
81 |
'id' => '_um_register_secondary_btn_word',
|
82 |
'type' => 'text',
|
83 |
-
'label' => __( '
|
84 |
'tooltip' => __( 'Customize the button text', 'ultimate-member' ),
|
85 |
'value' => UM()->query()->get_meta_value( '_um_register_secondary_btn_word', null, UM()->options()->get( 'register_secondary_btn_word' ) ),
|
86 |
'conditional' => array( '_um_register_secondary_btn', '=', 1 )
|
80 |
array(
|
81 |
'id' => '_um_register_secondary_btn_word',
|
82 |
'type' => 'text',
|
83 |
+
'label' => __( 'Primary Button Text', 'ultimate-member' ),
|
84 |
'tooltip' => __( 'Customize the button text', 'ultimate-member' ),
|
85 |
'value' => UM()->query()->get_meta_value( '_um_register_secondary_btn_word', null, UM()->options()->get( 'register_secondary_btn_word' ) ),
|
86 |
'conditional' => array( '_um_register_secondary_btn', '=', 1 )
|
includes/admin/templates/form/register_gdpr.php
DELETED
@@ -1,71 +0,0 @@
|
|
1 |
-
<div class="um-admin-metabox">
|
2 |
-
|
3 |
-
<?php
|
4 |
-
$options = array(
|
5 |
-
'' => __( 'Select page', 'ultimate-member' )
|
6 |
-
);
|
7 |
-
|
8 |
-
$pages = get_pages();
|
9 |
-
foreach ( $pages as $page ) {
|
10 |
-
$options[$page->ID] = $page->post_title;
|
11 |
-
}
|
12 |
-
|
13 |
-
UM()->admin_forms( array(
|
14 |
-
'class' => 'um-form-register-gdpr um-top-label',
|
15 |
-
'prefix_id' => 'form',
|
16 |
-
'fields' => array(
|
17 |
-
array(
|
18 |
-
'id' => '_um_register_use_gdpr',
|
19 |
-
'type' => 'select',
|
20 |
-
'label' => __( 'Enable on this form', 'ultimate-member' ),
|
21 |
-
'value' => UM()->query()->get_meta_value( '_um_register_use_gdpr', null, '' ),
|
22 |
-
'options' => array(
|
23 |
-
'0' => __( 'No', 'ultimate-member' ),
|
24 |
-
'1' => __( 'Yes', 'ultimate-member' )
|
25 |
-
),
|
26 |
-
),
|
27 |
-
array(
|
28 |
-
'id' => '_um_register_use_gdpr_content_id',
|
29 |
-
'type' => 'select',
|
30 |
-
'label' => __( 'Content', 'ultimate-member' ),
|
31 |
-
'value' => UM()->query()->get_meta_value('_um_register_use_gdpr_content_id', null, '' ),
|
32 |
-
'options' => $options,
|
33 |
-
'conditional' => array( '_um_register_use_gdpr', '=', '1' )
|
34 |
-
),
|
35 |
-
array(
|
36 |
-
'id' => '_um_register_use_gdpr_toggle_show',
|
37 |
-
'type' => 'text',
|
38 |
-
'label' => __( 'Toggle Show text', 'ultimate-member' ),
|
39 |
-
'placeholder' => __( 'Show privacy policy', 'ultimate-member' ),
|
40 |
-
'value' => UM()->query()->get_meta_value('_um_register_use_gdpr_toggle_show', null, __( 'Show privacy policy', 'ultimate-member' ) ),
|
41 |
-
'conditional' => array( '_um_register_use_gdpr', '=', '1' )
|
42 |
-
),
|
43 |
-
array(
|
44 |
-
'id' => '_um_register_use_gdpr_toggle_hide',
|
45 |
-
'type' => 'text',
|
46 |
-
'label' => __( 'Toggle Hide text', 'ultimate-member' ),
|
47 |
-
'placeholder' => __( 'Hide privacy policy', 'ultimate-member' ),
|
48 |
-
'value' => UM()->query()->get_meta_value('_um_register_use_gdpr_toggle_hide', null, __( 'Hide privacy policy', 'ultimate-member' ) ),
|
49 |
-
'conditional' => array( '_um_register_use_gdpr', '=', '1' )
|
50 |
-
),
|
51 |
-
array(
|
52 |
-
'id' => '_um_register_use_gdpr_agreement',
|
53 |
-
'type' => 'text',
|
54 |
-
'label' => __( 'Checkbox agreement description', 'ultimate-member' ),
|
55 |
-
'placeholder' => __( 'Please confirm that you agree to our privacy policy', 'ultimate-member' ),
|
56 |
-
'value' => UM()->query()->get_meta_value('_um_register_use_gdpr_agreement', null, __( 'Please confirm that you agree to our privacy policy', 'ultimate-member' ) ),
|
57 |
-
'conditional' => array( '_um_register_use_gdpr', '=', '1' )
|
58 |
-
),
|
59 |
-
array(
|
60 |
-
'id' => '_um_register_use_gdpr_error_text',
|
61 |
-
'type' => 'text',
|
62 |
-
'label' => __( 'Error Text', 'ultimate-member' ),
|
63 |
-
'placeholder' => __( 'Please confirm your acceptance of our privacy policy', 'ultimate-member' ),
|
64 |
-
'value' => UM()->query()->get_meta_value('_um_register_use_gdpr_error_text', null, __( 'Please confirm your acceptance of our privacy policy', 'ultimate-member' ) ),
|
65 |
-
'conditional' => array( '_um_register_use_gdpr', '=', '1' )
|
66 |
-
)
|
67 |
-
)
|
68 |
-
) )->render_form(); ?>
|
69 |
-
|
70 |
-
<div class="um-admin-clear"></div>
|
71 |
-
</div>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
includes/admin/templates/gdpr.php
DELETED
@@ -1,40 +0,0 @@
|
|
1 |
-
<?php if ( ! defined( 'ABSPATH' ) ) exit; // Exit if accessed directly. ?>
|
2 |
-
|
3 |
-
<h2>
|
4 |
-
<?php _e( 'What personal data we collect and why we collect it', 'ultimate-member' ); ?>
|
5 |
-
</h2>
|
6 |
-
<h3>
|
7 |
-
<?php _e( 'Forms', 'ultimate-member' ); ?>
|
8 |
-
</h3>
|
9 |
-
<p>
|
10 |
-
<?php printf( __( '%s provides you with forms for user registration, login and profiles.', 'ultimate-member' ), ultimatemember_plugin_name ); ?>
|
11 |
-
</p>
|
12 |
-
<p>
|
13 |
-
<?php _e( 'Via these forms you are collecting personal data from your users.', 'ultimate-member' ); ?>
|
14 |
-
</p>
|
15 |
-
<p>
|
16 |
-
<?php _e( 'You should include in your privacy policy what personal data is captured when someone submits/fills in one of the forms, why you collect it and what you do with this data and how long you keep it.', 'ultimate-member' ); ?>
|
17 |
-
</p>
|
18 |
-
|
19 |
-
<h2>
|
20 |
-
<?php _e( 'How long we retain your data', 'ultimate-member' ); ?>
|
21 |
-
</h2>
|
22 |
-
<p>
|
23 |
-
<?php _e( 'Registered user information is retained in your website’s database indefinitely.', 'ultimate-member' ); ?>
|
24 |
-
</p>
|
25 |
-
<p>
|
26 |
-
<?php _e( 'Data can be exported or removed upon users request via the existing WordPress data exporter or eraser.', 'ultimate-member' ); ?>
|
27 |
-
</p>
|
28 |
-
<p>
|
29 |
-
<?php _e( 'If syncing data to a 3rd party service (e.g Mailchimp via our MailChimp extension), data is retained there until unsubscribed or deleted.', 'ultimate-member' ); ?>
|
30 |
-
</p>
|
31 |
-
|
32 |
-
<h2>
|
33 |
-
<?php _e( 'Where we send your data', 'ultimate-member' ); ?>
|
34 |
-
</h2>
|
35 |
-
<p>
|
36 |
-
<?php printf( __( '%s does not send any user data outside of your site by default.', 'ultimate-member' ), ultimatemember_plugin_name ); ?>
|
37 |
-
</p>
|
38 |
-
<p>
|
39 |
-
<?php _e( 'If you have extended the functionality of the plugin (e.g sending registered user data to MailChimp via our MailChimp extension, this user info may be passed to these external services. These services may be located abroad and outwith the EU.', 'ultimate-member' ); ?>
|
40 |
-
</p>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
includes/class-dependencies.php
CHANGED
@@ -57,7 +57,6 @@ if ( ! class_exists( 'um\Dependencies' ) ) {
|
|
57 |
'woocommerce' => '2.0.1',
|
58 |
'restrict-content' => '2.0',
|
59 |
'beaver-builder' => '2.0',
|
60 |
-
'gdpr' => '1.0.0',
|
61 |
);
|
62 |
|
63 |
|
57 |
'woocommerce' => '2.0.1',
|
58 |
'restrict-content' => '2.0',
|
59 |
'beaver-builder' => '2.0',
|
|
|
60 |
);
|
61 |
|
62 |
|
includes/class-init.php
CHANGED
@@ -30,7 +30,6 @@ if ( ! class_exists( 'UM' ) ) {
|
|
30 |
* @method UM_Terms_Conditions_API Terms_Conditions_API()
|
31 |
* @method UM_Private_Content_API Private_Content_API()
|
32 |
* @method UM_User_Location_API User_Location_API()
|
33 |
-
* @method UM_GDPR_API GDPR_API()
|
34 |
*
|
35 |
*/
|
36 |
final class UM extends UM_Functions {
|
@@ -386,6 +385,47 @@ if ( ! class_exists( 'UM' ) ) {
|
|
386 |
}
|
387 |
|
388 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
389 |
/**
|
390 |
* Autoload UM classes handler
|
391 |
*
|
@@ -485,7 +525,6 @@ if ( ! class_exists( 'UM' ) ) {
|
|
485 |
$this->ajax_init();
|
486 |
$this->metabox();
|
487 |
$this->admin_upgrade()->init_packages_ajax_handlers();
|
488 |
-
$this->admin_gdpr();
|
489 |
} elseif ( $this->is_request( 'admin' ) ) {
|
490 |
$this->admin();
|
491 |
$this->admin_menu();
|
@@ -498,7 +537,6 @@ if ( ! class_exists( 'UM' ) ) {
|
|
498 |
$this->users();
|
499 |
$this->dragdrop();
|
500 |
$this->plugin_updater();
|
501 |
-
$this->admin_gdpr();
|
502 |
} elseif ( $this->is_request( 'frontend' ) ) {
|
503 |
$this->enqueue();
|
504 |
$this->account();
|
@@ -524,10 +562,9 @@ if ( ! class_exists( 'UM' ) ) {
|
|
524 |
$this->permalinks();
|
525 |
$this->modal();
|
526 |
$this->cron();
|
527 |
-
|
528 |
$this->mobile();
|
529 |
$this->external_integrations();
|
530 |
-
$this->gdpr();
|
531 |
}
|
532 |
|
533 |
|
@@ -637,55 +674,12 @@ if ( ! class_exists( 'UM' ) ) {
|
|
637 |
*/
|
638 |
function admin_upgrade() {
|
639 |
if ( empty( $this->classes['admin_upgrade'] ) ) {
|
640 |
-
$this->classes['admin_upgrade'] = um\admin\core\Admin_Upgrade
|
641 |
-
//$this->classes['admin_upgrade'] = new um\admin\core\Admin_Upgrade();
|
642 |
}
|
643 |
return $this->classes['admin_upgrade'];
|
644 |
}
|
645 |
|
646 |
|
647 |
-
/**
|
648 |
-
* GDPR privacy policy
|
649 |
-
*
|
650 |
-
* @since 2.0.14
|
651 |
-
*
|
652 |
-
* @return bool|um\admin\core\Admin_GDPR()
|
653 |
-
*/
|
654 |
-
function admin_gdpr() {
|
655 |
-
global $wp_version;
|
656 |
-
|
657 |
-
if ( version_compare( $wp_version, '4.9.6', '<' ) ) {
|
658 |
-
return false;
|
659 |
-
}
|
660 |
-
|
661 |
-
if ( empty( $this->classes['admin_gdpr'] ) ) {
|
662 |
-
$this->classes['admin_gdpr'] = new um\admin\core\Admin_GDPR();
|
663 |
-
}
|
664 |
-
return $this->classes['admin_gdpr'];
|
665 |
-
}
|
666 |
-
|
667 |
-
|
668 |
-
/**
|
669 |
-
* GDPR privacy policy
|
670 |
-
*
|
671 |
-
* @since 2.0.14
|
672 |
-
*
|
673 |
-
* @return bool|um\core\GDPR()
|
674 |
-
*/
|
675 |
-
function gdpr() {
|
676 |
-
global $wp_version;
|
677 |
-
|
678 |
-
if ( version_compare( $wp_version, '4.9.6', '<' ) ) {
|
679 |
-
return false;
|
680 |
-
}
|
681 |
-
|
682 |
-
if ( empty( $this->classes['gdpr'] ) ) {
|
683 |
-
$this->classes['gdpr'] = new um\core\GDPR();
|
684 |
-
}
|
685 |
-
return $this->classes['gdpr'];
|
686 |
-
}
|
687 |
-
|
688 |
-
|
689 |
/**
|
690 |
* @since 2.0
|
691 |
*
|
30 |
* @method UM_Terms_Conditions_API Terms_Conditions_API()
|
31 |
* @method UM_Private_Content_API Private_Content_API()
|
32 |
* @method UM_User_Location_API User_Location_API()
|
|
|
33 |
*
|
34 |
*/
|
35 |
final class UM extends UM_Functions {
|
385 |
}
|
386 |
|
387 |
|
388 |
+
/**
|
389 |
+
* Show notice for customers with old extension's versions
|
390 |
+
*/
|
391 |
+
/*function old_extensions_notice() {
|
392 |
+
if ( ! is_admin() ) {
|
393 |
+
return;
|
394 |
+
}
|
395 |
+
|
396 |
+
if ( defined( 'DOING_AJAX' ) && DOING_AJAX ) {
|
397 |
+
return;
|
398 |
+
}
|
399 |
+
|
400 |
+
$show = false;
|
401 |
+
|
402 |
+
$slugs = array_map( function( $item ) {
|
403 |
+
return 'um-' . $item . '/um-' . $item . '.php';
|
404 |
+
}, array_keys( $this->dependencies()->ext_required_version ) );
|
405 |
+
|
406 |
+
$active_plugins = $this->dependencies()->get_active_plugins();
|
407 |
+
foreach ( $slugs as $slug ) {
|
408 |
+
if ( in_array( $slug, $active_plugins ) ) {
|
409 |
+
$plugin_data = get_plugin_data( um_path . '..' . DIRECTORY_SEPARATOR . $slug );
|
410 |
+
if ( version_compare( '2.0', $plugin_data['Version'], '>' ) ) {
|
411 |
+
$show = true;
|
412 |
+
break;
|
413 |
+
}
|
414 |
+
}
|
415 |
+
}
|
416 |
+
|
417 |
+
if ( ! $show ) {
|
418 |
+
return;
|
419 |
+
}
|
420 |
+
|
421 |
+
/*global $um_woocommerce;
|
422 |
+
remove_action( 'init', array( $um_woocommerce, 'plugin_check' ), 1 );
|
423 |
+
$um_woocommerce->plugin_inactive = true;*
|
424 |
+
|
425 |
+
echo '<div class="error"><p>' . sprintf( __( '<strong>%s %s</strong> requires 2.0 extensions. You have pre 2.0 extensions installed on your site. <br /> Please update %s extensions to latest versions. For more info see this <a href="%s" target="_blank">doc</a>.', 'ultimate-member' ), ultimatemember_plugin_name, ultimatemember_version, ultimatemember_plugin_name, 'http://docs.ultimatemember.com/article/266-updating-to-2-0-versions-of-extensions' ) . '</p></div>';
|
426 |
+
}*/
|
427 |
+
|
428 |
+
|
429 |
/**
|
430 |
* Autoload UM classes handler
|
431 |
*
|
525 |
$this->ajax_init();
|
526 |
$this->metabox();
|
527 |
$this->admin_upgrade()->init_packages_ajax_handlers();
|
|
|
528 |
} elseif ( $this->is_request( 'admin' ) ) {
|
529 |
$this->admin();
|
530 |
$this->admin_menu();
|
537 |
$this->users();
|
538 |
$this->dragdrop();
|
539 |
$this->plugin_updater();
|
|
|
540 |
} elseif ( $this->is_request( 'frontend' ) ) {
|
541 |
$this->enqueue();
|
542 |
$this->account();
|
562 |
$this->permalinks();
|
563 |
$this->modal();
|
564 |
$this->cron();
|
565 |
+
$this->tracking();
|
566 |
$this->mobile();
|
567 |
$this->external_integrations();
|
|
|
568 |
}
|
569 |
|
570 |
|
674 |
*/
|
675 |
function admin_upgrade() {
|
676 |
if ( empty( $this->classes['admin_upgrade'] ) ) {
|
677 |
+
$this->classes['admin_upgrade'] = new um\admin\core\Admin_Upgrade();
|
|
|
678 |
}
|
679 |
return $this->classes['admin_upgrade'];
|
680 |
}
|
681 |
|
682 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
683 |
/**
|
684 |
* @since 2.0
|
685 |
*
|
includes/core/class-access.php
CHANGED
@@ -65,10 +65,6 @@ if ( ! class_exists( 'um\core\Access' ) ) {
|
|
65 |
add_action( 'template_redirect', array( &$this, 'template_redirect' ), 1000 );
|
66 |
add_action( 'um_access_check_individual_term_settings', array( &$this, 'um_access_check_individual_term_settings' ) );
|
67 |
add_action( 'um_access_check_global_settings', array( &$this, 'um_access_check_global_settings' ) );
|
68 |
-
|
69 |
-
/* Disable comments if user has not permission to access current post */
|
70 |
-
add_filter( 'comments_open', array( $this, 'disable_comments_open' ), 99, 2 );
|
71 |
-
add_filter( 'get_comments_number', array( $this, 'disable_comments_open' ), 99, 2 );
|
72 |
}
|
73 |
|
74 |
|
@@ -536,7 +532,7 @@ if ( ! class_exists( 'um\core\Access' ) ) {
|
|
536 |
if ( ! empty( $post->post_type ) && $post->post_type == 'page' ) {
|
537 |
if ( um_is_core_post( $post, 'login' ) || um_is_core_post( $post, 'register' ) ||
|
538 |
um_is_core_post( $post, 'account' ) || um_is_core_post( $post, 'logout' ) ||
|
539 |
-
um_is_core_post( $post, 'password-reset' )
|
540 |
return false;
|
541 |
}
|
542 |
|
@@ -938,63 +934,6 @@ if ( ! class_exists( 'um\core\Access' ) ) {
|
|
938 |
}
|
939 |
|
940 |
|
941 |
-
/**
|
942 |
-
* Disable comments if user has not permission to access this post
|
943 |
-
* @param mixed $open
|
944 |
-
* @param int $post_id
|
945 |
-
* @return boolean
|
946 |
-
*/
|
947 |
-
public function disable_comments_open( $open, $post_id ) {
|
948 |
-
|
949 |
-
static $cache = array();
|
950 |
-
|
951 |
-
if ( isset( $cache[ $post_id ] ) ) {
|
952 |
-
return $cache[ $post_id ] ? $open : false;
|
953 |
-
}
|
954 |
-
|
955 |
-
$post = get_post( $post_id );
|
956 |
-
$restriction = $this->get_post_privacy_settings( $post );
|
957 |
-
|
958 |
-
if ( ! $restriction ) {
|
959 |
-
$cache[ $post_id ] = $open;
|
960 |
-
return $open;
|
961 |
-
}
|
962 |
-
|
963 |
-
if ( '1' == $restriction['_um_accessible'] ) {
|
964 |
-
|
965 |
-
if ( is_user_logged_in() ) {
|
966 |
-
if ( ! current_user_can( 'administrator' ) ) {
|
967 |
-
$open = false;
|
968 |
-
}
|
969 |
-
}
|
970 |
-
|
971 |
-
} elseif ( '2' == $restriction['_um_accessible'] ) {
|
972 |
-
if ( ! is_user_logged_in() ) {
|
973 |
-
$open = false;
|
974 |
-
} else {
|
975 |
-
if ( ! current_user_can( 'administrator' ) ) {
|
976 |
-
$custom_restrict = $this->um_custom_restriction( $restriction );
|
977 |
-
|
978 |
-
if ( empty( $restriction['_um_access_roles'] ) || false === array_search( '1', $restriction['_um_access_roles'] ) ) {
|
979 |
-
if ( ! $custom_restrict ) {
|
980 |
-
$open = false;
|
981 |
-
}
|
982 |
-
} else {
|
983 |
-
$user_can = $this->user_can( get_current_user_id(), $restriction['_um_access_roles'] );
|
984 |
-
|
985 |
-
if ( ! isset( $user_can ) || ! $user_can || ! $custom_restrict ) {
|
986 |
-
$open = false;
|
987 |
-
}
|
988 |
-
}
|
989 |
-
}
|
990 |
-
}
|
991 |
-
}
|
992 |
-
|
993 |
-
$cache[ $post_id ] = $open;
|
994 |
-
return $open;
|
995 |
-
}
|
996 |
-
|
997 |
-
|
998 |
/**
|
999 |
* Protect Post Types in menu query
|
1000 |
* Restrict content new logic
|
65 |
add_action( 'template_redirect', array( &$this, 'template_redirect' ), 1000 );
|
66 |
add_action( 'um_access_check_individual_term_settings', array( &$this, 'um_access_check_individual_term_settings' ) );
|
67 |
add_action( 'um_access_check_global_settings', array( &$this, 'um_access_check_global_settings' ) );
|
|
|
|
|
|
|
|
|
68 |
}
|
69 |
|
70 |
|
532 |
if ( ! empty( $post->post_type ) && $post->post_type == 'page' ) {
|
533 |
if ( um_is_core_post( $post, 'login' ) || um_is_core_post( $post, 'register' ) ||
|
534 |
um_is_core_post( $post, 'account' ) || um_is_core_post( $post, 'logout' ) ||
|
535 |
+
um_is_core_post( $post, 'password-reset' ) )
|
536 |
return false;
|
537 |
}
|
538 |
|
934 |
}
|
935 |
|
936 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
937 |
/**
|
938 |
* Protect Post Types in menu query
|
939 |
* Restrict content new logic
|
includes/core/class-account.php
CHANGED
@@ -55,7 +55,6 @@ if ( ! class_exists( 'um\core\Account' ) ) {
|
|
55 |
* @param $args
|
56 |
*/
|
57 |
function init_tabs( $args ) {
|
58 |
-
|
59 |
$this->tabs = $this->get_tabs();
|
60 |
|
61 |
ksort( $this->tabs );
|
@@ -76,6 +75,7 @@ if ( ! class_exists( 'um\core\Account' ) ) {
|
|
76 |
}
|
77 |
|
78 |
}
|
|
|
79 |
$this->tabs = $tabs_structed;
|
80 |
}
|
81 |
|
@@ -527,7 +527,7 @@ if ( ! class_exists( 'um\core\Account' ) ) {
|
|
527 |
* ?>
|
528 |
*/
|
529 |
$args = apply_filters( 'um_account_tab_privacy_fields', $args, $shortcode_args );
|
530 |
-
|
531 |
$fields = UM()->builtin()->get_specific_fields( $args );
|
532 |
$fields = $this->account_secure_fields( $fields, $id );
|
533 |
$fields = $this->filter_fields_by_attrs( $fields, $shortcode_args );
|
@@ -535,6 +535,7 @@ if ( ! class_exists( 'um\core\Account' ) ) {
|
|
535 |
foreach ( $fields as $key => $data ){
|
536 |
$output .= UM()->fields()->edit_field( $key, $data );
|
537 |
}
|
|
|
538 |
break;
|
539 |
|
540 |
case 'delete':
|
55 |
* @param $args
|
56 |
*/
|
57 |
function init_tabs( $args ) {
|
|
|
58 |
$this->tabs = $this->get_tabs();
|
59 |
|
60 |
ksort( $this->tabs );
|
75 |
}
|
76 |
|
77 |
}
|
78 |
+
|
79 |
$this->tabs = $tabs_structed;
|
80 |
}
|
81 |
|
527 |
* ?>
|
528 |
*/
|
529 |
$args = apply_filters( 'um_account_tab_privacy_fields', $args, $shortcode_args );
|
530 |
+
|
531 |
$fields = UM()->builtin()->get_specific_fields( $args );
|
532 |
$fields = $this->account_secure_fields( $fields, $id );
|
533 |
$fields = $this->filter_fields_by_attrs( $fields, $shortcode_args );
|
535 |
foreach ( $fields as $key => $data ){
|
536 |
$output .= UM()->fields()->edit_field( $key, $data );
|
537 |
}
|
538 |
+
|
539 |
break;
|
540 |
|
541 |
case 'delete':
|
includes/core/class-builtin.php
CHANGED
@@ -1252,7 +1252,7 @@ if ( ! class_exists( 'um\core\Builtin' ) ) {
|
|
1252 |
*/
|
1253 |
$fields_without_metakey = apply_filters( 'um_fields_without_metakey', $fields_without_metakey );
|
1254 |
|
1255 |
-
if (
|
1256 |
$this->fields_dropdown = array('image','file','password','rating');
|
1257 |
$this->fields_dropdown = array_merge( $this->fields_dropdown, $fields_without_metakey );
|
1258 |
} else {
|
1252 |
*/
|
1253 |
$fields_without_metakey = apply_filters( 'um_fields_without_metakey', $fields_without_metakey );
|
1254 |
|
1255 |
+
if ( !$show_all ) {
|
1256 |
$this->fields_dropdown = array('image','file','password','rating');
|
1257 |
$this->fields_dropdown = array_merge( $this->fields_dropdown, $fields_without_metakey );
|
1258 |
} else {
|
includes/core/class-enqueue.php
CHANGED
@@ -319,8 +319,6 @@ if ( ! class_exists( 'um\core\Enqueue' ) ) {
|
|
319 |
wp_register_script('um_functions', um_url . 'assets/js/um-functions' . $this->suffix . '.js', array('jquery', 'jquery-masonry') );
|
320 |
wp_enqueue_script('um_functions');
|
321 |
|
322 |
-
wp_enqueue_script( 'um-gdpr', um_url . 'assets/js/um-gdpr' . $this->suffix . '.js', array( 'jquery' ), ultimatemember_version, false );
|
323 |
-
|
324 |
}
|
325 |
|
326 |
|
@@ -465,7 +463,7 @@ if ( ! class_exists( 'um\core\Enqueue' ) ) {
|
|
465 |
wp_register_script('um_responsive', um_url . 'assets/js/um-responsive' . $this->suffix . '.js' );
|
466 |
wp_enqueue_script('um_responsive');
|
467 |
|
468 |
-
wp_register_style('um_responsive', um_url . 'assets/css/um-responsive.css'
|
469 |
wp_enqueue_style('um_responsive');
|
470 |
|
471 |
}
|
319 |
wp_register_script('um_functions', um_url . 'assets/js/um-functions' . $this->suffix . '.js', array('jquery', 'jquery-masonry') );
|
320 |
wp_enqueue_script('um_functions');
|
321 |
|
|
|
|
|
322 |
}
|
323 |
|
324 |
|
463 |
wp_register_script('um_responsive', um_url . 'assets/js/um-responsive' . $this->suffix . '.js' );
|
464 |
wp_enqueue_script('um_responsive');
|
465 |
|
466 |
+
wp_register_style('um_responsive', um_url . 'assets/css/um-responsive.css' );
|
467 |
wp_enqueue_style('um_responsive');
|
468 |
|
469 |
}
|
includes/core/class-fields.php
CHANGED
@@ -43,8 +43,9 @@ if ( ! class_exists( 'um\core\Fields' ) ) {
|
|
43 |
<div class="um-field um-field-c">
|
44 |
<div class="um-field-area">
|
45 |
<label class="um-field-checkbox active">
|
46 |
-
<input type="checkbox" name="<?php echo $id; ?>" value="1" checked
|
47 |
-
|
|
|
48 |
<span class="um-field-checkbox-option"> <?php echo $title; ?></span>
|
49 |
</label>
|
50 |
</div>
|
@@ -573,8 +574,7 @@ if ( ! class_exists( 'um\core\Fields' ) ) {
|
|
573 |
|
574 |
} elseif ( um_user( $key ) && $this->editing == true ) {
|
575 |
|
576 |
-
|
577 |
-
if ( strstr( $key, 'user_pass' ) || $type == 'password' ) {
|
578 |
return '';
|
579 |
}
|
580 |
|
@@ -799,11 +799,6 @@ if ( ! class_exists( 'um\core\Fields' ) ) {
|
|
799 |
return true;
|
800 |
}
|
801 |
|
802 |
-
$stripslashed = array_map( 'stripslashes', UM()->form()->post_form[ $key ] );
|
803 |
-
if ( in_array( $value, $stripslashed ) ) {
|
804 |
-
return true;
|
805 |
-
}
|
806 |
-
|
807 |
if ( in_array( html_entity_decode( $value ), UM()->form()->post_form[ $key ] ) ) {
|
808 |
return true;
|
809 |
}
|
@@ -814,21 +809,16 @@ if ( ! class_exists( 'um\core\Fields' ) ) {
|
|
814 |
|
815 |
$field_value = um_user( $key );
|
816 |
|
817 |
-
if (
|
818 |
|
819 |
$role_keys = get_option( 'um_roles' );
|
820 |
|
821 |
-
if (
|
822 |
-
if (
|
823 |
$field_value = 'um_' . $field_value;
|
824 |
}
|
825 |
}
|
826 |
-
|
827 |
-
$data['default'] = UM()->options()->get( 'register_role' );
|
828 |
-
}
|
829 |
-
else{
|
830 |
-
$data['default'] = get_option( 'default_role' );
|
831 |
-
}*/
|
832 |
}
|
833 |
|
834 |
/**
|
@@ -941,25 +931,19 @@ if ( ! class_exists( 'um\core\Fields' ) ) {
|
|
941 |
|
942 |
$um_user_value = um_user( $key );
|
943 |
|
944 |
-
if (
|
945 |
$um_user_value = strtolower( $um_user_value );
|
946 |
|
947 |
$role_keys = get_option( 'um_roles' );
|
948 |
|
949 |
-
if (
|
950 |
-
if (
|
951 |
$um_user_value = 'um_' . $um_user_value;
|
952 |
}
|
953 |
}
|
954 |
-
/*elseif( $this->set_mode == 'register' ){
|
955 |
-
$data['default'] = UM()->options()->get( 'register_role' );
|
956 |
-
}
|
957 |
-
else{
|
958 |
-
$data['default'] = get_option( 'default_role' );
|
959 |
-
}*/
|
960 |
}
|
961 |
|
962 |
-
if (
|
963 |
return true;
|
964 |
}
|
965 |
|
@@ -1545,11 +1529,10 @@ if ( ! class_exists( 'um\core\Fields' ) ) {
|
|
1545 |
* @param string $key
|
1546 |
* @param array $data
|
1547 |
* @param boolean $rule
|
1548 |
-
* @param array $args
|
1549 |
*
|
1550 |
* @return string
|
1551 |
*/
|
1552 |
-
function edit_field( $key, $data, $rule = false
|
1553 |
global $_um_profile_id;
|
1554 |
$output = null;
|
1555 |
$disabled = '';
|
@@ -1583,7 +1566,7 @@ if ( ! class_exists( 'um\core\Fields' ) ) {
|
|
1583 |
* @var boolean $required
|
1584 |
* @var string $validate
|
1585 |
* @var string $default
|
1586 |
-
|
1587 |
*/
|
1588 |
extract( $data );
|
1589 |
}
|
@@ -1595,7 +1578,7 @@ if ( ! class_exists( 'um\core\Fields' ) ) {
|
|
1595 |
|
1596 |
if ($visibility == 'view' && $this->set_mode != 'register') return;
|
1597 |
|
1598 |
-
if (
|
1599 |
( isset( $data['editable'] ) && $data['editable'] == 0 && $this->set_mode == 'profile' )
|
1600 |
) {
|
1601 |
|
@@ -1636,7 +1619,6 @@ if ( ! class_exists( 'um\core\Fields' ) ) {
|
|
1636 |
// forbidden in edit mode?
|
1637 |
if (isset( $data['edit_forbidden'] )) return;
|
1638 |
|
1639 |
-
|
1640 |
// required option
|
1641 |
if (isset( $data['required_opt'] )) {
|
1642 |
$opt = $data['required_opt'];
|
@@ -1680,47 +1662,7 @@ if ( ! class_exists( 'um\core\Fields' ) ) {
|
|
1680 |
* ?>
|
1681 |
*/
|
1682 |
$type = apply_filters( "um_hook_for_field_{$type}", $type );
|
1683 |
-
switch ( $type ) {
|
1684 |
-
|
1685 |
-
case 'textarea':
|
1686 |
-
case 'multiselect':
|
1687 |
-
$field_id = $field_name = $key;
|
1688 |
-
$field_value = $this->field_value( $key, $default, $data );
|
1689 |
-
break;
|
1690 |
|
1691 |
-
case 'select':
|
1692 |
-
case 'radio':
|
1693 |
-
$form_key = str_replace( 'role_select', 'role', $key );
|
1694 |
-
$field_id = $form_key;
|
1695 |
-
break;
|
1696 |
-
default:
|
1697 |
-
$field_id = '';
|
1698 |
-
break;
|
1699 |
-
}
|
1700 |
-
|
1701 |
-
/**
|
1702 |
-
* UM hook
|
1703 |
-
*
|
1704 |
-
* @type filter
|
1705 |
-
* @title um_completeness_field_id
|
1706 |
-
* @description use for change core id not allowed duplicate
|
1707 |
-
* @input_vars
|
1708 |
-
* [{"var":"$field_id","type":"string","desc":"Field id"},
|
1709 |
-
* {"var":"$data","type":"array","desc":"Field Data"}]
|
1710 |
-
* {"var":"$args","type":"array","desc":"Optional field arguments"}]
|
1711 |
-
* @change_log
|
1712 |
-
* ["Since: 2.0.13"]
|
1713 |
-
* @usage add_filter( 'um_completeness_field_id', 'function_name', 10, 3 );
|
1714 |
-
* @example
|
1715 |
-
* <?php
|
1716 |
-
* add_filter( 'um_completeness_field_id', 'function_name', 10, 3 );
|
1717 |
-
* function function_name( $field_id, $data, $args ) {
|
1718 |
-
* // your code here
|
1719 |
-
* return $field_id;
|
1720 |
-
* }
|
1721 |
-
* ?>
|
1722 |
-
*/
|
1723 |
-
$field_id = apply_filters( 'um_completeness_field_id', $field_id, $data, $args );
|
1724 |
/* Begin by field type */
|
1725 |
switch ( $type ) {
|
1726 |
|
@@ -1779,8 +1721,8 @@ if ( ! class_exists( 'um\core\Fields' ) ) {
|
|
1779 |
|
1780 |
</div>';
|
1781 |
|
1782 |
-
|
1783 |
-
|
1784 |
}
|
1785 |
|
1786 |
if ($this->is_error( $key )) {
|
@@ -2090,6 +2032,8 @@ if ( ! class_exists( 'um\core\Fields' ) ) {
|
|
2090 |
}
|
2091 |
|
2092 |
$output .= '<div class="um-field-area">';
|
|
|
|
|
2093 |
|
2094 |
if (isset( $data['html'] ) && $data['html'] != 0 && $key != "description") {
|
2095 |
|
@@ -2140,17 +2084,16 @@ if ( ! class_exists( 'um\core\Fields' ) ) {
|
|
2140 |
// add the contents of the buffer to the output variable
|
2141 |
$output .= ob_get_clean();
|
2142 |
|
2143 |
-
} else
|
2144 |
-
$output .= '<textarea ' . $disabled . ' style="height: ' . $height . ';" class="' . $this->get_class( $key, $data ) . '" name="' . $field_name . '" id="' . $field_id . '" placeholder="' . $placeholder . '">' . $field_value . '</textarea>';
|
2145 |
-
}
|
2146 |
|
2147 |
-
$output .= '
|
|
|
2148 |
|
2149 |
-
if (
|
2150 |
$output .= $this->disabled_hidden_field( $field_name, $field_value );
|
2151 |
}
|
2152 |
|
2153 |
-
if (
|
2154 |
$output .= $this->field_error( $this->show_error( $key ) );
|
2155 |
}
|
2156 |
|
@@ -2168,6 +2111,7 @@ if ( ! class_exists( 'um\core\Fields' ) ) {
|
|
2168 |
$output .= '<div class="um-field-area">';
|
2169 |
|
2170 |
$output .= '<div class="um-rating um-raty" id="' . $key . '" data-key="' . $key . '" data-number="' . $data['number'] . '" data-score="' . $this->field_value( $key, $default, $data ) . '"></div>';
|
|
|
2171 |
$output .= '</div>';
|
2172 |
|
2173 |
$output .= '</div>';
|
@@ -2369,6 +2313,8 @@ if ( ! class_exists( 'um\core\Fields' ) ) {
|
|
2369 |
/* Select dropdown */
|
2370 |
case 'select':
|
2371 |
|
|
|
|
|
2372 |
$output .= '<div class="um-field' . $classes . '"' . $conditional . ' data-key="' . $key . '">';
|
2373 |
|
2374 |
|
@@ -2488,10 +2434,10 @@ if ( ! class_exists( 'um\core\Fields' ) ) {
|
|
2488 |
}
|
2489 |
|
2490 |
if( ! empty( $placeholder ) ) {
|
2491 |
-
|
2492 |
-
|
2493 |
|
2494 |
-
$output .= '<select ' . $disabled . ' ' . $select_original_option_value . ' ' . $disabled_by_parent_option . ' name="' . $form_key . '" id="' . $
|
2495 |
|
2496 |
/**
|
2497 |
* UM hook
|
@@ -2685,7 +2631,7 @@ if ( ! class_exists( 'um\core\Fields' ) ) {
|
|
2685 |
$output .= '<div class="um-field-icon"><i class="' . $icon . '"></i></div>';
|
2686 |
}
|
2687 |
|
2688 |
-
$output .= '<select ' . $disabled . ' multiple="multiple" name="' . $
|
2689 |
|
2690 |
|
2691 |
if ( isset( $options ) && $options == 'builtin' ) {
|
@@ -2822,6 +2768,8 @@ if ( ! class_exists( 'um\core\Fields' ) ) {
|
|
2822 |
/* Radio */
|
2823 |
case 'radio':
|
2824 |
|
|
|
|
|
2825 |
if ( isset( $options ) ) {
|
2826 |
/**
|
2827 |
* UM hook
|
@@ -2890,7 +2838,7 @@ if ( ! class_exists( 'um\core\Fields' ) ) {
|
|
2890 |
$um_field_checkbox_item_title = $v;
|
2891 |
$option_value = $v;
|
2892 |
|
2893 |
-
if (
|
2894 |
$um_field_checkbox_item_title = $v;
|
2895 |
$option_value = $k;
|
2896 |
}
|
@@ -3484,12 +3432,9 @@ if ( ! class_exists( 'um\core\Fields' ) ) {
|
|
3484 |
|
3485 |
if (isset( $data['in_group'] ) && $data['in_group'] != '' && $rule != 'group') return;
|
3486 |
|
3487 |
-
if (
|
3488 |
-
|
3489 |
-
//invisible on profile page
|
3490 |
-
if ( $type == 'password' ) return;
|
3491 |
|
3492 |
-
if (
|
3493 |
|
3494 |
} else {
|
3495 |
|
43 |
<div class="um-field um-field-c">
|
44 |
<div class="um-field-area">
|
45 |
<label class="um-field-checkbox active">
|
46 |
+
<input type="checkbox" name="<?php echo $id; ?>" value="1" checked/><span
|
47 |
+
class="um-field-checkbox-state"><i
|
48 |
+
class="um-icon-android-checkbox-outline"></i></span>
|
49 |
<span class="um-field-checkbox-option"> <?php echo $title; ?></span>
|
50 |
</label>
|
51 |
</div>
|
574 |
|
575 |
} elseif ( um_user( $key ) && $this->editing == true ) {
|
576 |
|
577 |
+
if ( strstr( $key, 'user_pass' ) ) {
|
|
|
578 |
return '';
|
579 |
}
|
580 |
|
799 |
return true;
|
800 |
}
|
801 |
|
|
|
|
|
|
|
|
|
|
|
802 |
if ( in_array( html_entity_decode( $value ), UM()->form()->post_form[ $key ] ) ) {
|
803 |
return true;
|
804 |
}
|
809 |
|
810 |
$field_value = um_user( $key );
|
811 |
|
812 |
+
if ($key == 'role') {
|
813 |
|
814 |
$role_keys = get_option( 'um_roles' );
|
815 |
|
816 |
+
if (!empty( $role_keys )) {
|
817 |
+
if (in_array( $field_value, $role_keys )) {
|
818 |
$field_value = 'um_' . $field_value;
|
819 |
}
|
820 |
}
|
821 |
+
|
|
|
|
|
|
|
|
|
|
|
822 |
}
|
823 |
|
824 |
/**
|
931 |
|
932 |
$um_user_value = um_user( $key );
|
933 |
|
934 |
+
if ($key == 'role') {
|
935 |
$um_user_value = strtolower( $um_user_value );
|
936 |
|
937 |
$role_keys = get_option( 'um_roles' );
|
938 |
|
939 |
+
if (!empty( $role_keys )) {
|
940 |
+
if (in_array( $um_user_value, $role_keys )) {
|
941 |
$um_user_value = 'um_' . $um_user_value;
|
942 |
}
|
943 |
}
|
|
|
|
|
|
|
|
|
|
|
|
|
944 |
}
|
945 |
|
946 |
+
if ($um_user_value == $value) {
|
947 |
return true;
|
948 |
}
|
949 |
|
1529 |
* @param string $key
|
1530 |
* @param array $data
|
1531 |
* @param boolean $rule
|
|
|
1532 |
*
|
1533 |
* @return string
|
1534 |
*/
|
1535 |
+
function edit_field( $key, $data, $rule = false ) {
|
1536 |
global $_um_profile_id;
|
1537 |
$output = null;
|
1538 |
$disabled = '';
|
1566 |
* @var boolean $required
|
1567 |
* @var string $validate
|
1568 |
* @var string $default
|
1569 |
+
* @var string $conditional
|
1570 |
*/
|
1571 |
extract( $data );
|
1572 |
}
|
1578 |
|
1579 |
if ($visibility == 'view' && $this->set_mode != 'register') return;
|
1580 |
|
1581 |
+
if (( $visibility == 'view' && $this->set_mode == 'register' ) ||
|
1582 |
( isset( $data['editable'] ) && $data['editable'] == 0 && $this->set_mode == 'profile' )
|
1583 |
) {
|
1584 |
|
1619 |
// forbidden in edit mode?
|
1620 |
if (isset( $data['edit_forbidden'] )) return;
|
1621 |
|
|
|
1622 |
// required option
|
1623 |
if (isset( $data['required_opt'] )) {
|
1624 |
$opt = $data['required_opt'];
|
1662 |
* ?>
|
1663 |
*/
|
1664 |
$type = apply_filters( "um_hook_for_field_{$type}", $type );
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1665 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1666 |
/* Begin by field type */
|
1667 |
switch ( $type ) {
|
1668 |
|
1721 |
|
1722 |
</div>';
|
1723 |
|
1724 |
+
if (!empty( $disabled )) {
|
1725 |
+
$output .= $this->disabled_hidden_field( $field_name, $field_value );
|
1726 |
}
|
1727 |
|
1728 |
if ($this->is_error( $key )) {
|
2032 |
}
|
2033 |
|
2034 |
$output .= '<div class="um-field-area">';
|
2035 |
+
$field_name = $key;
|
2036 |
+
$field_value = $this->field_value( $key, $default, $data );
|
2037 |
|
2038 |
if (isset( $data['html'] ) && $data['html'] != 0 && $key != "description") {
|
2039 |
|
2084 |
// add the contents of the buffer to the output variable
|
2085 |
$output .= ob_get_clean();
|
2086 |
|
2087 |
+
} else $output .= '<textarea ' . $disabled . ' style="height: ' . $height . ';" class="' . $this->get_class( $key, $data ) . '" name="' . $key . '" id="' . $key . '" placeholder="' . $placeholder . '">' . $field_value . '</textarea>';
|
|
|
|
|
2088 |
|
2089 |
+
$output .= '
|
2090 |
+
</div>';
|
2091 |
|
2092 |
+
if (!empty( $disabled )) {
|
2093 |
$output .= $this->disabled_hidden_field( $field_name, $field_value );
|
2094 |
}
|
2095 |
|
2096 |
+
if ($this->is_error( $key )) {
|
2097 |
$output .= $this->field_error( $this->show_error( $key ) );
|
2098 |
}
|
2099 |
|
2111 |
$output .= '<div class="um-field-area">';
|
2112 |
|
2113 |
$output .= '<div class="um-rating um-raty" id="' . $key . '" data-key="' . $key . '" data-number="' . $data['number'] . '" data-score="' . $this->field_value( $key, $default, $data ) . '"></div>';
|
2114 |
+
|
2115 |
$output .= '</div>';
|
2116 |
|
2117 |
$output .= '</div>';
|
2313 |
/* Select dropdown */
|
2314 |
case 'select':
|
2315 |
|
2316 |
+
$form_key = str_replace( 'role_select', 'role', $key );
|
2317 |
+
|
2318 |
$output .= '<div class="um-field' . $classes . '"' . $conditional . ' data-key="' . $key . '">';
|
2319 |
|
2320 |
|
2434 |
}
|
2435 |
|
2436 |
if( ! empty( $placeholder ) ) {
|
2437 |
+
$placeholder = strip_tags( $placeholder );
|
2438 |
+
}
|
2439 |
|
2440 |
+
$output .= '<select ' . $disabled . ' ' . $select_original_option_value . ' ' . $disabled_by_parent_option . ' name="' . $form_key . '" id="' . $form_key . '" data-validate="' . $validate . '" data-key="' . $key . '" class="' . $this->get_class( $key, $data, $class ) . '" style="width: 100%" data-placeholder="' . $placeholder . '" ' . $atts_ajax . '>';
|
2441 |
|
2442 |
/**
|
2443 |
* UM hook
|
2631 |
$output .= '<div class="um-field-icon"><i class="' . $icon . '"></i></div>';
|
2632 |
}
|
2633 |
|
2634 |
+
$output .= '<select ' . $disabled . ' multiple="multiple" name="' . $key . '[]" id="' . $key . '" data-maxsize="' . $max_selections . '" data-validate="' . $validate . '" data-key="' . $key . '" class="' . $this->get_class( $key, $data, $class ) . ' um-user-keyword_' . $use_keyword . '" style="width: 100%" data-placeholder="' . $placeholder . '">';
|
2635 |
|
2636 |
|
2637 |
if ( isset( $options ) && $options == 'builtin' ) {
|
2768 |
/* Radio */
|
2769 |
case 'radio':
|
2770 |
|
2771 |
+
$form_key = str_replace( 'role_radio', 'role', $key );
|
2772 |
+
|
2773 |
if ( isset( $options ) ) {
|
2774 |
/**
|
2775 |
* UM hook
|
2838 |
$um_field_checkbox_item_title = $v;
|
2839 |
$option_value = $v;
|
2840 |
|
2841 |
+
if (!is_numeric( $k ) && in_array( $form_key, array( 'role' ) )) {
|
2842 |
$um_field_checkbox_item_title = $v;
|
2843 |
$option_value = $k;
|
2844 |
}
|
3432 |
|
3433 |
if (isset( $data['in_group'] ) && $data['in_group'] != '' && $rule != 'group') return;
|
3434 |
|
3435 |
+
if ($visibility == 'edit') return;
|
|
|
|
|
|
|
3436 |
|
3437 |
+
if (in_array( $type, array( 'block', 'shortcode', 'spacing', 'divider', 'group' ) )) {
|
3438 |
|
3439 |
} else {
|
3440 |
|
includes/core/class-form.php
CHANGED
@@ -331,6 +331,19 @@ if ( ! class_exists( 'um\core\Form' ) ) {
|
|
331 |
wp_die( 'Hello, spam bot!', 'ultimate-member' );
|
332 |
}
|
333 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
334 |
/**
|
335 |
* UM hook
|
336 |
*
|
@@ -465,9 +478,8 @@ if ( ! class_exists( 'um\core\Form' ) ) {
|
|
465 |
$global_role = get_option( 'default_role' ); // WP Global settings
|
466 |
|
467 |
$um_global_role = UM()->options()->get( 'register_role' ); // UM Settings Global settings
|
468 |
-
if ( ! empty( $um_global_role ) )
|
469 |
$global_role = $um_global_role; // Form Global settings
|
470 |
-
}
|
471 |
|
472 |
|
473 |
$mode = $this->form_type( $post_id );
|
331 |
wp_die( 'Hello, spam bot!', 'ultimate-member' );
|
332 |
}
|
333 |
|
334 |
+
if ( ! in_array( $this->form_data['mode'], array( 'login' ) ) ) {
|
335 |
+
|
336 |
+
$form_timestamp = trim($_POST['timestamp']);
|
337 |
+
$live_timestamp = current_time( 'timestamp' );
|
338 |
+
|
339 |
+
if ( $form_timestamp == '' && UM()->options()->get( 'enable_timebot' ) == 1 )
|
340 |
+
wp_die( __('Hello, spam bot!','ultimate-member') );
|
341 |
+
|
342 |
+
if ( !current_user_can('manage_options') && $live_timestamp - $form_timestamp < 6 && UM()->options()->get( 'enable_timebot' ) == 1 )
|
343 |
+
wp_die( __('Whoa, slow down! You\'re seeing this message because you tried to submit a form too fast and we think you might be a spam bot. If you are a real human being please wait a few seconds before submitting the form. Thanks!','ultimate-member') );
|
344 |
+
|
345 |
+
}
|
346 |
+
|
347 |
/**
|
348 |
* UM hook
|
349 |
*
|
478 |
$global_role = get_option( 'default_role' ); // WP Global settings
|
479 |
|
480 |
$um_global_role = UM()->options()->get( 'register_role' ); // UM Settings Global settings
|
481 |
+
if ( ! empty( $um_global_role ) )
|
482 |
$global_role = $um_global_role; // Form Global settings
|
|
|
483 |
|
484 |
|
485 |
$mode = $this->form_type( $post_id );
|
includes/core/class-gdpr.php
DELETED
@@ -1,86 +0,0 @@
|
|
1 |
-
<?php
|
2 |
-
namespace um\core;
|
3 |
-
|
4 |
-
// Exit if accessed directly.
|
5 |
-
if ( ! defined( 'ABSPATH' ) ) exit;
|
6 |
-
|
7 |
-
|
8 |
-
if ( ! class_exists( 'um\core\GDPR' ) ) {
|
9 |
-
|
10 |
-
|
11 |
-
/**
|
12 |
-
* Class Admin_GDPR
|
13 |
-
* @package um\core
|
14 |
-
*/
|
15 |
-
class GDPR {
|
16 |
-
|
17 |
-
|
18 |
-
/**
|
19 |
-
* Admin_GDPR constructor.
|
20 |
-
*/
|
21 |
-
function __construct() {
|
22 |
-
add_action( 'um_submit_form_register', array( &$this, 'agreement_validation' ), 9 );
|
23 |
-
|
24 |
-
add_filter( 'um_before_save_filter_submitted', array( &$this, 'add_agreement_date' ), 10, 1 );
|
25 |
-
add_filter( 'um_email_registration_data', array( &$this, 'email_registration_data' ), 10, 1 );
|
26 |
-
|
27 |
-
add_action( 'um_after_form_fields', array( &$this, 'display_option' ) );
|
28 |
-
}
|
29 |
-
|
30 |
-
|
31 |
-
/**
|
32 |
-
* @param $args
|
33 |
-
*/
|
34 |
-
function display_option( $args ) {
|
35 |
-
if ( isset( $args['use_gdpr'] ) && $args['use_gdpr'] == 1 ) {
|
36 |
-
require um_path . 'templates/gdpr-register.php';
|
37 |
-
}
|
38 |
-
}
|
39 |
-
|
40 |
-
|
41 |
-
/**
|
42 |
-
* @param $args
|
43 |
-
*/
|
44 |
-
function agreement_validation( $args ) {
|
45 |
-
$gdpr_enabled = get_post_meta( $args['form_id'], '_um_register_use_gdpr', true );
|
46 |
-
|
47 |
-
if ( $gdpr_enabled && ! isset( $args['submitted']['use_gdpr_agreement'] ) ) {
|
48 |
-
UM()->form()->add_error( 'use_gdpr_agreement', isset( $args['use_gdpr_error_text'] ) ? $args['use_gdpr_error_text'] : '' );
|
49 |
-
}
|
50 |
-
}
|
51 |
-
|
52 |
-
|
53 |
-
/**
|
54 |
-
* @param $submitted
|
55 |
-
*
|
56 |
-
* @return mixed
|
57 |
-
*/
|
58 |
-
function add_agreement_date( $submitted ) {
|
59 |
-
if ( isset( $submitted['use_gdpr_agreement'] ) ) {
|
60 |
-
$submitted['use_gdpr_agreement'] = time();
|
61 |
-
}
|
62 |
-
|
63 |
-
return $submitted;
|
64 |
-
}
|
65 |
-
|
66 |
-
|
67 |
-
/**
|
68 |
-
* @param $submitted
|
69 |
-
*
|
70 |
-
* @return mixed
|
71 |
-
*/
|
72 |
-
function email_registration_data( $submitted ) {
|
73 |
-
|
74 |
-
$timestamp = ! empty( $submitted['timestamp'] ) ? $submitted['timestamp'] : $submitted['use_gdpr_agreement'];
|
75 |
-
|
76 |
-
if ( ! empty( $submitted['use_gdpr_agreement'] ) ) {
|
77 |
-
$submitted['GDPR Applied'] = date( "d M Y H:i", $timestamp );
|
78 |
-
unset( $submitted['use_gdpr_agreement'] );
|
79 |
-
}
|
80 |
-
|
81 |
-
return $submitted;
|
82 |
-
}
|
83 |
-
|
84 |
-
}
|
85 |
-
|
86 |
-
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
includes/core/class-mail.php
CHANGED
@@ -124,14 +124,10 @@ if ( ! class_exists( 'um\core\Mail' ) ) {
|
|
124 |
|
125 |
$this->message = $this->prepare_template( $template, $args );
|
126 |
|
127 |
-
|
128 |
-
$this->headers .= "Content-Type: text/html\r\n";
|
129 |
-
} else {
|
130 |
-
$this->headers .= "Content-Type: text/plain\r\n";
|
131 |
-
}
|
132 |
-
|
133 |
// Send mail
|
134 |
wp_mail( $email, $this->subject, $this->message, $this->headers, $this->attachments );
|
|
|
135 |
}
|
136 |
|
137 |
|
@@ -485,6 +481,22 @@ if ( ! class_exists( 'um\core\Mail' ) ) {
|
|
485 |
}
|
486 |
|
487 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
488 |
/**
|
489 |
* Ajax copy template to the theme
|
490 |
*
|
124 |
|
125 |
$this->message = $this->prepare_template( $template, $args );
|
126 |
|
127 |
+
add_filter( 'wp_mail_content_type', array( &$this, 'set_content_type' ) );
|
|
|
|
|
|
|
|
|
|
|
128 |
// Send mail
|
129 |
wp_mail( $email, $this->subject, $this->message, $this->headers, $this->attachments );
|
130 |
+
remove_filter( 'wp_mail_content_type', array( &$this, 'set_content_type' ) );
|
131 |
}
|
132 |
|
133 |
|
481 |
}
|
482 |
|
483 |
|
484 |
+
/**
|
485 |
+
* Set email content type
|
486 |
+
*
|
487 |
+
*
|
488 |
+
* @param $content_type
|
489 |
+
* @return string
|
490 |
+
*/
|
491 |
+
function set_content_type( $content_type ) {
|
492 |
+
if ( UM()->options()->get( 'email_html' ) ) {
|
493 |
+
return 'text/html';
|
494 |
+
} else {
|
495 |
+
return 'text/plain';
|
496 |
+
}
|
497 |
+
}
|
498 |
+
|
499 |
+
|
500 |
/**
|
501 |
* Ajax copy template to the theme
|
502 |
*
|
includes/core/class-permalinks.php
CHANGED
@@ -136,15 +136,22 @@ if ( ! class_exists( 'um\core\Permalinks' ) ) {
|
|
136 |
$um_port_forwarding_url = UM()->options()->get( 'um_port_forwarding_url' );
|
137 |
$um_port_forwarding_url = ! empty( $um_port_forwarding_url ) ? $um_port_forwarding_url : '';
|
138 |
|
139 |
-
$page_url = '';
|
140 |
if ( is_multisite() ) {
|
|
|
|
|
141 |
$blog_id = get_current_blog_id();
|
142 |
$siteurl = get_site_url( $blog_id );
|
143 |
|
144 |
$network_permalink_structure = UM()->options()->get( 'network_permalink_structure' );
|
145 |
|
146 |
if( $network_permalink_structure == "sub-directory" ){
|
147 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
148 |
$page_url .= $_SERVER[ $server_name_method ];
|
149 |
}else{
|
150 |
$page_url .= $siteurl;
|
@@ -152,6 +159,7 @@ if ( ! class_exists( 'um\core\Permalinks' ) ) {
|
|
152 |
|
153 |
if ( $um_port_forwarding_url == 1 && isset( $_SERVER["SERVER_PORT"] ) ) {
|
154 |
$page_url .= ":".$_SERVER["SERVER_PORT"].$_SERVER["REQUEST_URI"];
|
|
|
155 |
} else {
|
156 |
$page_url .= $_SERVER["REQUEST_URI"];
|
157 |
}
|
@@ -160,7 +168,13 @@ if ( ! class_exists( 'um\core\Permalinks' ) ) {
|
|
160 |
if ( !isset( $_SERVER['SERVER_NAME'] ) )
|
161 |
return '';
|
162 |
|
163 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
164 |
|
165 |
if ( $um_port_forwarding_url == 1 && isset( $_SERVER["SERVER_PORT"] ) ) {
|
166 |
$page_url .= $_SERVER[ $server_name_method ].":".$_SERVER["SERVER_PORT"].$_SERVER["REQUEST_URI"];
|
@@ -196,7 +210,7 @@ if ( ! class_exists( 'um\core\Permalinks' ) ) {
|
|
196 |
* }
|
197 |
* ?>
|
198 |
*/
|
199 |
-
return apply_filters( 'um_get_current_page_url',
|
200 |
}
|
201 |
|
202 |
|
136 |
$um_port_forwarding_url = UM()->options()->get( 'um_port_forwarding_url' );
|
137 |
$um_port_forwarding_url = ! empty( $um_port_forwarding_url ) ? $um_port_forwarding_url : '';
|
138 |
|
|
|
139 |
if ( is_multisite() ) {
|
140 |
+
|
141 |
+
$page_url = '';
|
142 |
$blog_id = get_current_blog_id();
|
143 |
$siteurl = get_site_url( $blog_id );
|
144 |
|
145 |
$network_permalink_structure = UM()->options()->get( 'network_permalink_structure' );
|
146 |
|
147 |
if( $network_permalink_structure == "sub-directory" ){
|
148 |
+
if ( is_ssl() ) {
|
149 |
+
$page_url = 'https';
|
150 |
+
} else {
|
151 |
+
$page_url = 'http';
|
152 |
+
}
|
153 |
+
$page_url .= "://";
|
154 |
+
|
155 |
$page_url .= $_SERVER[ $server_name_method ];
|
156 |
}else{
|
157 |
$page_url .= $siteurl;
|
159 |
|
160 |
if ( $um_port_forwarding_url == 1 && isset( $_SERVER["SERVER_PORT"] ) ) {
|
161 |
$page_url .= ":".$_SERVER["SERVER_PORT"].$_SERVER["REQUEST_URI"];
|
162 |
+
|
163 |
} else {
|
164 |
$page_url .= $_SERVER["REQUEST_URI"];
|
165 |
}
|
168 |
if ( !isset( $_SERVER['SERVER_NAME'] ) )
|
169 |
return '';
|
170 |
|
171 |
+
|
172 |
+
if ( is_ssl() ) {
|
173 |
+
$page_url = 'https';
|
174 |
+
} else {
|
175 |
+
$page_url = 'http';
|
176 |
+
}
|
177 |
+
$page_url .= "://";
|
178 |
|
179 |
if ( $um_port_forwarding_url == 1 && isset( $_SERVER["SERVER_PORT"] ) ) {
|
180 |
$page_url .= $_SERVER[ $server_name_method ].":".$_SERVER["SERVER_PORT"].$_SERVER["REQUEST_URI"];
|
210 |
* }
|
211 |
* ?>
|
212 |
*/
|
213 |
+
return apply_filters( 'um_get_current_page_url', $page_url );
|
214 |
}
|
215 |
|
216 |
|
includes/core/class-profile.php
CHANGED
@@ -118,18 +118,11 @@ if ( ! class_exists( 'um\core\Profile' ) ) {
|
|
118 |
|
119 |
// disable private tabs
|
120 |
if ( ! is_admin() ) {
|
121 |
-
if( is_user_logged_in() ) {
|
122 |
-
$user_id = um_user('ID');
|
123 |
-
um_fetch_user( get_current_user_id() );
|
124 |
-
}
|
125 |
foreach ( $tabs as $id => $tab ) {
|
126 |
if ( ! $this->can_view_tab( $id ) ) {
|
127 |
unset( $tabs[$id] );
|
128 |
}
|
129 |
}
|
130 |
-
if( is_user_logged_in() ) {
|
131 |
-
um_fetch_user( $user_id );
|
132 |
-
}
|
133 |
}
|
134 |
|
135 |
return $tabs;
|
118 |
|
119 |
// disable private tabs
|
120 |
if ( ! is_admin() ) {
|
|
|
|
|
|
|
|
|
121 |
foreach ( $tabs as $id => $tab ) {
|
122 |
if ( ! $this->can_view_tab( $id ) ) {
|
123 |
unset( $tabs[$id] );
|
124 |
}
|
125 |
}
|
|
|
|
|
|
|
126 |
}
|
127 |
|
128 |
return $tabs;
|
includes/core/class-rest-api.php
CHANGED
@@ -524,9 +524,9 @@ if ( ! class_exists( 'um\core\REST_API' ) ) {
|
|
524 |
$val->first_name = um_user('first_name');
|
525 |
$val->last_name = um_user('last_name');
|
526 |
$val->account_status = um_user('account_status');
|
527 |
-
$val->profile_pic_original =
|
528 |
-
$val->profile_pic_normal =
|
529 |
-
$val->profile_pic_small =
|
530 |
$val->cover_photo = $this->getsrc( um_user('cover_photo', 1000) );
|
531 |
|
532 |
/**
|
@@ -667,9 +667,9 @@ if ( ! class_exists( 'um\core\REST_API' ) ) {
|
|
667 |
break;
|
668 |
|
669 |
case 'profile_pic':
|
670 |
-
$response['profile_pic_original'] =
|
671 |
-
$response['profile_pic_normal'] =
|
672 |
-
$response['profile_pic_small'] =
|
673 |
break;
|
674 |
|
675 |
case 'status':
|
@@ -699,9 +699,9 @@ if ( ! class_exists( 'um\core\REST_API' ) ) {
|
|
699 |
$val->first_name = um_user('first_name');
|
700 |
$val->last_name = um_user('last_name');
|
701 |
$val->account_status = um_user('account_status');
|
702 |
-
$val->profile_pic_original =
|
703 |
-
$val->profile_pic_normal =
|
704 |
-
$val->profile_pic_small =
|
705 |
$val->cover_photo = $this->getsrc( um_user('cover_photo', 1000) );
|
706 |
|
707 |
/**
|
524 |
$val->first_name = um_user('first_name');
|
525 |
$val->last_name = um_user('last_name');
|
526 |
$val->account_status = um_user('account_status');
|
527 |
+
$val->profile_pic_original = $this->getsrc( um_user('profile_photo', 'original') );
|
528 |
+
$val->profile_pic_normal = $this->getsrc( um_user('profile_photo', 200) );
|
529 |
+
$val->profile_pic_small = $this->getsrc( um_user('profile_photo', 40) );
|
530 |
$val->cover_photo = $this->getsrc( um_user('cover_photo', 1000) );
|
531 |
|
532 |
/**
|
667 |
break;
|
668 |
|
669 |
case 'profile_pic':
|
670 |
+
$response['profile_pic_original'] = $this->getsrc( um_user('profile_photo', 'original') );
|
671 |
+
$response['profile_pic_normal'] = $this->getsrc( um_user('profile_photo', 200) );
|
672 |
+
$response['profile_pic_small'] = $this->getsrc( um_user('profile_photo', 40) );
|
673 |
break;
|
674 |
|
675 |
case 'status':
|
699 |
$val->first_name = um_user('first_name');
|
700 |
$val->last_name = um_user('last_name');
|
701 |
$val->account_status = um_user('account_status');
|
702 |
+
$val->profile_pic_original = $this->getsrc( um_user('profile_photo', 'original') );
|
703 |
+
$val->profile_pic_normal = $this->getsrc( um_user('profile_photo', 200) );
|
704 |
+
$val->profile_pic_small = $this->getsrc( um_user('profile_photo', 40) );
|
705 |
$val->cover_photo = $this->getsrc( um_user('cover_photo', 1000) );
|
706 |
|
707 |
/**
|
includes/core/class-user.php
CHANGED
@@ -39,7 +39,6 @@ if ( ! class_exists( 'um\core\User' ) ) {
|
|
39 |
add_action( 'init', array( &$this, 'set' ), 1 );
|
40 |
|
41 |
$this->preview = false;
|
42 |
-
$this->send_mail_on_delete = true;
|
43 |
|
44 |
// a list of keys that should never be in wp_usermeta
|
45 |
$this->update_user_keys = array(
|
@@ -55,8 +54,6 @@ if ( ! class_exists( 'um\core\User' ) ) {
|
|
55 |
|
56 |
// When the cache should be cleared
|
57 |
add_action('um_delete_user_hook', array(&$this, 'remove_cached_queue') );
|
58 |
-
add_action('um_delete_user', array( &$this, 'remove_cache' ), 10, 1 );
|
59 |
-
|
60 |
add_action('um_after_user_status_is_changed_hook', array(&$this, 'remove_cached_queue') );
|
61 |
|
62 |
// When user cache should be cleared
|
@@ -86,73 +83,6 @@ if ( ! class_exists( 'um\core\User' ) ) {
|
|
86 |
add_action( 'wpmu_activate_user', array( &$this, 'add_um_role_wpmu_new_user' ), 10, 1 );
|
87 |
|
88 |
add_action( 'init', array( &$this, 'check_membership' ), 10 );
|
89 |
-
|
90 |
-
add_action( 'delete_user', array( &$this, 'delete_user_handler' ), 10, 1 );
|
91 |
-
add_action( 'wpmu_delete_user', array( &$this, 'delete_user_handler' ), 10, 1 );
|
92 |
-
}
|
93 |
-
|
94 |
-
|
95 |
-
/**
|
96 |
-
* @param $user_id
|
97 |
-
*/
|
98 |
-
function delete_user_handler( $user_id ) {
|
99 |
-
|
100 |
-
um_fetch_user( $user_id );
|
101 |
-
|
102 |
-
/**
|
103 |
-
* UM hook
|
104 |
-
*
|
105 |
-
* @type action
|
106 |
-
* @title um_delete_user_hook
|
107 |
-
* @description On delete user
|
108 |
-
* @change_log
|
109 |
-
* ["Since: 2.0"]
|
110 |
-
* @usage add_action( 'um_delete_user_hook', 'function_name', 10 );
|
111 |
-
* @example
|
112 |
-
* <?php
|
113 |
-
* add_action( 'um_delete_user_hook', 'my_delete_user', 10 );
|
114 |
-
* function my_delete_user() {
|
115 |
-
* // your code here
|
116 |
-
* }
|
117 |
-
* ?>
|
118 |
-
*/
|
119 |
-
do_action( 'um_delete_user_hook' );
|
120 |
-
|
121 |
-
/**
|
122 |
-
* UM hook
|
123 |
-
*
|
124 |
-
* @type action
|
125 |
-
* @title um_delete_user
|
126 |
-
* @description On delete user
|
127 |
-
* @input_vars
|
128 |
-
* [{"var":"$user_id","type":"int","desc":"User ID"}]
|
129 |
-
* @change_log
|
130 |
-
* ["Since: 2.0"]
|
131 |
-
* @usage add_action( 'um_delete_user', 'function_name', 10, 1 );
|
132 |
-
* @example
|
133 |
-
* <?php
|
134 |
-
* add_action( 'um_delete_user', 'my_delete_user', 10, 1 );
|
135 |
-
* function my_delete_user( $user_id ) {
|
136 |
-
* // your code here
|
137 |
-
* }
|
138 |
-
* ?>
|
139 |
-
*/
|
140 |
-
do_action( 'um_delete_user', um_user( 'ID' ) );
|
141 |
-
|
142 |
-
// send email notifications
|
143 |
-
if ( $this->send_mail_on_delete ) {
|
144 |
-
UM()->mail()->send( um_user( 'user_email' ), 'deletion_email' );
|
145 |
-
|
146 |
-
$emails = um_multi_admin_email();
|
147 |
-
if ( ! empty( $emails ) ) {
|
148 |
-
foreach ( $emails as $email ) {
|
149 |
-
UM()->mail()->send( $email, 'notification_deletion', array( 'admin' => true ) );
|
150 |
-
}
|
151 |
-
}
|
152 |
-
}
|
153 |
-
|
154 |
-
// remove uploads
|
155 |
-
UM()->files()->remove_dir( um_user_uploads_dir() );
|
156 |
}
|
157 |
|
158 |
|
@@ -960,20 +890,6 @@ if ( ! class_exists( 'um\core\User' ) ) {
|
|
960 |
unset( $submitted['confirm_user_password'] );
|
961 |
}
|
962 |
|
963 |
-
//remove all password field values from submitted details
|
964 |
-
$password_fields = array();
|
965 |
-
foreach ( $submitted as $k => $v ) {
|
966 |
-
if ( UM()->fields()->get_field_type( $k ) == 'password' ) {
|
967 |
-
$password_fields[] = $k;
|
968 |
-
$password_fields[] = 'confirm_' . $k;
|
969 |
-
}
|
970 |
-
}
|
971 |
-
|
972 |
-
foreach ( $password_fields as $pw_field ) {
|
973 |
-
unset( $submitted[ $pw_field ] );
|
974 |
-
}
|
975 |
-
|
976 |
-
|
977 |
/**
|
978 |
* UM hook
|
979 |
*
|
@@ -1358,10 +1274,59 @@ if ( ! class_exists( 'um\core\User' ) ) {
|
|
1358 |
* @param bool $send_mail
|
1359 |
*/
|
1360 |
function delete( $send_mail = true ) {
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1361 |
|
1362 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1363 |
|
1364 |
-
|
|
|
1365 |
|
1366 |
// remove user
|
1367 |
if ( is_multisite() ) {
|
@@ -1661,29 +1626,23 @@ if ( ! class_exists( 'um\core\User' ) ) {
|
|
1661 |
}
|
1662 |
|
1663 |
}
|
1664 |
-
|
1665 |
-
|
1666 |
// update user
|
1667 |
if ( count( $args ) > 1 ) {
|
|
|
|
|
1668 |
|
1669 |
-
|
1670 |
-
|
1671 |
-
|
1672 |
-
|
1673 |
-
|
1674 |
-
|
1675 |
-
|
1676 |
-
return 'um_' . $item;
|
1677 |
-
}, get_option( 'um_roles' ) );
|
1678 |
-
} else {
|
1679 |
-
$role_keys = array();
|
1680 |
-
}
|
1681 |
|
1682 |
-
|
1683 |
|
1684 |
-
|
1685 |
-
|
1686 |
-
}
|
1687 |
}
|
1688 |
|
1689 |
wp_update_user( $args );
|
39 |
add_action( 'init', array( &$this, 'set' ), 1 );
|
40 |
|
41 |
$this->preview = false;
|
|
|
42 |
|
43 |
// a list of keys that should never be in wp_usermeta
|
44 |
$this->update_user_keys = array(
|
54 |
|
55 |
// When the cache should be cleared
|
56 |
add_action('um_delete_user_hook', array(&$this, 'remove_cached_queue') );
|
|
|
|
|
57 |
add_action('um_after_user_status_is_changed_hook', array(&$this, 'remove_cached_queue') );
|
58 |
|
59 |
// When user cache should be cleared
|
83 |
add_action( 'wpmu_activate_user', array( &$this, 'add_um_role_wpmu_new_user' ), 10, 1 );
|
84 |
|
85 |
add_action( 'init', array( &$this, 'check_membership' ), 10 );
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
86 |
}
|
87 |
|
88 |
|
890 |
unset( $submitted['confirm_user_password'] );
|
891 |
}
|
892 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
893 |
/**
|
894 |
* UM hook
|
895 |
*
|
1274 |
* @param bool $send_mail
|
1275 |
*/
|
1276 |
function delete( $send_mail = true ) {
|
1277 |
+
/**
|
1278 |
+
* UM hook
|
1279 |
+
*
|
1280 |
+
* @type action
|
1281 |
+
* @title um_delete_user_hook
|
1282 |
+
* @description On delete user
|
1283 |
+
* @change_log
|
1284 |
+
* ["Since: 2.0"]
|
1285 |
+
* @usage add_action( 'um_delete_user_hook', 'function_name', 10 );
|
1286 |
+
* @example
|
1287 |
+
* <?php
|
1288 |
+
* add_action( 'um_delete_user_hook', 'my_delete_user', 10 );
|
1289 |
+
* function my_delete_user() {
|
1290 |
+
* // your code here
|
1291 |
+
* }
|
1292 |
+
* ?>
|
1293 |
+
*/
|
1294 |
+
do_action( 'um_delete_user_hook' );
|
1295 |
+
/**
|
1296 |
+
* UM hook
|
1297 |
+
*
|
1298 |
+
* @type action
|
1299 |
+
* @title um_delete_user
|
1300 |
+
* @description On delete user
|
1301 |
+
* @input_vars
|
1302 |
+
* [{"var":"$user_id","type":"int","desc":"User ID"}]
|
1303 |
+
* @change_log
|
1304 |
+
* ["Since: 2.0"]
|
1305 |
+
* @usage add_action( 'um_delete_user', 'function_name', 10, 1 );
|
1306 |
+
* @example
|
1307 |
+
* <?php
|
1308 |
+
* add_action( 'um_delete_user', 'my_delete_user', 10, 1 );
|
1309 |
+
* function my_delete_user( $user_id ) {
|
1310 |
+
* // your code here
|
1311 |
+
* }
|
1312 |
+
* ?>
|
1313 |
+
*/
|
1314 |
+
do_action( 'um_delete_user', um_user( 'ID' ) );
|
1315 |
|
1316 |
+
// send email notifications
|
1317 |
+
if ( $send_mail ) {
|
1318 |
+
UM()->mail()->send( um_user( 'user_email' ), 'deletion_email' );
|
1319 |
+
|
1320 |
+
$emails = um_multi_admin_email();
|
1321 |
+
if ( ! empty( $emails ) ) {
|
1322 |
+
foreach ( $emails as $email ) {
|
1323 |
+
UM()->mail()->send( $email, 'notification_deletion', array( 'admin' => true ) );
|
1324 |
+
}
|
1325 |
+
}
|
1326 |
+
}
|
1327 |
|
1328 |
+
// remove uploads
|
1329 |
+
UM()->files()->remove_dir( um_user_uploads_dir() );
|
1330 |
|
1331 |
// remove user
|
1332 |
if ( is_multisite() ) {
|
1626 |
}
|
1627 |
|
1628 |
}
|
|
|
|
|
1629 |
// update user
|
1630 |
if ( count( $args ) > 1 ) {
|
1631 |
+
global $wp_roles;
|
1632 |
+
$um_roles = get_option( 'um_roles' );
|
1633 |
|
1634 |
+
if ( ! empty( $um_roles ) ) {
|
1635 |
+
$role_keys = array_map( function( $item ) {
|
1636 |
+
return 'um_' . $item;
|
1637 |
+
}, get_option( 'um_roles' ) );
|
1638 |
+
} else {
|
1639 |
+
$role_keys = array();
|
1640 |
+
}
|
|
|
|
|
|
|
|
|
|
|
1641 |
|
1642 |
+
$exclude_roles = array_diff( array_keys( $wp_roles->roles ), array_merge( $role_keys, array( 'subscriber' ) ) );
|
1643 |
|
1644 |
+
if ( isset( $args['role'] ) && in_array( $args['role'], $exclude_roles ) ) {
|
1645 |
+
unset( $args['role'] );
|
|
|
1646 |
}
|
1647 |
|
1648 |
wp_update_user( $args );
|
includes/core/um-actions-core.php
CHANGED
@@ -108,9 +108,7 @@ function um_action_request_process() {
|
|
108 |
break;
|
109 |
|
110 |
case 'um_delete':
|
111 |
-
if ( ! UM()->roles()->um_current_user_can( 'delete', $uid ) )
|
112 |
-
wp_die( __('You do not have permission to delete this user.','ultimate-member') );
|
113 |
-
}
|
114 |
um_fetch_user( $uid );
|
115 |
UM()->user()->delete();
|
116 |
exit( wp_redirect( UM()->permalinks()->get_current_url( true ) ) );
|
108 |
break;
|
109 |
|
110 |
case 'um_delete':
|
111 |
+
if ( ! UM()->roles()->um_current_user_can( 'delete', $uid ) ) wp_die( __('You do not have permission to delete this user.','ultimate-member') );
|
|
|
|
|
112 |
um_fetch_user( $uid );
|
113 |
UM()->user()->delete();
|
114 |
exit( wp_redirect( UM()->permalinks()->get_current_url( true ) ) );
|
includes/core/um-actions-form.php
CHANGED
@@ -314,9 +314,8 @@ function um_submit_form_errors_hook_( $args ) {
|
|
314 |
foreach ( $array['conditions'] as $condition ) {
|
315 |
list( $visibility, $parent_key, $op, $parent_value ) = $condition;
|
316 |
|
317 |
-
if ( ! isset( $args[ $parent_key ] ) )
|
318 |
continue;
|
319 |
-
}
|
320 |
|
321 |
$cond_value = ( $fields[ $parent_key ]['type'] == 'radio' ) ? $args[ $parent_key ][0] : $args[ $parent_key ];
|
322 |
|
@@ -338,11 +337,11 @@ function um_submit_form_errors_hook_( $args ) {
|
|
338 |
continue 2;
|
339 |
}
|
340 |
} elseif ( $op == 'greater than' ) {
|
341 |
-
if ( $cond_value > $
|
342 |
continue 2;
|
343 |
}
|
344 |
} elseif ( $op == 'less than' ) {
|
345 |
-
if ( $cond_value < $
|
346 |
continue 2;
|
347 |
}
|
348 |
} elseif ( $op == 'contains' ) {
|
@@ -368,11 +367,11 @@ function um_submit_form_errors_hook_( $args ) {
|
|
368 |
continue 2;
|
369 |
}
|
370 |
} elseif ( $op == 'greater than' ) {
|
371 |
-
if ( $cond_value <= $
|
372 |
continue 2;
|
373 |
}
|
374 |
} elseif ( $op == 'less than' ) {
|
375 |
-
if ( $cond_value >= $
|
376 |
continue 2;
|
377 |
}
|
378 |
} elseif ( $op == 'contains' ) {
|
314 |
foreach ( $array['conditions'] as $condition ) {
|
315 |
list( $visibility, $parent_key, $op, $parent_value ) = $condition;
|
316 |
|
317 |
+
if ( ! isset( $args[ $parent_key ] ) )
|
318 |
continue;
|
|
|
319 |
|
320 |
$cond_value = ( $fields[ $parent_key ]['type'] == 'radio' ) ? $args[ $parent_key ][0] : $args[ $parent_key ];
|
321 |
|
337 |
continue 2;
|
338 |
}
|
339 |
} elseif ( $op == 'greater than' ) {
|
340 |
+
if ( $cond_value > $op ) {
|
341 |
continue 2;
|
342 |
}
|
343 |
} elseif ( $op == 'less than' ) {
|
344 |
+
if ( $cond_value < $op ) {
|
345 |
continue 2;
|
346 |
}
|
347 |
} elseif ( $op == 'contains' ) {
|
367 |
continue 2;
|
368 |
}
|
369 |
} elseif ( $op == 'greater than' ) {
|
370 |
+
if ( $cond_value <= $op ) {
|
371 |
continue 2;
|
372 |
}
|
373 |
} elseif ( $op == 'less than' ) {
|
374 |
+
if ( $cond_value >= $op ) {
|
375 |
continue 2;
|
376 |
}
|
377 |
} elseif ( $op == 'contains' ) {
|
includes/core/um-actions-password.php
CHANGED
@@ -133,6 +133,15 @@ function um_reset_password_errors_hook( $args ) {
|
|
133 |
if ( $_POST[ UM()->honeypot ] != '' )
|
134 |
wp_die('Hello, spam bot!','ultimate-member');
|
135 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
136 |
$user = "";
|
137 |
|
138 |
foreach ( $_POST as $key => $val ) {
|
@@ -188,6 +197,16 @@ function um_change_password_errors_hook( $args ) {
|
|
188 |
wp_die('Hello, spam bot!','ultimate-member');
|
189 |
}
|
190 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
191 |
$reset_pass_hash = '';
|
192 |
|
193 |
if( isset( $_REQUEST['act'] ) && $_REQUEST['act'] == 'reset_password' && um_is_core_page('password-reset') ){
|
133 |
if ( $_POST[ UM()->honeypot ] != '' )
|
134 |
wp_die('Hello, spam bot!','ultimate-member');
|
135 |
|
136 |
+
$form_timestamp = trim($_POST['timestamp']);
|
137 |
+
$live_timestamp = current_time( 'timestamp' );
|
138 |
+
|
139 |
+
if ( $form_timestamp == '' && UM()->options()->get( 'enable_timebot' ) == 1 )
|
140 |
+
wp_die( __('Hello, spam bot!','ultimate-member') );
|
141 |
+
|
142 |
+
if ( $live_timestamp - $form_timestamp < 3 && UM()->options()->get( 'enable_timebot' ) == 1 )
|
143 |
+
wp_die( __('Whoa, slow down! You\'re seeing this message because you tried to submit a form too fast and we think you might be a spam bot. If you are a real human being please wait a few seconds before submitting the form. Thanks!','ultimate-member') );
|
144 |
+
|
145 |
$user = "";
|
146 |
|
147 |
foreach ( $_POST as $key => $val ) {
|
197 |
wp_die('Hello, spam bot!','ultimate-member');
|
198 |
}
|
199 |
|
200 |
+
$form_timestamp = trim($_POST['timestamp']);
|
201 |
+
$live_timestamp = current_time( 'timestamp' );
|
202 |
+
|
203 |
+
if ( $form_timestamp == '' && UM()->options()->get( 'enable_timebot' ) == 1 )
|
204 |
+
wp_die( __('Hello, spam bot!','ultimate-member') );
|
205 |
+
|
206 |
+
if ( $live_timestamp - $form_timestamp < 3 && UM()->options()->get( 'enable_timebot' ) == 1 ) {
|
207 |
+
wp_die( __('Whoa, slow down! You\'re seeing this message because you tried to submit a form too fast and we think you might be a spam bot. If you are a real human being please wait a few seconds before submitting the form. Thanks!','ultimate-member') );
|
208 |
+
}
|
209 |
+
|
210 |
$reset_pass_hash = '';
|
211 |
|
212 |
if( isset( $_REQUEST['act'] ) && $_REQUEST['act'] == 'reset_password' && um_is_core_page('password-reset') ){
|
includes/core/um-actions-profile.php
CHANGED
@@ -218,12 +218,8 @@ function um_user_edit_profile( $args ) {
|
|
218 |
|
219 |
// loop through fields
|
220 |
if ( ! empty( $fields ) ) {
|
221 |
-
|
222 |
foreach ( $fields as $key => $array ) {
|
223 |
|
224 |
-
/*if ( ! um_can_edit_field( $fields[ $key ] ) )
|
225 |
-
continue;*/
|
226 |
-
|
227 |
if ( ! um_can_edit_field( $fields[ $key ] ) && isset( $fields[ $key ]['editable'] ) && ! $fields[ $key ]['editable'] )
|
228 |
continue;
|
229 |
|
@@ -240,15 +236,10 @@ function um_user_edit_profile( $args ) {
|
|
240 |
|
241 |
} else {
|
242 |
|
243 |
-
if ( $
|
244 |
-
$to_update[ $key ] =
|
245 |
-
|
246 |
-
|
247 |
-
if ( isset( $userinfo[ $key ] ) && $args['submitted'][ $key ] != $userinfo[ $key ] ) {
|
248 |
-
$to_update[ $key ] = $args['submitted'][ $key ];
|
249 |
-
} elseif ( $args['submitted'][ $key ] ) {
|
250 |
-
$to_update[ $key ] = $args['submitted'][ $key ];
|
251 |
-
}
|
252 |
}
|
253 |
|
254 |
}
|
@@ -527,7 +518,11 @@ function um_profile_dynamic_meta_desc() {
|
|
527 |
$user_id = um_user( 'ID' );
|
528 |
$url = um_user_profile_url();
|
529 |
|
530 |
-
|
|
|
|
|
|
|
|
|
531 |
|
532 |
um_reset_user(); ?>
|
533 |
|
@@ -1377,46 +1372,40 @@ function um_profile_menu( $args ) {
|
|
1377 |
|
1378 |
<div class="um-profile-nav-item um-profile-nav-<?php echo $id . ' ' . $profile_nav_class; ?>">
|
1379 |
<?php if ( UM()->options()->get( 'profile_menu_icons' ) ) { ?>
|
1380 |
-
<a href="<?php echo $nav_link; ?>" class="
|
1381 |
title="<?php echo esc_attr( $tab['name'] ); ?>" original-title="<?php echo esc_attr( $tab['name'] ); ?>">
|
1382 |
|
1383 |
<i class="<?php echo $tab['icon']; ?>"></i>
|
1384 |
|
1385 |
<?php if ( isset( $tab['notifier'] ) && $tab['notifier'] > 0 ) { ?>
|
1386 |
-
<span class="um-tab-notifier
|
1387 |
<?php } ?>
|
1388 |
|
1389 |
-
<span class="
|
1390 |
-
</a>
|
1391 |
-
<a href="<?php echo $nav_link; ?>" class="uimob800-hide uimob500-hide uimob340-hide"
|
1392 |
-
title="<?php echo esc_attr( $tab['name'] ); ?>">
|
1393 |
-
|
1394 |
-
<i class="<?php echo $tab['icon']; ?>"></i>
|
1395 |
|
1396 |
-
<?php if ( isset( $tab['notifier'] ) && $tab['notifier'] > 0 ) { ?>
|
1397 |
-
<span class="um-tab-notifier uimob800-show uimob500-show uimob340-show"><?php echo $tab['notifier']; ?></span>
|
1398 |
-
<?php } ?>
|
1399 |
-
|
1400 |
-
<span class="title"><?php echo $tab['name']; ?></span>
|
1401 |
</a>
|
1402 |
-
|
1403 |
-
<a href="<?php echo $nav_link; ?>" class="uimob800-show uimob500-show uimob340-show um-tip-n"
|
1404 |
title="<?php echo esc_attr( $tab['name'] ); ?>" original-title="<?php echo esc_attr( $tab['name'] ); ?>">
|
1405 |
|
1406 |
<i class="<?php echo $tab['icon']; ?>"></i>
|
1407 |
|
1408 |
<?php if ( isset( $tab['notifier'] ) && $tab['notifier'] > 0 ) { ?>
|
1409 |
-
<span class="um-tab-notifier
|
1410 |
<?php } ?>
|
|
|
|
|
|
|
1411 |
</a>
|
1412 |
-
|
1413 |
-
|
|
|
1414 |
|
1415 |
<?php if ( isset( $tab['notifier'] ) && $tab['notifier'] > 0) { ?>
|
1416 |
-
<span class="um-tab-notifier
|
1417 |
<?php } ?>
|
1418 |
|
1419 |
-
<span class="title"><?php echo $tab['name']; ?></span>
|
|
|
1420 |
</a>
|
1421 |
<?php } ?>
|
1422 |
</div>
|
218 |
|
219 |
// loop through fields
|
220 |
if ( ! empty( $fields ) ) {
|
|
|
221 |
foreach ( $fields as $key => $array ) {
|
222 |
|
|
|
|
|
|
|
223 |
if ( ! um_can_edit_field( $fields[ $key ] ) && isset( $fields[ $key ]['editable'] ) && ! $fields[ $key ]['editable'] )
|
224 |
continue;
|
225 |
|
236 |
|
237 |
} else {
|
238 |
|
239 |
+
if ( isset( $userinfo[ $key ] ) && $args['submitted'][ $key ] != $userinfo[ $key ] ) {
|
240 |
+
$to_update[ $key ] = $args['submitted'][ $key ];
|
241 |
+
} elseif ( $args['submitted'][ $key ] ) {
|
242 |
+
$to_update[ $key ] = $args['submitted'][ $key ];
|
|
|
|
|
|
|
|
|
|
|
243 |
}
|
244 |
|
245 |
}
|
518 |
$user_id = um_user( 'ID' );
|
519 |
$url = um_user_profile_url();
|
520 |
|
521 |
+
if (um_profile( 'profile_photo' )) {
|
522 |
+
$avatar = um_user_uploads_uri() . um_profile( 'profile_photo' );
|
523 |
+
} else {
|
524 |
+
$avatar = um_get_default_avatar_uri();
|
525 |
+
}
|
526 |
|
527 |
um_reset_user(); ?>
|
528 |
|
1372 |
|
1373 |
<div class="um-profile-nav-item um-profile-nav-<?php echo $id . ' ' . $profile_nav_class; ?>">
|
1374 |
<?php if ( UM()->options()->get( 'profile_menu_icons' ) ) { ?>
|
1375 |
+
<a href="<?php echo $nav_link; ?>" class="um-tip-n uimob500-show uimob340-show uimob800-show"
|
1376 |
title="<?php echo esc_attr( $tab['name'] ); ?>" original-title="<?php echo esc_attr( $tab['name'] ); ?>">
|
1377 |
|
1378 |
<i class="<?php echo $tab['icon']; ?>"></i>
|
1379 |
|
1380 |
<?php if ( isset( $tab['notifier'] ) && $tab['notifier'] > 0 ) { ?>
|
1381 |
+
<span class="um-tab-notifier uimob500-show uimob340-show uimob800-show"><?php echo $tab['notifier']; ?></span>
|
1382 |
<?php } ?>
|
1383 |
|
1384 |
+
<span class="uimob500-hide uimob340-hide uimob800-hide title"><?php echo $tab['name']; ?></span>
|
|
|
|
|
|
|
|
|
|
|
1385 |
|
|
|
|
|
|
|
|
|
|
|
1386 |
</a>
|
1387 |
+
<a href="<?php echo $nav_link; ?>" class="uimob500-hide uimob340-hide uimob800-hide"
|
|
|
1388 |
title="<?php echo esc_attr( $tab['name'] ); ?>" original-title="<?php echo esc_attr( $tab['name'] ); ?>">
|
1389 |
|
1390 |
<i class="<?php echo $tab['icon']; ?>"></i>
|
1391 |
|
1392 |
<?php if ( isset( $tab['notifier'] ) && $tab['notifier'] > 0 ) { ?>
|
1393 |
+
<span class="um-tab-notifier uimob500-show uimob340-show uimob800-show"><?php echo $tab['notifier']; ?></span>
|
1394 |
<?php } ?>
|
1395 |
+
|
1396 |
+
<span class="uimob500-hide uimob340-hide uimob800-hide title"><?php echo $tab['name']; ?></span>
|
1397 |
+
|
1398 |
</a>
|
1399 |
+
<?php } else { ?>
|
1400 |
+
<a href="<?php echo $nav_link; ?>" title="<?php echo esc_attr( $tab['name'] ); ?>"
|
1401 |
+
original-title="<?php echo esc_attr( $tab['name'] ); ?>">
|
1402 |
|
1403 |
<?php if ( isset( $tab['notifier'] ) && $tab['notifier'] > 0) { ?>
|
1404 |
+
<span class="um-tab-notifier uimob500-show uimob340-show uimob800-show"><?php echo $tab['notifier']; ?></span>
|
1405 |
<?php } ?>
|
1406 |
|
1407 |
+
<span class="uimob500-hide uimob340-hide uimob800-hide title"><?php echo $tab['name']; ?></span>
|
1408 |
+
|
1409 |
</a>
|
1410 |
<?php } ?>
|
1411 |
</div>
|
includes/core/um-actions-register.php
CHANGED
@@ -54,9 +54,8 @@ function um_after_insert_user( $user_id, $args ) {
|
|
54 |
//clear Users cached queue
|
55 |
UM()->user()->remove_cached_queue();
|
56 |
|
57 |
-
um_fetch_user( $user_id );
|
58 |
-
UM()->user()->set_status( um_user( 'status' ) );
|
59 |
if ( ! empty( $args['submitted'] ) ) {
|
|
|
60 |
UM()->user()->set_registration_details( $args['submitted'] );
|
61 |
}
|
62 |
|
@@ -104,7 +103,7 @@ function um_after_insert_user( $user_id, $args ) {
|
|
104 |
*/
|
105 |
do_action( 'um_registration_complete', $user_id, $args );
|
106 |
}
|
107 |
-
add_action( 'um_user_register', 'um_after_insert_user',
|
108 |
|
109 |
|
110 |
/**
|
@@ -119,7 +118,7 @@ function um_send_registration_notification( $user_id, $args ) {
|
|
119 |
$emails = um_multi_admin_email();
|
120 |
if ( ! empty( $emails ) ) {
|
121 |
foreach ( $emails as $email ) {
|
122 |
-
if ( um_user( '
|
123 |
UM()->mail()->send( $email, 'notification_new_user', array( 'admin' => true ) );
|
124 |
} else {
|
125 |
UM()->mail()->send( $email, 'notification_review', array( 'admin' => true ) );
|
@@ -137,7 +136,7 @@ add_action( 'um_registration_complete', 'um_send_registration_notification', 10,
|
|
137 |
* @param $args
|
138 |
*/
|
139 |
function um_check_user_status( $user_id, $args ) {
|
140 |
-
$status = um_user( '
|
141 |
|
142 |
/**
|
143 |
* UM hook
|
@@ -369,30 +368,6 @@ function um_submit_form_register( $args ) {
|
|
369 |
$args['submitted'] = array_merge( $args['submitted'], $credentials );
|
370 |
$args = array_merge( $args, $credentials );
|
371 |
|
372 |
-
//get user role from global or form's settings
|
373 |
-
$user_role = UM()->form()->assigned_role( UM()->form()->form_id );
|
374 |
-
|
375 |
-
//get user role from field Role dropdown or radio
|
376 |
-
if ( isset( $args['role'] ) ) {
|
377 |
-
global $wp_roles;
|
378 |
-
$um_roles = get_option( 'um_roles' );
|
379 |
-
|
380 |
-
if ( ! empty( $um_roles ) ) {
|
381 |
-
$role_keys = array_map( function( $item ) {
|
382 |
-
return 'um_' . $item;
|
383 |
-
}, get_option( 'um_roles' ) );
|
384 |
-
} else {
|
385 |
-
$role_keys = array();
|
386 |
-
}
|
387 |
-
|
388 |
-
$exclude_roles = array_diff( array_keys( $wp_roles->roles ), array_merge( $role_keys, array( 'subscriber' ) ) );
|
389 |
-
|
390 |
-
//if role is properly set it
|
391 |
-
if ( ! in_array( $args['role'], $exclude_roles ) ) {
|
392 |
-
$user_role = $args['role'];
|
393 |
-
}
|
394 |
-
}
|
395 |
-
|
396 |
/**
|
397 |
* UM hook
|
398 |
*
|
@@ -415,7 +390,7 @@ function um_submit_form_register( $args ) {
|
|
415 |
* }
|
416 |
* ?>
|
417 |
*/
|
418 |
-
$user_role = apply_filters( 'um_registration_user_role',
|
419 |
|
420 |
$userdata = array(
|
421 |
'user_login' => $user_login,
|
@@ -750,18 +725,4 @@ function um_registration_set_profile_full_name( $user_id, $args ) {
|
|
750 |
*/
|
751 |
do_action( 'um_update_profile_full_name', $user_id, $args );
|
752 |
}
|
753 |
-
add_action( 'um_registration_set_extra_data', 'um_registration_set_profile_full_name', 10, 2 );
|
754 |
-
|
755 |
-
|
756 |
-
/**
|
757 |
-
* Redirect from default registration to UM registration page
|
758 |
-
*/
|
759 |
-
function um_form_register_redirect() {
|
760 |
-
$page_id = UM()->options()->get( UM()->options()->get_core_page_id( 'register' ) );
|
761 |
-
$register_post = get_post( $page_id );
|
762 |
-
if ( ! empty( $register_post ) ) {
|
763 |
-
wp_safe_redirect( get_permalink( $page_id ) );
|
764 |
-
exit();
|
765 |
-
}
|
766 |
-
}
|
767 |
-
add_action( 'login_form_register', 'um_form_register_redirect', 10 );
|
54 |
//clear Users cached queue
|
55 |
UM()->user()->remove_cached_queue();
|
56 |
|
|
|
|
|
57 |
if ( ! empty( $args['submitted'] ) ) {
|
58 |
+
um_fetch_user( $user_id );
|
59 |
UM()->user()->set_registration_details( $args['submitted'] );
|
60 |
}
|
61 |
|
103 |
*/
|
104 |
do_action( 'um_registration_complete', $user_id, $args );
|
105 |
}
|
106 |
+
add_action( 'um_user_register', 'um_after_insert_user', 10, 2 );
|
107 |
|
108 |
|
109 |
/**
|
118 |
$emails = um_multi_admin_email();
|
119 |
if ( ! empty( $emails ) ) {
|
120 |
foreach ( $emails as $email ) {
|
121 |
+
if ( um_user( 'status' ) != 'pending' ) {
|
122 |
UM()->mail()->send( $email, 'notification_new_user', array( 'admin' => true ) );
|
123 |
} else {
|
124 |
UM()->mail()->send( $email, 'notification_review', array( 'admin' => true ) );
|
136 |
* @param $args
|
137 |
*/
|
138 |
function um_check_user_status( $user_id, $args ) {
|
139 |
+
$status = um_user( 'status' );
|
140 |
|
141 |
/**
|
142 |
* UM hook
|
368 |
$args['submitted'] = array_merge( $args['submitted'], $credentials );
|
369 |
$args = array_merge( $args, $credentials );
|
370 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
371 |
/**
|
372 |
* UM hook
|
373 |
*
|
390 |
* }
|
391 |
* ?>
|
392 |
*/
|
393 |
+
$user_role = apply_filters( 'um_registration_user_role', UM()->form()->assigned_role( UM()->form()->form_id ), $args );
|
394 |
|
395 |
$userdata = array(
|
396 |
'user_login' => $user_login,
|
725 |
*/
|
726 |
do_action( 'um_update_profile_full_name', $user_id, $args );
|
727 |
}
|
728 |
+
add_action( 'um_registration_set_extra_data', 'um_registration_set_profile_full_name', 10, 2 );
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
includes/core/um-filters-avatars.php
CHANGED
@@ -27,6 +27,7 @@ add_filter( 'avatar_defaults', 'um_avatar_defaults', 99999 );
|
|
27 |
* @return string returns avatar in image html elements
|
28 |
*/
|
29 |
function um_get_avatar( $avatar = '', $id_or_email='', $size = '96', $avatar_class = '', $default = '', $alt = '' ) {
|
|
|
30 |
if ( is_numeric($id_or_email) )
|
31 |
$user_id = (int) $id_or_email;
|
32 |
elseif ( is_string( $id_or_email ) && ( $user = get_user_by( 'email', $id_or_email ) ) )
|
@@ -40,6 +41,64 @@ function um_get_avatar( $avatar = '', $id_or_email='', $size = '96', $avatar_cla
|
|
40 |
|
41 |
$avatar = um_user('profile_photo', $size);
|
42 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
43 |
return $avatar;
|
44 |
}
|
45 |
add_filter( 'get_avatar', 'um_get_avatar', 99999, 5 );
|
27 |
* @return string returns avatar in image html elements
|
28 |
*/
|
29 |
function um_get_avatar( $avatar = '', $id_or_email='', $size = '96', $avatar_class = '', $default = '', $alt = '' ) {
|
30 |
+
|
31 |
if ( is_numeric($id_or_email) )
|
32 |
$user_id = (int) $id_or_email;
|
33 |
elseif ( is_string( $id_or_email ) && ( $user = get_user_by( 'email', $id_or_email ) ) )
|
41 |
|
42 |
$avatar = um_user('profile_photo', $size);
|
43 |
|
44 |
+
/**
|
45 |
+
* UM hook
|
46 |
+
*
|
47 |
+
* @type filter
|
48 |
+
* @title um_avatar_image_alternate_text
|
49 |
+
* @description Change avatar image alt
|
50 |
+
* @input_vars
|
51 |
+
* [{"var":"$avatar_alt","type":"string","desc":"Image alternate text. Display name by default"}]
|
52 |
+
* @change_log
|
53 |
+
* ["Since: 2.0"]
|
54 |
+
* @usage
|
55 |
+
* <?php add_filter( 'um_avatar_image_alternate_text', 'function_name', 10, 1 ); ?>
|
56 |
+
* @example
|
57 |
+
* <?php
|
58 |
+
* add_filter( 'um_avatar_image_alternate_text', 'my_avatar_image_alternate_text', 10, 1 );
|
59 |
+
* function my_avatar_image_alternate_text( $avatar_alt ) {
|
60 |
+
* // your code here
|
61 |
+
* return $avatar_alt;
|
62 |
+
* }
|
63 |
+
* ?>
|
64 |
+
*/
|
65 |
+
$image_alt = apply_filters( "um_avatar_image_alternate_text", um_user("display_name") );
|
66 |
+
|
67 |
+
if ( ! $avatar && UM()->options()->get( 'use_gravatars' ) ) {
|
68 |
+
|
69 |
+
$default = get_option( 'avatar_default', 'mystery' );
|
70 |
+
if ( $default == 'gravatar_default' ) {
|
71 |
+
$default = '';
|
72 |
+
}
|
73 |
+
|
74 |
+
$rating = get_option('avatar_rating');
|
75 |
+
if ( !empty( $rating ) ) {
|
76 |
+
$rating = "&r={$rating}";
|
77 |
+
}
|
78 |
+
|
79 |
+
if ( UM()->options()->get('use_gravatars') && ! um_user('synced_profile_photo') && ! $has_profile_photo ){
|
80 |
+
$avatar_url = um_get_domain_protocol().'gravatar.com/avatar/'.um_user('synced_gravatar_hashed_id');
|
81 |
+
$avatar_url = add_query_arg('s',400, $avatar_url);
|
82 |
+
$gravatar_type = UM()->options()->get( 'use_um_gravatar_default_builtin_image' );
|
83 |
+
|
84 |
+
if ( $gravatar_type == 'default' ) {
|
85 |
+
if ( UM()->options()->get( 'use_um_gravatar_default_image' ) ) {
|
86 |
+
$avatar_url = add_query_arg('d', um_get_default_avatar_uri(), $avatar_url );
|
87 |
+
}
|
88 |
+
} else {
|
89 |
+
$avatar_url = add_query_arg('d', $gravatar_type, $avatar_url );
|
90 |
+
}
|
91 |
+
|
92 |
+
}
|
93 |
+
|
94 |
+
$avatar = '<img src="' .$avatar_url .'?d='. $default . '&s=' . $size . $rating .'" class="func-um_get_avatar gravatar avatar avatar-'.$size.' um-avatar" width="'.$size.'" height="'.$size.'" alt="'.$image_alt.'" />';
|
95 |
+
|
96 |
+
}else if( empty( $avatar ) ){
|
97 |
+
$default_avatar_uri = um_get_default_avatar_uri();
|
98 |
+
|
99 |
+
$avatar = '<img src="' .$default_avatar_uri .'" class="gravatar avatar avatar-'.$size.' um-avatar" width="'.$size.'" height="'.$size.'" alt="'.$image_alt.'" />';
|
100 |
+
}
|
101 |
+
|
102 |
return $avatar;
|
103 |
}
|
104 |
add_filter( 'get_avatar', 'um_get_avatar', 99999, 5 );
|
includes/core/um-filters-fields.php
CHANGED
@@ -367,70 +367,18 @@ add_filter( 'um_get_form_fields', 'um_get_form_fields', 99 );
|
|
367 |
*/
|
368 |
function um_get_custom_field_array( $array, $fields ) {
|
369 |
|
370 |
-
if (
|
371 |
-
|
372 |
-
|
373 |
-
|
374 |
-
|
375 |
-
|
376 |
-
|
377 |
-
|
378 |
-
|
379 |
-
if (
|
380 |
-
$array['required'] = 0;
|
381 |
-
}
|
382 |
-
} elseif ( $op == 'not empty' ) {
|
383 |
-
if ( ! empty( $cond_value ) ) {
|
384 |
-
$array['required'] = 0;
|
385 |
-
}
|
386 |
-
} elseif ( $op == 'equals to' ) {
|
387 |
-
if ( $cond_value == $parent_value ) {
|
388 |
-
$array['required'] = 0;
|
389 |
-
}
|
390 |
-
} elseif ( $op == 'not equals' ) {
|
391 |
-
if ( $cond_value != $parent_value ) {
|
392 |
-
$array['required'] = 0;
|
393 |
-
}
|
394 |
-
} elseif ( $op == 'greater than' ) {
|
395 |
-
if ( $cond_value > $parent_value ) {
|
396 |
-
$array['required'] = 0;
|
397 |
-
}
|
398 |
-
} elseif ( $op == 'less than' ) {
|
399 |
-
if ( $cond_value < $parent_value ) {
|
400 |
-
$array['required'] = 0;
|
401 |
-
}
|
402 |
-
} elseif ( $op == 'contains' ) {
|
403 |
-
if ( strstr( $cond_value, $parent_value ) ) {
|
404 |
-
$array['required'] = 0;
|
405 |
-
}
|
406 |
-
}
|
407 |
-
} elseif ( $visibility == 'show' ) {
|
408 |
-
if ( $op == 'empty' ) {
|
409 |
-
if ( ! empty( $cond_value ) ) {
|
410 |
-
$array['required'] = 0;
|
411 |
-
}
|
412 |
-
} elseif ( $op == 'not empty' ) {
|
413 |
-
if ( empty( $cond_value ) ) {
|
414 |
-
$array['required'] = 0;
|
415 |
-
}
|
416 |
-
} elseif ( $op == 'equals to' ) {
|
417 |
-
if ( $cond_value != $parent_value ) {
|
418 |
-
$array['required'] = 0;
|
419 |
-
}
|
420 |
-
} elseif ( $op == 'not equals' ) {
|
421 |
-
if ( $cond_value == $parent_value ) {
|
422 |
-
$array['required'] = 0;
|
423 |
-
}
|
424 |
-
} elseif ( $op == 'greater than' ) {
|
425 |
-
if ( $cond_value <= $parent_value ) {
|
426 |
-
$array['required'] = 0;
|
427 |
-
}
|
428 |
-
} elseif ( $op == 'less than' ) {
|
429 |
-
if ( $cond_value >= $parent_value ) {
|
430 |
$array['required'] = 0;
|
431 |
-
}
|
432 |
-
} elseif ( $op == 'contains' ) {
|
433 |
-
if ( ! strstr( $cond_value, $parent_value ) ) {
|
434 |
$array['required'] = 0;
|
435 |
}
|
436 |
}
|
367 |
*/
|
368 |
function um_get_custom_field_array( $array, $fields ) {
|
369 |
|
370 |
+
if ( isset( $array['conditions'] ) ) {
|
371 |
+
for ( $a = 0; $a < count( $array['conditions'] ); $a++ ) {
|
372 |
+
if ( isset( $array['conditional_value'] ) || isset( $array['conditional_value' . $a] ) ) {
|
373 |
+
foreach ( $array['conditions'] as $key => $value ) {
|
374 |
+
$condition_metakey = $fields[ $value[1] ]['metakey'];
|
375 |
+
|
376 |
+
if ( isset( $_POST[ $condition_metakey ] ) ) {
|
377 |
+
$cond_value = ( $fields[ $value[1] ]['type'] == 'radio' ) ? $_POST[ $condition_metakey ][0] : $_POST[ $condition_metakey ];
|
378 |
+
|
379 |
+
if ( isset( $array['conditional_value'] ) && $cond_value !== $array['conditional_value'] ) {
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
380 |
$array['required'] = 0;
|
381 |
+
} elseif ( isset( $array['conditional_value'.$a] ) && $cond_value !== $array['conditional_value'.$a] ) {
|
|
|
|
|
382 |
$array['required'] = 0;
|
383 |
}
|
384 |
}
|
includes/core/um-navmenu.php
CHANGED
@@ -55,8 +55,7 @@ if ( ! class_exists( 'UM_Menu_Item_Custom_Fields_Editor' ) ) {
|
|
55 |
// Sanitize
|
56 |
if ( ! empty( $_POST[ $key ][ $menu_item_db_id ] ) ) {
|
57 |
// Do some checks here...
|
58 |
-
$value =
|
59 |
-
array_keys( $_POST[ $key ][ $menu_item_db_id ] ) : $_POST[ $key ][ $menu_item_db_id ];
|
60 |
} else {
|
61 |
$value = null;
|
62 |
}
|
@@ -166,7 +165,7 @@ if ( ! class_exists( 'UM_Menu_Item_Custom_Fields_Editor' ) ) {
|
|
166 |
$id_attr = ' id="edit-menu-item-um_nav_roles-{{data.menuItemID}}_' . $k . '" ';
|
167 |
$for_attr = ' for="edit-menu-item-um_nav_roles-{{data.menuItemID}}_' . $k . '" ';
|
168 |
$html .= "<label $for_attr>
|
169 |
-
<input type='checkbox' {$id_attr} name='menu-item-um_nav_roles[{{data.menuItemID}}][
|
170 |
<span>{$title}</span>
|
171 |
</label>";
|
172 |
}
|
55 |
// Sanitize
|
56 |
if ( ! empty( $_POST[ $key ][ $menu_item_db_id ] ) ) {
|
57 |
// Do some checks here...
|
58 |
+
$value = $_POST[ $key ][ $menu_item_db_id ];
|
|
|
59 |
} else {
|
60 |
$value = null;
|
61 |
}
|
165 |
$id_attr = ' id="edit-menu-item-um_nav_roles-{{data.menuItemID}}_' . $k . '" ';
|
166 |
$for_attr = ' for="edit-menu-item-um_nav_roles-{{data.menuItemID}}_' . $k . '" ';
|
167 |
$html .= "<label $for_attr>
|
168 |
+
<input type='checkbox' {$id_attr} name='menu-item-um_nav_roles[{{data.menuItemID}}][]' value='{$k}' <# if( _.contains( data.restriction_data.um_nav_roles,'{$k}' ) ){ #>checked='checked'<# } #> />
|
169 |
<span>{$title}</span>
|
170 |
</label>";
|
171 |
}
|
includes/um-short-functions.php
CHANGED
@@ -442,7 +442,7 @@ function um_js_redirect( $url ) {
|
|
442 |
if (headers_sent() || empty( $url )) {
|
443 |
//for blank redirects
|
444 |
if ('' == $url) {
|
445 |
-
$url =
|
446 |
}
|
447 |
|
448 |
$funtext = "echo \"<script data-cfasync='false' type='text/javascript'>window.location = '" . $url . "'</script>\";";
|
@@ -508,11 +508,10 @@ function um_user_submitted_registration( $style = false ) {
|
|
508 |
|
509 |
$data = um_user( 'submitted' );
|
510 |
|
511 |
-
if (
|
512 |
$output .= '<div class="um-admin-infobox">';
|
513 |
-
}
|
514 |
|
515 |
-
if (
|
516 |
|
517 |
/**
|
518 |
* UM hook
|
@@ -536,51 +535,38 @@ function um_user_submitted_registration( $style = false ) {
|
|
536 |
*/
|
537 |
$data = apply_filters( 'um_email_registration_data', $data );
|
538 |
|
539 |
-
$
|
540 |
-
foreach ( $data as $k => $v ) {
|
541 |
-
|
542 |
-
if ( strstr( $k, 'user_pass' ) || in_array( $k, array( 'g-recaptcha-response', 'request', '_wpnonce', '_wp_http_referer' ) ) ) {
|
543 |
-
continue;
|
544 |
-
}
|
545 |
-
|
546 |
-
if ( UM()->fields()->get_field_type( $k ) == 'password' ) {
|
547 |
-
$pw_fields[] = $k;
|
548 |
-
$pw_fields[] = 'confirm_' . $k;
|
549 |
-
continue;
|
550 |
-
}
|
551 |
-
|
552 |
-
if ( ! empty( $pw_fields ) && in_array( $k, $pw_fields ) ) {
|
553 |
-
continue;
|
554 |
-
}
|
555 |
|
556 |
-
if (
|
557 |
$file = basename( $v );
|
558 |
$v = um_user_uploads_uri() . $file;
|
559 |
}
|
560 |
|
561 |
-
if (
|
562 |
-
$v = implode( ',', $v );
|
563 |
-
}
|
564 |
|
565 |
-
|
566 |
-
|
567 |
-
|
568 |
-
}
|
569 |
|
570 |
-
|
571 |
-
|
572 |
-
$v =
|
573 |
}
|
574 |
-
|
575 |
-
|
576 |
-
|
|
|
|
|
|
|
|
|
|
|
577 |
}
|
|
|
578 |
}
|
579 |
}
|
580 |
|
581 |
-
if (
|
582 |
$output .= '</div>';
|
583 |
-
}
|
584 |
|
585 |
return $output;
|
586 |
}
|
@@ -1608,7 +1594,9 @@ function um_youtube_id_from_url( $url ) {
|
|
1608 |
* @return string
|
1609 |
*/
|
1610 |
function um_user_uploads_uri() {
|
1611 |
-
|
|
|
|
|
1612 |
|
1613 |
$uri = UM()->files()->upload_baseurl . um_user( 'ID' ) . '/';
|
1614 |
|
@@ -1718,23 +1706,33 @@ function um_get_avatar_uri( $image, $attrs ) {
|
|
1718 |
*/
|
1719 |
$cache_time = apply_filters( 'um_filter_avatar_cache_time', current_time( 'timestamp' ), um_user( 'ID' ) );
|
1720 |
|
1721 |
-
if
|
1722 |
-
|
1723 |
-
|
1724 |
-
|
|
|
|
|
|
|
|
|
1725 |
} else {
|
|
|
1726 |
$sizes = UM()->options()->get( 'photo_thumb_sizes' );
|
1727 |
if (is_array( $sizes )) $find = um_closest_num( $sizes, $attrs );
|
1728 |
|
1729 |
-
if (file_exists(
|
1730 |
-
|
1731 |
-
|
1732 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1733 |
}
|
1734 |
-
}
|
1735 |
|
1736 |
-
if ( !empty( $cache_time ) ) {
|
1737 |
-
$uri .= "?{$cache_time}";
|
1738 |
}
|
1739 |
|
1740 |
return $uri;
|
@@ -1751,128 +1749,35 @@ function um_get_default_avatar_uri() {
|
|
1751 |
$uri = !empty( $uri['url'] ) ? $uri['url'] : '';
|
1752 |
if ( ! $uri ) {
|
1753 |
$uri = um_url . 'assets/img/default_avatar.jpg';
|
1754 |
-
}
|
1755 |
-
|
1756 |
-
return set_url_scheme( $uri );
|
1757 |
-
}
|
1758 |
-
|
1759 |
|
1760 |
-
|
1761 |
-
|
1762 |
-
*
|
1763 |
-
* @param $user_id
|
1764 |
-
* @param $size
|
1765 |
-
*
|
1766 |
-
* @return bool|string
|
1767 |
-
*/
|
1768 |
-
function um_get_user_avatar_data( $user_id = '', $size = '96' ) {
|
1769 |
-
if( empty( $user_id ) ) {
|
1770 |
-
$user_id = um_user( 'ID' );
|
1771 |
-
} else {
|
1772 |
-
um_fetch_user( $user_id );
|
1773 |
-
}
|
1774 |
|
1775 |
-
|
1776 |
-
|
1777 |
-
|
1778 |
-
|
1779 |
-
'size' => $size
|
1780 |
-
);
|
1781 |
-
|
1782 |
-
if ( $profile_photo = um_profile( 'profile_photo' ) ) {
|
1783 |
-
$data['url'] = um_get_avatar_uri( $profile_photo, $size );
|
1784 |
-
$data['type'] = 'upload';
|
1785 |
-
$data['class'] .= ' um-avatar-uploaded';
|
1786 |
-
} else if( $synced_profile_photo = um_user( 'synced_profile_photo' ) ) {
|
1787 |
-
$data['url'] = $synced_profile_photo;
|
1788 |
-
$data['type'] = 'sync';
|
1789 |
-
$data['class'] .= ' um-avatar-default';
|
1790 |
-
} else if( UM()->options()->get( 'use_gravatars' ) ) {
|
1791 |
-
$avatar_hash_id = get_user_meta( $user_id, 'synced_gravatar_hashed_id', true );
|
1792 |
-
$data['url'] = set_url_scheme( '//gravatar.com/avatar/' . $avatar_hash_id );
|
1793 |
-
$data['url'] = add_query_arg( 's', 400, $data['url'] );
|
1794 |
-
$rating = get_option('avatar_rating');
|
1795 |
-
if ( !empty( $rating ) ) {
|
1796 |
-
$data['url'] = add_query_arg( 'r', $rating, $data['url'] );
|
1797 |
}
|
1798 |
-
|
1799 |
-
if ( $gravatar_type == 'default' ) {
|
1800 |
-
if ( UM()->options()->get( 'use_um_gravatar_default_image' ) ) {
|
1801 |
-
$data['url'] = add_query_arg( 'd', $data['default'], $data['url'] );
|
1802 |
-
}
|
1803 |
-
} else {
|
1804 |
-
$default = get_option( 'avatar_default', 'mystery' );
|
1805 |
-
if ( $default == 'gravatar_default' ) {
|
1806 |
-
$default = '';
|
1807 |
-
}
|
1808 |
-
$data['url'] = add_query_arg( 'd', $default, $data['url'] );
|
1809 |
-
}
|
1810 |
-
$data['type'] = 'gravatar';
|
1811 |
-
$data['class'] .= ' um-avatar-gravatar';
|
1812 |
-
} else {
|
1813 |
-
$data['url'] = $data['default'];
|
1814 |
-
$data['type'] = 'default';
|
1815 |
-
$data['class'] .= ' um-avatar-default';
|
1816 |
-
}
|
1817 |
|
1818 |
-
|
1819 |
-
* UM hook
|
1820 |
-
*
|
1821 |
-
* @type filter
|
1822 |
-
* @title um_user_avatar_url_filter
|
1823 |
-
* @description Change user avatar URL
|
1824 |
-
* @input_vars
|
1825 |
-
* [{"var":"$avatar_uri","type":"string","desc":"Avatar URL"},
|
1826 |
-
* {"var":"$user_id","type":"int","desc":"User ID"}]
|
1827 |
-
* @change_log
|
1828 |
-
* ["Since: 2.0"]
|
1829 |
-
* @usage add_filter( 'um_user_avatar_url_filter', 'function_name', 10, 2 );
|
1830 |
-
* @example
|
1831 |
-
* <?php
|
1832 |
-
* add_filter( 'um_user_avatar_url_filter', 'my_user_avatar_url', 10, 2 );
|
1833 |
-
* function my_user_avatar_url( $avatar_uri ) {
|
1834 |
-
* // your code here
|
1835 |
-
* return $avatar_uri;
|
1836 |
-
* }
|
1837 |
-
* ?>
|
1838 |
-
*/
|
1839 |
-
$data['url'] = apply_filters( 'um_user_avatar_url_filter', $data['url'], $user_id, $data );
|
1840 |
-
/**
|
1841 |
-
* UM hook
|
1842 |
-
*
|
1843 |
-
* @type filter
|
1844 |
-
* @title um_avatar_image_alternate_text
|
1845 |
-
* @description Change user display name on um_user function profile photo
|
1846 |
-
* @input_vars
|
1847 |
-
* [{"var":"$display_name","type":"string","desc":"User Display Name"}]
|
1848 |
-
* @change_log
|
1849 |
-
* ["Since: 2.0"]
|
1850 |
-
* @usage add_filter( 'um_avatar_image_alternate_text', 'function_name', 10, 1 );
|
1851 |
-
* @example
|
1852 |
-
* <?php
|
1853 |
-
* add_filter( 'um_avatar_image_alternate_text', 'my_avatar_image_alternate_text', 10, 1 );
|
1854 |
-
* function my_avatar_image_alternate_text( $display_name ) {
|
1855 |
-
* // your code here
|
1856 |
-
* return $display_name;
|
1857 |
-
* }
|
1858 |
-
* ?>
|
1859 |
-
*/
|
1860 |
-
$data['alt'] = apply_filters( "um_avatar_image_alternate_text", um_user( "display_name" ), $data );
|
1861 |
-
|
1862 |
-
return $data;
|
1863 |
}
|
1864 |
|
|
|
1865 |
/**
|
1866 |
* get user avatar url
|
1867 |
*
|
1868 |
-
* @param $user_id
|
1869 |
-
* @param $size
|
1870 |
-
*
|
1871 |
* @return bool|string
|
1872 |
*/
|
1873 |
-
function um_get_user_avatar_url(
|
1874 |
-
|
1875 |
-
|
|
|
|
|
|
|
|
|
|
|
1876 |
}
|
1877 |
|
1878 |
|
@@ -2161,15 +2066,88 @@ function um_user( $data, $attrs = null ) {
|
|
2161 |
break;
|
2162 |
|
2163 |
case 'profile_photo':
|
2164 |
-
|
2165 |
-
|
2166 |
-
|
2167 |
-
|
2168 |
-
|
2169 |
-
|
2170 |
-
|
2171 |
-
|
2172 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2173 |
|
2174 |
break;
|
2175 |
|
442 |
if (headers_sent() || empty( $url )) {
|
443 |
//for blank redirects
|
444 |
if ('' == $url) {
|
445 |
+
$url = ( is_ssl() ? 'https://' : 'http://' ) . $_SERVER["HTTP_HOST"] . $_SERVER["REQUEST_URI"];
|
446 |
}
|
447 |
|
448 |
$funtext = "echo \"<script data-cfasync='false' type='text/javascript'>window.location = '" . $url . "'</script>\";";
|
508 |
|
509 |
$data = um_user( 'submitted' );
|
510 |
|
511 |
+
if ($style)
|
512 |
$output .= '<div class="um-admin-infobox">';
|
|
|
513 |
|
514 |
+
if (isset( $data ) && is_array( $data )) {
|
515 |
|
516 |
/**
|
517 |
* UM hook
|
535 |
*/
|
536 |
$data = apply_filters( 'um_email_registration_data', $data );
|
537 |
|
538 |
+
foreach ($data as $k => $v) {
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
539 |
|
540 |
+
if (!is_array( $v ) && strstr( $v, 'ultimatemember/temp' )) {
|
541 |
$file = basename( $v );
|
542 |
$v = um_user_uploads_uri() . $file;
|
543 |
}
|
544 |
|
545 |
+
if (!strstr( $k, 'user_pass' ) && !in_array( $k, array( 'g-recaptcha-response', 'request', '_wpnonce', '_wp_http_referer' ) )) {
|
|
|
|
|
546 |
|
547 |
+
if (is_array( $v )) {
|
548 |
+
$v = implode( ',', $v );
|
549 |
+
}
|
|
|
550 |
|
551 |
+
if ($k == 'timestamp') {
|
552 |
+
$k = __( 'date submitted', 'ultimate-member' );
|
553 |
+
$v = date( "d M Y H:i", $v );
|
554 |
}
|
555 |
+
|
556 |
+
if ($style) {
|
557 |
+
if (!$v) $v = __( '(empty)', 'ultimate-member' );
|
558 |
+
$output .= "<p><label>$k</label><span>$v</span></p>";
|
559 |
+
} else {
|
560 |
+
$output .= "$k: $v" . "<br />";
|
561 |
+
}
|
562 |
+
|
563 |
}
|
564 |
+
|
565 |
}
|
566 |
}
|
567 |
|
568 |
+
if ($style)
|
569 |
$output .= '</div>';
|
|
|
570 |
|
571 |
return $output;
|
572 |
}
|
1594 |
* @return string
|
1595 |
*/
|
1596 |
function um_user_uploads_uri() {
|
1597 |
+
if (is_ssl()) {
|
1598 |
+
UM()->files()->upload_baseurl = str_replace( "http://", "https://", UM()->files()->upload_baseurl );
|
1599 |
+
}
|
1600 |
|
1601 |
$uri = UM()->files()->upload_baseurl . um_user( 'ID' ) . '/';
|
1602 |
|
1706 |
*/
|
1707 |
$cache_time = apply_filters( 'um_filter_avatar_cache_time', current_time( 'timestamp' ), um_user( 'ID' ) );
|
1708 |
|
1709 |
+
if (!empty( $cache_time )) {
|
1710 |
+
$cache_time = "?{$cache_time}";
|
1711 |
+
}
|
1712 |
+
|
1713 |
+
if (file_exists( UM()->files()->upload_basedir . um_user( 'ID' ) . "/profile_photo-{$attrs}{$ext}" )) {
|
1714 |
+
|
1715 |
+
$uri = um_user_uploads_uri() . "profile_photo-{$attrs}{$ext}{$cache_time}";
|
1716 |
+
|
1717 |
} else {
|
1718 |
+
|
1719 |
$sizes = UM()->options()->get( 'photo_thumb_sizes' );
|
1720 |
if (is_array( $sizes )) $find = um_closest_num( $sizes, $attrs );
|
1721 |
|
1722 |
+
if (file_exists( UM()->files()->upload_basedir . um_user( 'ID' ) . "/profile_photo-{$find}{$ext}" )) {
|
1723 |
+
|
1724 |
+
$uri = um_user_uploads_uri() . "profile_photo-{$find}{$ext}{$cache_time}";
|
1725 |
+
|
1726 |
+
} else if (file_exists( UM()->files()->upload_basedir . um_user( 'ID' ) . "/profile_photo{$ext}" )) {
|
1727 |
+
|
1728 |
+
$uri = um_user_uploads_uri() . "profile_photo{$ext}{$cache_time}";
|
1729 |
+
|
1730 |
+
}
|
1731 |
+
|
1732 |
+
if ($attrs == 'original') {
|
1733 |
+
$uri = um_user_uploads_uri() . "profile_photo{$ext}{$cache_time}";
|
1734 |
}
|
|
|
1735 |
|
|
|
|
|
1736 |
}
|
1737 |
|
1738 |
return $uri;
|
1749 |
$uri = !empty( $uri['url'] ) ? $uri['url'] : '';
|
1750 |
if ( ! $uri ) {
|
1751 |
$uri = um_url . 'assets/img/default_avatar.jpg';
|
1752 |
+
} else {
|
|
|
|
|
|
|
|
|
1753 |
|
1754 |
+
//http <-> https compatibility default avatar option of SSL was changed
|
1755 |
+
$url_array = parse_url( $uri );
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1756 |
|
1757 |
+
if (is_ssl() && $url_array['scheme'] == 'http') {
|
1758 |
+
$uri = str_replace( 'http://', 'https://', $uri );
|
1759 |
+
} else if (!is_ssl() && $url_array['scheme'] == 'https') {
|
1760 |
+
$uri = str_replace( 'https://', 'http://', $uri );
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1761 |
}
|
1762 |
+
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1763 |
|
1764 |
+
return $uri;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1765 |
}
|
1766 |
|
1767 |
+
|
1768 |
/**
|
1769 |
* get user avatar url
|
1770 |
*
|
|
|
|
|
|
|
1771 |
* @return bool|string
|
1772 |
*/
|
1773 |
+
function um_get_user_avatar_url() {
|
1774 |
+
if (um_profile( 'profile_photo' )) {
|
1775 |
+
$avatar_uri = um_get_avatar_uri( um_profile( 'profile_photo' ), 32 );
|
1776 |
+
} else {
|
1777 |
+
$avatar_uri = um_get_default_avatar_uri();
|
1778 |
+
}
|
1779 |
+
|
1780 |
+
return $avatar_uri;
|
1781 |
}
|
1782 |
|
1783 |
|
2066 |
break;
|
2067 |
|
2068 |
case 'profile_photo':
|
2069 |
+
|
2070 |
+
$has_profile_photo = false;
|
2071 |
+
$photo_type = 'um-avatar-default';
|
2072 |
+
|
2073 |
+
/**
|
2074 |
+
* UM hook
|
2075 |
+
*
|
2076 |
+
* @type filter
|
2077 |
+
* @title um_avatar_image_alternate_text
|
2078 |
+
* @description Change user display name on um_user function profile photo
|
2079 |
+
* @input_vars
|
2080 |
+
* [{"var":"$display_name","type":"string","desc":"User Display Name"}]
|
2081 |
+
* @change_log
|
2082 |
+
* ["Since: 2.0"]
|
2083 |
+
* @usage add_filter( 'um_avatar_image_alternate_text', 'function_name', 10, 1 );
|
2084 |
+
* @example
|
2085 |
+
* <?php
|
2086 |
+
* add_filter( 'um_avatar_image_alternate_text', 'my_avatar_image_alternate_text', 10, 1 );
|
2087 |
+
* function my_avatar_image_alternate_text( $display_name ) {
|
2088 |
+
* // your code here
|
2089 |
+
* return $display_name;
|
2090 |
+
* }
|
2091 |
+
* ?>
|
2092 |
+
*/
|
2093 |
+
$image_alt = apply_filters( "um_avatar_image_alternate_text", um_user( "display_name" ) );
|
2094 |
+
|
2095 |
+
if (um_profile( 'profile_photo' )) {
|
2096 |
+
$avatar_uri = um_get_avatar_uri( um_profile( 'profile_photo' ), $attrs );
|
2097 |
+
$has_profile_photo = true;
|
2098 |
+
$photo_type = 'um-avatar-uploaded';
|
2099 |
+
} else if (um_user( 'synced_profile_photo' )) {
|
2100 |
+
$avatar_uri = um_user( 'synced_profile_photo' );
|
2101 |
+
} else {
|
2102 |
+
$avatar_uri = um_get_default_avatar_uri();
|
2103 |
+
}
|
2104 |
+
|
2105 |
+
/**
|
2106 |
+
* UM hook
|
2107 |
+
*
|
2108 |
+
* @type filter
|
2109 |
+
* @title um_user_avatar_url_filter
|
2110 |
+
* @description Change user avatar URL
|
2111 |
+
* @input_vars
|
2112 |
+
* [{"var":"$avatar_uri","type":"string","desc":"Avatar URL"},
|
2113 |
+
* {"var":"$user_id","type":"int","desc":"User ID"}]
|
2114 |
+
* @change_log
|
2115 |
+
* ["Since: 2.0"]
|
2116 |
+
* @usage add_filter( 'um_user_avatar_url_filter', 'function_name', 10, 2 );
|
2117 |
+
* @example
|
2118 |
+
* <?php
|
2119 |
+
* add_filter( 'um_user_avatar_url_filter', 'my_user_avatar_url', 10, 2 );
|
2120 |
+
* function my_user_avatar_url( $avatar_uri ) {
|
2121 |
+
* // your code here
|
2122 |
+
* return $avatar_uri;
|
2123 |
+
* }
|
2124 |
+
* ?>
|
2125 |
+
*/
|
2126 |
+
$avatar_uri = apply_filters( 'um_user_avatar_url_filter', $avatar_uri, um_user( 'ID' ) );
|
2127 |
+
|
2128 |
+
|
2129 |
+
if (!$avatar_uri)
|
2130 |
+
return '';
|
2131 |
+
|
2132 |
+
if ( UM()->options()->get( 'use_gravatars' ) && !um_user( 'synced_profile_photo' ) && !$has_profile_photo) {
|
2133 |
+
$avatar_hash_id = get_user_meta( um_user( 'ID' ), 'synced_gravatar_hashed_id', true );
|
2134 |
+
$avatar_uri = um_get_domain_protocol() . 'gravatar.com/avatar/' . $avatar_hash_id;
|
2135 |
+
$avatar_uri = add_query_arg( 's', 400, $avatar_uri );
|
2136 |
+
$gravatar_type = UM()->options()->get( 'use_um_gravatar_default_builtin_image' );
|
2137 |
+
$photo_type = 'um-avatar-gravatar';
|
2138 |
+
if ( $gravatar_type == 'default' ) {
|
2139 |
+
if ( UM()->options()->get( 'use_um_gravatar_default_image' ) ) {
|
2140 |
+
$avatar_uri = add_query_arg( 'd', um_get_default_avatar_uri(), $avatar_uri );
|
2141 |
+
}
|
2142 |
+
} else {
|
2143 |
+
$avatar_uri = add_query_arg( 'd', $gravatar_type, $avatar_uri );
|
2144 |
+
}
|
2145 |
+
|
2146 |
+
}
|
2147 |
+
|
2148 |
+
$default_avatar = um_get_default_avatar_uri();
|
2149 |
+
|
2150 |
+
return '<img onerror="this.src=\''.esc_attr($default_avatar).'\';" src="' . $avatar_uri . '" class="func-um_user gravatar avatar avatar-' . $attrs . ' um-avatar ' . $photo_type . '" width="' . $attrs . '" height="' . $attrs . '" alt="' . $image_alt . '" />';
|
2151 |
|
2152 |
break;
|
2153 |
|
readme.txt
CHANGED
@@ -6,7 +6,7 @@ Donate link:
|
|
6 |
Tags: community, member, membership, user-profile, user-registration
|
7 |
Requires at least: 4.1
|
8 |
Tested up to: 4.9
|
9 |
-
Stable tag: 2.0.
|
10 |
License: GNU Version 2 or Any Later Version
|
11 |
License URI: http://www.gnu.org/licenses/gpl-3.0.txt
|
12 |
|
@@ -131,55 +131,6 @@ The plugin works with popular caching plugins by automatically excluding Ultimat
|
|
131 |
|
132 |
= Important: UM2.0+ is a significant update to the code base from 1.3.88. Please make sure you take a full-site backup with restore point before updating the plugin =
|
133 |
|
134 |
-
= 2.0.17: May 30, 2018 =
|
135 |
-
|
136 |
-
* Enhancements:
|
137 |
-
- Added UM dashboard widget for getting latest extension's upgrades
|
138 |
-
|
139 |
-
* Bugfixes:
|
140 |
-
- Fixed User Profile restriction when the user isn't logged in
|
141 |
-
- Fixed Profile Tabs displaying on desktop/mobile
|
142 |
-
- Fixed set user status after registration on some installs
|
143 |
-
- Fixed PHP memory limit issue on some installs with small PHP memory limit
|
144 |
-
- Fixed PHP validation on submit UM Forms with conditional fields logic
|
145 |
-
|
146 |
-
= 2.0.16: May 23, 2018 =
|
147 |
-
|
148 |
-
* Bugfixes:
|
149 |
-
- Fixed Profile Tabs issues
|
150 |
-
|
151 |
-
= 2.0.15: May 22, 2018 =
|
152 |
-
|
153 |
-
* Bugfixes:
|
154 |
-
- Fixed GDPR min.js script
|
155 |
-
|
156 |
-
= 2.0.14: May 22, 2018 =
|
157 |
-
|
158 |
-
* Enhancements:
|
159 |
-
- Added support for GDPR Personal Data Exporter
|
160 |
-
- Added support for GDPR Personal Data Eraser
|
161 |
-
- Added new privacy field to form builder for GDPR consent collection
|
162 |
-
- Added GDPR privacy policy guide text
|
163 |
-
- Added GDPR compatibility on delete user process
|
164 |
-
- Added security to Restricted posts comments
|
165 |
-
- Added security to custom field type `Password`
|
166 |
-
- Deprecated time checking spam bot
|
167 |
-
|
168 |
-
* Bugfixes:
|
169 |
-
- Fixed settings tabs for PHP7.1
|
170 |
-
- Fixed issues with Profile Tabs
|
171 |
-
- Fixed User Avatars
|
172 |
-
- Fixed set user status on Registration process
|
173 |
-
- Fixed Account Privacy tab content
|
174 |
-
|
175 |
-
= 2.0.13: May 2, 2018 =
|
176 |
-
|
177 |
-
* Bugfixes:
|
178 |
-
- Fixed and optimized user avatars
|
179 |
-
- Fixed Profile Menu on some installs
|
180 |
-
- Fixed fields IDs duplicates
|
181 |
-
- Fixed cache users count
|
182 |
-
|
183 |
= 2.0.12: April 30, 2018 =
|
184 |
|
185 |
* Bugfixes:
|
6 |
Tags: community, member, membership, user-profile, user-registration
|
7 |
Requires at least: 4.1
|
8 |
Tested up to: 4.9
|
9 |
+
Stable tag: 2.0.12
|
10 |
License: GNU Version 2 or Any Later Version
|
11 |
License URI: http://www.gnu.org/licenses/gpl-3.0.txt
|
12 |
|
131 |
|
132 |
= Important: UM2.0+ is a significant update to the code base from 1.3.88. Please make sure you take a full-site backup with restore point before updating the plugin =
|
133 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
134 |
= 2.0.12: April 30, 2018 =
|
135 |
|
136 |
* Bugfixes:
|
templates/gdpr-register.php
DELETED
@@ -1,44 +0,0 @@
|
|
1 |
-
<?php ?>
|
2 |
-
|
3 |
-
<!-- This file should primarily consist of HTML with a little bit of PHP. -->
|
4 |
-
<div class="um-field um-field-type_terms_conditions" data-key="use_terms_conditions_agreement" style="display:block;padding:0;">
|
5 |
-
<div class="um-field-area">
|
6 |
-
<div class='um-gdpr-content' style="display:none;">
|
7 |
-
<?php if ( ! empty( $args['use_gdpr_content_id'] ) ) {
|
8 |
-
$um_content_query = get_post( $args['use_gdpr_content_id'] );
|
9 |
-
if ( isset( $um_content_query ) ) {
|
10 |
-
echo apply_filters( 'um_gdpr_policies_page_content', $um_content_query->post_content, $args );
|
11 |
-
}
|
12 |
-
} ?>
|
13 |
-
</div>
|
14 |
-
<a href="javascript:;" class="um-toggle-gdpr" data-toggle-state="hidden"
|
15 |
-
data-toggle-show="<?php echo ! empty( $args['use_gdpr_toggle_show'] ) ? $args['use_gdpr_toggle_show'] : __( 'Show privacy policy', 'ultimate-member' ); ?>"
|
16 |
-
data-toggle-hide="<?php echo ! empty( $args['use_gdpr_toggle_hide'] ) ? $args['use_gdpr_toggle_hide'] : __( 'Hide privacy policy', 'ultimate-member' ); ?>">
|
17 |
-
<?php echo ! empty( $args['use_gdpr_toggle_show'] ) ? $args['use_gdpr_toggle_show'] : __( 'Show privacy policy', 'ultimate-member' ); ?>
|
18 |
-
</a>
|
19 |
-
</div>
|
20 |
-
<div class="um-field-area">
|
21 |
-
|
22 |
-
<label class="um-field-checkbox">
|
23 |
-
<input type="checkbox" name="use_gdpr_agreement" value="1">
|
24 |
-
<span class="um-field-checkbox-state">
|
25 |
-
<i class="um-icon-android-checkbox-outline-blank"></i>
|
26 |
-
</span>
|
27 |
-
<span class="um-field-checkbox-option">
|
28 |
-
<?php echo ! empty( $args['use_gdpr_agreement'] ) ? $args['use_gdpr_agreement'] : __( 'Please confirm that you agree to our privacy policy', 'ultimate-member' ); ?>
|
29 |
-
</span>
|
30 |
-
</label>
|
31 |
-
<div class="um-clear"></div>
|
32 |
-
|
33 |
-
<?php $errors = UM()->form()->errors;
|
34 |
-
|
35 |
-
if ( isset( $errors['use_gdpr_agreement'] ) ) {
|
36 |
-
|
37 |
-
$error_message = ! empty( $args['use_gdpr_error_text'] ) ? $args['use_gdpr_error_text'] : __( 'Please confirm your acceptance of our privacy policy', 'ultimate-member' );
|
38 |
-
|
39 |
-
echo '<p class="um-notice err"><i class="um-icon-ios-close-empty" onclick="jQuery(this).parent().fadeOut();"></i>' . $error_message . '</p><br/>';
|
40 |
-
} ?>
|
41 |
-
|
42 |
-
<div class="um-clear"></div>
|
43 |
-
</div>
|
44 |
-
</div>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
ultimate-member.php
CHANGED
@@ -3,7 +3,7 @@
|
|
3 |
Plugin Name: Ultimate Member
|
4 |
Plugin URI: http://ultimatemember.com/
|
5 |
Description: The easiest way to create powerful online communities and beautiful user profiles with WordPress
|
6 |
-
Version: 2.0.
|
7 |
Author: Ultimate Member
|
8 |
Author URI: http://ultimatemember.com/
|
9 |
Text Domain: ultimate-member
|
3 |
Plugin Name: Ultimate Member
|
4 |
Plugin URI: http://ultimatemember.com/
|
5 |
Description: The easiest way to create powerful online communities and beautiful user profiles with WordPress
|
6 |
+
Version: 2.0.12
|
7 |
Author: Ultimate Member
|
8 |
Author URI: http://ultimatemember.com/
|
9 |
Text Domain: ultimate-member
|