Skip to content
settings_web.go 5.15 KiB
Newer Older
Timothee Gosselin's avatar
Timothee Gosselin committed
/*

Licensed under the Apache License, Version 2.0 (the "License");
Timothee Gosselin's avatar
Timothee Gosselin committed
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

    http://www.apache.org/licenses/LICENSE-2.0
Timothee Gosselin's avatar
Timothee Gosselin committed

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/

package v1alpha1
Timothee Gosselin's avatar
Timothee Gosselin committed
	"fmt"

	"k8s.libre.sh/application/settings"
	"k8s.libre.sh/application/settings/parameters"
	"k8s.libre.sh/meta"
	"k8s.libre.sh/objects"
	"sigs.k8s.io/controller-runtime/pkg/client"
)

const nginxConf = `
Timothee Gosselin's avatar
Timothee Gosselin committed
	user www-data;
Timothee Gosselin's avatar
Timothee Gosselin committed

Timothee Gosselin's avatar
Timothee Gosselin committed
	events {
	worker_connections 768;
	}

	http {
	upstream backend {
		server {{ .components.app.service.meta.name }}:{{ .components.app.service.port.port }};
Timothee Gosselin's avatar
Timothee Gosselin committed
	}
Timothee Gosselin's avatar
Timothee Gosselin committed
	include /etc/nginx/mime.types;
Timothee Gosselin's avatar
Timothee Gosselin committed
	default_type application/octet-stream;

	server {
		listen 80;
Timothee Gosselin's avatar
Timothee Gosselin committed
		
Timothee Gosselin's avatar
Timothee Gosselin committed
		# Add headers to serve security related headers
		add_header X-Content-Type-Options nosniff;
		add_header X-XSS-Protection "1; mode=block";
		add_header X-Robots-Tag none;
		add_header X-Download-Options noopen;
		add_header X-Permitted-Cross-Domain-Policies none;
		add_header Referrer-Policy no-referrer;

		root /var/www/html;

		location = /robots.txt {
		allow all;
		log_not_found off;
		access_log off;
		}

		location = /.well-known/carddav {
		return 301 https://$host/remote.php/dav;
		}
		location = /.well-known/caldav {
		return 301 https://$host/remote.php/dav;
		}

		client_max_body_size 1G;
		fastcgi_buffers 64 4K;

		gzip off; # handled at haproxy level
Timothee Gosselin's avatar
Timothee Gosselin committed
	
Timothee Gosselin's avatar
Timothee Gosselin committed
		location / {
			rewrite ^ /index.php;
		}
Timothee Gosselin's avatar
Timothee Gosselin committed
		
Timothee Gosselin's avatar
Timothee Gosselin committed
		location ~ ^\/(?:build|tests|config|lib|3rdparty|templates|data)\/ {
			deny all;
		}
Timothee Gosselin's avatar
Timothee Gosselin committed
		
Timothee Gosselin's avatar
Timothee Gosselin committed
		location ~ ^\/(?:\.|autotest|occ|issue|indie|db_|console) {
			deny all;
		}

		location ~ ^\/(?:index|remote|public|cron|core\/ajax\/update|status|ocs\/v[12]|updater\/.+|oc[ms]-provider\/.+)\.php(?:$|\/) {
			fastcgi_split_path_info ^(.+\.php)(/.*)$;
			try_files $fastcgi_script_name =404;
			set $path_info $fastcgi_path_info;
			include fastcgi_params;
			fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
			fastcgi_param PATH_INFO $path_info;
			fastcgi_param HTTPS on;
			#Avoid sending the security headers twice
			fastcgi_param modHeadersAvailable true;
			fastcgi_param front_controller_active true;
			fastcgi_pass backend;
			fastcgi_intercept_errors on;
			fastcgi_request_buffering off;
		}

		location ~ ^\/(?:updater|oc[ms]-provider)(?:$|\/) {
			try_files $uri/ =404;
			index index.php;
		}

		# Adding the cache control header for js and css files
		# Make sure it is BELOW the PHP block
		location ~ \.(?:css|js|woff2?|svg|gif|map)$ {
			try_files $uri /index.php$request_uri;
			add_header Cache-Control "public, max-age=15778463";
			# Add headers to serve security related headers (It is intended to
			# have those duplicated to the ones above)
			# Before enabling Strict-Transport-Security headers please read into
			# this topic first.
			# add_header Strict-Transport-Security "max-age=15768000;
			#  includeSubDomains; preload;";
			add_header X-Content-Type-Options nosniff;
			add_header X-Frame-Options "SAMEORIGIN";
			add_header X-XSS-Protection "1; mode=block";
			add_header X-Robots-Tag none;
			add_header X-Download-Options noopen;
			add_header X-Permitted-Cross-Domain-Policies none;
			add_header Referrer-Policy no-referrer;
			# Optional: Don't log access to assets
			access_log off;
		}

		location ~ \.(?:png|html|ttf|ico|jpg|jpeg|bcmap)$ {
			try_files $uri /index.php$request_uri;
			# Optional: Don't log access to other assets
			access_log off;
		}
	}
}
`

type WebSettings struct {
	CreateOptions settings.CreateOptions `json:"createOptions,omitempty"`
	Sources       []settings.Source      `json:"sources,omitempty"`
	ConfTemplate  parameters.Parameter   `json:"conf,omitempty" env:"nginx-conf"`
}

func (s *WebSettings) SetDefaults() {

	//	s.CreateOptions.Init()
	//	s.CreateOptions.CommonMeta.Labels["app.kubernetes.io/component"] = "web"

Timothee Gosselin's avatar
Timothee Gosselin committed
	if len(s.ConfTemplate.Value) == 0 && len(s.ConfTemplate.ValueFrom.Ref) == 0 {
		s.ConfTemplate.Value = nginxConf
		s.ConfTemplate.Generate = parameters.GenerateTemplate
		s.ConfTemplate.MountType = parameters.MountEnvFile
		s.ConfTemplate.Type = parameters.ConfigParameter
		s.ConfTemplate.MountType = parameters.MountFile
		s.ConfTemplate.MountPath.Path = "/etc/nginx/nginx.conf"
		s.ConfTemplate.MountPath.SubPath = "nginx.conf"
Timothee Gosselin's avatar
Timothee Gosselin committed
		s.ConfTemplate.Key = "nginx-conf"
Timothee Gosselin's avatar
Timothee Gosselin committed
	fmt.Println(s.ConfTemplate)
}

func (s *WebSettings) GetConfig() settings.Config {

Timothee Gosselin's avatar
Timothee Gosselin committed
	//	params, _ := parameters.Marshal(*s)
Timothee Gosselin's avatar
Timothee Gosselin committed
	params := parameters.Parameters{}
	params = append(params, &s.ConfTemplate)
	settings := &settings.ConfigSpec{
		Parameters: &params,
		Sources:    s.Sources,
	}
	return settings
}

func (s *WebSettings) GetMeta() meta.Instance { return s.CreateOptions.CommonMeta }

func (s *WebSettings) GetObjects() map[int]objects.Object {
	return nil
}

func (s *WebSettings) Init(c client.Client) error {
	return nil
}

func (s *WebSettings) GetCreateOptions() *settings.CreateOptions {
	return &s.CreateOptions
}