- Enable Edit Event into dialog form ... (and save to the db)
- Event: enabled drag and drop (date) - Q-Select components in every table field external: Where, Operators, etc... - CMyEditor: Add HTML Editor to the details field ! - Added button Color for change font color to the text. - Complete insert Events Site
This commit is contained in:
45
plugins/file.js
Normal file
45
plugins/file.js
Normal file
@@ -0,0 +1,45 @@
|
|||||||
|
var fs = require('fs');
|
||||||
|
|
||||||
|
var FILE = function() {};
|
||||||
|
|
||||||
|
FILE.prototype.save = function(base64, file_url, callback) {
|
||||||
|
var base64Data = base64.split(',')[1];
|
||||||
|
return fs.writeFile(
|
||||||
|
file_url,
|
||||||
|
base64Data,
|
||||||
|
{
|
||||||
|
flags: 'wx',
|
||||||
|
encoding: 'base64'
|
||||||
|
},
|
||||||
|
function(err) {
|
||||||
|
if (err) {
|
||||||
|
console.error('writeFile', err);
|
||||||
|
throw err;
|
||||||
|
}
|
||||||
|
|
||||||
|
callback();
|
||||||
|
}
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
FILE.prototype.get = function(path, isVideo) {
|
||||||
|
var bitmap = fs.readFileSync(path);
|
||||||
|
|
||||||
|
if (!isVideo) {
|
||||||
|
try {
|
||||||
|
return new Buffer(bitmap).toString('base64');
|
||||||
|
} catch (e) {
|
||||||
|
throw e;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
var binary = '';
|
||||||
|
var bytes = new Uint8Array(bitmap);
|
||||||
|
var len = bytes.byteLength;
|
||||||
|
for (var i = 0; i < len; i++) {
|
||||||
|
binary += String.fromCharCode(bytes[i]);
|
||||||
|
}
|
||||||
|
return new Buffer(binary).toString('base64');
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
module.exports = new FILE();
|
||||||
193
plugins/googleapi.js
Normal file
193
plugins/googleapi.js
Normal file
@@ -0,0 +1,193 @@
|
|||||||
|
const fs = require('fs');
|
||||||
|
const readline = require('readline');
|
||||||
|
const {google} = require('googleapis');
|
||||||
|
var FILE = require('./file');
|
||||||
|
|
||||||
|
var GOOGLEAPI = function() {};
|
||||||
|
var auth = null;
|
||||||
|
|
||||||
|
GOOGLEAPI.prototype.init = function() {
|
||||||
|
// If modifying these scopes, delete token.json.
|
||||||
|
const SCOPES = [
|
||||||
|
'https://www.googleapis.com/auth/drive',
|
||||||
|
'https://www.googleapis.com/auth/drive.file',
|
||||||
|
'https://www.googleapis.com/auth/drive.appdata',
|
||||||
|
'https://www.googleapis.com/auth/drive.apps.readonly',
|
||||||
|
'https://www.googleapis.com/auth/drive.readonly',
|
||||||
|
'https://www.googleapis.com/auth/drive.metadata.readonly',
|
||||||
|
'https://www.googleapis.com/auth/drive.metadata',
|
||||||
|
'https://www.googleapis.com/auth/drive.photos.readonly'
|
||||||
|
];
|
||||||
|
// The file token.json stores the user's access and refresh tokens, and is
|
||||||
|
// created automatically when the authorization flow completes for the first
|
||||||
|
// time.
|
||||||
|
const TOKEN_PATH = 'token.json';
|
||||||
|
|
||||||
|
// Load client secrets from a local file.
|
||||||
|
fs.readFile('credentials.json', (err, content) => {
|
||||||
|
if (err) return console.log('Error loading client secret file:', err);
|
||||||
|
// Authorize a client with credentials, then call the Google Drive API.
|
||||||
|
authorize(JSON.parse(content), listFiles);
|
||||||
|
});
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create an OAuth2 client with the given credentials, and then execute the
|
||||||
|
* given callback function.
|
||||||
|
* @param {Object} credentials The authorization client credentials.
|
||||||
|
* @param {function} callback The callback to call with the authorized client.
|
||||||
|
*/
|
||||||
|
function authorize(credentials, callback) {
|
||||||
|
const {client_secret, client_id, redirect_uris} = credentials.installed;
|
||||||
|
const oAuth2Client = new google.auth.OAuth2(
|
||||||
|
client_id,
|
||||||
|
client_secret,
|
||||||
|
redirect_uris[0]
|
||||||
|
);
|
||||||
|
|
||||||
|
// Check if we have previously stored a token.
|
||||||
|
fs.readFile(TOKEN_PATH, (err, token) => {
|
||||||
|
if (err) return getAccessToken(oAuth2Client, callback);
|
||||||
|
oAuth2Client.setCredentials(JSON.parse(token));
|
||||||
|
callback(oAuth2Client);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get and store new token after prompting for user authorization, and then
|
||||||
|
* execute the given callback with the authorized OAuth2 client.
|
||||||
|
* @param {google.auth.OAuth2} oAuth2Client The OAuth2 client to get token for.
|
||||||
|
* @param {getEventsCallback} callback The callback for the authorized client.
|
||||||
|
*/
|
||||||
|
function getAccessToken(oAuth2Client, callback) {
|
||||||
|
const authUrl = oAuth2Client.generateAuthUrl({
|
||||||
|
access_type: 'offline',
|
||||||
|
scope: SCOPES
|
||||||
|
});
|
||||||
|
console.log('Authorize this app by visiting this url:', authUrl);
|
||||||
|
const rl = readline.createInterface({
|
||||||
|
input: process.stdin,
|
||||||
|
output: process.stdout
|
||||||
|
});
|
||||||
|
rl.question('Enter the code from that page here: ', code => {
|
||||||
|
rl.close();
|
||||||
|
oAuth2Client.getToken(code, (err, token) => {
|
||||||
|
if (err) return console.error('Error retrieving access token', err);
|
||||||
|
oAuth2Client.setCredentials(token);
|
||||||
|
// Store the token to disk for later program executions
|
||||||
|
fs.writeFile(TOKEN_PATH, JSON.stringify(token), err => {
|
||||||
|
if (err) console.error(err);
|
||||||
|
// console.log('Token stored to', TOKEN_PATH);
|
||||||
|
});
|
||||||
|
callback(oAuth2Client);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Lists the names and IDs of up to 10 files.
|
||||||
|
* @param {google.auth.OAuth2} auth An authorized OAuth2 client.
|
||||||
|
*/
|
||||||
|
function listFiles(a) {
|
||||||
|
auth = a;
|
||||||
|
// console.log('auth', auth);
|
||||||
|
const drive = google.drive({version: 'v3', auth});
|
||||||
|
drive.files.list(
|
||||||
|
{
|
||||||
|
pageSize: 10,
|
||||||
|
fields: 'nextPageToken, files(id, name, mimeType, size)'
|
||||||
|
},
|
||||||
|
(err, res) => {
|
||||||
|
if (err) return console.log('The API returned an error: ' + err);
|
||||||
|
const files = res.data.files;
|
||||||
|
if (files.length) {
|
||||||
|
console.log('Files:');
|
||||||
|
files.map(file => {
|
||||||
|
console.log(`${file.name} (${file.id})`);
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
console.log('No files found.');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
GOOGLEAPI.prototype.listGoogleDrive = function(callback) {
|
||||||
|
console.log('listGoogleDrive');
|
||||||
|
const drive = google.drive({version: 'v3', auth});
|
||||||
|
drive.files.list(
|
||||||
|
{
|
||||||
|
pageSize: 10,
|
||||||
|
fields: 'nextPageToken, files(id, name, mimeType, size)'
|
||||||
|
},
|
||||||
|
(err, res) => {
|
||||||
|
if (err) return console.log('The API returned an error: ' + err);
|
||||||
|
var files = res.data.files;
|
||||||
|
// console.log('Files:', files);
|
||||||
|
files.map(f => {
|
||||||
|
f.filename = f.name;
|
||||||
|
return f;
|
||||||
|
});
|
||||||
|
files = files.filter(f => !f.mimeType.includes('vnd.google-apps.document'))
|
||||||
|
callback(files);
|
||||||
|
}
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
GOOGLEAPI.prototype.uploadGoogleDrive = function(
|
||||||
|
file_name,
|
||||||
|
type,
|
||||||
|
file_url,
|
||||||
|
callback
|
||||||
|
) {
|
||||||
|
const drive = google.drive({version: 'v3', auth});
|
||||||
|
var fileMetadata = {
|
||||||
|
name: file_name
|
||||||
|
};
|
||||||
|
var media = {
|
||||||
|
mimeType: type,
|
||||||
|
body: fs.createReadStream(file_url)
|
||||||
|
};
|
||||||
|
console.log('uploadGoogleDrive...');
|
||||||
|
drive.files.create(
|
||||||
|
{
|
||||||
|
resource: fileMetadata,
|
||||||
|
media: media,
|
||||||
|
fields: 'id'
|
||||||
|
},
|
||||||
|
function(err, file) {
|
||||||
|
if (err) {
|
||||||
|
// Handle error
|
||||||
|
console.error('uploadGoogleDrive', err);
|
||||||
|
} else {
|
||||||
|
console.log('uploadGoogleDrive => file', file);
|
||||||
|
callback(file.data.id);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
GOOGLEAPI.prototype.downloadGoogleDrive = function(file, callback) {
|
||||||
|
console.log('downloadGoogleDrive => file', file);
|
||||||
|
let drive = google.drive({version: 'v3', auth});
|
||||||
|
let file_url = 'files\\' + file.filename;
|
||||||
|
var dest = fs.createWriteStream(file_url);
|
||||||
|
drive.files.get(
|
||||||
|
{fileId: file.id, alt: 'media'},
|
||||||
|
{responseType: 'stream'},
|
||||||
|
function(err, res) {
|
||||||
|
if (err) console.error('drive.files.get', err);
|
||||||
|
res.data
|
||||||
|
.on('end', () => {
|
||||||
|
console.log('Done');
|
||||||
|
callback(file_url);
|
||||||
|
})
|
||||||
|
.on('error', err => {
|
||||||
|
console.log('Error', err);
|
||||||
|
})
|
||||||
|
.pipe(dest);
|
||||||
|
}
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
module.exports = new GOOGLEAPI();
|
||||||
@@ -30,4 +30,27 @@ const authenticate = (req, res, next) => {
|
|||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
module.exports = {authenticate};
|
const authenticate_noerror = (req, res, next) => {
|
||||||
|
const token = req.header('x-auth');
|
||||||
|
|
||||||
|
const access = 'auth';
|
||||||
|
|
||||||
|
User.findByToken(token, access).then((user) => {
|
||||||
|
if (!user) {
|
||||||
|
req.user = null;
|
||||||
|
req.token = null;
|
||||||
|
req.access = null;
|
||||||
|
}else {
|
||||||
|
req.user = user;
|
||||||
|
req.token = token;
|
||||||
|
req.access = access;
|
||||||
|
}
|
||||||
|
next();
|
||||||
|
}).catch((e) => {
|
||||||
|
req.user = null;
|
||||||
|
req.token = null;
|
||||||
|
req.access = null;
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
module.exports = {authenticate, authenticate_noerror};
|
||||||
|
|||||||
@@ -42,7 +42,6 @@ const bookingSchema = new Schema({
|
|||||||
booked: {
|
booked: {
|
||||||
type: Boolean,
|
type: Boolean,
|
||||||
},
|
},
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
bookingSchema.statics.findAllByUserIdAndIdApp = function (userId, idapp, sall) {
|
bookingSchema.statics.findAllByUserIdAndIdApp = function (userId, idapp, sall) {
|
||||||
|
|||||||
43
server/models/contribtype.js
Normal file
43
server/models/contribtype.js
Normal file
@@ -0,0 +1,43 @@
|
|||||||
|
const mongoose = require('mongoose');
|
||||||
|
const Schema = mongoose.Schema;
|
||||||
|
|
||||||
|
const tools = require('../tools/general');
|
||||||
|
|
||||||
|
mongoose.Promise = global.Promise;
|
||||||
|
mongoose.level = "F";
|
||||||
|
|
||||||
|
|
||||||
|
// Resolving error Unknown modifier: $pushAll
|
||||||
|
mongoose.plugin(schema => {
|
||||||
|
schema.options.usePushEach = true
|
||||||
|
});
|
||||||
|
|
||||||
|
const ContribtypeSchema = new Schema({
|
||||||
|
idapp: {
|
||||||
|
type: String,
|
||||||
|
},
|
||||||
|
label: {
|
||||||
|
type: String,
|
||||||
|
},
|
||||||
|
showprice: {
|
||||||
|
type: Boolean,
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
ContribtypeSchema.statics.executeQueryTable = function (idapp, params) {
|
||||||
|
return tools.executeQueryTable(this, idapp, params);
|
||||||
|
};
|
||||||
|
|
||||||
|
ContribtypeSchema.statics.findAllIdApp = function (idapp) {
|
||||||
|
const Contribtype = this;
|
||||||
|
|
||||||
|
const myfind = { idapp };
|
||||||
|
|
||||||
|
return Contribtype.find(myfind, (err, arrrec) => {
|
||||||
|
return arrrec
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
const Contribtype = mongoose.model('Contribtype', ContribtypeSchema);
|
||||||
|
|
||||||
|
module.exports = { Contribtype };
|
||||||
@@ -50,8 +50,8 @@ const MyEventSchema = new Schema({
|
|||||||
wherecode: {
|
wherecode: {
|
||||||
type: String,
|
type: String,
|
||||||
},
|
},
|
||||||
contribtype: { // TABLE
|
contribtype: {
|
||||||
type: Number,
|
type: String,
|
||||||
},
|
},
|
||||||
price: {
|
price: {
|
||||||
type: Number,
|
type: Number,
|
||||||
@@ -59,7 +59,7 @@ const MyEventSchema = new Schema({
|
|||||||
infoafterprice: {
|
infoafterprice: {
|
||||||
type: String,
|
type: String,
|
||||||
},
|
},
|
||||||
teacher: { // TABLE ?!
|
teacher: {
|
||||||
type: String,
|
type: String,
|
||||||
},
|
},
|
||||||
teacher2: {
|
teacher2: {
|
||||||
|
|||||||
@@ -10,6 +10,7 @@ const { Booking } = require('../models/booking');
|
|||||||
const { MyEvent } = require('../models/myevent');
|
const { MyEvent } = require('../models/myevent');
|
||||||
const { Operator } = require('../models/operator');
|
const { Operator } = require('../models/operator');
|
||||||
const { Where } = require('../models/where');
|
const { Where } = require('../models/where');
|
||||||
|
const { Contribtype } = require('../models/contribtype');
|
||||||
|
|
||||||
const { ObjectID } = require('mongodb');
|
const { ObjectID } = require('mongodb');
|
||||||
|
|
||||||
@@ -97,45 +98,41 @@ router.delete('/:id/:notify/:idapp', authenticate, (req, res) => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
router.get('/:userId/:idapp/:sall', authenticate, (req, res) => {
|
// router.get('/:userId/:idapp/:sall', authenticate, (req, res) => {
|
||||||
const userId = req.params.userId;
|
// const userId = req.params.userId;
|
||||||
const idapp = req.params.idapp;
|
// const idapp = req.params.idapp;
|
||||||
const sall = req.params.sall;
|
// const sall = req.params.sall;
|
||||||
// var category = req.params.category;
|
// // var category = req.params.category;
|
||||||
|
//
|
||||||
// tools.mylog('GET BOOKINGS : ', req.params);
|
// // tools.mylog('GET BOOKINGS : ', req.params);
|
||||||
|
//
|
||||||
if (!ObjectID.isValid(userId)) {
|
// if (!ObjectID.isValid(userId)) {
|
||||||
return res.status(404).send();
|
// return res.status(404).send();
|
||||||
}
|
// }
|
||||||
|
//
|
||||||
if (userId !== String(req.user._id)) {
|
// if (userId !== String(req.user._id)) {
|
||||||
// I'm trying to write something not mine!
|
// // I'm trying to write something not mine!
|
||||||
return res.status(404).send({ code: server_constants.RIS_CODE_TODO_CREATING_NOTMYUSER });
|
// return res.status(404).send({ code: server_constants.RIS_CODE_TODO_CREATING_NOTMYUSER });
|
||||||
}
|
// }
|
||||||
|
//
|
||||||
// Extract all the todos of the userId only
|
// // Extract all the todos of the userId only
|
||||||
Booking.findAllByUserIdAndIdApp(userId, idapp, sall).then((bookedevent) => {
|
// const bookedevent = Booking.findAllByUserIdAndIdApp(userId, idapp, sall);
|
||||||
|
// const eventlist = MyEvent.findAllIdApp(idapp);
|
||||||
return MyEvent.findAllIdApp(idapp)
|
// const operators = Operator.findAllIdApp(idapp);
|
||||||
.then((eventlist) => {
|
// const wheres = Where.findAllIdApp(idapp);
|
||||||
return Operator.findAllIdApp(idapp)
|
// const contribtype = Contribtype.findAllIdApp(idapp);
|
||||||
.then((operators) => {
|
//
|
||||||
|
// return Promise.all([bookedevent, eventlist, operators, wheres, contribtype])
|
||||||
return Where.findAllIdApp(idapp)
|
// .then((arrdata) => {
|
||||||
.then((wheres) => {
|
// console.table(arrdata);
|
||||||
|
// res.send({ bookedevent: arrdata[0], eventlist: arrdata[1], operators: arrdata[2], wheres: arrdata[3], contribtype: arrdata[4] });
|
||||||
res.send({ bookedevent, eventlist, operators, wheres });
|
// })
|
||||||
})
|
// .catch((e) => {
|
||||||
})
|
// console.log(e);
|
||||||
})
|
// res.status(400).send(e);
|
||||||
|
// });
|
||||||
}).catch((e) => {
|
//
|
||||||
console.log(e);
|
// });
|
||||||
res.status(400).send(e);
|
//
|
||||||
});
|
|
||||||
|
|
||||||
});
|
|
||||||
|
|
||||||
|
|
||||||
module.exports = router;
|
module.exports = router;
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
const express = require('express');
|
const express = require('express');
|
||||||
const router = express.Router();
|
const router = express.Router();
|
||||||
|
|
||||||
const { authenticate } = require('../middleware/authenticate');
|
const { authenticate, authenticate_noerror } = require('../middleware/authenticate');
|
||||||
|
|
||||||
const { ObjectID } = require('mongodb');
|
const { ObjectID } = require('mongodb');
|
||||||
|
|
||||||
@@ -15,6 +15,7 @@ const { Booking } = require('../models/booking');
|
|||||||
const { Operator } = require('../models/operator');
|
const { Operator } = require('../models/operator');
|
||||||
const { Where } = require('../models/where');
|
const { Where } = require('../models/where');
|
||||||
const { MyEvent } = require('../models/myevent');
|
const { MyEvent } = require('../models/myevent');
|
||||||
|
const { Contribtype } = require('../models/contribtype');
|
||||||
|
|
||||||
|
|
||||||
const tools = require('../tools/general');
|
const tools = require('../tools/general');
|
||||||
@@ -59,9 +60,9 @@ router.post(process.env.LINKVERIF_REG, (req, res) => {
|
|||||||
|
|
||||||
// Faccio richiesta di una Nuova Password
|
// Faccio richiesta di una Nuova Password
|
||||||
router.post(process.env.LINK_REQUEST_NEWPASSWORD, (req, res) => {
|
router.post(process.env.LINK_REQUEST_NEWPASSWORD, (req, res) => {
|
||||||
var body = _.pick(req.body, ['idapp', 'email']);
|
const body = _.pick(req.body, ['idapp', 'email']);
|
||||||
var idapp = body.idapp;
|
const idapp = body.idapp;
|
||||||
var email = body.email;
|
const email = body.email;
|
||||||
console.log("POST " + process.env.LINK_REQUEST_NEWPASSWORD + " idapp= " + idapp + " email = " + email);
|
console.log("POST " + process.env.LINK_REQUEST_NEWPASSWORD + " idapp= " + idapp + " email = " + email);
|
||||||
|
|
||||||
User.findByEmail(idapp, email).then((user) => {
|
User.findByEmail(idapp, email).then((user) => {
|
||||||
@@ -84,6 +85,7 @@ router.post(process.env.LINK_REQUEST_NEWPASSWORD, (req, res) => {
|
|||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
router.get(process.env.LINK_CHECK_UPDATES, authenticate, (req, res) => {
|
router.get(process.env.LINK_CHECK_UPDATES, authenticate, (req, res) => {
|
||||||
const userId = req.user._id;
|
const userId = req.user._id;
|
||||||
|
|
||||||
@@ -167,6 +169,8 @@ function getTableByTableName(tablename) {
|
|||||||
mytable = Where;
|
mytable = Where;
|
||||||
else if (tablename === 'myevents')
|
else if (tablename === 'myevents')
|
||||||
mytable = MyEvent;
|
mytable = MyEvent;
|
||||||
|
else if (tablename === 'contribtype')
|
||||||
|
mytable = Contribtype;
|
||||||
|
|
||||||
return mytable
|
return mytable
|
||||||
}
|
}
|
||||||
@@ -325,5 +329,38 @@ function doOtherThingsAfterDeleted() {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
router.get('/loadsite/:userId/:idapp/:sall', authenticate_noerror, (req, res) => {
|
||||||
|
const userId = req.params.userId;
|
||||||
|
const idapp = req.params.idapp;
|
||||||
|
const sall = req.params.sall;
|
||||||
|
// var category = req.params.category;
|
||||||
|
|
||||||
|
tools.mylog('loadsite : ', req.params);
|
||||||
|
|
||||||
|
let bookedevent = [];
|
||||||
|
|
||||||
|
if (userId !== '0') {
|
||||||
|
// LOGGED WITH USERID
|
||||||
|
bookedevent = Booking.findAllByUserIdAndIdApp(userId, idapp, sall);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Extract all the todos of the userId only
|
||||||
|
const eventlist = MyEvent.findAllIdApp(idapp);
|
||||||
|
const operators = Operator.findAllIdApp(idapp);
|
||||||
|
const wheres = Where.findAllIdApp(idapp);
|
||||||
|
const contribtype = Contribtype.findAllIdApp(idapp);
|
||||||
|
|
||||||
|
return Promise.all([bookedevent, eventlist, operators, wheres, contribtype])
|
||||||
|
.then((arrdata) => {
|
||||||
|
console.table(arrdata);
|
||||||
|
res.send({ bookedevent: arrdata[0], eventlist: arrdata[1], operators: arrdata[2], wheres: arrdata[3], contribtype: arrdata[4] });
|
||||||
|
})
|
||||||
|
.catch((e) => {
|
||||||
|
console.log(e);
|
||||||
|
res.status(400).send(e);
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
module.exports = router;
|
module.exports = router;
|
||||||
|
|||||||
Reference in New Issue
Block a user