Cloudron makes it easy to run web apps like WordPress, Nextcloud, GitLab on your server. Find out more or install now.


Skip to content
  • Categories
  • Recent
  • Tags
  • Popular
  • Bookmarks
  • Search
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Default (No Skin)
  • No Skin
Collapse
Brand Logo

Cloudron Forum

Apps - Status | Demo | Docs | Install
  1. Cloudron Forum
  2. App Packaging & Development
  3. Update on community packages

Update on community packages

Scheduled Pinned Locked Moved App Packaging & Development
32 Posts 10 Posters 1.8k Views 10 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • girishG girish

    We would like to add support for Community packages as part of 9.1. The idea is that a 3rd party developer can create a cloudron package and provide it to other users with no intervention by cloudron team. I have implemented most of the stuff. Here's how it will look like:

    • The CLI tool gained some new commands - cloudron versions init/add/update/list. This just manipulates a file named CloudronVersions.json .
    • CloudronVersions.json has to be uploaded somewhere (or serve it straight from git repo).
    • There is a button in the App store view to install a community app.
      2b96ce78-6aec-4d76-a88f-dcb1eb21fe6a-image.png
    • Test with a URL like https://git.cloudron.io/playground/contacts/-/raw/main/CloudronVersions.json
    • After this, it will show the app and install just like any other app.
      a5e28c39-9969-4f33-a5fd-43cf706733b2-image.png
    • A new packager name appears in the Info
      0b0780fd-1d6c-45a1-83ce-a2f312ebb2ac-image.png

    Other than that, updates etc works like a normal app.

    cc @timconsidine @appdev

    murgeroM Offline
    murgeroM Offline
    murgero
    App Dev
    wrote on last edited by
    #5

    @girish I absolutely love this idea but is there a way to maybe host a community store? Like Arch's AUR for example that way it can be searchable too - you can allow "verified devs" for an extra layer of security or something

    --
    https://urgero.org
    ~ Professional Nerd. Freelance Programmer. ~

    BrutalBirdieB 1 Reply Last reply
    3
    • murgeroM murgero

      @girish I absolutely love this idea but is there a way to maybe host a community store? Like Arch's AUR for example that way it can be searchable too - you can allow "verified devs" for an extra layer of security or something

      BrutalBirdieB Offline
      BrutalBirdieB Offline
      BrutalBirdie
      Partner
      wrote on last edited by
      #6

      @murgero
      Are you talking about the CUR? 😄
      Very happy to see this comming to Cloudron!

      Like my work? Consider donating a drink. Cheers!

      1 Reply Last reply
      5
      • rmdesR Offline
        rmdesR Offline
        rmdes
        wrote on last edited by
        #7

        Amazing !

        1 Reply Last reply
        2
        • jadudmJ jadudm

          I would ask, for simplicity, that you require the developer to put the JSON in a fixed/predictable path, and allow the user to paste the URL for the main GH repo. Asking users to find the "raw" link is likely hard/confusing. Put the onus on the person packaging, not the person installing?

          girishG Offline
          girishG Offline
          girish
          Staff
          wrote on last edited by
          #8

          @jadudm Good idea, will give it a try.

          @murgero right now, the first step is to make it possible to install community packages easily. Depending on how many packages we have and how many people provide multiple packages, we have to look into adding custom stores.

          timconsidineT 1 Reply Last reply
          2
          • girishG girish

            @jadudm Good idea, will give it a try.

            @murgero right now, the first step is to make it possible to install community packages easily. Depending on how many packages we have and how many people provide multiple packages, we have to look into adding custom stores.

            timconsidineT Offline
            timconsidineT Offline
            timconsidine
            App Dev
            wrote on last edited by
            #9

            @girish said in Update on community packages:

            Depending on how many packages

            my CustomAppGateway has ~25 apps, and there are more currently out there not added to it, and with 9.1, I would expect the numbers to double at least.

            I have no hesitancy with deferring 'app discovery' in favour of getting the core functionality available and working.

            I feel we will need a discovery place of some kind, relying on a forum post in an AppWishList topic might be viable as short and medium term. But catalogue / CUR / "awesome" style git package is likely needed longer term. And it's more polished / prettier 😄

            Indie app dev, scratching my itches, lover of Cloudron PaaS, communityapps.appx.uk

            1 Reply Last reply
            6
            • KubernetesK Offline
              KubernetesK Offline
              Kubernetes
              App Dev
              wrote on last edited by
              #10

              Sorry, maybe a stupid question, but I didn't find the answer anywhere. Don't we have any "Guide" on how to create the new Community Apps for Cloudron? How do I know how the CloudronVersions.json have to be configured. What are the requirements? Are there limitations? When I look at existing CloudronVersions.json it seems that Community Apps do not need to use the Cloudron Base Image anymore? Questions over questions 🙂

              1 Reply Last reply
              0
              • jamesJ Offline
                jamesJ Offline
                james
                Staff
                wrote on last edited by
                #11

                Hello @kubernetes

                In the announcement https://forum.cloudron.io/topic/15174/community-apps we have linked the documentation.
                Follow the Packaging documentation and Publishing.

                1 Reply Last reply
                3
                • jamesJ Offline
                  jamesJ Offline
                  james
                  Staff
                  wrote on last edited by
                  #12

                  Hello @kubernetes

                  If you find something unclear of lacking in the documentation, please let me know so we can improve further.

                  timconsidineT 2 Replies Last reply
                  2
                  • jamesJ james

                    Hello @kubernetes

                    If you find something unclear of lacking in the documentation, please let me know so we can improve further.

                    timconsidineT Offline
                    timconsidineT Offline
                    timconsidine
                    App Dev
                    wrote on last edited by
                    #13

                    @james

                    Spread the word
                    
                    Post about new packages in the App Packaging & Development category of the forum.
                    

                    Personally I think that category should remain more technical, devs needing assistance / having questions.

                    You published a different category : https://forum.cloudron.io/category/220/community-apps

                    I think that is where the word should be spread.

                    Just my 2p.

                    Indie app dev, scratching my itches, lover of Cloudron PaaS, communityapps.appx.uk

                    1 Reply Last reply
                    4
                    • jamesJ Offline
                      jamesJ Offline
                      james
                      Staff
                      wrote on last edited by
                      #14

                      Hello @timconsidine
                      Good point.
                      Will update the documentation.

                      1 Reply Last reply
                      2
                      • jamesJ james

                        Hello @kubernetes

                        If you find something unclear of lacking in the documentation, please let me know so we can improve further.

                        timconsidineT Offline
                        timconsidineT Offline
                        timconsidine
                        App Dev
                        wrote on last edited by
                        #15

                        @james said:

                        If you find something unclear of lacking in the documentation ...

                        Just getting my head around the workflow, and I like to "spell things out" :


                        • build the Community App (previously known as a Custom App) ✅
                          (my 'old fashioned' approach : docker build, docker push, cloudron install, probably keep doing that because my build script does it, don't fix what ain't broke)

                        • make a CloudronVersions.json file
                          ✅
                          same folder as project dev folder (Dockerfile, start.sh, CloudronManifest.json, README.md, POSTINSTALL.md etc.)
                          • cloudron versions init
                          • cloudron versions add
                          • maybe add to my build script

                        • why "CloudronVersions" in the plural ?
                          🤷
                          I guess Cloudron thinking is that a Community App might have v1.0.0, v1.0.1, v2.0.0
                          Very complete approach, lovely 👍
                          but with cloudron versions revoke I wonder if this will ever be in true in practice (I would likely revoke every old version).

                        • upload CloudronVersions.json to static hosting
                          ✅ gotcha 👍
                          but if I have 10 Custom oops Community Apps, what is Cloudron team envisioning :
                          • that I will have 10 Surfer apps (app1.tim.uk, app2.tim.uk, etc) ?

                          • Or 1 sectioned Surfer app (communityapps.tim.uk) ?

                          • Or no Surfer apps and just stick CloudronVersions.json in the relevant git repo (urls to files from git are not always clear) ?

                          • I guess you probably don't care, but I'm intrigued what your expectations are


                        Cloudron CLI help typo ?

                        % cloudron versions --help 
                        Usage: cloudron-versions [options] [command]
                        

                        Hyphenated ?


                        Indie app dev, scratching my itches, lover of Cloudron PaaS, communityapps.appx.uk

                        girishG 1 Reply Last reply
                        2
                        • timconsidineT timconsidine

                          @james said:

                          If you find something unclear of lacking in the documentation ...

                          Just getting my head around the workflow, and I like to "spell things out" :


                          • build the Community App (previously known as a Custom App) ✅
                            (my 'old fashioned' approach : docker build, docker push, cloudron install, probably keep doing that because my build script does it, don't fix what ain't broke)

                          • make a CloudronVersions.json file
                            ✅
                            same folder as project dev folder (Dockerfile, start.sh, CloudronManifest.json, README.md, POSTINSTALL.md etc.)
                            • cloudron versions init
                            • cloudron versions add
                            • maybe add to my build script

                          • why "CloudronVersions" in the plural ?
                            🤷
                            I guess Cloudron thinking is that a Community App might have v1.0.0, v1.0.1, v2.0.0
                            Very complete approach, lovely 👍
                            but with cloudron versions revoke I wonder if this will ever be in true in practice (I would likely revoke every old version).

                          • upload CloudronVersions.json to static hosting
                            ✅ gotcha 👍
                            but if I have 10 Custom oops Community Apps, what is Cloudron team envisioning :
                            • that I will have 10 Surfer apps (app1.tim.uk, app2.tim.uk, etc) ?

                            • Or 1 sectioned Surfer app (communityapps.tim.uk) ?

                            • Or no Surfer apps and just stick CloudronVersions.json in the relevant git repo (urls to files from git are not always clear) ?

                            • I guess you probably don't care, but I'm intrigued what your expectations are


                          Cloudron CLI help typo ?

                          % cloudron versions --help 
                          Usage: cloudron-versions [options] [command]
                          

                          Hyphenated ?


                          girishG Offline
                          girishG Offline
                          girish
                          Staff
                          wrote on last edited by girish
                          #16

                          @timconsidine said:

                          upload CloudronVersions.json to static hosting

                          I think if the packaging code is public, it makes much sense to keep it in version control itself. If packaging code is private, you can upload it to surfer. In the case latter case, I would just have 1 surfer instance for all the apps that I would publish.

                          Cloudron CLI help typo ?

                          This is quirk of commander. Which incidentally, I just fixed yesterday - https://git.cloudron.io/platform/cloudron-cli/-/commit/a926a848400de22ddaae30f2139e0556e9461f80

                          1 Reply Last reply
                          1
                          • timconsidineT Offline
                            timconsidineT Offline
                            timconsidine
                            App Dev
                            wrote on last edited by timconsidine
                            #17

                            @James

                            % cloudron versions add
                            Error: Bad changelog format or missing changelog for this version
                            

                            'CHANGELOG' is present :

                            * 1.0.0
                            - Initial release
                            

                            But I don't see any mention in cloudron docs what format is expected.

                            Maybe error is because this test community app has a CloudronManifest.json entry of :

                            "changelog": "file://CHANGELOG",
                            

                            Does 'cloudron versions add' not recognise/support this way of doing it ?


                            EDIT : I changed CloudronManifest.json to read :

                              "changelog": "v1.0.0 - Initial release",
                            

                            Then 'cloudron versions add' worked

                            Not suggesting anything needs fixing as such. But potential mismatch of usage. Simple text string is easier - but it won't be practical for complex changelog descriptions.

                            And this cheat works :

                             "changelog": "see CHANGELOG",
                            

                            Not sure I should be cheating, but ...

                            'cloudron versions add' seems to handle 'file://POSTINSTALL.md' but not 'file://CHANGELOG'

                            Being creative, I tried this, thinking POSTINSTALL.md worked with file name extension.

                            "changelog": "file://CHANGELOG.md",
                            

                            But it does not.
                            Seems like 'cloudron versions' treats the entries differently.

                            Indie app dev, scratching my itches, lover of Cloudron PaaS, communityapps.appx.uk

                            girishG 1 Reply Last reply
                            0
                            • timconsidineT timconsidine

                              @James

                              % cloudron versions add
                              Error: Bad changelog format or missing changelog for this version
                              

                              'CHANGELOG' is present :

                              * 1.0.0
                              - Initial release
                              

                              But I don't see any mention in cloudron docs what format is expected.

                              Maybe error is because this test community app has a CloudronManifest.json entry of :

                              "changelog": "file://CHANGELOG",
                              

                              Does 'cloudron versions add' not recognise/support this way of doing it ?


                              EDIT : I changed CloudronManifest.json to read :

                                "changelog": "v1.0.0 - Initial release",
                              

                              Then 'cloudron versions add' worked

                              Not suggesting anything needs fixing as such. But potential mismatch of usage. Simple text string is easier - but it won't be practical for complex changelog descriptions.

                              And this cheat works :

                               "changelog": "see CHANGELOG",
                              

                              Not sure I should be cheating, but ...

                              'cloudron versions add' seems to handle 'file://POSTINSTALL.md' but not 'file://CHANGELOG'

                              Being creative, I tried this, thinking POSTINSTALL.md worked with file name extension.

                              "changelog": "file://CHANGELOG.md",
                              

                              But it does not.
                              Seems like 'cloudron versions' treats the entries differently.

                              girishG Offline
                              girishG Offline
                              girish
                              Staff
                              wrote on last edited by girish
                              #18

                              @timconsidine I will fix the docs but the changelog file format file://CHANGELOG.md is:

                              [version]
                              * change 1
                              * change 2
                              

                              The CLI tool reads the changelog file from the above format and then populated manifest accordingly into the versions file.

                              1 Reply Last reply
                              2
                              • timconsidineT Offline
                                timconsidineT Offline
                                timconsidine
                                App Dev
                                wrote on last edited by timconsidine
                                #19

                                @girish
                                Ah, looking at output of 'cloudron versions add' in CloudronVersions.json, I see !

                                There is background processing/expectations, pulling only the changlog content for that version.

                                Neat ! But opaque pending docs clarification.

                                Still not sure how it will work in practice with long changelog entries, but good discipline and neat handling.

                                Indie app dev, scratching my itches, lover of Cloudron PaaS, communityapps.appx.uk

                                girishG 1 Reply Last reply
                                2
                                • timconsidineT timconsidine

                                  @girish
                                  Ah, looking at output of 'cloudron versions add' in CloudronVersions.json, I see !

                                  There is background processing/expectations, pulling only the changlog content for that version.

                                  Neat ! But opaque pending docs clarification.

                                  Still not sure how it will work in practice with long changelog entries, but good discipline and neat handling.

                                  girishG Offline
                                  girishG Offline
                                  girish
                                  Staff
                                  wrote on last edited by
                                  #20

                                  @timconsidine it's following the same format as our existing appstore apps. For example, one of our longtime packages - https://git.cloudron.io/packages/gitlab-app/-/blob/master/CHANGELOG?ref_type=heads

                                  1 Reply Last reply
                                  2
                                  • girishG Offline
                                    girishG Offline
                                    girish
                                    Staff
                                    wrote on last edited by
                                    #21

                                    OK, updated https://docs.cloudron.io/packaging/manifest/#changelog

                                    1 Reply Last reply
                                    2
                                    • timconsidineT Offline
                                      timconsidineT Offline
                                      timconsidine
                                      App Dev
                                      wrote on last edited by timconsidine
                                      #22

                                      There's a conundrum rattling in my head.

                                      • cloudron build prompts for a registry.
                                        so supplied a Cloudron-hosted registry
                                        and all works fine : builds, pushes, shown in registry list
                                      • cloudron versions add does its work
                                      • but cloudron-hosted registries do not support public pulls

                                      So test of installing community app fails.

                                      • am I doing something wrong ?
                                      • or effectively cloudron versions does not support cloudron-hosted registries ?
                                      • if so, this should be surfaced in docs
                                      • if so, is it time to consider support for public pulls in cloudron-hosted registry package ?

                                      Docs should also be clear that community app repo link should be open (publicly accessible), if it does not already do so.

                                      Indie app dev, scratching my itches, lover of Cloudron PaaS, communityapps.appx.uk

                                      jdaviescoatesJ 1 Reply Last reply
                                      1
                                      • girishG Offline
                                        girishG Offline
                                        girish
                                        Staff
                                        wrote on last edited by
                                        #23

                                        Right, the cloudron registry app can only host private packages. We can possibly look into adding support to make it a public registry as well, but afaik this is complicated. We need private push and public pulls - this is not implemented out of the box by the opensource registry project.

                                        1 Reply Last reply
                                        2
                                        • timconsidineT timconsidine

                                          There's a conundrum rattling in my head.

                                          • cloudron build prompts for a registry.
                                            so supplied a Cloudron-hosted registry
                                            and all works fine : builds, pushes, shown in registry list
                                          • cloudron versions add does its work
                                          • but cloudron-hosted registries do not support public pulls

                                          So test of installing community app fails.

                                          • am I doing something wrong ?
                                          • or effectively cloudron versions does not support cloudron-hosted registries ?
                                          • if so, this should be surfaced in docs
                                          • if so, is it time to consider support for public pulls in cloudron-hosted registry package ?

                                          Docs should also be clear that community app repo link should be open (publicly accessible), if it does not already do so.

                                          jdaviescoatesJ Offline
                                          jdaviescoatesJ Offline
                                          jdaviescoates
                                          wrote on last edited by
                                          #24

                                          I think this:

                                          @girish said:

                                          Right, the cloudron registry app can only host private packages. We can possibly look into adding support to make it a public registry as well, but afaik this is complicated. We need private push and public pulls - this is not implemented out of the box by the opensource registry project.

                                          Means this is correct:

                                          @timconsidine said:

                                          or effectively cloudron versions does not support cloudron-hosted registries ?

                                          Right?

                                          🙂

                                          I use Cloudron with Gandi & Hetzner

                                          girishG 1 Reply Last reply
                                          1

                                          Hello! It looks like you're interested in this conversation, but you don't have an account yet.

                                          Getting fed up of having to scroll through the same posts each visit? When you register for an account, you'll always come back to exactly where you were before, and choose to be notified of new replies (either via email, or push notification). You'll also be able to save bookmarks and upvote posts to show your appreciation to other community members.

                                          With your input, this post could be even better 💗

                                          Register Login
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Categories
                                          • Recent
                                          • Tags
                                          • Popular
                                          • Bookmarks
                                          • Search