Page MenuHomeFreeBSD

New port: mail/slimta: Configurable MTA based on the python-slimta libraries
ClosedPublic

Authored by nc on Jan 9 2021, 12:03 AM.
Tags
None
Referenced Files
Unknown Object (File)
Sat, Oct 25, 3:10 PM
Unknown Object (File)
Sat, Oct 25, 3:00 AM
Unknown Object (File)
Fri, Oct 24, 5:04 AM
Unknown Object (File)
Tue, Oct 21, 7:01 AM
Unknown Object (File)
Mon, Oct 20, 8:09 PM
Unknown Object (File)
Mon, Oct 20, 8:08 PM
Unknown Object (File)
Mon, Oct 20, 8:08 PM
Unknown Object (File)
Sun, Oct 19, 5:33 PM
Subscribers

Details

Summary

New port: mail/slimta: Configurable MTA based on the python-slimta libraries

Test Plan

Passes poudriere on i386 and amd64.

Diff Detail

Repository
rP FreeBSD ports repository
Lint
No Lint Coverage
Unit
No Test Coverage
Build Status
Buildable 36103
Build 32992: arc lint + arc unit

Event Timeline

nc requested review of this revision.Jan 9 2021, 12:03 AM
This comment was removed by nc.

Add a rc script and a pkg-message.in

Forgot a pkg-plist, since we create a new directory.

Remove files from another port update.

Sorry, had to do it again.

0mp requested changes to this revision.Jan 11 2021, 6:35 PM
0mp added inline comments.
mail/slimta/Makefile
12

Is LICENSE_FILE available perhaps?

27
  1. It would probably be better if you patch occurrences of etc/ with %%PREFIX%% and then used REINPLACE_CMD to replace %%PREFIX%% with ${PREFIX}.
  2. You may want to use REINPLACE_ARGS= -i "". This way it might be easier to grep for it in the future.
31

Would it also work?

BTW, if upstream offers a sample slimta.yaml file you can install it as a sample.

mail/slimta/files/pkg-message.in
5

We usually try to avoid you in pkg-messages (although I cannot find any documentation codifying that),

mail/slimta/files/slimta.in
12

Missing space.

34

It could be that you'd be fine with:

procname="%%PREFIX%%/bin/slimta"
command="/usr/sbin/daemon"
command_args="-p $pidfile $procname -c $slimta_conf"
mail/slimta/pkg-plist
2

Could you confirm that this is the what make makeplist generates? Also, if it's only one entry, then maybe PLIST_FILES= is a better mechanism in this case.

This revision now requires changes to proceed.Jan 11 2021, 6:35 PM

Here's an updated diff.

Some highlights:

  • There is no license file, so LICENSE_FILE isn't used
  • pkg-message.in was removed, since there are sample configuration files
  • pkg-plist is used, since I'm installing the sample config files
  • Some cleanups in the rc script
nc marked 5 inline comments as done.Jan 11 2021, 7:07 PM
nc added inline comments.
mail/slimta/Makefile
12

There is no LICENSE_FILE for this port, sorry.

27

Sure, done.

31

Sure, done.

nc marked 3 inline comments as done.

Make it possible to stop slimta in the rc.d script.

Use @sample macros for config files

Hmm, it seems like both the slimta_start and the slimta_stop functions are simple enough that they could be removed altogether as their default implementations are probably good enough if not better. Am I missing something subtle?

Otherwise, the patch seems fine. We are almost ready to commit.

mail/slimta/Makefile
36

${PREFIX}/etc/${PORTNAME} could probably be replaced with ${ETCDIR}

mail/slimta/files/slimta.in
39

The rc service should support stopping the service if it is not enabled, e.g., when a user issues service slimta onestop.

42

Would pkill -F ${pidfile} also work?

Here's an updated diff.

Some highlights:

  • I do need a slimta_stop(), but the default slimta_start() works fine
  • Using ${ETCDIR} would mean I would end up with etc/py37-slimta, which obviously can't be done
In D28052#630148, @nc wrote:

Here's an updated diff.

Some highlights:

  • I do need a slimta_stop(), but the default slimta_start() works fine

You might need to define command_interpreter. See rc.subr(8).

Let me know if that works.

  • Using ${ETCDIR} would mean I would end up with etc/py37-slimta, which obviously can't be done

Ach, good catch!

Use command_intepreter in rc script.

This revision is now accepted and ready to land.Jan 16 2021, 9:19 PM