mirror of
https://gitlab.com/allianceauth/allianceauth.git
synced 2025-07-12 14:00:17 +02:00
Prevent FAT CorpStats creation for missing corp models.
This commit is contained in:
parent
901dd5033a
commit
5a93128f4f
@ -9,6 +9,7 @@ from django.utils.translation import ugettext_lazy as _
|
|||||||
from django.utils import timezone
|
from django.utils import timezone
|
||||||
from django.contrib import messages
|
from django.contrib import messages
|
||||||
from django.core.paginator import Paginator, EmptyPage, PageNotAnInteger
|
from django.core.paginator import Paginator, EmptyPage, PageNotAnInteger
|
||||||
|
from django.db.models import Q
|
||||||
from eveonline.models import EveCharacter
|
from eveonline.models import EveCharacter
|
||||||
from eveonline.models import EveCorporationInfo
|
from eveonline.models import EveCorporationInfo
|
||||||
from eveonline.managers import EveManager
|
from eveonline.managers import EveManager
|
||||||
@ -100,19 +101,16 @@ def fatlink_statistics_view(request, year=datetime.date.today().year, month=date
|
|||||||
fat_stats = {}
|
fat_stats = {}
|
||||||
|
|
||||||
# get FAT stats for member corps
|
# get FAT stats for member corps
|
||||||
for corp_id in settings.STR_CORP_IDS:
|
query = Q(corporation_id__in=settings.STR_CORP_IDS) | Q(alliance__alliance_id__in=settings.STR_ALLIANCE_IDS)
|
||||||
fat_stats[corp_id] = CorpStat(corp_id, start_of_month, start_of_next_month)
|
for corp in EveCorporationInfo.objects.filter(query).distinct():
|
||||||
for alliance_id in settings.STR_ALLIANCE_IDS:
|
fat_stats[corp.corporation_id] = CorpStat(corp.corporation_id, start_of_month, start_of_next_month)
|
||||||
alliance_corps = EveCorporationInfo.objects.filter(alliance__alliance_id=alliance_id)
|
|
||||||
for corp in alliance_corps:
|
|
||||||
fat_stats[corp.corporation_id] = CorpStat(corp.corporation_id, start_of_month, start_of_next_month)
|
|
||||||
|
|
||||||
# get FAT stats for corps not in alliance
|
# get FAT stats for corps not in alliance
|
||||||
fats_in_span = Fat.objects.filter(fatlink__fatdatetime__gte=start_of_month).filter(
|
fats_in_span = Fat.objects.filter(fatlink__fatdatetime__gte=start_of_month).filter(
|
||||||
fatlink__fatdatetime__lt=start_of_next_month).exclude(character__corporation_id__in=fat_stats)
|
fatlink__fatdatetime__lt=start_of_next_month).exclude(character__corporation_id__in=fat_stats)
|
||||||
|
|
||||||
for fat in fats_in_span:
|
for fat in fats_in_span.exclude(character__corporation_id__in=fat_stats):
|
||||||
if fat.character.corporation_id not in fat_stats:
|
if EveCorporationInfo.objects.filter(corporation_id=fat.character.corporation_id).exists():
|
||||||
fat_stats[fat.character.corporation_id] = CorpStat(fat.character.corporation_id, start_of_month,
|
fat_stats[fat.character.corporation_id] = CorpStat(fat.character.corporation_id, start_of_month,
|
||||||
start_of_next_month)
|
start_of_next_month)
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user