Block Collect IP option if disabled globally
This commit is contained in:
		
							parent
							
								
									d67e14b08f
								
							
						
					
					
						commit
						d071a91917
					
				| @ -1,5 +1,6 @@ | ||||
| from allauth.account.admin import EmailAddress | ||||
| from django import forms | ||||
| from django.conf import settings | ||||
| from django.utils.translation import gettext_lazy as _ | ||||
| 
 | ||||
| from core.models import Service, User | ||||
| @ -33,7 +34,6 @@ class ServiceForm(forms.ModelForm): | ||||
|         labels = { | ||||
|             "origins": "Allowed origins", | ||||
|             "respect_dnt": "Respect DNT", | ||||
|             "collect_ips": "Collect IP addresses", | ||||
|             "ignored_ips": "Ignored IP addresses", | ||||
|             "ignore_robots": "Ignore robots", | ||||
|             "hide_referrer_regex": "Hide specific referrers", | ||||
| @ -46,13 +46,25 @@ class ServiceForm(forms.ModelForm): | ||||
|                 "At what origins does the service operate? Use commas to separate multiple values. This sets CORS headers, so use '*' if you're not sure (or don't care)." | ||||
|             ), | ||||
|             "respect_dnt": "Should visitors who have enabled <a href='https://en.wikipedia.org/wiki/Do_Not_Track'>Do Not Track</a> be excluded from all data?", | ||||
|             "collect_ips": "Should individual IP addresses be collected? IP metadata (location, host, etc) will still be collected.", | ||||
|             "ignored_ips": "A comma-separated list of IP addresses or IP ranges (IPv4 and IPv6) to exclude from tracking (e.g., '192.168.0.2, 127.0.0.1/32').", | ||||
|             "ignore_robots": "Should sessions generated by bots be excluded from tracking?", | ||||
|             "hide_referrer_regex": "Any referrers that match this <a href='https://regexr.com/'>RegEx</a> will not be listed in the referrer summary. Sessions will still be tracked normally. No effect if left blank.", | ||||
|             "script_inject": "Optional additional JavaScript to inject at the end of the Shynet script. This code will be injected on every page where this service is installed.", | ||||
|         } | ||||
| 
 | ||||
|     collect_ips = forms.BooleanField( | ||||
|         help_text="IP address collection is disabled globally by your administrator." if settings.BLOCK_ALL_IPS else "Should individual IP addresses be collected? IP metadata (location, host, etc) will still be collected.", | ||||
|         widget=forms.RadioSelect(choices=[(True, "Yes"), (False, "No")]), | ||||
|         initial=False if settings.BLOCK_ALL_IPS else True, | ||||
|         required=False, | ||||
|         disabled=settings.BLOCK_ALL_IPS | ||||
|     ) | ||||
| 
 | ||||
|     def clean_collect_ips(self): | ||||
|         collect_ips = self.cleaned_data["collect_ips"] | ||||
|         # Forces collect IPs to be false if it is disabled globally | ||||
|         return False if settings.BLOCK_ALL_IPS else collect_ips | ||||
| 
 | ||||
|     collaborators = forms.CharField( | ||||
|         help_text="Which users on this Shynet instance should have read-only access to this service? (Comma separated list of emails.)", | ||||
|         required=False, | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user