-
Notifications
You must be signed in to change notification settings - Fork 142
/
Copy pathindex.ts
74 lines (64 loc) · 2.86 KB
/
index.ts
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
/* A simple webapp that authenticates the user with Internet Identity and that
* then calls the whoami canister to check the user's principal.
*/
import { Actor, ActorMethod, HttpAgent } from "@dfinity/agent";
import { AuthClient } from "@dfinity/auth-client";
import type { Principal } from "@dfinity/principal";
const webapp_id = process.env.WHOAMI_CANISTER_ID;
// The <canisterId>.localhost URL is used as opposed to setting the canister id as a parameter
// since the latter is brittle with regards to transitively loaded resources.
const local_ii_url = `http://${process.env.INTERNET_IDENTITY_CANISTER_ID}.localhost:4943`;
// @ts-ignore - The interface of the whoami canister
const webapp_idl = ({ IDL }) => {
return IDL.Service({ whoami: IDL.Func([], [IDL.Principal], ["query"]) });
};
// @ts-ignore
export const init = ({ IDL }) => {
return [];
};
export interface _SERVICE {
whoami: ActorMethod<[], Principal>;
}
// Autofills the <input> for the II Url to point to the correct canister.
document.body.onload = () => {
let iiUrl;
if (process.env.DFX_NETWORK === "local") {
iiUrl = local_ii_url;
} else if (process.env.DFX_NETWORK === "ic") {
iiUrl = `https://${process.env.INTERNET_IDENTITY_CANISTER_ID}.ic0.app`;
} else {
// fall back to local
iiUrl = local_ii_url;
}
document.querySelector<HTMLInputElement>("#iiUrl")!.value = iiUrl;
};
document.getElementById("loginBtn")?.addEventListener("click", async () => {
// When the user clicks, we start the login process.
// First we have to create and AuthClient.
const authClient = await AuthClient.create();
// Find out which URL should be used for login.
const iiUrl = document.querySelector<HTMLInputElement>("#iiUrl")!.value;
// Call authClient.login(...) to login with Internet Identity. This will open a new tab
// with the login prompt. The code has to wait for the login process to complete.
// We can either use the callback functions directly or wrap in a promise.
await new Promise<void>((resolve, reject) => {
authClient.login({
identityProvider: iiUrl,
onSuccess: resolve,
onError: reject,
});
});
// At this point we're authenticated, and we can get the identity from the auth client:
const identity = authClient.getIdentity();
// Using the identity obtained from the auth client, we can create an agent to interact with the IC.
const agent = await HttpAgent.create({ identity, shouldFetchRootKey: true });
// Using the interface description of our webapp, we create an actor that we use to call the service methods.
const webapp: _SERVICE = Actor.createActor(webapp_idl, {
agent,
canisterId: webapp_id!,
});
// Call whoami which returns the principal (user id) of the current user.
const principal = await webapp.whoami();
// show the principal on the page
document.getElementById("loginStatus")!.innerText = principal.toText();
});