* stub in poetry for pipenv
* re-add tester image
* add pre-commit / formatting
* fix ghactions
* revert test data whitespace, exclude tests/data
* revert ws
* decruft, rm tox/pipenv
* install dev packages for base image
* add lgtm config to force to py3
* fixes#965: intermittent bug during consolidation of notifications
* fixes#863: better visibility for input validation errors
* fixes#375: re-evaluate affiliation requests on email change
* fixes#741: remove data quality validation for superusers
* fixes#587: customizable pagination in django admin
* fixes#923: Prevent deletion of a last technical contact if there is an existing netixlan object
* better search #23 (first pass)
* black format
* haystack test config to run_tests.py
remove old django_init.py test settings
* black format
* haystack test config fixes
* #23 better search (pt.2)
* rate limit distance queries (#23)
rate limiting based on query filters
* settings controlled blocking of distance filter for unauthenticated / unverified users (#23)
* fix distance filter throttling with api key auth (#23)
* fix anon user access check on distance queries
* search index and performance tweaks
* fix org_id not set in search results
* org id to int
Co-authored-by: Stefan Pratter <stefan@20c.com>
* install django-grainy
* nsp to grainy first iteration
* nsp to grainy second iteration
* grainy and django-grainy pinned to latest releases
* Fix typo
* Update djangorestframework, peeringdb, django-ratelimit
* Rewrite login view ratelimit decorator
* Relock pipfile
* add list() to make copy of dictionaries before iterating
* relock pipfile with python3.9
change docker to use python3.9
* add ordering to admin search queryset for deskproticket and email
* add org api key and begin to write tests
* additional key tests
* add drf-api-keys to pipfile
* Wire orgapikey to modelviewsetpermissions
* Update api key helper functions
* add put test
* Add Org API key tab to frontend
* Add user api key model
* Update user key handling and tests
* Update APIPermissionsApplicator to make it work w requests
* Add org api key perm panel
* add org key permissions
* Add user api key views
* Add templates for handling user api key (adding, not revoking)
* relock pipfile
* assorted fixes and tweaks
* Add general user group permissions and org user group perms
* refactor org api key perms
* Add tests for api keys
* Add docstrings to permissions helpers
* Add api key examples
* squash migrations
* remove custom api key header config
* Change api key test setup
* Update permissions for grainy change
* Bump up pipfile and pipfile.lock
* Add API Key to Verification Queue Item
* Delete travis
* Add workaround to Dockerfile
* update pipfile and sort out migrations
* Add comment to Dockerfile
* Re-add API Key migrations
* Add locale to .gitignore
* remove suggest functionality from ix
* Update test to recognize that IX api no longer has suggest function
* Add test to outlaw POSTing an IX w its org equal to the suggest entity org
* Add meta information geowarning
* Add alert to demonstrate UI
* Add error to fac update
* Add template warning for geovalidation
* Add geowarning meta js
* cover absent meta_response test case
* Update styles for geowarning
* refactor geotag warning implementation
* null lat and long on unsuccessful geo locate
* modify geovalidation frontend update
* Add deskproticket model email field
* Add missing span
* add email to org keys
* Add email to org key tests
* update serializer with rdap validation wrapper
* update admin for api keys
* Enable writing an email as part of org key creation
* Add email validation to org api key form
* fix css style on perm row
* Add suggested info to api response
* display suggested address on frontend
* add needs geocode to serializer
* save lat long on forward geonormalization
* add address suggestion submit button
* Add suggested address popin to ADD facility form
* Fix css
* add lat and long rounding to geocodenabled model clean method
* add migration and regression test for lat long decimal db constraint
* Add another regression test for model decimal places
* Get deskpro functions passing isort and flake
* Update ticket_queue_deletion_prevented
* update ticket_queue_deletion_prevented for use with org api key
* add template for org key dpt from asnauto skipvq
* Update deskproticket for rdap error
* add facility aka
* add aka to serializer and views
* black and isort test api keys
* fix typo in org key deskpro template
* skip or rewrite unapplicable org key tests, and add as_set tests
* adjust api key test comments
* Add vqi_notify to signals
* Add reversion comments for api keys and helper function
* update how org keys are added to verification queue items
* rename verification queue item fk from api_key to org_key
* fix group id error
* update key tests with correct http header info
* check both user and key, not just user
* templates fiex
* adapt deskpro integration to work with email only
* make org api keys editable for desc and email
* pipfile relock
* edit test setupdata settings for groups
* Change comment to signify we don't need to remove code
* address untranslated accept button
* Add docstrings to the serializer functions
* Add loading shim
* Add migration for all longname and aka
* Add aka and long name to views and serializers
* delete migration w decimals
* standardize serializer lat and long fields
* Add clean rounding for lat and long
* fix serializer error
* api key admin improvements
* fix linebreak in user api key form
* remove debug prints
* Add rounding util
* Add rounding to lat and long fields
* remove 'clean' from geocode method (logic now in admin form)
* remove erroneous tests
* revert serializer changes
* Fix migrations
* Add long name and aka to admin models
* Update API key docs
* Add documentation for api keys
* fix typo
* fix org api key revoke broken by editable api keys
* doc tweaks
* doc tweaks
* doc tweaks
* black format
* fix migration hierarchy
* docs
* docs
* api key permissions screenshot
* formatting
* formatting
* padding fixed
* remove one image
* fix get_user_from_request type checking
take out POST only valdiator for entity suggest
* didnt mean to commit the django-peeringdb mount
* fix suggest on PUT net
fix tests
* black formatting
* update org key permission template
* install rust for cryptography
* pipfile relock (django-peeringdb to 2.6)
Co-authored-by: Stefan Pratter <stefan@20c.com>
Co-authored-by: Elliot Frank <elliot@20c.com>
* install django-grainy
* nsp to grainy first iteration
* Fix validation error message overflow
* Add migration, update views.py and template to add help_text to UI
* nsp to grainy second iteration
* grainy and django-grainy pinned to latest releases
* deskpro ticket cc (#875)
* black formatting
* move ac link to bottom for ticket body
* Fix typo
* Update djangorestframework, peeringdb, django-ratelimit
* Rewrite login view ratelimit decorator
* Relock pipfile
* add list() to make copy of dictionaries before iterating
* respect ix-f url visibilty in ix-f conflict emails
* Add type coercion to settings taken from environment variables
* Add bool handling
* relock pipfile with python3.9
change docker to use python3.9
* Check bool via isinstance
* add ordering to admin search queryset for deskproticket and email
* update settings with envvar_type option
* Add tooltips to add ix and add exchange views (in org)
* Add tooltip to suggest fac view
* get phone information in view
* add missing migration
* add migration and make org a geo model
* Wire normalization to put/create requests for Facility
* Update admin with new address fields
* Refactor serializer using mixin
* Add floor and suite to address API
* Write command to geonormalize existing entries
* Remove unnecessary method from model
* Add floor and suite to views
* Add ignore geo status
* Force refresh for fac and org updates
* adjust frontend typo
* add checking if update needs geosync
* redo error handling for geosync
* remove save keyword from geonormalize command script
* change raw_id_fields
* alternate autocomplete lookup field depending on where inline is called
* remove unnecessary error handling
* Add csv option
* Fix bug
with None vs empty string
* add regex parsing for suite and floor conversion
* Add migration that removes geo error as a field
* add geostatus update to command
* Ignore suite floor and address2 changes for api normalization
* update geomodel by removing geo_error
* Black models.py
* Black serializers.py
* remove geocode error from admin
* Add function for reversing pretty speed
* add conversion to export method
* fix typo
* fix speed value feedback after submit
* remove conditional
* Add error handling to create endpoint
* Refine floor and suite parsing regex
* Add geocoding tests
* Add json for tests
* IX-F Importer: Bogus output of "Preview" tool #896
* remove cruft
* black formatting
* IX-F Importer: history of changes per ixlan & netixlan #893
* 6 add geocode to org view
* 4 update geocode without refresh
* Update error display
* Fix bug with formatting translated string
* Add DateTimeFields to model
* Add update signals
* add last updated fields to views and serializers
* Add last updated model migration
* Add the data migration for last updated fields
* add test that tests a normal org user with create org permissions
* grainy to 1.7
django grainy to 1.9.1
* Fix formatting issues
* Adjust var names
* Refactor signals
* Temporary: save override from network model
* Empty vlan lists no longer cause error
* typo in ixf.py
* typo in admin
* Typos in model verbose names
* Add serializer IXLAN validation for ixf_ixp_import_enabled
* Add model validation to IXLan
* relock pipfile
* relock pipfile
* begin signal test file
* Remove full clean from save in ixlan
* use post_reversion_commit signal instead
* remove redundant save override
* remove cruft / debug code
* Add signal tests
* exclude organizations with city missing from commandline geosync
* Skip geosync if the only address information we have is a country
* initial commit for vlan matcher in importer
* Add more tests and remove unused imports
* update tests
* Actually add vlan matching to importer
* Add type checking for speed list and state
* Change how we register connection.state
* add bootstrap options
* add rdap cache command
* remove outdated perm docs
* rdap from master and relock
* propagate rdap settings to peeringdb.settings
* add loaddata for initial fixtures
* user friendly error message on RdapNotFound errors (#497)
* update rdap errors
* django-peeringdb to 2.5.0 and relock
* rdap to 1.2.0 and relock
* fix migration hierarchy
* add ignore_recurse_errors option
* add missing fields to mock
remove cruft missed during merge
* rdap to 1.2.1
* dont geo validate during api tests
* fix tests
* Add test file
* fix merge
* RDAP_SELF_BOOTSTRAP to False while running tests
* black formatted
* run black
* add github actions
* add runs on
Co-authored-by: Stefan Pratter <stefan@20c.com>
Co-authored-by: Elliot Frank <elliot@20c.com>
* Change label from primary ASN to ASN
* Raise validation error when trying to update ASN
* first steps for dotf importer procotol (#697)
* migrations (#697)
* Add translation to error meessage
* Make ASN readonly in table
* Add test now that ASN should not be able to update
* Set fac.rencode to '' for all entries and make it readonly in serializer
* Add unique constraints to network ixlan ip addresses
* Add migration to null out duplicate ipaddresses for deleted netixlans
* Add unique constraints to network ixlan ip addresses
* Add migration to null out duplicate ipaddresses for deleted netixlans
* remove old migrations (#697)
* fix netixlan ipaddr dedupe migration (#268)
add netixlan ipaddr unique constraint migration (#268)
* ixf_member_data migrations (#697)
* fix table name (#697)
* importer protocol (#697)
* fix netixlan ipaddr dedupe migration (#268)
add netixlan ipaddr unique constraint migration (#268)
* ixf proposed changes notifications (#697)
* Delete repeated query
* Add a test to show rencode is readonly
* Blank out rencode when mocking data
* Remove validator now that constraint exists
* Add back unique field validator w Check Deleted true
* conflict resolving (#697)
* UniqueFieldValidator raise error with code "unique" (#268)
* conflict resolution (#697)
* Add fixme comment to tests
* conflict resolution (#697)
* Remove now invalid undelete tests
* UniqueFieldValidator raise error with code "unique" (#268)
* delete admin tools for duplicate ip addresses
* Make migration to delete duplicateipnetworkixlan
* Add ixlan-ixpfx status matching validation, add corresponding test
* delete redundant checking in test
* resolve conflict ui (#697)
* fix migrations hierarchy
* squash migrations for ixf member data
* clean up preview and post-mortem tools
* remove non-sensical permission check when undeleting soft-deleted objects through unique integrity error handling
* only include the ix-f data url in notifications to admincom (#697)
* resolve on --skip-import (#697)
* ac conflict resolution (#697)
* Define more accurately the incompatible statuses for ixlan and ixpfx
* Add another status test
* Preventing disrupting changes (#697)
* fix tests (#697)
* Stop allow_ixp_update from being write only and add a global stat for automated networks
* Add tests for global stats that appear in footer
* Change how timezone is called with datetime, to get test_stats.py/test_generate_for_current_date to pass
* test for protected entities (#697)
* admincom conflict resolution refine readonly fields (#697)
network notifications only if the problem is actually actionable by the network (#697)
* ixp / ac notifcation when ix-f source cannot be parsed (#697)
fix issue with ixlan prefix protection (#697)
* migrations (#697)
* code documentation (#697)
* ux tweaks (#697)
* UX tweaks (#697)
* Fix typo
* fix netixlan returned in IXFMemberData.apply when adding a new one (#697)
* fix import log incosistencies (#697)
* Add IXFMemberData to test
* Update test data
* Add protocol tests
* Add tests for views
* always persist changes to remote data on set_conflict (#697)
* More tests
* always persist changes to remote data on set_conflict (#697)
* suggest-add test
* net_present_at_ix should check status (#697)
* Add more protocol tests
* Edit language of some tests
* django-peeringdb to 2.1.1
relock pipfile, pin django-ratelimit to <3 as it breaks stuff
* Add net_count_ixf field to ix object (#683)
* Add the IX-F Member Export URL to the ixlan API endpoint (#249)
* Lock some objects from being deleted by the owner (#696)
* regenerate api docs (#249)
* always persist changes to remote data on set_add and set_update (#697)
* IXFMemberData: always persist remote data changes during set_add and set_update, also allow for saving without touching the updated field
* always persist changes to remote data on set_add and set_update (#697)
* Fix suggest-add tests
* IXFMemberData: always persist remote data changes during set_add and set_update, also allow for saving without touching the updated field
* IXFMemberData: always persist remote data changes during set_add and set_update, also allow for saving without touching the updated field
* fix issue with deletion when ixfmemberdata for entry existed previously (#697)
* fix test_suggest_delete_local_ixf_no_flag (#697 tests)
* fix issue with deletion when ixfmemberdata for entry existed previously (#697)
* invalid ips get logged and notified to the ix via notify_error (#697)
* Fix more tests
* issue with previous_data when running without save (#697)
properly track speed errors (#697)
* reset errors on ixfmemberdata that go into pending_save (#697)
* add remote_data to admin view (#697)
* fix error reset inconsistency (#697)
* Refine invalid data tests
* remove debug output
* for notifications to ac include contact points for net and ix in the message (#697)
* settings to toggle ix-f tickets / emails (#697)
* allow turning off ix-f notifications for net and ix separately (#697)
* add jsonschema test
* Add idempotent tests to updater
* remove old ixf member tests
* Invalid data tests when ixp_updates are enabled
* fix speed error validation (#697)
* fix issue with rollback (#697)
* fix migration hierarchy
* fix ixfmemberdata _email
* django-peeringdb to 2.2 and relock
* add ixf rollback tests
* ixf email notifications off by default
* black formatted
* pyupgrade
Co-authored-by: egfrank <egfrank@20c.com>
Co-authored-by: Stefan Pratter <stefan@20c.com>
* Add pointer from API docs to tutorial #650
* Sorting by clicking table headers should use local-compare #356
* Mark IXP peering LAN as bogon #352
* Add help text to "Add (Facility, Network, Exchange)" tab #669
* Add Looking Glass field to the IX object #672
* Add read-only Superuser #679
* Make spelling of traffic levels consistent #519 (#723)
* Offer 2FA (#290)
* Show "Last Updated" fields on fac, ix, org records (#526)
* Enable sort and reverse sort of IP column in IX display (#72)
* IRR validation not handling unexpected characters gracefully (#712)
* Support alternative direction of writing, e.g. Arabic (#618)
* Undeleting an ixlan with an emtpy IPv4 XOR IPv6 field throws a silly error (#644)
* Changing org while adding net results in 500 #654
* missing delete button for organisations (#121)
* When changing owner of an ix admin GUI borks because of "Ixlan for exchange already exists" #666
* Selection should only present undeleted objects (#664)
* change default encoding of API calls to 'utf-8' #663
* Posting https://www.peeringdb.com onto social media doesn't select a good preview image #537
* Revert "Add Looking Glass field to the IX object #672"
This reverts commit 4daf2520043c241fabe9a521757efa86a274e28a.
Conflicts:
peeringdb_server/migrations/0037_ix_looking_glass.py
peeringdb_server/views.py
* 500 Internal Error when creating IX where prefix already exists elsewhere #718
* Fix graceful restore of soft-deleted objects with translation active (#580)
* Don't return any POC data with status=deleted #569
Hard delete soft-deleted pocs after grace period #566
* django-peeringdb from github@2.0.0.2-beta
Co-authored-by: Stefan Pratter <stefan@20c.com>
* use new peeringdb client (1.0.0) for pdb_load_data sync (#599)
* drop django-mobi for lack of py3/dj2 support (#492)
remove django-forms-bootstrap for lack of py3/dj2 support (#492)
* black formatted
* django2.2 and py3 upgrade (#492)
* drop ixlans (#21) ui and api changes
* drop local_asn (#168)
* org search (#193)
* phone number validation (#50)
* implement help text tooltips (#228)
* Mark own ASN as transit-free (#394)
* py3 fix for `pdb_migrate_ixlans` command when writing migration report
* pdb_migrate_ixlans: properly handle py3 Runtime error if ixlan dict changes during iteration
* set rest DEFAULT_SCHEMA_CLASS to coreapi to fix swagger apidocs
fix migration 0027 missing from facsimile manifest
* fix swagger doc strings
* fix tests that were broken from api doc fixes
* fix UniqueFieldValidator for netixlan ipaddress validation that broke during django/drf upgrade
* fix org merge tool layout issues
* travis config
* update pipfile and lock
* black formatting
* update travis dist
* beta mode banner (#411)
* add beta banner template (#411)
* automatically scheduled sync may not always be on, add a flag that lets us reflect that state in the beta banner message
clean up beta banner implementation (#411)
* add tests for beta banner (#411)