Compare commits
30 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 0dfad07399 | |||
| e6b8b7d0fa | |||
| 0cdba0d764 | |||
| 9c0e0baf95 | |||
| 925d382f2f | |||
| 3ff97569f5 | |||
| 52a5ae9180 | |||
| 4647fbda16 | |||
| 647d26db85 | |||
| 40b8ca91ee | |||
| d92a58b2ad | |||
| 5a43ebe06f | |||
| 56259adaf7 | |||
| 470f272183 | |||
| e2d37c2efe | |||
| 487cca530b | |||
| 9e867fc0b3 | |||
| 23ec1989f7 | |||
| 1c3608743e | |||
| 33bb3cc550 | |||
| fe1807fcd5 | |||
| aaef56cb29 | |||
| 32846c1e44 | |||
| 771e071005 | |||
| 2ba8bdadfc | |||
| 6c057d4cd7 | |||
| 00259fc865 | |||
| 3356ffd052 | |||
| 6ca94dc574 | |||
| 182b760404 |
@ -1,2 +1,5 @@
|
|||||||
dist
|
dist
|
||||||
node_modules
|
node_modules
|
||||||
|
docs
|
||||||
|
.github
|
||||||
|
.vscode
|
||||||
|
|||||||
82
.github/workflows/studio.yml
vendored
Normal file
82
.github/workflows/studio.yml
vendored
Normal file
@ -0,0 +1,82 @@
|
|||||||
|
|
||||||
|
name: studio-nuxt-build
|
||||||
|
run-name: studio nuxt build
|
||||||
|
|
||||||
|
on:
|
||||||
|
# Runs on pushes targeting the default branch
|
||||||
|
push:
|
||||||
|
branches: ["main"]
|
||||||
|
|
||||||
|
# Allows you to run this workflow manually from the Actions tab
|
||||||
|
workflow_dispatch:
|
||||||
|
|
||||||
|
# Add write workflow permissions
|
||||||
|
permissions:
|
||||||
|
contents: write
|
||||||
|
|
||||||
|
# Allow one concurrent deployment
|
||||||
|
concurrency:
|
||||||
|
group: "pages"
|
||||||
|
cancel-in-progress: true
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
# Build job
|
||||||
|
build-and-deploy:
|
||||||
|
if: startsWith(github.event.head_commit.message, 'docs:')
|
||||||
|
runs-on: ${{ matrix.os }}
|
||||||
|
defaults:
|
||||||
|
run:
|
||||||
|
working-directory: docs
|
||||||
|
|
||||||
|
strategy:
|
||||||
|
matrix:
|
||||||
|
os: [ubuntu-latest]
|
||||||
|
node: [18]
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Checkout
|
||||||
|
uses: actions/checkout@v3
|
||||||
|
|
||||||
|
- name: Identify package manager
|
||||||
|
id: pkgman
|
||||||
|
run: |
|
||||||
|
cache=`[ -f "docs/pnpm-lock.yaml" ] && echo "pnpm" || ([ -f "docs/package-lock.json" ] && echo "npm" || ([ -f "docs/yarn.lock" ] && echo "yarn" || echo ""))`
|
||||||
|
package_manager=`[ ! -z "$cache" ] && echo "$cache" || echo "pnpm"`
|
||||||
|
echo "cache=$cache" >> $GITHUB_OUTPUT
|
||||||
|
echo "package_manager=$package_manager" >> $GITHUB_OUTPUT
|
||||||
|
|
||||||
|
- uses: pnpm/action-setup@v2.2.4
|
||||||
|
if: ${{ steps.pkgman.outputs.package_manager == 'pnpm' }}
|
||||||
|
name: Install pnpm
|
||||||
|
id: pnpm-install
|
||||||
|
with:
|
||||||
|
version: 7
|
||||||
|
|
||||||
|
- uses: actions/setup-node@v3
|
||||||
|
with:
|
||||||
|
version: ${{ matrix.node }}
|
||||||
|
cache: ${{ steps.pkgman.outputs.cache }}
|
||||||
|
|
||||||
|
- name: Install dependencies
|
||||||
|
run: ${{ steps.pkgman.outputs.package_manager }} install
|
||||||
|
|
||||||
|
- name: Install @nuxthq/studio
|
||||||
|
run: ${{ steps.pkgman.outputs.package_manager }} add -D @nuxthq/studio
|
||||||
|
|
||||||
|
- name: Create .nuxtrc
|
||||||
|
run: echo 'modules[]=@nuxthq/studio' > .nuxtrc
|
||||||
|
|
||||||
|
- name: Generate
|
||||||
|
run: ${{ steps.pkgman.outputs.package_manager }} nuxi generate
|
||||||
|
env:
|
||||||
|
NUXT_PUBLIC_STUDIO_API_URL: https://api.nuxt.studio
|
||||||
|
NUXT_PUBLIC_STUDIO_TOKENS: 6222c5e49391ad99e20e3c1b1a475c656436e8b0877c32021147d8727205c440
|
||||||
|
|
||||||
|
- name: Add .nojekyll file
|
||||||
|
run: touch .output/public/.nojekyll
|
||||||
|
|
||||||
|
# Deployment job
|
||||||
|
- name: Deploy 🚀
|
||||||
|
uses: JamesIves/github-pages-deploy-action@v4
|
||||||
|
with:
|
||||||
|
folder: docs/.output/public
|
||||||
1
.nuxtrc
1
.nuxtrc
@ -1,2 +1 @@
|
|||||||
imports.autoImport=false
|
|
||||||
typescript.includeWorkspace=true
|
typescript.includeWorkspace=true
|
||||||
|
|||||||
13
.vscode/settings.json
vendored
13
.vscode/settings.json
vendored
@ -1,16 +1,3 @@
|
|||||||
{
|
{
|
||||||
"editor.tabSize": 2,
|
"editor.tabSize": 2,
|
||||||
"files.exclude": {
|
|
||||||
"**/.git": true,
|
|
||||||
"**/.svn": true,
|
|
||||||
"**/.hg": true,
|
|
||||||
"**/CVS": true,
|
|
||||||
"**/.DS_Store": true,
|
|
||||||
"**/Thumbs.db": true,
|
|
||||||
"**/node_modules": true,
|
|
||||||
"**/.nuxt": true,
|
|
||||||
"**/.output": true,
|
|
||||||
"**/dist": true,
|
|
||||||
"**/.nuxtrc": true
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
73
CHANGELOG.md
73
CHANGELOG.md
@ -1,6 +1,79 @@
|
|||||||
# Changelog
|
# Changelog
|
||||||
|
|
||||||
|
|
||||||
|
## v0.0.9
|
||||||
|
|
||||||
|
[compare changes](https://github.com/arashsheyda/nuxt-mongoose/compare/v0.0.8...v0.0.9)
|
||||||
|
|
||||||
|
### 🚀 Enhancements
|
||||||
|
|
||||||
|
- Add possibility to type mongoose model ([#8](https://github.com/arashsheyda/nuxt-mongoose/pull/8))
|
||||||
|
- Mongoose schema hooks ([d92a58b](https://github.com/arashsheyda/nuxt-mongoose/commit/d92a58b))
|
||||||
|
|
||||||
|
### 🩹 Fixes
|
||||||
|
|
||||||
|
- Update connection message in logger ([#10](https://github.com/arashsheyda/nuxt-mongoose/pull/10))
|
||||||
|
|
||||||
|
### 📖 Documentation
|
||||||
|
|
||||||
|
- **utils:** Add hooks and improve documentation ([647d26d](https://github.com/arashsheyda/nuxt-mongoose/commit/647d26d))
|
||||||
|
- **utils:** Fix model options type ([3ff9756](https://github.com/arashsheyda/nuxt-mongoose/commit/3ff9756))
|
||||||
|
- Add types link ([9c0e0ba](https://github.com/arashsheyda/nuxt-mongoose/commit/9c0e0ba))
|
||||||
|
|
||||||
|
### 🏡 Chore
|
||||||
|
|
||||||
|
- Fix defineNitroPlugin patch ([#9](https://github.com/arashsheyda/nuxt-mongoose/pull/9))
|
||||||
|
- Example env ([40b8ca9](https://github.com/arashsheyda/nuxt-mongoose/commit/40b8ca9))
|
||||||
|
- Fix defineNitroPlugin patch " ([#9](https://github.com/arashsheyda/nuxt-mongoose/pull/9))
|
||||||
|
- Update dependencies ([925d382](https://github.com/arashsheyda/nuxt-mongoose/commit/925d382))
|
||||||
|
- Lint ([0cdba0d](https://github.com/arashsheyda/nuxt-mongoose/commit/0cdba0d))
|
||||||
|
- Fix tsconfig for build time ([e6b8b7d](https://github.com/arashsheyda/nuxt-mongoose/commit/e6b8b7d))
|
||||||
|
|
||||||
|
### ❤️ Contributors
|
||||||
|
|
||||||
|
- Arash Sheyda <sheidaeearash1999@gmail.com>
|
||||||
|
- Arash
|
||||||
|
- Amir-al-mohamad111
|
||||||
|
- Oumar Barry ([@oumarbarry](http://github.com/oumarbarry))
|
||||||
|
|
||||||
|
## v0.0.8
|
||||||
|
|
||||||
|
[compare changes](https://github.com/arashsheyda/nuxt-mongoose/compare/v0.0.7...v0.0.8)
|
||||||
|
|
||||||
|
|
||||||
|
### 🚀 Enhancements
|
||||||
|
|
||||||
|
- Documentation ([6ca94dc](https://github.com/arashsheyda/nuxt-mongoose/commit/6ca94dc))
|
||||||
|
|
||||||
|
### 🩹 Fixes
|
||||||
|
|
||||||
|
- Module options type ([182b760](https://github.com/arashsheyda/nuxt-mongoose/commit/182b760))
|
||||||
|
- Run studio action only for docs ([33bb3cc](https://github.com/arashsheyda/nuxt-mongoose/commit/33bb3cc))
|
||||||
|
- Resource generator modelsDir output ([1c36087](https://github.com/arashsheyda/nuxt-mongoose/commit/1c36087))
|
||||||
|
|
||||||
|
### 💅 Refactors
|
||||||
|
|
||||||
|
- Reuse vite's websocket ([aaef56c](https://github.com/arashsheyda/nuxt-mongoose/commit/aaef56c))
|
||||||
|
|
||||||
|
### 📖 Documentation
|
||||||
|
|
||||||
|
- Remove devtools ([6c057d4](https://github.com/arashsheyda/nuxt-mongoose/commit/6c057d4))
|
||||||
|
- **devtools:** Demo video ([2ba8bda](https://github.com/arashsheyda/nuxt-mongoose/commit/2ba8bda))
|
||||||
|
- Style ([23ec198](https://github.com/arashsheyda/nuxt-mongoose/commit/23ec198))
|
||||||
|
- Favicon ([9e867fc](https://github.com/arashsheyda/nuxt-mongoose/commit/9e867fc))
|
||||||
|
|
||||||
|
### 🏡 Chore
|
||||||
|
|
||||||
|
- Playground example ([3356ffd](https://github.com/arashsheyda/nuxt-mongoose/commit/3356ffd))
|
||||||
|
- **deployment:** Add workflow file ([00259fc](https://github.com/arashsheyda/nuxt-mongoose/commit/00259fc))
|
||||||
|
- Update cover ([487cca5](https://github.com/arashsheyda/nuxt-mongoose/commit/487cca5))
|
||||||
|
|
||||||
|
### ❤️ Contributors
|
||||||
|
|
||||||
|
- Arash
|
||||||
|
- Arash Sheyda <sheidaeearash1999@gmail.com>
|
||||||
|
- Arashsheyda <sheidaeearash1999@gmail.com>
|
||||||
|
|
||||||
## v0.0.7
|
## v0.0.7
|
||||||
|
|
||||||
[compare changes](https://github.com/arashsheyda/nuxt-mongoose/compare/v0.0.6...v0.0.7)
|
[compare changes](https://github.com/arashsheyda/nuxt-mongoose/compare/v0.0.6...v0.0.7)
|
||||||
|
|||||||
@ -1,4 +1,4 @@
|
|||||||

|

|
||||||
|
|
||||||
<div align="center">
|
<div align="center">
|
||||||
<h1>Nuxt Mongoose</h1>
|
<h1>Nuxt Mongoose</h1>
|
||||||
|
|||||||
@ -1,24 +0,0 @@
|
|||||||
import { defineBuildConfig } from 'unbuild'
|
|
||||||
|
|
||||||
export default defineBuildConfig({
|
|
||||||
entries: [
|
|
||||||
'src/module',
|
|
||||||
// Chunking
|
|
||||||
'src/types',
|
|
||||||
],
|
|
||||||
externals: [
|
|
||||||
'nuxt',
|
|
||||||
'nuxt/schema',
|
|
||||||
'vite',
|
|
||||||
'@nuxt/kit',
|
|
||||||
'@nuxt/schema',
|
|
||||||
// Type only
|
|
||||||
'vue',
|
|
||||||
'vue-router',
|
|
||||||
'unstorage',
|
|
||||||
'nitropack',
|
|
||||||
],
|
|
||||||
rollup: {
|
|
||||||
inlineDependencies: true,
|
|
||||||
},
|
|
||||||
})
|
|
||||||
@ -81,8 +81,9 @@ function editDocument(document: any) {
|
|||||||
async function saveDocument(document: any, create = true) {
|
async function saveDocument(document: any, create = true) {
|
||||||
const method = create ? rpc.createDocument : rpc.updateDocument
|
const method = create ? rpc.createDocument : rpc.updateDocument
|
||||||
const newDocument = await method(props.collection, document)
|
const newDocument = await method(props.collection, document)
|
||||||
|
// TODO: show toast
|
||||||
if (newDocument?.error)
|
if (newDocument?.error)
|
||||||
return alert(newDocument.error.message)
|
return
|
||||||
|
|
||||||
if (create) {
|
if (create) {
|
||||||
if (!documents.value.length) {
|
if (!documents.value.length) {
|
||||||
@ -105,8 +106,9 @@ function discardEditing() {
|
|||||||
|
|
||||||
async function deleteDocument(document: any) {
|
async function deleteDocument(document: any) {
|
||||||
const newDocument = await rpc.deleteDocument(props.collection, document._id)
|
const newDocument = await rpc.deleteDocument(props.collection, document._id)
|
||||||
|
// TODO: show toast
|
||||||
if (newDocument.deletedCount === 0)
|
if (newDocument.deletedCount === 0)
|
||||||
return alert('Failed to delete document')
|
return
|
||||||
|
|
||||||
documents.value = documents.value.filter((doc: any) => doc._id !== document._id)
|
documents.value = documents.value.filter((doc: any) => doc._id !== document._id)
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,14 +1,15 @@
|
|||||||
import { createBirpc } from 'birpc'
|
import { createBirpc } from 'birpc'
|
||||||
import { parse, stringify } from 'flatted'
|
import { parse, stringify } from 'flatted'
|
||||||
|
import { createHotContext } from 'vite-hot-client'
|
||||||
import type { ClientFunctions, ServerFunctions } from '../../src/types'
|
import type { ClientFunctions, ServerFunctions } from '../../src/types'
|
||||||
import { PATH_ENTRY } from '../../src/constants'
|
import { WS_EVENT_NAME } from '../../src/constants'
|
||||||
|
|
||||||
const RECONNECT_INTERVAL = 2000
|
|
||||||
|
|
||||||
export const wsConnecting = ref(true)
|
export const wsConnecting = ref(true)
|
||||||
export const wsError = ref<any>()
|
export const wsError = ref<any>()
|
||||||
|
export const wsConnectingDebounced = useDebounce(wsConnecting, 2000)
|
||||||
|
|
||||||
let connectPromise = connectWS()
|
const connectPromise = connectVite()
|
||||||
|
// eslint-disable-next-line @typescript-eslint/ban-types
|
||||||
let onMessage: Function = () => {}
|
let onMessage: Function = () => {}
|
||||||
|
|
||||||
export const clientFunctions = {
|
export const clientFunctions = {
|
||||||
@ -19,9 +20,11 @@ export const extendedRpcMap = new Map<string, any>()
|
|||||||
|
|
||||||
export const rpc = createBirpc<ServerFunctions>(clientFunctions, {
|
export const rpc = createBirpc<ServerFunctions>(clientFunctions, {
|
||||||
post: async (d) => {
|
post: async (d) => {
|
||||||
(await connectPromise).send(d)
|
(await connectPromise).send(WS_EVENT_NAME, d)
|
||||||
|
},
|
||||||
|
on: (fn) => {
|
||||||
|
onMessage = fn
|
||||||
},
|
},
|
||||||
on: (fn) => { onMessage = fn },
|
|
||||||
serialize: stringify,
|
serialize: stringify,
|
||||||
deserialize: parse,
|
deserialize: parse,
|
||||||
resolver(name, fn) {
|
resolver(name, fn) {
|
||||||
@ -35,35 +38,22 @@ export const rpc = createBirpc<ServerFunctions>(clientFunctions, {
|
|||||||
onError(error, name) {
|
onError(error, name) {
|
||||||
console.error(`[nuxt-devtools] RPC error on executing "${name}":`, error)
|
console.error(`[nuxt-devtools] RPC error on executing "${name}":`, error)
|
||||||
},
|
},
|
||||||
|
timeout: 120_000,
|
||||||
})
|
})
|
||||||
|
|
||||||
async function connectWS() {
|
async function connectVite() {
|
||||||
const wsUrl = new URL(`ws://host${PATH_ENTRY}`)
|
const hot = await createHotContext()
|
||||||
wsUrl.protocol = location.protocol === 'https:' ? 'wss:' : 'ws:'
|
|
||||||
wsUrl.host = 'localhost:3000'
|
|
||||||
|
|
||||||
const ws = new WebSocket(wsUrl.toString())
|
if (!hot)
|
||||||
ws.addEventListener('message', e => onMessage(String(e.data)))
|
throw new Error('Unable to connect to devtools')
|
||||||
ws.addEventListener('error', (e) => {
|
|
||||||
console.error(e)
|
hot.on(WS_EVENT_NAME, (data) => {
|
||||||
wsError.value = e
|
onMessage(data)
|
||||||
})
|
})
|
||||||
ws.addEventListener('close', () => {
|
|
||||||
// eslint-disable-next-line no-console
|
|
||||||
console.log('[nuxt-devtools] WebSocket closed, reconnecting...')
|
|
||||||
wsConnecting.value = true
|
|
||||||
setTimeout(async () => {
|
|
||||||
connectPromise = connectWS()
|
|
||||||
}, RECONNECT_INTERVAL)
|
|
||||||
})
|
|
||||||
wsConnecting.value = true
|
|
||||||
if (ws.readyState !== WebSocket.OPEN)
|
|
||||||
await new Promise(resolve => ws.addEventListener('open', resolve))
|
|
||||||
|
|
||||||
// eslint-disable-next-line no-console
|
// TODO:
|
||||||
console.log('[nuxt-devtools] WebSocket connected.')
|
// hot.on('vite:connect', (data) => {})
|
||||||
wsConnecting.value = false
|
// hot.on('vite:disconnect', (data) => {})
|
||||||
wsError.value = null
|
|
||||||
|
|
||||||
return ws
|
return hot
|
||||||
}
|
}
|
||||||
|
|||||||
12
docs/.gitignore
vendored
Normal file
12
docs/.gitignore
vendored
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
node_modules
|
||||||
|
*.iml
|
||||||
|
.idea
|
||||||
|
*.log*
|
||||||
|
.nuxt
|
||||||
|
.vscode
|
||||||
|
.DS_Store
|
||||||
|
coverage
|
||||||
|
dist
|
||||||
|
sw.*
|
||||||
|
.env
|
||||||
|
.output
|
||||||
2
docs/.npmrc
Normal file
2
docs/.npmrc
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
shamefully-hoist=true
|
||||||
|
strict-peer-dependencies=false
|
||||||
42
docs/app.config.ts
Normal file
42
docs/app.config.ts
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
export default defineAppConfig({
|
||||||
|
docus: {
|
||||||
|
title: 'Nuxt Mongoose',
|
||||||
|
description: 'A Nuxt module for simplifying the use of Mongoose in your project.',
|
||||||
|
image: '/cover.jpg',
|
||||||
|
socials: {
|
||||||
|
twitter: 'arash_sheyda',
|
||||||
|
github: 'arashsheyda/nuxt-mongoose',
|
||||||
|
},
|
||||||
|
github: {
|
||||||
|
dir: 'docs/content',
|
||||||
|
branch: 'main',
|
||||||
|
repo: 'nuxt-mongoose',
|
||||||
|
owner: 'arashsheyda',
|
||||||
|
edit: true,
|
||||||
|
},
|
||||||
|
aside: {
|
||||||
|
level: 0,
|
||||||
|
collapsed: false,
|
||||||
|
exclude: [],
|
||||||
|
},
|
||||||
|
main: {
|
||||||
|
padded: true,
|
||||||
|
fluid: true,
|
||||||
|
},
|
||||||
|
header: {
|
||||||
|
logo: true,
|
||||||
|
showLinkIcon: true,
|
||||||
|
exclude: [],
|
||||||
|
fluid: true,
|
||||||
|
},
|
||||||
|
footer: {
|
||||||
|
fluid: true,
|
||||||
|
iconLinks: [
|
||||||
|
{
|
||||||
|
href: 'https://nuxt.com',
|
||||||
|
icon: 'simple-icons:nuxtdotjs',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
})
|
||||||
18
docs/components/content/Logo.vue
Normal file
18
docs/components/content/Logo.vue
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
<template>
|
||||||
|
<svg id="NuxtMongooseLogo" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 235.5 33.2">
|
||||||
|
<rect width="32" height="32" rx="7.5" style="fill:#023430" />
|
||||||
|
<path d="M21.4,13.4C20.1,7.6,17.3,6.1,16.6,5a10.1,10.1,0,0,1-.7-1.5,1.6,1.6,0,0,1-.6,1.2,14.1,14.1,0,0,0-4.9,10.5c-.3,6.1,4.5,9.9,5.1,10.3a1.4,1.4,0,0,0,1.4-.2,12.1,12.1,0,0,0,4.5-11.9" style="fill:#10aa50" />
|
||||||
|
<path d="M16.1,22.2a17.8,17.8,0,0,1-.5,3.3s.2,1.5.3,3h.5a30.6,30.6,0,0,1,.5-3.2C16.3,25,16.1,23.6,16.1,22.2Z" style="fill:#b8c4c2" />
|
||||||
|
<path d="M16.9,25.3c-.6-.3-.8-1.7-.8-3.1s.2-4.3.1-6.5,0-10.7-.3-12.1L16.6,5c.7,1.1,3.5,2.6,4.8,8.4A12,12,0,0,1,16.9,25.3Z" style="fill:#12924f" />
|
||||||
|
<text transform="translate(32.8 25.6)" style="font-size:25.818214416503906px;font-family:var(--font-sans);font-weight:700">
|
||||||
|
<tspan fill="currentColor" x="4" y="0">Nuxt</tspan>
|
||||||
|
<tspan x="67.8" y="0" style="fill:#10aa50">Mongoose</tspan>
|
||||||
|
</text>
|
||||||
|
</svg>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<style>
|
||||||
|
.NuxtMongooseLogo {
|
||||||
|
font-family: serif;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
36
docs/content/0.index.md
Normal file
36
docs/content/0.index.md
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
---
|
||||||
|
title: Home
|
||||||
|
navigation: false
|
||||||
|
layout: page
|
||||||
|
main:
|
||||||
|
fluid: false
|
||||||
|
---
|
||||||
|
|
||||||
|
:ellipsis{right=0px width=75% blur=150px}
|
||||||
|
|
||||||
|
::block-hero
|
||||||
|
---
|
||||||
|
cta:
|
||||||
|
- Get started
|
||||||
|
- /getting-started/setup
|
||||||
|
secondary:
|
||||||
|
- Open on GitHub →
|
||||||
|
- https://github.com/arashsheyda/nuxt-mongoose
|
||||||
|
---
|
||||||
|
|
||||||
|
#title
|
||||||
|
Nuxt [Mongoose]{style="color: var(--color-primary-500)"}
|
||||||
|
|
||||||
|
#description
|
||||||
|
A Nuxt module for simplifying the use of [Mongoose](https://mongoosejs.com/) in your project.
|
||||||
|
|
||||||
|
#support
|
||||||
|
::terminal
|
||||||
|
---
|
||||||
|
content:
|
||||||
|
- npm i nuxt-mongoose -D
|
||||||
|
---
|
||||||
|
::
|
||||||
|
::
|
||||||
|
|
||||||
|
<!-- TODO: features -->
|
||||||
56
docs/content/1.getting-started/1.setup.md
Normal file
56
docs/content/1.getting-started/1.setup.md
Normal file
@ -0,0 +1,56 @@
|
|||||||
|
# Setup
|
||||||
|
|
||||||
|
A Nuxt module for simplifying the use of Mongoose in your project.
|
||||||
|
|
||||||
|
## Installation
|
||||||
|
|
||||||
|
1. Install `nuxt-mongoose` to your dependencies.
|
||||||
|
|
||||||
|
::code-group
|
||||||
|
|
||||||
|
```bash [pnpm]
|
||||||
|
pnpm add nuxt-mongoose -D
|
||||||
|
```
|
||||||
|
|
||||||
|
```bash [npm]
|
||||||
|
npm install nuxt-mongoose -D
|
||||||
|
```
|
||||||
|
|
||||||
|
```bash [yarn]
|
||||||
|
yarn add nuxt-mongoose -D
|
||||||
|
```
|
||||||
|
|
||||||
|
::
|
||||||
|
|
||||||
|
2. Add `nuxt-mongoose` to the `modules` section of your `nuxt.config` file.
|
||||||
|
|
||||||
|
```ts [nuxt.config]
|
||||||
|
export default defineNuxtConfig({
|
||||||
|
modules: [
|
||||||
|
'nuxt-mongoose',
|
||||||
|
],
|
||||||
|
})
|
||||||
|
```
|
||||||
|
|
||||||
|
::alert{ type=success }
|
||||||
|
That's it! You can now use Mongoose in your Nuxt app ✨
|
||||||
|
::
|
||||||
|
|
||||||
|
|
||||||
|
## Options
|
||||||
|
|
||||||
|
You can configure the module by adding a `mongoose` section to your `nuxt.config` file.
|
||||||
|
read more about [Mongoose options](/getting-started/configuration).
|
||||||
|
|
||||||
|
```ts [nuxt.config]
|
||||||
|
export default defineNuxtConfig({
|
||||||
|
mongoose: {
|
||||||
|
// Options
|
||||||
|
},
|
||||||
|
})
|
||||||
|
```
|
||||||
|
If you want to configure only the `uri` just add `MONGODB_URI` in your `.env` file.
|
||||||
|
|
||||||
|
```env
|
||||||
|
MONGODB_URI=YOUR_MONGO_URI
|
||||||
|
```
|
||||||
21
docs/content/1.getting-started/3.configuration.md
Normal file
21
docs/content/1.getting-started/3.configuration.md
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
# Configuration
|
||||||
|
|
||||||
|
Configure Nuxt Mongoose with the `mongoose` property.
|
||||||
|
|
||||||
|
```ts [nuxt.config]
|
||||||
|
export default defineNuxtConfig({
|
||||||
|
mongoose: {
|
||||||
|
uri: 'process.env.MONGODB_URI',
|
||||||
|
options: {},
|
||||||
|
modelsDir: 'models',
|
||||||
|
devtools: true,
|
||||||
|
},
|
||||||
|
})
|
||||||
|
```
|
||||||
|
|
||||||
|
| **Key** | **Type** | **Default** | **Description** |
|
||||||
|
| ---------------------------- | ---------- | ----------------------- | ---------------------------------------------------------------------------------------------------- |
|
||||||
|
| `uri` | `string` | process.env.MONGODB_URI | Connection Uri String |
|
||||||
|
| `options` | `ConnectOptions` | { } | Connection Options |
|
||||||
|
| `modelsDir` | `string` | models | The models(schema) directory located in `server` for auto-import |
|
||||||
|
| `devtools` | `boolean` | true | Enable Mongoose module in [`Nuxt Devtools`](https://github.com/nuxt/devtools) |
|
||||||
2
docs/content/1.getting-started/_dir.yml
Normal file
2
docs/content/1.getting-started/_dir.yml
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
icon: tabler:brand-mongodb
|
||||||
|
navigation.redirect: /getting-started/setup
|
||||||
69
docs/content/2.api/1.utils.md
Normal file
69
docs/content/2.api/1.utils.md
Normal file
@ -0,0 +1,69 @@
|
|||||||
|
# Utils
|
||||||
|
|
||||||
|
Discover all available utils.
|
||||||
|
|
||||||
|
## `defineMongooseModel`
|
||||||
|
|
||||||
|
This function creates a new Mongoose model with schema. Example usage:
|
||||||
|
|
||||||
|
::code-group
|
||||||
|
|
||||||
|
```ts [named parameters]
|
||||||
|
export const User = defineMongooseModel({
|
||||||
|
name: 'User',
|
||||||
|
schema: {
|
||||||
|
email: {
|
||||||
|
type: 'string',
|
||||||
|
required: true,
|
||||||
|
unique: true,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
options: {
|
||||||
|
|
||||||
|
},
|
||||||
|
hooks(schema) {
|
||||||
|
|
||||||
|
},
|
||||||
|
})
|
||||||
|
```
|
||||||
|
|
||||||
|
```ts [positional parameters]
|
||||||
|
import { defineMongooseModel } from '#nuxt/mongoose'
|
||||||
|
|
||||||
|
export const User = defineMongooseModel('User', {
|
||||||
|
email: {
|
||||||
|
type: 'string',
|
||||||
|
required: true,
|
||||||
|
unique: true,
|
||||||
|
},
|
||||||
|
}, {
|
||||||
|
|
||||||
|
}, (schema) => {
|
||||||
|
|
||||||
|
})
|
||||||
|
```
|
||||||
|
|
||||||
|
::
|
||||||
|
|
||||||
|
|
||||||
|
| **Key** | **Type** | **Require** | **Description** |
|
||||||
|
| ---------------------------- | ----------- | ----------- | ----- |
|
||||||
|
| `name` | `string` | true | Name of Model |
|
||||||
|
| `schema` | [`SchemaDefinition`](https://mongoosejs.com/docs/schematypes.html) | true | Schema Definition of Model |
|
||||||
|
| `options` | [`SchemaOptions`](https://mongoosejs.com/docs/guide.html#options) | false | Schema Options for Model |
|
||||||
|
| `hooks` | [`(schema: Schema<T>) => void`](https://mongoosejs.com/docs/middleware.html) | false | Schema Hooks Function to customize Model |
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
## `defineMongooseConnection`
|
||||||
|
This function creates a new Mongoose connection.
|
||||||
|
- `nuxt-mongoose` provides a default connection for you, it auto-register a plugin in nitro, so you don't need to use this function unless you want to create a new connection. more info [here](https://github.com/arashsheyda/nuxt-mongoose/blob/main/src/runtime/server/plugins/mongoose.db.ts).
|
||||||
|
|
||||||
|
Example usage:
|
||||||
|
|
||||||
|
```ts
|
||||||
|
import { defineMongooseConnection } from '#nuxt/mongoose'
|
||||||
|
|
||||||
|
export const connection = defineMongooseConnection('mongodb://127.0.0.1/nuxt-mongoose')
|
||||||
|
```
|
||||||
8
docs/content/2.api/2.devtools.md
Normal file
8
docs/content/2.api/2.devtools.md
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
# Devtools (beta)
|
||||||
|
|
||||||
|
`nuxt-mongoose` comes with a [Nuxt Devtools](https://github.com/nuxt/devtools) module that allows you to manage your collections and generate api-endpoints & schemas...
|
||||||
|
|
||||||
|
Here is a demo video:
|
||||||
|
|
||||||
|
:video-player{src="https://www.youtube.com/watch?v=hK0npSfr_Vs"}
|
||||||
|
|
||||||
2
docs/content/2.api/_dir.yml
Normal file
2
docs/content/2.api/_dir.yml
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
title: API
|
||||||
|
icon: tabler:book
|
||||||
19
docs/nuxt.config.ts
Normal file
19
docs/nuxt.config.ts
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
export default defineNuxtConfig({
|
||||||
|
extends: '@nuxt-themes/docus',
|
||||||
|
|
||||||
|
app: {
|
||||||
|
head: {
|
||||||
|
link: [
|
||||||
|
{
|
||||||
|
rel: 'icon',
|
||||||
|
type: 'image/x-icon',
|
||||||
|
href: '/mongoose-icon.svg',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
|
||||||
|
modules: [
|
||||||
|
'@nuxthq/studio',
|
||||||
|
],
|
||||||
|
})
|
||||||
17
docs/package.json
Normal file
17
docs/package.json
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
{
|
||||||
|
"name": "docus-starter",
|
||||||
|
"version": "0.1.0",
|
||||||
|
"private": true,
|
||||||
|
"scripts": {
|
||||||
|
"dev": "nuxi dev",
|
||||||
|
"build": "nuxi build",
|
||||||
|
"generate": "nuxi generate",
|
||||||
|
"preview": "nuxi preview",
|
||||||
|
"lint": "eslint ."
|
||||||
|
},
|
||||||
|
"devDependencies": {
|
||||||
|
"@nuxt-themes/docus": "^1.12.0",
|
||||||
|
"@nuxthq/studio": "^0.13.2",
|
||||||
|
"nuxt": "^3.5.0"
|
||||||
|
}
|
||||||
|
}
|
||||||
6655
docs/pnpm-lock.yaml
generated
Normal file
6655
docs/pnpm-lock.yaml
generated
Normal file
File diff suppressed because it is too large
Load Diff
BIN
docs/public/cover.jpg
Normal file
BIN
docs/public/cover.jpg
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 46 KiB |
1
docs/public/mongoose-icon.svg
Normal file
1
docs/public/mongoose-icon.svg
Normal file
@ -0,0 +1 @@
|
|||||||
|
<svg xmlns="http://www.w3.org/2000/svg" width="32" height="32" viewBox="0 0 256 256"><g fill="none"><rect width="256" height="256" fill="#023430" rx="60"/><path fill="#10AA50" d="M171.173 107.591c-10.537-46.481-32.497-58.855-38.099-67.602A99.398 99.398 0 0 1 126.949 28c-.296 4.13-.84 6.73-4.35 9.862c-7.047 6.283-36.977 30.673-39.496 83.486c-2.347 49.242 36.2 79.605 41.292 82.744c3.916 1.927 8.685.041 11.012-1.728c18.581-12.752 43.969-46.75 35.786-94.773"/><path fill="#B8C4C2" d="M128.545 177.871c-.97 12.188-1.665 19.27-4.129 26.235c0 0 1.617 11.603 2.753 23.894h4.019a223.446 223.446 0 0 1 4.384-25.732c-5.203-2.56-6.827-13.702-7.027-24.397Z"/><path fill="#12924F" d="M135.565 202.275c-5.258-2.429-6.779-13.806-7.013-24.404a499.824 499.824 0 0 0 1.136-52.545c-.276-9.194.13-85.158-2.265-96.28a92.425 92.425 0 0 0 5.651 10.936c5.602 8.754 27.569 21.128 38.099 67.609c8.203 47.941-17.047 81.849-35.608 94.684Z"/></g></svg>
|
||||||
|
After Width: | Height: | Size: 926 B |
@ -1,26 +1 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
<svg id="Layer_1" data-name="Layer 1" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 235.5 33.2"><rect width="32" height="32" rx="7.5" style="fill:#023430"/><path d="M21.4,13.4C20.1,7.6,17.3,6.1,16.6,5a10.1,10.1,0,0,1-.7-1.5,1.6,1.6,0,0,1-.6,1.2,14.1,14.1,0,0,0-4.9,10.5c-.3,6.1,4.5,9.9,5.1,10.3a1.4,1.4,0,0,0,1.4-.2,12.1,12.1,0,0,0,4.5-11.9" style="fill:#10aa50"/><path d="M16.1,22.2a17.8,17.8,0,0,1-.5,3.3s.2,1.5.3,3h.5a30.6,30.6,0,0,1,.5-3.2C16.3,25,16.1,23.6,16.1,22.2Z" style="fill:#b8c4c2"/><path d="M16.9,25.3c-.6-.3-.8-1.7-.8-3.1s.2-4.3.1-6.5,0-10.7-.3-12.1L16.6,5c.7,1.1,3.5,2.6,4.8,8.4A12,12,0,0,1,16.9,25.3Z" style="fill:#12924f"/><text transform="translate(32.8 25.6)" style="font-size:25.818214416503906px;font-family:OpenSans-Bold, Open Sans;font-weight:700">Nuxt <tspan x="70.8" y="0" style="fill:#10aa50">Mongoose</tspan></text></svg>
|
||||||
<!-- Generator: Adobe Illustrator 25.0.0, SVG Export Plug-In . SVG Version: 6.00 Build 0) -->
|
|
||||||
<svg version="1.1" id="Layer_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px"
|
|
||||||
viewBox="0 0 520.1 232.7" style="enable-background:new 0 0 520.1 232.7;" xml:space="preserve">
|
|
||||||
<style type="text/css">
|
|
||||||
.st0{fill:#880000;}
|
|
||||||
.st1{fill:#00DC82;}
|
|
||||||
</style>
|
|
||||||
<path class="st0" d="M323.9,193.5c-47.8-6.5-96.2,6.6-134.1,36.4c-9.7-24.3-21.1-48-34.1-70.8c-10.8-19.1-18.1-29.1-28.6-29.9
|
|
||||||
s-21.3,9.9-25.3,15C94,126,82.2,113.3,71.2,114.3c-6.5,0.6-12,7.6-22.6,21.5C38.3,149.5,31,161.7,25,172.5
|
|
||||||
c-5.4,9.7-12.4,22.7-19.9,38.5C5.3,133.1,6,75,5.8,49.3c0-4.6-0.1-15.1,6.8-22.9c7.3-8.2,18.6-9.1,34.2-10.2
|
|
||||||
c9.6-0.7,23.6-0.8,40.5,2.3c1.2,12,8.2,42,31.4,72.1c14.4,18.7,31.7,31.1,48.4,33.8c-14.4-13.7-33.3-29-48.6-47.3
|
|
||||||
c-13.2-15.6-21.3-34.8-21-56.6c0.2-12.6,5.8-19.8,17.5-18.2c23.3,3.5,46.3,8.9,69.3,13.6c2.5,0.5,4.9,1.7,8.4,0.5L169.6,4.9
|
|
||||||
c0.4-1.4,0.7-2.8,1.1-4.2c114.6-5.8,221.8,26,328.4,65.5c-1.4,7.4-2.5,12.9-3.6,18.4l1.5,0.6l7.1-14c16.3,2.2,18.3,6.4,14.1,20.7
|
|
||||||
c-7.4,25.7-24.1,39.2-50,44.1c-41.3,7.9-82.2,17.2-123.5,25.3C318.2,166.6,317.3,167.5,323.9,193.5z M185,62.7
|
|
||||||
c-16.8-20-51.7-37.3-67.5-34.9c-2.3,22.4,34.4,68.2,57.8,71.7c-2.7-4.4-5.3-8.4-7.8-12.6l6.4-3.5l-15.2-19.8l18.7,7.9l-6.6-13.7
|
|
||||||
L185,62.7z M375.9,66.2l0.2-4.8L285.7,44l-1.3,4.5c14.2,7,27.8,16.7,42.8,20.2C343.4,72.3,360.2,71.5,375.9,66.2L375.9,66.2z
|
|
||||||
M363.3,130.2l-1.6-4.3c-20.4,8.3-41.2,15.8-61,25.3c-11.1,5.3-10.9,14-3,22.5C305.5,138.6,340.3,142.8,363.3,130.2z"/>
|
|
||||||
<path class="st1" d="M103.4,232.7h59.5c1.9,0,3.7-0.5,5.4-1.4c3.3-1.9,5.3-5.5,5.3-9.3c0-1.9-0.5-3.7-1.4-5.3l-40-68.7
|
|
||||||
c-0.9-1.6-2.3-2.9-3.9-3.8c-3.3-2-7.5-2-10.8,0c-1.6,0.9-2.9,2.2-3.9,3.8l-10.2,17.6l-20-34.4c-1-1.6-2.4-2.9-4-3.8
|
|
||||||
c-3.3-2-7.4-2-10.7,0c-1.6,0.9-2.9,2.2-3.9,3.8l-49.9,85.5c-3,5-1.3,11.5,3.7,14.5c1.7,1,3.6,1.5,5.6,1.5h37.4
|
|
||||||
c14.7,0,25.7-6.4,33.3-19l18.2-31.4l9.8-16.7l29.3,50.4h-39.1L103.4,232.7z M61,215.9H34.9L74,148.8l19.5,33.6l-13.1,22.4
|
|
||||||
C75.5,213,69.8,215.9,61,215.9L61,215.9z"/>
|
|
||||||
<path class="st1" d="M375.9,66.2l0.2-4.8L285.7,44l-1.3,4.5c14.2,7,27.8,16.7,42.8,20.2C343.4,72.3,360.2,71.5,375.9,66.2
|
|
||||||
L375.9,66.2z"/>
|
|
||||||
</svg>
|
|
||||||
|
Before Width: | Height: | Size: 2.2 KiB After Width: | Height: | Size: 851 B |
8
docs/renovate.json
Normal file
8
docs/renovate.json
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
{
|
||||||
|
"extends": [
|
||||||
|
"@nuxtjs"
|
||||||
|
],
|
||||||
|
"lockFileMaintenance": {
|
||||||
|
"enabled": true
|
||||||
|
}
|
||||||
|
}
|
||||||
18
docs/tokens.config.ts
Normal file
18
docs/tokens.config.ts
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
import { defineTheme } from 'pinceau'
|
||||||
|
|
||||||
|
export default defineTheme({
|
||||||
|
color: {
|
||||||
|
primary: {
|
||||||
|
50: '#e8f5e9',
|
||||||
|
100: '#c8e6c9',
|
||||||
|
200: '#a5d6a7',
|
||||||
|
300: '#81c784',
|
||||||
|
400: '#66bb6a',
|
||||||
|
500: '#10a74f',
|
||||||
|
600: '#10a74f',
|
||||||
|
700: '#388e3c',
|
||||||
|
800: '#2e7d32',
|
||||||
|
900: '#1b5e20',
|
||||||
|
},
|
||||||
|
},
|
||||||
|
})
|
||||||
3
docs/tsconfig.json
Normal file
3
docs/tsconfig.json
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
{
|
||||||
|
"extends": "./.nuxt/tsconfig.json"
|
||||||
|
}
|
||||||
45
package.json
45
package.json
@ -1,7 +1,7 @@
|
|||||||
{
|
{
|
||||||
"name": "nuxt-mongoose",
|
"name": "nuxt-mongoose",
|
||||||
"type": "module",
|
"type": "module",
|
||||||
"version": "0.0.7",
|
"version": "0.0.9",
|
||||||
"description": "Nuxt 3 module for MongoDB with Mongoose",
|
"description": "Nuxt 3 module for MongoDB with Mongoose",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"repository": {
|
"repository": {
|
||||||
@ -14,10 +14,6 @@
|
|||||||
"require": "./module.cjs",
|
"require": "./module.cjs",
|
||||||
"import": "./dist/module.mjs"
|
"import": "./dist/module.mjs"
|
||||||
},
|
},
|
||||||
"./types": {
|
|
||||||
"types": "./dist/types.d.ts",
|
|
||||||
"import": "./dist/types.mjs"
|
|
||||||
},
|
|
||||||
"./*": "./*"
|
"./*": "./*"
|
||||||
},
|
},
|
||||||
"main": "./module.cjs",
|
"main": "./module.cjs",
|
||||||
@ -38,35 +34,36 @@
|
|||||||
"test:watch": "vitest watch"
|
"test:watch": "vitest watch"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@nuxt/devtools-kit": "^0.5.5",
|
"@nuxt/devtools-kit": "^0.6.7",
|
||||||
"@nuxt/kit": "^3.5.2",
|
"@nuxt/kit": "^3.6.2",
|
||||||
"@types/fs-extra": "^11.0.1",
|
"@types/fs-extra": "^11.0.1",
|
||||||
"birpc": "^0.2.11",
|
"birpc": "^0.2.12",
|
||||||
"defu": "^6.1.2",
|
"defu": "^6.1.2",
|
||||||
"flatted": "^3.2.7",
|
"flatted": "^3.2.7",
|
||||||
"fs-extra": "^11.1.1",
|
"fs-extra": "^11.1.1",
|
||||||
"mongoose": "^7.2.2",
|
"mongoose": "^7.3.2",
|
||||||
"pathe": "^1.1.0",
|
"ofetch": "^1.1.1",
|
||||||
|
"pathe": "^1.1.1",
|
||||||
"pluralize": "^8.0.0",
|
"pluralize": "^8.0.0",
|
||||||
"sirv": "^2.0.3",
|
"sirv": "^2.0.3",
|
||||||
"tinyws": "^0.1.0",
|
"vite-hot-client": "^0.2.1",
|
||||||
"ws": "^8.13.0"
|
"ws": "^8.13.0"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@antfu/eslint-config": "^0.38.5",
|
"@antfu/eslint-config": "^0.39.7",
|
||||||
"@nuxt/devtools": "^0.5.5",
|
"@nuxt/devtools": "^0.6.7",
|
||||||
"@nuxt/devtools-ui-kit": "^0.5.5",
|
"@nuxt/devtools-ui-kit": "^0.6.7",
|
||||||
"@nuxt/module-builder": "^0.4.0",
|
"@nuxt/module-builder": "^0.4.0",
|
||||||
"@nuxt/schema": "^3.5.2",
|
"@nuxt/schema": "^3.6.2",
|
||||||
"@nuxt/test-utils": "^3.5.2",
|
"@nuxt/test-utils": "^3.6.2",
|
||||||
"@types/pluralize": "^0.0.29",
|
"@types/pluralize": "^0.0.30",
|
||||||
"@types/ws": "^8.5.4",
|
"@types/ws": "^8.5.5",
|
||||||
"changelogen": "^0.5.3",
|
"changelogen": "^0.5.4",
|
||||||
"eslint": "^8.39.0",
|
"eslint": "^8.44.0",
|
||||||
"nuxt": "^3.5.2",
|
"nuxt": "^3.6.2",
|
||||||
"sass": "^1.62.1",
|
"sass": "^1.63.6",
|
||||||
"sass-loader": "^13.3.1",
|
"sass-loader": "^13.3.2",
|
||||||
"splitpanes": "^3.1.5",
|
"splitpanes": "^3.1.5",
|
||||||
"vitest": "^0.31.2"
|
"vitest": "^0.33.0"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
1
playground/.env.example
Normal file
1
playground/.env.example
Normal file
@ -0,0 +1 @@
|
|||||||
|
MONGODB_URI="mongodb://127.0.0.1:27017/nuxt-mongoose"
|
||||||
8
playground/server/api/users/[_id].delete.ts
Normal file
8
playground/server/api/users/[_id].delete.ts
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
export default defineEventHandler(async (event) => {
|
||||||
|
try {
|
||||||
|
return await UserSchema.findOneAndDelete({ _id: event.context.params?._id })
|
||||||
|
}
|
||||||
|
catch (error) {
|
||||||
|
return error
|
||||||
|
}
|
||||||
|
})
|
||||||
8
playground/server/api/users/[_id].get.ts
Normal file
8
playground/server/api/users/[_id].get.ts
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
export default defineEventHandler(async (event) => {
|
||||||
|
try {
|
||||||
|
return await UserSchema.findOne({ _id: event.context.params?._id })
|
||||||
|
}
|
||||||
|
catch (error) {
|
||||||
|
return error
|
||||||
|
}
|
||||||
|
})
|
||||||
9
playground/server/api/users/[_id].put.ts
Normal file
9
playground/server/api/users/[_id].put.ts
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
export default defineEventHandler(async (event) => {
|
||||||
|
const body = await readBody(event)
|
||||||
|
try {
|
||||||
|
return await UserSchema.findOneAndUpdate({ _id: event.context.params?._id }, body, { new: true })
|
||||||
|
}
|
||||||
|
catch (error) {
|
||||||
|
return error
|
||||||
|
}
|
||||||
|
})
|
||||||
9
playground/server/api/users/create.post.ts
Normal file
9
playground/server/api/users/create.post.ts
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
export default defineEventHandler(async (event) => {
|
||||||
|
const body = await readBody(event)
|
||||||
|
try {
|
||||||
|
return await new UserSchema(body).save()
|
||||||
|
}
|
||||||
|
catch (error) {
|
||||||
|
return error
|
||||||
|
}
|
||||||
|
})
|
||||||
8
playground/server/api/users/index.get.ts
Normal file
8
playground/server/api/users/index.get.ts
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
export default defineEventHandler(async () => {
|
||||||
|
try {
|
||||||
|
return await UserSchema.find({})
|
||||||
|
}
|
||||||
|
catch (error) {
|
||||||
|
return error
|
||||||
|
}
|
||||||
|
})
|
||||||
26
playground/server/models/user.schema.ts
Normal file
26
playground/server/models/user.schema.ts
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
import { defineMongooseModel } from '#nuxt/mongoose'
|
||||||
|
|
||||||
|
export const UserSchema = defineMongooseModel({
|
||||||
|
name: 'User',
|
||||||
|
schema: {
|
||||||
|
name: {
|
||||||
|
type: 'string',
|
||||||
|
required: true,
|
||||||
|
},
|
||||||
|
email: {
|
||||||
|
type: 'string',
|
||||||
|
required: true,
|
||||||
|
unique: false,
|
||||||
|
},
|
||||||
|
password: {
|
||||||
|
type: 'string',
|
||||||
|
required: true,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
hooks(schema) {
|
||||||
|
schema.pre('save', function (this, next) {
|
||||||
|
this.password = `hash.${this.password}.${Math.random()}`
|
||||||
|
next()
|
||||||
|
})
|
||||||
|
},
|
||||||
|
})
|
||||||
3744
pnpm-lock.yaml
generated
3744
pnpm-lock.yaml
generated
File diff suppressed because it is too large
Load Diff
@ -1,3 +1,3 @@
|
|||||||
export const PATH = '/__nuxt_mongoose__'
|
export const PATH = '/__nuxt_mongoose__'
|
||||||
export const PATH_ENTRY = `${PATH}/entry`
|
|
||||||
export const PATH_CLIENT = `${PATH}/client`
|
export const PATH_CLIENT = `${PATH}/client`
|
||||||
|
export const WS_EVENT_NAME = 'nuxt:devtools:mongoose:rpc'
|
||||||
|
|||||||
@ -2,17 +2,19 @@ import {
|
|||||||
addImportsDir,
|
addImportsDir,
|
||||||
addServerPlugin,
|
addServerPlugin,
|
||||||
addTemplate,
|
addTemplate,
|
||||||
|
addVitePlugin,
|
||||||
createResolver,
|
createResolver,
|
||||||
defineNuxtModule,
|
defineNuxtModule,
|
||||||
logger,
|
logger,
|
||||||
} from '@nuxt/kit'
|
} from '@nuxt/kit'
|
||||||
import { pathExists } from 'fs-extra'
|
import { pathExists } from 'fs-extra'
|
||||||
import { tinyws } from 'tinyws'
|
|
||||||
import { join } from 'pathe'
|
import { join } from 'pathe'
|
||||||
import { defu } from 'defu'
|
import { defu } from 'defu'
|
||||||
import sirv from 'sirv'
|
import sirv from 'sirv'
|
||||||
|
import { $fetch } from 'ofetch'
|
||||||
|
import { version } from '../package.json'
|
||||||
|
|
||||||
import { PATH_CLIENT, PATH_ENTRY } from './constants'
|
import { PATH_CLIENT } from './constants'
|
||||||
import type { ModuleOptions } from './types'
|
import type { ModuleOptions } from './types'
|
||||||
|
|
||||||
import { setupRPC } from './server-rpc'
|
import { setupRPC } from './server-rpc'
|
||||||
@ -32,7 +34,14 @@ export default defineNuxtModule<ModuleOptions>({
|
|||||||
},
|
},
|
||||||
setup(options, nuxt) {
|
setup(options, nuxt) {
|
||||||
const { resolve } = createResolver(import.meta.url)
|
const { resolve } = createResolver(import.meta.url)
|
||||||
const runtimeConfig = nuxt.options.runtimeConfig
|
const runtimeConfig = nuxt.options.runtimeConfig as any
|
||||||
|
|
||||||
|
if (nuxt.options.dev) {
|
||||||
|
$fetch('https://registry.npmjs.org/nuxt-mongoose/latest').then((release) => {
|
||||||
|
if (release.version > version)
|
||||||
|
logger.info(`A new version of Nuxt Mongoose (v${release.version}) is available: https://github.com/arashsheyda/nuxt-mongoose/releases/latest`)
|
||||||
|
}).catch(() => {})
|
||||||
|
}
|
||||||
|
|
||||||
addImportsDir(resolve('./runtime/composables'))
|
addImportsDir(resolve('./runtime/composables'))
|
||||||
|
|
||||||
@ -58,11 +67,11 @@ export default defineNuxtModule<ModuleOptions>({
|
|||||||
}
|
}
|
||||||
|
|
||||||
const clientPath = distResolve('./client')
|
const clientPath = distResolve('./client')
|
||||||
const { middleware: rpcMiddleware } = setupRPC(nuxt, options)
|
const { vitePlugin } = setupRPC(nuxt, options)
|
||||||
|
|
||||||
|
addVitePlugin(vitePlugin)
|
||||||
|
|
||||||
nuxt.hook('vite:serverCreated', async (server) => {
|
nuxt.hook('vite:serverCreated', async (server) => {
|
||||||
server.middlewares.use(PATH_ENTRY, tinyws() as any)
|
|
||||||
server.middlewares.use(PATH_ENTRY, rpcMiddleware as any)
|
|
||||||
if (await pathExists(clientPath))
|
if (await pathExists(clientPath))
|
||||||
server.middlewares.use(PATH_CLIENT, sirv(clientPath, { dev: true, single: true }))
|
server.middlewares.use(PATH_CLIENT, sirv(clientPath, { dev: true, single: true }))
|
||||||
})
|
})
|
||||||
|
|||||||
@ -11,14 +11,24 @@ export async function defineMongooseConnection({ uri, options }: { uri?: string;
|
|||||||
|
|
||||||
try {
|
try {
|
||||||
await mongoose.connect(mongooseUri, { ...mongooseOptions })
|
await mongoose.connect(mongooseUri, { ...mongooseOptions })
|
||||||
logger.info('Connected to mongoose database')
|
logger.success('Connected to MongoDB database')
|
||||||
}
|
}
|
||||||
catch (err) {
|
catch (err) {
|
||||||
logger.error('Error connecting to database', err)
|
logger.error('Error connecting to MongoDB database', err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
export function defineMongooseModel(nameOrOptions: string | { name: string; schema: SchemaDefinition; options?: SchemaOptions }, schema?: SchemaDefinition, options?: SchemaOptions): Model<any> {
|
export function defineMongooseModel<T>(
|
||||||
|
nameOrOptions: string | {
|
||||||
|
name: string
|
||||||
|
schema: SchemaDefinition
|
||||||
|
options?: SchemaOptions
|
||||||
|
hooks?: (schema: mongoose.Schema<T>) => void
|
||||||
|
},
|
||||||
|
schema?: SchemaDefinition,
|
||||||
|
options?: SchemaOptions,
|
||||||
|
hooks?: (schema: mongoose.Schema<T>) => void,
|
||||||
|
): Model<T> {
|
||||||
let name: string
|
let name: string
|
||||||
if (typeof nameOrOptions === 'string') {
|
if (typeof nameOrOptions === 'string') {
|
||||||
name = nameOrOptions
|
name = nameOrOptions
|
||||||
@ -27,10 +37,13 @@ export function defineMongooseModel(nameOrOptions: string | { name: string; sche
|
|||||||
name = nameOrOptions.name
|
name = nameOrOptions.name
|
||||||
schema = nameOrOptions.schema
|
schema = nameOrOptions.schema
|
||||||
options = nameOrOptions.options
|
options = nameOrOptions.options
|
||||||
|
hooks = nameOrOptions.hooks
|
||||||
}
|
}
|
||||||
|
|
||||||
const newSchema = new mongoose.Schema({
|
const newSchema = new mongoose.Schema<T>(schema, options as any)
|
||||||
...schema,
|
|
||||||
}, { ...options })
|
if (hooks)
|
||||||
return mongoose.model(name, newSchema)
|
hooks(newSchema)
|
||||||
|
|
||||||
|
return mongoose.model<T>(name, newSchema)
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,12 +1,12 @@
|
|||||||
import type { TinyWSRequest } from 'tinyws'
|
|
||||||
import type { NodeIncomingMessage, NodeServerResponse } from 'h3'
|
|
||||||
import type { WebSocket } from 'ws'
|
import type { WebSocket } from 'ws'
|
||||||
import { createBirpcGroup } from 'birpc'
|
import { createBirpcGroup } from 'birpc'
|
||||||
import type { ChannelOptions } from 'birpc'
|
import type { ChannelOptions } from 'birpc'
|
||||||
|
|
||||||
import { parse, stringify } from 'flatted'
|
import { parse, stringify } from 'flatted'
|
||||||
|
import type { Plugin } from 'vite'
|
||||||
import type { Nuxt } from 'nuxt/schema'
|
import type { Nuxt } from 'nuxt/schema'
|
||||||
import type { ClientFunctions, ModuleOptions, NuxtDevtoolsServerContext, ServerFunctions } from '../types'
|
import type { ClientFunctions, ModuleOptions, NuxtDevtoolsServerContext, ServerFunctions } from '../types'
|
||||||
|
import { WS_EVENT_NAME } from '../constants'
|
||||||
import { setupDatabaseRPC } from './database'
|
import { setupDatabaseRPC } from './database'
|
||||||
import { setupResourceRPC } from './resource'
|
import { setupResourceRPC } from './resource'
|
||||||
|
|
||||||
@ -68,14 +68,30 @@ export function setupRPC(nuxt: Nuxt, options: ModuleOptions): any {
|
|||||||
} satisfies Partial<ServerFunctions>)
|
} satisfies Partial<ServerFunctions>)
|
||||||
|
|
||||||
const wsClients = new Set<WebSocket>()
|
const wsClients = new Set<WebSocket>()
|
||||||
const middleware = async (req: NodeIncomingMessage & TinyWSRequest, _res: NodeServerResponse, next: Function) => {
|
|
||||||
// Handle WebSocket
|
const vitePlugin: Plugin = {
|
||||||
if (req.ws) {
|
name: 'nuxt:devtools:rpc',
|
||||||
const ws = await req.ws()
|
configureServer(server) {
|
||||||
|
server.ws.on('connection', (ws) => {
|
||||||
wsClients.add(ws)
|
wsClients.add(ws)
|
||||||
const channel: ChannelOptions = {
|
const channel: ChannelOptions = {
|
||||||
post: d => ws.send(d),
|
post: d => ws.send(JSON.stringify({
|
||||||
on: fn => ws.on('message', fn),
|
type: 'custom',
|
||||||
|
event: WS_EVENT_NAME,
|
||||||
|
data: d,
|
||||||
|
})),
|
||||||
|
on: (fn) => {
|
||||||
|
ws.on('message', (e) => {
|
||||||
|
try {
|
||||||
|
const data = JSON.parse(String(e)) || {}
|
||||||
|
if (data.type === 'custom' && data.event === WS_EVENT_NAME) {
|
||||||
|
// console.log(data.data)
|
||||||
|
fn(data.data)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch {}
|
||||||
|
})
|
||||||
|
},
|
||||||
serialize: stringify,
|
serialize: stringify,
|
||||||
deserialize: parse,
|
deserialize: parse,
|
||||||
}
|
}
|
||||||
@ -90,14 +106,12 @@ export function setupRPC(nuxt: Nuxt, options: ModuleOptions): any {
|
|||||||
c.splice(index, 1)
|
c.splice(index, 1)
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
}
|
})
|
||||||
else {
|
},
|
||||||
next()
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return {
|
return {
|
||||||
middleware,
|
vitePlugin,
|
||||||
...ctx,
|
...ctx,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -5,6 +5,8 @@ import { generateApiRoute, generateSchemaFile } from '../utils/schematics'
|
|||||||
import { capitalize, pluralize, singularize } from '../utils/formatting'
|
import { capitalize, pluralize, singularize } from '../utils/formatting'
|
||||||
|
|
||||||
export function setupResourceRPC({ nuxt, rpc }: NuxtDevtoolsServerContext): any {
|
export function setupResourceRPC({ nuxt, rpc }: NuxtDevtoolsServerContext): any {
|
||||||
|
const runtimeConfig = nuxt.options.runtimeConfig as any
|
||||||
|
|
||||||
return {
|
return {
|
||||||
// TODO: maybe separate functions
|
// TODO: maybe separate functions
|
||||||
async generateResource(collection: Collection, resources: Resource[]) {
|
async generateResource(collection: Collection, resources: Resource[]) {
|
||||||
@ -13,9 +15,9 @@ export function setupResourceRPC({ nuxt, rpc }: NuxtDevtoolsServerContext): any
|
|||||||
const dbName = capitalize(singular)
|
const dbName = capitalize(singular)
|
||||||
|
|
||||||
if (collection.fields) {
|
if (collection.fields) {
|
||||||
const schemaPath = resolve(nuxt.options.serverDir, 'utils/models', `${singular}.schema.ts`)
|
const schemaPath = resolve(nuxt.options.serverDir, runtimeConfig.mongoose.modelsDir, `${singular}.schema.ts`)
|
||||||
if (!fs.existsSync(schemaPath)) {
|
if (!fs.existsSync(schemaPath)) {
|
||||||
fs.ensureDirSync(resolve(nuxt.options.serverDir, 'utils/models'))
|
fs.ensureDirSync(resolve(nuxt.options.serverDir, runtimeConfig.mongoose.modelsDir))
|
||||||
fs.writeFileSync(schemaPath, generateSchemaFile(dbName, collection.fields))
|
fs.writeFileSync(schemaPath, generateSchemaFile(dbName, collection.fields))
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -51,7 +53,7 @@ export function setupResourceRPC({ nuxt, rpc }: NuxtDevtoolsServerContext): any
|
|||||||
async resourceSchema(collection: string) {
|
async resourceSchema(collection: string) {
|
||||||
// TODO: use magicast
|
// TODO: use magicast
|
||||||
const singular = singularize(collection).toLowerCase()
|
const singular = singularize(collection).toLowerCase()
|
||||||
const schemaPath = resolve(nuxt.options.serverDir, 'utils/models', `${singular}.schema.ts`)
|
const schemaPath = resolve(nuxt.options.serverDir, runtimeConfig.mongoose.modelsDir, `${singular}.schema.ts`)
|
||||||
if (fs.existsSync(schemaPath)) {
|
if (fs.existsSync(schemaPath)) {
|
||||||
const content = fs.readFileSync(schemaPath, 'utf-8').match(/schema: \{(.|\n)*\}/g)
|
const content = fs.readFileSync(schemaPath, 'utf-8').match(/schema: \{(.|\n)*\}/g)
|
||||||
if (content) {
|
if (content) {
|
||||||
|
|||||||
@ -25,7 +25,7 @@ export interface ClientFunctions {
|
|||||||
|
|
||||||
export interface Collection {
|
export interface Collection {
|
||||||
name: string
|
name: string
|
||||||
fields?: {}[]
|
fields?: object[]
|
||||||
}
|
}
|
||||||
|
|
||||||
export interface Resource {
|
export interface Resource {
|
||||||
|
|||||||
@ -11,5 +11,5 @@ export interface NuxtDevtoolsServerContext {
|
|||||||
|
|
||||||
refresh: (event: keyof ServerFunctions) => void
|
refresh: (event: keyof ServerFunctions) => void
|
||||||
|
|
||||||
extendServerRpc: <ClientFunctions = {}, ServerFunctions = {}>(name: string, functions: ServerFunctions) => BirpcGroup<ClientFunctions, ServerFunctions>
|
extendServerRpc: <ClientFunctions = object, ServerFunctions = object>(name: string, functions: ServerFunctions) => BirpcGroup<ClientFunctions, ServerFunctions>
|
||||||
}
|
}
|
||||||
|
|||||||
1
types.d.ts
vendored
1
types.d.ts
vendored
@ -1 +0,0 @@
|
|||||||
export * from './dist/types'
|
|
||||||
Reference in New Issue
Block a user