commit
0e8121bc25
@ -1,16 +0,0 @@
|
||||
root = true
|
||||
|
||||
[*]
|
||||
indent_style = space
|
||||
indent_size = 2
|
||||
end_of_line = lf
|
||||
charset = utf-8
|
||||
trim_trailing_whitespace = true
|
||||
insert_final_newline = true
|
||||
|
||||
[{package.json,*.yml}]
|
||||
indent_style = space
|
||||
indent_size = 2
|
||||
|
||||
[*.md]
|
||||
trim_trailing_whitespace = false
|
||||
@ -1,28 +0,0 @@
|
||||
HOST=0.0.0.0
|
||||
PORT=1337
|
||||
APP_KEYS=chUnDYzQYwe0TBtXVv4sPg==,fVrGPGw5Xd4UdPisWHOHxQ==,Qre2n8wneae2BrXOotmagw==,B3suExWQFpyJS9mhqNcOLg==
|
||||
API_TOKEN_SALT=tyYia7Nui8Y0lM0IRTDjmg==
|
||||
ADMIN_JWT_SECRET=q1dnfyvh3K7yhTYbYNS7jw==
|
||||
JWT_SECRET=nc8prafomnDTfDdS00OqTQ==
|
||||
|
||||
PG_DATABASE_HOST=localhost
|
||||
PG_DATABASE_PORT=5432
|
||||
PG_DATABASE_NAME=gs_database
|
||||
PG_DATABASE_USERNAME=gs_username
|
||||
PG_DATABASE_ROOT_PASSWORD=gs_root_username
|
||||
PG_DATABASE_PASSWORD=gs_password
|
||||
PG_DATABASE_SCHEMA=public
|
||||
|
||||
MYSQL_DATABASE_HOST=localhost
|
||||
MYSQL_DATABASE_PORT=3307
|
||||
MYSQL_DATABASE_NAME=gs_database
|
||||
MYSQL_DATABASE_USERNAME=gs_username
|
||||
MYSQL_DATABASE_ROOT_PASSWORD=gs_root_username
|
||||
MYSQL_DATABASE_PASSWORD=gs_password
|
||||
|
||||
SMTP_HOST=mail.infomaniak.com
|
||||
SMTP_PORT=587
|
||||
SMTP_USERNAME=synology@naser.fr
|
||||
SMTP_PASSWORD=Em18071988!
|
||||
SMTP_DEFAULT_FROM=no-reply@strapi.io
|
||||
SMTP_DEFAULT_REPLY=synology@naser.fr
|
||||
@ -1,28 +0,0 @@
|
||||
HOST=0.0.0.0
|
||||
PORT=1337
|
||||
APP_KEYS=chUnDYzQYwe0TBtXVv4sPg==,fVrGPGw5Xd4UdPisWHOHxQ==,Qre2n8wneae2BrXOotmagw==,B3suExWQFpyJS9mhqNcOLg==
|
||||
API_TOKEN_SALT=tyYia7Nui8Y0lM0IRTDjmg==
|
||||
ADMIN_JWT_SECRET=q1dnfyvh3K7yhTYbYNS7jw==
|
||||
JWT_SECRET=nc8prafomnDTfDdS00OqTQ==
|
||||
|
||||
PG_DATABASE_HOST=localhost
|
||||
PG_DATABASE_PORT=5432
|
||||
PG_DATABASE_NAME=gs_database
|
||||
PG_DATABASE_USERNAME=gs_username
|
||||
PG_DATABASE_ROOT_PASSWORD=gs_root_username
|
||||
PG_DATABASE_PASSWORD=gs_password
|
||||
PG_DATABASE_SCHEMA=public
|
||||
|
||||
MYSQL_DATABASE_HOST=localhost
|
||||
MYSQL_DATABASE_PORT=3306
|
||||
MYSQL_DATABASE_NAME=dpxtrufj_gs_database
|
||||
MYSQL_DATABASE_USERNAME=dpxtrufj_gs_username
|
||||
MYSQL_DATABASE_ROOT_PASSWORD=gs_root_username
|
||||
MYSQL_DATABASE_PASSWORD=q7=@oa*F*s4?8*Hq4H
|
||||
|
||||
SMTP_HOST=node143-eu.n0c.com
|
||||
SMTP_PORT=587
|
||||
SMTP_USERNAME=no-reply@nasercloud.fr
|
||||
SMTP_PASSWORD=GuitarSchool123!
|
||||
SMTP_DEFAULT_FROM=no-reply@strapi.io
|
||||
SMTP_DEFAULT_REPLY=synology@naser.fr
|
||||
@ -1,28 +0,0 @@
|
||||
HOST=0.0.0.0
|
||||
PORT=1337
|
||||
APP_KEYS=chUnDYzQYwe0TBtXVv4sPg==,fVrGPGw5Xd4UdPisWHOHxQ==,Qre2n8wneae2BrXOotmagw==,B3suExWQFpyJS9mhqNcOLg==
|
||||
API_TOKEN_SALT=tyYia7Nui8Y0lM0IRTDjmg==
|
||||
ADMIN_JWT_SECRET=q1dnfyvh3K7yhTYbYNS7jw==
|
||||
JWT_SECRET=nc8prafomnDTfDdS00OqTQ==
|
||||
|
||||
PG_DATABASE_HOST=localhost
|
||||
PG_DATABASE_PORT=5432
|
||||
PG_DATABASE_NAME=gs_database
|
||||
PG_DATABASE_USERNAME=gs_username
|
||||
PG_DATABASE_ROOT_PASSWORD=gs_root_username
|
||||
PG_DATABASE_PASSWORD=gs_password
|
||||
PG_DATABASE_SCHEMA=public
|
||||
|
||||
MYSQL_DATABASE_HOST=localhost
|
||||
MYSQL_DATABASE_PORT=3306
|
||||
MYSQL_DATABASE_NAME=dpxtrufj_gs_database
|
||||
MYSQL_DATABASE_USERNAME=dpxtrufj_gs_user
|
||||
MYSQL_DATABASE_ROOT_PASSWORD=gs_root_username
|
||||
MYSQL_DATABASE_PASSWORD=q7=@oa*F*s4?8*Hq4H
|
||||
|
||||
SMTP_HOST=node143-eu.n0c.com
|
||||
SMTP_PORT=587
|
||||
SMTP_USERNAME=no-reply@nasercloud.fr
|
||||
SMTP_PASSWORD=GuitarSchool123!
|
||||
SMTP_DEFAULT_FROM=no-reply@nasercloud.fr
|
||||
SMTP_DEFAULT_REPLY=contact@nasercloud.fr
|
||||
@ -1,115 +0,0 @@
|
||||
############################
|
||||
# OS X
|
||||
############################
|
||||
|
||||
.DS_Store
|
||||
.AppleDouble
|
||||
.LSOverride
|
||||
Icon
|
||||
.Spotlight-V100
|
||||
.Trashes
|
||||
._*
|
||||
|
||||
|
||||
############################
|
||||
# Linux
|
||||
############################
|
||||
|
||||
*~
|
||||
|
||||
|
||||
############################
|
||||
# Windows
|
||||
############################
|
||||
|
||||
Thumbs.db
|
||||
ehthumbs.db
|
||||
Desktop.ini
|
||||
$RECYCLE.BIN/
|
||||
*.cab
|
||||
*.msi
|
||||
*.msm
|
||||
*.msp
|
||||
|
||||
|
||||
############################
|
||||
# Packages
|
||||
############################
|
||||
|
||||
*.7z
|
||||
*.csv
|
||||
*.dat
|
||||
*.dmg
|
||||
*.gz
|
||||
*.iso
|
||||
*.jar
|
||||
*.rar
|
||||
*.tar
|
||||
*.zip
|
||||
*.com
|
||||
*.class
|
||||
*.dll
|
||||
*.exe
|
||||
*.o
|
||||
*.seed
|
||||
*.so
|
||||
*.swo
|
||||
*.swp
|
||||
*.swn
|
||||
*.swm
|
||||
*.out
|
||||
*.pid
|
||||
|
||||
|
||||
############################
|
||||
# Logs and databases
|
||||
############################
|
||||
|
||||
.tmp
|
||||
*.log
|
||||
*.sql
|
||||
*.sqlite
|
||||
*.sqlite3
|
||||
|
||||
|
||||
############################
|
||||
# Misc.
|
||||
############################
|
||||
|
||||
*#
|
||||
ssl
|
||||
.idea
|
||||
nbproject
|
||||
public/uploads/*
|
||||
!public/uploads/.gitkeep
|
||||
|
||||
############################
|
||||
# Node.js
|
||||
############################
|
||||
|
||||
lib-cov
|
||||
lcov.info
|
||||
pids
|
||||
logs
|
||||
results
|
||||
node_modules
|
||||
.node_history
|
||||
|
||||
############################
|
||||
# Tests
|
||||
############################
|
||||
|
||||
testApp
|
||||
coverage
|
||||
|
||||
############################
|
||||
# Strapi
|
||||
############################
|
||||
|
||||
.env
|
||||
license.txt
|
||||
exports
|
||||
*.cache
|
||||
dist
|
||||
build
|
||||
.strapi-updater.json
|
||||
@ -1,57 +0,0 @@
|
||||
# 🚀 Getting started with Strapi
|
||||
|
||||
Strapi comes with a full featured [Command Line Interface](https://docs.strapi.io/developer-docs/latest/developer-resources/cli/CLI.html) (CLI) which lets you scaffold and manage your project in seconds.
|
||||
|
||||
### `develop`
|
||||
|
||||
Start your Strapi application with autoReload enabled. [Learn more](https://docs.strapi.io/developer-docs/latest/developer-resources/cli/CLI.html#strapi-develop)
|
||||
|
||||
```
|
||||
npm run develop
|
||||
# or
|
||||
yarn develop
|
||||
```
|
||||
|
||||
### `start`
|
||||
|
||||
Start your Strapi application with autoReload disabled. [Learn more](https://docs.strapi.io/developer-docs/latest/developer-resources/cli/CLI.html#strapi-start)
|
||||
|
||||
```
|
||||
npm run start
|
||||
# or
|
||||
yarn start
|
||||
```
|
||||
|
||||
### `build`
|
||||
|
||||
Build your admin panel. [Learn more](https://docs.strapi.io/developer-docs/latest/developer-resources/cli/CLI.html#strapi-build)
|
||||
|
||||
```
|
||||
npm run build
|
||||
# or
|
||||
yarn build
|
||||
```
|
||||
|
||||
## ⚙️ Deployment
|
||||
|
||||
Strapi gives you many possible deployment options for your project. Find the one that suits you on the [deployment section of the documentation](https://docs.strapi.io/developer-docs/latest/setup-deployment-guides/deployment.html).
|
||||
|
||||
## 📚 Learn more
|
||||
|
||||
- [Resource center](https://strapi.io/resource-center) - Strapi resource center.
|
||||
- [Strapi documentation](https://docs.strapi.io) - Official Strapi documentation.
|
||||
- [Strapi tutorials](https://strapi.io/tutorials) - List of tutorials made by the core team and the community.
|
||||
- [Strapi blog](https://docs.strapi.io) - Official Strapi blog containing articles made by the Strapi team and the community.
|
||||
- [Changelog](https://strapi.io/changelog) - Find out about the Strapi product updates, new features and general improvements.
|
||||
|
||||
Feel free to check out the [Strapi GitHub repository](https://github.com/strapi/strapi). Your feedback and contributions are welcome!
|
||||
|
||||
## ✨ Community
|
||||
|
||||
- [Discord](https://discord.strapi.io) - Come chat with the Strapi community including the core team.
|
||||
- [Forum](https://forum.strapi.io/) - Place to discuss, ask questions and find answers, show your Strapi project and get feedback or just talk with other Community members.
|
||||
- [Awesome Strapi](https://github.com/strapi/awesome-strapi) - A curated list of awesome things related to Strapi.
|
||||
|
||||
---
|
||||
|
||||
<sub>🤫 Psst! [Strapi is hiring](https://strapi.io/careers).</sub>
|
||||
@ -1,8 +0,0 @@
|
||||
export default ({ env }) => ({
|
||||
auth: {
|
||||
secret: env('ADMIN_JWT_SECRET'),
|
||||
},
|
||||
apiToken: {
|
||||
salt: env('API_TOKEN_SALT'),
|
||||
},
|
||||
});
|
||||
@ -1,10 +0,0 @@
|
||||
export default {
|
||||
responses: {
|
||||
privateAttributes: ['_v', 'id', 'created_at'],
|
||||
},
|
||||
rest: {
|
||||
defaultLimit: 100,
|
||||
maxLimit: 250,
|
||||
withCount: true,
|
||||
},
|
||||
};
|
||||
@ -1,20 +0,0 @@
|
||||
export default ({env}) => ({
|
||||
connection: {
|
||||
client: 'mysql',
|
||||
connection: {
|
||||
host: env('MYSQL_DATABASE_HOST', 'localhost'),
|
||||
port: env.int('MYSQL_DATABASE_PORT', 3306),
|
||||
database: env('MYSQL_DATABASE_NAME', 'bank'),
|
||||
user: env('MYSQL_DATABASE_USERNAME', 'postgres'),
|
||||
password: env('MYSQL_DATABASE_PASSWORD', '0000'),
|
||||
},
|
||||
debug: false,
|
||||
},
|
||||
// connection: {
|
||||
// client: 'sqlite',
|
||||
// connection: {
|
||||
// filename: path.join(__dirname, '..', '..', env('DATABASE_FILENAME', '.tmp/data.db')),
|
||||
// },
|
||||
// useNullAsDefault: true,
|
||||
// },
|
||||
});
|
||||
@ -1,12 +0,0 @@
|
||||
export default [
|
||||
'strapi::errors',
|
||||
'strapi::security',
|
||||
'strapi::cors',
|
||||
'strapi::poweredBy',
|
||||
'strapi::logger',
|
||||
'strapi::query',
|
||||
'strapi::body',
|
||||
'strapi::session',
|
||||
'strapi::favicon',
|
||||
'strapi::public',
|
||||
];
|
||||
@ -1,25 +0,0 @@
|
||||
module.exports = ({env}) => ({
|
||||
// ...
|
||||
email: {
|
||||
config: {
|
||||
provider: 'nodemailer',
|
||||
providerOptions: {
|
||||
host: env('SMTP_HOST', 'smtp.example.com'),
|
||||
port: env('SMTP_PORT', 587),
|
||||
auth: {
|
||||
user: env('SMTP_USERNAME'),
|
||||
pass: env('SMTP_PASSWORD'),
|
||||
},
|
||||
// ... any custom nodemailer options
|
||||
},
|
||||
settings: {
|
||||
defaultFrom: env('SMTP_DEFAULT_FROM', 'no-reply@strapi.io'),
|
||||
defaultReplyTo: env('SMTP_DEFAULT_REPLY', 'synology@naser.fr'),
|
||||
},
|
||||
},
|
||||
},
|
||||
'import-export-entries': {
|
||||
enabled: true
|
||||
}
|
||||
// ...
|
||||
});
|
||||
@ -1,7 +0,0 @@
|
||||
export default ({ env }) => ({
|
||||
host: env('HOST', '0.0.0.0'),
|
||||
port: env.int('PORT', 1337),
|
||||
app: {
|
||||
keys: env.array('APP_KEYS'),
|
||||
},
|
||||
});
|
||||
|
Before Width: | Height: | Size: 497 B |
@ -1,20 +0,0 @@
|
||||
services:
|
||||
gs_mysql:
|
||||
image: 'mariadb:10.3'
|
||||
environment:
|
||||
MYSQL_DATABASE: ${MYSQL_DATABASE_NAME}
|
||||
# So you don't have to use root, but you can if you like
|
||||
MYSQL_USER: ${MYSQL_DATABASE_USERNAME}
|
||||
# You can use whatever password you like
|
||||
MYSQL_PASSWORD: ${MYSQL_DATABASE_PASSWORD}
|
||||
# Password for root access
|
||||
MYSQL_ROOT_PASSWORD: ${MYSQL_DATABASE_ROOT_PASSWORD}
|
||||
ports:
|
||||
# <Port exposed> : < MySQL Port running inside container>
|
||||
- '${MYSQL_DATABASE_PORT}:3306'
|
||||
expose:
|
||||
# Opens port 3306 on the container
|
||||
- '${MYSQL_DATABASE_PORT}'
|
||||
# Where our data will be persisted
|
||||
volumes:
|
||||
- gs_mariadb-master:/var/lib/mysql
|
||||
File diff suppressed because it is too large
Load Diff
@ -1,40 +0,0 @@
|
||||
{
|
||||
"name": "backend",
|
||||
"private": true,
|
||||
"version": "0.1.0",
|
||||
"description": "A Strapi application",
|
||||
"scripts": {
|
||||
"generate": "strapi generate",
|
||||
"develop": "strapi develop",
|
||||
"start": "strapi start",
|
||||
"build": "strapi build",
|
||||
"strapi": "strapi"
|
||||
},
|
||||
"overrides": {
|
||||
"@strapi/strapi": "4.5.4"
|
||||
},
|
||||
"dependencies": {
|
||||
"@strapi/plugin-i18n": "4.5.4",
|
||||
"@strapi/plugin-users-permissions": "4.5.4",
|
||||
"@strapi/provider-email-nodemailer": "4.5.6",
|
||||
"@strapi/strapi": "4.5.4",
|
||||
"@strapi/utils": "4.5.6",
|
||||
"better-sqlite3": "7.4.6",
|
||||
"mysql": "2.18.1",
|
||||
"pg": "8.8.0",
|
||||
"strapi-plugin-import-export-entries": "1.18.0",
|
||||
"strapi-plugin-menus": "1.2.1",
|
||||
"strapi-plugin-populate-deep": "1.1.2"
|
||||
},
|
||||
"author": {
|
||||
"name": "A Strapi developer"
|
||||
},
|
||||
"strapi": {
|
||||
"uuid": "d1de7a93-c68b-4597-80ee-b5b56ea4eb10"
|
||||
},
|
||||
"engines": {
|
||||
"node": ">=14.19.1 <=18.x.x",
|
||||
"npm": ">=6.0.0"
|
||||
},
|
||||
"license": "MIT"
|
||||
}
|
||||
@ -1,20 +0,0 @@
|
||||
services:
|
||||
gs_postgres:
|
||||
image: postgres:14-alpine
|
||||
container_name: gs_postgres
|
||||
shm_size: '4gb'
|
||||
environment:
|
||||
POSTGRES_USER: ${DATABASE_USERNAME}
|
||||
POSTGRES_PASSWORD: ${DATABASE_PASSWORD}
|
||||
POSTGRES_DB: ${DATABASE_NAME}
|
||||
TZ: Europe/Paris
|
||||
healthcheck:
|
||||
test: 'PGPASSWORD="${DATABASE_PASSWORD}" psql --host ${DATABASE_HOST} --username ${DATABASE_USERNAME} --dbname ${DATABASE_NAME} -c "select 1" ; [ "0" -eq "$$?" ]; echo $$?'
|
||||
interval: 30s
|
||||
timeout: 10s
|
||||
retries: 3
|
||||
volumes:
|
||||
- gs_postgres-master:/var/lib/postgresql/data:z
|
||||
- ./.db/init:/docker-entrypoint-initdb.d
|
||||
ports:
|
||||
- ${DATABASE_PORT}:5432 # DB
|
||||
@ -1,3 +0,0 @@
|
||||
# To prevent search engines from seeing the site altogether, uncomment the next two lines:
|
||||
# User-Agent: *
|
||||
# Disallow: /
|
||||
@ -1,35 +0,0 @@
|
||||
export default {
|
||||
config: {
|
||||
locales: [
|
||||
// 'ar',
|
||||
// 'fr',
|
||||
// 'cs',
|
||||
// 'de',
|
||||
// 'dk',
|
||||
// 'es',
|
||||
// 'he',
|
||||
// 'id',
|
||||
// 'it',
|
||||
// 'ja',
|
||||
// 'ko',
|
||||
// 'ms',
|
||||
// 'nl',
|
||||
// 'no',
|
||||
// 'pl',
|
||||
// 'pt-BR',
|
||||
// 'pt',
|
||||
// 'ru',
|
||||
// 'sk',
|
||||
// 'sv',
|
||||
// 'th',
|
||||
// 'tr',
|
||||
// 'uk',
|
||||
// 'vi',
|
||||
// 'zh-Hans',
|
||||
// 'zh',
|
||||
],
|
||||
},
|
||||
bootstrap(app) {
|
||||
console.log(app);
|
||||
},
|
||||
};
|
||||
@ -1,13 +0,0 @@
|
||||
{
|
||||
"extends": "@strapi/typescript-utils/tsconfigs/admin",
|
||||
"include": [
|
||||
"../plugins/**/admin/src/**/*",
|
||||
"./"
|
||||
],
|
||||
"exclude": [
|
||||
"node_modules/",
|
||||
"build/",
|
||||
"dist/",
|
||||
"**/*.test.ts"
|
||||
]
|
||||
}
|
||||
@ -1,12 +0,0 @@
|
||||
'use strict';
|
||||
const MonacoWebackPlugin = require('monaco-editor-webpack-plugin');
|
||||
|
||||
/* eslint-disable no-unused-vars */
|
||||
module.exports = (config, webpack) => {
|
||||
// Note: we provide webpack above so you should not `require` it
|
||||
// Perform customizations to webpack config
|
||||
// Important: return the modified config
|
||||
|
||||
config.plugins.push(new MonacoWebackPlugin())
|
||||
return config;
|
||||
};
|
||||
@ -1,32 +0,0 @@
|
||||
{
|
||||
"kind": "collectionType",
|
||||
"collectionName": "pages",
|
||||
"info": {
|
||||
"singularName": "page",
|
||||
"pluralName": "pages",
|
||||
"displayName": "Pages",
|
||||
"description": ""
|
||||
},
|
||||
"options": {
|
||||
"draftAndPublish": true
|
||||
},
|
||||
"pluginOptions": {},
|
||||
"attributes": {
|
||||
"label": {
|
||||
"type": "string"
|
||||
},
|
||||
"slug": {
|
||||
"type": "uid",
|
||||
"targetField": "label"
|
||||
},
|
||||
"seo": {
|
||||
"type": "component",
|
||||
"repeatable": false,
|
||||
"component": "shared.seo"
|
||||
},
|
||||
"Login": {
|
||||
"type": "dynamiczone",
|
||||
"components": []
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -1,7 +0,0 @@
|
||||
/**
|
||||
* page controller
|
||||
*/
|
||||
|
||||
import { factories } from '@strapi/strapi'
|
||||
|
||||
export default factories.createCoreController('api::page.page');
|
||||
@ -1,7 +0,0 @@
|
||||
/**
|
||||
* page router
|
||||
*/
|
||||
|
||||
import { factories } from '@strapi/strapi';
|
||||
|
||||
export default factories.createCoreRouter('api::page.page');
|
||||
@ -1,7 +0,0 @@
|
||||
/**
|
||||
* page service
|
||||
*/
|
||||
|
||||
import { factories } from '@strapi/strapi';
|
||||
|
||||
export default factories.createCoreService('api::page.page');
|
||||
@ -1,17 +0,0 @@
|
||||
/**
|
||||
* A set of functions called "actions" for `username`
|
||||
*/
|
||||
|
||||
export default {
|
||||
findOne: async (ctx, next) => {
|
||||
try {
|
||||
const data = await strapi
|
||||
.service("api::username.username")
|
||||
.findUsername(ctx.params.username);
|
||||
|
||||
ctx.body = data;
|
||||
} catch (err) {
|
||||
ctx.badRequest("Post report controller error", {moreDetails: err});
|
||||
}
|
||||
}
|
||||
};
|
||||
@ -1,13 +0,0 @@
|
||||
export default {
|
||||
routes: [
|
||||
{
|
||||
method: 'GET',
|
||||
path: '/username/:username',
|
||||
handler: 'username.findOne',
|
||||
config: {
|
||||
policies: [],
|
||||
middlewares: [],
|
||||
},
|
||||
},
|
||||
],
|
||||
};
|
||||
@ -1,18 +0,0 @@
|
||||
/**
|
||||
* username service
|
||||
*/
|
||||
|
||||
export default () => ({
|
||||
findUsername: async (username) => {
|
||||
try {
|
||||
console.log(username);
|
||||
let users = await strapi.entityService.findMany(
|
||||
"plugin::users-permissions.user", {filters: {email: username}}
|
||||
);
|
||||
|
||||
return users.length !== 0;
|
||||
} catch (err) {
|
||||
return err;
|
||||
}
|
||||
}
|
||||
});
|
||||
@ -1,16 +0,0 @@
|
||||
{
|
||||
"collectionName": "components_meta_metas",
|
||||
"info": {
|
||||
"displayName": "meta",
|
||||
"icon": "network-wired"
|
||||
},
|
||||
"options": {},
|
||||
"attributes": {
|
||||
"property": {
|
||||
"type": "string"
|
||||
},
|
||||
"content": {
|
||||
"type": "string"
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -1,36 +0,0 @@
|
||||
{
|
||||
"collectionName": "components_shared_seos",
|
||||
"info": {
|
||||
"displayName": "Seo",
|
||||
"icon": "book",
|
||||
"description": ""
|
||||
},
|
||||
"options": {},
|
||||
"attributes": {
|
||||
"metaTitle": {
|
||||
"type": "string"
|
||||
},
|
||||
"metaDescription": {
|
||||
"type": "text"
|
||||
},
|
||||
"SharedImage": {
|
||||
"displayName": "SharedImage",
|
||||
"type": "component",
|
||||
"repeatable": false,
|
||||
"component": "shared.shared-image"
|
||||
},
|
||||
"Meta": {
|
||||
"displayName": "meta",
|
||||
"type": "component",
|
||||
"repeatable": true,
|
||||
"component": "meta.meta"
|
||||
},
|
||||
"preventIndexing": {
|
||||
"type": "boolean",
|
||||
"default": false
|
||||
},
|
||||
"structuredData": {
|
||||
"type": "json"
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -1,24 +0,0 @@
|
||||
{
|
||||
"collectionName": "components_shared_shared_images",
|
||||
"info": {
|
||||
"displayName": "SharedImage",
|
||||
"icon": "file-image",
|
||||
"description": ""
|
||||
},
|
||||
"options": {},
|
||||
"attributes": {
|
||||
"alt": {
|
||||
"type": "string"
|
||||
},
|
||||
"media": {
|
||||
"allowedTypes": [
|
||||
"images",
|
||||
"files",
|
||||
"videos",
|
||||
"audios"
|
||||
],
|
||||
"type": "media",
|
||||
"multiple": false
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -1,79 +0,0 @@
|
||||
{
|
||||
"kind": "collectionType",
|
||||
"collectionName": "up_users",
|
||||
"info": {
|
||||
"name": "user",
|
||||
"description": "",
|
||||
"singularName": "user",
|
||||
"pluralName": "users",
|
||||
"displayName": "User"
|
||||
},
|
||||
"options": {
|
||||
"draftAndPublish": false,
|
||||
"timestamps": true
|
||||
},
|
||||
"attributes": {
|
||||
"username": {
|
||||
"type": "string",
|
||||
"minLength": 3,
|
||||
"unique": true,
|
||||
"configurable": false,
|
||||
"required": true
|
||||
},
|
||||
"email": {
|
||||
"type": "email",
|
||||
"minLength": 6,
|
||||
"configurable": false,
|
||||
"required": true
|
||||
},
|
||||
"provider": {
|
||||
"type": "string",
|
||||
"configurable": false
|
||||
},
|
||||
"password": {
|
||||
"type": "password",
|
||||
"minLength": 6,
|
||||
"configurable": false,
|
||||
"private": true
|
||||
},
|
||||
"resetPasswordToken": {
|
||||
"type": "string",
|
||||
"configurable": false,
|
||||
"private": true
|
||||
},
|
||||
"confirmationToken": {
|
||||
"type": "string",
|
||||
"configurable": false,
|
||||
"private": true
|
||||
},
|
||||
"confirmed": {
|
||||
"type": "boolean",
|
||||
"default": false,
|
||||
"configurable": false
|
||||
},
|
||||
"blocked": {
|
||||
"type": "boolean",
|
||||
"default": false,
|
||||
"configurable": false
|
||||
},
|
||||
"role": {
|
||||
"type": "relation",
|
||||
"relation": "manyToOne",
|
||||
"target": "plugin::users-permissions.role",
|
||||
"inversedBy": "users",
|
||||
"configurable": false
|
||||
},
|
||||
"avatar": {
|
||||
"allowedTypes": [
|
||||
"images"
|
||||
],
|
||||
"type": "media",
|
||||
"configurable": false,
|
||||
"multiple": false
|
||||
},
|
||||
"newsletter": {
|
||||
"type": "boolean",
|
||||
"default": false
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -1,18 +0,0 @@
|
||||
export default {
|
||||
/**
|
||||
* An asynchronous register function that runs before
|
||||
* your application is initialized.
|
||||
*
|
||||
* This gives you an opportunity to extend code.
|
||||
*/
|
||||
register(/*{ strapi }*/) {},
|
||||
|
||||
/**
|
||||
* An asynchronous bootstrap function that runs before
|
||||
* your application gets started.
|
||||
*
|
||||
* This gives you an opportunity to set up your data model,
|
||||
* run jobs, or perform some special logic.
|
||||
*/
|
||||
bootstrap(/*{ strapi }*/) {},
|
||||
};
|
||||
@ -1,23 +0,0 @@
|
||||
{
|
||||
"extends": "@strapi/typescript-utils/tsconfigs/server",
|
||||
"compilerOptions": {
|
||||
"outDir": "../../dist/apps/backend/dist",
|
||||
"rootDir": "."
|
||||
},
|
||||
"include": [
|
||||
"./",
|
||||
"./**/*.ts",
|
||||
"./**/*.js",
|
||||
"src/**/*.json"
|
||||
],
|
||||
"exclude": [
|
||||
"node_modules/",
|
||||
"build/",
|
||||
"dist/",
|
||||
".cache/",
|
||||
".tmp/",
|
||||
"src/admin/",
|
||||
"**/*.test.*",
|
||||
"src/plugins/**"
|
||||
]
|
||||
}
|
||||
@ -0,0 +1,2 @@
|
||||
NX_STRAPI_URL_API=http://localhost:1337/api
|
||||
NX_STRAPI_URL=http://localhost:1337
|
||||
@ -0,0 +1,7 @@
|
||||
/*
|
||||
* Replace this with your own classes
|
||||
*
|
||||
* e.g.
|
||||
* .container {
|
||||
* }
|
||||
*/
|
||||
@ -0,0 +1,170 @@
|
||||
import delve from "dlv";
|
||||
import axios from "axios";
|
||||
import {SubmitHandler, useForm} from "react-hook-form";
|
||||
|
||||
import SeoConfig from "../../components/seo-config/seo-config";
|
||||
import Layout from "../../components/layout/layout";
|
||||
import {environment} from "../../environments/environment";
|
||||
import {ResetPasswordInputs} from "../../libs/api";
|
||||
|
||||
import styles from './index.module.scss';
|
||||
import {useRouter} from "next/router";
|
||||
import {useState} from "react";
|
||||
import {resetPasswordStrapi} from "../../libs/auth";
|
||||
|
||||
const getPageMetadata = async (path) => {
|
||||
try {
|
||||
return await axios.get(`${environment.strapiApiUrl}/pages?filters[slug]=${path === '/' ? 'home' : path.slice(1, path.length)}&populate=deep`);
|
||||
} catch (e) {
|
||||
console.error(e);
|
||||
return Promise.resolve({})
|
||||
}
|
||||
}
|
||||
|
||||
export const getServerSideProps = async (context) => {
|
||||
const path = context.resolvedUrl;
|
||||
const menuHeader = await axios.get(`${environment.strapiApiUrl}/menus/1?nested&populate=deep`);
|
||||
const menuFooter = await axios.get(`${environment.strapiApiUrl}/menus/2?nested&populate=deep`);
|
||||
const page = await getPageMetadata(path);
|
||||
return {
|
||||
props: {
|
||||
menuHeaders: delve(menuHeader, 'data.data.attributes.items.data', []),
|
||||
menuFooter: delve(menuFooter, 'data.data.attributes.items.data', []),
|
||||
page: delve(page, "data.data.0.attributes", {}),
|
||||
seo: delve(page, "data.data.0.attributes.seo", {})
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
export function ResetPassword({menuHeaders, menuFooter, page, seo}) {
|
||||
const router = useRouter();
|
||||
const [success, setSuccess] = useState(null);
|
||||
|
||||
const {register, handleSubmit, getValues, formState: {errors}} = useForm({
|
||||
defaultValues: {
|
||||
password: null,
|
||||
passwordConfirmation: null,
|
||||
code: router.query ? router.query.code : null
|
||||
}
|
||||
});
|
||||
|
||||
const onSubmit: SubmitHandler<ResetPasswordInputs> = async (data: ResetPasswordInputs) => {
|
||||
try {
|
||||
const result = await resetPasswordStrapi({
|
||||
password: data.password,
|
||||
passwordConfirmation: data.passwordConfirmation,
|
||||
code: data.code
|
||||
});
|
||||
setSuccess(result);
|
||||
setTimeout(() => router.push('/sign-in'), 5000);
|
||||
} catch (e) {
|
||||
setSuccess(false);
|
||||
}
|
||||
}
|
||||
|
||||
const hasErrors = () => Object.keys(errors).length > 0;
|
||||
|
||||
const isBoolean = (val) => typeof val === "boolean";
|
||||
|
||||
return (
|
||||
<>
|
||||
<SeoConfig {...seo}/>
|
||||
<Layout menuHeader={menuHeaders} menuFooter={menuFooter}>
|
||||
<div className={styles['page-sign-up']}>
|
||||
<section className={styles['section']}>
|
||||
<div className="container px-6 py-4 md:py-12 h-full mx-auto">
|
||||
<div className="flex justify-center items-center flex-wrap h-full g-6 text-gray-800">
|
||||
<div className="md:w-8/12 lg:w-6/12 mb-12 md:mb-0 hidden md:block">
|
||||
<img src="/images/page-lost-password.png"
|
||||
className="w-full" alt="Phone image"/>
|
||||
</div>
|
||||
<div className="md:w-8/12 lg:w-6/12 flex justify-end">
|
||||
<div
|
||||
className="w-full max-w-[560px] p-4 bg-white border border-gray-200 rounded-lg shadow-md sm:p-6 md:p-8 dark:bg-gray-800 dark:border-gray-700">
|
||||
<form className="space-y-6" onSubmit={handleSubmit(onSubmit)}>
|
||||
<header className="text-left block">
|
||||
<h3 className="text-3xl font-normal dark:text-white mb-6">Changer votre mot de passe</h3>
|
||||
<p className="mb-6 text-base font-normal text-gray-500 dark:text-gray-400">
|
||||
Indiquez votre nouveau mot de passe
|
||||
</p>
|
||||
</header>
|
||||
{isBoolean(success) && success ? (<div
|
||||
className="p-4 mb-4 text-sm text-green-800 rounded-lg bg-green-50 dark:bg-gray-800 dark:text-green-400"
|
||||
role="alert">
|
||||
<span className="font-medium">Mot de passe changé !</span> vous allez être redirigé vers la page
|
||||
de connexion.
|
||||
</div>) : ('')}
|
||||
{isBoolean(success) && !success ? (<div
|
||||
className="p-4 mb-4 text-sm text-red-800 rounded-lg bg-red-50 dark:bg-gray-800 dark:text-red-400"
|
||||
role="alert">
|
||||
<span className="font-medium">Oups !</span> Une erreur est survenue durant le changement du mot
|
||||
de passe. Rapprochez vous de nos équipes pour en savoir plus.
|
||||
</div>) : ('')}
|
||||
<main>
|
||||
<section className="grid grid-cols-1 gap-4 mb-4">
|
||||
<div>
|
||||
<label htmlFor="password"
|
||||
className="block mb-2 text-sm font-medium text-gray-900 dark:text-white">
|
||||
Mot de passe
|
||||
</label>
|
||||
<div className="relative">
|
||||
<input type="password"
|
||||
name="password"
|
||||
id="password"
|
||||
{...register("password", {required: "Le mot de passe est requis", minLength: 8})}
|
||||
className={errors.email ? 'bg-red-50 border border-red-500 text-red-900 placeholder-red-700 text-sm rounded-lg focus:ring-red-500 dark:bg-gray-700 focus:border-red-500 block w-full p-2.5 dark:text-red-500 dark:placeholder-red-500 dark:border-red-500' : 'bg-gray-50 border border-gray-300 text-gray-900 text-sm rounded-lg focus:ring-blue-500 focus:border-blue-500 block w-full pr-10 p-2.5 dark:bg-gray-600 dark:border-gray-500 dark:placeholder-gray-400 dark:text-white'}/>
|
||||
{errors.password && errors.password.type !== "minLength" && (
|
||||
<p
|
||||
className="mt-2 text-sm text-red-600 dark:text-red-500">{errors.password.message}</p>)}
|
||||
{errors.password && errors.password.type === "minLength" && (
|
||||
<p className="mt-2 text-sm text-red-600 dark:text-red-500">Le mot de passe doit avoir
|
||||
une
|
||||
longueur minimum de 8 charactères</p>)}
|
||||
</div>
|
||||
</div>
|
||||
<div>
|
||||
<label htmlFor="passwordConfirmation"
|
||||
className="block mb-2 text-sm font-medium text-gray-900 dark:text-white">
|
||||
Confirmez votre mot de passe
|
||||
</label>
|
||||
<div className="relative">
|
||||
<input type="password"
|
||||
name="passwordConfirmation"
|
||||
id="passwordConfirmation"
|
||||
{...register("passwordConfirmation", {
|
||||
required: "Veuillez confirmer le mot de passe", validate: {
|
||||
matchesPreviousPassword: (value) => {
|
||||
const {password} = getValues();
|
||||
return password === value || "Les mots de passe ne correspondent pas";
|
||||
}
|
||||
}
|
||||
})}
|
||||
className={errors.password ? 'bg-red-50 border border-red-500 text-red-900 placeholder-red-700 text-sm rounded-lg focus:ring-red-500 dark:bg-gray-700 focus:border-red-500 block w-full p-2.5 dark:text-red-500 dark:placeholder-red-500 dark:border-red-500' : 'bg-gray-50 border border-gray-300 text-gray-900 text-sm rounded-lg focus:ring-blue-500 focus:border-blue-500 block w-full pr-10 p-2.5 dark:bg-gray-600 dark:border-gray-500 dark:placeholder-gray-400 dark:text-white'}/>
|
||||
{errors.passwordConfirmation && (
|
||||
<p
|
||||
className="mt-2 text-sm text-red-600 dark:text-red-500">{errors.passwordConfirmation.message}</p>)}
|
||||
</div>
|
||||
</div>
|
||||
</section>
|
||||
<section className="flex items-center pt-5">
|
||||
<button type="submit"
|
||||
className="text-white bg-blue-700 hover:bg-blue-800 focus:ring-4 focus:ring-blue-300 font-medium rounded-lg text-sm px-5 py-2.5 mb-2 dark:bg-blue-600 dark:hover:bg-blue-700 focus:outline-none dark:focus:ring-blue-800 w-full disabled:bg-gray-500 focus:disabled:bg-gray-500 hover:disabled:bg-gray-500"
|
||||
data-mdb-ripple="true"
|
||||
data-mdb-ripple-color="light" disabled={hasErrors()}>
|
||||
Changer votre mot de passe
|
||||
</button>
|
||||
</section>
|
||||
</main>
|
||||
</form>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</section>
|
||||
</div>
|
||||
</Layout>
|
||||
</>
|
||||
);
|
||||
}
|
||||
|
||||
export default ResetPassword;
|
||||
|
After Width: | Height: | Size: 140 KiB |
@ -1,34 +0,0 @@
|
||||
services:
|
||||
|
||||
# PostgreSQL (Database)
|
||||
#gs_postgres:
|
||||
# extends:
|
||||
# file: apps/backend/postgres.yml
|
||||
# service: gs_postgres
|
||||
|
||||
# MySQL (Database)
|
||||
gs_mysql:
|
||||
extends:
|
||||
file: apps/backend/mysql.yml
|
||||
service: gs_mysql
|
||||
|
||||
gs_redis:
|
||||
image: "redis:alpine"
|
||||
ports:
|
||||
- "6379:6379"
|
||||
|
||||
gs_redis_commander:
|
||||
image: rediscommander/redis-commander:latest
|
||||
environment:
|
||||
- REDIS_HOSTS=local:gs_redis:6379
|
||||
ports:
|
||||
- "8081:8081"
|
||||
depends_on:
|
||||
- gs_redis
|
||||
|
||||
|
||||
volumes:
|
||||
gs_postgres-master:
|
||||
driver: local
|
||||
gs_mariadb-master:
|
||||
driver: local
|
||||
File diff suppressed because one or more lines are too long
@ -1,9 +0,0 @@
|
||||
const fs = require('fs');
|
||||
const fse = require('fs-extra');
|
||||
const path = require('path');
|
||||
|
||||
fse.copySync(path.join(__dirname, '..', '..', 'apps/backend/public'), path.join(__dirname, '..', '..', 'dist', 'apps', 'backend/public'));
|
||||
fs.copyFileSync(path.join(__dirname, '..', '..', 'apps/backend/.env.staging'), path.join(__dirname, '..', '..', 'dist', 'apps', 'backend/.env'));
|
||||
fs.copyFileSync(path.join(__dirname, 'sources/server.js'), path.join(__dirname, '..', '..', 'dist', 'apps', 'backend/server.js'));
|
||||
fs.copyFileSync(path.join(__dirname, 'sources/package.json'), path.join(__dirname, '..', '..', 'dist', 'apps', 'backend/package.json'));
|
||||
fs.copyFileSync(path.join(__dirname, 'sources/.strapi-updater.json'), path.join(__dirname, '..', '..', 'dist', 'apps', 'backend/.strapi-updater.json'));
|
||||
@ -1,4 +0,0 @@
|
||||
{
|
||||
"latest": "4.5.6",
|
||||
"lastUpdateCheck": 1674315789881
|
||||
}
|
||||
@ -1,31 +0,0 @@
|
||||
{
|
||||
"name": "nx-guitar-school",
|
||||
"version": "0.0.0",
|
||||
"overrides": {
|
||||
"@strapi/strapi": "4.5.4"
|
||||
},
|
||||
"dependencies": {
|
||||
"@strapi/plugin-i18n": "4.5.4",
|
||||
"@strapi/plugin-users-permissions": "4.5.4",
|
||||
"@strapi/provider-email-nodemailer": "4.5.6",
|
||||
"@strapi/strapi": "4.5.4",
|
||||
"@strapi/utils": "4.5.6",
|
||||
"better-sqlite3": "7.4.6",
|
||||
"mysql": "2.18.1",
|
||||
"pg": "8.8.0",
|
||||
"strapi-plugin-import-export-entries": "1.18.0",
|
||||
"strapi-plugin-menus": "1.2.1",
|
||||
"strapi-plugin-populate-deep": "1.1.2"
|
||||
},
|
||||
"author": {
|
||||
"name": "A Strapi developer"
|
||||
},
|
||||
"strapi": {
|
||||
"uuid": "d1de7a93-c68b-4597-80ee-b5b56ea4eb10"
|
||||
},
|
||||
"engines": {
|
||||
"node": ">=14.19.1 <=18.x.x",
|
||||
"npm": ">=6.0.0"
|
||||
},
|
||||
"license": "MIT"
|
||||
}
|
||||
@ -1,3 +0,0 @@
|
||||
const strapi = require('@strapi/strapi');
|
||||
const app = strapi({distDir: './dist'});
|
||||
app.start();
|
||||
Loading…
Reference in new issue