| Left: | ||
| Right: |
| LEFT | RIGHT |
|---|---|
| 1 # Puppet: <%= @title %> | 1 # Puppet: <%= @title %> |
|
mathias
2018/03/27 14:46:52
Please don't simply copy from our legacy. There's
| |
| 2 | 2 |
| 3 root /var/www/<%= @domain %>; | 3 root /var/www/<%= @domain %>; |
| 4 index index; | 4 index index; |
| 5 default_type text/html; | 5 default_type text/html; |
| 6 charset utf-8; | 6 charset utf-8; |
| 7 | 7 |
| 8 set $index_page "index"; | 8 set $index_page "index"; |
| 9 | 9 |
| 10 <% if @custom_config %> | 10 <% if @custom_config %> |
| 11 <%= @custom_config %> | 11 <%= @custom_config %> |
|
mathias
2018/03/27 14:46:52
We know the two spaces in front of the custom conf
f.lopez
2018/03/27 19:29:50
Acknowledged.
| |
| 12 <% end %> | 12 <% end %> |
| 13 | 13 |
| 14 location / | 14 location / |
| 15 { | 15 { |
| 16 expires 1d; | 16 expires 1d; |
| 17 | 17 |
| 18 # Redirect server/language root | 18 # Redirect server/language root |
| 19 | 19 |
| 20 rewrite ^/$ /$index_page last; | 20 rewrite ^/$ /$index_page last; |
| 21 rewrite ^/(\w\w(_\w\w)?)$ /$1/ permanent; | 21 rewrite ^/([a-z][a-z](_[A-Z][A-Z])?)$ /$1/ permanent; |
| 22 rewrite ^/(\w\w(_\w\w)?)/$ /$1/$index_page last; | 22 rewrite ^/([a-z][a-z](_[A-Z][A-Z])?)/$ /$1/$index_page last; |
| 23 | 23 |
| 24 # Match Accept-Language header against available languages | 24 # Match Accept-Language header against available languages |
| 25 | 25 |
| 26 set $preferredLang en; | 26 set $language en; |
| 27 set $preferredRegion ""; | 27 set $region ""; |
|
mathias
2018/03/27 14:46:52
Please avoid camel case where possible, and always
f.lopez
2018/03/27 19:29:51
Acknowledged.
| |
| 28 if ($http_accept_language ~ ^(\w\w)\b) | 28 |
|
mathias
2018/03/27 14:46:52
An empty line in front of this block would be appr
f.lopez
2018/03/27 19:29:51
Acknowledged.
| |
| 29 if ($http_accept_language ~ ^([a-z][a-z])\b) | |
| 29 { | 30 { |
| 30 set $preferredLang $1; | 31 set $language $1; |
| 31 } | 32 } |
| 32 if ($http_accept_language ~ ^\w\w-(\w\w)\b) | 33 if ($http_accept_language ~ ^([a-z][a-z])-([A-Z][A-Z])\b) |
| 33 { | 34 { |
| 34 set $preferredRegion $1; | 35 set $region $1; |
| 35 } | 36 } |
| 36 | 37 |
| 37 if ($arg_fb_locale ~ ^(\w\w)_(\w\w)$) | 38 if ($arg_fb_locale ~ ^([a-z][a-z])_([A-Z][A-Z])$) |
| 38 { | 39 { |
| 39 set $preferredLang $1; | 40 set $language $1; |
| 40 set $preferredRegion $2; | 41 set $region $2; |
| 41 } | 42 } |
| 42 | 43 |
| 43 # Redirect canonical URLs to language-specific versions | 44 # Redirect canonical URLs to language-specific versions |
| 44 | 45 |
| 45 if (-e "$document_root/${preferredLang}_$preferredRegion$uri") | 46 if (-e "$document_root/${language}_$region$uri") |
| 46 { | 47 { |
| 47 rewrite ^(.*) /${preferredLang}_$preferredRegion$1 last; | 48 rewrite ^(.*) /${language}_$region last; |
| 48 } | 49 } |
| 49 if (-e "$document_root/$preferredLang$uri") | 50 if (-e "$document_root/$language$uri") |
| 50 { | 51 { |
| 51 rewrite ^(.*) /$preferredLang$1 last; | 52 rewrite ^(.*) /$language$1 last; |
| 52 } | 53 } |
| 53 if (-e "$document_root/en$uri") | 54 if (-e "$document_root/en$uri") |
| 54 { | 55 { |
| 55 rewrite ^(.*) /en$1 last; | 56 rewrite ^(.*) /en$1 last; |
| 56 } | 57 } |
| 57 } | 58 } |
| 58 | 59 |
| 59 # Redirect language URIs if no translations are found for the requested page | 60 # Redirect language URIs if no translations are found for the requested page |
| 60 | 61 |
| 61 location ~ ^/([a-z][a-z]\_[A-Z][A-Z])(/.+) | 62 location ~ ^/([a-z][a-z]\_[A-Z][A-Z])(/.+) |
|
mathias
2018/03/27 14:46:52
Why use [a-z] here but \w above?
Why use [A-Z] her
f.lopez
2018/03/27 19:29:51
Not sure, gonna try it with \w, I reused what we a
f.lopez
2018/03/28 16:05:09
This is because how the translations pages are bui
| |
| 62 { | 63 { |
| 63 if (!-e "$document_root$uri") | 64 if (!-e "$document_root$uri") |
| 64 { | 65 { |
| 65 # if there is no language+region translation, try parent language URI | 66 # if there is no language+region translation, try parent language URI |
| 66 # example /es_MX/page -> /es/page | 67 # example /es_MX/page -> /es/page |
| 67 rewrite ^/([a-z][a-z])\_([A-Z][A-Z])(/.+) /$1$3 redirect; | 68 rewrite ^/([a-z][a-z])\_([A-Z][A-Z])(/.+) /$1$3 redirect; |
| 68 } | 69 } |
| 69 } | 70 } |
| 70 | 71 |
| 71 location ~ ^/([a-z][a-z])(/.+) | 72 location ~ ^/([a-z][a-z])(/.+) |
| 72 { | 73 { |
| 73 if (!-e "$document_root$uri") | 74 if (!-e "$document_root$uri") |
| 74 { | 75 { |
| 75 # if there is no language translation, try canonical page for default langua ge | 76 # if there is no language translation, try canonical page for default langua ge |
| 76 # example /es/page -> /page | 77 # example /es/page -> /page |
| 77 rewrite ^/([a-z][a-z])(/.+) $2 redirect; | 78 rewrite ^/([a-z][a-z])(/.+) $2 redirect; |
| 78 } | 79 } |
| 79 } | 80 } |
| LEFT | RIGHT |