-
Notifications
You must be signed in to change notification settings - Fork 5
Expand file tree
/
Copy pathapp.js
More file actions
116 lines (99 loc) · 3.7 KB
/
app.js
File metadata and controls
116 lines (99 loc) · 3.7 KB
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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
const express = require("express");
const { ApolloServer } = require("apollo-server-express");
const { mergeTypeDefs, mergeResolvers } = require("@graphql-tools/merge");
const { config } = require("dotenv");
const cors = require("cors");
const User=require("./models/userModel.js");
const createUser=require("./utils/createUser.js");
const userResolvers = require("./resolvers/userResolvers.js");
const notesResolvers = require("./resolvers/notesResolvers.js");
const sessionResolvers = require("./resolvers/sessionResolvers.js");
const reportsResolvers = require("./resolvers/reportsResolvers.js");
const contactFormResolvers = require("./resolvers/contactFormResolvers.js");
const userTypes = require("./types/userTypes.js");
const notesTypes = require("./types/notesTypes.js");
const sessionTypes = require("./types/sessionTypes.js");
const reportsTypes = require("./types/reportsTypes.js");
const contactFormTypes = require("./types/contactTypes.js");
const mongoose = require('mongoose');
const { OAuth2Client } = require('google-auth-library');
const client = new OAuth2Client();
// Load environment variables from .env file
config();
const app = express();
// Connect to MongoDB
mongoose.connect(process.env.MONGO_URI, {
// useNewUrlParser: true,
// useUnifiedTopology: true,
})
.then(() => {
console.log('Connected to MongoDB');
})
.catch((error) => {
console.error('Error connecting to MongoDB:', error);
process.exit(1); // Exit the application if unable to connect to MongoDB
});
// Enable CORS for all routes
app.use(cors());
app.use(express.json());
app.get('/checkr',(req,res)=>{
console.log(['5','5','5','5'].map(parseInt));
return res.status(200).json({message:"true"});
})
const mergedTypeDefs = mergeTypeDefs([userTypes, notesTypes, sessionTypes, reportsTypes, contactFormTypes]);
const mergedResolvers = mergeResolvers([userResolvers, notesResolvers, sessionResolvers, reportsResolvers, contactFormResolvers]);
const server = new ApolloServer({
typeDefs: mergedTypeDefs,
resolvers: mergedResolvers,
});
async function startServer() {
await server.start();
// Middleware to log every request data
app.use((req, res, next) => {
if (req.body && req.body.query && req.body.query.includes("IntrospectionQuery")) {
console.log("Introspect query received");
} else {
// console.log(`Request received at ${new Date().toISOString()}`);
// console.log(`Path: ${req.path}`);
console.log(`Method: ${req.method}`);
console.log(`Body: ${JSON.stringify(req.body)}`);
}
next();
});
// API for Google Authentication
app.post("/google-auth", async (req, res) => {
console.log("this route of google login gets hit");
const { credential, client_id } = req.body;
try {
const ticket = await client.verifyIdToken({
idToken: credential,
audience: client_id,
});
const payload = ticket.getPayload();
const userid = payload["sub"];
console.log("getting ticket",ticket);
console.log("getting payload",payload);
console.log("getting userid",userid);
// Check if the user exists in your database
let user=await User.findOne({email:"pranavgoogle@anymail.com"});
if(!user){
const { user, token } = await createUser();
return res.status(200).json({payload,user,token,userid})
}else {
return res.status(409).json({ message:"User already exists" });
}
} catch (err) {
console.log("getting error in backedn",err);
res.status(400).json({ err });
}
});
// Apply the Apollo Server middleware to the "/graphql" path
server.applyMiddleware({ app, path: "/graphql" });
const PORT = process.env.PORT || 4000;
app.listen(PORT, () => {
console.log(
`Server running at http://localhost:${PORT}${server.graphqlPath}`
);
});
}
startServer();