]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blobdiff - scripts/reset-password.ts
Faster ci using compiled ts files
[github/Chocobozzz/PeerTube.git] / scripts / reset-password.ts
index 09f27bfa49b043fb406c57b872caa9322a584e7a..7c1a64a3f61077b30e3799bc686ee3657ce3f6ff 100755 (executable)
@@ -1,30 +1,36 @@
-import * as program from 'commander'
+import { registerTSPaths } from '../server/helpers/register-ts-paths'
+registerTSPaths()
 
-import { database as db } from '../server/initializers/database'
+import * as program from 'commander'
+import { initDatabaseModels } from '../server/initializers/database'
+import { UserModel } from '../server/models/user/user'
+import { isUserPasswordValid } from '../server/helpers/custom-validators/users'
 
 program
   .option('-u, --user [user]', 'User')
   .parse(process.argv)
 
-if (program.user === undefined) {
+const options = program.opts()
+
+if (options.user === undefined) {
   console.error('All parameters are mandatory.')
   process.exit(-1)
 }
 
-db.init(true)
+initDatabaseModels(true)
   .then(() => {
-    return db.User.loadByUsername(program.user)
+    return UserModel.loadByUsername(options.user)
   })
   .then(user => {
     if (!user) {
-      console.error('User unknown.')
-      return
+      console.error('Unknown user.')
+      process.exit(-1)
     }
 
     const readline = require('readline')
     const Writable = require('stream').Writable
     const mutableStdout = new Writable({
-      write: function (chunk, encoding, callback) {
+      write: function (_chunk, _encoding, callback) {
         callback()
       }
     })
@@ -36,6 +42,11 @@ db.init(true)
 
     console.log('New password?')
     rl.on('line', function (password) {
+      if (!isUserPasswordValid(password)) {
+        console.error('New password is invalid.')
+        process.exit(-1)
+      }
+
       user.password = password
 
       user.save()
@@ -44,3 +55,7 @@ db.init(true)
         .finally(() => process.exit(0))
     })
   })
+  .catch(err => {
+    console.error(err)
+    process.exit(-1)
+  })