Skip to content

Instantly share code, notes, and snippets.

Setup

$ docker build -f python3.7.Dockerfile -t sddp-350-py3.7 .
$ docker build -f python3.9.Dockerfile -t sddp-350-py3.9 .

Expected results

| Command | Python | Result

Gist file Target file
rc.local sys-net:/rw/config/rc.local
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8" />
<meta http-equiv="x-ua-compatible" content="IE=edge">
<meta name="referrer" content="no-referrer" />
<meta name="generator" content="diffoscope" />
<link rel="icon" type="image/png" href="
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
@cfm
cfm / commentary.md
Last active April 27, 2022 19:43
[DRAFT] SecureDrop Client: grand unified state machine

[DRAFT] SecureDrop Client: grand unified state machine

Goal: To able to reason about the SecureDrop Client as a single application-level state machine, in which each global state is composed of (in order from left to right):

  1. an authentication state or state machine;
  2. a synchronization state or state machine; and
  3. a job-queue state or state machine.

Notes:

  • This diagram is both descriptive and prescriptive. It describes what I read the SecureDrop Client codebase and supporting specifications as wanting to do. It prescribes (or implies) some changes that might help realize those design intentions. (And, inevitably, it makes some assumptions that may no longer hold or serve us.)
  • Refer to the Mermaid state-diagram syntax if you have questions about how to read this diagram.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8" />
<meta http-equiv="x-ua-compatible" content="IE=edge">
<meta name="referrer" content="no-referrer" />
<meta name="generator" content="diffoscope" />
<link rel="icon" type="image/png" href="

How to think about translation workflows: a refresher

Any translation workflow we adopt must implement the following stages:

  1. extraction of source strings from Python code (securedrop_client/**/*.py) to the catalog template (securedrop/locale/messages.pot);
  2. merging of the source strings from the template into each locale's translation catalog (securedrop/locale/*/LC_MESSAGES/messages.po); and
  3. compilation of each locale's translation catalog from portable-object format (.po) to the machine-object format (.mo) loaded at runtime.

The following table summarizes the approaches we've considered to date: