Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Django 5.0 warnings: baseconv is deprecated #74

Open
MrCocoDev opened this issue Apr 25, 2022 · 35 comments · May be fixed by #108
Open

Django 5.0 warnings: baseconv is deprecated #74

MrCocoDev opened this issue Apr 25, 2022 · 35 comments · May be fixed by #108
Assignees
Labels

Comments

@MrCocoDev
Copy link

RemovedInDjango50Warning: The django.utils.baseconv module is deprecated.
    from django.utils import baseconv

https://code.djangoproject.com/ticket/32712

# django_cryptography/core/signing.py
- from django.utils import baseconv
+ from django.core.signing import b62_encode, b62_decode
@MrCocoDev
Copy link
Author

I can't create a PR for this repo but here is the diff:

diff --git a/django_cryptography/core/signing.py b/django_cryptography/core/signing.py
index 73ccc7f..c64f526 100644
--- a/django_cryptography/core/signing.py
+++ b/django_cryptography/core/signing.py
@@ -17,7 +17,7 @@ from django.core.signing import (
     b64_encode,
     get_cookie_signer,
 )
-from django.utils import baseconv
+from django.core.signing import b62_encode, b62_decode
 from django.utils.encoding import force_bytes, force_str
 
 from ..utils.crypto import constant_time_compare, salted_hmac
@@ -138,7 +138,7 @@ class Signer:
 
 class TimestampSigner(Signer):
     def timestamp(self):
-        return baseconv.base62.encode(int(time.time()))
+        return b62_encode(int(time.time()))
 
     def sign(self, value):
         value = force_str(value)
@@ -152,7 +152,7 @@ class TimestampSigner(Signer):
         """
         result = super().unsign(value)
         value, timestamp = result.rsplit(self.sep, 1)
-        timestamp = baseconv.base62.decode(timestamp)
+        timestamp = b62_decode(timestamp)
         if max_age is not None:
             if isinstance(max_age, datetime.timedelta):
                 max_age = max_age.total_seconds()

@georgemarshall
Copy link
Owner

I am going to sit on this for now, as I have been re-working the code to add type information. Django 5.0 isn't set to be release until December 2023o over a full year from now.

The unfortunate part is Django 3.2 will still be supported until April 2024. So a compatibility shims will be needed, or Django 3.2 support will be dropped once Django 5.0 is released.

@rburhum
Copy link

rburhum commented Oct 16, 2023

Getting close to that December date :-)

@MrCocoDev
Copy link
Author

@georgemarshall , would this not be as easy as:

try:
    from django.core.signing import b62_encode as encode
    from django.core.signing import b62_decode as decode
except ImportError:
    from django.utils import baseconv
    encode = baseconv.base62.encode
    decode = baseconv.base62.decode

...

 class TimestampSigner(Signer):
     def timestamp(self):
-        return baseconv.base62.encode(int(time.time()))
+        return encode(int(time.time()))
 
     def sign(self, value):
         value = force_str(value)
@@ -152,7 +152,7 @@ class TimestampSigner(Signer):
         """
         result = super().unsign(value)
         value, timestamp = result.rsplit(self.sep, 1)
-        timestamp = baseconv.base62.decode(timestamp)
+        timestamp = decode(timestamp)
         if max_age is not None:
             if isinstance(max_age, datetime.timedelta):
                 max_age = max_age.total_seconds()

Using try:except: to handle compatibility through imports is pretty powerful, and its easy to cleanup when the compatibility is no longer needed.

@jameslao
Copy link

Django 5.0 release is around the corner... any plan to fix this?

@saurav-codes
Copy link

Django 5 is released and i am having this error -

  File "/Users/sauravsharma/Developer/work/TPA/worktree_archipay/django-5-upgrades/env/lib/python3.10/site-packages/django_cryptography/core/signing.py", line 20, in <module>
    from django.utils import baseconv
ImportError: cannot import name 'baseconv' from 'django.utils' 

@saurav-codes
Copy link

alright, i fixed the issue.

  • first i cloned the repo in my django project.
  • cd django-cryptography
  • pip install -e .

initially i tried with pip install --upgrade django-cryptography but that didn't update the package so then i tried to install it with git repo but then it doesn't install it correctly. the core folder was missing. finally at the last above method works.

It seems the issue may be related to the package configuration for installation directly from the repository. The setup.py or pyproject.toml may not be including necessary sub-packages or dependencies for a correct install.

@saurav-codes
Copy link

i found the issue in setup.cfg. after this change, i can directly install from the repo and the subfolders ( the core folder ) is also included now. idk may be this may not be issue as i am unaware of the third party package code structure but since this change solves the issue, i created a PR here #106

@alexander-schillemans
Copy link

The 1.1 release on PyPi does not include the updated import statements in the core/signing.py which is throwing errors.
@georgemarshall Any chance you can push the new version to PyPi?

@saurav-codes
Copy link

As of now for those who are having issues can do -

pip install "git+https://github.com/saurav-codes/django-cryptography"

@jmaddington
Copy link

As of now for those who are having issues can do -

pip install "git+https://github.com/saurav-codes/django-cryptography"

This is for Django 5.0? As opposed to the comment that MrSage made above?

@MrCocoDev
Copy link
Author

Just as a general note, using an unmaintained cryptography library is probably not a good idea. I found some of the patterns shared here were quite extensible and dodged the problem:

https://www.piiano.com/blog/field-level-encryption-in-python-for-django-applications

@jmaddington
Copy link

As in you used approach 1 or 2 there?

@iyedeisaiah
Copy link

I reverted to django 4.1.3 and this solved the issue. Warning though other dependecies that depend on django 5.0 like crispy forms, django_q would have to be updated accordingly

@vitaliyf
Copy link

vitaliyf commented Jan 11, 2024

This change was already merged to master of this repository as part of #97 - just hasn't been released to PyPi yet. I opened #108 to perhaps make that easier.

@Redowan-Ahmed
Copy link

I'm using Django 5.0, To use the Django_cyptography,
Currently, I'm using this command because the Pypy is not updated yet
pip install "git+https://github.com/saurav-codes/django-cryptography"

@vhalis
Copy link

vhalis commented Feb 9, 2024

The change in #106 is required for installing from pip. Thanks @saurav-codes for the alternative for now and for the PR!

For those looking for the fix but want to be safe if you need to use a requirements file, you can pin to the commit hash:

django-cryptography @ git+https://github.com/saurav-codes/django-cryptography.git@ac210338dd2c84a410452e0b8e18ddee43f1920f

For pip above version 20.1

@adrenaline681
Copy link

Any update? Its already been over 3 months since Django 5 got released and we still can't install django-cryptography properly

@kirienko
Copy link

It seems that this issue is solved in #97 and therefore can be closed.

@chrisclark
Copy link

The issue is that there is no release that has been made -- not that it is not resolved in the code.

@adrenaline681
Copy link

The issue is that there is no release that has been made -- not that it is not resolved in the code.

Yes, please can we get a new release with these changes?

@chrisclark
Copy link

Concretely -- if a package depends on django-cryptography and that package wants to release to pypi, it can't happen without a release of this change first. A pinned github hash in the requirements will be rejected from pypi.

@chrisclark
Copy link

chrisclark commented Jun 4, 2024

I have forked the project, updated some dependencies, and published on pypi here:
https://pypi.org/project/django-cryptography-django5/

You can see the fork (and the code) here:
https://github.com/chrisclark/django-cryptography/

Feel free to pip install that version for anyone who needs it. Hopefully the changes can be brought into the official project soon. I hate to maintain a weird fork like this.

Simply: pip install django-cryptography-django5==2.2

@redblacktree
Copy link

Can we please get a comment from the authors on the pypi release? What is preventing this from happening? Do you need help resolving some issues?

@MrCocoDev
Copy link
Author

Open source projects are created and abandoned all the time. Forking the repo and petitioning Pypi for the original name doesn’t seem so farfetched to me.

@chrisclark
Copy link

Open source projects are created and abandoned all the time. Forking the repo and petitioning Pypi for the original name doesn’t seem so farfetched to me.

I agree in theory, but in practice I don’t intend on maintaining this indefinitely; if someone wants to pick up the mantle that would be great but it ain’t me, hah! This was easy since I was just updating some dependencies and incorporating changes others had already proposed. But I don’t know the codebase and certainly don’t have the expertise to be touching a bunch of crypto stuff. I promise no one wants me doing that :)

@ailandini-accenture
Copy link

Did anyone here switch to a different cryptology package? I'm having a lot of trouble finding one that is explicitly Django 5.0 compatible and actively maintained.

@pataquets
Copy link

pataquets commented Jun 11, 2024

On a cursory status check, maintainer seems quite unresponsive lately (which is understandable, since he has no obligation, keep in mind) and I'm wondering if he might be swamped by work, lost interest, not getting notifications or anything else. Sometimes it's just a newborn baby, which understandably pushes projects aside 😄.
I wonder if he might use some help (e.g. appointing co-mainteiners) or want to hand off project maintenance if he's lost interest/not using it anymore, which is perfectly fine.
So, I'm pinging @georgemarshall directly to increasing odds the notification finds its way and letting him know there is people interested who might want to step in to keep the project alive (thumb-up this comment to voice your interest). Just a quick note about reasonable expectations will be enough to make everyone aware and proceed forward.
I'll leave this comment for a while before opening a typical "Project maintenance status" issue (which it might be necessary anyway). I've had some success reviving/keeping projects alive this way in the past, and no doubt this one deserves better than just fade away silently, given the user base (read: potential candidate [co-]maintainers).

@georgemarshall Also, creating a Github organization and transferring the project might be an easy/useful first step for later adding [co-]maintainers you deem trustworthy.
In any case, thanks for considering and also thanks for sharing your work. Hope you're doing well.

@iklobato
Copy link

Django5 need some general fixes at django_q/core_signing.py, downgrade to latest LTS version:

pip install -U Django==4.2

@akhileshThapliyal
Copy link

Any idea when the package for Djnago 5.x will be released?

@rburhum
Copy link

rburhum commented Sep 4, 2024

@akhileshThapliyal use @chrisclark version for now. His fork includes the support for Django 5.x that you need.

@Armagad1972
Copy link

Hello,
It seems that it still not working:
image
Any chance to correct it ?

@ailandini-accenture
Copy link

@Armagad1972 I wouldn't hold your breath.
You didn't ask for it, but if you want my advice, I'd suggest forking the repo and fixing it like others have done above.
It seems crypto libraries in general aren't overtly maintained, so until someone steps up, you'll likely want to handle it yourself if you want something stable.

@Armagad1972
Copy link

@ailandini-accenture Thanks for your answer, but I have done by git and it works perfectly.
I will check if I will really need further

@noesis-software-technologies
Copy link

noesis-software-technologies commented Jan 4, 2025

as a work around I went into my directory where the import is made -> deleted the import and paste for the moment

    class BaseConverter(object):
        decimal_digits = "0123456789"
        
        def __init__(self, digits):
            self.digits = digits
        
        def from_int(self, i):
            return self.convert(i, self.decimal_digits, self.digits)
        
        def to_int(self, s):
            return int(self.convert(s, self.digits, self.decimal_digits))
        
        def convert(number, fromdigits, todigits):
            # Based on http://code.activestate.com/recipes/111286/
            if str(number)[0] == '-':
                number = str(number)[1:]
                neg = 1
            else:
                neg = 0
    
            # make an integer out of the number
            x = 0
            for digit in str(number):
               x = x * len(fromdigits) + fromdigits.index(digit)
        
            # create the result in base 'len(todigits)'
            if x == 0:
                res = todigits[0]
            else:
                res = ""
                while x > 0:
                    digit = x % len(todigits)
                    res = todigits[digit] + res
                    x = int(x / len(todigits))
                if neg:
                    res = '-' + res
            return res
        convert = staticmethod(convert)
    
    base2 = BaseConverter('01')
    base16 = BaseConverter('0123456789ABCDEF')
    base36 = BaseConverter('0123456789abcdefghijklmnopqrstuvwxyz')
    base62 = BaseConverter(
        '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz'
    )

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

Successfully merging a pull request may close this issue.