pootriarch

joined 2 years ago
MODERATOR OF

Prerequisites

  • Internet-facing web server with reverse proxy and domain name (preferably SSL of course)
  • Server behind the reverse proxy with Rust environment

Installation

  • Don't bother downloading the source code to your server; installing it that way gives you a big debug executable
  • Instead just cargo install mollysocket
  • Move the mollysocket executable if desired
  • Run mollysocket once so that it will emit the default config

Configuration

  • Fish the config file out of .config/mollysocket/default-config.toml and copy it somewhere.

config.toml

  • In the new file, replace the allowed_endpoints line with allowed_endpoints = ['*']. The default 0.0.0.0 config appears to be a bug; this setting controls access to endpoints within the app, not IPs from outside. Leaving the original value causes mollysocket to reject everything.
  • Put a proper path in the db = './mollysocket.db' line rather than just having it land wherever you're sitting.
  • Delete the mollysocket.db that was created on first run (even if it's already where you're intending to put it). This is just to make sure the web server creates it and has the correct permissions.

Run script

  • The environment variable ROCKET_PORT must be set or the server will sit and do nothing. It's best to create all of the environment variables mentioned in the README, whether that is in a user profile script or in a shell script that wraps startup. You can change any of these values, but they must exist.
  • export ROCKET_PORT=8020
    export RUST_LOG=info
    export MOLLY_CONF=/path/to/your/config.toml
    

Proxy server

  • You'll need to proxy everything from / to your mollysocket server and ROCKET_PORT.
  • Exclude anything that you may need served from your web server, such as .well-known.

Things to know

you probably already found this, but for others who might be curious:

https://molly.im/

https://github.com/mollyim/mollyim-android

in the settings if you change notification method from websocket to unified push, the UP settings come up, including a server address (which is what they intend to be used) or some air gap mode that i can't find documented

 

The Molly fork of Signal now has a variant that supports UnifiedPush, but it requires a helper called Mollysocket to be installed on a server somewhere. I can't get my head around the (we'll call them 'lean') docs, and I've never encountered such a helper for other UP apps. They just ask what to attach to, and they attach.

Has anyone fought through this?

[–] pootriarch@poptalk.scrubbles.tech 3 points 1 year ago (1 children)

i'm shopping for mp3 players for precisely this reason - a friend has an ipod touch that abruptly stopped scrobbling. the last.fm app is stuck in a loop sucking battery. and she needs bluetooth anyway. she has always kept music and phone separate but now we have to ask the five whys on that before getting her a new unfamiliar gadget.

again not foss so won't dwell at length — but i use fund manager from beiley software. commercial, but works double-entry and handles more investment complexity than a human could ever need. windows app, i run it under wine on linux and crossover on mac. (i don't own a windows box — that's how irreplaceable it was for me.)

 

A few updates ago Pop started nagging me to accept firmware updates. My layman's reading of the release notes is that it's a Microsoft package that can block boot based on an ever-increasing number of packages they don't like.

Is it safe to take an update like this? Unlike a kernel change, I don't know how to recover if this goes wrong.

so per wikipedia and confirmed at MDN, firefox is the only major browser line not to consider certificate transparency at all. and yet it's the only one that has given me occasional maddening SSL errors that have blocked site access (not always little sites, it's happened with amazon).

i don't understand how firefox can be simultaneously the least picky about certificates and the most likely to spuriously decide they're invalid.

well i feel stupid now for not doing the obvious. but…

Blocked Page

Your organization has blocked access to this page or website.

on the PPA box, this is what it showed me (meanwhile it was attempting to connect to incoming.telemetry.mozilla.org). another symptom of displaying respect for enterprise policies but in fact ignoring them. (as i had mentioned, on this box all of the settings look locked down as they should be, but it's still attempting to send telemetry.)

thanks, i'll look again. it's not that i love the idea of being fingerprinted; i just think that five mylar bags, four tin hats and a partridge in a pear tree won't save me from that. i need my password manager, and once that's in, enforcing a generic screen is silly - cow's out of the barn. but not having the arms race against pocket and telemetry would be a big bonus.

[–] pootriarch@poptalk.scrubbles.tech 6 points 1 year ago (4 children)

i did try that but the never-dark mode blinded me. i understand the reasoning, but absolute anonymity isn't my own threat model; i'd like to be able to use themes and resize the window

an interesting oddity: on my non-rooted xperia, signal thinks that i don't have play services and so it falls back to… polling. every five minutes. killing my battery and my logs.

i had to put signal into the restricted battery group, which means no notifications. i anxiously await the new molly, as i already have a unified push environment. it looks like the migration will be a bit delicate.

 

Since the integrity environment gunk, I've switched all boxes over to use Firefox as primary. This took a lot of configuring, as Firefox out of the box brings… a lot of stuff I don't want.

One of those things is telemetry — whatever that means to Mozilla — that was tamed only with a combination of an enterprise profile (hi sudo!) and user.js hacks.

However, the policy and user.js changes don't work on the Ubuntu box, where I've installed Firefox from the PPA to get it out from under Snap (and thereby usable with a password manager). The policy locks down and disables the right configs and the configs all have the right settings, but it keeps pinging incoming.telemetry.mozilla.org. Two Macs and a Pop!_OS box don't ping Mozilla at all with these settings.

No harm no foul, I just blocked them in NextDNS and laugh in their general direction. I just wonder what else is different in the PPA.

[–] pootriarch@poptalk.scrubbles.tech 4 points 1 year ago (2 children)

neo store refuses to run if you don't grant it the right to send notifications and bypass battery optimizations. if an app demands a permission and doesn't have a plausible explanation why it needs it, i don't keep it :/

 

In SF we have some really long bus lines, 6 miles long and a ton of stops. One of those lines has a part-time extension now - it runs to an underserved overground rail station. It's a very high-value extension but runs only on weekdays, not weekends.

Normally we have separate relations for the weekday route and the weekend route. But others built those routes. I help maintain the ones we have, but I can't think of any way to get iD to clone a relation.

Is anyone either in SF and wants to clone the 31-Balboa, or knows of a tool that can do this? I've looked at JOSM and simply couldn't figure it out. I'm happy to do the grunt work of extending the line; I just have no good starting point.

 

i've tried grocy a few times over and it's burned a lot of time and brain cells. is there anything that does this (or even much less than this) and just works?

i understand why it was made this complex - i code and i work with people who want everything to be so theoretically 'flexible' that nothing simple works, so i'm used to the abstraction layers. but

  • first try: looked at number and size of packages, no tree-shaking, code doesn't pass sniff test. dozens of megabyes for this? nope
  • second try: well i don't want to build this myself. i'll put it in its own instance to minimize security exposure. but hey, this release is months old and these terrible bugs have been fixed, i'll just grab newer code. missed the thing where database migrations are tested only from official releases. database breaks.
  • i learn sqlite syntax and reconstruct the database.
  • months later i download new grocy android client, which expects a v4 grocy back end. all recipes break.
  • i download official grocy v4 release (the third one in rapid succession, due to major bugs - luckily i hadn't tried too early).
  • database breaks.

i'm done. i don't care that i lose the work i already put into it. i just want to open the cupboard twice and have the same thing be there both times. help

view more: next ›