Skip to content

Commit

Permalink
Make CREATE_MISSING_FLAGS logic universal (#400)
Browse files Browse the repository at this point in the history
Before CREATE_MISSING_FLAGS was only respected when `is_active(request)`
method was used, now any check against a flag (calling `get(name)`) will
trigger the automatic creation of the `Flag` model.
  • Loading branch information
honzakral committed Mar 2, 2022
1 parent b22a97e commit fff498f
Showing 1 changed file with 7 additions and 10 deletions.
17 changes: 7 additions & 10 deletions waffle/models.py
Original file line number Diff line number Diff line change
Expand Up @@ -56,6 +56,13 @@ def get_from_db(cls, name):
objects = cls.objects
if get_setting('READ_FROM_WRITE_DB'):
objects = objects.using(router.db_for_write(cls))

if get_setting('CREATE_MISSING_FLAGS'):
flag, _created = objects.get_or_create(
name=name, defaults={'everyone': get_setting('FLAG_DEFAULT')}
)
return flag

return objects.get(name=name)

@classmethod
Expand Down Expand Up @@ -247,16 +254,6 @@ def is_active(self, request):
log_level = get_setting('LOG_MISSING_FLAGS')
if log_level:
logger.log(log_level, 'Flag %s not found', self.name)
if get_setting('CREATE_MISSING_FLAGS'):
flag, _created = get_waffle_flag_model().objects.get_or_create(
name=self.name,
defaults={
'everyone': get_setting('FLAG_DEFAULT')
}
)
cache = get_cache()
cache.set(self._cache_key(self.name), flag)

return get_setting('FLAG_DEFAULT')

if get_setting('OVERRIDE'):
Expand Down

0 comments on commit fff498f

Please sign in to comment.