Tue Dec 8 17:15:21 2015 UTC ()
Update sysutils/cfengine3 to 3.7.2.

Patch based largely on a pull request by bahamat@:

  https://github.com/joyent/pkgsrc/pull/307

3.7.2:

Bug fixes:
- readfile() and read*list() should print an error if they fail to read file.
  (Redmine #7702)
- Fix 'AIX_PREINSTALL_ALREADY_DONE.txt: cannot create' error
  message on AIX.
- If there is an error saving a mustache template file
  it is now logged with log-level error (was inform).
- Change: Clarify bootstrap/failsafe reports
- Fixed several bugs which prevented CFEngine from loading
  libraries from the correct location. This affected several platforms.
  (Redmine #6708)
- If file_select.file_types is set to symlink and there
  are regular files in the scanned directory, CFEngine no longer
  produces an unneccessary error message. (Redmine #6996)
- Fix: Solaris packages no longer contain duplicate library
  files, but instead symlinks to them. (Redmine #7591)
- cf-agent, cf-execd, cf-promises, cf-runagent and cf-serverd honor
  multiple -D, -N and -s arguments (Redmine #7191)
- Fix "@endif" keyword sometimes being improperly processed
  by policy parser. (Redmine #7413)
- It is possible to edit the same value in multiple regions
  of one file. (Redmine #7460)
- Fix select_class not setting class when used in common bundle with slist.
  (Redmine #7482)
- Fix broken HA policy for 3rd disaster-recovery node.
- Directories should no more be changed randomly
  into files. (Redmine #6027)
- Include latest security updates for 3.7.
- Reduce malloc() thread contention on heavily loaded
  cf-serverd, by not exiting early in the logging function, if no message
  is to be printed. (Redmine #7624)
- Improve cf-serverd's lock contention because of getpwnam()
  call. (Redmine #7643)
- action_policy "warn" now correctly produces warnings instead
  of various other verbosity levels. (Redmine #7274)
- Change: Improve efficiency and debug reports (Redmine #7527)
- Change package modules permissions on hub package so that
  hub can execute package promises. (Redmine #7602)
- No longer hang when changing permissions/ownership on fifos
  (Redmine #7030)
- Fix exporting CSV reports through HTTPS. (Redmine #7267)
- failsafe.cf will be created when needed. (Redmine #7634)
- Mustache templates: Fix  key when value is not a
  primitive. The old behavior, when iterating across a map or array of
  maps, was to abort if the key was requested with . The new
  behavior is to always replace  with either the key name or the
  iteration position in the array. An error is printed if  is used
  outside of a Mustache iteration section.
- Legacy package promise: Result classes are now defined if
  the package being promised is already up to date. (Redmine #7399)
- TTY detection should be more reliable. (Redmine #7606)

Masterfiles:
- Add: Path to svcprop in stdlib
- Add: New `results` classes body [] (Redmine #7418, #7481)
- Remove: Support for email settings from augments_file (Redmine #7682)

3.7.1:

Bug fixes:
- Fix daemons not restarting correctly on upgrade on AIX. (Redmine #7550)
- Fix upgrade causing error message under systemd because of open ports.
- Fix build with musl libc. (Redmine #7455)
- Long promiser strings with multiple lines are now
  abbreviated in logs. (Redmine #3964)
- Fixed a bug which could cause daemons to not to be killed
  correctly when upgrading or manually running "service cfengine3 stop".
  (Redmine #7193)
- Package promise: Fix inability to install certain packages
  with numbers.
- Fix package promise not removing dependant packages. (Redmine #7424)
- Fix warning "Failed to parse csv file entry" with certain very long
  commands promises. (Redmine #7400)
- Fix misaligned help output in cf-hub. (Redmine #7273)
- Augmenting inputs from the augments_file (Redmine #7420)
- Add support for failover to 3rd HA node located outside cluster.
- Upgrade all dependencies for patch release.
- Fix a bug which caused daemons not to be restarted on
  upgrade. (Redmine #7528)

3.7.0:

New features:
- New package promise implementation.
- Full systemd support for all relevant platforms
- New classes to determine whether certain features are enabled:
    * feature_yaml
    * feature_xml
  For the official CFEngine packages, these are always enabled, but
  packages from other sources may be built without the support.
- New readdata() support for generic data input (CSV, YAML, JSON, or auto)
- YAML support: new readyaml() function and in readdata()
- CSV support: new readcsv() function and in readdata()
- New string_mustache() function
- New data_regextract() function
- eval() can now be called with "class" as the "mode" argument, which
  will cause it to return true ("any") if the calculated result is
  non-zero, and false ("!any") if it is zero.
- New list_ifelse() function
- New mapjson() function as well as JSON support in maparray().
- filestat() function now supports "xattr" argument for extended
  attributes.
- "ifvarclass" now has "if" as an alias, and "unless" as an inverse
  alias.
- Ability to expand JSON variables directory in Mustache templates:
  Prefix the name with '%' for multiline expansion, '$' for compact
  expansion.
- Ability to expand the iteration *key* in Mustache templates with @
- Canonical JSON output: JSON output has reliably sorted keys so the
  same data structure will produce the same JSON every time.
- New "@if minimum_version(x.x)" syntax in order to hide future language
  improvements from versions that don't understand them.
- compile time option (--with-statedir) to
  override the default state/ directory path.
- Fix error messages/ handling in process signalling which no longer
  allowed any signals to fail silently
- Also enable shortcut keyword for cf-serverd classic protocol, eg to
  simplify the bootstrap process for clients that have different
  sys.masterdir settings (Redmine #3697)
- methods promises now accepts the bundle name in the promiser string,
  as long as it doesn't have any parameters.
- In a services promise, if the service_method bundle is not specified,
  it defaults to the promiser string (canonified) with "service_" as a
  prefix. The bundle must be in the same namespace as the promise.
- inline JSON in policy files: surrounding with parsejson() is now
  optional *when creating a new data container*.
- New data_expand() function to interpolate variables in a data container.
- Add configurable network bandwidth limit for all outgoing
  connections ("bwlimit" attribute in "body common control") . To
  enforce it in both directions, make sure the attribute is set on both
  sides of the connection.
- Secure bootstrap has been facilitated by use of
  "cf-agent --boostrap HUB_ADDRESS --trust-server=no"
- Implement new TLS-relevant options (Redmine #6883):
  - body common control: tls_min_version
  - body server control: allowtlsversion
  - body common control: tls_ciphers
  - body server control: allowciphers (preexisting)

Changes:
- Improved output format, less verbose, and messages are grouped.
- cf-execd: agent_expireafter default was changed to 120 minutes
  (Redmine #7113)
- All embedded databases are now rooted in the state/ directory.
- TLS used as default for all outgoing connections.
- process promise now reports kept status instead of repaired if a
  signal is not sent, even if the restart_class is set. The old
  behavior was to set the repaired status whenever the process was not
  running. (Redmine#7216).
- Bootstrapping requires keys to be generated in advance using cf-key.
- Disable class set on reverse lookup of interfaces IP addresses.
  (Redmine #3993, Redmine #6870)
- Define a hard class with just the OS major version on FreeBSD.
- Abort cf-agent if OpenSSL's random number generator can't
  be seeded securely.
- Masterfiles source tarball now installs using the usual commands
  "./configure; make install".
- Updated Emacs syntax highlighting template to support the latest
  syntax enhancements in 3.7.

Deprecations:
- Arbitrary arguments to cfruncommand (using "cf-runagent -o") are
  not acceptable any more. (Redmine #6978)
- 3.4 is no longer supported in masterfiles.

Bug fixes:
- Fix server common bundles evaluation order (Redmine#7211).
- Limit LMDB disk usage by preserving sparse areas in LMDB files
  (Redmine#7242).
- Fixed LMDB corruption on HP-UX 11.23. (Redmine #6994)
- Fixed insert_lines failing to converge if preserve_block was used.
  (Redmine #7094)
- Fixed init script failing to stop/restart daemons on openvz/lxc
  hosts. (Redmine #3394)
- rm_rf_depth now deletes base directory as advertised. (Redmine #7009)
- Refactored cf-agent's connection cache to properly differentiate
  hosts using all needed attributes like host and port.
  (Redmine #4646)
- Refactored lastseen database handling to avoid inconsistencies.
  (Redmine #6660)
- cf-key --trust-key now supports new syntax to also update the
  lastseen database, so that clients using old protocol will trust
  the server correctly.
- Fixed a bug which sometimes caused an agent or daemon to kill or stop
  itself. (Redmine #7075, #7244)
- Fixed a bug which made it difficult to kill CFEngine daemons,
  particularly cf-execd. (Redmine #6659, #7193)
- Fixed a bug causing systemd not to be detected correctly on Debian.
  (Redmine #7297)
- "cf-promises -T" will now correctly report the checked out commit,
  even if you haven't checked out a Git branch. (Redmine #7332)
- Reduce verbosity of harmless errors related to socket timeouts and
  missing thermal zone files. (Redmine #6486 and #7238)
- Fix process_result logic to match the purpose of body process_select
  days_older_than (Redmine #3009)

Masterfiles:

Added:
- Support for user specified overring of framework defaults without
  modifying policy supplied by the framework itself (see
  example_def.json)
- Support for def.json class augmentation in update policy
- Run vacuum operation on postgresql every night as a part of
  maintenance.
- Add measure_promise_time action body to lib (3.5, 3.6, 3.7, 3.8)
- New negative class guard `cfengine_internal_disable_agent_email` so
  that agent email can be easily disabled by augmenting def.json

Changed:
- Relocate def.cf to controls/VER/
- Relocate update_def to controls/VER
- Relocate all controls to controls/VER
- Only load cf_hub and reports.cf on CFEngine Enterprise installs
- Relocate acls related to report collection from bundle server
  access_rules to controls/VER/reports.cf into bundle server
  report_access_rules
- Re-organize cfe_internal splitting core from enterprise specific
  policies and loading the appropriate inputs only when necessary
- Moved update directory into cfe_internal as it is not generally
  intended to be modified
- services/autorun.cf moved to lib/VER/ as it is not generally intended
  to be modified
- To improve predictibility autorun bundles are activated in
  lexicographical order
- Relocate services/file_change.cf to cfe_internal/enterprise. This
  policy is most useful for a good OOTB experience with CFEngine
  Enterprise Mission Portal.
- Relocate service_catalogue from promsies.cf to services/main.cf. It is
  intended to be a user entry. This name change correlates with the main
  bundle being activated by default if there is no bundlesequence
  specified.
- Reduce benchmarks sample history to 1 day.
- Update policy no longer generates a keypair if one is not found.
  (Redmine: #7167)
- Relocate cfe_internal_postgresql_maintenance bundle to lib/VER/
- Set postgresql_monitoring_maintenance only for versions 3.6.0 and
  3.6.1
- Move hub specific bundles from lib/VER/cfe_internal.cf into
  lib/VER/cfe_internal_hub.cf and load them only if policy_server policy
  if set.
- Re-organize lib/VER/stdlib.cf from lists into classic array for use
  with getvalues

Removed:
- Diff reporting on /etc/shadow (Enterprise)
- Update policy from promise.cf inputs. There is no reason to include
  the update policy into promsies.cf, update.cf is the entry for the
  update policy
- _not_repaired outcome from classes_generic and scoped_classes generic
  (Redmine: # 7022)

Fixes:
- standard_services now restarts the service if it was not already
  running when using service_policy => restart with chkconfig (Redmine
  #7258)


(fhajny)
diff -r1.14 -r1.15 pkgsrc/sysutils/cfengine3/Makefile
diff -r1.1 -r1.2 pkgsrc/sysutils/cfengine3/Makefile.cf
diff -r1.7 -r1.8 pkgsrc/sysutils/cfengine3/PLIST
diff -r1.8 -r1.9 pkgsrc/sysutils/cfengine3/distinfo
diff -r0 -r1.1 pkgsrc/sysutils/cfengine3/files/pkgsrc
diff -r0 -r1.1 pkgsrc/sysutils/cfengine3/files/smf/manifest.xml
diff -r1.2 -r1.3 pkgsrc/sysutils/cfengine3/patches/patch-ext_Makefile.in
diff -r1.1 -r0 pkgsrc/sysutils/cfengine3/patches/patch-libenv_unix_iface.c

cvs diff -r1.14 -r1.15 pkgsrc/sysutils/cfengine3/Makefile (expand / switch to context diff)
--- pkgsrc/sysutils/cfengine3/Makefile 2015/04/14 13:33:32 1.14
+++ pkgsrc/sysutils/cfengine3/Makefile 2015/12/08 17:15:21 1.15
@@ -1,9 +1,9 @@
-# $NetBSD: Makefile,v 1.14 2015/04/14 13:33:32 fhajny Exp $
+# $NetBSD: Makefile,v 1.15 2015/12/08 17:15:21 fhajny Exp $
 #
 
-DISTNAME=	cfengine-3.6.5
+DISTNAME=	cfengine-3.7.2
 CATEGORIES=	sysutils
-MASTER_SITES=	http://cfengine.package-repos.s3.amazonaws.com/tarballs/
+MASTER_SITES=	http://cfengine-package-repos.s3.amazonaws.com/tarballs/
 
 MAINTAINER=	pettai@NetBSD.org
 HOMEPAGE=	http://cfengine.com/pages/community
@@ -12,22 +12,25 @@
 
 USE_LANGUAGES=		c c++ c99
 USE_LIBTOOL=		yes
-USE_TOOLS+=		gmake
+USE_TOOLS+=		gmake pax
 
 .include "options.mk"
 
 DISTFILES=		${DEFAULT_DISTFILES}
-DISTFILES+=		masterfiles-${PKGVERSION_NOREV}.tar.gz
+DISTFILES+=		cfengine-masterfiles-${PKGVERSION_NOREV}.tar.gz
 
 GNU_CONFIGURE=		yes
 CONFIGURE_ARGS+=	--enable-fhs
 CONFIGURE_ARGS+=	--docdir=${DOCDIR}
+CONFIGURE_ARGS+=	--datadir=${CFENGINE_DIR:Q}
 CONFIGURE_ARGS+=	--with-masterdir=${PKG_SYSCONFDIR:Q}
 CONFIGURE_ARGS+=	--with-sysconfdir=${PKG_SYSCONFDIR:Q}
 CONFIGURE_ARGS+=	--with-workdir=${CFENGINE_DIR:Q}
 CONFIGURE_ARGS+=	--with-openssl=${BUILDLINK_PREFIX.openssl:Q}
 CONFIGURE_ARGS+=	--with-pcre=${BUILDLINK_PREFIX.pcre:Q}
 
+CONFIGURE_DIRS+=	. ${WRKDIR}/cfengine-masterfiles-${PKGVERSION_NOREV}
+
 BUILD_DEFS+=		VARBASE CFENGINE_DIR
 FILES_SUBST+=		CFENGINE_DIR=${CFENGINE_DIR}
 
@@ -46,27 +49,56 @@
 .endfor
 
 RCD_SCRIPTS=		cfserverd cfexecd cfmonitord
+SMF_INSTANCES=		${RCD_SCRIPTS}
 
 INSTALLATION_DIRS+=	${PKGMANDIR}/man8
 INSTALL_MAKE_FLAGS+=	examplesdir=${EGDIR} projlibdir=${PREFIX}/lib
+INSTALL_MAKE_FLAGS+=	masterfilesdir=${EGDIR}/CoreBase
+INSTALL_MAKE_FLAGS+=	package_modulesdir=${EGDIR}/CoreBase/modules/packages
+INSTALL_MAKE_FLAGS+=	dist_package_modules_SCRIPTS="apt_get pkgsrc yum"
 
 MAKE_DIRS=		${CFENGINE_DIR}
-MAKE_DIRS+=		${PKG_SYSCONFDIR}/controls ${PKG_SYSCONFDIR}/libraries
-MAKE_DIRS+=		${PKG_SYSCONFDIR}/services
+MAKE_DIRS+=		${PKG_SYSCONFDIR}/cfe_internal/core/deprecated
+MAKE_DIRS+=		${PKG_SYSCONFDIR}/cfe_internal/update
+MAKE_DIRS+=		${PKG_SYSCONFDIR}/cfe_internal/enterprise/ha
+MAKE_DIRS+=		${PKG_SYSCONFDIR}/controls/3.5
+MAKE_DIRS+=		${PKG_SYSCONFDIR}/controls/3.6
+MAKE_DIRS+=		${PKG_SYSCONFDIR}/controls/3.7
+MAKE_DIRS+=		${PKG_SYSCONFDIR}/inventory
+MAKE_DIRS+=		${PKG_SYSCONFDIR}/lib/3.5
+MAKE_DIRS+=		${PKG_SYSCONFDIR}/lib/3.6
+MAKE_DIRS+=		${PKG_SYSCONFDIR}/lib/3.7
+MAKE_DIRS+=		${PKG_SYSCONFDIR}/modules/packages
+MAKE_DIRS+=		${PKG_SYSCONFDIR}/services/autorun
+MAKE_DIRS+=		${PKG_SYSCONFDIR}/sketches/meta
+MAKE_DIRS+=		${PKG_SYSCONFDIR}/templates
 
-update-masterfiles:
+SUBST_CLASSES+=		path
+SUBST_MESSAGE.path=	Fixing default paths
+SUBST_STAGE.path=	pre-configure
+SUBST_FILES.path=	${WRKDIR}/cfengine-masterfiles-${PKGVERSION_NOREV}/modules/packages/pkgsrc
+SUBST_VARS.path=	MACHINE_ARCH PKG_SYSCONFBASE PREFIX
+
+# This can be removed once this module is released in 3.8.
+post-extract:
+	${INSTALL_SCRIPT} files/pkgsrc \
+		${WRKDIR}/cfengine-masterfiles-${PKGVERSION_NOREV}/modules/packages/pkgsrc
+
+update-masterfiles: configure
 	(${ECHO} '# $$''NetBSD''$$'; \
-	 ${ECHO} '# Generated by "${MAKE:Q} update-masterfiles", post-extract'; \
+	 ${ECHO} '# Generated by "make update-masterfiles", post-configure'; \
 	 ${ECHO}; \
-	 cd ${WRKDIR}/masterfiles && ${FIND} * -type f | ${SORT} | \
-	 ${SED} -e 's|^|CFILES+=|') \
+	 cd ${WRKDIR}/cfengine-masterfiles-${PKGVERSION_NOREV} && (\
+		${FIND} cfe_internal controls inventory lib services sketches/meta update -name '*.cf'; \
+		${FIND} templates -name '*.mustache'; \
+		${FIND} modules -type f | grep -v Makefile \
+	 ) | ${SORT} | ${SED} -e 's|^|CFILES+=|') \
 	 > ${.CURDIR}/../../sysutils/cfengine3/Makefile.cf
 
 post-install:
-	cp -r ${WRKDIR}/masterfiles ${DESTDIR}/${PREFIX}/share/examples/cfengine/CoreBase
 	for cf in cf-agent cf-execd cf-key cf-monitord cf-promises cf-runagent cf-serverd ; \
-	do \
-	LD_LIBRARY_PATH=${DESTDIR}${PREFIX}/lib ${DESTDIR}${PREFIX}/sbin/$$cf -M > ${DESTDIR}/${PREFIX}/${PKGMANDIR}/man8/$$cf.8 ; \
+	do LD_LIBRARY_PATH=${DESTDIR}${PREFIX}/lib ${DESTDIR}${PREFIX}/sbin/$$cf -M \
+		> ${DESTDIR}/${PREFIX}/${PKGMANDIR}/man8/$$cf.8 ; \
 	done
 
 .include "../../devel/pcre/buildlink3.mk"

cvs diff -r1.1 -r1.2 pkgsrc/sysutils/cfengine3/Makefile.cf (expand / switch to context diff)
--- pkgsrc/sysutils/cfengine3/Makefile.cf 2015/04/07 08:43:35 1.1
+++ pkgsrc/sysutils/cfengine3/Makefile.cf 2015/12/08 17:15:21 1.2
@@ -1,23 +1,61 @@
-# $NetBSD: Makefile.cf,v 1.1 2015/04/07 08:43:35 fhajny Exp $
-# This file is generated by "/opt/local/bin/bmake update-masterfiles", post-extract
+# $NetBSD: Makefile.cf,v 1.2 2015/12/08 17:15:21 fhajny Exp $
+# Generated by "make update-masterfiles", post-configure
 
 CFILES+=cfe_internal/CFE_cfengine.cf
-CFILES+=cfe_internal/CFE_hub_specific.cf
-CFILES+=cfe_internal/CFE_knowledge.cf
-CFILES+=cfe_internal/cfengine_processes.cf
-CFILES+=cfe_internal/ha/ha.cf
-CFILES+=cfe_internal/ha/ha_def.cf
-CFILES+=cfe_internal/host_info_report.cf
-CFILES+=controls/3.4/cf_serverd.cf
-CFILES+=controls/cf_agent.cf
-CFILES+=controls/cf_execd.cf
-CFILES+=controls/cf_hub.cf
-CFILES+=controls/cf_monitord.cf
-CFILES+=controls/cf_runagent.cf
-CFILES+=controls/cf_serverd.cf
-CFILES+=def.cf
+CFILES+=cfe_internal/core/deprecated/cfengine_processes.cf
+CFILES+=cfe_internal/core/host_info_report.cf
+CFILES+=cfe_internal/core/limit_robot_agents.cf
+CFILES+=cfe_internal/core/log_rotation.cf
+CFILES+=cfe_internal/core/main.cf
+CFILES+=cfe_internal/enterprise/CFE_hub_specific.cf
+CFILES+=cfe_internal/enterprise/CFE_knowledge.cf
+CFILES+=cfe_internal/enterprise/file_change.cf
+CFILES+=cfe_internal/enterprise/ha/ha.cf
+CFILES+=cfe_internal/enterprise/ha/ha_def.cf
+CFILES+=cfe_internal/enterprise/ha/ha_update.cf
+CFILES+=cfe_internal/enterprise/main.cf
+CFILES+=cfe_internal/update/cfe_internal_dc_workflow.cf
+CFILES+=cfe_internal/update/cfe_internal_local_git_remote.cf
+CFILES+=cfe_internal/update/cfe_internal_update_from_repository.cf
+CFILES+=cfe_internal/update/update_bins.cf
+CFILES+=cfe_internal/update/update_policy.cf
+CFILES+=cfe_internal/update/update_processes.cf
+CFILES+=controls/3.5/cf_agent.cf
+CFILES+=controls/3.5/cf_execd.cf
+CFILES+=controls/3.5/cf_hub.cf
+CFILES+=controls/3.5/cf_monitord.cf
+CFILES+=controls/3.5/cf_runagent.cf
+CFILES+=controls/3.5/cf_serverd.cf
+CFILES+=controls/3.5/def.cf
+CFILES+=controls/3.5/def_inputs.cf
+CFILES+=controls/3.5/reports.cf
+CFILES+=controls/3.5/update_def.cf
+CFILES+=controls/3.5/update_def_inputs.cf
+CFILES+=controls/3.6/cf_agent.cf
+CFILES+=controls/3.6/cf_execd.cf
+CFILES+=controls/3.6/cf_hub.cf
+CFILES+=controls/3.6/cf_monitord.cf
+CFILES+=controls/3.6/cf_runagent.cf
+CFILES+=controls/3.6/cf_serverd.cf
+CFILES+=controls/3.6/def.cf
+CFILES+=controls/3.6/def_inputs.cf
+CFILES+=controls/3.6/reports.cf
+CFILES+=controls/3.6/update_def.cf
+CFILES+=controls/3.6/update_def_inputs.cf
+CFILES+=controls/3.7/cf_agent.cf
+CFILES+=controls/3.7/cf_execd.cf
+CFILES+=controls/3.7/cf_hub.cf
+CFILES+=controls/3.7/cf_monitord.cf
+CFILES+=controls/3.7/cf_runagent.cf
+CFILES+=controls/3.7/cf_serverd.cf
+CFILES+=controls/3.7/def.cf
+CFILES+=controls/3.7/def_inputs.cf
+CFILES+=controls/3.7/reports.cf
+CFILES+=controls/3.7/update_def.cf
+CFILES+=controls/3.7/update_def_inputs.cf
 CFILES+=inventory/any.cf
 CFILES+=inventory/debian.cf
+CFILES+=inventory/freebsd.cf
 CFILES+=inventory/generic.cf
 CFILES+=inventory/linux.cf
 CFILES+=inventory/lsb.cf
@@ -38,11 +76,12 @@
 CFILES+=lib/3.5/packages.cf
 CFILES+=lib/3.5/paths.cf
 CFILES+=lib/3.5/processes.cf
-CFILES+=lib/3.5/reports.cf
 CFILES+=lib/3.5/services.cf
 CFILES+=lib/3.5/storage.cf
+CFILES+=lib/3.6/autorun.cf
 CFILES+=lib/3.6/bundles.cf
 CFILES+=lib/3.6/cfe_internal.cf
+CFILES+=lib/3.6/cfe_internal_hub.cf
 CFILES+=lib/3.6/cfengine_enterprise_hub_ha.cf
 CFILES+=lib/3.6/commands.cf
 CFILES+=lib/3.6/common.cf
@@ -56,35 +95,37 @@
 CFILES+=lib/3.6/packages.cf
 CFILES+=lib/3.6/paths.cf
 CFILES+=lib/3.6/processes.cf
-CFILES+=lib/3.6/reports.cf
 CFILES+=lib/3.6/services.cf
 CFILES+=lib/3.6/stdlib.cf
 CFILES+=lib/3.6/storage.cf
 CFILES+=lib/3.6/users.cf
 CFILES+=lib/3.6/vcs.cf
-CFILES+=promises.cf
-CFILES+=services/CVE_2015_0235/def.cf
-CFILES+=services/CVE_2015_0235/policy/CVE_2015_0235_inventory.cf
-CFILES+=services/autorun.cf
+CFILES+=lib/3.7/autorun.cf
+CFILES+=lib/3.7/bundles.cf
+CFILES+=lib/3.7/cfe_internal.cf
+CFILES+=lib/3.7/cfe_internal_hub.cf
+CFILES+=lib/3.7/cfengine_enterprise_hub_ha.cf
+CFILES+=lib/3.7/commands.cf
+CFILES+=lib/3.7/common.cf
+CFILES+=lib/3.7/databases.cf
+CFILES+=lib/3.7/edit_xml.cf
+CFILES+=lib/3.7/examples.cf
+CFILES+=lib/3.7/feature.cf
+CFILES+=lib/3.7/files.cf
+CFILES+=lib/3.7/guest_environments.cf
+CFILES+=lib/3.7/monitor.cf
+CFILES+=lib/3.7/packages.cf
+CFILES+=lib/3.7/paths.cf
+CFILES+=lib/3.7/processes.cf
+CFILES+=lib/3.7/services.cf
+CFILES+=lib/3.7/stdlib.cf
+CFILES+=lib/3.7/storage.cf
+CFILES+=lib/3.7/users.cf
+CFILES+=lib/3.7/vcs.cf
+CFILES+=modules/packages/apt_get
+CFILES+=modules/packages/pkgsrc
+CFILES+=modules/packages/yum
 CFILES+=services/autorun/hello.cf
-CFILES+=services/file_change.cf
-CFILES+=services/linux_kernel/def.cf
-CFILES+=services/linux_kernel/examples/promises.cf
-CFILES+=services/linux_kernel/policy/linux_kernel_params_inventory.cf
-CFILES+=services/sysctl/def.cf
-CFILES+=services/sysctl/policy/example_sysctl_data_from_policy.cf
-CFILES+=services/sysctl/policy/sysctl_conf_selective_present.cf
-CFILES+=services/sysctl/test.cf
-CFILES+=services/yum/def.cf
-CFILES+=services/yum/policy/yum_inventory.cf
-CFILES+=services/yum/policy/yum_inventory_yum_info_yum.cf
-CFILES+=services/yum/policy/yum_inventory_yum_repolist.cf
+CFILES+=services/main.cf
 CFILES+=sketches/meta/api-runfile.cf
 CFILES+=templates/host_info_report.mustache
-CFILES+=update.cf
-CFILES+=update/cfe_internal_dc_workflow.cf
-CFILES+=update/cfe_internal_local_git_remote.cf
-CFILES+=update/cfe_internal_update_from_repository.cf
-CFILES+=update/update_bins.cf
-CFILES+=update/update_policy.cf
-CFILES+=update/update_processes.cf

cvs diff -r1.7 -r1.8 pkgsrc/sysutils/cfengine3/PLIST (expand / switch to context diff)
--- pkgsrc/sysutils/cfengine3/PLIST 2015/04/07 08:43:35 1.7
+++ pkgsrc/sysutils/cfengine3/PLIST 2015/12/08 17:15:21 1.8
@@ -1,4 +1,4 @@
-@comment $NetBSD: PLIST,v 1.7 2015/04/07 08:43:35 fhajny Exp $
+@comment $NetBSD: PLIST,v 1.8 2015/12/08 17:15:21 fhajny Exp $
 lib/libpromises.la
 man/man8/cf-agent.8
 man/man8/cf-execd.8
@@ -18,22 +18,60 @@
 share/doc/cfengine/ChangeLog
 share/doc/cfengine/README.md
 share/examples/cfengine/CoreBase/cfe_internal/CFE_cfengine.cf
-share/examples/cfengine/CoreBase/cfe_internal/CFE_hub_specific.cf
-share/examples/cfengine/CoreBase/cfe_internal/CFE_knowledge.cf
-share/examples/cfengine/CoreBase/cfe_internal/cfengine_processes.cf
-share/examples/cfengine/CoreBase/cfe_internal/ha/ha.cf
-share/examples/cfengine/CoreBase/cfe_internal/ha/ha_def.cf
-share/examples/cfengine/CoreBase/cfe_internal/host_info_report.cf
-share/examples/cfengine/CoreBase/controls/3.4/cf_serverd.cf
-share/examples/cfengine/CoreBase/controls/cf_agent.cf
-share/examples/cfengine/CoreBase/controls/cf_execd.cf
-share/examples/cfengine/CoreBase/controls/cf_hub.cf
-share/examples/cfengine/CoreBase/controls/cf_monitord.cf
-share/examples/cfengine/CoreBase/controls/cf_runagent.cf
-share/examples/cfengine/CoreBase/controls/cf_serverd.cf
-share/examples/cfengine/CoreBase/def.cf
+share/examples/cfengine/CoreBase/cfe_internal/core/deprecated/cfengine_processes.cf
+share/examples/cfengine/CoreBase/cfe_internal/core/host_info_report.cf
+share/examples/cfengine/CoreBase/cfe_internal/core/limit_robot_agents.cf
+share/examples/cfengine/CoreBase/cfe_internal/core/log_rotation.cf
+share/examples/cfengine/CoreBase/cfe_internal/core/main.cf
+share/examples/cfengine/CoreBase/cfe_internal/enterprise/CFE_hub_specific.cf
+share/examples/cfengine/CoreBase/cfe_internal/enterprise/CFE_knowledge.cf
+share/examples/cfengine/CoreBase/cfe_internal/enterprise/file_change.cf
+share/examples/cfengine/CoreBase/cfe_internal/enterprise/ha/ha.cf
+share/examples/cfengine/CoreBase/cfe_internal/enterprise/ha/ha_def.cf
+share/examples/cfengine/CoreBase/cfe_internal/enterprise/ha/ha_update.cf
+share/examples/cfengine/CoreBase/cfe_internal/enterprise/main.cf
+share/examples/cfengine/CoreBase/cfe_internal/update/cfe_internal_dc_workflow.cf
+share/examples/cfengine/CoreBase/cfe_internal/update/cfe_internal_local_git_remote.cf
+share/examples/cfengine/CoreBase/cfe_internal/update/cfe_internal_update_from_repository.cf
+share/examples/cfengine/CoreBase/cfe_internal/update/update_bins.cf
+share/examples/cfengine/CoreBase/cfe_internal/update/update_policy.cf
+share/examples/cfengine/CoreBase/cfe_internal/update/update_processes.cf
+share/examples/cfengine/CoreBase/controls/3.5/cf_agent.cf
+share/examples/cfengine/CoreBase/controls/3.5/cf_execd.cf
+share/examples/cfengine/CoreBase/controls/3.5/cf_hub.cf
+share/examples/cfengine/CoreBase/controls/3.5/cf_monitord.cf
+share/examples/cfengine/CoreBase/controls/3.5/cf_runagent.cf
+share/examples/cfengine/CoreBase/controls/3.5/cf_serverd.cf
+share/examples/cfengine/CoreBase/controls/3.5/def.cf
+share/examples/cfengine/CoreBase/controls/3.5/def_inputs.cf
+share/examples/cfengine/CoreBase/controls/3.5/reports.cf
+share/examples/cfengine/CoreBase/controls/3.5/update_def.cf
+share/examples/cfengine/CoreBase/controls/3.5/update_def_inputs.cf
+share/examples/cfengine/CoreBase/controls/3.6/cf_agent.cf
+share/examples/cfengine/CoreBase/controls/3.6/cf_execd.cf
+share/examples/cfengine/CoreBase/controls/3.6/cf_hub.cf
+share/examples/cfengine/CoreBase/controls/3.6/cf_monitord.cf
+share/examples/cfengine/CoreBase/controls/3.6/cf_runagent.cf
+share/examples/cfengine/CoreBase/controls/3.6/cf_serverd.cf
+share/examples/cfengine/CoreBase/controls/3.6/def.cf
+share/examples/cfengine/CoreBase/controls/3.6/def_inputs.cf
+share/examples/cfengine/CoreBase/controls/3.6/reports.cf
+share/examples/cfengine/CoreBase/controls/3.6/update_def.cf
+share/examples/cfengine/CoreBase/controls/3.6/update_def_inputs.cf
+share/examples/cfengine/CoreBase/controls/3.7/cf_agent.cf
+share/examples/cfengine/CoreBase/controls/3.7/cf_execd.cf
+share/examples/cfengine/CoreBase/controls/3.7/cf_hub.cf
+share/examples/cfengine/CoreBase/controls/3.7/cf_monitord.cf
+share/examples/cfengine/CoreBase/controls/3.7/cf_runagent.cf
+share/examples/cfengine/CoreBase/controls/3.7/cf_serverd.cf
+share/examples/cfengine/CoreBase/controls/3.7/def.cf
+share/examples/cfengine/CoreBase/controls/3.7/def_inputs.cf
+share/examples/cfengine/CoreBase/controls/3.7/reports.cf
+share/examples/cfengine/CoreBase/controls/3.7/update_def.cf
+share/examples/cfengine/CoreBase/controls/3.7/update_def_inputs.cf
 share/examples/cfengine/CoreBase/inventory/any.cf
 share/examples/cfengine/CoreBase/inventory/debian.cf
+share/examples/cfengine/CoreBase/inventory/freebsd.cf
 share/examples/cfengine/CoreBase/inventory/generic.cf
 share/examples/cfengine/CoreBase/inventory/linux.cf
 share/examples/cfengine/CoreBase/inventory/lsb.cf
@@ -54,11 +92,12 @@
 share/examples/cfengine/CoreBase/lib/3.5/packages.cf
 share/examples/cfengine/CoreBase/lib/3.5/paths.cf
 share/examples/cfengine/CoreBase/lib/3.5/processes.cf
-share/examples/cfengine/CoreBase/lib/3.5/reports.cf
 share/examples/cfengine/CoreBase/lib/3.5/services.cf
 share/examples/cfengine/CoreBase/lib/3.5/storage.cf
+share/examples/cfengine/CoreBase/lib/3.6/autorun.cf
 share/examples/cfengine/CoreBase/lib/3.6/bundles.cf
 share/examples/cfengine/CoreBase/lib/3.6/cfe_internal.cf
+share/examples/cfengine/CoreBase/lib/3.6/cfe_internal_hub.cf
 share/examples/cfengine/CoreBase/lib/3.6/cfengine_enterprise_hub_ha.cf
 share/examples/cfengine/CoreBase/lib/3.6/commands.cf
 share/examples/cfengine/CoreBase/lib/3.6/common.cf
@@ -72,38 +111,42 @@
 share/examples/cfengine/CoreBase/lib/3.6/packages.cf
 share/examples/cfengine/CoreBase/lib/3.6/paths.cf
 share/examples/cfengine/CoreBase/lib/3.6/processes.cf
-share/examples/cfengine/CoreBase/lib/3.6/reports.cf
 share/examples/cfengine/CoreBase/lib/3.6/services.cf
 share/examples/cfengine/CoreBase/lib/3.6/stdlib.cf
 share/examples/cfengine/CoreBase/lib/3.6/storage.cf
 share/examples/cfengine/CoreBase/lib/3.6/users.cf
 share/examples/cfengine/CoreBase/lib/3.6/vcs.cf
+share/examples/cfengine/CoreBase/lib/3.7/autorun.cf
+share/examples/cfengine/CoreBase/lib/3.7/bundles.cf
+share/examples/cfengine/CoreBase/lib/3.7/cfe_internal.cf
+share/examples/cfengine/CoreBase/lib/3.7/cfe_internal_hub.cf
+share/examples/cfengine/CoreBase/lib/3.7/cfengine_enterprise_hub_ha.cf
+share/examples/cfengine/CoreBase/lib/3.7/commands.cf
+share/examples/cfengine/CoreBase/lib/3.7/common.cf
+share/examples/cfengine/CoreBase/lib/3.7/databases.cf
+share/examples/cfengine/CoreBase/lib/3.7/edit_xml.cf
+share/examples/cfengine/CoreBase/lib/3.7/examples.cf
+share/examples/cfengine/CoreBase/lib/3.7/feature.cf
+share/examples/cfengine/CoreBase/lib/3.7/files.cf
+share/examples/cfengine/CoreBase/lib/3.7/guest_environments.cf
+share/examples/cfengine/CoreBase/lib/3.7/monitor.cf
+share/examples/cfengine/CoreBase/lib/3.7/packages.cf
+share/examples/cfengine/CoreBase/lib/3.7/paths.cf
+share/examples/cfengine/CoreBase/lib/3.7/processes.cf
+share/examples/cfengine/CoreBase/lib/3.7/services.cf
+share/examples/cfengine/CoreBase/lib/3.7/stdlib.cf
+share/examples/cfengine/CoreBase/lib/3.7/storage.cf
+share/examples/cfengine/CoreBase/lib/3.7/users.cf
+share/examples/cfengine/CoreBase/lib/3.7/vcs.cf
+share/examples/cfengine/CoreBase/modules/packages/apt_get
+share/examples/cfengine/CoreBase/modules/packages/pkgsrc
+share/examples/cfengine/CoreBase/modules/packages/yum
 share/examples/cfengine/CoreBase/promises.cf
-share/examples/cfengine/CoreBase/services/CVE_2015_0235/def.cf
-share/examples/cfengine/CoreBase/services/CVE_2015_0235/policy/CVE_2015_0235_inventory.cf
-share/examples/cfengine/CoreBase/services/autorun.cf
 share/examples/cfengine/CoreBase/services/autorun/hello.cf
-share/examples/cfengine/CoreBase/services/file_change.cf
-share/examples/cfengine/CoreBase/services/linux_kernel/def.cf
-share/examples/cfengine/CoreBase/services/linux_kernel/examples/promises.cf
-share/examples/cfengine/CoreBase/services/linux_kernel/policy/linux_kernel_params_inventory.cf
-share/examples/cfengine/CoreBase/services/sysctl/def.cf
-share/examples/cfengine/CoreBase/services/sysctl/policy/example_sysctl_data_from_policy.cf
-share/examples/cfengine/CoreBase/services/sysctl/policy/sysctl_conf_selective_present.cf
-share/examples/cfengine/CoreBase/services/sysctl/test.cf
-share/examples/cfengine/CoreBase/services/yum/def.cf
-share/examples/cfengine/CoreBase/services/yum/policy/yum_inventory.cf
-share/examples/cfengine/CoreBase/services/yum/policy/yum_inventory_yum_info_yum.cf
-share/examples/cfengine/CoreBase/services/yum/policy/yum_inventory_yum_repolist.cf
+share/examples/cfengine/CoreBase/services/main.cf
 share/examples/cfengine/CoreBase/sketches/meta/api-runfile.cf
 share/examples/cfengine/CoreBase/templates/host_info_report.mustache
 share/examples/cfengine/CoreBase/update.cf
-share/examples/cfengine/CoreBase/update/cfe_internal_dc_workflow.cf
-share/examples/cfengine/CoreBase/update/cfe_internal_local_git_remote.cf
-share/examples/cfengine/CoreBase/update/cfe_internal_update_from_repository.cf
-share/examples/cfengine/CoreBase/update/update_bins.cf
-share/examples/cfengine/CoreBase/update/update_policy.cf
-share/examples/cfengine/CoreBase/update/update_processes.cf
 share/examples/cfengine/abort.cf
 share/examples/cfengine/accessed_before.cf
 share/examples/cfengine/accessedbefore.cf
@@ -125,6 +168,7 @@
 share/examples/cfengine/bsdflags.cf
 share/examples/cfengine/bundle_return_values.cf
 share/examples/cfengine/bundlesmatching.cf
+share/examples/cfengine/bundlestate.cf
 share/examples/cfengine/canonify.cf
 share/examples/cfengine/cf2_integration.cf
 share/examples/cfengine/change_detect.cf
@@ -151,7 +195,9 @@
 share/examples/cfengine/create_filedir.cf
 share/examples/cfengine/createdb.cf
 share/examples/cfengine/customize_by_named_list.cf
+share/examples/cfengine/data_expand.cf
 share/examples/cfengine/data_readstringarray.cf
+share/examples/cfengine/data_regextract.cf
 share/examples/cfengine/datastate.cf
 share/examples/cfengine/defaults.cf
 share/examples/cfengine/defaults2.cf
@@ -180,6 +226,7 @@
 share/examples/cfengine/edit_template.cf
 share/examples/cfengine/edit_triggerclass.cf
 share/examples/cfengine/edit_xml.cf
+share/examples/cfengine/ensure_line_present_prepend_append.cf
 share/examples/cfengine/env.cf
 share/examples/cfengine/epimenides.cf
 share/examples/cfengine/escape.cf
@@ -193,6 +240,7 @@
 share/examples/cfengine/failedcommand.cf
 share/examples/cfengine/failsafe.cf
 share/examples/cfengine/file_change_detection.cf
+share/examples/cfengine/file_hash.cf
 share/examples/cfengine/file_owner_list_template.cf
 share/examples/cfengine/fileexists.cf
 share/examples/cfengine/filenames.cf
@@ -263,6 +311,7 @@
 share/examples/cfengine/loops.cf
 share/examples/cfengine/lsdir.cf
 share/examples/cfengine/maparray.cf
+share/examples/cfengine/mapdata.cf
 share/examples/cfengine/maplist.cf
 share/examples/cfengine/max-min-mean-variance.cf
 share/examples/cfengine/measure_log.cf
@@ -315,6 +364,7 @@
 share/examples/cfengine/package_windows_feature.cf
 share/examples/cfengine/package_yum.cf
 share/examples/cfengine/package_zypper.cf
+share/examples/cfengine/packagesmatching.cf
 share/examples/cfengine/parallel_exec.cf
 share/examples/cfengine/parseintrealstringarray.cf
 share/examples/cfengine/parsestringarray.cf
@@ -332,10 +382,13 @@
 share/examples/cfengine/process_restart.cf
 share/examples/cfengine/process_restart_basic.cf
 share/examples/cfengine/process_signalling.cf
+share/examples/cfengine/processes_define_class_based_on_process_runtime.cf
 share/examples/cfengine/product.cf
 share/examples/cfengine/promise_knowledge.cf
 share/examples/cfengine/promises.cf
 share/examples/cfengine/randomint.cf
+share/examples/cfengine/readcsv.cf
+share/examples/cfengine/readdata.cf
 share/examples/cfengine/readfile.cf
 share/examples/cfengine/readintrealstringlist.cf
 share/examples/cfengine/readlist.cf
@@ -397,6 +450,7 @@
 share/examples/cfengine/string_downcase.cf
 share/examples/cfengine/string_head.cf
 share/examples/cfengine/string_length.cf
+share/examples/cfengine/string_mustache.cf
 share/examples/cfengine/string_reverse.cf
 share/examples/cfengine/string_split.cf
 share/examples/cfengine/string_tail.cf

cvs diff -r1.8 -r1.9 pkgsrc/sysutils/cfengine3/distinfo (expand / switch to context diff)
--- pkgsrc/sysutils/cfengine3/distinfo 2015/11/04 01:32:08 1.8
+++ pkgsrc/sysutils/cfengine3/distinfo 2015/12/08 17:15:21 1.9
@@ -1,12 +1,11 @@
-$NetBSD: distinfo,v 1.8 2015/11/04 01:32:08 agc Exp $
+$NetBSD: distinfo,v 1.9 2015/12/08 17:15:21 fhajny Exp $
 
-SHA1 (cfengine-3.6.5.tar.gz) = 7329ab681bf39e4a607003f56df56fe0c6226406
+SHA1 (cfengine-3.7.2.tar.gz) = 9f454db3ce9c86c6c230bfd5bba534970ada7893
-RMD160 (cfengine-3.6.5.tar.gz) = 323d047f8dffc37924d82e4dbcd4d75172b41ea6
+RMD160 (cfengine-3.7.2.tar.gz) = 83d48c484e3a8132fa0bf331402aa8305dab125c
-SHA512 (cfengine-3.6.5.tar.gz) = c024fcf2c28ac30884f91964310619939b5e9ae371e8c51ef6602eeee6ca147c7d8522916ab287a179161ddde6979ffe0a97acdf6cde340a128ea9f3397eb263
+SHA512 (cfengine-3.7.2.tar.gz) = 8b4d0dac81cb3734489e3e1d60a034c3074d710f35a6c2ab35cffe9c066a63c3214b062ef4116ff3ef46461c8ce53ebb02c6513cb49f9edf2c9a81f4679066e6
-Size (cfengine-3.6.5.tar.gz) = 2011114 bytes
+Size (cfengine-3.7.2.tar.gz) = 2114764 bytes
-SHA1 (masterfiles-3.6.5.tar.gz) = f23e8e61ccef9b25a59ca6230406fba36d6b52ac
+SHA1 (cfengine-masterfiles-3.7.2.tar.gz) = 8b00f9e81815890220d7e8ad5209cdf1fc04b07d
-RMD160 (masterfiles-3.6.5.tar.gz) = 538ec2192de35489110d101a7644d3a9262ccd51
+RMD160 (cfengine-masterfiles-3.7.2.tar.gz) = 2f67dd56f8b82575c799a1d9a83b44bd67d3bc38
-SHA512 (masterfiles-3.6.5.tar.gz) = 90ee42d1dbe707356656fbd26930eaa94882537236914a355a11e2f636ee2b4ae931cf083df8e9bfa94336551263e15b8ede372f384460ce491f0517c12a7505
+SHA512 (cfengine-masterfiles-3.7.2.tar.gz) = e2a6ceba4db90e6b2cd4f30fc2c276012660aca8a76fbd5bbc3debd8e6226cd5f8f270f5936b38e1ccd36cee706fd697bfde5c96739bde38d8c11f4ef3f0f86b
-Size (masterfiles-3.6.5.tar.gz) = 128384 bytes
+Size (cfengine-masterfiles-3.7.2.tar.gz) = 449943 bytes
-SHA1 (patch-ext_Makefile.in) = 2a231187b2e3f237cd856d990bca9f2472817074
+SHA1 (patch-ext_Makefile.in) = b0f8c773b3351c949fe33028a3122c5673d8778d
-SHA1 (patch-libenv_unix_iface.c) = f6fbb791be6283cd84a70674c58b166dac6b7c41

File Added: pkgsrc/sysutils/cfengine3/files/pkgsrc
#!/bin/sh

## Licensed under:
## MIT Public License
## http://www.opensource.org/licenses/MIT

## Copyright (c) 2015, Brian Bennett <bahamat@digitalelf.net>

## pkgsrc package module for cfengine

# Set up mock environment if necessary
if [ -n $CFENGINE_TEST_PKGSRC_MOCK ]; then
    alias pkgin='./mock_pkgin'
    alias pkg_info='./mock_pkg_info'
fi

# Add pkgsrc paths
export PATH=@PREFIX@/bin:@PREFIX@/sbin:$PATH
export MACHINE_ARCH=@MACHINE_ARCH@
export PKG_ROOT=@PREFIX@
export PKG_INSTALL_CONF=@PKG_SYSCONFBASE@/pkg_install.conf

LEVEL=0

fatal () {
    echo "ErrorMessage=$@"
    exit 2
}

warn () {
    [ $LEVEL -gt 0 ] && echo "[TRACE]: $*" >&2
}

supports_api_version () {
    echo 1
}

repo_install () {
    # If a version number is specified, insert a dash between the name and
    # version
    [ -n "$Version" ] && ver="-$Version"
    pkgin -y in "${Name}${ver}" > /dev/null
    if [ $? -gt 0 ]; then
        fatal "Error installing ${Name}${ver}"
    fi
}

file_install () {
    # The specified config file might, for example override signature reqs:
    # VERIFIED_INSTALLATION=never
    pkg_add -U -C "$PKG_INSTALL_CONF" "$File" > /dev/null
    if [ $? -gt 0 ]; then
        echo "Error installing ${File}"
    fi
}

remove () {
    # If a version number is specified, insert a dash between the name and
    # version
    [ -n "$Version" ] && ver="-$Version"
    pkgin -y rm "${Name}${ver}" > /dev/null
}

list_installed () {
    parse_pkg_data "$(pkgin -p list)"
}

list_updates () {
    # The difference between list-updates and list-updates-local, it seems
    # is that list-updates expects to refresh from the upstream repo.
    pkgin -f update >&2
    list_updates_local
}

list_updates_local () {
    parse_pkg_data "$(pkgin -pl '<' ls)"
}

get_package_data () {
    if echo "$File" | grep '/' >/dev/null; then
        # If there's a / in $File then we'll expec this to be a 'file' install.
        # This is reliable because 1) pkgsrc packages don't have / in the name
        # and because cfengine can't install a PackageType=file from a relative
        # path.
        #
        # The package will be installed with pkg_add later, which also supports
        # arbitrary HTTP locations.
        echo "PackageType=file"
        # To appease cfengine, we'll take the basename of the package passed.
        echo "Name=$(echo "$File" | sed 's/.*\///g')"
    else
        # If $File does not contain /, it must be in an existing remote repo,
        # because cfengine can't install files from relative paths.
        echo "PackageType=repo"
        # Cfengine expects a *single* matching package. So sort and return the
        # most recent. If a version is specified it can partial match, in which
        # case we'll again take the latest. If there's no match on the name
        # or version, return nothing.
        # There's possibly a bug here because we're already emitting that the
        # PackageType is repo.
        parse_pkg_data "$(pkgin -pP avail | grep "^$File" | grep "$Version;" | sort -n | tail -1)"
    fi
}

parse_pkg_data () {
    # This is a bit tricky.
    # pkgin is called with parsable format and separates fields with ';'.
    # Packages are further sub-split between name and version with '-', but
    # package names may also contain '-'. To complicate matters, package
    # versions can have '-' as well.

    # Take the example package mozilla-rootcerts-1.0.20141117nb1
    # $1 is the package-version compound. Discard the description in $2..
    # Split $1 on 'separator' and store in array 'package'. Return length 'l'
    # 'version' is the last element of array 'package'
    # Now the tricky bit. We've split the package name, so now must reassemble
    # it with dashes in tact, without the version number.
    # For each element less 1 in 'package', if this is the first iteration
    # print the element. On subsequent passes print "-element"
    # Finally print the version and the machine architecture as well.
    echo "$*" | awk -F';' '
    {
        separator="-"
        l=split($1,package,separator)
        version=package[l]
        printf("Name=")
        for (i=1ength;i<l;i++) {
            if (i>1) {
                printf("-")
            }
            printf("%s",package[i])
        }
        printf("\nVersion=%s\n",version)
        printf("Architecture=%s\n",ENVIRON["MACHINE_ARCH"])
    }'
}

# Cfengine passes data on STDIN. Absorb that and convert to shell variables.
while IFS= read -r -u 0 line; do
  eval "$line"
  # options can be passed multiple times so we need to avoid clobbering
  # previous instances. Plus, what we really want to eval is the value of
  # each option.
  if [ -n "$options" ]; then
    eval "$options"
  fi
done

case "$1" in
    supports-api-version) supports_api_version;;
    repo-install) repo_install;;
    file-install) file_install;;
    remove) remove;;
    list-installed) list_installed;;
    list-updates) list_updates;;
    list-updates-local) list_updates_local;;
    get-package-data) get_package_data;;
    *) fatal "Invalid operation";;
esac

File Added: pkgsrc/sysutils/cfengine3/files/smf/manifest.xml
<?xml version="1.0"?>
<!DOCTYPE service_bundle SYSTEM "/usr/share/lib/xml/dtd/service_bundle.dtd.1">
<service_bundle type="manifest" name="cfexecd">
  <service name="@SMF_PREFIX@/cfengine" type="service" version="1">
    <dependency name="network" grouping="require_all" restart_on="error" type="service">
      <service_fmri value="svc:/milestone/network:default" />
    </dependency>
    <dependency name="filesystem" grouping="require_all" restart_on="error" type="service">
      <service_fmri value="svc:/system/filesystem/local" />
    </dependency>
    <property_group name="startd" type="framework">
      <propval name="duration" type="astring" value="contract" />
      <propval name="ignore_error" type="astring" value="core,signal" />
    </property_group>
    <property_group name="application" type="application"></property_group>
    <instance name='cfexecd' enabled='false'>
      <exec_method type="method" name="start" exec="@PREFIX@/sbin/cf-execd" timeout_seconds="60" />
      <exec_method type="method" name="stop" exec=":kill" timeout_seconds="60" />
      <template>
        <common_name>
          <loctext xml:lang="C">CfEngine Execution Daemon</loctext>
        </common_name>
      </template>
    </instance>
    <instance name='cfmonitord' enabled='false'>
      <exec_method type="method" name="start" exec="@PREFIX@/sbin/cf-monitord" timeout_seconds="60" />
      <exec_method type="method" name="stop" exec=":kill" timeout_seconds="60" />
      <template>
        <common_name>
          <loctext xml:lang="C">CfEngine Monitor Daemon</loctext>
        </common_name>
      </template>
    </instance>
    <instance name='cfserverd' enabled='false'>
      <exec_method type="method" name="start" exec="@PREFIX@/sbin/cf-serverd" timeout_seconds="60" />
      <exec_method type="method" name="stop" exec=":kill" timeout_seconds="60" />
      <template>
        <common_name>
          <loctext xml:lang="C">CfEngine Server Daemon</loctext>
        </common_name>
      </template>
    </instance>
    <stability value="Evolving" />
  </service>
</service_bundle>

cvs diff -r1.2 -r1.3 pkgsrc/sysutils/cfengine3/patches/patch-ext_Makefile.in (expand / switch to context diff)
--- pkgsrc/sysutils/cfengine3/patches/patch-ext_Makefile.in 2015/04/07 08:43:35 1.2
+++ pkgsrc/sysutils/cfengine3/patches/patch-ext_Makefile.in 2015/12/08 17:15:21 1.3
@@ -1,14 +1,14 @@
-$NetBSD: patch-ext_Makefile.in,v 1.2 2015/04/07 08:43:35 fhajny Exp $
+$NetBSD: patch-ext_Makefile.in,v 1.3 2015/12/08 17:15:21 fhajny Exp $
 
 No use for rpmvercmp.
 
---- ext/Makefile.in.orig	2015-04-03 10:59:08.525934907 +0000
+--- ext/Makefile.in.orig	2015-11-27 23:12:07.000000000 +0000
 +++ ext/Makefile.in
-@@ -79,7 +79,6 @@ POST_UNINSTALL = :
+@@ -35,7 +35,6 @@ POST_UNINSTALL = :
  build_triplet = @build@
  host_triplet = @host@
  target_triplet = @target@
 -sbin_PROGRAMS = rpmvercmp$(EXEEXT)
  subdir = ext
- DIST_COMMON = $(srcdir)/Makefile.in $(srcdir)/Makefile.am \
+ DIST_COMMON = $(srcdir)/Makefile.am $(srcdir)/Makefile.in
- 	$(top_srcdir)/depcomp
+ ACLOCAL_M4 = $(top_srcdir)/aclocal.m4

File Deleted: pkgsrc/sysutils/cfengine3/patches/Attic/patch-libenv_unix_iface.c