-
Notifications
You must be signed in to change notification settings - Fork 88
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Browse files
Browse the repository at this point in the history
* Add a "create-user" management command #458 Signed-off-by: Thomas Druez <tdruez@nexb.com> * Refine the stdout/stderr syntax on management commands #458 Signed-off-by: Thomas Druez <tdruez@nexb.com> * Add password prompt for the create-user command #458 Signed-off-by: Thomas Druez <tdruez@nexb.com> * Add documentation for the create-user command #458 Signed-off-by: Thomas Druez <tdruez@nexb.com>
- Loading branch information
Showing
17 changed files
with
215 additions
and
42 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,117 @@ | ||
# SPDX-License-Identifier: Apache-2.0 | ||
# | ||
# http://nexb.com and https://github.com/nexB/scancode.io | ||
# The ScanCode.io software is licensed under the Apache License version 2.0. | ||
# Data generated with ScanCode.io is provided as-is without warranties. | ||
# ScanCode is a trademark of nexB Inc. | ||
# | ||
# You may not use this software except in compliance with the License. | ||
# You may obtain a copy of the License at: http://apache.org/licenses/LICENSE-2.0 | ||
# Unless required by applicable law or agreed to in writing, software distributed | ||
# under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR | ||
# CONDITIONS OF ANY KIND, either express or implied. See the License for the | ||
# specific language governing permissions and limitations under the License. | ||
# | ||
# Data Generated with ScanCode.io is provided on an "AS IS" BASIS, WITHOUT WARRANTIES | ||
# OR CONDITIONS OF ANY KIND, either express or implied. No content created from | ||
# ScanCode.io should be considered or used as legal advice. Consult an Attorney | ||
# for any legal advice. | ||
# | ||
# ScanCode.io is a free software code scanning tool from nexB Inc. and others. | ||
# Visit https://github.com/nexB/scancode.io for support and download. | ||
|
||
import getpass | ||
|
||
from django.contrib.auth import get_user_model | ||
from django.contrib.auth.password_validation import validate_password | ||
from django.core import exceptions | ||
from django.core.management.base import BaseCommand | ||
from django.core.management.base import CommandError | ||
|
||
from rest_framework.authtoken.models import Token | ||
|
||
|
||
class Command(BaseCommand): | ||
help = "Create a user and generate an API key for authentication." | ||
requires_migrations_checks = True | ||
|
||
def __init__(self, *args, **kwargs): | ||
super().__init__(*args, **kwargs) | ||
self.UserModel = get_user_model() | ||
self.username_field = self.UserModel._meta.get_field( | ||
self.UserModel.USERNAME_FIELD | ||
) | ||
|
||
def add_arguments(self, parser): | ||
parser.add_argument("username", help="Specifies the username for the user.") | ||
parser.add_argument( | ||
"--no-input", | ||
action="store_false", | ||
dest="interactive", | ||
help="Do not prompt the user for input of any kind.", | ||
) | ||
|
||
def handle(self, *args, **options): | ||
username = options["username"] | ||
|
||
error_msg = self._validate_username(username) | ||
if error_msg: | ||
raise CommandError(error_msg) | ||
|
||
password = None | ||
if options["interactive"]: | ||
password = self.get_password_from_stdin(username) | ||
|
||
user = self.UserModel._default_manager.create_user(username, password=password) | ||
token, _ = Token._default_manager.get_or_create(user=user) | ||
|
||
if options["verbosity"] >= 1: | ||
msg = f"User {username} created with API key: {token.key}" | ||
self.stdout.write(msg, self.style.SUCCESS) | ||
|
||
def get_password_from_stdin(self, username): | ||
# Validators, such as UserAttributeSimilarityValidator, depends on other user's | ||
# fields data for password validation. | ||
fake_user_data = { | ||
self.UserModel.USERNAME_FIELD: username, | ||
} | ||
|
||
password = None | ||
while password is None: | ||
password1 = getpass.getpass() | ||
password2 = getpass.getpass("Password (again): ") | ||
if password1 != password2: | ||
self.stderr.write("Error: Your passwords didn't match.") | ||
continue | ||
if password1.strip() == "": | ||
self.stderr.write("Error: Blank passwords aren't allowed.") | ||
continue | ||
try: | ||
validate_password(password2, self.UserModel(**fake_user_data)) | ||
except exceptions.ValidationError as err: | ||
self.stderr.write("\n".join(err.messages)) | ||
response = input( | ||
"Bypass password validation and create user anyway? [y/N]: " | ||
) | ||
if response.lower() != "y": | ||
continue | ||
password = password1 | ||
|
||
return password | ||
|
||
def _validate_username(self, username): | ||
""" | ||
Validate username. If invalid, return a string error message. | ||
""" | ||
if self.username_field.unique: | ||
try: | ||
self.UserModel._default_manager.get_by_natural_key(username) | ||
except self.UserModel.DoesNotExist: | ||
pass | ||
else: | ||
return "Error: That username is already taken." | ||
|
||
try: | ||
self.username_field.clean(username, None) | ||
except exceptions.ValidationError as e: | ||
return "; ".join(e.messages) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.