Merge pull request #72 from ClaytonWWilson/fix-delete

Fix delete
This commit is contained in:
Clayton Wilson 2019-11-01 13:26:25 -04:00 committed by GitHub
commit d4ea00d2e9
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -70,12 +70,14 @@ exports.signup = (req, res) => {
}) })
.then(idToken => { .then(idToken => {
token = idToken; token = idToken;
const defaultImageUrl = `https://firebasestorage.googleapis.com/v0/b/${config.storageBucket}/o/no-img.png?alt=media`;
const userCred = { const userCred = {
email: newUser.email, email: newUser.email,
handle: newUser.handle, handle: newUser.handle,
createdAt: newUser.createdAt, createdAt: newUser.createdAt,
userId, userId,
followedTopics: [] followedTopics: [],
imageUrl: defaultImageUrl
}; };
return db.doc(`/users/${newUser.handle}`).set(userCred); return db.doc(`/users/${newUser.handle}`).set(userCred);
}) })
@ -193,62 +195,80 @@ exports.login = (req, res) => {
} }
}; };
//Deletes user account //Deletes user account and all associated data
exports.deleteUser = (req, res) => { exports.deleteUser = (req, res) => {
var currentUser; // Get the profile image filename
firebase.auth().onAuthStateChanged(function(user) { // `https://firebasestorage.googleapis.com/v0/b/${config.storageBucket}/o/${imageFileName}?alt=media`
currentUser = user; let imageFileName;
if (currentUser) { req.userData.imageUrl ?
var post_query = db imageFileName = req.userData.imageUrl.split('/o/')[1].split('?alt=')[0] :
.collection("posts") imageFileName = 'no-img.png'
.where("userHandle", "==", req.user.handle);
post_query
.get()
.then(function(myPosts) {
myPosts.forEach(function(doc) {
doc.ref.delete();
});
return;
})
.then(function() {
res
.status(200)
.send("Successfully removed all user's posts from database.");
return;
})
.catch(function(err) {
res
.status(500)
.send("Failed to remove all user's posts from database.", err);
});
db.collection("users") const userId = req.userData.userId;
.doc(`${req.user.handle}`) let errors = {};
.delete()
.then(function() {
res.status(200).send("Sucessfully removed user from database.");
return;
})
.catch(function(err) {
res.status(500).send("Failed to remove user from database.", err);
});
currentUser function thenFunction(data) {
.delete() console.log(`${data} data for ${req.userData.handle} has been deleted.`);
.then(function() { }
console.log("Successfully deleted user.");
res.status(200).send("Sucessfully deleted user."); function catchFunction(data, err) {
return; console.error(err);
}) errors[data] = err;
.catch(function(err) { }
console.log("Failed to delete user.", err);
res.status(500).send("Failed to delete user."); // Deletes user from authentication
}); let auth = admin.auth().deleteUser(userId);
// Deletes database data
let data = db.collection("users").doc(`${req.user.handle}`).delete();
// Deletes any custom profile image
let image;
if (imageFileName !== 'no-img.png') {
image = admin.storage().bucket().file(imageFileName).delete()
} else {
image = Promise.resolve();
}
// Deletes all users posts
let posts = db.collection("posts")
.where("userHandle", "==", req.user.handle)
.get()
.then((query) => {
query.forEach((snap) => {
snap.ref.delete();
})
})
let promises = [
auth
.then(thenFunction('auth'))
.catch((err) => catchFunction('auth', err)),
data
.then(thenFunction('data'))
.catch((err) => catchFunction('data', err)),
image
.then(thenFunction('image'))
.catch((err) => catchFunction('image', err)),
posts
.then(thenFunction('posts'))
.catch((err) => catchFunction('image', err))
];
// Wait for all promises to resolve
let waitPromise = Promise.all(promises);
waitPromise.then(() => {
if (Object.keys(errors) > 0) {
return res.status(500).json(errors);
} else { } else {
console.log("Failed to deleter user or cannot get user."); return res.status(200).json({message: `All data for ${req.userData.handle} has been deleted.`});
res.status(500).send("Failed to deleter user or cannot get user.");
} }
}); })
.catch((err) => {
return res.status(500).json({error: err});
})
}; };
// Returns all data in the database for the user who is currently signed in // Returns all data in the database for the user who is currently signed in