R 使用jwt访问Zoom.us API
是否有人使用R访问或访问 文档中说我需要生成一个JSON Web令牌,例如jwt.io。该站点有多种语言(python、php、perl、java、go、scala等)的实现,但没有RR 使用jwt访问Zoom.us API,r,R,是否有人使用R访问或访问 文档中说我需要生成一个JSON Web令牌,例如jwt.io。该站点有多种语言(python、php、perl、java、go、scala等)的实现,但没有R 任何提示或实际工作代码都将不胜感激。您可以使用R中相当简单的函数创建您的令牌 library(digest) library(jsonlite) library(base64enc) jwt_hs256 <- function(x, auto_unbox=FALSE) { as_json_hex &l
任何提示或实际工作代码都将不胜感激。您可以使用R中相当简单的函数创建您的令牌
library(digest)
library(jsonlite)
library(base64enc)
jwt_hs256 <- function(x, auto_unbox=FALSE) {
as_json_hex <- function(x, auto_unbox) {
base64encode(charToRaw(toJSON(x, auto_unbox = auto_unbox )))
}
header <- list(
"alg"= "HS256",
"typ"= "JWT"
)
body <-paste(
as_json_hex(header, TRUE),
as_json_hex(x, auto_unbox), sep=".")
tail <- base64encode(hmac("secret", body, algo="sha256", raw=TRUE))
paste(body, tail, sep=".")
}
库(摘要)
图书馆(jsonlite)
图书馆(base64enc)
jwt_hs256事实证明,感谢@MrFlick建议查看http://cran.r-project.org/web/packages/jose/vignettes/jwt.html
有一个超级简单的解决方案。它的工作原理如下:
library(tidyverse)
library(lubridate)
library(openssl)
library(jose)
library(jsonlite)
library(curl)
library(RCurl)
这些就是我最终使用的库——对于这个例子来说,这些可能都不是必需的
claim <- jwt_claim(exp = as.numeric(Sys.time() + 2592000),
iss = Sys.getenv("zoom_api_key"))
jwt <- jwt_encode_hmac(claim,
secret = charToRaw(Sys.getenv("zoom_api_secret")))
claim以下是连接到jwt并创建会议的代码
<?php
require_once 'config.php';
class Zoom_Api
{
protected function sendRequest($data)
{
$request_url = "https://api.zoom.us/v2/users/nawoapp1@gmail.com/meetings";
$postFields = '{
"topic": "New Meeting",
"type": 2,
"start_time": "2020-08-09T12:00:00Z",
"duration": 45,
"timezone": "America/Anchorage",
"password": "1234",
"agenda": "Zoom WordPress",
"tracking_fields": [
{
"field": "string",
"value": "string"
}
],
"settings": {
"host_video": true,
"participant_video": true,
"cn_meeting": false,
"in_meeting": false,
"join_before_host": false,
"mute_upon_entry": true,
"watermark": false,
"use_pmi": false,
"approval_type": 0,
"registration_type": 1,
"audio":"voip",
"enforce_login": false,
"enforce_login_domains": "",
"alternative_hosts": "",
"registrants_email_notification": false
}
}';
$ch = curl_init();
curl_setopt_array($ch, array(
CURLOPT_URL => $request_url,
CURLOPT_RETURNTRANSFER => true,
CURLOPT_ENCODING => "",
CURLOPT_MAXREDIRS => 10,
CURLOPT_TIMEOUT => 30,
CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
CURLOPT_CUSTOMREQUEST => "POST",
CURLOPT_POSTFIELDS => $postFields,
CURLOPT_HTTPHEADER => array(
"authorization: Bearer jfklsjf342384flksjdfl",
"content-type: application/json",
"Accept: application/json",
),
));
$response = curl_exec($ch);
$err = curl_error($ch);
curl_close($ch);
if (!$response) {
return $err;
}
return json_decode($response);
}
public function createAMeeting($data = array())
{
$post_time = $data['start_date'];
$start_time = gmdate("Y-m-d\TH:i:s", strtotime($post_time));
$createAMeetingArray = array();
if (!empty($data['alternative_host_ids'])) {
if (count($data['alternative_host_ids']) > 1) {
$alternative_host_ids = implode(",", $data['alternative_host_ids']);
} else {
$alternative_host_ids = $data['alternative_host_ids'][0];
}
}
$createAMeetingArray['topic'] = $data['topic'];
$createAMeetingArray['agenda'] = !empty($data['agenda']) ? $data['agenda'] : "";
$createAMeetingArray['type'] = !empty($data['type']) ? $data['type'] : 2; //Scheduled
$createAMeetingArray['start_time'] = $start_time;
$createAMeetingArray['timezone'] = 'PST';
$createAMeetingArray['password'] = !empty($data['password']) ? $data['password'] : "";
$createAMeetingArray['duration'] = !empty($data['duration']) ? $data['duration'] : 60;
$createAMeetingArray['settings'] = array(
'join_before_host' => !empty($data['join_before_host']) ? true : false,
'host_video' => !empty($data['option_host_video']) ? true : false,
'participant_video' => !empty($data['option_participants_video']) ? true : false,
'mute_upon_entry' => !empty($data['option_mute_participants']) ? true : false,
'enforce_login' => !empty($data['option_enforce_login']) ? true : false,
'auto_recording' => !empty($data['option_auto_recording']) ? $data['option_auto_recording'] : "none",
'alternative_hosts' => isset($alternative_host_ids) ? $alternative_host_ids : ""
);
return $this->sendRequest($createAMeetingArray);
}
}
$zoom_meeting = new Zoom_Api();
try {
$z = $zoom_meeting->createAMeeting(
array(
'start_date' => date("Y-m-d h:i:s", strtotime('tomorrow')),
'topic' => 'Example Test Meeting'
)
);
echo json_encode($z);
} catch (Exception $ex) {
echo $ex;
}
你检查过这个了吗:谢谢@MrFlick…它一般都是这样工作的,但是我无法将它翻译成类似的东西。插入你建议的代码需要更多关于Rcurl选项的知识,而不是我所拥有或似乎能够挖掘的知识。
get_users_meetings <- function(email_id) {
response <- curl_fetch_memory(paste0("https://api.zoom.us/v2/users/",
email_id, "/meetings?type=scheduled&page_size=60&page_number=1&access_token=",
jwt))
# Previous assumed that nobody has more than 60 meetings scheduled.
sched1 <- fromJSON(rawToChar(response$content))
meetings <- sched1$meetings
meetings$host_email <- URLdecode(email_id)
meetings
}
# using a list of URL encoded email addresses in email_id:
live_meetings <- get_users_meetings(email_id)
<?php
require_once 'config.php';
class Zoom_Api
{
protected function sendRequest($data)
{
$request_url = "https://api.zoom.us/v2/users/nawoapp1@gmail.com/meetings";
$postFields = '{
"topic": "New Meeting",
"type": 2,
"start_time": "2020-08-09T12:00:00Z",
"duration": 45,
"timezone": "America/Anchorage",
"password": "1234",
"agenda": "Zoom WordPress",
"tracking_fields": [
{
"field": "string",
"value": "string"
}
],
"settings": {
"host_video": true,
"participant_video": true,
"cn_meeting": false,
"in_meeting": false,
"join_before_host": false,
"mute_upon_entry": true,
"watermark": false,
"use_pmi": false,
"approval_type": 0,
"registration_type": 1,
"audio":"voip",
"enforce_login": false,
"enforce_login_domains": "",
"alternative_hosts": "",
"registrants_email_notification": false
}
}';
$ch = curl_init();
curl_setopt_array($ch, array(
CURLOPT_URL => $request_url,
CURLOPT_RETURNTRANSFER => true,
CURLOPT_ENCODING => "",
CURLOPT_MAXREDIRS => 10,
CURLOPT_TIMEOUT => 30,
CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
CURLOPT_CUSTOMREQUEST => "POST",
CURLOPT_POSTFIELDS => $postFields,
CURLOPT_HTTPHEADER => array(
"authorization: Bearer jfklsjf342384flksjdfl",
"content-type: application/json",
"Accept: application/json",
),
));
$response = curl_exec($ch);
$err = curl_error($ch);
curl_close($ch);
if (!$response) {
return $err;
}
return json_decode($response);
}
public function createAMeeting($data = array())
{
$post_time = $data['start_date'];
$start_time = gmdate("Y-m-d\TH:i:s", strtotime($post_time));
$createAMeetingArray = array();
if (!empty($data['alternative_host_ids'])) {
if (count($data['alternative_host_ids']) > 1) {
$alternative_host_ids = implode(",", $data['alternative_host_ids']);
} else {
$alternative_host_ids = $data['alternative_host_ids'][0];
}
}
$createAMeetingArray['topic'] = $data['topic'];
$createAMeetingArray['agenda'] = !empty($data['agenda']) ? $data['agenda'] : "";
$createAMeetingArray['type'] = !empty($data['type']) ? $data['type'] : 2; //Scheduled
$createAMeetingArray['start_time'] = $start_time;
$createAMeetingArray['timezone'] = 'PST';
$createAMeetingArray['password'] = !empty($data['password']) ? $data['password'] : "";
$createAMeetingArray['duration'] = !empty($data['duration']) ? $data['duration'] : 60;
$createAMeetingArray['settings'] = array(
'join_before_host' => !empty($data['join_before_host']) ? true : false,
'host_video' => !empty($data['option_host_video']) ? true : false,
'participant_video' => !empty($data['option_participants_video']) ? true : false,
'mute_upon_entry' => !empty($data['option_mute_participants']) ? true : false,
'enforce_login' => !empty($data['option_enforce_login']) ? true : false,
'auto_recording' => !empty($data['option_auto_recording']) ? $data['option_auto_recording'] : "none",
'alternative_hosts' => isset($alternative_host_ids) ? $alternative_host_ids : ""
);
return $this->sendRequest($createAMeetingArray);
}
}
$zoom_meeting = new Zoom_Api();
try {
$z = $zoom_meeting->createAMeeting(
array(
'start_date' => date("Y-m-d h:i:s", strtotime('tomorrow')),
'topic' => 'Example Test Meeting'
)
);
echo json_encode($z);
} catch (Exception $ex) {
echo $ex;
}