Skip to content
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

redirect http requests to https to satisfy Chrome #88

Open
mbutterick opened this issue Feb 8, 2019 · 22 comments
Open

redirect http requests to https to satisfy Chrome #88

mbutterick opened this issue Feb 8, 2019 · 22 comments

Comments

@mbutterick
Copy link
Collaborator

screen shot 2019-02-08 at feb 08 6 29 17 am

To be clear: this is Chrome idiocy. But as with much Chrome idiocy, it is often imputed back to the webmaster. https seems active on all Racket websites. But typing in racket-lang.org to a Chrome URL box still selects the http version by default, and produces the naughty-looking “not secure” warning. The fix is to redirect all http requests to https.

@samth
Copy link
Member

samth commented Feb 8, 2019

@mflatt and I were discussing this yesterday. For most everything (everything that's fronted by Cloudflare) we can just press a button and it ought to work, but we should perhaps decide when a good time to hit the button is.

@jackfirth
Copy link
Contributor

Out of curiosity, does this button enable a plain redirect or does it turn on HSTS?

@samth
Copy link
Member

samth commented Feb 8, 2019 via email

@jackfirth
Copy link
Contributor

Is the latter a feasible option? The former is (relatively) insecure.

@samth
Copy link
Member

samth commented Feb 11, 2019

The redirect is now implemented. There's still a http:// resource on school.racket-lang.org/2019 which is no longer the active page, but people may still be linked to it. Otherwise, Firefox shows everything working well on all the pages I've checked.

After checking that everything is working and that it won't take on too much risk, I'm going to enable HSTS as well.

@mbutterick
Copy link
Collaborator Author

mbutterick commented Feb 20, 2019

Is it possible this change had an unintended consequence with the catalog server? I’m now getting Travis build failures for Racket 6.0 that look like this:

Resolving "txexpr" via http://download.racket-lang.org/releases/6.0/catalog/
ssl-connect: connect failed (error:14077410:SSL routines:SSL23_GET_SERVER_HELLO:sslv3 alert 
handshake failure)

I wonder if the http link is becoming https, and then Racket 6.0 doesn’t know how to handle it?

But recently, the package-server infrastructure has been generally flaky, so this is only a guess.

@mbutterick
Copy link
Collaborator Author

@mflatt wrote

We’ve turned off HTTP->HTTPS for now. Part of the idea is to check whether that fixes the package server, as you have suggested.

My quick check suggests that yes, this does fix the package server (inasmuch as Travis CI builds against 6.0 now work normally)

Do you need v6.0 support, or would supporting/testing only v6.2 and later be ok?

If Racket Command decides that this is the path forward, it doesn’t bother me to drop support for pre-6.2. I’m merely trying to be a good citizen by not obsoleting older versions that I don’t have to. The CI builds are the only way I know whether the software still works on those older versions.

(I’m aware that I seem to be arguing both sides of the HTTPS issue. I didn’t know about this interplay.)

@samth
Copy link
Member

samth commented Feb 27, 2019

@jeapostrophe fixed pkgs.racket-lang.org today, so we've turned the redirect back on.

@mbutterick this will still break the ability of pre-6.2 Racket to contact download.racket-lang.org, which is the failure you saw. If people are concerned about this, we can consider trying to make this still work.

@abmclin
Copy link
Contributor

abmclin commented Feb 27, 2019

This may be the reason why raco pkg installation on my TrueOS FreeBSD system is now broken. I don't recall having this problem before. Whenever I try to install a package from the main catalog in Racket 7.2, the error says ssl-make-client-context: requested protocol not supported; SSL not available; check ssl-load-fail-reason

Analyzing the error by evaluating (require openssl) ssl-load-fail-reason I get ffi-lib: couldn't open "libcrypto.so" (Shared object "libcrypto.so" not found, required by "racket")

Checking my system, I see there's libcrypto.so.111 under /lib. I tried creating a symbolic link libcrypto.so pointing to the previously mentioned file but no luck. I'm not sure but possibly the error is arising from a difference between how dynamic libraries are searched for between Linux and BSD variants and this is only being exposed because of the switch to forced use of https.

@samth
Copy link
Member

samth commented Feb 27, 2019

Probably you need to add a new entry to this list: https://github.com/racket/racket/blob/master/racket/collects/openssl/libcrypto.rkt#L35

@samth samth reopened this Feb 27, 2019
@greghendershott
Copy link
Contributor

Can the package server force a redirect to https -- or not -- based on the value of the User-Agent header?

I'm guessing that raco supplies one with "Racket" in the value, or (perhaps in older Rackets) no User-Agent header at all.

@greghendershott
Copy link
Contributor

By the way, I have some packages where I am still trying to support Racket versions older than 6.2.

Why? Because I've had no reason to drop support. Travis CI helps me identify blatant problems like using procedures provided only in newer versions of Racket. If CI can no longer help with that (because older versions of raco can no longer install anything), I will need to drop < 6.2 support.

I wanted to point out that it's a consequence. I don't know if it's a particularly bad one.

@samth
Copy link
Member

samth commented Feb 27, 2019

Currently we're doing this at the Cloudflare CDN level, rather than on download.racket-lang.org. That doesn't make this easy, but it could be possible (although it would almost certainly cost some money). Alternatively we could do the redirect somewhere else, at the cost of some more work.

For pre-6.2 Racket, it would no longer be possible to install any packages via the package catalog with this change, so you'd have to drop support regardless.

If anyone actually wants to support pre-6.2 Racket, or even more significantly wants to use pre-6.2 Racket, then saying that would be helpful.

@greghendershott
Copy link
Contributor

Do you have stats for URLs like http://download.racket-lang.org/releases/6.0/catalog/? It won't be zero if only because of CI scripts. 😄. But it might be tiny enough.

@samth
Copy link
Member

samth commented Feb 27, 2019

I don't immediately have the logs for that machine, but I'll see what I can find.

@abmclin
Copy link
Contributor

abmclin commented Feb 28, 2019

After some experimenting and reading up on the expected conventions regarding shared libraries on *nix platforms. The convention is to have a libcrypto.so symbolic link to the latest version of libcrypto.so.xxx on the platform. It's not absolutely required since typically programs link to the specific version of shared library they want. It makes sense for racket to use versionless as first choice to ensure maximum portability.

In any event, I'm able to resolve the problem simply by adding the missing symbolic link by installing the development package version which will automatically configure the links.

I don't think any changes are necessary in libcrypto.rkt.

@samth
Copy link
Member

samth commented Feb 28, 2019

Well, it shouldn't be necessary to install the development package for Racket to work. If you add "111" to that list, does that fix the problem?

@abmclin
Copy link
Contributor

abmclin commented Feb 28, 2019

Adding 111 to the list does fix the problem, shall I open a pull request with the new list entry?

Aside, the resolution of the libcrypto.so problem exposed an entirely new problem that is not related to the previous one as far as I can tell. I will move discussion of the new problem elsewhere.

@samth
Copy link
Member

samth commented Feb 28, 2019

Yes, a PR for that would be great. I wish that there was something that would just make this work in general, but we haven't found it yet.

mbutterick referenced this issue in greghendershott/markdown Mar 3, 2019
- Fewer details in .travis.yml.
- Use generic Makefile.
- Put some details in info.rkt files.

Also, move markdown.scrbl up from pointless "docs" subdir.
greghendershott pushed a commit to greghendershott/markdown that referenced this issue Mar 8, 2019
- Drop support for Racket before 6.2 as it is no longer testable.
  See <racket/racket-lang-org#88>

- Depend on threading-lib not rackjure. All we were using from
  rackjure was `~>` and `str`. We can get former directly from
  threading-lib, and latter is just `~a`.

- Add newer Racket versions 7.1 and 7.2.

- Bump our version to 0.26.
greghendershott pushed a commit to greghendershott/markdown that referenced this issue Mar 8, 2019
- Drop support for Rackets < 6.2 because they are no longer testable
  -- see <racket/racket-lang-org#88>.

- Now that we require 6.2, our info.rkt can use `#lang info` instead
  of `#lang setup/infotab`.

- Depend on threading-lib not rackjure. All we were using from
  rackjure was `~>` and `str`. We can get former directly from
  threading-lib, and latter is just `~a`.

- Add newer Racket versions 7.1 and 7.2.

- Bump our version to 0.26.
greghendershott pushed a commit to greghendershott/rackjure that referenced this issue Mar 8, 2019
- Drop support for Rackets < 6.2 because they are no longer testable
  -- see <racket/racket-lang-org#88>.

- Now that we require 6.2, our info.rkt can use `#lang info` instead
  of `#lang setup/infotab`.

- Add newer Racket versions 7.0, 7.1, and 7.2.

- Bump our version to 0.10.
greghendershott pushed a commit to greghendershott/frog that referenced this issue Mar 8, 2019
- Drop support for Rackets < 6.2 because they are no longer testable
  -- see <racket/racket-lang-org#88>.

- Add newer Racket version 7.2.

- Bump our version to 0.30.
greghendershott pushed a commit to greghendershott/racket-mode that referenced this issue Mar 8, 2019
- Drop support for Rackets < 6.2 because they are no longer testable
  -- see <racket/racket-lang-org#88>.

- Add newer Racket version 7.2.
greghendershott pushed a commit to greghendershott/aws that referenced this issue Mar 8, 2019
- Drop support for Rackets < 6.2 because they are no longer testable
  -- see <racket/racket-lang-org#88>.

- Now that we require 6.2, our info.rkt can use `#lang info` instead
  of `#lang setup/infotab`.

- Add newer Racket versions 7.0, 7.1, and 7.2.

- Bump our version to 1.13.
greghendershott pushed a commit to greghendershott/http that referenced this issue Mar 8, 2019
- Drop support for Rackets < 6.2 because they are no longer testable
  -- see <racket/racket-lang-org#88>.

- Now that we require 6.2, our info.rkt can use `#lang info` instead
  of `#lang setup/infotab`.

- Add newer Racket versions 6.10 through 7.2.

- Bump our version to 0.4.
@jarcane
Copy link

jarcane commented Apr 8, 2019

I was hoping to maintain support for 6.0.1 in Heresy, because I just got a retro iBook and 6.0.1 was the last version built for PowerPC. 😞

Unfortunately, we depend on rackjure so I guess that's a no go unless I can find a way to replace that dependency. I'll have to see what I'm using.

@samth
Copy link
Member

samth commented Apr 8, 2019

@jarcane Is the issue just about pre-built binaries? Could you compile 6.2 yourself?

@jarcane
Copy link

jarcane commented Apr 8, 2019

I honestly don't know. I will have to try; might be a few days before I can get to it though.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

6 participants