aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--app.ts2
-rw-r--r--config/default.json14
-rw-r--r--models/users/user.schema.ts5
-rw-r--r--package-lock.json167
-rw-r--r--package.json3
-rw-r--r--populateDb.ts1
-rw-r--r--services/auth/auth.service.ts16
-rw-r--r--services/index.ts2
-rw-r--r--services/users/users.hooks.ts16
-rw-r--r--services/users/users.service.ts2
10 files changed, 225 insertions, 3 deletions
diff --git a/app.ts b/app.ts
index 4b5ac3b..0623ef3 100644
--- a/app.ts
+++ b/app.ts
@@ -1,6 +1,7 @@
import feathers from '@feathersjs/feathers';
import express from '@feathersjs/express';
import socketio from '@feathersjs/socketio';
+import configuration from '@feathersjs/configuration'
import '@feathersjs/transport-commons';
import cors from 'cors';
@@ -15,6 +16,7 @@ app.use(express.static(__dirname));
app.use(express.errorHandler());
app.use(cors());
+app.configure(configuration());
app.configure(express.rest());
app.configure(socketio());
app.configure(services);
diff --git a/config/default.json b/config/default.json
new file mode 100644
index 0000000..141bf4c
--- /dev/null
+++ b/config/default.json
@@ -0,0 +1,14 @@
+{
+ "authentication": {
+ "secret": "2JtbBy2ycQ1V3kQfPcSgXYmFsB7",
+ "service": "users",
+ "authStrategies": [
+ "jwt",
+ "local"
+ ],
+ "local": {
+ "usernameField": "name",
+ "passwordField": "password"
+ }
+ }
+}
diff --git a/models/users/user.schema.ts b/models/users/user.schema.ts
index 07979d1..fd7d1e1 100644
--- a/models/users/user.schema.ts
+++ b/models/users/user.schema.ts
@@ -6,10 +6,13 @@ export interface User {
age?: number;
}
-export interface UserSchema extends Document, User {}
+export interface UserSchema extends Document, User {
+ password: string;
+}
export const userSchema = new Schema({
name: String,
+ password: String,
avatarUrl: {
type: String,
required: false
diff --git a/package-lock.json b/package-lock.json
index d8eb8a9..771797b 100644
--- a/package-lock.json
+++ b/package-lock.json
@@ -53,11 +53,50 @@
"@feathersjs/feathers": "^4.5.2"
}
},
+ "@feathersjs/authentication": {
+ "version": "4.5.3",
+ "resolved": "https://registry.npmjs.org/@feathersjs/authentication/-/authentication-4.5.3.tgz",
+ "integrity": "sha512-OhwLktiULpKMk0hwMNI0Rn285xDjvhnVkyeg6QuQ+84jhb4dFNHp8gE29wgJS0tYXL6jJchq5b9VvguHyoThmQ==",
+ "requires": {
+ "@feathersjs/errors": "^4.5.3",
+ "@feathersjs/feathers": "^4.5.3",
+ "@feathersjs/transport-commons": "^4.5.3",
+ "@types/jsonwebtoken": "^8.3.9",
+ "debug": "^4.1.1",
+ "jsonwebtoken": "^8.5.1",
+ "lodash": "^4.17.15",
+ "long-timeout": "^0.1.1",
+ "uuid": "^7.0.3"
+ }
+ },
+ "@feathersjs/authentication-local": {
+ "version": "4.5.4",
+ "resolved": "https://registry.npmjs.org/@feathersjs/authentication-local/-/authentication-local-4.5.4.tgz",
+ "integrity": "sha512-ji+Ai33rMT7xsS7mEsFZe/ICb8mR6YYnr0vz7bEGDoyWbGt/K/A+UeLKKMfcAyF+37RgiZ3386pIboR+IHlqfw==",
+ "requires": {
+ "@feathersjs/authentication": "^4.5.3",
+ "@feathersjs/errors": "^4.5.3",
+ "@feathersjs/feathers": "^4.5.3",
+ "bcryptjs": "^2.4.3",
+ "debug": "^4.1.1",
+ "lodash": "^4.17.15"
+ }
+ },
"@feathersjs/commons": {
"version": "4.5.3",
"resolved": "https://registry.npmjs.org/@feathersjs/commons/-/commons-4.5.3.tgz",
"integrity": "sha512-LsiZ0jxh13TT6SOrDq5VYtdBCv0Vdvu4a5Wei/Dvd/daZHX6ERuH6iQtfh2f5hFwuydtd+Ch/2GlYld8XziwhA=="
},
+ "@feathersjs/configuration": {
+ "version": "4.5.3",
+ "resolved": "https://registry.npmjs.org/@feathersjs/configuration/-/configuration-4.5.3.tgz",
+ "integrity": "sha512-CaVbrOBiEEeSf1R5XioIAb/u85Fktm3nu+3wwNwrVMgr7yk28qIB/+6G+2tf1SVl/gJV7nuKaBzotaDLYXqbqQ==",
+ "requires": {
+ "@feathersjs/feathers": "^4.5.3",
+ "config": "^3.3.1",
+ "debug": "^4.1.1"
+ }
+ },
"@feathersjs/errors": {
"version": "4.5.3",
"resolved": "https://registry.npmjs.org/@feathersjs/errors/-/errors-4.5.3.tgz",
@@ -209,6 +248,14 @@
"integrity": "sha1-7ihweulOEdK4J7y+UnC86n8+ce4=",
"dev": true
},
+ "@types/jsonwebtoken": {
+ "version": "8.5.0",
+ "resolved": "https://registry.npmjs.org/@types/jsonwebtoken/-/jsonwebtoken-8.5.0.tgz",
+ "integrity": "sha512-9bVao7LvyorRGZCw0VmH/dr7Og+NdjYSsKAxB43OQoComFbBgsEpoR9JW6+qSq/ogwVBg8GI2MfAlk4SYI4OLg==",
+ "requires": {
+ "@types/node": "*"
+ }
+ },
"@types/lodash": {
"version": "4.14.155",
"resolved": "https://registry.npmjs.org/@types/lodash/-/lodash-4.14.155.tgz",
@@ -483,6 +530,11 @@
"resolved": "https://registry.npmjs.org/base64id/-/base64id-2.0.0.tgz",
"integrity": "sha512-lGe34o6EHj9y3Kts9R4ZYs/Gr+6N7MCaMlIFA3F1R2O5/m7K06AxfSeO5530PEERE6/WyEg3lsuyw4GHlPZHog=="
},
+ "bcryptjs": {
+ "version": "2.4.3",
+ "resolved": "https://registry.npmjs.org/bcryptjs/-/bcryptjs-2.4.3.tgz",
+ "integrity": "sha1-mrVie5PmBiH/fNrF2pczAn3x0Ms="
+ },
"better-assert": {
"version": "1.0.2",
"resolved": "https://registry.npmjs.org/better-assert/-/better-assert-1.0.2.tgz",
@@ -557,6 +609,11 @@
"resolved": "https://registry.npmjs.org/bson/-/bson-1.1.4.tgz",
"integrity": "sha512-S/yKGU1syOMzO86+dGpg2qGoDL0zvzcb262G+gqEy6TgP6rt6z6qxSFX/8X6vLC91P7G7C3nLs0+bvDzmvBA3Q=="
},
+ "buffer-equal-constant-time": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz",
+ "integrity": "sha1-+OcRMvf/5uAaXJaXpMbz5I1cyBk="
+ },
"bytes": {
"version": "3.1.0",
"resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.0.tgz",
@@ -682,6 +739,24 @@
"integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=",
"dev": true
},
+ "config": {
+ "version": "3.3.1",
+ "resolved": "https://registry.npmjs.org/config/-/config-3.3.1.tgz",
+ "integrity": "sha512-+2/KaaaAzdwUBE3jgZON11L1ggLLhpf2FsGrfqYFHZW22ySGv/HqYIXrBwKKvn+XZh1UBUjHwAcrfsSkSygT+Q==",
+ "requires": {
+ "json5": "^2.1.1"
+ },
+ "dependencies": {
+ "json5": {
+ "version": "2.1.3",
+ "resolved": "https://registry.npmjs.org/json5/-/json5-2.1.3.tgz",
+ "integrity": "sha512-KXPvOm8K9IJKFM0bmdn8QXh7udDh1g/giieX0NLCaMnb4hEiVFqnop2ImTXCc5e0/oHz3LTqmHGtExn5hfMkOA==",
+ "requires": {
+ "minimist": "^1.2.5"
+ }
+ }
+ }
+ },
"confusing-browser-globals": {
"version": "1.0.9",
"resolved": "https://registry.npmjs.org/confusing-browser-globals/-/confusing-browser-globals-1.0.9.tgz",
@@ -789,6 +864,14 @@
"esutils": "^2.0.2"
}
},
+ "ecdsa-sig-formatter": {
+ "version": "1.0.11",
+ "resolved": "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.11.tgz",
+ "integrity": "sha512-nagl3RYrbNv6kQkeJIpt6NJZy8twLB/2vtz6yN9Z4vRKHN4/QZJIEbqohALSgwKdnksuY3k5Addp5lg8sVoVcQ==",
+ "requires": {
+ "safe-buffer": "^5.0.1"
+ }
+ },
"ee-first": {
"version": "1.1.1",
"resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz",
@@ -1732,6 +1815,42 @@
"minimist": "^1.2.0"
}
},
+ "jsonwebtoken": {
+ "version": "8.5.1",
+ "resolved": "https://registry.npmjs.org/jsonwebtoken/-/jsonwebtoken-8.5.1.tgz",
+ "integrity": "sha512-XjwVfRS6jTMsqYs0EsuJ4LGxXV14zQybNd4L2r0UvbVnSF9Af8x7p5MzbJ90Ioz/9TI41/hTCvznF/loiSzn8w==",
+ "requires": {
+ "jws": "^3.2.2",
+ "lodash.includes": "^4.3.0",
+ "lodash.isboolean": "^3.0.3",
+ "lodash.isinteger": "^4.0.4",
+ "lodash.isnumber": "^3.0.3",
+ "lodash.isplainobject": "^4.0.6",
+ "lodash.isstring": "^4.0.1",
+ "lodash.once": "^4.0.0",
+ "ms": "^2.1.1",
+ "semver": "^5.6.0"
+ }
+ },
+ "jwa": {
+ "version": "1.4.1",
+ "resolved": "https://registry.npmjs.org/jwa/-/jwa-1.4.1.tgz",
+ "integrity": "sha512-qiLX/xhEEFKUAJ6FiBMbes3w9ATzyk5W7Hvzpa/SLYdxNtng+gcurvrI7TbACjIXlsJyr05/S1oUhZrc63evQA==",
+ "requires": {
+ "buffer-equal-constant-time": "1.0.1",
+ "ecdsa-sig-formatter": "1.0.11",
+ "safe-buffer": "^5.0.1"
+ }
+ },
+ "jws": {
+ "version": "3.2.2",
+ "resolved": "https://registry.npmjs.org/jws/-/jws-3.2.2.tgz",
+ "integrity": "sha512-YHlZCB6lMTllWDtSPHz/ZXTsi8S00usEV6v1tjq8tOUZzw7DpSDWVXjXDre6ed1w/pd495ODpHZYSdkRTsa0HA==",
+ "requires": {
+ "jwa": "^1.4.1",
+ "safe-buffer": "^5.0.1"
+ }
+ },
"kareem": {
"version": "2.3.1",
"resolved": "https://registry.npmjs.org/kareem/-/kareem-2.3.1.tgz",
@@ -1774,6 +1893,46 @@
"resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.15.tgz",
"integrity": "sha512-8xOcRHvCjnocdS5cpwXQXVzmmh5e5+saE2QGoeQmbKmRS6J3VQppPOIt0MnmE+4xlZoumy0GPG0D0MVIQbNA1A=="
},
+ "lodash.includes": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/lodash.includes/-/lodash.includes-4.3.0.tgz",
+ "integrity": "sha1-YLuYqHy5I8aMoeUTJUgzFISfVT8="
+ },
+ "lodash.isboolean": {
+ "version": "3.0.3",
+ "resolved": "https://registry.npmjs.org/lodash.isboolean/-/lodash.isboolean-3.0.3.tgz",
+ "integrity": "sha1-bC4XHbKiV82WgC/UOwGyDV9YcPY="
+ },
+ "lodash.isinteger": {
+ "version": "4.0.4",
+ "resolved": "https://registry.npmjs.org/lodash.isinteger/-/lodash.isinteger-4.0.4.tgz",
+ "integrity": "sha1-YZwK89A/iwTDH1iChAt3sRzWg0M="
+ },
+ "lodash.isnumber": {
+ "version": "3.0.3",
+ "resolved": "https://registry.npmjs.org/lodash.isnumber/-/lodash.isnumber-3.0.3.tgz",
+ "integrity": "sha1-POdoEMWSjQM1IwGsKHMX8RwLH/w="
+ },
+ "lodash.isplainobject": {
+ "version": "4.0.6",
+ "resolved": "https://registry.npmjs.org/lodash.isplainobject/-/lodash.isplainobject-4.0.6.tgz",
+ "integrity": "sha1-fFJqUtibRcRcxpC4gWO+BJf1UMs="
+ },
+ "lodash.isstring": {
+ "version": "4.0.1",
+ "resolved": "https://registry.npmjs.org/lodash.isstring/-/lodash.isstring-4.0.1.tgz",
+ "integrity": "sha1-1SfftUVuynzJu5XV2ur4i6VKVFE="
+ },
+ "lodash.once": {
+ "version": "4.1.1",
+ "resolved": "https://registry.npmjs.org/lodash.once/-/lodash.once-4.1.1.tgz",
+ "integrity": "sha1-DdOXEhPHxW34gJd9UEyI+0cal6w="
+ },
+ "long-timeout": {
+ "version": "0.1.1",
+ "resolved": "https://registry.npmjs.org/long-timeout/-/long-timeout-0.1.1.tgz",
+ "integrity": "sha1-lyHXiLR+C8taJMLivuGg2lXatRQ="
+ },
"media-typer": {
"version": "0.3.0",
"resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz",
@@ -1831,8 +1990,7 @@
"minimist": {
"version": "1.2.5",
"resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz",
- "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==",
- "dev": true
+ "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw=="
},
"mkdirp": {
"version": "0.5.5",
@@ -2857,6 +3015,11 @@
"resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz",
"integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM="
},
+ "uuid": {
+ "version": "7.0.3",
+ "resolved": "https://registry.npmjs.org/uuid/-/uuid-7.0.3.tgz",
+ "integrity": "sha512-DPSke0pXhTZgoF/d+WSt2QaKMCFSfx7QegxEWT+JOuHF5aWrKEn0G+ztjuJg/gG8/ItK+rbPCD/yNv8yyih6Cg=="
+ },
"v8-compile-cache": {
"version": "2.1.1",
"resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.1.1.tgz",
diff --git a/package.json b/package.json
index 4cbabab..7116faa 100644
--- a/package.json
+++ b/package.json
@@ -10,6 +10,9 @@
"author": "",
"license": "ISC",
"dependencies": {
+ "@feathersjs/authentication": "^4.5.3",
+ "@feathersjs/authentication-local": "^4.5.4",
+ "@feathersjs/configuration": "^4.5.3",
"@feathersjs/express": "^4.5.4",
"@feathersjs/feathers": "^4.5.3",
"@feathersjs/socketio": "^4.5.4",
diff --git a/populateDb.ts b/populateDb.ts
index 0a89cc9..a21b669 100644
--- a/populateDb.ts
+++ b/populateDb.ts
@@ -46,6 +46,7 @@ const createPoll = (authorId: string): Promise<PollSchema> => {
const createUser = (name: string): Promise<UserSchema> => {
return app.service('users').create({
avatarUrl: _.sample(imageUrls) || '',
+ password: 'supersecret',
name
});
};
diff --git a/services/auth/auth.service.ts b/services/auth/auth.service.ts
new file mode 100644
index 0000000..42846b0
--- /dev/null
+++ b/services/auth/auth.service.ts
@@ -0,0 +1,16 @@
+import {
+ AuthenticationService,
+ JWTStrategy
+} from '@feathersjs/authentication';
+import { LocalStrategy } from '@feathersjs/authentication-local';
+import { Application } from '@feathersjs/express';
+
+export default (app: Application): void => {
+ const authentication = new AuthenticationService(app);
+
+ authentication.register('local', new LocalStrategy());
+ authentication.register('jwt', new JWTStrategy());
+
+ app.use('/authentication', authentication);
+};
+
diff --git a/services/index.ts b/services/index.ts
index d946e9d..f000837 100644
--- a/services/index.ts
+++ b/services/index.ts
@@ -2,8 +2,10 @@ import { Application } from '@feathersjs/express';
import Users from './users/users.service';
import Polls from './polls/polls.service';
import Profiles from './profiles/profiles.service';
+import Auth from './auth/auth.service';
export default (app: Application): void => {
+ app.configure(Auth);
app.configure(Users);
app.configure(Polls);
app.configure(Profiles);
diff --git a/services/users/users.hooks.ts b/services/users/users.hooks.ts
new file mode 100644
index 0000000..fc17ed7
--- /dev/null
+++ b/services/users/users.hooks.ts
@@ -0,0 +1,16 @@
+import { hooks } from '@feathersjs/authentication-local';
+
+const hashPassword = hooks.hashPassword('password');
+const protectPassword = hooks.protect('password');
+
+export default {
+ after: {
+ all: [protectPassword]
+ },
+ before: {
+ create: [hashPassword],
+ patch: [hashPassword],
+ update: [hashPassword]
+ }
+};
+
diff --git a/services/users/users.service.ts b/services/users/users.service.ts
index 988d162..08c347d 100644
--- a/services/users/users.service.ts
+++ b/services/users/users.service.ts
@@ -1,10 +1,12 @@
import { Application } from '@feathersjs/express';
import service from 'feathers-mongoose';
import Model from '../../models/users/user.model';
+import hooks from './users.hooks';
const UserService = service({ Model });
export default (app: Application): void => {
app.use('/users', UserService);
+ app.service('users').hooks(hooks);
};