SvelteKit App using MongoDB as backend with custom authentication and GridFS helper functions.
Create a .env
file at the root of your application and add the following variables :
MONGODB_URI=mongodb+srv://...
DATABASE_NAME=
Use your own connection URI available in your personal space within MongoDB. Add the name of the database you'll be using in your project. If you want to use several databases, feel free to change this behaviour.
A full working backend is already built on top of this template. Create the right database and you'll be able to test it!
I'm using a database which has the following collections :
users
{
email: string,
password: string,
picture?: string
}
projects
{
title: string
}
The homepage is composed of a form asking you to log in or to sign in. Once connected, you'll be able to see the list of all the projects of your "projects" collection (./src/routes/projects/). The user also has a unique profile page where he can upload his own profile picture.
I use a custom method to encrypt the user ID of the cookie. To maximise the security of the cookie it is also set as secure
and httpOnly
(so only accessible in the server), with strict SameSite
attribute. To avoid the cookie to be replayed, it is encrypted using the IP address of the user as key.
If, for some reason, the user has a different IP address than when he first logged in, during the same session, then he'll be disconnected (meaning the cookie is deleted).
Make sure the secret variables are stored in .env
files and that those files are registered in .gitignore
. Push on GitHub and then deploy on Vercel and set your environment variables there using their GUI.
The goal of this template is to help you get started more quickly when building a project with SvelteKit by giving you all the necessary tools such as SCSS
or FontAwesome
. Obviously, if you're using this template, it also means that you need a backend. Implementing MongoDB can be a pain, especially if you want to store files (images for example) so the template comes with a set of basic functions using the GridFS method :
uploadFile
to upload a file (using Blob data)downloadFile
to download a file stored in your database.replaceFile
to delete one, and to upload one with the same name.findUploadedFile
to get the information related to a file. This does not include its raw data.deleteFile
to delete a file.renameFile
to rename a file.deleteBucket
to delete everything in the specified bucket.
Find these helper functions in gfs.ts. Find more functions in db and lib folders. The db
folder contains functions that are server-only (meaning they can't be executed on the client side). On the contrary, the lib
folder contains client-only functions.
This template is using the following dependencies that often come in handy :
- FontAwesome
- SCSS, SASS (
node-sass
&svelte-preprocess
)
Note that despite the use of GridFS
, and contrary to most tutorials out there, mongoose
and multer
are not necessary. By using the API directly the goal is to reduce as much as possible the useless dependencies.
For more details about SCSS/SASS and how to use VSCode with it, see this article.
Also, for more details about FontAwesome, see this article. Note that it is a bit outdated so there is a section explaining that in this README.
And necessary dependencies :
Assuming you're only using the free version of FontAwesome, everything you need is already installed. Use the icons like this:
<script>
import Fa from 'svelte-fa';
import { faArrowDown } from '@fortawesome/free-solid-svg-icons';
</script>
<a>See what's below <Fa icon={faArrowDown} size="xs" /><a>
In this project, only the solid and regular icons are available. Add more icon types like this :
npm i @fortawesome/free-regular-svg-icons
Replace regular
with solid
, brand
or whatever.