1👍
✅
In essence, the settings
object is a lazy object that gets populate from the settings module. It will only populate with items that are written in uppercase (can be with punctuations like an underscore). Indeed, the source code that populates the items [GitHub] says:
for setting in dir(global_settings): if setting.isupper(): setattr(self, setting, getattr(global_settings, setting))
It will thus check if the setting satisfies the str.isupper()
method [Python-doc], if that is the case, it is added to the object, otherwise it is not. So you will need to define this in all-caps. The rationale behind it is likely that settings are constants, and in Python the convention is that constants are written in all-caps snake-case.
You can define the enum as:
class SYNCS(Enum):
A = 'a'
B = 'b'
But it makes me wondering why you want to define an enum in the settings, this is a bit "odd".
Source:stackexchange.com