Hi,

I’ve been trying to host my own lemmy instance for a while. i’ve almost got it working (i think). But my problem now is that whenever i try to post something with a picture i get an error SyntaxError: JSON.parse: unexpected character at line 1 column 1 of the JSON data. In firefox i get a 502 bad gateway error pointing to https://lemmy.emphisia.nl/pictrs/image I don’t really know why because everything seems to be working

  • youpie_temp@reddthat.comOP
    link
    fedilink
    arrow-up
    0
    ·
    1 year ago

    it does appear to be in its own network (according to portainer) the error log in the lemmy container is

    2023-07-23T13:58:44.850844Z  WARN lemmy_server::root_span_builder: Request error: error sending request for url (http://127.0.0.1:8080/image): error trying to connect: tcp connect error: Connection refused (os error 111)
    
    Reqwest(reqwest::Error { kind: Request, url: Url { scheme: "http", cannot_be_a_base: false, username: "", password: None, host: Some(Ipv4(127.0.0.1)), port: Some(8080), path: "/image", query: None, fragment: None }, source: hyper::Error(Connect, ConnectError("tcp connect error", Os { code: 111, kind: ConnectionRefused, message: "Connection refused" })) })
    

    no errors appear when i look at the pictrs log. I don’t know why it says password: None as i’ve set a password

    • poVoq@slrpnk.net
      link
      fedilink
      arrow-up
      1
      ·
      1 year ago

      Hmm not sure. The api-key ENV variable changed with pict-rs 0.4 to PICTRS__SERVER__API_KEY, maybe double-check that this is correctly updated and also the same as in your lemmy.hjson config file.

      • youpie_temp@reddthat.comOP
        link
        fedilink
        arrow-up
        1
        ·
        1 year ago

        PICTRS__SERVER__API_KEY

        the config in docker compose looks like

          pictrs:
            image: asonix/pictrs:0.4.0
            # this needs to match the pictrs url in lemmy.hjson
            hostname: 127.0.0.1
            # we can set options to pictrs like this, here we set max. image size and forced format for conversion
            # entrypoint: /sbin/tini -- /usr/local/bin/pict-rs -p /mnt -m 4 --image-format webp
            environment:
              - PICTRS_OPENTELEMETRY_URL=http://otel:4137
              - PICTRS__SERVER__API_KEY=****
              - RUST_LOG=debug
              - RUST_BACKTRACE=full
              - PICTRS__MEDIA__VIDEO_CODEC=vp9
              - PICTRS__MEDIA__GIF__MAX_WIDTH=256
              - PICTRS__MEDIA__GIF__MAX_HEIGHT=256
              - PICTRS__MEDIA__GIF__MAX_AREA=65536
              - PICTRS__MEDIA__GIF__MAX_FRAME_COUNT=400
            user: 991:991
        

        and in the config it is

          pictrs: {
            url: "http://127.0.0.1:8080/"
            api_key: "****"
          }
        

        the password on both is the same so i don’t see what is going wrong :(

        • MangoPenguin
          link
          fedilink
          English
          arrow-up
          1
          ·
          1 year ago

          I haven’t done this setup myself, but the hostname being 127.0.0.1 is suspect, especially since it mentions a pictrs URL config in lemmy.

          • youpie_temp@reddthat.comOP
            link
            fedilink
            English
            arrow-up
            1
            ·
            1 year ago

            yeah i changed that because i was testing. but i now realize that was dumb. ive change both the hostname and the url to pictrs. OMG that just worked… i feel so dumb rn. it is strange tho because that wasnt working before. Thanks for all the help :)

          • youpie_temp@reddthat.comOP
            link
            fedilink
            arrow-up
            1
            ·
            edit-2
            1 year ago

            hmm after looking i dont even see an option to change the port (in pictrs). it seems stuck at 8080, but since its running on its own network, i doubt it would matter.