Existing passwd and group files overwritten by pkgbase upgrade

Emmanuel Vadot manu at bidouilliste.com
Mon May 13 12:39:27 UTC 2019


On Sun, 12 May 2019 20:24:04 -0700
Ashley Chase <erisianash at gmail.com> wrote:

> On Sat, May 11, 2019 at 03:44:10PM +0200, Emmanuel Vadot wrote:
> > On Sat, 11 May 2019 15:23:21 +0200
> > mj-mailinglist at gmx.de wrote:
> > 
> > > Hi Ashley,
> > > 
> > > I guess this change is the cause: https://reviews.freebsd.org/D20173
> > > It marks the group and the master.passwd file for inclusion in the 
> > > FreebSD-runtime package.
> > > I tried this change on my 12 system, the files are included in the
> > > package. You also see them in the runtime.plist file, but as regular file,
> > > not marked as a config file, like the motd file for example.
> > >  
> > > ...
> > > @(root,wheel,0644,) /etc/group
> > > @(root,wheel,0600,) /etc/master.passwd
> > > @config(root,wheel,0644,) /etc/motd
> > > ...
> > >  
> > > i guess now the existing file is replaced by the new file, instead of beeing
> > > merged with it.
> > > i think, the tag "config" must be added to the above patch. But i am not sure,
> > > what the sytnax looks like for this.
> > >  
> > > --
> > > Martin
> > >  
> > > > After building and installing -CURRENT r347469 using in-tree pkgbase, I
> > > > discovered that my /etc/group, /etc/passwd, /etc/master.passwd,
> > > > /etc/pwd.db and /etc/spwd.db had been overwritten.
> > > > 
> > > > I encountered this after running 'make packages', installing into a
> > > > ZFS Boot Environment using bectl to create and mount a new BE, running
> > > > 'pkg -r $mounpoint upgrade -y' and 'pkg -r $mountpoint -yg "FreeBSD-*"'
> > > > to upgrade the packages and insure that new base packages got installed,
> > > > and finally unmounting and activating the BE.
> > > > 
> > > > ~Ashley Chase
> > > > _______________________________________________
> > > > freebsd-pkgbase at freebsd.org mailing list
> > > > https://lists.freebsd.org/mailman/listinfo/freebsd-pkgbase[https://lists.freebsd.org/mailman/listinfo/freebsd-pkgbase]
> > > > To unsubscribe, send any mail to "freebsd-pkgbase-unsubscribe at freebsd.org"
> > > > 
> > > _______________________________________________
> > > freebsd-pkgbase at freebsd.org mailing list
> > > https://lists.freebsd.org/mailman/listinfo/freebsd-pkgbase
> > > To unsubscribe, send any mail to "freebsd-pkgbase-unsubscribe at freebsd.org"
> > 
> >  Yes sorry that's my fault.
> >  I beleive the included patch should work but I don't have time to test
> > right now.
> > 
> >  diff --git a/etc/Makefile b/etc/Makefile
> > index ab70a94bc761..4b60868fe3dc 100644
> > --- a/etc/Makefile
> > +++ b/etc/Makefile
> > @@ -69,9 +69,9 @@ distribution:
> >  		rc.firewall ${DESTDIR}/etc;
> >  .endif
> >  	cd ${.CURDIR}; \
> > -	    ${INSTALL} -o ${BINOWN} -g ${BINGRP} -m 644 -T
> > "tags=package=runtime"\
> > +	    ${INSTALL} -o ${BINOWN} -g ${BINGRP} -m 644 -T
> > "tags=package=runtime,config"\ ${BIN1} ${DESTDIR}/etc; \
> > -	    ${INSTALL} -o ${BINOWN} -g ${BINGRP} -m 600 -T
> > "tags=package=runtime"\
> > +	    ${INSTALL} -o ${BINOWN} -g ${BINGRP} -m 600 -T
> > "tags=package=runtime,config"\ master.passwd ${DESTDIR}/etc;
> >  
> >  .if ${MK_TCSH} == "no"
> > 
> >  I'll try to test soon and commit.
> 
> This resolved the issue. Thank you.

 I'll come up with a different version of the patch, the problem with
this one is that we install rc.bsdextended as a config file while it's
not one.
 I also think that we should use CONFS for those file so the metadata
will be added automatically.
 I've reverted the commits for now.

-- 
Emmanuel Vadot <manu at bidouilliste.com> <manu at freebsd.org>


More information about the freebsd-pkgbase mailing list