-
Notifications
You must be signed in to change notification settings - Fork 0
/
index.js
124 lines (118 loc) · 3.99 KB
/
index.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
import "./styles.css";
const serverURL = "https://agora-token-generator-demo.vercel.app/api/main";
if (document.getElementById("product").value.toString() === "chat") {
document.getElementById("channelName").hidden = true;
} else {
document.getElementById("channelName").hidden = false;
}
window.onload = async function () {
// Generate token using token generator server
document.getElementById("generateToken").onclick = async function () {
let tokenType = document.getElementById("product").value.toString();
let appId = document.getElementById("appId").value.toString();
let appCert = document.getElementById("appCert").value.toString();
let uid = document.getElementById("userId").value.toString();
let channelName = document.getElementById("channelName").value.toString();
let tokenExpiry = Number(document.getElementById("expiry").value.toString());
let token = "";
switch (tokenType) {
case "rtc":
token = await fetch(serverURL + "?type=rtc", {
method: "POST",
headers: {
"Content-Type": "application/json",
},
body: JSON.stringify({
appId: appId,
certificate: appCert,
channel: channelName,
uid: uid,
role: "publisher",
expire: tokenExpiry,
}),
})
.then((response) => response.json())
.then((data) => {
// Process the response data here
console.log(data);
document.getElementById("tokenText").value = data.rtcToken;
})
.catch((error) => {
// Handle any errors that occur during the request
console.error(error);
});
break;
case "rtm":
token = await fetch(serverURL + "?type=rtm", {
method: "POST",
headers: {
"Content-Type": "application/json",
},
body: JSON.stringify({
appId: appId,
certificate: appCert,
channel: channelName,
uid: uid,
role: "publisher",
expire: tokenExpiry,
}),
})
.then((response) => response.json())
.then((data) => {
// Process the response data here
console.log(data);
document.getElementById("tokenText").value = data.rtmToken;
})
.catch((error) => {
// Handle any errors that occur during the request
console.error(error);
});
break;
case "chat":
token = await fetch(serverURL + "?type=chat", {
method: "POST",
headers: {
"Content-Type": "application/json",
},
body: JSON.stringify({
appId: appId,
certificate: appCert,
uid: uid,
role: "publisher",
expire: tokenExpiry,
}),
})
.then((response) => response.json())
.then((data) => {
// Process the response data here
console.log(data);
document.getElementById("tokenText").value = data.chatToken;
})
.catch((error) => {
// Handle any errors that occur during the request
console.error(error);
});
break;
default:
break;
}
};
document.getElementById("product").onclick = async function () {
if (document.getElementById("product").value.toString() === "chat") {
document.getElementById("channelName").hidden = true;
} else {
document.getElementById("channelName").hidden = false;
}
};
let copyText = document.querySelector(".copy-text");
copyText.querySelector("button").addEventListener("click", function () {
let input = copyText.querySelector(".textbox");
input.select();
document.execCommand("copy");
copyText.classList.add("active");
window.getSelection().removeAllRanges();
setTimeout(function () {
copyText.classList.remove("active");
}, 2500);
});
};