1
0
mirror of https://github.com/peeringdb/peeringdb.git synced 2024-05-11 05:55:09 +00:00
Files
peeringdb-peeringdb/peeringdb_server/data_views.py

199 lines
5.0 KiB
Python
Raw Normal View History

2018-11-08 19:45:21 +00:00
"""
This holds JSON views for various data sets,
Mostly these are needed for filling form-selects for editable
mode
"""
import datetime
2018-11-08 19:45:21 +00:00
from django.contrib.auth.decorators import login_required
from django.http import JsonResponse
import django_countries
from . import models
2018-11-08 19:45:21 +00:00
import django_peeringdb.const as const
from django.utils import translation
from django.utils.translation import ugettext_lazy as _
2019-12-05 16:57:52 +00:00
from peeringdb_server.models import Organization, Network, Sponsorship
2019-12-05 16:57:52 +00:00
# def _(x):
2018-11-08 19:45:21 +00:00
# return x
# until django-peeringdb is updated we want to remove
# the 100+ Gbps choice since it's redundant
const.TRAFFIC = [(k, i) for k, i in const.TRAFFIC if k != "100+ Gbps"]
# create enums without duplicate "Not Disclosed" choices
const.RATIOS_TRUNC = const.RATIOS[1:]
const.SCOPES_TRUNC = const.SCOPES[1:]
const.NET_TYPES_TRUNC = const.NET_TYPES[1:]
# create enums without duplicate "Not Disclosed" choices
# but with the one Not Disclosed choice combining both
# values in a comma separated fashion - user for
# advanced search
const.RATIOS_ADVS = list(const.RATIOS[1:])
2019-12-05 16:57:52 +00:00
const.RATIOS_ADVS[0] = (",%s" % const.RATIOS_ADVS[0][0], const.RATIOS_ADVS[0][1])
2018-11-08 19:45:21 +00:00
const.SCOPES_ADVS = list(const.SCOPES[1:])
2019-12-05 16:57:52 +00:00
const.SCOPES_ADVS[0] = (",%s" % const.SCOPES_ADVS[0][0], const.SCOPES_ADVS[0][1])
2018-11-08 19:45:21 +00:00
const.NET_TYPES_ADVS = list(const.NET_TYPES[1:])
2019-12-05 16:57:52 +00:00
const.NET_TYPES_ADVS[0] = (
",%s" % const.NET_TYPES_ADVS[0][0],
const.NET_TYPES_ADVS[0][1],
)
2018-11-08 19:45:21 +00:00
const.ORG_GROUPS = (("member", "member"), ("admin", "admin"))
const.POC_ROLES = sorted(const.POC_ROLES, key=lambda x: x[1])
BOOL_CHOICE = ((False, _("No")), (True, _("Yes")))
const.BOOL_CHOICE_STR = (("False", _("No")), ("True", _("Yes")))
def countries_w_blank(request):
"""
Returns all valid countries and their country codes with a blank field
"""
2019-12-05 16:57:52 +00:00
return JsonResponse(
{
"countries_b": [{"id": "", "name": ""}]
+ [
{"id": str(code), "name": str(name)}
2019-12-05 16:57:52 +00:00
for code, name in list(django_countries.countries)
]
}
)
2018-11-08 19:45:21 +00:00
def countries(request):
"""
Returns all valid countries and their country codes
"""
2019-12-05 16:57:52 +00:00
return JsonResponse(
{
"countries": [
{"id": str(code), "name": str(name)}
2019-12-05 16:57:52 +00:00
for code, name in list(django_countries.countries)
]
}
)
2018-11-08 19:45:21 +00:00
def sponsorships(request):
"""
Returns all sponsorships
"""
sponsors = {}
for org, sponsorship in Sponsorship.active_by_org():
2019-12-05 16:57:52 +00:00
sponsors[org.id] = {"id": org.id, "name": sponsorship.label.lower()}
return JsonResponse({"sponsors": sponsors,})
2018-11-08 19:45:21 +00:00
@login_required
def facilities(request):
"""
Returns all valid facilities with id and name
"""
2019-12-05 16:57:52 +00:00
return JsonResponse(
{
"facilities": [
{"id": fac.id, "name": str(fac.name)}
2019-12-05 16:57:52 +00:00
for fac in models.Facility.handleref.all().undeleted().order_by("name")
]
}
)
2018-11-08 19:45:21 +00:00
def enum(request, name):
if name.upper() not in [
2019-12-05 16:57:52 +00:00
"RATIOS",
"RATIOS_TRUNC",
"RATIOS_ADVS",
"TRAFFIC",
"SCOPES",
"SCOPES_TRUNC",
"SCOPES_ADVS",
"NET_TYPES",
"NET_TYPES_TRUNC",
"NET_TYPES_ADVS",
"POLICY_GENERAL",
"POLICY_LOCATIONS",
"POLICY_CONTRACTS",
"REGIONS",
"POC_ROLES",
"MEDIA",
"PROTOCOLS",
"ORG_GROUPS",
"BOOL_CHOICE_STR",
"VISIBILITY",
2018-11-08 19:45:21 +00:00
]:
raise Exception("Unknown enum")
2019-12-05 16:57:52 +00:00
return JsonResponse(
{
"enum/%s"
% name: [
{
"id": id,
# as of django-peeringdb 1.0.0 already comes in
# translated
"name": n,
2019-12-05 16:57:52 +00:00
}
for id, n in getattr(const, name.upper())
]
}
)
2018-11-08 19:45:21 +00:00
def asns(request):
"""
Returns a JSON response with a list of asns that the user's
organizations own, to use for selecting asn in netixlan
creation
"""
rv = []
try:
net = Network.objects.get(id=request.GET.get("id"))
org = net.org
except Network.DoesNotExist:
return JsonResponse({"asns": []})
for net in org.net_set_active.order_by("asn"):
rv.append({"id": net.asn, "name": net.asn})
return JsonResponse({"asns": rv})
def organizations(request):
"""
Returns a JSON response with a list of organization names and ids
This is currently only used by the org-merge-tool which is only
available to site administrators.
"""
if not request.user.is_superuser:
return JsonResponse({}, status=403)
2019-12-05 16:57:52 +00:00
return JsonResponse(
{
"organizations": [
{"id": o.id, "name": o.name}
for o in Organization.objects.filter(status="ok").order_by("name")
]
}
)
2018-11-08 19:45:21 +00:00
def languages(request):
from django.conf import settings
2019-12-05 16:57:52 +00:00
2018-11-08 19:45:21 +00:00
cur_language = translation.get_language()
2019-12-05 16:57:52 +00:00
return JsonResponse(
{"locales": [{"id": id, "name": _(name)} for (id, name) in settings.LANGUAGES]}
)