Skip to content

Commit

Permalink
Mark passwords as sensitive variables #11652
Browse files Browse the repository at this point in the history
  • Loading branch information
jacobtylerwalls committed Nov 25, 2024
1 parent 06ed15a commit fb626c1
Show file tree
Hide file tree
Showing 3 changed files with 11 additions and 1 deletion.
2 changes: 2 additions & 0 deletions arches/app/views/api/auth.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@
from django.contrib.auth.views import LoginView, LogoutView
from django.contrib.auth import authenticate, login, logout
from django.utils.decorators import method_decorator
from django.views.decorators.debug import sensitive_variables
from django.utils.translation import gettext as _
from django_ratelimit.decorators import ratelimit

Expand All @@ -17,6 +18,7 @@ class Login(LoginView, APIBase):

http_method_names = ["post"]

@sensitive_variables()
@method_decorator(
ratelimit(key="post:username", rate=settings.RATE_LIMIT, block=False)
)
Expand Down
9 changes: 8 additions & 1 deletion arches/app/views/auth.py
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,6 @@
import base64
import io

from django.http import response
from arches.app.utils.external_oauth_backend import ExternalOauthAuthenticationBackend
import qrcode
import pyotp
Expand All @@ -33,6 +32,7 @@
from django.utils.decorators import method_decorator
from django.views.decorators.cache import never_cache
from django.views.decorators.csrf import csrf_exempt
from django.views.decorators.debug import sensitive_variables
from django.utils.html import strip_tags
from django.utils.translation import gettext as _
from django.utils.http import urlencode
Expand Down Expand Up @@ -87,6 +87,7 @@ def get(self, request):
},
)

@sensitive_variables()
@method_decorator(
ratelimit(
key="post:username",
Expand Down Expand Up @@ -369,6 +370,7 @@ def get(self, request):
}
return JSONResponse(messages)

@sensitive_variables()
@method_decorator(ratelimit(key="user", rate=settings.RATE_LIMIT, block=False))
def post(self, request):
messages = {
Expand Down Expand Up @@ -425,6 +427,7 @@ class PasswordResetConfirmView(auth_views.PasswordResetConfirmView):

@method_decorator(csrf_exempt, name="dispatch")
class UserProfileView(View):
@sensitive_variables()
@method_decorator(ratelimit(key="post:username", rate=settings.RATE_LIMIT))
def post(self, request):
username = request.POST.get("username", None)
Expand All @@ -446,6 +449,7 @@ def post(self, request):

@method_decorator(csrf_exempt, name="dispatch")
class GetClientIdView(View):
@sensitive_variables()
@method_decorator(ratelimit(key="post:username", rate=settings.RATE_LIMIT))
def post(self, request):
if settings.OAUTH_CLIENT_ID == "":
Expand All @@ -465,6 +469,7 @@ def post(self, request):

@method_decorator(csrf_exempt, name="dispatch")
class ServerSettingView(View):
@sensitive_variables()
@method_decorator(ratelimit(key="post:username", rate=settings.RATE_LIMIT))
def post(self, request):
if settings.OAUTH_CLIENT_ID == "":
Expand Down Expand Up @@ -573,6 +578,7 @@ def post(self, request):

@method_decorator(never_cache, name="dispatch")
class TwoFactorAuthenticationLoginView(View):
@sensitive_variables()
def post(self, request):
username = request.POST.get("username", None)
password = request.POST.get("password", None)
Expand Down Expand Up @@ -718,6 +724,7 @@ def post(self, request):

@method_decorator(csrf_exempt, name="dispatch")
class Token(View):
@sensitive_variables()
def get(self, request):
if settings.DEBUG:
data = {
Expand Down
1 change: 1 addition & 0 deletions releases/8.0.0.md
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ Arches 8.0.0 Release Notes
### Additional highlights
- Add session-based REST APIs for login, logout [#11261](https://github.com/archesproject/arches/issues/11261)
- Add system check advising next action when enabling additional languages without updating graphs [#10079](https://github.com/archesproject/arches/issues/10079)
- Auth views now filter out passwords from error reports when running in production [#11652](https://github.com/archesproject/arches/issues/11652)
- Improve handling of longer model names [#11317](https://github.com/archesproject/arches/issues/11317)
- Support more expressive plugin URLs [#11320](https://github.com/archesproject/arches/issues/11320)
- Make node aliases not nullable [#10437](https://github.com/archesproject/arches/issues/10437)
Expand Down

0 comments on commit fb626c1

Please sign in to comment.