Blazing fast file uploader and awesome bunker written in node! 🚀
Go to file
Bobby Wibowo 5e5d5c5647
Manage albums admin page, and more!
Resolves #194.

Added pagination for Manage your albums page.

Albums sidebar will now only list 9 albums at most.
Use Manage your albums page to view the rest.
Albums in the list will now have View uploads button after all.

Delete album button for albums renamed to Disable album.
Since techincally the server would've always been disabling the albums
instead of deleting them.
It was something upstream dev's decided, and I haven't bothered changing
its behavior.

I'll work on actual Delete album feature some other days.

As the title says, added Manage albums admin page.

Viewing uploads of an album will hook into albumid: filter key.

I'll work on filter and bulk operations some other days.

Updated styling for disabled albums and users.
Instead of havine a line through them, they will be greyed out.
Disable public page of albums will still use line through however.

Links to album's disabled public page are now clickable.

Added a new button styling is-dangerish.
It'll be orange.

Renamed /api/albums/delete to /api/albums/disable.
For backwards compatibility, /api/albums/delete will still work
but automatically re-routed to /api/albums/disable.

/api/uploads/list will no longer print SQLite errors for moderators
or higher when encountering them.
It was originally used to inform moderators of non-existing colum names
when used for sorting.
But on one of the recent commits, I had added a check for allowed colum
names.

Improved some caching in dashboard page.

Added new entries to cookie policy.

Some other small things.

Bumped v1 version string and rebuilt client assets.
2020-06-01 11:44:16 +07:00
.github Added FUNDING.yml 2020-04-09 03:12:42 +07:00
controllers Manage albums admin page, and more! 2020-06-01 11:44:16 +07:00
database !!! RUN "yarn migrate" !!! 2020-05-16 22:32:32 +07:00
dist Manage albums admin page, and more! 2020-06-01 11:44:16 +07:00
pages/error Updated built-in error pages 2020-05-24 03:45:36 +07:00
public Updated placeholder thumbnail 2020-05-17 05:23:03 +07:00
routes Manage albums admin page, and more! 2020-06-01 11:44:16 +07:00
scripts Updated thumbs.js 2020-05-28 04:23:26 +07:00
src Manage albums admin page, and more! 2020-06-01 11:44:16 +07:00
views Manage albums admin page, and more! 2020-06-01 11:44:16 +07:00
.browserslistrc Updates (very important to read) 2019-09-15 13:20:11 +07:00
.editorconfig Updates 2018-04-13 23:20:57 +07:00
.eslintignore Updated 2019-09-17 11:13:41 +07:00
.eslintrc.js Updated dependencies 2020-05-17 00:11:10 +07:00
.gitignore Updated dependencies 2020-05-19 23:46:23 +07:00
.stylelintignore Updated 2019-09-17 11:13:41 +07:00
.stylelintrc.json Updated 2019-10-06 05:20:59 +07:00
AUTHORS Updated 2019-09-12 14:44:31 +07:00
config.sample.js Switched to BLAKE3 for file hashing [MORE] 2020-05-29 02:52:58 +07:00
Dockerfile update deps and add dockerfile 2018-03-01 22:03:47 +01:00
gulpfile.js Enabled verbose output for gulp linter tasks 2019-10-15 01:45:04 +07:00
LICENSE De loli-safe (#77) 2018-04-26 08:54:07 +02:00
logger.js More improvements to uploads filtering! 2020-04-20 01:19:20 +07:00
lolisafe.js Updated lolisafe.js 2020-05-27 01:18:25 +07:00
nginx-ssl.sample.conf Updated Nginx sample configs 2020-05-28 09:54:40 +07:00
nginx.sample.conf Updated Nginx sample configs 2020-05-28 09:54:40 +07:00
package.json Updated dependencies 2020-05-29 02:58:56 +07:00
README.md !!! RUN "yarn migrate" !!! 2020-05-16 22:32:32 +07:00
real-ip-from-cf Updated IP's 2018-04-01 23:51:25 -07:00
yarn.lock Updated dependencies 2020-05-29 02:58:56 +07:00

lolisafe, a small safe worth protecting

safe.fiery.me

GitHub license

safe.fiery.me

JavaScript Style Guide

This fork is the one being used at https://safe.fiery.me. If you are looking for the original, head to WeebDev/lolisafe.

If you want to use an existing lolisafe database with this fork, run node ./database/migration.js (or yarn migrate) at least once to create the new columns introduced in this branch (don't forget to make a backup).

Configuration file of lolisafe, config.js, is also NOT fully compatible with this fork. There are some options that had been renamed and/or restructured. Please make sure your config matches the sample in config.sample.js before starting.

Running in production mode

  1. Ensure you have at least Node v10.x installed (v12.x should also work just fine).
  2. Clone this repo.
  3. Copy config.sample.js as config.js.
  4. Modify port, domain and privacy options if desired.
  5. Run yarn install --production to install all production dependencies (Yes, use yarn).
  6. Run yarn start to start the service.

Default admin account:
Username: root
Password: changeme

You can also start it with yarn pm2 if you have PM2.

When running in production mode, the safe will use pre-built client-side CSS/JS files from dist directory, while the actual source codes are in src directory.

The pre-built files were processed with postcss-preset-env, cssnano, bublé, and terser.

Running in development mode

This fork has a separate development mode, with which client-side CSS/JS files in src directory will be automatically rebuilt using Gulp tasks.

  1. Follow step 1 to 4 from the production instructions above.
  2. Run yarn install to install all dependencies (including development ones).
  3. Run yarn develop to start the service in development mode.

You can configure the Gulp tasks through gulpfile.js file.

During development, the rebuilt files will be saved in dist-dev directory instead of dist directory. The service will also automatically serve the files from dist-dev directory instead. This is to avoid your IDE's Git from unnecessarily rebuilding diff of the modified files.

Once you feel like your modifications are ready for production usage, you can then run yarn build to build production-ready files that will actually go to dist directory.

Updating when you have modified some files

Try to use git stash.

Basically you'll be doing this:

  1. git stash to stash away your changes.
  2. git pull to pull updates.
  3. yarn install (or yarn install --production) to install dependencies matching the updated yarn.lock file.
  4. git stash pop (or git stash apply) to restore your changes.

Be warned that some files may have been updated too heavily that they will require manual merging.

If you only do some small modifications such as editing views/_globals.njk and not much else, it's generally safe to do this even in a live production environment. But it's still best practice to at least review just what have been updated, and whether you will need to do some manual merging beforehand.

Still, I heavily recommend simply forking this repository and manually merging upstream changes whenever you feel like doing so. Read more about syncing a fork.

Afterwards, you can instead clone your fork in your production server and pull updates from there. You can then choose to only install production dependencies with yarn install --production there (hint: this is how I setup safe.fiery.me).

Script for missing thumbnails

Thumbnails will not be automatically generated for existing files, that had been uploaded prior to enabling thumbnails in the config file.

To generate thumbnails for those files, you can use yarn thumbs.

$ yarn thumbs
$ node ./scripts/thumbs.js

Generate thumbnails.

Usage  :
node scripts/thumbs.js <mode=1|2|3> [force=0|1] [verbose=0|1] [cfcache=0|1]

mode   : 1 = images only, 2 = videos only, 3 = both images and videos
force  : 0 = no force (default), 1 = overwrite existing thumbnails
verbose: 0 = only print missing thumbs (default), 1 = print all
cfcache: 0 = do not clear cloudflare cache (default), 1 = clear cloudflare cache

For example, if you only want to generate thumbnails for image files without overwriting existing ones, you can run yarn thumbs 1.

Or if you want to generate thumbnails for both image and video files, while also overwriting existsing ones, you can run yarn thumbs 3 1.

ClamAV support

This fork has an optional virus scanning support using ClamAV, through clamdjs library.

It will scan new files right after they are uploaded. It will then alert the uploaders of the virus names in ClamAV's database if their files are dirty.

Unfortunately, this will slow down uploads processing as it has to wait for scan results before responding the uploaders, however it's still highly recommended for public usage (or at least if you find Google Safe Search too annoying).

To enable this, make sure you have ClamAV daemon running, then fill in the daemon's IP and port into your config file.

From the config file you can also choose to exclude certain extensions from being scanned to lessen the burden on your server.