From bc2a642e7a51f5f8228400c174870f686c3394bf Mon Sep 17 00:00:00 2001 From: Kjeld Schouten Date: Wed, 16 Oct 2024 12:29:19 +0200 Subject: [PATCH] (feat) Add riven (#27673) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit **Description** Adds Riven chart **โš™๏ธ Type of change** - [ ] โš™๏ธ Feature/App addition - [ ] ๐Ÿช› Bugfix - [ ] โš ๏ธ Breaking change (fix or feature that would cause existing functionality to not work as expected) - [ ] ๐Ÿ”ƒ Refactor of current code **๐Ÿงช How Has This Been Tested?** **๐Ÿ“ƒ Notes:** **โœ”๏ธ Checklist:** - [ ] โš–๏ธ My code follows the style guidelines of this project - [ ] ๐Ÿ‘€ I have performed a self-review of my own code - [ ] #๏ธโƒฃ I have commented my code, particularly in hard-to-understand areas - [ ] ๐Ÿ“„ I have made corresponding changes to the documentation - [ ] โš ๏ธ My changes generate no new warnings - [ ] ๐Ÿงช I have added tests to this description that prove my fix is effective or that my feature works - [ ] โฌ†๏ธ I increased versions for any altered app according to semantic versioning - [ ] I made sure the title starts with `feat(chart-name):`, `fix(chart-name):` or `chore(chart-name):` **โž• App addition** If this PR is an app addition please make sure you have done the following. - [ ] ๐Ÿ–ผ๏ธ I have added an icon in the Chart's root directory called `icon.png` --- _Please don't blindly check all the boxes. Read them and only check those that apply. Those checkboxes are there for the reviewer to see what is this all about and the status of this PR with a quick glance._ --------- Signed-off-by: Kjeld Schouten Signed-off-by: alfi0812 <43101280+alfi0812@users.noreply.github.com> Co-authored-by: alfi0812 <43101280+alfi0812@users.noreply.github.com> --- charts/incubator/riven/.helmignore | 32 +++++ charts/incubator/riven/CHANGELOG.md | 0 charts/incubator/riven/Chart.yaml | 31 +++++ charts/incubator/riven/README.md | 61 ++++++++++ charts/incubator/riven/icon.png | Bin 0 -> 7116 bytes charts/incubator/riven/templates/NOTES.txt | 1 + charts/incubator/riven/templates/common.yaml | 2 + charts/incubator/riven/values.yaml | 116 +++++++++++++++++++ 8 files changed, 243 insertions(+) create mode 100644 charts/incubator/riven/.helmignore create mode 100644 charts/incubator/riven/CHANGELOG.md create mode 100644 charts/incubator/riven/Chart.yaml create mode 100644 charts/incubator/riven/README.md create mode 100644 charts/incubator/riven/icon.png create mode 100644 charts/incubator/riven/templates/NOTES.txt create mode 100644 charts/incubator/riven/templates/common.yaml create mode 100644 charts/incubator/riven/values.yaml diff --git a/charts/incubator/riven/.helmignore b/charts/incubator/riven/.helmignore new file mode 100644 index 0000000000000..feb7464da6f7c --- /dev/null +++ b/charts/incubator/riven/.helmignore @@ -0,0 +1,32 @@ +# Patterns to ignore when building packages. +# This supports shell glob matching, relative path matching, and +# negation (prefixed with !). Only one pattern per line. +.DS_Store +# Common VCS dirs +.git/ +.gitignore +.bzr/ +.bzrignore +.hg/ +.hgignore +.svn/ +# Common backup files +*.swp +*.bak +*.tmp +*~ +# Various IDEs +.project +.idea/ +*.tmproj +.vscode/ +# OWNERS file for Kubernetes +OWNERS +# helm-docs templates +*.gotmpl +# docs folder +/docs +# icon +icon.png +icon.webp +icon-small.webp diff --git a/charts/incubator/riven/CHANGELOG.md b/charts/incubator/riven/CHANGELOG.md new file mode 100644 index 0000000000000..e69de29bb2d1d diff --git a/charts/incubator/riven/Chart.yaml b/charts/incubator/riven/Chart.yaml new file mode 100644 index 0000000000000..f220f24bc3365 --- /dev/null +++ b/charts/incubator/riven/Chart.yaml @@ -0,0 +1,31 @@ +annotations: + truecharts.org/category: security + truecharts.org/max_helm_version: "3.15" + truecharts.org/min_helm_version: "3.11" + truecharts.org/train: incubator +apiVersion: v2 +appVersion: 1.32.1 +dependencies: + - name: common + version: 25.0.0 + repository: oci://tccr.io/truecharts + condition: "" + alias: "" + tags: [] + import-values: [] +deprecated: false +description: Riven Self-Hosted +home: https://truecharts.org/charts/premium/riven +icon: https://truecharts.org/img/hotlink-ok/chart-icons/riven.webp +keywords: + - riven +kubeVersion: '>=1.24.0-0' +maintainers: + - name: TrueCharts + email: info@truecharts.org + url: https://truecharts.org +name: riven +sources: + - https://github.com/truecharts/charts/tree/master/charts/premium/riven +type: application +version: 0.0.1 diff --git a/charts/incubator/riven/README.md b/charts/incubator/riven/README.md new file mode 100644 index 0000000000000..4f656372f650d --- /dev/null +++ b/charts/incubator/riven/README.md @@ -0,0 +1,61 @@ +--- +title: README +--- + +## General Info + +TrueCharts can be installed as both _normal_ Helm Charts or as TrueNAS SCALE Apps. +Both solutions are fully supported, but we heavily advice the use of normal Helm Charts where possible + +For more information about this Chart, please check the docs on the TrueCharts [website](https://truecharts.org/charts/premium/riven) + +**This chart is not maintained by the upstream project and any issues with the chart should be raised [here](https://github.com/truecharts/charts/issues/new/choose)** + +## Installation + +### Helm-Chart installation + +To install TrueCharts Helm charts using Helm, you can use our OCI Repository. + +`helm install mychart oci://tccr.io/truecharts/riven` + +For more information on how to install TrueCharts Helm charts, checkout the [instructions on the website](/guides) + + +### TrueNAS SCALE Apps + +For more information on how to use TrueCharts as TrueNAS SCALE Apps, please checkout the [quick-start guides for TrueNAS SCALE](/deprecated/scale). + +## Chart Specific Guides and information + +All our charts have dedicated documentation pages. +The documentation for this chart can be found here: +https://truecharts.org/charts/premium/riven + +## Configuration Options + +Please note: For TrueNAS SCALE, only options available in the GUI are supported. +Hence most of these docs do not apply to TrueNAS SCALE + +To view the chart specific options, please view Values.yaml included in the chart. +The most recent version of which, is available here: https://github.com/truecharts/public/blob/master/charts/premium/riven/values.yaml + +All our Charts use a shared "common" library chart that contains most of the templating and options. +For the complete overview of all available options, please checkout the documentation for them on the [common docs on our website](/common) + +For information about the common chart and all defaults included with it, please review its values.yaml file available here: https://github.com/truecharts/public/blob/master/charts/library/common/values.yaml + +## Support + +- See the [Website](https://truecharts.org) +- Check our [Discord](https://discord.gg/tVsPTHWTtr) +- Open a [issue](https://github.com/truecharts/charts/issues/new/choose) + +--- + +## Sponsor TrueCharts + +TrueCharts can only exist due to the incredible effort of our staff. +Please consider making a [donation](/general/sponsor) or contributing back to the project any way you can! + +_All Rights Reserved - The TrueCharts Project_ diff --git a/charts/incubator/riven/icon.png b/charts/incubator/riven/icon.png new file mode 100644 index 0000000000000000000000000000000000000000..25bc12f52e74e41bdc64282799cdd6fbae6320e6 GIT binary patch literal 7116 zcmW+*c|26#8@~6>(AbS7OJRiU`%(y#J=vEmStc4wWG_lJ*OF*e_H`^}7e%t0D3PKP zNm*jDlq{17WA1OhzrXIi@44^!ob$ftdCxh|lWK2k!No4h4gdhx2}@H)005b~sVz@ZoUr>foR zlHj6BXDn*}#Kg&ZE8Dfc*wdf(t173MzartT3uuqpzt}jadh@&ud$~OwFDKw@$!p}W z{>!>?dTXz9VQ)Nc*h4eef9!4Tv<)u6aO_xcT|kj`+~zg04QD)~AzBS{*M{!fJ=l$c~(}1azhR<|5M1JpkD)Zr#zUvV*VZBzT z@2%P^OtcAbLYV(c;<(a)z^@QYhA9PuV?FPeApGgUuJG~zZxI&(jk{NMClI5Rh}T3D zmZz<)b4w1OCsM}!F@%E3b5h|ue=Ov`NiC!<@290>@fgY77?WZ@^ld=zq6#S}w^^i1 za;%IOG6$~1%|V>t9Za-2(3}{=`7~cAm(;Xfp#r)c3%qqB`S%mT%?NKVDCNocjxdxA z3o~7O?I-ZbFe^INDzFHM^$T=+_Jx2EhOn3%CuncIjS^{80QvagOKJh}^pDr(#jDSAmKw1)Crj42ox?AT&-0_A$% zv#YNG@AHpfbcT+(5;HEG)Q+utVC;dila));Ovi)goN3eTAJ`_9r0cizWr0??wW(?D z8F}D2rj05);)Her6H+GZmC$;!@CBu#8#A5cqQ9h@*H!A)EefL~O0=JyN`{pn6Ml+l zMg^7GYP&Ms6HopZJ>$s|o|Ecl|EgI`rRq>#q|*VAx4}9ckrq`G#IGf4-?v~66Am)p zCh4{pvhdRFJ5SVT_`eF30*sws^^?nCN=l!V~4zL3!u zzbMkc)Qmw(e;i4Wl6ZZrbj2HAav{B3M0LlqL0a46FkljgT7E>A75gF6>O1nq8LyWt zXpWQSC^^B>D>UU@eful7a;vauhO#-3bcC&a9k<_plUWpueAVIl3?fass0lYl#puw1eoh=q;nRV=Y1V zs^BDw%ILGd>KP9u`q7hnjuPU7lQt5nUy~278a^b_=77h#O07L44pw zg0&P4;aw?lfwvgL0G%J6zLoMq7W6!^tE;oq$9Kl(gNixub@CzghLOy{W3}vSQ{DU& zA)o{1q_#%qU;DB2d#H8#{_Dl25-cSPc#Mjzv64{zEY@2ES5kd0{zMJ6l2SG=$sQua zLj6hziDPDL5qEmE(u##TwC_8WoVNFUB|G?)n(o)FcK!)Wbb~YbfOo#Uo^us^F!-C;zpM9M{)}+7 zt`xN2nCj@xGU3PjZJ?NbV1lY_OLP&$dm%1HTmDwD0jrH5d2eytoBy8JQaR%S2sy&1)f7 z(e{|F+x3iVk z9;vsFqN~awxxVWYXRmw`%DcR?b!HHjWGjA1cddeK9ZQ?#DqH^e98zB%fgRWgn;S-* z0AM;=K<%XRehGq)jYzHI@#f3KgIZfk-H|8z#~L z@^#5_D04}8nP#Moi95yc?y5K4HRlm=TGZEjUB2* z%kECRZ*po&Ql5nSzI0C>7>aak^tpQbU)`RKz&qP=b4D{`7qZt{nNV`ya4BvK% zRcdd?peYKdoQa2DE5K58n)qgM?oGdgnZaTIyd(<=)!?&1r7KEo?&NSA+Bkf#7=(;XG3Zui<=OVz+NB&ZC+D;V5W zA-6igq#vZCL9q(B>Y>~{Z#bH!sdUTsnj)%aJ$jpnTi{Sl-}lU$!y(075in zzoI%502J+;p`SGTcvnw+m2@%euYsaASFqHK-Gqw>NiN@#3n>J0(R)I z>w6VGl|fe2!d+SWi45+p$8X?G3_&tQ+lw)f8xX00Kc;?ka43(i4-q;KP}IfoM~HYk zbojL$RsJ~zD#?xMCqkWIRqP_o0UdV%{}geXH8;~S*|VMO4CRQsy^2M>i% z!3$gD%`-R`8bZz3y$Xo4x5``{;eLnT*_s_7d$J~FkD7_R?|>{HAdO#tVU??o?uB`> zIG_A4jY_AO72@ZDgDoOt2|t8-&ZO0ujZ&X$;FdpIp?P&~Px$`LUkloC?R=>iuAlZZ zx%J}g5xVc4^(h}zxJ)x*W%O5_&m+nUvJ`-3X^61$GaAWnp1XZi779WO-zC|3*Q)H=nb`Q2xs{~oWhW$k zynh@J(Ks4mxqG5g8J^nhhSu(-h8JD9H!d{V&k*5j(3o-55r;>VK+A?5tDeOyL^io% ziX+8xLwB)9zx(}TL6hk38aV$?HstdEV}g&zgGzcMT51wnKF3hP%jM@bUr#6N7DxYi zd!Wxsq*%sy9$RMx$lK0)GS18=O)$5C*hkfHtk1tNROlbY&UL?xr64=hP(`# z+^O$w!Bz|jl>kRjJXVhCeEj7n=7Rl)E@Dkeoa=bSYU3|bY$2HBE5mw!`RZi`&5k|x z`YKDM!P@Dbw9~9=sZWPS;0*Y~mI`o3M3+WRwM(ZV&Mfv*Si)@NL`PL2f|iIA4F^)J zSQ^Yxp8Eq>FE`SV$U>GOD9?t$CdF(kz$&oe!pBGZYPz-5d#SP>e{N561nMy>3c-hc zBI$z;{$I9hX(Mmk;Y?6JJnso+lzpv)M=Z=39|t z)i&p)_o0h#Jz8jZ){b->+nnkapg3!E7JZI#61OG#&JGP1J#*XFF3@zntrD^<5iX(! zXkKy{vwabtFFCb4y>Bi2RugS2+V|m9akoK7#8qu96*j9+S7Rzkhe?I5!kf487dd@i(9YB z6u7uUo?ZH_xh90lF_hX21xTDTJQqzE67W*hi?Wg6S3|92S=&+57)2C&Ht@vZer{cU zH=Y01uf;tLLoPzs0o-r4Hs26qF!0h}*9jYgI~F{;1~tqnLX<7gTIRuq4?hvFhz@5o z`e>}2W2|&@a!TFSuybgA1Mqluhp&kL?yr^w(vb-hx$LV%EwgSS@J_V`ZQsWduNkze z=)?E`L+^6OZr;N?5%J0PA;-aJRYdb&CYcSjm7|Orw@VKIosny)=ODFhqwrJvJ$L$v zFgxTn0Seh6Cd&tRVv6GjjaW1ZYgOEXaQI@wi#Fz!B4E7xo}=adY8)(MIow5;S`gFU z3wRwdEf#6Ol{57!{3e;T@~TKbl{C#(asEOu5kK4IwC(s_@8dZ^nEr#@dBBDdJZQ+W zsr6S2&#U?l9Ui_z?tk$b&ZP@+78fOpKH;=K0USo+tZFWfY0QoQb?CIewBhSf!wq)C zuc>~G87Y*d<5W{ ziSW7t5p}e{rc391j1vhLl^12BP)WwX>Ce$aet{uU}15~Joihx;Jqml74YJBaS<48kfc%&c^4+AudvH^rp{3#f> za%~-K^y7DBO?&I;!0PPE4E2c@j*lGTmK1o>H%8#}o|4NV#qq%MO81p-6DbLpjVtn% z3SbUh=(ghlg#(a5Hu#JUPo)jtUT8Pm8{WU9v!(=nBvJ;XT?XL^G=Vn#Kn04Atl-bq ze07Wqr&9ZK1ki;DI}cmv0TUL{McN0@@r@d|ZBdGNOSK(}ih)Hi7k7ryZ}VKu@THt? z-*2BI;%y+p0EzWG_n%1;zcx{~@rx@X&ozfG_>T0K#&uVFc;=V>9_PG?qk085X{1C|zYu!{B}IJ8w%! z0?QjdJ;(3dmV6>|Lg`tyMzJ(FzSM0>{UUshx6+H%5^zXjUIdVy1RI6~81>X*|5uG$ zHqzLwLw*};T7)7X>1wMIB85gC{c85IVcbf3%Egz6=ONtZ1MQ0b5tt8+i`hbi52Yh~*bqNy$+T9^mTBGWIfuDx?_@9p zGluLsv1HKb#QK@SeR!Oo$eQ-Tx6A@w6+YOMEr4cJ@hc=m8Pi19!qq^<-i*|6W(G0u zE4`%q$$G9lzo~<;6tTdbHOU}1|G$~~CEb`aE*q^r|3DEn^k%k}h}U68yI#+GpT=X( zug^SKsnWn`1w!nZJvMyq-Pa3!ihxTO=TVxQu}H(pB@rkm0^TxYMna*)&*f|d;uR3p zeyc1Kbg=7snh9#4!)F_>&`7AF$-S^67H!QPuQYH%U}YBKWl^I1SQPp|1Z)J(%A+E& z_&mDL#gYN!-1qbRPQ1mLV8;D&9gDYVk2rZ{0o`qq)vd!w)fvCv+*r9d<9_Cu{xlM* z?LNiTf1HUWWz-Eb*p;;bL+Ekt;QYVo1{dk{Kl7G25*PliK7IDTqk8`U@&#WVx8rl_ zgvVhAto@>pw+P;AvAi%=1ZTtS#huaAXK;w3h|0mlep^+cdSkN=1M1r(N3kzUMw+%` z`HJ6k_{SacL$`7?Krd zHre{Kv?kSpMR5PL@Q%!khv}Vt7aN40e*IYCbW$N>t3VP}YqL87pM~BlBd1f; z(j}B*<;To_6Ja#iq>T6(1n+Tz5cGrytT(7_PXcVvdr9QHluVLeWoo>zvE2N$b~bo| zSv`ynAFLe?#H_smW~aJY)VC*L=l>w*q4o9h7tG5n@MY?QH%t@LJJr&?Q5TJQN`C*c z!OMd1gp+XoUt^TC7yHe_z)gBZ-T7vh*&h-d7AAz9Ys)J&9_*BvOi(Ftco67obHY%l zMuT=^v1ieNMBw~j!3*^^PD@Et}20^ENi$J4d2~*=%4zNI&DQ5-=wBYIK3p#_as&Xjyd~Ox0*9WhS?{X z?RH7B7yFx+gh@X+?Yp&3(H=7G=3{{lcBpZ5nmeQMRLC8RWYGHY;f$E=CN#lmc&;1RhKJ?w<{+qtzPdJaNT=`0=wSN&HQNiy{;p zux~Z&+yAN7rlezRZCU%zHj6@kFb#tMD;RQZUHbD6iKt3RyeVbz81TtTB>b9L+DQOm zpAj#u_@w0|s8M~}VeXJja=)HzsMfjqR~KvR1Mjm@;t=}epKYPVwf%x}Vq;TH386}qi4^xb1LpQ#eDC2(yA)- zZ;qG30n*WwKgNmTNSv8)WwH+8&;|MP&B483YpsCz){%A-ijSl3cNpj)W7nq;4mie< zb?lqDaQM5E%KrIhJUD+&n%+twF{yNwYVETuYFvw*Bvp9WX`fwK_Wn~roxNiV;zl9I zca?jDlTSC@OIT!QeAC@x`I+JgsRwf;un;|N`gDE7SWl-0mlJUH; z5ksheyiqf3fa*X4aNwy0x(Q3xh`akX_4)4rfbmjy%gYw?gpFVU{m1DO^n`EI^*w{= z)l#xy&H0job8RaQ`P}rW-v#YMX0kVdi_&YX01v7qQNL<_^MdiCq1wE?_hsjEJLug2 zqepkk=U2`<37Q2zs&OOR={bZ&%t2Bw~j4 z4vi&9LoEfL;z&#iwgQC#VxXLqlHG19=L*Q_7&*zYGkydA=d%=$0!#nsC=CD{!8d z$entmf(=UXDf(+|OyMis=aU#K0W{!UGO<}XJ348;_0z9h0=P}XODG2IR XLsGd}@BWuec@8*XW^4M`n2_*4v%U?s literal 0 HcmV?d00001 diff --git a/charts/incubator/riven/templates/NOTES.txt b/charts/incubator/riven/templates/NOTES.txt new file mode 100644 index 0000000000000..efcb74cb77218 --- /dev/null +++ b/charts/incubator/riven/templates/NOTES.txt @@ -0,0 +1 @@ +{{- include "tc.v1.common.lib.chart.notes" $ -}} diff --git a/charts/incubator/riven/templates/common.yaml b/charts/incubator/riven/templates/common.yaml new file mode 100644 index 0000000000000..992373e7501df --- /dev/null +++ b/charts/incubator/riven/templates/common.yaml @@ -0,0 +1,2 @@ + +{{ include "tc.v1.common.loader.all" . }} diff --git a/charts/incubator/riven/values.yaml b/charts/incubator/riven/values.yaml new file mode 100644 index 0000000000000..170f08504ce97 --- /dev/null +++ b/charts/incubator/riven/values.yaml @@ -0,0 +1,116 @@ +image: + repository: ghcr.io/elfhosted/riven + pullPolicy: IfNotPresent + tag: v0.15.3@sha256:2942af96b90708f24c87acdf2c1cd22e334c5cb3d5421c6d280e1ce4988df59e + +frontendImage: + repository: ghcr.io/elfhosted/riven-frontend + pullPolicy: IfNotPresent + tag: v0.13.1@sha256:92cee31094be29b9a2df7e18527dc7cfc3e82bb4acff56c7da6496576ef619ad + +service: + main: + ports: + main: + port: 3001 + targetPort: 3001 + + frontend: + enabled: true + ports: + frontend: + enabled: true + port: 3000 + targetPort: 3000 + backend: + enabled: true + ports: + backend: + enabled: true + port: 8080 + targetPort: 8080 + +workload: + main: + podSpec: + containers: + main: + tty: true + env: + # forces the use of env vars to be always used! + RIVEN_FORCE_ENV: "true" + ZURG_URL: somezurgurl:9999 + # Set this to your rclone's mount `__all__` dir if using Zurg + RIVEN_SYMLINK_RCLONE_PATH: "/mnt/zurg/__all__" + # This is the path that symlinks will be placed in + RIVEN_SYMLINK_LIBRARY_PATH: "/mnt/library" + RIVEN_DATABASE_HOST: '{{ printf "postgresql+psycopg2://%s:%s@%s.%s/%s" .Values.cnpg.main.user .Values.cnpg.main.creds.password (.Values.cnpg.main.creds.host | trimAll "\"") .Release.Namespace .Values.cnpg.main.database }}' + RIVEN_DOWNLOADERS_REAL_DEBRID_ENABLED: "false" + # set your real debrid api key + RIVEN_DOWNLOADERS_REAL_DEBRID_API_KEY: "xxxxx" + RIVEN_UPDATERS_PLEX_ENABLED: "false" + RIVEN_UPDATERS_PLEX_URL: "http://plex:32400" + # set your plex token" + RIVEN_UPDATERS_PLEX_TOKEN: "xxxxx" + RIVEN_CONTENT_OVERSEERR_ENABLED: "false" + RIVEN_CONTENT_OVERSEERR_URL: "http://overseerr:5055" + # set your overseerr token + RIVEN_CONTENT_OVERSEERR_API_KEY: "xxxxx" + RIVEN_SCRAPING_TORRENTIO_ENABLED: "false" + RIVEN_SCRAPING_ZILEAN_ENABLED: "false" + RIVEN_SCRAPING_ZILEAN_URL: "http://zilean:8181" + probes: + liveness: + type: tcp + readiness: + type: tcp + startup: + type: tcp + frontend: + enabled: true + tty: true + imageSelector: frontendImage + probes: + liveness: + port: 3000 + type: tcp + readiness: + port: 3000 + type: tcp + startup: + port: 3000 + type: tcp + env: + # ORIGIN: "http://localhost:3000" + BACKEND_URL: "http://localhost:8080" + DIALECT: "postgres" + DATABASE_URL: '{{ printf "postgresql://%s:%s@%s.%s/%s" .Values.cnpg.main.user .Values.cnpg.main.creds.password (.Values.cnpg.main.creds.host | trimAll "\"") .Release.Namespace .Values.cnpg.main.database }}' + + +persistence: + logs: + enabled: true + mountPath: "/riven/data/logs" + data: + enabled: true + mountPath: "/riven/data" + zurg-all: + enabled: true + mountPath: "/mnt/zurg/__all__" + library: + enabled: true + mountPath: "/mnt/library" + +cnpg: + main: + enabled: true + user: riven + database: riven + +portal: + open: + enabled: true +ingress: + main: + targetSelector: + frontend: frontend