send: sending in your work
B4 supports sending your series either via your own SMTP-compliant mail server, or via a web submission endpoint.
Upsides of using your own mail server:
it’s part of decentralized infrastructure not dependent on a single point of failure
it adds domain-level attestation to your messages via DKIM signatures
it avoids the need to rewrite the From: headers in patches, which is required for email delivery that originates at a different domain
However, using your own mail server may not always be a valid option:
your provider may not offer an SMTP-compliant endpoint for sending mail; for example it may only provide a webmail/exchange interface
there may be limits on the number of messages you can send through your mail server in a short period of time, which makes it hard to send large patch series
your company mail server may modify the message bodies by adding huge legal disclaimers to all outgoing mail
The web submission endpoint helps with such cases, plus offers several other upsides:
the endpoint writes all messages to a public-inbox feed and makes them immediately available for others to follow and query
all patches are end-to-end attested with the developer signature
messages are less likely to get lost or delayed by mail relays
Note
Even if you opt to use the web submission endpoint, you still need a valid email account for participating in decentralized development – it’s required for taking part in discussions and for sending and receiving code review feedback.
Authenticating with the web submission endpoint
Before you start, you need to configure your attestation mechanism. If you already have a PGP key configured for use with git, you can just use that and skip the next section. If you don’t already have a PGP key, you can create a separate ed25519 key just for web submission purposes.
Creating a new ed25519 key
Note
Creating a new ed25519 key isn’t required if you already have a PGP
key configured with git using the user.signingKey
git-config
setting.
Installing b4 should have already pulled in the patatt patch attestation library. You can use the command line tool to create your ed25519 key:
$ patatt genkey
Generating a new ed25519 keypair
Wrote: /home/user/.local/share/patatt/private/20220915.key
Wrote: /home/user/.local/share/patatt/public/20220915.pub
Wrote: /home/user/.local/share/patatt/public/ed25519/example.org/alice.developer/20220915
Add the following to your .git/config (or global ~/.gitconfig):
---
[patatt]
signingkey = ed25519:20220915
selector = 20220915
---
Next, communicate the contents of the following file to the
repository keyring maintainers for inclusion into the project:
/home/user/.local/share/patatt/public/20220915.pub
Copy the [patatt]
section and add it to your ~/.gitconfig
or to
your .git/config
in the repository that you want to enable for b4
send
.
Configuring the web endpoint
Which web endpoint to use is going to be dependent on the project. For
the Linux kernel and associated tools (like Git, B4, patatt, etc), you
can use the kernel.org endpoint by adding the following to your
~/.gitconfig
:
[b4]
send-endpoint-web = https://lkml.kernel.org/_b4_submit
Note
You can only use the kernel.org endpoint for kernel.org-hosted projects. If there are no recognized mailing lists in the to/cc headers, the endpoint refuses to accept the submission.
After updating your git configuration file, you can request authentication, as in the example below:
$ b4 send --web-auth-new
Will submit a new email authorization request to:
Endpoint: https://lkml.kernel.org/_b4_submit
Name: Alice Developer
Identity: alice.developer@example.org
Selector: 20220915
Pubkey: ed25519:ABCDE1lNXHvHOTuHV+Cf1eK9SuRNZZYrQmcJ44IkE8Q=
---
Press Enter to confirm or Ctrl-C to abort
Submitting new auth request to https://lkml.kernel.org/_b4_submit
---
Challenge generated and sent to alice.developer@example.org
Once you receive it, run b4 send --web-auth-verify [challenge-string]
As the instructions say, you should receive a verification email to the
address you specified in your user.email
. Once you have received it,
run the verification command by copy-pasting the confirmation string
from the message:
$ b4 send --web-auth-verify abcd9b34-2ecf-4d25-946a-0631c414227e
Signing challenge
Submitting verification to https://lkml.kernel.org/_b4_submit
---
Challenge successfully verified for alice.developer@example.org
You may now use this endpoint for submitting patches.
You should now be able to send patches via this web submission endpoint.
Using your own SMTP server
If there is a sendmail
section in your git configuration, B4 tries
to use that by default instead of going via the web endpoint. At this
time, b4 only recognizes a subset of sendmail
options supported by
git itself. The vast majority of servers should only need the following
settings:
[sendemail]
smtpServer = smtp.example.org
smtpServerPort = 465
smtpEncryption = ssl
smtpUser = alice.developer@example.org
smtpPass = [omitted]
You can also set up msmtp
or a similar tool and specify the path to
the sendmail
-compliant binary as the value for smtpServer
. To
force B4 to use the web endpoint even when a sendmail
option is
present, use the --use-web-endpoint
switch.
Sending your patches
Once your web endpoint or SMTP server is configured, you can start sending your work.
Note
At this time, the endpoint only accepts the series prepared with b4
prep
, but future versions may support sending arbitrary patches
generated with git format-patch
.
Passing pre-flight checks (v0.14+)
B4 defines some pre-flight checks that should be passing, or the command generates a warning:
needs-editing
: there is an “EDITME” string in the patches generated, which usually indicates that the cover letter needs to be edited withb4 prep --edit-cover
needs-checking
: you need to runb4 prep --check
to make sure that there are no common errors in your submissionneeds-checking-deps
: your series defines dependencies, and you need to runb4 prep --check-deps
to verify that they are valid (see prep: preparing your patch series)needs-auto-to-cc
: you need to runb4 prep --auto-to-cc
to populate the list of addresses that should receive your patch series
If you find that some of these pre-flight checks aren’t relevant to you,
you can either turn them all off, or only the ones that you don’t like.
To do so, use the prep-pre-flight-checks
configuration option, for
example:
[b4]
prep-pre-flight-checks = disable-all
or:
[b4]
prep-pre-flight-checks = disable-needs-auto-to-cc, disable-needs-checking
B4 automatically recognizes when your commits have changed and triggers the pre-flight checks warning when it thinks that you should re-run them.
Checking things over with -o
Before you send things out, it’s a good idea to verify that everything
is looking good by running the send command with -o somedir
, e.g.:
b4 send -o /tmp/presend
This generates the messages and writes them out into the directory provided, giving you a way to verify that everything is looking as it should before sending.
Checking things over with --reflect
One final test you can do before you submit your series is to send everything to yourself. This is especially useful when using the web endpoint, because this allows you to see what the messages are going to look like after being potentially post-processed on the remote end.
When --reflect
is on:
b4 still populates the To:/Cc: headers with all the addresses, because this allows to identify any encoding problems
b4 only sends the series to the address in the From: field
when using the web endpoint, the messages aren’t added to the public-inbox feed
your branch is not automatically rerolled to the next revision
Checking things over with --preview-to
(v0.13+)
Sometimes you want to ask your friend, colleague, boss, or mentor to
give your submission a quick review. You can send them your series using
--preview-to boss@example.com
before you send things out to the
actual maintainers.
When --preview-to
is on:
b4 only sends to the addresses you specify on the command line
your branch is not automatically rerolled to the next revision
(NB: the web submission endpoint can’t currently be used with this feature.)
What happens after you send
The following happens after you send your patches:
b4 automatically creates a detached head containing the commits from your sent series and tags it with the contents of the cover letter; this creates a historical record of your submission, as well as adds a way to easily resend a previously sent series, should you decide to do so in the future
b4 rerolls your series to the next version, so that a
v1
of the series becomesv2
, etcb4 automatically edits the cover letter to add changelog entries containing a pre-populated link to the just-sent series
Resending your series
If something went wrong, or if you need to resend the series because
nobody paid attention to it the first time, it’s easy to do this with
--resend vN
. B4 automatically generates the series from the tagged
historical version created during the previous sending attempt and sends
it out.
Command line flags
-d, --dry-run
Don’t send any mail, just output the raw pre-rendered messages. Normally, this is a wall of text, so you’d want to use
-o
instead.-o OUTPUT_DIR, --output-dir OUTPUT_DIR
Prepares everything for sending, but writes out the messages into the folder specified instead. This is usually a good last step before actually sending things out and lets you verify that all patches are looking good and all recipients are correctly set.
--preview-to
(v0.13+)Sometimes it’s useful to send your series for a pre-review to a colleague, mentor, boss, etc. Using this option sends out the prepared patches to the addresses specified on the command line, but doesn’t reroll your series, allowing you to send the actual submission at some later point.
--reflect
(v0.11+)Prepares everything for sending, but only emails yourself (the address in the
From:
header). Useful as a last step to make sure that everything is looking good, and especially useful when using the web endpoint, because it may rewrite your From: header for DMARC reasons.--no-trailer-to-cc
Tells b4 not to add any addresses found in the cover or patch trailers to To: or Cc:. This is usually handy for testing purposes, in case you want to send a set of patches to a test address (also see
--reflect
).--to
Additional email addresses to include into the To: header. Separate multiple entries with a comma. You can also set this in the configuration file using the
b4.send-series-to
option (see Contributor-oriented settings).--cc
Additional email addresses to include into the Cc: header. Separate multiple entries with a comma. You can also set this in the configuration file using the
b4.send-series-cc
option (see Contributor-oriented settings).--not-me-too
Removes your own email address from the recipients.
--no-sign
Don’t sign your patches with your configured attestation mechanism. Note, that sending via the web submission endpoint requires cryptographic signatures at all times, so this is only a valid option to use with
-o
or when using your own SMTP server. This can be set in the configuration using theb4.send-no-patatt-sign
(see Contributor-oriented settings).--resend V
Resend the specified previously sent version.