嗨@Towfiq:
注释在数据库中与帖子相关。您需要做很多工作才能获得与用户相关的评论。
您是否考虑过为用户创建自定义帖子类型,然后使用一个user_meta
字段来存储post_id
或使用一个postmeta
字段来存储user_id
,或两者都使用?如果这样做,您将毫不费力地得到评论。
更新
接下来是我们在评论中进行讨论之后开发的代码。
我一直想写这样的东西很长时间了,但是您的问题发现使我将其列为优先事项。我'towfiq-person'
为您创建了一个自定义帖子类型,并将其设置为在添加用户时自动添加一个Person帖子,并且它使用电子邮件地址作为名为的帖子自定义字段中的关联关键字'_email'
。
如果用户添加或使用相同的电子邮件更新现有的人也有适当的电子邮件地址的人职位相关联的用户(这可能是也可能不是一个好主意。)它交叉引用用户与人和拥有用户的人分别使用postmeta和usermeta字段'_user_id'
和'_person_id'
。
这些当然是我选择要实现的业务规则,但事实证明它们不适合您的用例,在这种情况下,您可能需要对其进行修改。您可能还会发现WordPress允许这两者不同步的方法,但是如果不进行详尽的测试,很难知道这一点。如果发现问题,可以随时寻求更新逻辑来解决。
您可以将以下代码复制到主题functions.php
文件中:
class Towfiq_Person {
static function on_load() {
add_action('init',array(__CLASS__,'init'));
add_action('wp_insert_post',array(__CLASS__,'wp_insert_post'),10,2);
add_action('profile_update',array(__CLASS__,'profile_update'),10,2);
add_action('user_register',array(__CLASS__,'profile_update'));
add_filter('author_link',array(__CLASS__,'author_link'),10,2);
add_filter('get_the_author_url',array(__CLASS__,'author_link'),10,2);
}
static function init() {
register_post_type('towfiq-person',
array(
'labels' => array('name'=>'People','singular_name'=>'Person'),
'public' => true,
'show_ui' => true,
'rewrite' => array('slug' => 'people'),
'hierarchical' => false,
//'supports' => array('title','editor','custom-fields'),
)
);
}
static function get_email_key() {
return apply_filters( 'person_email_key', '_email' );
}
static function profile_update($user_id,$old_user_data=false) {
global $wpdb;
$is_new_person = false;
$user = get_userdata($user_id);
$user_email = ($old_user_data ? $old_user_data->user_email : $user->user_email);
$email_key = self::get_email_key();
$person_id = $wpdb->get_var($wpdb->prepare("SELECT post_id FROM {$wpdb->postmeta} WHERE meta_key='%s' AND meta_value='%s'",$email_key,$user_email));
if (!is_numeric($person_id)) {
$person_id = $is_new_person = wp_insert_post(array(
'post_type' => 'towfiq-person',
'post_status' => 'publish', // Maybe this should be pending or draft?
'post_title' => $user->display_name,
));
}
update_user_meta($user_id,'_person_id',$person_id);
update_post_meta($person_id,'_user_id',$user_id);
if ($is_new_person || ($old_user_data && $user->user_email!=$old_user_data->user_email)) {
update_post_meta($person_id,$email_key,$user->user_email);
}
}
static function wp_insert_post($person_id,$person) {
if ($person->post_type=='towfiq-person') {
$email = get_post_meta($person_id,self::get_email_key(),true);
if (filter_var($email, FILTER_VALIDATE_EMAIL)) {
$user = get_user_by('email',$email);
if ($user) { // Associate the user IF there is an user with the same email address
update_user_meta($user->ID,'_person_id',$person_id);
update_post_meta($person_id,'_user_id',$user->ID);
} else {
delete_post_meta($person_id,'_user_id');
}
}
}
}
static function get_user_id($person_id) {
return get_user_meta($user_id,'_user_id',true);
}
static function get_user($person_id) {
$user_id = self::get_user_id($person_id);
return get_userdata($user_id);
}
static function get_person_id($user_id) {
return get_user_meta($user_id,'_person_id',true);
}
static function get_person($user_id) {
$person_id = self::get_person_id($user_id);
return get_post($person_id);
}
static function author_link($permalink, $user_id) {
$author_id = get_user_meta($user_id,'_person_id',true);
if ($author_id) // If an associate is found, use it
$permalink = get_post_permalink($author_id);
return $permalink;
}
}
Towfiq_Person::on_load();
如果您需要对我的工作及其原因进行澄清,请在评论中提出。