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
|
|
|
|
"""
|
2019-04-01 15:01:57 -05:00
|
|
|
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
|
2020-01-08 13:29:58 -06:00
|
|
|
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-04-01 15:01:57 -05:00
|
|
|
|
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": ""}]
|
|
|
|
+ [
|
2020-01-08 13:29:58 -06:00
|
|
|
{"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": [
|
2020-01-08 13:29:58 -06:00
|
|
|
{"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
|
|
|
|
2019-04-01 15:01:57 -05:00
|
|
|
def sponsorships(request):
|
|
|
|
"""
|
|
|
|
Returns all sponsorships
|
|
|
|
"""
|
|
|
|
|
2019-11-16 21:32:27 -06:00
|
|
|
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,})
|
2019-04-01 15:01:57 -05:00
|
|
|
|
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": [
|
2020-01-08 13:29:58 -06:00
|
|
|
{"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
|
2020-01-08 13:29:58 -06:00
|
|
|
"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]}
|
|
|
|
)
|