106 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			106 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
const express = require("express");
 | 
						|
const app = express();
 | 
						|
const server = require("http").Server(app);
 | 
						|
const io = require("socket.io")(server);
 | 
						|
const path = require("path");
 | 
						|
const session = require("express-session");
 | 
						|
const User = require(path.join(__dirname + "/schemas/User"));
 | 
						|
 | 
						|
const apiRouter = require(path.join(__dirname + "/api/router.js"));
 | 
						|
 | 
						|
const loginApi = require(path.join(__dirname + "/api/login"));
 | 
						|
const subscriptionApi = require(path.join(__dirname + "/api/subscriptions"));
 | 
						|
 | 
						|
//This is required for the chat to work
 | 
						|
const chat = require(path.join(__dirname + "/api/chat"))(io);
 | 
						|
const chatHistory = require(path.join(__dirname + "/api/chatHistory"));
 | 
						|
 | 
						|
const bodyParser = require("body-parser");
 | 
						|
 | 
						|
const mongoose = require("mongoose");
 | 
						|
const MongoStore = require("connect-mongo")(session);
 | 
						|
const cors = require("cors");
 | 
						|
 | 
						|
const referrerPolicy = require("referrer-policy");
 | 
						|
const helmet = require("helmet");
 | 
						|
const featurePolicy = require("feature-policy");
 | 
						|
 | 
						|
const compression = require("compression");
 | 
						|
app.use(compression());
 | 
						|
 | 
						|
app.use(
 | 
						|
  featurePolicy({
 | 
						|
    features: {
 | 
						|
      fullscreen: ["*"],
 | 
						|
      //vibrate: ["'none'"],
 | 
						|
      payment: ["'none'"],
 | 
						|
      microphone: ["'none'"],
 | 
						|
      camera: ["'self'"],
 | 
						|
      speaker: ["*"],
 | 
						|
      syncXhr: ["'self'"]
 | 
						|
      //notifications: ["'self'"]
 | 
						|
    }
 | 
						|
  })
 | 
						|
);
 | 
						|
app.use(helmet());
 | 
						|
app.use(helmet.frameguard({ action: "sameorigin" }));
 | 
						|
app.use(referrerPolicy({ policy: "origin" }));
 | 
						|
 | 
						|
app.use(cors());
 | 
						|
mongoose.promise = global.Promise;
 | 
						|
mongoose.connect("mongodb://localhost/vinlottis");
 | 
						|
mongoose.set("debug", true);
 | 
						|
 | 
						|
app.use(
 | 
						|
  bodyParser.urlencoded({
 | 
						|
    extended: true
 | 
						|
  })
 | 
						|
);
 | 
						|
app.use(bodyParser.json());
 | 
						|
 | 
						|
app.use(
 | 
						|
  session({
 | 
						|
    secret: "passport-tutorial",
 | 
						|
    cookie: { maxAge: 86400 * 24 * 24 },
 | 
						|
    resave: false,
 | 
						|
    saveUninitialized: false,
 | 
						|
    store: new MongoStore({
 | 
						|
      mongooseConnection: mongoose.connection
 | 
						|
    })
 | 
						|
  })
 | 
						|
);
 | 
						|
 | 
						|
app.set('socketio', io);
 | 
						|
 | 
						|
const passport = require("passport");
 | 
						|
const LocalStrategy = require("passport-local");
 | 
						|
 | 
						|
app.use(passport.initialize());
 | 
						|
app.use(passport.session());
 | 
						|
// use static authenticate method of model in LocalStrategy
 | 
						|
passport.use(new LocalStrategy(User.authenticate()));
 | 
						|
 | 
						|
// use static serialize and deserialize of model for passport session support
 | 
						|
passport.serializeUser(User.serializeUser());
 | 
						|
passport.deserializeUser(User.deserializeUser());
 | 
						|
 | 
						|
app.use("/public", express.static(path.join(__dirname, "public")));
 | 
						|
app.use("/dist", express.static(path.join(__dirname, "public/dist")));
 | 
						|
app.use("/", loginApi);
 | 
						|
app.use("/api/", chatHistory);
 | 
						|
app.use("/api/", apiRouter);
 | 
						|
app.use("/subscription", subscriptionApi);
 | 
						|
 | 
						|
app.get("/dagens", function(req, res) {
 | 
						|
  res.redirect("/#/dagens");
 | 
						|
});
 | 
						|
app.get("/winner/:id", function(req, res) {
 | 
						|
  res.redirect("/#/winner/" + req.params.id);
 | 
						|
});
 | 
						|
 | 
						|
app.use("/service-worker.js", function(req, res) {
 | 
						|
  res.sendFile(path.join(__dirname, "public/sw/serviceWorker.js"));
 | 
						|
});
 | 
						|
 | 
						|
server.listen(30030);
 |