Serve URL relative per le immagini caricate

How can I get Discourse to generate relative URLs for uploaded images?

I have a site that is available over HTTPS and a TOR .onion and I need a way to get images working for both.

How can I configure Discourse so that upload:// URLs are converted to relative URLs in the <img> tag? Where (which source file) does this URL generation take place?

I don’t think relative image URLs is a supported configuration, and that might be a very difficult change cc @sam

1 Mi Piace

Just to clarify:

Uploading works correctly both from the HTTPS domain and the TOR hidden service .onion but the actual HTML generated for a post uses a full URL which is a problem.

I’m assuming somewhere there is some code that does something like

 '<img src="' + Discourse.base_url_no_prefix + '/uploads/....jpg' + '">'

and I need it to generate

 '<img src="' + '/uploads/....jpg' + '">'

Would playing with absolute_without_cdn be too low-level and affect too many things?

The URL needs to be relative because:

  • A normal browser cannot access the .onion URL.
  • Cannot access the normal site over TOR because it is behind DDoS protection. And even if it worked, I don’t want to leak details to TOR exit nodes.
1 Mi Piace

This would require some internal changes, I am somewhat sympathetic cause it makes life a bit easier when changing domain names for sites that do not use A CDN.

Would have to be something like, IF no CDN configured then cook a relative url.

3 Mi Piace

I assume you only need to set this up when the configuration is changed?

Imagine having

'<img src="' + Discourse.cdn_url_no_prefix + '/uploads/....jpg' + '">'

When there is no CDN configured then Discourse.cdn_url_no_prefix can simply be a empty string.

Does that mean that there is a chance you can implement this in the (near) future?

Just to add a voice and to agree with @sam, we’ve already had some switcheroos with our domains and relative URLs is most certainly needed.

Vorrei aggiungere la mia voce a favore dei collegamenti interni relativi. Attualmente uso URL completi per fare riferimento, ad esempio, a un altro argomento sullo stesso sito.

Infatti, il nostro sito ha recentemente cambiato dominio (segnalando che la reindirizzazione è attualmente attiva):

E il nostro nuovo host, Communiteq (precedentemente DiscourseHosting), ha gentilmente in qualche modo sedato il nostro database per riflettere questo cambiamento.

Forse ci sono motivi tecnici per lo stato attuale? Forse in futuro potremmo usare qualcosa come %{THIS}/t/000? Come sviluppatore, i percorsi assoluti mi rendono solitamente nervoso. C’è anche la questione del passaggio da http: a https:, che abbiamo anche intrapreso (o almeno applicato in modo più rigoroso) come parte della suddetta migrazione. Questo sembra molto simile al caso d’uso di @mreach

Come sempre, molti ringraziamenti al team di Discourse per un prodotto meraviglioso. R.

1 Mi Piace

Di solito non è un grosso problema eseguire una ricerca e sostituzione mirata su tutti i post interessati quando cambia il dominio.

1 Mi Piace