-
Notifications
You must be signed in to change notification settings - Fork 891
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add UserContent mechanism #676
base: main
Are you sure you want to change the base?
Conversation
02a7aed
to
e360ba2
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I am not sure if this is the best way to achieve it. Wouldn't it be simpler to mount a config map or any other volume to that location?
I guess that's already possible, but it would not hurt to document in this PR how that works. From my perspective it's not strictly necessary that that volume is managed by this chart.
The use-case I'd like to solve is to let Jenkins host a simple
To achieve this with the current implementation:
All of these come with more or less overhead. Therefore, letting Jenkins host the files itself would be the most elegant one. Not sure if there is a more easy way to achieve this - any hint would be great. |
60b22b8
to
6088563
Compare
Signed-off-by: Timm Drevensek <[email protected]>
6088563
to
59e9af4
Compare
Hey @torstenwalter, I refactored to work with ConfigMaps instead of Secrets. Also it's possible to provide UTF-8 or binary encoded content separately. What's your suggestion? |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
content looks ok. Would you mind adding a test for this?
https://github.com/jenkinsci/helm-charts/tree/main/charts/jenkins/unittests has quite some examples
{{- if or .Values.controller.userContents .Values.controller.binaryUserContents }} | ||
{{- range $content := .Values.controller.userContents }} | ||
- name: jenkins-user-contents | ||
mountPath: {{ $.Values.controller.jenkinsHome }}/userContent/{{ $content.name }} | ||
subPath: {{ $content.name }} | ||
readOnly: true | ||
{{- end }} | ||
{{- range $content := .Values.controller.binaryUserContents }} | ||
- name: jenkins-user-contents | ||
mountPath: {{ $.Values.controller.jenkinsHome }}/userContent/{{ $content.name }} | ||
subPath: {{ $content.name }} | ||
readOnly: true | ||
{{- end }} | ||
{{- end }} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is there a reason why you are mounting files individually instead of mounting all at once?
- name: jenkins-user-contents
mountPath: {{ $.Values.controller.jenkinsHome }}/userContent/
readOnly: true
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If you mount the Configmap, K8S will create symlinks foobar.txt -> ..data/foobar.txt
where ..data -> ..2020_03_03_16_40_36.675612011
Jenkins seems to be not supporting symlinks at this point - neither by displaying nor serving it:
Might be related to Jenkins Security Advisory 2021-01-13?
So you can not access userContent/foobar.txt
directly but would need to go via something like userContent/..2020_03_03_16_40_36.675612011/foobar.txt
- and this is an always changing URL.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thx for the clarification.
@timmjd Sorry I lost track of this. You can ping me once the merge conflicts are resolved and a test is added otherwise this looks good to me. |
What this PR does / why we need it
Implements a way to provide User Content files that will be served by Jenkins. Common use-case is to let Jenkins host a
svg
orpng
together with a customcss
to customize the UI.Which issue this PR fixes
Special notes for your reviewer
Checklist