Secure Your Media Library with Unkey
This templates utilizes Unkey's API to secure your media library with time-sensitive API keys. Invite others to view and contribute to your collection while ensuring that only authorized users have access to your valuable digital content.
Features
- ๐ท Image upload and display with
hubBlob()
- ๐ผ๏ธ Image Filters: Apply a variety of filters to your images.
- ๐พ Saving: Save your images with applied filters.
- ๐ Cloud Storage: Blob powered by NuxtHub (cloudflare R2).
- ๐ Custom Carousel: Includes a custom carousel component that can be adapted for in-house use.
- ๐๐ป View transition API The View Transitions API provides a mechanism for easily creating animated transitions between different DOM states while also updating the DOM contents in a single step.
- ๐ Nuxt Auth Utils Minimalist Authentication module for Nuxt exposing Vue composables and server utils combined with Unkey for securing and generating temporary access to your API at any scale.
Stack
- NuxtHub - A Nuxt toolkit to build fullstack applications on the edge
- NuxtUI - A UI Library for Modern Web Apps
- Nuxt Fonts - Plug-and-play custom web font optimization and configuration for Nuxt apps
- VueUse - Collection of useful composition APIs
- ESLint with @nuxt/eslint-config, single quotes, no semi
- TypeScript
Getting started
Create a Unkey Root Key
- Navigate to Unkey Root Keys and click "Create New Root Key".
- Name your root key.
- Select the following workspace permissions:
create_key
read_key
encrypt_key
decrypt_key
- Click "Create" and save your root key securely.
Create a Unkey API
- Go to Unkey APIs and click "Create New API".
- Enter a name for the API.
- Click "Create".
Generate your first API Key
This step is required only once for the first user. You can generate additional keys for other users from within the app.
- From the Unkey APIs page, select your newly created API.
- Click "Create Key" in the top right corner.
- In
Meta
section add this JSON:
1{ "role": "contributor" }
- Click "Create" and copy the generated key. You'll use it on your first login.
Setup
- Clone this repository to your local machine.
- Install dependencies using the command
pnpm install
or your favorite package manager.
- Run the application with the command
pnpm dev
or your favorite package manager.
If you don't have pnpm installed, run: corepack enable pnpm
Environment Variables
Create a .env
file in the root directory and populate it with the following environment variables:
1NUXT_UNKEY_ROOT_KEY=your-unkey-root-key
2NUXT_UNKEY_API_ID=your-unkey-api-id
Ensure you replace your-unkey-*
with your actual Unkey credentials.
Development
Remote Storage
Once you deployed your project, you can connect to your remote database locally running:
Deploy
You can deploy this project on your Cloudflare account for free and with zero configuration using NuxtHub.
It's also possible to leverage Cloudflare Pages CI for deploying, learn more about the different options on https://hub.nuxt.com/docs/getting-started/deploy
Learn more about remote storage on https://hub.nuxt.com/docs/getting-started/remote-storage