├── .DS_Store ├── .gitignore ├── app.js ├── bin └── www ├── package-lock.json ├── package.json ├── public ├── .DS_Store ├── images │ ├── .DS_Store │ ├── image.png │ ├── logo.png │ └── uploads │ │ └── .DS_Store └── stylesheets │ └── style.css ├── readme.md ├── routes ├── index.js ├── multer.js ├── posts.js ├── story.js └── users.js ├── utils └── utils.js └── views ├── edit.ejs ├── error.ejs ├── feed.ejs ├── index.ejs ├── login.ejs ├── partials ├── footer.ejs └── header.ejs ├── profile.ejs ├── search.ejs ├── upload.ejs └── userprofile.ejs /.DS_Store: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/asynchronousJavascriptor/instaclone/920173667d39b42221dfbc256fe2b1e87fc58ca2/.DS_Store -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules -------------------------------------------------------------------------------- /app.js: -------------------------------------------------------------------------------- 1 | var createError = require('http-errors'); 2 | var express = require('express'); 3 | var path = require('path'); 4 | var cookieParser = require('cookie-parser'); 5 | var logger = require('morgan'); 6 | var expressSession = require('express-session'); 7 | 8 | var indexRouter = require('./routes/index'); 9 | var usersRouter = require('./routes/users'); 10 | const passport = require('passport'); 11 | 12 | var app = express(); 13 | 14 | // view engine setup 15 | app.set('views', path.join(__dirname, 'views')); 16 | app.set('view engine', 'ejs'); 17 | 18 | app.use(expressSession({ 19 | resave: false, 20 | saveUninitialized: false, 21 | secret: "heyheyehhdd" 22 | })); 23 | app.use(passport.initialize()); 24 | app.use(passport.session()); 25 | passport.serializeUser(usersRouter.serializeUser()); 26 | passport.deserializeUser(usersRouter.deserializeUser()); 27 | 28 | app.use(logger('dev')); 29 | app.use(express.json()); 30 | app.use(express.urlencoded({ extended: false })); 31 | app.use(cookieParser()); 32 | app.use(express.static(path.join(__dirname, 'public'))); 33 | 34 | app.use('/', indexRouter); 35 | app.use('/users', usersRouter); 36 | 37 | // catch 404 and forward to error handler 38 | app.use(function(req, res, next) { 39 | next(createError(404)); 40 | }); 41 | 42 | // error handler 43 | app.use(function(err, req, res, next) { 44 | // set locals, only providing error in development 45 | res.locals.message = err.message; 46 | res.locals.error = req.app.get('env') === 'development' ? err : {}; 47 | 48 | // render the error page 49 | res.status(err.status || 500); 50 | res.render('error'); 51 | }); 52 | 53 | module.exports = app; 54 | -------------------------------------------------------------------------------- /bin/www: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env node 2 | 3 | /** 4 | * Module dependencies. 5 | */ 6 | 7 | var app = require('../app'); 8 | var debug = require('debug')('insta:server'); 9 | var http = require('http'); 10 | 11 | /** 12 | * Get port from environment and store in Express. 13 | */ 14 | 15 | var port = normalizePort(process.env.PORT || '3000'); 16 | app.set('port', port); 17 | 18 | /** 19 | * Create HTTP server. 20 | */ 21 | 22 | var server = http.createServer(app); 23 | 24 | /** 25 | * Listen on provided port, on all network interfaces. 26 | */ 27 | 28 | server.listen(port); 29 | server.on('error', onError); 30 | server.on('listening', onListening); 31 | 32 | /** 33 | * Normalize a port into a number, string, or false. 34 | */ 35 | 36 | function normalizePort(val) { 37 | var port = parseInt(val, 10); 38 | 39 | if (isNaN(port)) { 40 | // named pipe 41 | return val; 42 | } 43 | 44 | if (port >= 0) { 45 | // port number 46 | return port; 47 | } 48 | 49 | return false; 50 | } 51 | 52 | /** 53 | * Event listener for HTTP server "error" event. 54 | */ 55 | 56 | function onError(error) { 57 | if (error.syscall !== 'listen') { 58 | throw error; 59 | } 60 | 61 | var bind = typeof port === 'string' 62 | ? 'Pipe ' + port 63 | : 'Port ' + port; 64 | 65 | // handle specific listen errors with friendly messages 66 | switch (error.code) { 67 | case 'EACCES': 68 | console.error(bind + ' requires elevated privileges'); 69 | process.exit(1); 70 | break; 71 | case 'EADDRINUSE': 72 | console.error(bind + ' is already in use'); 73 | process.exit(1); 74 | break; 75 | default: 76 | throw error; 77 | } 78 | } 79 | 80 | /** 81 | * Event listener for HTTP server "listening" event. 82 | */ 83 | 84 | function onListening() { 85 | var addr = server.address(); 86 | var bind = typeof addr === 'string' 87 | ? 'pipe ' + addr 88 | : 'port ' + addr.port; 89 | debug('Listening on ' + bind); 90 | } 91 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "insta", 3 | "version": "0.0.0", 4 | "lockfileVersion": 3, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "insta", 9 | "version": "0.0.0", 10 | "dependencies": { 11 | "cookie-parser": "~1.4.4", 12 | "debug": "~2.6.9", 13 | "ejs": "~2.6.1", 14 | "express": "~4.16.1", 15 | "express-session": "^1.17.3", 16 | "http-errors": "~1.6.3", 17 | "mongoose": "^8.0.4", 18 | "morgan": "~1.9.1", 19 | "multer": "^1.4.5-lts.1", 20 | "passport": "^0.7.0", 21 | "passport-local": "^1.0.0", 22 | "passport-local-mongoose": "^8.0.0" 23 | } 24 | }, 25 | "node_modules/@mongodb-js/saslprep": { 26 | "version": "1.1.4", 27 | "resolved": "https://registry.npmjs.org/@mongodb-js/saslprep/-/saslprep-1.1.4.tgz", 28 | "integrity": "sha512-8zJ8N1x51xo9hwPh6AWnKdLGEC5N3lDa6kms1YHmFBoRhTpJR6HG8wWk0td1MVCu9cD4YBrvjZEtd5Obw0Fbnw==", 29 | "dependencies": { 30 | "sparse-bitfield": "^3.0.3" 31 | } 32 | }, 33 | "node_modules/@types/node": { 34 | "version": "20.11.4", 35 | "resolved": "https://registry.npmjs.org/@types/node/-/node-20.11.4.tgz", 36 | "integrity": "sha512-6I0fMH8Aoy2lOejL3s4LhyIYX34DPwY8bl5xlNjBvUEk8OHrcuzsFt+Ied4LvJihbtXPM+8zUqdydfIti86v9g==", 37 | "dependencies": { 38 | "undici-types": "~5.26.4" 39 | } 40 | }, 41 | "node_modules/@types/webidl-conversions": { 42 | "version": "7.0.3", 43 | "resolved": "https://registry.npmjs.org/@types/webidl-conversions/-/webidl-conversions-7.0.3.tgz", 44 | "integrity": "sha512-CiJJvcRtIgzadHCYXw7dqEnMNRjhGZlYK05Mj9OyktqV8uVT8fD2BFOB7S1uwBE3Kj2Z+4UyPmFw/Ixgw/LAlA==" 45 | }, 46 | "node_modules/@types/whatwg-url": { 47 | "version": "8.2.2", 48 | "resolved": "https://registry.npmjs.org/@types/whatwg-url/-/whatwg-url-8.2.2.tgz", 49 | "integrity": "sha512-FtQu10RWgn3D9U4aazdwIE2yzphmTJREDqNdODHrbrZmmMqI0vMheC/6NE/J1Yveaj8H+ela+YwWTjq5PGmuhA==", 50 | "dependencies": { 51 | "@types/node": "*", 52 | "@types/webidl-conversions": "*" 53 | } 54 | }, 55 | "node_modules/accepts": { 56 | "version": "1.3.8", 57 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.8.tgz", 58 | "integrity": "sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==", 59 | "dependencies": { 60 | "mime-types": "~2.1.34", 61 | "negotiator": "0.6.3" 62 | }, 63 | "engines": { 64 | "node": ">= 0.6" 65 | } 66 | }, 67 | "node_modules/append-field": { 68 | "version": "1.0.0", 69 | "resolved": "https://registry.npmjs.org/append-field/-/append-field-1.0.0.tgz", 70 | "integrity": "sha512-klpgFSWLW1ZEs8svjfb7g4qWY0YS5imI82dTg+QahUvJ8YqAY0P10Uk8tTyh9ZGuYEZEMaeJYCF5BFuX552hsw==" 71 | }, 72 | "node_modules/array-flatten": { 73 | "version": "1.1.1", 74 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 75 | "integrity": "sha512-PCVAQswWemu6UdxsDFFX/+gVeYqKAod3D3UVm91jHwynguOwAvYPhx8nNlM++NqRcK6CxxpUafjmhIdKiHibqg==" 76 | }, 77 | "node_modules/basic-auth": { 78 | "version": "2.0.1", 79 | "resolved": "https://registry.npmjs.org/basic-auth/-/basic-auth-2.0.1.tgz", 80 | "integrity": "sha512-NF+epuEdnUYVlGuhaxbbq+dvJttwLnGY+YixlXlME5KpQ5W3CnXA5cVTneY3SPbPDRkcjMbifrwmFYcClgOZeg==", 81 | "dependencies": { 82 | "safe-buffer": "5.1.2" 83 | }, 84 | "engines": { 85 | "node": ">= 0.8" 86 | } 87 | }, 88 | "node_modules/body-parser": { 89 | "version": "1.18.3", 90 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.18.3.tgz", 91 | "integrity": "sha512-YQyoqQG3sO8iCmf8+hyVpgHHOv0/hCEFiS4zTGUwTA1HjAFX66wRcNQrVCeJq9pgESMRvUAOvSil5MJlmccuKQ==", 92 | "dependencies": { 93 | "bytes": "3.0.0", 94 | "content-type": "~1.0.4", 95 | "debug": "2.6.9", 96 | "depd": "~1.1.2", 97 | "http-errors": "~1.6.3", 98 | "iconv-lite": "0.4.23", 99 | "on-finished": "~2.3.0", 100 | "qs": "6.5.2", 101 | "raw-body": "2.3.3", 102 | "type-is": "~1.6.16" 103 | }, 104 | "engines": { 105 | "node": ">= 0.8" 106 | } 107 | }, 108 | "node_modules/bson": { 109 | "version": "6.2.0", 110 | "resolved": "https://registry.npmjs.org/bson/-/bson-6.2.0.tgz", 111 | "integrity": "sha512-ID1cI+7bazPDyL9wYy9GaQ8gEEohWvcUl/Yf0dIdutJxnmInEEyCsb4awy/OiBfall7zBA179Pahi3vCdFze3Q==", 112 | "engines": { 113 | "node": ">=16.20.1" 114 | } 115 | }, 116 | "node_modules/buffer-from": { 117 | "version": "1.1.2", 118 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", 119 | "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==" 120 | }, 121 | "node_modules/busboy": { 122 | "version": "1.6.0", 123 | "resolved": "https://registry.npmjs.org/busboy/-/busboy-1.6.0.tgz", 124 | "integrity": "sha512-8SFQbg/0hQ9xy3UNTB0YEnsNBbWfhf7RtnzpL7TkBiTBRfrQ9Fxcnz7VJsleJpyp6rVLvXiuORqjlHi5q+PYuA==", 125 | "dependencies": { 126 | "streamsearch": "^1.1.0" 127 | }, 128 | "engines": { 129 | "node": ">=10.16.0" 130 | } 131 | }, 132 | "node_modules/bytes": { 133 | "version": "3.0.0", 134 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.0.0.tgz", 135 | "integrity": "sha512-pMhOfFDPiv9t5jjIXkHosWmkSyQbvsgEVNkz0ERHbuLh2T/7j4Mqqpz523Fe8MVY89KC6Sh/QfS2sM+SjgFDcw==", 136 | "engines": { 137 | "node": ">= 0.8" 138 | } 139 | }, 140 | "node_modules/concat-stream": { 141 | "version": "1.6.2", 142 | "resolved": "https://registry.npmjs.org/concat-stream/-/concat-stream-1.6.2.tgz", 143 | "integrity": "sha512-27HBghJxjiZtIk3Ycvn/4kbJk/1uZuJFfuPEns6LaEvpvG1f0hTea8lilrouyo9mVc2GWdcEZ8OLoGmSADlrCw==", 144 | "engines": [ 145 | "node >= 0.8" 146 | ], 147 | "dependencies": { 148 | "buffer-from": "^1.0.0", 149 | "inherits": "^2.0.3", 150 | "readable-stream": "^2.2.2", 151 | "typedarray": "^0.0.6" 152 | } 153 | }, 154 | "node_modules/content-disposition": { 155 | "version": "0.5.2", 156 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.2.tgz", 157 | "integrity": "sha512-kRGRZw3bLlFISDBgwTSA1TMBFN6J6GWDeubmDE3AF+3+yXL8hTWv8r5rkLbqYXY4RjPk/EzHnClI3zQf1cFmHA==", 158 | "engines": { 159 | "node": ">= 0.6" 160 | } 161 | }, 162 | "node_modules/content-type": { 163 | "version": "1.0.5", 164 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.5.tgz", 165 | "integrity": "sha512-nTjqfcBFEipKdXCv4YDQWCfmcLZKm81ldF0pAopTvyrFGVbcR6P/VAAd5G7N+0tTr8QqiU0tFadD6FK4NtJwOA==", 166 | "engines": { 167 | "node": ">= 0.6" 168 | } 169 | }, 170 | "node_modules/cookie": { 171 | "version": "0.4.1", 172 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.1.tgz", 173 | "integrity": "sha512-ZwrFkGJxUR3EIoXtO+yVE69Eb7KlixbaeAWfBQB9vVsNn/o+Yw69gBWSSDK825hQNdN+wF8zELf3dFNl/kxkUA==", 174 | "engines": { 175 | "node": ">= 0.6" 176 | } 177 | }, 178 | "node_modules/cookie-parser": { 179 | "version": "1.4.6", 180 | "resolved": "https://registry.npmjs.org/cookie-parser/-/cookie-parser-1.4.6.tgz", 181 | "integrity": "sha512-z3IzaNjdwUC2olLIB5/ITd0/setiaFMLYiZJle7xg5Fe9KWAceil7xszYfHHBtDFYLSgJduS2Ty0P1uJdPDJeA==", 182 | "dependencies": { 183 | "cookie": "0.4.1", 184 | "cookie-signature": "1.0.6" 185 | }, 186 | "engines": { 187 | "node": ">= 0.8.0" 188 | } 189 | }, 190 | "node_modules/cookie-signature": { 191 | "version": "1.0.6", 192 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 193 | "integrity": "sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ==" 194 | }, 195 | "node_modules/core-util-is": { 196 | "version": "1.0.3", 197 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.3.tgz", 198 | "integrity": "sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ==" 199 | }, 200 | "node_modules/debug": { 201 | "version": "2.6.9", 202 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 203 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 204 | "dependencies": { 205 | "ms": "2.0.0" 206 | } 207 | }, 208 | "node_modules/depd": { 209 | "version": "1.1.2", 210 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", 211 | "integrity": "sha512-7emPTl6Dpo6JRXOXjLRxck+FlLRX5847cLKEn00PLAgc3g2hTZZgr+e4c2v6QpSmLeFP3n5yUo7ft6avBK/5jQ==", 212 | "engines": { 213 | "node": ">= 0.6" 214 | } 215 | }, 216 | "node_modules/destroy": { 217 | "version": "1.0.4", 218 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz", 219 | "integrity": "sha512-3NdhDuEXnfun/z7x9GOElY49LoqVHoGScmOKwmxhsS8N5Y+Z8KyPPDnaSzqWgYt/ji4mqwfTS34Htrk0zPIXVg==" 220 | }, 221 | "node_modules/ee-first": { 222 | "version": "1.1.1", 223 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 224 | "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==" 225 | }, 226 | "node_modules/ejs": { 227 | "version": "2.6.2", 228 | "resolved": "https://registry.npmjs.org/ejs/-/ejs-2.6.2.tgz", 229 | "integrity": "sha512-PcW2a0tyTuPHz3tWyYqtK6r1fZ3gp+3Sop8Ph+ZYN81Ob5rwmbHEzaqs10N3BEsaGTkh/ooniXK+WwszGlc2+Q==", 230 | "engines": { 231 | "node": ">=0.10.0" 232 | } 233 | }, 234 | "node_modules/encodeurl": { 235 | "version": "1.0.2", 236 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 237 | "integrity": "sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w==", 238 | "engines": { 239 | "node": ">= 0.8" 240 | } 241 | }, 242 | "node_modules/escape-html": { 243 | "version": "1.0.3", 244 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 245 | "integrity": "sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow==" 246 | }, 247 | "node_modules/etag": { 248 | "version": "1.8.1", 249 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 250 | "integrity": "sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg==", 251 | "engines": { 252 | "node": ">= 0.6" 253 | } 254 | }, 255 | "node_modules/express": { 256 | "version": "4.16.4", 257 | "resolved": "https://registry.npmjs.org/express/-/express-4.16.4.tgz", 258 | "integrity": "sha512-j12Uuyb4FMrd/qQAm6uCHAkPtO8FDTRJZBDd5D2KOL2eLaz1yUNdUB/NOIyq0iU4q4cFarsUCrnFDPBcnksuOg==", 259 | "dependencies": { 260 | "accepts": "~1.3.5", 261 | "array-flatten": "1.1.1", 262 | "body-parser": "1.18.3", 263 | "content-disposition": "0.5.2", 264 | "content-type": "~1.0.4", 265 | "cookie": "0.3.1", 266 | "cookie-signature": "1.0.6", 267 | "debug": "2.6.9", 268 | "depd": "~1.1.2", 269 | "encodeurl": "~1.0.2", 270 | "escape-html": "~1.0.3", 271 | "etag": "~1.8.1", 272 | "finalhandler": "1.1.1", 273 | "fresh": "0.5.2", 274 | "merge-descriptors": "1.0.1", 275 | "methods": "~1.1.2", 276 | "on-finished": "~2.3.0", 277 | "parseurl": "~1.3.2", 278 | "path-to-regexp": "0.1.7", 279 | "proxy-addr": "~2.0.4", 280 | "qs": "6.5.2", 281 | "range-parser": "~1.2.0", 282 | "safe-buffer": "5.1.2", 283 | "send": "0.16.2", 284 | "serve-static": "1.13.2", 285 | "setprototypeof": "1.1.0", 286 | "statuses": "~1.4.0", 287 | "type-is": "~1.6.16", 288 | "utils-merge": "1.0.1", 289 | "vary": "~1.1.2" 290 | }, 291 | "engines": { 292 | "node": ">= 0.10.0" 293 | } 294 | }, 295 | "node_modules/express-session": { 296 | "version": "1.17.3", 297 | "resolved": "https://registry.npmjs.org/express-session/-/express-session-1.17.3.tgz", 298 | "integrity": "sha512-4+otWXlShYlG1Ma+2Jnn+xgKUZTMJ5QD3YvfilX3AcocOAbIkVylSWEklzALe/+Pu4qV6TYBj5GwOBFfdKqLBw==", 299 | "dependencies": { 300 | "cookie": "0.4.2", 301 | "cookie-signature": "1.0.6", 302 | "debug": "2.6.9", 303 | "depd": "~2.0.0", 304 | "on-headers": "~1.0.2", 305 | "parseurl": "~1.3.3", 306 | "safe-buffer": "5.2.1", 307 | "uid-safe": "~2.1.5" 308 | }, 309 | "engines": { 310 | "node": ">= 0.8.0" 311 | } 312 | }, 313 | "node_modules/express-session/node_modules/cookie": { 314 | "version": "0.4.2", 315 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.2.tgz", 316 | "integrity": "sha512-aSWTXFzaKWkvHO1Ny/s+ePFpvKsPnjc551iI41v3ny/ow6tBG5Vd+FuqGNhh1LxOmVzOlGUriIlOaokOvhaStA==", 317 | "engines": { 318 | "node": ">= 0.6" 319 | } 320 | }, 321 | "node_modules/express-session/node_modules/depd": { 322 | "version": "2.0.0", 323 | "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", 324 | "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==", 325 | "engines": { 326 | "node": ">= 0.8" 327 | } 328 | }, 329 | "node_modules/express-session/node_modules/safe-buffer": { 330 | "version": "5.2.1", 331 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", 332 | "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", 333 | "funding": [ 334 | { 335 | "type": "github", 336 | "url": "https://github.com/sponsors/feross" 337 | }, 338 | { 339 | "type": "patreon", 340 | "url": "https://www.patreon.com/feross" 341 | }, 342 | { 343 | "type": "consulting", 344 | "url": "https://feross.org/support" 345 | } 346 | ] 347 | }, 348 | "node_modules/express/node_modules/cookie": { 349 | "version": "0.3.1", 350 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.3.1.tgz", 351 | "integrity": "sha512-+IJOX0OqlHCszo2mBUq+SrEbCj6w7Kpffqx60zYbPTFaO4+yYgRjHwcZNpWvaTylDHaV7PPmBHzSecZiMhtPgw==", 352 | "engines": { 353 | "node": ">= 0.6" 354 | } 355 | }, 356 | "node_modules/finalhandler": { 357 | "version": "1.1.1", 358 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.1.tgz", 359 | "integrity": "sha512-Y1GUDo39ez4aHAw7MysnUD5JzYX+WaIj8I57kO3aEPT1fFRL4sr7mjei97FgnwhAyyzRYmQZaTHb2+9uZ1dPtg==", 360 | "dependencies": { 361 | "debug": "2.6.9", 362 | "encodeurl": "~1.0.2", 363 | "escape-html": "~1.0.3", 364 | "on-finished": "~2.3.0", 365 | "parseurl": "~1.3.2", 366 | "statuses": "~1.4.0", 367 | "unpipe": "~1.0.0" 368 | }, 369 | "engines": { 370 | "node": ">= 0.8" 371 | } 372 | }, 373 | "node_modules/forwarded": { 374 | "version": "0.2.0", 375 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz", 376 | "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==", 377 | "engines": { 378 | "node": ">= 0.6" 379 | } 380 | }, 381 | "node_modules/fresh": { 382 | "version": "0.5.2", 383 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 384 | "integrity": "sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q==", 385 | "engines": { 386 | "node": ">= 0.6" 387 | } 388 | }, 389 | "node_modules/generaterr": { 390 | "version": "1.5.0", 391 | "resolved": "https://registry.npmjs.org/generaterr/-/generaterr-1.5.0.tgz", 392 | "integrity": "sha512-JgcGRv2yUKeboLvvNrq9Bm90P4iJBu7/vd5wSLYqMG5GJ6SxZT46LAAkMfNhQ+EK3jzC+cRBm7P8aUWYyphgcQ==" 393 | }, 394 | "node_modules/http-errors": { 395 | "version": "1.6.3", 396 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.6.3.tgz", 397 | "integrity": "sha512-lks+lVC8dgGyh97jxvxeYTWQFvh4uw4yC12gVl63Cg30sjPX4wuGcdkICVXDAESr6OJGjqGA8Iz5mkeN6zlD7A==", 398 | "dependencies": { 399 | "depd": "~1.1.2", 400 | "inherits": "2.0.3", 401 | "setprototypeof": "1.1.0", 402 | "statuses": ">= 1.4.0 < 2" 403 | }, 404 | "engines": { 405 | "node": ">= 0.6" 406 | } 407 | }, 408 | "node_modules/iconv-lite": { 409 | "version": "0.4.23", 410 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.23.tgz", 411 | "integrity": "sha512-neyTUVFtahjf0mB3dZT77u+8O0QB89jFdnBkd5P1JgYPbPaia3gXXOVL2fq8VyU2gMMD7SaN7QukTB/pmXYvDA==", 412 | "dependencies": { 413 | "safer-buffer": ">= 2.1.2 < 3" 414 | }, 415 | "engines": { 416 | "node": ">=0.10.0" 417 | } 418 | }, 419 | "node_modules/inherits": { 420 | "version": "2.0.3", 421 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 422 | "integrity": "sha512-x00IRNXNy63jwGkJmzPigoySHbaqpNuzKbBOmzK+g2OdZpQ9w+sxCN+VSB3ja7IAge2OP2qpfxTjeNcyjmW1uw==" 423 | }, 424 | "node_modules/ipaddr.js": { 425 | "version": "1.9.1", 426 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", 427 | "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==", 428 | "engines": { 429 | "node": ">= 0.10" 430 | } 431 | }, 432 | "node_modules/isarray": { 433 | "version": "1.0.0", 434 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 435 | "integrity": "sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ==" 436 | }, 437 | "node_modules/kareem": { 438 | "version": "2.5.1", 439 | "resolved": "https://registry.npmjs.org/kareem/-/kareem-2.5.1.tgz", 440 | "integrity": "sha512-7jFxRVm+jD+rkq3kY0iZDJfsO2/t4BBPeEb2qKn2lR/9KhuksYk5hxzfRYWMPV8P/x2d0kHD306YyWLzjjH+uA==", 441 | "engines": { 442 | "node": ">=12.0.0" 443 | } 444 | }, 445 | "node_modules/media-typer": { 446 | "version": "0.3.0", 447 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 448 | "integrity": "sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ==", 449 | "engines": { 450 | "node": ">= 0.6" 451 | } 452 | }, 453 | "node_modules/memory-pager": { 454 | "version": "1.5.0", 455 | "resolved": "https://registry.npmjs.org/memory-pager/-/memory-pager-1.5.0.tgz", 456 | "integrity": "sha512-ZS4Bp4r/Zoeq6+NLJpP+0Zzm0pR8whtGPf1XExKLJBAczGMnSi3It14OiNCStjQjM6NU1okjQGSxgEZN8eBYKg==" 457 | }, 458 | "node_modules/merge-descriptors": { 459 | "version": "1.0.1", 460 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 461 | "integrity": "sha512-cCi6g3/Zr1iqQi6ySbseM1Xvooa98N0w31jzUYrXPX2xqObmFGHJ0tQ5u74H3mVh7wLouTseZyYIq39g8cNp1w==" 462 | }, 463 | "node_modules/methods": { 464 | "version": "1.1.2", 465 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 466 | "integrity": "sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w==", 467 | "engines": { 468 | "node": ">= 0.6" 469 | } 470 | }, 471 | "node_modules/mime": { 472 | "version": "1.4.1", 473 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.4.1.tgz", 474 | "integrity": "sha512-KI1+qOZu5DcW6wayYHSzR/tXKCDC5Om4s1z2QJjDULzLcmf3DvzS7oluY4HCTrc+9FiKmWUgeNLg7W3uIQvxtQ==", 475 | "bin": { 476 | "mime": "cli.js" 477 | } 478 | }, 479 | "node_modules/mime-db": { 480 | "version": "1.52.0", 481 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", 482 | "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", 483 | "engines": { 484 | "node": ">= 0.6" 485 | } 486 | }, 487 | "node_modules/mime-types": { 488 | "version": "2.1.35", 489 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", 490 | "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", 491 | "dependencies": { 492 | "mime-db": "1.52.0" 493 | }, 494 | "engines": { 495 | "node": ">= 0.6" 496 | } 497 | }, 498 | "node_modules/minimist": { 499 | "version": "1.2.8", 500 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.8.tgz", 501 | "integrity": "sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA==", 502 | "funding": { 503 | "url": "https://github.com/sponsors/ljharb" 504 | } 505 | }, 506 | "node_modules/mkdirp": { 507 | "version": "0.5.6", 508 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.6.tgz", 509 | "integrity": "sha512-FP+p8RB8OWpF3YZBCrP5gtADmtXApB5AMLn+vdyA+PyxCjrCs00mjyUozssO33cwDeT3wNGdLxJ5M//YqtHAJw==", 510 | "dependencies": { 511 | "minimist": "^1.2.6" 512 | }, 513 | "bin": { 514 | "mkdirp": "bin/cmd.js" 515 | } 516 | }, 517 | "node_modules/mongodb": { 518 | "version": "6.2.0", 519 | "resolved": "https://registry.npmjs.org/mongodb/-/mongodb-6.2.0.tgz", 520 | "integrity": "sha512-d7OSuGjGWDZ5usZPqfvb36laQ9CPhnWkAGHT61x5P95p/8nMVeH8asloMwW6GcYFeB0Vj4CB/1wOTDG2RA9BFA==", 521 | "dependencies": { 522 | "@mongodb-js/saslprep": "^1.1.0", 523 | "bson": "^6.2.0", 524 | "mongodb-connection-string-url": "^2.6.0" 525 | }, 526 | "engines": { 527 | "node": ">=16.20.1" 528 | }, 529 | "peerDependencies": { 530 | "@aws-sdk/credential-providers": "^3.188.0", 531 | "@mongodb-js/zstd": "^1.1.0", 532 | "gcp-metadata": "^5.2.0", 533 | "kerberos": "^2.0.1", 534 | "mongodb-client-encryption": ">=6.0.0 <7", 535 | "snappy": "^7.2.2", 536 | "socks": "^2.7.1" 537 | }, 538 | "peerDependenciesMeta": { 539 | "@aws-sdk/credential-providers": { 540 | "optional": true 541 | }, 542 | "@mongodb-js/zstd": { 543 | "optional": true 544 | }, 545 | "gcp-metadata": { 546 | "optional": true 547 | }, 548 | "kerberos": { 549 | "optional": true 550 | }, 551 | "mongodb-client-encryption": { 552 | "optional": true 553 | }, 554 | "snappy": { 555 | "optional": true 556 | }, 557 | "socks": { 558 | "optional": true 559 | } 560 | } 561 | }, 562 | "node_modules/mongodb-connection-string-url": { 563 | "version": "2.6.0", 564 | "resolved": "https://registry.npmjs.org/mongodb-connection-string-url/-/mongodb-connection-string-url-2.6.0.tgz", 565 | "integrity": "sha512-WvTZlI9ab0QYtTYnuMLgobULWhokRjtC7db9LtcVfJ+Hsnyr5eo6ZtNAt3Ly24XZScGMelOcGtm7lSn0332tPQ==", 566 | "dependencies": { 567 | "@types/whatwg-url": "^8.2.1", 568 | "whatwg-url": "^11.0.0" 569 | } 570 | }, 571 | "node_modules/mongoose": { 572 | "version": "8.0.4", 573 | "resolved": "https://registry.npmjs.org/mongoose/-/mongoose-8.0.4.tgz", 574 | "integrity": "sha512-wN9qvdevX3+922VnLT7CpaZRT3jmVCBOK2QMHMGeScQxDRnFMPpkuI9StEPpZo/3x8t+kbzH7F8RMPsyNwyM4w==", 575 | "dependencies": { 576 | "bson": "^6.2.0", 577 | "kareem": "2.5.1", 578 | "mongodb": "6.2.0", 579 | "mpath": "0.9.0", 580 | "mquery": "5.0.0", 581 | "ms": "2.1.3", 582 | "sift": "16.0.1" 583 | }, 584 | "engines": { 585 | "node": ">=16.20.1" 586 | }, 587 | "funding": { 588 | "type": "opencollective", 589 | "url": "https://opencollective.com/mongoose" 590 | } 591 | }, 592 | "node_modules/mongoose/node_modules/ms": { 593 | "version": "2.1.3", 594 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", 595 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" 596 | }, 597 | "node_modules/morgan": { 598 | "version": "1.9.1", 599 | "resolved": "https://registry.npmjs.org/morgan/-/morgan-1.9.1.tgz", 600 | "integrity": "sha512-HQStPIV4y3afTiCYVxirakhlCfGkI161c76kKFca7Fk1JusM//Qeo1ej2XaMniiNeaZklMVrh3vTtIzpzwbpmA==", 601 | "dependencies": { 602 | "basic-auth": "~2.0.0", 603 | "debug": "2.6.9", 604 | "depd": "~1.1.2", 605 | "on-finished": "~2.3.0", 606 | "on-headers": "~1.0.1" 607 | }, 608 | "engines": { 609 | "node": ">= 0.8.0" 610 | } 611 | }, 612 | "node_modules/mpath": { 613 | "version": "0.9.0", 614 | "resolved": "https://registry.npmjs.org/mpath/-/mpath-0.9.0.tgz", 615 | "integrity": "sha512-ikJRQTk8hw5DEoFVxHG1Gn9T/xcjtdnOKIU1JTmGjZZlg9LST2mBLmcX3/ICIbgJydT2GOc15RnNy5mHmzfSew==", 616 | "engines": { 617 | "node": ">=4.0.0" 618 | } 619 | }, 620 | "node_modules/mquery": { 621 | "version": "5.0.0", 622 | "resolved": "https://registry.npmjs.org/mquery/-/mquery-5.0.0.tgz", 623 | "integrity": "sha512-iQMncpmEK8R8ncT8HJGsGc9Dsp8xcgYMVSbs5jgnm1lFHTZqMJTUWTDx1LBO8+mK3tPNZWFLBghQEIOULSTHZg==", 624 | "dependencies": { 625 | "debug": "4.x" 626 | }, 627 | "engines": { 628 | "node": ">=14.0.0" 629 | } 630 | }, 631 | "node_modules/mquery/node_modules/debug": { 632 | "version": "4.3.4", 633 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 634 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 635 | "dependencies": { 636 | "ms": "2.1.2" 637 | }, 638 | "engines": { 639 | "node": ">=6.0" 640 | }, 641 | "peerDependenciesMeta": { 642 | "supports-color": { 643 | "optional": true 644 | } 645 | } 646 | }, 647 | "node_modules/mquery/node_modules/ms": { 648 | "version": "2.1.2", 649 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 650 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" 651 | }, 652 | "node_modules/ms": { 653 | "version": "2.0.0", 654 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 655 | "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==" 656 | }, 657 | "node_modules/multer": { 658 | "version": "1.4.5-lts.1", 659 | "resolved": "https://registry.npmjs.org/multer/-/multer-1.4.5-lts.1.tgz", 660 | "integrity": "sha512-ywPWvcDMeH+z9gQq5qYHCCy+ethsk4goepZ45GLD63fOu0YcNecQxi64nDs3qluZB+murG3/D4dJ7+dGctcCQQ==", 661 | "dependencies": { 662 | "append-field": "^1.0.0", 663 | "busboy": "^1.0.0", 664 | "concat-stream": "^1.5.2", 665 | "mkdirp": "^0.5.4", 666 | "object-assign": "^4.1.1", 667 | "type-is": "^1.6.4", 668 | "xtend": "^4.0.0" 669 | }, 670 | "engines": { 671 | "node": ">= 6.0.0" 672 | } 673 | }, 674 | "node_modules/negotiator": { 675 | "version": "0.6.3", 676 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz", 677 | "integrity": "sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg==", 678 | "engines": { 679 | "node": ">= 0.6" 680 | } 681 | }, 682 | "node_modules/object-assign": { 683 | "version": "4.1.1", 684 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 685 | "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==", 686 | "engines": { 687 | "node": ">=0.10.0" 688 | } 689 | }, 690 | "node_modules/on-finished": { 691 | "version": "2.3.0", 692 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", 693 | "integrity": "sha512-ikqdkGAAyf/X/gPhXGvfgAytDZtDbr+bkNUJ0N9h5MI/dmdgCs3l6hoHrcUv41sRKew3jIwrp4qQDXiK99Utww==", 694 | "dependencies": { 695 | "ee-first": "1.1.1" 696 | }, 697 | "engines": { 698 | "node": ">= 0.8" 699 | } 700 | }, 701 | "node_modules/on-headers": { 702 | "version": "1.0.2", 703 | "resolved": "https://registry.npmjs.org/on-headers/-/on-headers-1.0.2.tgz", 704 | "integrity": "sha512-pZAE+FJLoyITytdqK0U5s+FIpjN0JP3OzFi/u8Rx+EV5/W+JTWGXG8xFzevE7AjBfDqHv/8vL8qQsIhHnqRkrA==", 705 | "engines": { 706 | "node": ">= 0.8" 707 | } 708 | }, 709 | "node_modules/parseurl": { 710 | "version": "1.3.3", 711 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 712 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==", 713 | "engines": { 714 | "node": ">= 0.8" 715 | } 716 | }, 717 | "node_modules/passport": { 718 | "version": "0.7.0", 719 | "resolved": "https://registry.npmjs.org/passport/-/passport-0.7.0.tgz", 720 | "integrity": "sha512-cPLl+qZpSc+ireUvt+IzqbED1cHHkDoVYMo30jbJIdOOjQ1MQYZBPiNvmi8UM6lJuOpTPXJGZQk0DtC4y61MYQ==", 721 | "dependencies": { 722 | "passport-strategy": "1.x.x", 723 | "pause": "0.0.1", 724 | "utils-merge": "^1.0.1" 725 | }, 726 | "engines": { 727 | "node": ">= 0.4.0" 728 | }, 729 | "funding": { 730 | "type": "github", 731 | "url": "https://github.com/sponsors/jaredhanson" 732 | } 733 | }, 734 | "node_modules/passport-local": { 735 | "version": "1.0.0", 736 | "resolved": "https://registry.npmjs.org/passport-local/-/passport-local-1.0.0.tgz", 737 | "integrity": "sha512-9wCE6qKznvf9mQYYbgJ3sVOHmCWoUNMVFoZzNoznmISbhnNNPhN9xfY3sLmScHMetEJeoY7CXwfhCe7argfQow==", 738 | "dependencies": { 739 | "passport-strategy": "1.x.x" 740 | }, 741 | "engines": { 742 | "node": ">= 0.4.0" 743 | } 744 | }, 745 | "node_modules/passport-local-mongoose": { 746 | "version": "8.0.0", 747 | "resolved": "https://registry.npmjs.org/passport-local-mongoose/-/passport-local-mongoose-8.0.0.tgz", 748 | "integrity": "sha512-jgfN/B0j11WT5f96QlL5EBvxbIwmzd+tbwPzG1Vk8hzDOF68jrch5M+NFvrHjWjb3lfAU0DkxKmNRT9BjFZysQ==", 749 | "dependencies": { 750 | "generaterr": "^1.5.0", 751 | "passport-local": "^1.0.0", 752 | "scmp": "^2.1.0" 753 | }, 754 | "engines": { 755 | "node": ">= 8.0.0" 756 | } 757 | }, 758 | "node_modules/passport-strategy": { 759 | "version": "1.0.0", 760 | "resolved": "https://registry.npmjs.org/passport-strategy/-/passport-strategy-1.0.0.tgz", 761 | "integrity": "sha512-CB97UUvDKJde2V0KDWWB3lyf6PC3FaZP7YxZ2G8OAtn9p4HI9j9JLP9qjOGZFvyl8uwNT8qM+hGnz/n16NI7oA==", 762 | "engines": { 763 | "node": ">= 0.4.0" 764 | } 765 | }, 766 | "node_modules/path-to-regexp": { 767 | "version": "0.1.7", 768 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 769 | "integrity": "sha512-5DFkuoqlv1uYQKxy8omFBeJPQcdoE07Kv2sferDCrAq1ohOU+MSDswDIbnx3YAM60qIOnYa53wBhXW0EbMonrQ==" 770 | }, 771 | "node_modules/pause": { 772 | "version": "0.0.1", 773 | "resolved": "https://registry.npmjs.org/pause/-/pause-0.0.1.tgz", 774 | "integrity": "sha512-KG8UEiEVkR3wGEb4m5yZkVCzigAD+cVEJck2CzYZO37ZGJfctvVptVO192MwrtPhzONn6go8ylnOdMhKqi4nfg==" 775 | }, 776 | "node_modules/process-nextick-args": { 777 | "version": "2.0.1", 778 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", 779 | "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==" 780 | }, 781 | "node_modules/proxy-addr": { 782 | "version": "2.0.7", 783 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz", 784 | "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==", 785 | "dependencies": { 786 | "forwarded": "0.2.0", 787 | "ipaddr.js": "1.9.1" 788 | }, 789 | "engines": { 790 | "node": ">= 0.10" 791 | } 792 | }, 793 | "node_modules/punycode": { 794 | "version": "2.3.1", 795 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz", 796 | "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==", 797 | "engines": { 798 | "node": ">=6" 799 | } 800 | }, 801 | "node_modules/qs": { 802 | "version": "6.5.2", 803 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.2.tgz", 804 | "integrity": "sha512-N5ZAX4/LxJmF+7wN74pUD6qAh9/wnvdQcjq9TZjevvXzSUo7bfmw91saqMjzGS2xq91/odN2dW/WOl7qQHNDGA==", 805 | "engines": { 806 | "node": ">=0.6" 807 | } 808 | }, 809 | "node_modules/random-bytes": { 810 | "version": "1.0.0", 811 | "resolved": "https://registry.npmjs.org/random-bytes/-/random-bytes-1.0.0.tgz", 812 | "integrity": "sha512-iv7LhNVO047HzYR3InF6pUcUsPQiHTM1Qal51DcGSuZFBil1aBBWG5eHPNek7bvILMaYJ/8RU1e8w1AMdHmLQQ==", 813 | "engines": { 814 | "node": ">= 0.8" 815 | } 816 | }, 817 | "node_modules/range-parser": { 818 | "version": "1.2.1", 819 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 820 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==", 821 | "engines": { 822 | "node": ">= 0.6" 823 | } 824 | }, 825 | "node_modules/raw-body": { 826 | "version": "2.3.3", 827 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.3.3.tgz", 828 | "integrity": "sha512-9esiElv1BrZoI3rCDuOuKCBRbuApGGaDPQfjSflGxdy4oyzqghxu6klEkkVIvBje+FF0BX9coEv8KqW6X/7njw==", 829 | "dependencies": { 830 | "bytes": "3.0.0", 831 | "http-errors": "1.6.3", 832 | "iconv-lite": "0.4.23", 833 | "unpipe": "1.0.0" 834 | }, 835 | "engines": { 836 | "node": ">= 0.8" 837 | } 838 | }, 839 | "node_modules/readable-stream": { 840 | "version": "2.3.8", 841 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.8.tgz", 842 | "integrity": "sha512-8p0AUk4XODgIewSi0l8Epjs+EVnWiK7NoDIEGU0HhE7+ZyY8D1IMY7odu5lRrFXGg71L15KG8QrPmum45RTtdA==", 843 | "dependencies": { 844 | "core-util-is": "~1.0.0", 845 | "inherits": "~2.0.3", 846 | "isarray": "~1.0.0", 847 | "process-nextick-args": "~2.0.0", 848 | "safe-buffer": "~5.1.1", 849 | "string_decoder": "~1.1.1", 850 | "util-deprecate": "~1.0.1" 851 | } 852 | }, 853 | "node_modules/safe-buffer": { 854 | "version": "5.1.2", 855 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 856 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 857 | }, 858 | "node_modules/safer-buffer": { 859 | "version": "2.1.2", 860 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 861 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" 862 | }, 863 | "node_modules/scmp": { 864 | "version": "2.1.0", 865 | "resolved": "https://registry.npmjs.org/scmp/-/scmp-2.1.0.tgz", 866 | "integrity": "sha512-o/mRQGk9Rcer/jEEw/yw4mwo3EU/NvYvp577/Btqrym9Qy5/MdWGBqipbALgd2lrdWTJ5/gqDusxfnQBxOxT2Q==" 867 | }, 868 | "node_modules/send": { 869 | "version": "0.16.2", 870 | "resolved": "https://registry.npmjs.org/send/-/send-0.16.2.tgz", 871 | "integrity": "sha512-E64YFPUssFHEFBvpbbjr44NCLtI1AohxQ8ZSiJjQLskAdKuriYEP6VyGEsRDH8ScozGpkaX1BGvhanqCwkcEZw==", 872 | "dependencies": { 873 | "debug": "2.6.9", 874 | "depd": "~1.1.2", 875 | "destroy": "~1.0.4", 876 | "encodeurl": "~1.0.2", 877 | "escape-html": "~1.0.3", 878 | "etag": "~1.8.1", 879 | "fresh": "0.5.2", 880 | "http-errors": "~1.6.2", 881 | "mime": "1.4.1", 882 | "ms": "2.0.0", 883 | "on-finished": "~2.3.0", 884 | "range-parser": "~1.2.0", 885 | "statuses": "~1.4.0" 886 | }, 887 | "engines": { 888 | "node": ">= 0.8.0" 889 | } 890 | }, 891 | "node_modules/serve-static": { 892 | "version": "1.13.2", 893 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.13.2.tgz", 894 | "integrity": "sha512-p/tdJrO4U387R9oMjb1oj7qSMaMfmOyd4j9hOFoxZe2baQszgHcSWjuya/CiT5kgZZKRudHNOA0pYXOl8rQ5nw==", 895 | "dependencies": { 896 | "encodeurl": "~1.0.2", 897 | "escape-html": "~1.0.3", 898 | "parseurl": "~1.3.2", 899 | "send": "0.16.2" 900 | }, 901 | "engines": { 902 | "node": ">= 0.8.0" 903 | } 904 | }, 905 | "node_modules/setprototypeof": { 906 | "version": "1.1.0", 907 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.0.tgz", 908 | "integrity": "sha512-BvE/TwpZX4FXExxOxZyRGQQv651MSwmWKZGqvmPcRIjDqWub67kTKuIMx43cZZrS/cBBzwBcNDWoFxt2XEFIpQ==" 909 | }, 910 | "node_modules/sift": { 911 | "version": "16.0.1", 912 | "resolved": "https://registry.npmjs.org/sift/-/sift-16.0.1.tgz", 913 | "integrity": "sha512-Wv6BjQ5zbhW7VFefWusVP33T/EM0vYikCaQ2qR8yULbsilAT8/wQaXvuQ3ptGLpoKx+lihJE3y2UTgKDyyNHZQ==" 914 | }, 915 | "node_modules/sparse-bitfield": { 916 | "version": "3.0.3", 917 | "resolved": "https://registry.npmjs.org/sparse-bitfield/-/sparse-bitfield-3.0.3.tgz", 918 | "integrity": "sha512-kvzhi7vqKTfkh0PZU+2D2PIllw2ymqJKujUcyPMd9Y75Nv4nPbGJZXNhxsgdQab2BmlDct1YnfQCguEvHr7VsQ==", 919 | "dependencies": { 920 | "memory-pager": "^1.0.2" 921 | } 922 | }, 923 | "node_modules/statuses": { 924 | "version": "1.4.0", 925 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.4.0.tgz", 926 | "integrity": "sha512-zhSCtt8v2NDrRlPQpCNtw/heZLtfUDqxBM1udqikb/Hbk52LK4nQSwr10u77iopCW5LsyHpuXS0GnEc48mLeew==", 927 | "engines": { 928 | "node": ">= 0.6" 929 | } 930 | }, 931 | "node_modules/streamsearch": { 932 | "version": "1.1.0", 933 | "resolved": "https://registry.npmjs.org/streamsearch/-/streamsearch-1.1.0.tgz", 934 | "integrity": "sha512-Mcc5wHehp9aXz1ax6bZUyY5afg9u2rv5cqQI3mRrYkGC8rW2hM02jWuwjtL++LS5qinSyhj2QfLyNsuc+VsExg==", 935 | "engines": { 936 | "node": ">=10.0.0" 937 | } 938 | }, 939 | "node_modules/string_decoder": { 940 | "version": "1.1.1", 941 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 942 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 943 | "dependencies": { 944 | "safe-buffer": "~5.1.0" 945 | } 946 | }, 947 | "node_modules/tr46": { 948 | "version": "3.0.0", 949 | "resolved": "https://registry.npmjs.org/tr46/-/tr46-3.0.0.tgz", 950 | "integrity": "sha512-l7FvfAHlcmulp8kr+flpQZmVwtu7nfRV7NZujtN0OqES8EL4O4e0qqzL0DC5gAvx/ZC/9lk6rhcUwYvkBnBnYA==", 951 | "dependencies": { 952 | "punycode": "^2.1.1" 953 | }, 954 | "engines": { 955 | "node": ">=12" 956 | } 957 | }, 958 | "node_modules/type-is": { 959 | "version": "1.6.18", 960 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 961 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 962 | "dependencies": { 963 | "media-typer": "0.3.0", 964 | "mime-types": "~2.1.24" 965 | }, 966 | "engines": { 967 | "node": ">= 0.6" 968 | } 969 | }, 970 | "node_modules/typedarray": { 971 | "version": "0.0.6", 972 | "resolved": "https://registry.npmjs.org/typedarray/-/typedarray-0.0.6.tgz", 973 | "integrity": "sha512-/aCDEGatGvZ2BIk+HmLf4ifCJFwvKFNb9/JeZPMulfgFracn9QFcAf5GO8B/mweUjSoblS5In0cWhqpfs/5PQA==" 974 | }, 975 | "node_modules/uid-safe": { 976 | "version": "2.1.5", 977 | "resolved": "https://registry.npmjs.org/uid-safe/-/uid-safe-2.1.5.tgz", 978 | "integrity": "sha512-KPHm4VL5dDXKz01UuEd88Df+KzynaohSL9fBh096KWAxSKZQDI2uBrVqtvRM4rwrIrRRKsdLNML/lnaaVSRioA==", 979 | "dependencies": { 980 | "random-bytes": "~1.0.0" 981 | }, 982 | "engines": { 983 | "node": ">= 0.8" 984 | } 985 | }, 986 | "node_modules/undici-types": { 987 | "version": "5.26.5", 988 | "resolved": "https://registry.npmjs.org/undici-types/-/undici-types-5.26.5.tgz", 989 | "integrity": "sha512-JlCMO+ehdEIKqlFxk6IfVoAUVmgz7cU7zD/h9XZ0qzeosSHmUJVOzSQvvYSYWXkFXC+IfLKSIffhv0sVZup6pA==" 990 | }, 991 | "node_modules/unpipe": { 992 | "version": "1.0.0", 993 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 994 | "integrity": "sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==", 995 | "engines": { 996 | "node": ">= 0.8" 997 | } 998 | }, 999 | "node_modules/util-deprecate": { 1000 | "version": "1.0.2", 1001 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 1002 | "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==" 1003 | }, 1004 | "node_modules/utils-merge": { 1005 | "version": "1.0.1", 1006 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 1007 | "integrity": "sha512-pMZTvIkT1d+TFGvDOqodOclx0QWkkgi6Tdoa8gC8ffGAAqz9pzPTZWAybbsHHoED/ztMtkv/VoYTYyShUn81hA==", 1008 | "engines": { 1009 | "node": ">= 0.4.0" 1010 | } 1011 | }, 1012 | "node_modules/vary": { 1013 | "version": "1.1.2", 1014 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 1015 | "integrity": "sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg==", 1016 | "engines": { 1017 | "node": ">= 0.8" 1018 | } 1019 | }, 1020 | "node_modules/webidl-conversions": { 1021 | "version": "7.0.0", 1022 | "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-7.0.0.tgz", 1023 | "integrity": "sha512-VwddBukDzu71offAQR975unBIGqfKZpM+8ZX6ySk8nYhVoo5CYaZyzt3YBvYtRtO+aoGlqxPg/B87NGVZ/fu6g==", 1024 | "engines": { 1025 | "node": ">=12" 1026 | } 1027 | }, 1028 | "node_modules/whatwg-url": { 1029 | "version": "11.0.0", 1030 | "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-11.0.0.tgz", 1031 | "integrity": "sha512-RKT8HExMpoYx4igMiVMY83lN6UeITKJlBQ+vR/8ZJ8OCdSiN3RwCq+9gH0+Xzj0+5IrM6i4j/6LuvzbZIQgEcQ==", 1032 | "dependencies": { 1033 | "tr46": "^3.0.0", 1034 | "webidl-conversions": "^7.0.0" 1035 | }, 1036 | "engines": { 1037 | "node": ">=12" 1038 | } 1039 | }, 1040 | "node_modules/xtend": { 1041 | "version": "4.0.2", 1042 | "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.2.tgz", 1043 | "integrity": "sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ==", 1044 | "engines": { 1045 | "node": ">=0.4" 1046 | } 1047 | } 1048 | } 1049 | } 1050 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "insta", 3 | "version": "0.0.0", 4 | "private": true, 5 | "scripts": { 6 | "start": "node ./bin/www" 7 | }, 8 | "dependencies": { 9 | "cookie-parser": "~1.4.4", 10 | "debug": "~2.6.9", 11 | "ejs": "~2.6.1", 12 | "express": "~4.16.1", 13 | "express-session": "^1.17.3", 14 | "http-errors": "~1.6.3", 15 | "mongoose": "^8.0.4", 16 | "morgan": "~1.9.1", 17 | "multer": "^1.4.5-lts.1", 18 | "passport": "^0.7.0", 19 | "passport-local": "^1.0.0", 20 | "passport-local-mongoose": "^8.0.0" 21 | } 22 | } 23 | -------------------------------------------------------------------------------- /public/.DS_Store: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/asynchronousJavascriptor/instaclone/920173667d39b42221dfbc256fe2b1e87fc58ca2/public/.DS_Store -------------------------------------------------------------------------------- /public/images/.DS_Store: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/asynchronousJavascriptor/instaclone/920173667d39b42221dfbc256fe2b1e87fc58ca2/public/images/.DS_Store -------------------------------------------------------------------------------- /public/images/image.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/asynchronousJavascriptor/instaclone/920173667d39b42221dfbc256fe2b1e87fc58ca2/public/images/image.png -------------------------------------------------------------------------------- /public/images/logo.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/asynchronousJavascriptor/instaclone/920173667d39b42221dfbc256fe2b1e87fc58ca2/public/images/logo.png -------------------------------------------------------------------------------- /public/images/uploads/.DS_Store: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/asynchronousJavascriptor/instaclone/920173667d39b42221dfbc256fe2b1e87fc58ca2/public/images/uploads/.DS_Store -------------------------------------------------------------------------------- /public/stylesheets/style.css: -------------------------------------------------------------------------------- 1 | .story::-webkit-scrollbar{ 2 | display: none; 3 | } 4 | 5 | a:focus { 6 | outline: none !important; 7 | } -------------------------------------------------------------------------------- /readme.md: -------------------------------------------------------------------------------- 1 | HQ instagram clone -------------------------------------------------------------------------------- /routes/index.js: -------------------------------------------------------------------------------- 1 | var express = require("express"); 2 | var router = express.Router(); 3 | const passport = require("passport"); 4 | const localStrategy = require("passport-local"); 5 | const userModel = require("./users"); 6 | const postModel = require("./posts"); 7 | const storyModel = require("./story"); 8 | passport.use(new localStrategy(userModel.authenticate())); 9 | const upload = require("./multer"); 10 | const utils = require("../utils/utils"); 11 | 12 | 13 | // GET 14 | router.get("/", function (req, res) { 15 | res.render("index", { footer: false }); 16 | }); 17 | 18 | router.get("/login", function (req, res) { 19 | res.render("login", { footer: false }); 20 | }); 21 | 22 | router.get("/like/:postid", async function (req, res) { 23 | const post = await postModel.findOne({ _id: req.params.postid }); 24 | const user = await userModel.findOne({ username: req.session.passport.user }); 25 | if (post.like.indexOf(user._id) === -1) { 26 | post.like.push(user._id); 27 | } else { 28 | post.like.splice(post.like.indexOf(user._id), 1); 29 | } 30 | await post.save(); 31 | res.json(post); 32 | }); 33 | 34 | router.get("/feed", isLoggedIn, async function (req, res) { 35 | let user = await userModel 36 | .findOne({ username: req.session.passport.user }) 37 | .populate("posts"); 38 | 39 | let stories = await storyModel.find({ user: { $ne: user._id } }) 40 | .populate("user"); 41 | 42 | var uniq = {}; 43 | var filtered = stories.filter(item => { 44 | if(!uniq[item.user.id]){ 45 | uniq[item.user.id] = " "; 46 | return true; 47 | } 48 | else return false; 49 | }) 50 | 51 | let posts = await postModel.find().populate("user"); 52 | 53 | res.render("feed", { 54 | footer: true, 55 | user, 56 | posts, 57 | stories: filtered, 58 | dater: utils.formatRelativeTime, 59 | }); 60 | }); 61 | 62 | router.get("/profile", isLoggedIn, async function (req, res) { 63 | let user = await userModel 64 | .findOne({ username: req.session.passport.user }) 65 | .populate("posts") 66 | .populate("saved"); 67 | console.log(user); 68 | 69 | res.render("profile", { footer: true, user }); 70 | }); 71 | 72 | router.get("/profile/:user", isLoggedIn, async function (req, res) { 73 | let user = await userModel.findOne({ username: req.session.passport.user }); 74 | 75 | if (user.username === req.params.user) { 76 | res.redirect("/profile"); 77 | } 78 | 79 | let userprofile = await userModel 80 | .findOne({ username: req.params.user }) 81 | .populate("posts"); 82 | 83 | res.render("userprofile", { footer: true, userprofile, user }); 84 | }); 85 | 86 | router.get("/follow/:userid", isLoggedIn, async function (req, res) { 87 | let followKarneWaala = await userModel.findOne({ 88 | username: req.session.passport.user, 89 | }); 90 | 91 | let followHoneWaala = await userModel.findOne({ _id: req.params.userid }); 92 | 93 | if (followKarneWaala.following.indexOf(followHoneWaala._id) !== -1) { 94 | let index = followKarneWaala.following.indexOf(followHoneWaala._id); 95 | followKarneWaala.following.splice(index, 1); 96 | 97 | let index2 = followHoneWaala.followers.indexOf(followKarneWaala._id); 98 | followHoneWaala.followers.splice(index2, 1); 99 | } else { 100 | followHoneWaala.followers.push(followKarneWaala._id); 101 | followKarneWaala.following.push(followHoneWaala._id); 102 | } 103 | 104 | await followHoneWaala.save(); 105 | await followKarneWaala.save(); 106 | 107 | res.redirect("back"); 108 | }); 109 | 110 | router.get("/search", isLoggedIn, async function (req, res) { 111 | let user = await userModel.findOne({ username: req.session.passport.user }); 112 | res.render("search", { footer: true, user }); 113 | }); 114 | 115 | router.get("/save/:postid", isLoggedIn, async function (req, res) { 116 | let user = await userModel.findOne({ username: req.session.passport.user }); 117 | 118 | if (user.saved.indexOf(req.params.postid) === -1) { 119 | user.saved.push(req.params.postid); 120 | } else { 121 | var index = user.saved.indexOf(req.params.postid); 122 | user.saved.splice(index, 1); 123 | } 124 | await user.save(); 125 | res.json(user); 126 | }); 127 | 128 | router.get("/search/:user", isLoggedIn, async function (req, res) { 129 | const searchTerm = `^${req.params.user}`; 130 | const regex = new RegExp(searchTerm); 131 | 132 | let users = await userModel.find({ username: { $regex: regex } }); 133 | 134 | res.json(users); 135 | }); 136 | 137 | router.get("/edit", isLoggedIn, async function (req, res) { 138 | const user = await userModel.findOne({ username: req.session.passport.user }); 139 | res.render("edit", { footer: true, user }); 140 | }); 141 | 142 | router.get("/upload", isLoggedIn, async function (req, res) { 143 | let user = await userModel.findOne({ username: req.session.passport.user }); 144 | res.render("upload", { footer: true, user }); 145 | }); 146 | 147 | router.post("/update", isLoggedIn, async function (req, res) { 148 | const user = await userModel.findOneAndUpdate( 149 | { username: req.session.passport.user }, 150 | { username: req.body.username, name: req.body.name, bio: req.body.bio }, 151 | { new: true } 152 | ); 153 | req.login(user, function (err) { 154 | if (err) throw err; 155 | res.redirect("/profile"); 156 | }); 157 | }); 158 | 159 | router.post( 160 | "/post", 161 | isLoggedIn, 162 | upload.single("image"), 163 | async function (req, res) { 164 | const user = await userModel.findOne({ 165 | username: req.session.passport.user, 166 | }); 167 | 168 | if (req.body.category === "post") { 169 | const post = await postModel.create({ 170 | user: user._id, 171 | caption: req.body.caption, 172 | picture: req.file.filename, 173 | }); 174 | user.posts.push(post._id); 175 | } else if (req.body.category === "story") { 176 | let story = await storyModel.create({ 177 | story: req.file.filename, 178 | user: user._id, 179 | }); 180 | user.stories.push(story._id); 181 | } else { 182 | res.send("tez mat chalo"); 183 | } 184 | 185 | await user.save(); 186 | res.redirect("/feed"); 187 | } 188 | ); 189 | 190 | router.post( 191 | "/upload", 192 | isLoggedIn, 193 | upload.single("image"), 194 | async function (req, res) { 195 | const user = await userModel.findOne({ 196 | username: req.session.passport.user, 197 | }); 198 | user.picture = req.file.filename; 199 | await user.save(); 200 | res.redirect("/edit"); 201 | } 202 | ); 203 | 204 | // POST 205 | 206 | router.post("/register", function (req, res) { 207 | const user = new userModel({ 208 | username: req.body.username, 209 | email: req.body.email, 210 | name: req.body.name, 211 | }); 212 | 213 | userModel.register(user, req.body.password).then(function (registereduser) { 214 | passport.authenticate("local")(req, res, function () { 215 | res.redirect("/profile"); 216 | }); 217 | }); 218 | }); 219 | 220 | router.post( 221 | "/login", 222 | passport.authenticate("local", { 223 | successRedirect: "/feed", 224 | failureRedirect: "/login", 225 | }), 226 | function (req, res) {} 227 | ); 228 | 229 | router.get("/logout", function (req, res) { 230 | req.logout(function (err) { 231 | if (err) { 232 | return next(err); 233 | } 234 | res.redirect("/login"); 235 | }); 236 | }); 237 | 238 | function isLoggedIn(req, res, next) { 239 | if (req.isAuthenticated()) { 240 | return next(); 241 | } else { 242 | res.redirect("/login"); 243 | } 244 | } 245 | 246 | module.exports = router; 247 | -------------------------------------------------------------------------------- /routes/multer.js: -------------------------------------------------------------------------------- 1 | const multer = require("multer"); 2 | const path = require("path"); 3 | const crypto = require("crypto"); 4 | 5 | const storage = multer.diskStorage({ 6 | destination: function (req, file, cb) { 7 | cb(null, "./public/images/uploads"); 8 | }, 9 | filename: function (req, file, cb) { 10 | const fn = 11 | crypto.randomBytes(16).toString("hex") + path.extname(file.originalname); 12 | cb(null, fn); 13 | }, 14 | }); 15 | 16 | const upload = multer({ storage: storage }); 17 | module.exports = upload; -------------------------------------------------------------------------------- /routes/posts.js: -------------------------------------------------------------------------------- 1 | const mongoose = require('mongoose'); 2 | 3 | const postSchema = mongoose.Schema({ 4 | user: { 5 | type: mongoose.Schema.Types.ObjectId, 6 | ref: "user" 7 | }, 8 | caption: String, 9 | like: [{ 10 | type: mongoose.Schema.Types.ObjectId, 11 | ref: "user" 12 | }], 13 | comments: { 14 | type: Array, 15 | default: [] 16 | }, 17 | date: { 18 | type: Date, 19 | default: Date.now 20 | }, 21 | shares: [{ 22 | type: mongoose.Schema.Types.ObjectId, 23 | ref: "user" 24 | }], 25 | picture: String 26 | }) 27 | 28 | 29 | module.exports = mongoose.model("post", postSchema); -------------------------------------------------------------------------------- /routes/story.js: -------------------------------------------------------------------------------- 1 | const mongoose = require('mongoose'); 2 | 3 | const storySchema = mongoose.Schema({ 4 | user: { 5 | type: mongoose.Schema.Types.ObjectId, 6 | ref: "user" 7 | }, 8 | story: String, 9 | date: { 10 | type: Date, 11 | default: Date.now 12 | } 13 | }) 14 | 15 | 16 | module.exports = mongoose.model("story", storySchema); -------------------------------------------------------------------------------- /routes/users.js: -------------------------------------------------------------------------------- 1 | const mongoose = require('mongoose'); 2 | const plm = require("passport-local-mongoose"); 3 | 4 | mongoose.connect("mongodb://127.0.0.1:27017/instainsta"); 5 | 6 | const userSchema = mongoose.Schema({ 7 | username: String, 8 | name: String, 9 | email: String, 10 | password: String, 11 | picture: { 12 | type: String, 13 | default: "def.png" 14 | }, 15 | contact: String, 16 | bio: String, 17 | stories: [ 18 | { 19 | type: mongoose.Schema.Types.ObjectId, 20 | ref: "story" 21 | } 22 | ], 23 | saved: [ 24 | { 25 | type: mongoose.Schema.Types.ObjectId, 26 | ref: "post" 27 | } 28 | ], 29 | posts: [{ 30 | type: mongoose.Schema.Types.ObjectId, 31 | ref: "post" 32 | }], 33 | followers: [ 34 | { 35 | type: mongoose.Schema.Types.ObjectId, 36 | ref: "user" 37 | } 38 | ], 39 | following: [ 40 | { 41 | type: mongoose.Schema.Types.ObjectId, 42 | ref: "user" 43 | } 44 | ] 45 | }) 46 | 47 | userSchema.plugin(plm); 48 | 49 | module.exports = mongoose.model("user", userSchema); -------------------------------------------------------------------------------- /utils/utils.js: -------------------------------------------------------------------------------- 1 | var utils = { 2 | formatRelativeTime: function (date) { 3 | const now = new Date(); 4 | const diff = now - date; 5 | 6 | // Convert milliseconds to seconds 7 | const seconds = Math.floor(diff / 1000); 8 | 9 | if (seconds < 60) { 10 | return `${seconds}s`; 11 | } 12 | 13 | const minutes = Math.floor(seconds / 60); 14 | 15 | if (minutes < 60) { 16 | return `${minutes}m`; 17 | } 18 | 19 | const hours = Math.floor(minutes / 60); 20 | 21 | if (hours < 24) { 22 | return `${hours}h`; 23 | } 24 | 25 | const days = Math.floor(hours / 24); 26 | 27 | if (days < 7) { 28 | return `${days}d`; 29 | } 30 | 31 | const weeks = Math.floor(days / 7); 32 | 33 | return `${weeks}w`; 34 | } 35 | } 36 | module.exports = utils; -------------------------------------------------------------------------------- /views/edit.ejs: -------------------------------------------------------------------------------- 1 | <% include ./partials/header.ejs %> 2 | 3 | 6 | 7 |
8 |
9 | profile 10 |

Edit Profile

11 | home 12 |
13 |
14 |
15 | 16 |
17 | 18 |
19 |
20 |

Edit Account Details

21 |
22 |
23 | 24 | 25 | 26 | 27 |
28 |
29 |
30 | 31 | 41 | <% include ./partials/footer.ejs %> -------------------------------------------------------------------------------- /views/error.ejs: -------------------------------------------------------------------------------- 1 |

<%= message %>

2 |

<%= error.status %>

3 |
<%= error.stack %>
4 | -------------------------------------------------------------------------------- /views/feed.ejs: -------------------------------------------------------------------------------- 1 | <% include ./partials/header.ejs %> 2 |
3 |
4 | 5 |
6 | 7 | 8 |
9 |
10 |
11 | 12 |
13 |
15 |
16 | 17 |
18 |
19 |
20 |
21 | <% stories.forEach(function(story){ %> 22 | 23 |
24 |
26 |
27 | 28 |
29 |
30 |
31 |
32 | <% }) %> 33 |
34 |
35 | <% posts.reverse().forEach(function(post){ %> 36 |
37 |
38 |
39 | 40 |
41 |

42 | <%= post.user.username %> 43 |

44 |
45 | <%= dater(new Date(post.date)) %> 46 |
47 |
48 |
49 | 51 |
52 |
53 |
54 | <% if(post.like.indexOf(user._id)===-1){ %> 55 | 56 | <% } else { %> 57 | 58 | <% } %> 59 | 60 | 61 |
62 | <% if(user.saved.indexOf(post.id)===-1){ %> 63 | 64 | <% } else { %> 65 | 66 | <% } %> 67 |
68 |

69 | <%= post.like.length %> likes 70 |

71 |

72 | 73 | <%= post.user.username %> 74 | 75 | <%= post.caption %> 76 |

77 |
78 | <% }) %> 79 |
80 |
81 | 82 | 85 | 185 | 186 | 187 | <% include ./partials/footer.ejs %> -------------------------------------------------------------------------------- /views/index.ejs: -------------------------------------------------------------------------------- 1 | <% include ./partials/header.ejs %> 2 |
3 |
4 | 5 |
6 | 7 | 8 | 9 | 10 | 11 |
12 | Already have an account ? Log In 13 |
14 |
15 | <% include ./partials/footer.ejs %> -------------------------------------------------------------------------------- /views/login.ejs: -------------------------------------------------------------------------------- 1 | <% include ./partials/header.ejs %> 2 |
3 |
4 | 5 |
6 | 7 | 8 | 9 |
10 | Don't have an account ? Sign Up 11 |
12 |
13 | <% include ./partials/footer.ejs %> -------------------------------------------------------------------------------- /views/partials/footer.ejs: -------------------------------------------------------------------------------- 1 | <% if(footer){ %> 2 | 12 | <% } %> 13 | 14 | 15 | 16 | -------------------------------------------------------------------------------- /views/partials/header.ejs: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | Document 7 | 8 | 9 | 10 | 11 | -------------------------------------------------------------------------------- /views/profile.ejs: -------------------------------------------------------------------------------- 1 | <% include ./partials/header.ejs %> 2 |
3 | 10 |
11 |
12 | 13 |
14 |
15 |
16 |

<%= user.posts.length %>

17 |

Posts

18 |
19 |
20 |

<%= user.followers.length %>

21 |

Followers

22 |
23 |
24 |

<%= user.following.length %>

25 |

Following

26 |
27 |
28 |
29 |
30 |

<%= user.name %>

31 |

<%= user.bio ?? "You have not set anything yet, (click edit profile to set)" %>

32 |
33 |
34 | Edit Profile 35 |
36 |
37 | <% if(user.posts.length>0){ %> 38 | <% user.posts.reverse().forEach(function(post){ %> 39 |
40 | 41 |
42 | <% }) %> 43 | <% } else { %> 44 |
45 | no posts yet. 46 |
47 | <% } %> 48 |
49 |
50 | <% include ./partials/footer.ejs %> -------------------------------------------------------------------------------- /views/search.ejs: -------------------------------------------------------------------------------- 1 | <% include ./partials/header.ejs %> 2 |
3 |
4 | 5 | 7 |
8 |
9 | 10 |
11 |
12 | 13 | 43 | <% include ./partials/footer.ejs %> -------------------------------------------------------------------------------- /views/upload.ejs: -------------------------------------------------------------------------------- 1 | <% include ./partials/header.ejs %> 2 |
3 |
4 | profile 5 |

Upload Post

6 | home 7 |
8 |
9 |
10 | 11 |
12 | 13 |
14 |
15 |
post
16 |
story
17 |
18 |
19 | 20 | 21 | 22 | 23 | 24 |
25 |
26 | 27 | 57 | <% include ./partials/footer.ejs %> -------------------------------------------------------------------------------- /views/userprofile.ejs: -------------------------------------------------------------------------------- 1 | <% include ./partials/header.ejs %> 2 |
3 | 10 |
11 |
12 | 13 |
14 |
15 |
16 |

<%= userprofile.posts.length %>

17 |

Posts

18 |
19 |
20 |

<%= userprofile.followers.length %>

21 |

Followers

22 |
23 |
24 |

<%= userprofile.following.length %>

25 |

Following

26 |
27 |
28 |
29 |
30 |

<%= userprofile.name %>

31 |

<%= userprofile.bio ?? "You have not set anything yet, (click edit profile to set)" %>

32 |
33 |
34 | <% if(user.following.indexOf(userprofile._id) === -1){ %> 35 | Follow 36 | <% } else { %> 37 | Following 38 | <% } %> 39 | Message 40 | Contact 41 |
42 |
43 | <% if(userprofile.posts.length>0){ %> 44 | <% userprofile.posts.reverse().forEach(function(post){ %> 45 |
46 | 47 |
48 | <% }) %> 49 | <% } else { %> 50 |
51 | no posts yet. 52 |
53 | <% } %> 54 |
55 |
56 | <% include ./partials/footer.ejs %> --------------------------------------------------------------------------------