2020-10-27 04:37:00 -04:00
|
|
|
## Version 2020/10/27 - Changelog: https://github.com/linuxserver/docker-swag/commits/master/root/defaults/geoip2.conf
|
2020-09-20 17:30:06 -04:00
|
|
|
# To enable, uncommment the Geoip2 config line in nginx.conf
|
|
|
|
# Add the -e MAXMINDDB_LICENSE_KEY=<licensekey> to automatically download the Geolite2 database.
|
2020-09-20 18:39:13 -04:00
|
|
|
# A Maxmind license key can be acquired here: https://www.maxmind.com/en/geolite2/signup
|
2020-09-20 17:30:06 -04:00
|
|
|
|
2020-09-22 21:08:00 -04:00
|
|
|
geoip2 /config/geoip2db/GeoLite2-City.mmdb {
|
2020-09-22 20:53:40 -04:00
|
|
|
auto_reload 1w;
|
|
|
|
$geoip2_data_city_name city names en;
|
|
|
|
$geoip2_data_postal_code postal code;
|
|
|
|
$geoip2_data_latitude location latitude;
|
|
|
|
$geoip2_data_longitude location longitude;
|
|
|
|
$geoip2_data_state_name subdivisions 0 names en;
|
|
|
|
$geoip2_data_state_code subdivisions 0 iso_code;
|
|
|
|
$geoip2_data_continent_code continent code;
|
|
|
|
$geoip2_data_country_iso_code country iso_code;
|
2020-09-20 17:30:06 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
# GEOIP2 COUNTRY CONFIG
|
2020-09-22 20:53:40 -04:00
|
|
|
map $geoip2_data_country_iso_code $allowed_country {
|
|
|
|
# default must be yes or no
|
2020-10-26 17:51:04 -04:00
|
|
|
# If default is set to "no" you will need to add the local ip ranges that you want to allow access in the $allow_list variable below.
|
2020-09-22 20:53:40 -04:00
|
|
|
default yes;
|
|
|
|
|
|
|
|
# Below you will setup conditions with yes or no
|
|
|
|
# ex: <condition> <yes/no>;
|
|
|
|
|
|
|
|
# allow United Kingdom.
|
|
|
|
#GB yes;
|
2020-09-20 17:30:06 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
# GEOIP2 CITY CONFIG
|
2020-09-22 20:53:40 -04:00
|
|
|
map $geoip2_data_city_name $allowed_city {
|
|
|
|
# default must be yes or no
|
2020-10-26 17:51:04 -04:00
|
|
|
# If default is set to "no" you will need to add the local ip ranges that you want to allow access in the $allow_list variable below.
|
2020-09-22 20:53:40 -04:00
|
|
|
default yes;
|
|
|
|
|
|
|
|
# Below you will setup conditions with yes or no
|
|
|
|
# ex: <condition> <yes/no>;
|
2020-09-20 17:30:06 -04:00
|
|
|
|
2020-09-22 20:53:40 -04:00
|
|
|
# allow Inverness.
|
|
|
|
#Inverness yes;
|
2020-10-26 17:51:04 -04:00
|
|
|
}
|
2020-09-22 20:53:40 -04:00
|
|
|
|
2020-10-26 17:51:04 -04:00
|
|
|
# ALLOW LOCAL ACCESS
|
|
|
|
geo $allow_list {
|
|
|
|
default yes; # Set this to no if $allowed_country or $allowed_city default is no.
|
|
|
|
# IP/CIDR yes; # e.g. 192.168.1.0/24 yes;
|
2020-09-22 20:53:40 -04:00
|
|
|
}
|
2020-09-20 17:30:06 -04:00
|
|
|
|
|
|
|
# Server config example:
|
2020-10-26 17:51:04 -04:00
|
|
|
# Add the following if statements inside any server context where you want to geo block countries.
|
2020-09-20 17:30:06 -04:00
|
|
|
|
2020-09-22 11:16:01 -04:00
|
|
|
########################################
|
2021-04-27 15:32:41 -04:00
|
|
|
# if ($allow_list = yes) {
|
|
|
|
# set $allowed_country yes;
|
|
|
|
# }
|
|
|
|
# if ($allowed_country = no) {
|
|
|
|
# return 444;
|
|
|
|
# }
|
2020-09-22 11:16:01 -04:00
|
|
|
#########################################
|
2020-09-20 17:30:06 -04:00
|
|
|
|
2020-10-26 17:51:04 -04:00
|
|
|
# Add the following if statements inside any server context where you want to geo block cities.
|
2020-09-22 11:16:01 -04:00
|
|
|
########################################
|
2021-04-27 15:32:41 -04:00
|
|
|
# if ($allow_list = yes) {
|
|
|
|
# set $allowed_country yes;
|
|
|
|
# }
|
|
|
|
# if ($allowed_city = no) {
|
|
|
|
# return 444;
|
|
|
|
# }
|
2020-09-22 11:16:01 -04:00
|
|
|
#########################################
|
|
|
|
|
|
|
|
# Example using a config from proxy-confs
|
2020-09-20 17:30:06 -04:00
|
|
|
|
|
|
|
#server {
|
2020-09-22 11:16:01 -04:00
|
|
|
# listen 443 ssl;
|
|
|
|
# listen [::]:443 ssl;
|
|
|
|
#
|
|
|
|
# server_name unifi.*;
|
2020-09-20 17:30:06 -04:00
|
|
|
#
|
2020-09-22 11:16:01 -04:00
|
|
|
# include /config/nginx/ssl.conf;
|
2020-09-20 17:30:06 -04:00
|
|
|
#
|
2020-09-22 11:16:01 -04:00
|
|
|
# client_max_body_size 0;
|
|
|
|
#
|
|
|
|
# # enable for ldap auth, fill in ldap details in ldap.conf
|
|
|
|
# #include /config/nginx/ldap.conf;
|
|
|
|
#
|
|
|
|
# # enable for Authelia
|
|
|
|
# #include /config/nginx/authelia-server.conf;
|
2020-09-20 17:30:06 -04:00
|
|
|
|
|
|
|
|
2020-10-26 17:51:04 -04:00
|
|
|
# # Allow lan access if default is set to no
|
|
|
|
# if ($allow_list = yes) {
|
2021-04-27 15:32:41 -04:00
|
|
|
# set $allowed_country yes;
|
2020-10-26 17:51:04 -04:00
|
|
|
# }
|
2021-04-27 15:32:41 -04:00
|
|
|
# # Country geo block
|
|
|
|
# if ($allowed_country = no) {
|
2020-09-22 11:16:01 -04:00
|
|
|
# return 444;
|
2021-04-27 15:32:41 -04:00
|
|
|
# }
|
2020-09-20 17:30:06 -04:00
|
|
|
|
|
|
|
|
|
|
|
#
|
2020-09-22 11:16:01 -04:00
|
|
|
# location / {
|
|
|
|
# # enable the next two lines for http auth
|
|
|
|
# #auth_basic "Restricted";
|
|
|
|
# #auth_basic_user_file /config/nginx/.htpasswd;
|
2020-09-20 17:30:06 -04:00
|
|
|
#
|
2020-09-22 11:16:01 -04:00
|
|
|
# # enable the next two lines for ldap auth
|
|
|
|
# #auth_request /auth;
|
|
|
|
# #error_page 401 =200 /ldaplogin;
|
2020-09-20 17:30:06 -04:00
|
|
|
#
|
2020-09-22 11:16:01 -04:00
|
|
|
# # enable for Authelia
|
|
|
|
# #include /config/nginx/authelia-location.conf;
|
2020-09-20 17:30:06 -04:00
|
|
|
#
|
2020-09-22 11:16:01 -04:00
|
|
|
# include /config/nginx/proxy.conf;
|
|
|
|
# resolver 127.0.0.11 valid=30s;
|
|
|
|
# set $upstream_app unifi-controller;
|
|
|
|
# set $upstream_port 8443;
|
|
|
|
# set $upstream_proto https;
|
|
|
|
# proxy_pass $upstream_proto://$upstream_app:$upstream_port;
|
2020-09-20 17:30:06 -04:00
|
|
|
#
|
2020-09-22 11:16:01 -04:00
|
|
|
# proxy_buffering off;
|
|
|
|
# }
|
2020-09-20 17:30:06 -04:00
|
|
|
#}
|