Application Files after Digital Ocean Setup

We successfully installed Discourse on Digital Ocean, everything works well, but we can’t for the life of us find where the actual discourse files are. We wanted to test some modifications and build some plugins, but we can’t find any files. We used Filezilla to log into the site. However, we can’t actually find any of the Discourse application files anywhere, e.g. discourse/app. We went into the var/discourse folder and nothing. Then var/discourse/containers and nothing. We did SSH .launcher enter app, and we can see our files in the terminal are located in var/www, but this directly doesn’t exist when we log into the server. We tried var/lib/docker/containers and nothing. Where exactly are the discourse files located? Thanks.

1 Like

That is how Docker works, the actual files are inside a Docker container, and therefore “invisible” using Filezilla.

If you want to test modifications to Discourse, like plugins and themes, you won’t be able to do it in a production install.

For themes check Beginner's guide to using Discourse themes

For plugins Beginner's Guide to Creating Discourse Plugins - Part 1

1 Like

Is there another way to install this other than using docker then? I have read all the guides, but it’s kind of difficult to develop with invisible files.

1 Like

The paradigm is very different from the 90’s PHP applications, where it was normal to edit files in production servers using FTP.

Changes to Discourse behavior are supposed to be separate projects, living in a git repository of their own, and to make use of the existing plugin and theme APIs.

So let’s say you want to add an extra field to the topic composer where a user will add their preferred color. You will create a new Discourse plugin following Beginner's Guide to Creating Discourse Plugins - Part 1, then put that on GitHub in a repository named discourse-favorite-color and install that to your instance using Install Plugins in Discourse

3 Likes

OK, got it. Will have to get used to this new way to develop. Just curious, every time we add a plugin we need to ./launcher rebuild app? And then do that again when modify the plugin?

1 Like

Yes.

However, that is something that should happen infrequently, as that is your production install.

For development and test purposes, the very first part of Beginner's Guide to Creating Discourse Plugins - Part 1 tells you to setup a “Development Environment” where you can do changes and test just refreshing your browser.

1 Like

That’s what I do, though you can also do an upgrade via the web interface at /admin/upgrade.

Also, a 2-container install lets you upgrade like

./launcher bootstrap web_only
./launcher destroy web_only; ./launcher start web_only

so your site is down just as long as it takes the new server to boot up (about a minute).

2 Likes