<!doctype html>
<!--
  trentpower.fr · /integrity/

  static, semantic, self-managed, privacy-first.
  signed manifest, detached signature, public signing key.
  no analytics. no cookies. no external assets.

  every public file is hashed, signed,
  and listed at /integrity.json.
-->
<html lang="en-AU" dir="ltr">
<head>
  <!-- head · 01 · foundations -->
  <meta charset="utf-8">
  <meta name="viewport" content="width=device-width, initial-scale=1, viewport-fit=cover">
  <meta name="format-detection" content="telephone=no">
  <meta name="color-scheme" content="light dark">
  <meta name="theme-color" content="#E9E5DC">

  <!-- head · 02 · appearance bootstrap -->
  <script>(()=>{const e=document.documentElement;e.classList.add('js');try{const m=localStorage.getItem('tp-theme');if(m==='dark'||m==='light')e.dataset.theme=m}catch(_){}})();</script>

  <!-- head · 03 · document identity -->
  <title>Integrity · Trent Power</title>
  <meta name="description"
        content="Signed public releases, integrity manifest, detached signature and public signing key">
  <meta name="document-edition" content="2026-05-23">
  <link rel="canonical" href="https://trentpower.fr/en-au/integrity/">
  <link rel="alternate" hreflang="en-AU" href="https://trentpower.fr/en-au/integrity/">
  <link rel="alternate" hreflang="fr" href="https://trentpower.fr/fr/integrite/">
  <link rel="alternate" hreflang="x-default" href="https://trentpower.fr/">

  <!-- head · 04 · indexing and discovery -->
  <meta name="robots" content="noindex">
  <meta name="referrer" content="no-referrer">

  <!-- head · 05 · authorship and identity -->
  <meta name="author" content="Trent Power">
  <link rel="author" href="/.well-known/person.json">
  <link rel="alternate" type="application/ld+json" href="/.well-known/person.json">
  <link rel="alternate" type="text/plain" href="/llms.txt">
  <link rel="me" href="https://commons.wikimedia.org/wiki/File:Trent_Power_portrait.jpg">
  <link rel="me" href="https://www.linkedin.com/in/trentpower/">
  <link rel="me" href="https://orcid.org/0009-0002-2652-7188">
  <link rel="me" href="https://www.crunchbase.com/person/trent-power-3f52">

  <!-- head · 06 · provenance, rights and reuse -->
  <link rel="license" href="https://creativecommons.org/licenses/by-sa/4.0/">
  <link rel="describedby" href="/.well-known/attribution.txt">
  <link rel="describedby" href="/integrity.json">
  <link rel="cite-as" href="https://trentpower.fr/en-au/integrity/">
  <link rel="privacy-policy" href="https://trentpower.fr/en-au/privacy/">
  <link rel="help" href="https://trentpower.fr/en-au/security/">

  <!-- head · 07 · social and sharing -->
  <meta property="og:type" content="website">
  <meta property="og:site_name" content="Trent Power">
  <meta property="og:title" content="Integrity · Trent Power">
  <meta property="og:description" content="Signed public releases, integrity manifest, detached signature and public signing key">
  <meta property="og:url" content="https://trentpower.fr/en-au/integrity/">
  <meta property="og:locale" content="en_AU">
  <meta property="og:locale:alternate" content="fr_FR">
  <meta property="og:image" content="https://trentpower.fr/images/og/integrity-og.png">
  <meta property="og:image:width" content="1200">
  <meta property="og:image:height" content="630">
  <meta property="og:image:type" content="image/png">
  <meta property="og:image:alt" content="Integrity · Trent Power">

  <!-- head · 08 · application surface -->
  <meta name="application-name" content="Trent Power">
  <meta name="apple-mobile-web-app-title" content="Trent Power">
  <link rel="icon" href="/favicon.ico" sizes="any">
  <link rel="icon" href="/favicon.svg" type="image/svg+xml">
  <link rel="apple-touch-icon" href="/apple-touch-icon.png">
  <link rel="manifest" href="/manifest.webmanifest" type="application/manifest+json">

  <!-- head · 09 · rendering and assets -->
  <link rel="stylesheet" href="/styles.css?v=2026-05-23.d73a065e" integrity="sha384-jsLOFfd+NWjpdmWzZMcp+iz29oJdegRsgBRP+HM3Epzq72lclJkqgNDCKfSkEtEc">
  <link rel="stylesheet" href="/print.css?v=2026-05-23.d73a065e" media="print">

  <!-- head · 10 · structured data -->
  <script type="application/ld+json">
{
  "@context": "https://schema.org",
  "@type": "WebPage",
  "@id": "https://trentpower.fr/integrity/#page",
  "url": "https://trentpower.fr/en-au/integrity/",
  "name": "Integrity · Trent Power",
  "description": "Signed public releases, integrity manifest, detached signature and public signing key",
  "inLanguage": "en-AU",
  "isPartOf": {
    "@id": "https://trentpower.fr/#website"
  },
  "about": {
    "@id": "https://trentpower.fr/#trent-power"
  },
  "author": {
    "@id": "https://trentpower.fr/#trent-power"
  },
  "publisher": {
    "@id": "https://trentpower.fr/#trent-power"
  },
  "primaryImageOfPage": {
    "@type": "ImageObject",
    "url": "https://trentpower.fr/images/og/integrity-og.png",
    "width": 1200,
    "height": 630
  },
  "datePublished": "2026-02-15T00:00:00+00:00",
  "dateModified": "2026-05-23T00:00:00+00:00"
}
  </script>
</head>
<body data-page="integrity" data-layout="masthead" data-surface="record" data-masthead="brand-only" data-edition="2026-05-23" data-source-sha256-short="--------">

<a href="#main" class="skip-link">Skip to content</a>

<!-- body · masthead -->
<header class="site-header" data-component="site-header">
  <div class="nav">
    <div class="nav-inner">
      <a class="nav-mark u-author" href="/en-au/" aria-label="Trent Power home"><span>Trent</span> <span>Power</span></a>
    </div>
  </div>
</header>

<!-- body · primary content -->
<main class="site" id="main" tabindex="-1" itemscope itemtype="https://schema.org/WebPage">
  <div class="page">

    <!-- primary · 01 · statement -->
    <p class="page-kicker">Integrity</p>
    <h1 class="page-title hero-stack measure-tight"><span class="hero-line">Signed.</span><span class="hero-line">Verifiable.</span><span class="hero-line">Reproducible.</span></h1>
    <div class="page-body">
      <p class="page-lede">Every public file is hashed and listed in a manifest, signed with a detached <abbr title="Pretty Good Privacy">PGP</abbr> signature so each release can be checked against the publisher's key - independently, on your own machine, without trust in this server. You can <a href="/en-au/integrity/verify-locally/" aria-describedby="desc-verify-locally">verify locally here</a>.</p>
      <span class="visually-hidden" id="desc-verify-locally">Read the instructions to verify the publication locally with command-line tools</span>
      <span class="visually-hidden" id="desc-verify">Check the current page against the published integrity data</span>

      <!-- primary · 02 · current signed release -->
      <article class="integrity-record-card" aria-labelledby="integrity-record-title">
        <header class="integrity-record-header">
          <h2 class="integrity-record-title" id="integrity-record-title"><time datetime="2026-05">May 2026</time></h2>
          <p class="integrity-record-status">Manifest · Signature · Public key</p>
        </header>

        <section class="integrity-record-group" aria-labelledby="integrity-group-verification">
          <p class="integrity-record-group-label" id="integrity-group-verification">Verification records</p>
          <dl class="integrity-record-dl">
            <div class="integrity-rg">
              <dt class="integrity-rg-label">Manifest</dt>
              <dd class="integrity-rg-value">
                <a class="integrity-rg-link" href="/integrity.json" aria-describedby="desc-link-manifest"><code>/integrity.json</code></a>
                <span class="visually-hidden" id="desc-link-manifest">Download the signed integrity manifest (JSON listing every public file and its SHA-256)</span>
              </dd>
            </div>
            <div class="integrity-rg">
              <dt class="integrity-rg-label">Detached signature</dt>
              <dd class="integrity-rg-value">
                <a class="integrity-rg-link" href="/integrity.json.sig" aria-describedby="desc-link-signature"><code>/integrity.json.sig</code></a>
                <span class="visually-hidden" id="desc-link-signature">Download the detached PGP signature for the integrity manifest</span>
              </dd>
            </div>
            <div class="integrity-rg">
              <dt class="integrity-rg-label">Archive checksums</dt>
              <dd class="integrity-rg-value">
                <a class="integrity-rg-link" href="/integrity/releases/2026-05-23/SHA256SUMS" aria-describedby="desc-link-checksums"><code>/SHA256SUMS</code></a>
                <span class="visually-hidden" id="desc-link-checksums">Download the SHA-256 checksums for the signed release archives</span>
              </dd>
            </div>
            <div class="integrity-rg">
              <dt class="integrity-rg-label">Public key</dt>
              <dd class="integrity-rg-value">
                <a class="integrity-rg-link" href="/.well-known/pgp-key.asc" aria-describedby="desc-link-public-key"><code>/.well-known/pgp-key.asc</code></a>
                <span class="visually-hidden" id="desc-link-public-key">Download the public PGP key used to sign releases</span>
              </dd>
            </div>
          </dl>
        </section>

        <section class="integrity-record-group" aria-labelledby="integrity-group-archives">
          <p class="integrity-record-group-label" id="integrity-group-archives">Source archives</p>
          <p class="integrity-record-archives">
            <a class="integrity-rg-link" href="/integrity/releases/2026-05-23/trentpower-fr-2026-05-23.zip" title="trentpower-fr-2026-05-23.zip" aria-describedby="desc-link-zip">ZIP</a>
            <span class="visually-hidden" id="desc-link-zip">Download the source archive as a ZIP file</span>
            <span class="integrity-rg-sep" aria-hidden="true">·</span>
            <a class="integrity-rg-link" href="/integrity/releases/2026-05-23/trentpower-fr-2026-05-23.tar.gz" title="trentpower-fr-2026-05-23.tar.gz" aria-describedby="desc-link-targz">TAR.GZ</a>
            <span class="visually-hidden" id="desc-link-targz">Download the source archive as a TAR.GZ file</span>
          </p>
        </section>

        <section class="integrity-record-group integrity-record-group--fingerprint" aria-labelledby="integrity-group-fingerprint">
          <p class="integrity-record-group-label" id="integrity-group-fingerprint">Release fingerprint</p>
          <samp class="fingerprint-grid" id="pgp-fingerprint" tabindex="0" aria-label="Public key fingerprint">
            <span>A729 591B</span>
            <span>450D 3F59</span>
            <span>3694 98BD</span>
            <span>8299 1F25</span>
            <span>04AE 0263</span>
          </samp>
          <button type="button" class="integrity-record-action copy-fingerprint record-inline-action text-action"
                  data-copy-target="pgp-fingerprint"
                  data-copy-collapse="whitespace"
                  data-copy-feedback="Copied">Copy fingerprint</button>
        </section>
      </article>

    </div>
  </div>

</main>


<!-- body · footer -->
<footer class="site-footer" aria-label="Site footer">
  <div class="site-footer__inner">

    <!-- top stratum · identity · nav · language -->
    <div class="site-footer__top">

      <p class="site-footer__identity">
        <span class="year">&copy; <time datetime="2026">2026</time></span>
        <a class="wm" href="/en-au/" rel="home" aria-describedby="desc-home-footer"><bdi>Trent Power</bdi></a>
        <span class="visually-hidden" id="desc-home-footer">Return to the homepage</span>
      </p>

      <nav class="site-footer__nav" aria-label="Footer">
        <span>Paris, France</span>
        <span class="sep" aria-hidden="true">&middot;</span>
        <a class="site-footer__action" href="/en-au/privacy/" rel="privacy-policy" aria-describedby="desc-privacy">Privacy</a>
        <span class="visually-hidden" id="desc-privacy">Read how this site avoids analytics, cookies, profiling, tracking, and third-party assets</span>
        <span class="sep" aria-hidden="true">&middot;</span>
        <button type="button" class="site-footer__action"
                data-cite-open aria-haspopup="dialog"
                aria-describedby="desc-cite">Verify</button>
        <span class="visually-hidden" id="desc-cite">Open citation and verification details for this page</span>
      </nav>

      <ul class="site-footer__language" aria-label="Language">
        <li><a href="/en-au/integrity/"  aria-describedby="desc-lang-en" lang="en" aria-current="page">English</a> <span class="visually-hidden" id="desc-lang-en">Read this site in English</span></li>
        <li aria-hidden="true"><span class="sep">&middot;</span></li>
        <li><a href="/fr/integrite/" aria-describedby="desc-lang-fr" lang="fr">Français</a> <span class="visually-hidden" id="desc-lang-fr">Lire ce site en français</span></li>
      </ul>

    </div>

    <hr class="site-footer__break" aria-hidden="true">

    <!-- bottom stratum · colophon · theme -->
    <div class="site-footer__bottom">

      <ul class="site-footer__colophon" id="footerImprint" aria-label="Publication integrity">
        <li class="site-footer__colophon-row">
          <a class="site-footer__colophon-link" href="/en-au/integrity/" aria-describedby="desc-integrity"><span class="site-footer__colophon-key">Edition</span> <time datetime="2026-05-23">2026-05-23</time></a>
          <span class="site-footer__colophon-sep" aria-hidden="true">·</span>
          <span class="site-footer__colophon-note" data-edition-age>Published today</span>
          <span class="visually-hidden" id="desc-integrity">Open the public integrity record, including hashes, signatures, and release verification</span>
        </li>
      </ul>

      <ul class="site-footer__theme" aria-label="Appearance">
        <li><button type="button" data-theme="light"  aria-pressed="false" aria-describedby="desc-theme-light">Light</button> <span class="visually-hidden" id="desc-theme-light">Switch to the light appearance</span></li>
        <li aria-hidden="true"><span class="sep">&middot;</span></li>
        <li><button type="button" data-theme="system" aria-pressed="true"  aria-describedby="desc-theme-auto">Auto</button> <span class="visually-hidden" id="desc-theme-auto">Match the system appearance setting</span></li>
        <li aria-hidden="true"><span class="sep">&middot;</span></li>
        <li><button type="button" data-theme="dark"   aria-pressed="false" aria-describedby="desc-theme-dark">Dark</button> <span class="visually-hidden" id="desc-theme-dark">Switch to the dark appearance</span></li>
      </ul>

    </div>

  </div>
</footer>
<!-- body · print edition -->
<div class="print-trust-sheet print-only" data-print-sheet="integrity" hidden aria-hidden="true">
  <header class="print-trust-header">
    <p class="print-trust-kicker">Integrity</p>
    <p class="print-trust-title">Signed public verification</p>
    <p class="print-trust-lede">Published files are listed in a public manifest and signed with a detached <abbr title="Pretty Good Privacy">PGP</abbr> signature so updates can be verified independently.</p>
    <p class="print-trust-meta">Edition 2026-05-23 · trentpower.fr/integrity/</p>
  </header>

  <div class="print-trust-grid">
    <div class="print-trust-card">
      <p class="print-trust-label"><span class="num">01</span> <span>Manifest</span></p>
      <p class="print-trust-code"><code>/integrity.json</code> - <abbr title="Secure Hash Algorithm, 256-bit">SHA-256</abbr> hashes of every intentional public file.</p>
    </div>
    <div class="print-trust-card">
      <p class="print-trust-label"><span class="num">02</span> <span>Detached signature</span></p>
      <p class="print-trust-code">/integrity.json.sig - detached <abbr title="Pretty Good Privacy">PGP</abbr> signature that verifies the manifest.</p>
    </div>
    <div class="print-trust-card">
      <p class="print-trust-label"><span class="num">03</span> <span>Public key</span></p>
      <p class="print-trust-code">/.well-known/pgp-key.asc - fingerprint A729 591B 450D 3F59 3694 98BD 8299 1F25 04AE 0263.</p>
    </div>
    <div class="print-trust-card">
      <p class="print-trust-label"><span class="num">04</span> <span>Frozen releases</span></p>
      <p>/integrity/releases/ - public snapshots: February 2026 and May 2026.</p>
    </div>
    <div class="print-trust-card">
      <p class="print-trust-label"><span class="num">05</span> <span>Source route</span></p>
      <p>/source/ - public text view of selected source files. No secrets, no private artefacts.</p>
    </div>
    <div class="print-trust-card">
      <p class="print-trust-label"><span class="num">06</span> <span>Verification</span></p>
      <p class="print-trust-code">curl -O trentpower.fr/integrity.json &amp;&amp; curl -O trentpower.fr/integrity.json.sig &amp;&amp; gpg --verify integrity.json.sig integrity.json</p>
    </div>
  </div>

  <footer class="print-trust-footer">
    <div class="print-trust-footer-text">
      <p class="print-proof">Private · Static · Signed · No tracking</p>
      <p>Edition 2026-05-23 · trentpower.fr/integrity/</p>
    </div>
    <div class="print-qr-block" aria-hidden="true">
      <img class="print-qr-image" src="/images/qr/qr-integrity.svg" width="144" height="144" loading="lazy" decoding="async" alt="">
      <p class="print-qr-url">trentpower.fr/integrity/</p>
    </div>
  </footer>
</div>

<!-- scripts · progressive enhancement, no telemetry -->
<script src="/js/theme.js?v=2026-05-23.d73a065e" integrity="sha384-BoulfjXBzTzKZepcXtJ55HOBvZ6Z1vlJ2F1/oKeG0duSBmbq+8iuuNRBq9cOEtuS" defer></script>
<script src="/sw-register.js?v=2026-05-23.d73a065e" integrity="sha384-MP2//mwcEop223nSOjLo88jfXSPa31Eq/z1M55MMGtlxrYow4JwOcBY7y17k25Hj" defer></script>
<script src="/js/reveal.js?v=2026-05-23.d73a065e" integrity="sha384-gJrD72vW4itE2hwAmR5NxJ+cM2fYK9g539BMlbkVo1XCnRQB9/7lgK7NeueXVxtX" defer></script>
<script src="/js/overlay.js?v=2026-05-23.d73a065e" integrity="sha384-l+Vc3PNJDjvx8gi1aRUleJISQOkRCwQLPmHpkv8eqTuGrVwSBV5RPYHAmXLvOUar" defer></script>
<script src="/verify/verification-data.js?v=2026-05-23.d73a065e" defer></script>
<script src="/js/copy.js?v=2026-05-23.d73a065e" integrity="sha384-DdRZwwcGiuQPESkhWLaQFW0uVBQlUTAGClbjri9fGyp6+tNTK1InuNzZ7HoaCBXN" defer></script>
<script src="/js/edition.js?v=2026-05-23.d73a065e" integrity="sha384-cN14MAsjXYPB/8YCL5yCVDJyxu0gOn1VRtQgKd7IwewcZtx1X32yTpfoUzkiA1D+" defer></script>
<script src="/js/verify-modal.js?v=2026-05-23.d73a065e" integrity="sha384-Q0iI1qkIJDhbE2icuiPlRJ13yLrteYd8bSCbdetGS+wOcPAcmK466/lkI0G3OWqM" defer></script>
<script src="/js/fonts.js?v=2026-05-23.d73a065e" integrity="sha384-hqccZnNIbxh/tvycK1UR5+oe9gifY+gHe/QZiwKcEtJa3RWkSjMIUQhb3jZRfx01" defer></script>

</body>
</html>
