- // NOTE: still superficial identity usurpation possible, but difficult.
- ajax("/whoami", "GET", res => {
- this.state.user.id = res.id;
- const storedId = localStorage.getItem("myid");
- if (res.id > 0 && !storedId)
- // User cleared localStorage
- localStorage.setItem("myid", res.id);
- else if (res.id == 0 && !!storedId)
- // User cleared cookie
- localStorage.removeItem("myid");
- this.state.user.name = res.name;
- const storedName = localStorage.getItem("myname");
- if (!!res.name && !storedName)
- // User cleared localStorage
- localStorage.setItem("myname", res.name);
- else if (!res.name && !!storedName)
- // User cleared cookie
- localStorage.removeItem("myname");
- this.state.user.email = res.email;
- this.state.user.notify = res.notify;
+ fetch(
+ params.serverUrl + "/whoami",
+ {
+ method: "GET",
+ headers: headers,
+ credentials: params.credentials
+ }
+ )
+ .then(res => res.json())
+ .then(json => {
+ if (!json.id) {
+ // Removed, or wrong token
+ if (this.state.user.id > 0) {
+ this.state.user.id = 0;
+ localStorage.removeItem("myid");
+ }
+ if (!!this.state.user.name) {
+ this.state.user.name = "";
+ localStorage.removeItem("myname");
+ }
+ if (document.cookie.indexOf("token") >= 0) delCookie("token");
+ }
+ else {
+ if (this.state.user.id != json.id) {
+ this.state.user.id = json.id;
+ localStorage.setItem("myid", json.id);
+ }
+ if (this.state.user.name != json.name) {
+ this.state.user.name = json.name;
+ localStorage.setItem("myname", json.name);
+ }
+ this.state.user.email = json.email;
+ this.state.user.notify = json.notify;
+ }