User story #8919
closedRemove modifications made to the inventory by the agent
Description
- Trigger a fusioninventory-agent run and store the generated inventory XML
- Modify it using the agent to add custom entries
- Send it to the Rudder server
It is a fact that as of now, most of the additions we do using the agent are obsolete, since they are added by FusionInventory itself as part of standard inventory tasks.
We should clean up our custom additions so we may someday be able to eat a vanilla fusioninventory report !
The addition is done in the system technique "techniques/system/inventory/1.0/fusionAgent.st"
The added fields are:
- on android, <OPERATINGSYSTEM> and <ACCESSLOG>. We don't care of that, because Android support must be upgraded in all case. So we should directly patch fusion if still needed in place of adding something fusion is supposed to do (existing tag)
- <VMS><VM></VM></VMS>: not mandatory for Rudder, superseeded by <VIRTUALMACHINES> tag, much more complete and supported since BEFORE Rudder 2.11 / fusionagent 2.3.6 (they are their since at least 2.1.0)
- <USERSLIST><USER></USER></USERLIST>: not mandatory, superseeded by fusion LOCAL_USERS (same as VMS)
- UUID, USER, AGENTSNAME, CFKEY, POLICY_SERVER, HOSTNAME: there are superseeded by the <RUDDER> tag provided in fusion in no more used for real since BEFORE 2.11
- PROCESSORS: it is NO MORE USED since AT LEAST Rudder 2.11
- MACHINEID: It is the same think that in <HARDWARE><UUID>. It used to be buggy with VM, but our is, too, and since 2.11 AT LEAST, if the MACHINEID field does not exists or is empty, we are derivating one from node UUID. So it may lead to some regeneration of machines, but that shouldn't break anything
- SERVER_ROLES:
exists only in added tag by CFEngineIt was done and in 4.1, it is both under <RUDDER> and at the end in added tags.
So, given all the above, the only actions to do are:
- add SERVER_ROLES to fusioninventory <RUDDER> tag in Rudder 3.1. It is a bug that it wasn't added in that place but in a deprecated one. Add the corresponding parsing in ldap-inventory. On the server, parse that and fall-back with parsing the one outside <RUDDER>
- add support for HARDWARE/UUID, LOCAL_USERS and VIRTUALMACHINES in ldap-inventory with fallback to MACHINEID / USERLIST / VMS in Rudder 3.1
With that, we are able to safely remove ALL added things for nodes up-to-date in 3.1, and as soon as 3.1 - but of course, we won't do it before 4.0.
So, removing addition in 4.0, with the corresponding update in fusion/ldap-inventory in 3.1, covers the cases:- "last Rudder 3.1 or Rudder 4.0 with nodes in last 3.1, 3.2, or 4.0": as explained, all is good in that case.
- "Rudder 4.0 in other case": as we continue fall-back parsing old place for SERVER_ROLE, LOCAL_USERS and VIRTUALMACHINES, it should just work as before.
- "non last Rudder 3.1 with nodes 4.0": none of the missing tag is mandatory and as soon as the node get its system technique, it will add them (so at worst, first inventory is missing information). We could also keep the old addition only in initial promises for the first time (now that they are merged :)
Updated by François ARMAND over 8 years ago
- Related to User story #8127: On agent, check inventory before sending it to Rudder server added
Updated by François ARMAND over 8 years ago
- Description updated (diff)
We have in #8127 all the mandatory fields. We can see than NONE of the added fields are mandatory.
Also, explained what is exactly going on for each tags, in each version.
Updated by François ARMAND over 8 years ago
- Description updated (diff)
The proposed solution does not handle the case where a node was on 3.1-pre-fusion-updated, and is updated to system technique post-removal of the added option, then the node won't be able to provide SERVER_ROLES. That mean that we won't be able to know the role at all in such a case.
The only case where it is a problem is on relay servers installed before the patch, with a root server after the patch, or in a multi-version multi-instance rudder installation (which seems to be asking for problem)
So, we have three possibilities:
1/ keep the added extension in 4.0 for server_roles only. We will remove them in a long future away (until we don't support anymore relay on a pre-patch version, at least until end of 3.1 support)
2/ impose user to upgrade relay servers before upgrading Rudder server, and rudder-multi-instance install in one go;
3/ don't care for relay server, as server role for relay server is just an information, and users which rely on that information are able to switch first relay, then Rudder.
I really don't like 1/, because it means supporting a complexe addition for just one missing case. But at least, we won't have to support it on non cfengine agent, as it is relevant only for server with rudder roles.
3/ seem a little to surprising for people with group based on server_roles and who don't carefully read upgrade information. 2/ may not be ok because relay servers may be in difficult place to reach.
Thougts ?
Updated by François ARMAND over 8 years ago
We also need to addd the agent timezone in Rudder extension, because it is blocking for #7092.
Updated by François ARMAND over 8 years ago
- Related to Bug #7092: Include Timezone in Node Info added
Updated by François ARMAND over 8 years ago
- Related to User story #7093: Include Timezone in Inventory added
Updated by François ARMAND over 8 years ago
- Target version changed from 4.0.0~rc2 to 4.1.0~beta1
Updated by Vincent MEMBRÉ about 8 years ago
- Target version changed from 4.1.0~beta1 to 4.1.0~beta2
Updated by Vincent MEMBRÉ about 8 years ago
- Related to Bug #8921: The FusionInventory Rudder task does not work on Windows and will not return server roles added
Updated by Vincent MEMBRÉ almost 8 years ago
- Target version changed from 4.1.0~beta2 to 4.1.0~beta3
Updated by Vincent MEMBRÉ almost 8 years ago
- Target version changed from 4.1.0~beta3 to 4.1.0~rc1
Updated by François ARMAND almost 8 years ago
- Target version changed from 4.1.0~rc1 to 4.2.0~beta1
Updated by Alexis Mousset over 7 years ago
- Target version changed from 4.2.0~beta1 to 4.2.0~beta2
Updated by Vincent MEMBRÉ over 7 years ago
- Target version changed from 4.2.0~beta2 to 4.2.0~beta3
Updated by Vincent MEMBRÉ over 7 years ago
- Target version changed from 4.2.0~beta3 to 4.2.0~rc1
Updated by Vincent MEMBRÉ over 7 years ago
- Target version changed from 4.2.0~rc1 to 4.2.0~rc2
Updated by Vincent MEMBRÉ over 7 years ago
- Target version changed from 4.2.0~rc2 to 4.2.0
Updated by Vincent MEMBRÉ over 7 years ago
- Target version changed from 4.2.0 to 4.2.1
Updated by Vincent MEMBRÉ over 7 years ago
- Target version changed from 4.2.1 to 4.2.2
Updated by Vincent MEMBRÉ about 7 years ago
- Target version changed from 4.2.2 to 4.2.3
Updated by Vincent MEMBRÉ about 7 years ago
- Target version changed from 4.2.3 to 4.2.4
Updated by François ARMAND almost 7 years ago
- Target version changed from 4.2.4 to 4.3.0~rc1
It can be done when #8920 is merged, safe for server_role) but that will simplify a lot of things.
Note for MACHINEID: we don't use it for the machine id (i.e the node container link) at all since at least 3.1. So actually, MACHINEID is really the motherboarduuid, it is set in that place, but it is less reliable than newer fusion HARDWARE/UUID.
Updated by François ARMAND almost 7 years ago
- Description updated (diff)
So, in 4.3 we can:
- only parse <RUDDER> tag (and its children)
- remove all added tags at the end of the inventory file \o/
Updated by François ARMAND almost 7 years ago
- Status changed from New to In progress
Updated by François ARMAND almost 7 years ago
Work in progess here: https://github.com/fanf/ldap-inventory/commit/e58c9772e48cb79cb948b0e4f9999db07d7a522c
Updated by François ARMAND almost 7 years ago
- Status changed from In progress to Pending technical review
- Assignee changed from François ARMAND to Vincent MEMBRÉ
- Pull Request set to https://github.com/Normation/ldap-inventory/pull/129
Updated by Rudder Quality Assistant almost 7 years ago
- Assignee changed from Vincent MEMBRÉ to François ARMAND
Updated by Vincent MEMBRÉ almost 7 years ago
- Target version changed from 4.3.0~rc1 to 4.3.0~rc2
Updated by François ARMAND almost 7 years ago
- Status changed from Pending technical review to Pending release
Applied in changeset ldap-inventory|88df5ccbab5f82958fe65d7256eb719ef53920f6.
Updated by Vincent MEMBRÉ almost 7 years ago
- Status changed from Pending release to Released
This bug has been fixed in Rudder 4.3.0~rc2 which was released today.
- 4.3.0~rc2: Announce Changelog
- Download: https://www.rudder-project.org/site/get-rudder/downloads/