繁体   English   中英

WP rest api - POST 端点并存储在用户元数据中

[英]WP rest api - POST endpoint and store in the user meta data

我正在尝试在 Wordpress 上创建一个自定义端点来处理 WooCommerce 身份验证密钥。

概括地说,当您使用 rest api 生成身份验证密钥时,这些 API 密钥将在单独的 POST 请求中发回。

所以发生的事情是,我的反应网站将授权请求提交给 WooCommerce/Wordpress 无头服务器,回调是wordpress_url/xxx/v1/authkeys 它还需要支持https。

我正在尝试将此xxx/v1/authkeys端点添加到 wordpress,目的是提取 JSON 数据,如下所示:

{
    "key_id": 1,
    "user_id": 123,
    "consumer_key": "ck_xxxxxxxxxxxxxxxx",
    "consumer_secret": "cs_xxxxxxxxxxxxxxxx",
    "key_permissions": "read_write"
}

并将consumer_keyconsumer_secretkey_permissions存储在与user_id相关的用户元数据中。

我的目标是在我提取用户信息(包括那些元数据)时能够获得密钥。

默认情况下,这些字段是新的,所以我需要确保如果数据库中不存在consumer_keyconsumer_secretkey_permissions ,我们会创建这些字段。

现在,我已经在function.php添加了:

function handle_woocommerce_keys($request){
    $user_id = $request[user_id];
    $consumer_key=$request[consumer_key];
    $consumer_secret=$request[consumer_secret];
    $key_permissions=$request[key_permissions];

/* search user_id in db and store the keys as meta_data */


    $response = new WP_REST_Response();
    $response->set_status(200);

    return $response;
}

add_action('rest_api_init', function () {
    register_rest_route( 'village/v1', 'authkeys',array(
        'methods'  => 'POST',
        'callback' => 'handle_woocommerce_keys'
    ));
});

由于我是 php/wordpress 的新手,我不知道如何在用户数据库中为特定的 user_id 添加数据

感谢您的帮助

如果您缺少的只是数据库存储部分,那么使用 WP 很容易,您只需要:

// Load wp user object (if needed)
$user = new WP_User($user_id);
// or just save the data..
update_user_meta($user_id,'consumer_key',$consumer_key);
update_user_meta($user_id,'consumer_secret',$consumer_secret);
update_user_meta($user_id,'key_permissions',$key_permissions);

update_user_meta 已经做了检查缺失 -> 创建或现有 -> 更新

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM