--with-port=PORT
Change the TCP port used by the network code. Default is 3493 as registered with IANA.
Ancient versions of upsd used port 3305.  NUT 2.0 and up use a
substantially different network protocol and are not able to
communicate with anything older than the 1.4 series.
If you have to monitor a mixed environment, use the last 1.4 version, as it contains compatibility code for both the old "REQ" and the new "GET" versions of the protocol.
--with-user=<username> --with-group=<groupname>
See also --enable-inplace-runtime.
Programs started as root will setuid() to <username> for somewhat
safer operation.  You can override this with -u <otheruser> in several
programs, including upsdrvctl (and all drivers by extension), upsd,
and upsmon.  The "user" directive in ups.conf overrides this at run
time for the drivers.
upsmon does not totally drop root because it may need to
initiate a shutdown.  There is always at least a stub process
remaining with root powers.  The network code runs in another
(separate) process as the new user.
The <groupname> is used for the permissions of some files,
particularly the hotplugging rules for USB. The idea is that the
device files for any UPS devices should be readable and writable by
members of that group.
The default value for both the username and groupname is nobody
(or nogroup on systems that have it when configure script runs).
This was done since it’s slightly better than staying around as
root.  Running things as nobody is not a good idea, since it’s a
hack for NFS access.  You should create at least one separate user
for this software.
If you use one of the --with-user and --with-group options, then
you have to use the other one too.
See the INSTALL.nut document and the FAQ for more on this topic.
--with-logfacility=FACILITY
Change the facility used when writing to the log file.  Read the man
page for openlog to get some idea of what’s available on your system.
Default is LOG_DAEMON.
Sometimes as a developer or user you need to interact with a device for which a "proper" NUT driver does not yet exist (or is not in your version), but some proof-of-concept script can be good enough to collect some data.
In some cases, an UPS does not support local monitoring at all, but has a network port for cloud-based monitoring through its vendor’s portal.
Such data can be converted and fed into the NUT dummy-ups driver, and so
represented in the NUT ecosystem, by rewriting the "sequence" file whose
contents it processes in a loop (see dummy-ups(8) for more details).
NUT provides sample scripts for such integration, which can be used if you
have a suitable use-case, or provide inspiration for you to begin experiments
with a new device and (as often happens) a shell or Python script polling
it for information. For more details, see scripts/external_apis in NUT
sources (and pull requests with more integrations would be welcome there).
--enable-extapi-enphase=(yes|auto|no)
Enable installation of integration script for External API: Enphase Monitor (default: no)