mirror of
https://github.com/naturalcrit/homebrewery.git
synced 2026-01-06 23:02:45 +00:00
Code Cleanup
Remove req, res from update, new, and getFolder google actions
This commit is contained in:
@@ -187,7 +187,7 @@ const EditPage = createClass({
|
|||||||
return;
|
return;
|
||||||
});
|
});
|
||||||
|
|
||||||
this.savedBrew = res.body.brew;
|
this.savedBrew = res.body;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
console.log('Saving Locally');
|
console.log('Saving Locally');
|
||||||
|
|||||||
@@ -1,4 +1,3 @@
|
|||||||
/* eslint-disable max-lines */
|
|
||||||
const _ = require('lodash');
|
const _ = require('lodash');
|
||||||
const { google } = require('googleapis');
|
const { google } = require('googleapis');
|
||||||
const { nanoid } = require('nanoid');
|
const { nanoid } = require('nanoid');
|
||||||
@@ -49,49 +48,7 @@ GoogleActions = {
|
|||||||
return oAuth2Client;
|
return oAuth2Client;
|
||||||
},
|
},
|
||||||
|
|
||||||
getGoogleFolder : async (req, res)=>{
|
getGoogleFolder : async (auth)=>{
|
||||||
console.log('getting google folder');
|
|
||||||
oAuth2Client = GoogleActions.authCheck(req.account, res);
|
|
||||||
|
|
||||||
const drive = google.drive({ version: 'v3', auth: oAuth2Client });
|
|
||||||
|
|
||||||
fileMetadata = {
|
|
||||||
'name' : 'Homebrewery',
|
|
||||||
'mimeType' : 'application/vnd.google-apps.folder'
|
|
||||||
};
|
|
||||||
|
|
||||||
const obj = await drive.files.list({
|
|
||||||
q : 'mimeType = \'application/vnd.google-apps.folder\''
|
|
||||||
})
|
|
||||||
.catch((err)=>{
|
|
||||||
console.log('Error searching Google Drive Folders');
|
|
||||||
console.error(err);
|
|
||||||
});
|
|
||||||
|
|
||||||
let folderId;
|
|
||||||
|
|
||||||
if(obj.data.files.length == 0){
|
|
||||||
console.log('no folders found'); // CREATE APP FOLDER
|
|
||||||
|
|
||||||
const obj = await drive.files.create({
|
|
||||||
resource : fileMetadata
|
|
||||||
})
|
|
||||||
.catch((err)=>{
|
|
||||||
console.log('Error creating google app folder');
|
|
||||||
console.error(err);
|
|
||||||
});
|
|
||||||
|
|
||||||
console.log('created new drive folder with ID:');
|
|
||||||
console.log(obj.data.id);
|
|
||||||
folderId = obj.data.id;
|
|
||||||
} else {
|
|
||||||
folderId = obj.data.files[0].id;
|
|
||||||
}
|
|
||||||
|
|
||||||
return folderId;
|
|
||||||
},
|
|
||||||
|
|
||||||
getGoogleFolderNew : async (auth)=>{
|
|
||||||
console.log('getting google folder');
|
console.log('getting google folder');
|
||||||
const drive = google.drive({ version: 'v3', auth: auth });
|
const drive = google.drive({ version: 'v3', auth: auth });
|
||||||
|
|
||||||
@@ -190,88 +147,27 @@ GoogleActions = {
|
|||||||
return false;
|
return false;
|
||||||
},
|
},
|
||||||
|
|
||||||
updateGoogleBrew : async (req, res)=>{
|
updateGoogleBrew : async (auth, brew)=>{
|
||||||
oAuth2Client = GoogleActions.authCheck(req.account, res);
|
const drive = google.drive({ version: 'v3', auth: auth });
|
||||||
|
|
||||||
const drive = google.drive({ version: 'v3', auth: oAuth2Client });
|
if(await GoogleActions.existsGoogleBrew(auth, brew.googleId) == true) {
|
||||||
const brew = req.body;
|
|
||||||
|
|
||||||
const media = {
|
await drive.files.update({
|
||||||
mimeType : 'text/plain',
|
fileId : brew.googleId,
|
||||||
body : brew.text
|
resource : { name : `${brew.title}.txt`,
|
||||||
};
|
properties : { title: brew.title } //AppProperties is not accessible via API key
|
||||||
|
},
|
||||||
let obj;
|
media : { mimeType : 'text/plain',
|
||||||
|
body : brew.text }
|
||||||
//CHECK IF FILE ALREADY EXISTS
|
|
||||||
if(await GoogleActions.existsGoogleBrew(oAuth2Client, req.body.googleId) == true) {
|
|
||||||
//IF SO, JUST UPDATE EXISTING FILE
|
|
||||||
const fileMetadata = {
|
|
||||||
'name' : `${brew.title}.txt`,
|
|
||||||
'properties' : { //AppProperties is not accessible
|
|
||||||
'shareId' : brew.shareId,
|
|
||||||
'editId' : brew.editId,
|
|
||||||
'title' : brew.title,
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
obj = await drive.files.update({
|
|
||||||
fileId : req.body.googleId,
|
|
||||||
resource : fileMetadata,
|
|
||||||
media : media
|
|
||||||
})
|
})
|
||||||
.catch((err)=>{
|
.catch((err)=>{
|
||||||
console.log('Error saving to google');
|
console.log('Error saving to google');
|
||||||
console.error(err);
|
console.error(err);
|
||||||
//return res.status(500).send('Error while saving');
|
//return res.status(500).send('Error while saving');
|
||||||
});
|
});
|
||||||
} else {
|
|
||||||
//IF NOT, CREATE NEW FILE
|
|
||||||
const folderId = await GoogleActions.getGoogleFolder(req, res);
|
|
||||||
const fileMetadata = {
|
|
||||||
'name' : `${brew.title}.txt`,
|
|
||||||
'parents' : [folderId],
|
|
||||||
'properties' : { //AppProperties is not accessible
|
|
||||||
'shareId' : nanoid(12),
|
|
||||||
'editId' : nanoid(12),
|
|
||||||
'title' : brew.title,
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
obj = await drive.files.create({
|
|
||||||
resource : fileMetadata,
|
|
||||||
media : media
|
|
||||||
})
|
|
||||||
.catch((err)=>{
|
|
||||||
console.log('Error saving to google');
|
|
||||||
console.error(err);
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if(obj) {
|
return (brew);
|
||||||
//Update permissions
|
|
||||||
const permissions = {
|
|
||||||
'type' : 'anyone',
|
|
||||||
'role' : 'writer',
|
|
||||||
};
|
|
||||||
|
|
||||||
await drive.permissions.create({
|
|
||||||
resource : permissions,
|
|
||||||
fileId : obj.data.id,
|
|
||||||
fields : 'id',
|
|
||||||
})
|
|
||||||
.catch((err)=>{
|
|
||||||
console.log('Error updating permissions');
|
|
||||||
console.error(err);
|
|
||||||
});
|
|
||||||
|
|
||||||
response = {
|
|
||||||
brew : brew,
|
|
||||||
googleId : obj.data.id
|
|
||||||
};
|
|
||||||
|
|
||||||
return res.status(200).send(response);
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
|
|
||||||
newGoogleBrew : async (auth, brew)=>{
|
newGoogleBrew : async (auth, brew)=>{
|
||||||
@@ -283,7 +179,7 @@ GoogleActions = {
|
|||||||
body : brew.text
|
body : brew.text
|
||||||
};
|
};
|
||||||
|
|
||||||
const folderId = await GoogleActions.getGoogleFolderNew(auth);
|
const folderId = await GoogleActions.getGoogleFolder(auth);
|
||||||
|
|
||||||
const fileMetadata = {
|
const fileMetadata = {
|
||||||
'name' : `${brew.title}.txt`,
|
'name' : `${brew.title}.txt`,
|
||||||
@@ -300,20 +196,15 @@ GoogleActions = {
|
|||||||
media : media
|
media : media
|
||||||
})
|
})
|
||||||
.catch((err)=>{
|
.catch((err)=>{
|
||||||
console.log('Error saving to google');
|
|
||||||
console.error(err);
|
console.error(err);
|
||||||
return res.status(500).send('Error while creating google brew');
|
return res.status(500).send('Error while creating google brew');
|
||||||
});
|
});
|
||||||
|
|
||||||
if(!obj) return;
|
if(!obj) return;
|
||||||
|
|
||||||
const permissions = {
|
|
||||||
'type' : 'anyone',
|
|
||||||
'role' : 'writer',
|
|
||||||
};
|
|
||||||
|
|
||||||
await drive.permissions.create({
|
await drive.permissions.create({
|
||||||
resource : permissions,
|
resource : { type : 'anyone',
|
||||||
|
role : 'writer'},
|
||||||
fileId : obj.data.id,
|
fileId : obj.data.id,
|
||||||
fields : 'id',
|
fields : 'id',
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -120,7 +120,7 @@ const deleteBrew = (req, res)=>{
|
|||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
newGoogleBrew = async (req, res, next)=>{
|
const newGoogleBrew = async (req, res, next)=>{
|
||||||
let oAuth2Client;
|
let oAuth2Client;
|
||||||
|
|
||||||
console.log('newGoogleBrew (API)');
|
console.log('newGoogleBrew (API)');
|
||||||
@@ -142,57 +142,28 @@ newGoogleBrew = async (req, res, next)=>{
|
|||||||
|
|
||||||
console.log(oAuth2Client);
|
console.log(oAuth2Client);
|
||||||
|
|
||||||
const newHomebrew = await GoogleActions.newGoogleBrew(oAuth2Client, brew);
|
const newBrew = await GoogleActions.newGoogleBrew(oAuth2Client, brew);
|
||||||
|
|
||||||
return res.status(200).send(newHomebrew);
|
return res.status(200).send(newBrew);
|
||||||
|
};
|
||||||
|
|
||||||
|
const updateGoogleBrew = async (req, res, next)=>{
|
||||||
|
let oAuth2Client;
|
||||||
|
|
||||||
|
try { oAuth2Client = GoogleActions.authCheck(req.account, res); } catch (err) { return res.status(err.status).send(err.message); }
|
||||||
|
|
||||||
|
const updatedBrew = await GoogleActions.updateGoogleBrew(oAuth2Client, req.body);
|
||||||
|
|
||||||
|
return res.status(200).send(updatedBrew);
|
||||||
};
|
};
|
||||||
|
|
||||||
router.post('/api', newBrew);
|
router.post('/api', newBrew);
|
||||||
router.post('/api/newGoogle/', newGoogleBrew);
|
router.post('/api/newGoogle/', newGoogleBrew);
|
||||||
router.put('/api/:id', updateBrew);
|
router.put('/api/:id', updateBrew);
|
||||||
router.put('/api/update/:id', updateBrew);
|
router.put('/api/update/:id', updateBrew);
|
||||||
router.put('/api/updateGoogle/:id', (req, res)=>{GoogleActions.updateGoogleBrew(req, res);});
|
router.put('/api/updateGoogle/:id', updateGoogleBrew);
|
||||||
router.delete('/api/:id', deleteBrew);
|
router.delete('/api/:id', deleteBrew);
|
||||||
router.get('/api/remove/:id', deleteBrew);
|
router.get('/api/remove/:id', deleteBrew);
|
||||||
router.get('/api/removeGoogle/:id', (req, res)=>{GoogleActions.deleteGoogleBrew(req, res, req.params.id);});
|
router.get('/api/removeGoogle/:id', (req, res)=>{GoogleActions.deleteGoogleBrew(req, res, req.params.id);});
|
||||||
|
|
||||||
module.exports = router;
|
module.exports = router;
|
||||||
|
|
||||||
/*
|
|
||||||
module.exports = function(app) {
|
|
||||||
app;
|
|
||||||
|
|
||||||
app.get('/api/search', mw.adminOnly, function(req, res) {
|
|
||||||
var page = req.query.page || 0;
|
|
||||||
var count = req.query.count || 20;
|
|
||||||
|
|
||||||
var query = {};
|
|
||||||
if (req.query && req.query.id) {
|
|
||||||
query = {
|
|
||||||
"$or": [{
|
|
||||||
editId : req.query.id
|
|
||||||
}, {
|
|
||||||
shareId : req.query.id
|
|
||||||
}]
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
HomebrewModel.find(query, {
|
|
||||||
text : 0 //omit the text
|
|
||||||
}, {
|
|
||||||
skip: page*count,
|
|
||||||
limit: count*1
|
|
||||||
}, function(err, objs) {
|
|
||||||
if (err) console.error(err);
|
|
||||||
return res.json({
|
|
||||||
page : page,
|
|
||||||
count : count,
|
|
||||||
total : homebrewTotal,
|
|
||||||
brews : objs
|
|
||||||
});
|
|
||||||
});
|
|
||||||
})
|
|
||||||
|
|
||||||
return app;
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|||||||
Reference in New Issue
Block a user