Skip to content

Lite OCSInventory-NG Agent for Linux (Unofficial)

License

Notifications You must be signed in to change notification settings

ebilbil/ocs-agent

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

CodeFactor Language grade: C/C++

Linux lite inventory agent

A couple of years ago, where I work, we started using OCS Inventory NG, which is a really useful application in enterprises. It allows system administrators to inventory servers and workstations, in order to plan obsolescenses and investments. In the last two years, we also started using Thinstation to recycle old computers as Citrix terminals, by booting them via PXE. Unfortunately, the OCS Inventory Agent for Unix is written in Perl. The Perl interpreter is quite big (~16MB) and can't be put into the Thinstation images without getting a performance hit on booting. Moreover, the agent doesn't work on a system with a read only filesystem (actually, the filesystem is read-write, but changes are lost when the terminal is powered off, since it's a in-RAM filesystem). So I decided to write a small agent in C++ to be able to inventory also those machines which I was not able to do with the official agent. The agent is not complete yet, but it can already produce an inventory of the machine and send it to the OCSInventory server, or save it locally. The compiled program weights around 300kb on disk for now, and only has zlib and openssl as dependency, which are already present on any Thinstation installation. It also uses tinyxml2, a very small and efficient XML parsing/writing library, linked statically into the executable. This is not the official OCSInventory NG agent, which can be found here: https://github.com/OCSInventory-NG/UnixAgent

Usage:
  -h, --help                         Print usage
  -c, --conf <config_file>           Specify configuration file
  -s, --server <server>              Specify OCSInventory server url
                                     If the server needs authentication, use the standard syntax <user>:<password>@<host>
  -l, --local <folder>               Don't send inventory, instead save a local copy in the specified file or folder
      --stdout                       Don't send inventory, print it to stdout
  -t, --tag <TAG>                    Specify tag. Will be ignored by server if a value already exists
      --nosoftware                   Do not retrieve installed software

      --agent-string <string>        Specify custom HTTP agent string

  -d, --daemonize                    Detach from running terminal
  -w, --wait <s>                     Wait for the specified amount of seconds before building the inventory

      --log <option>                 Specify error log output (STDERR / SYSLOG).
                                     Default is standard error if attached to a terminal, otherwise syslog. 
  -v, --verbose                      Verbose mode
      --version                      Print version and exit

    --use-current-time-in-device-ID  Use current time in the device ID, instead of the BIOS Date.
                                     No need to use this option unless you know why you need it.

The -l and -s option are mutually exclusive.
If no server or output file is specified, either via the -s/-l option or via configuration file (option -c), the program will exit without doing anything.

Examples:
  Print inventory to standard output :
    ocsinventory-agent --stdout

  Send inventory to server http://ocsinventory-ng/ocsinventory :
    ocsinventory-agent --server http://ocsinventory-ng/ocsinventory

  Use the configuration file /etc/ocsinventory-ng.conf :
    ocsinventory-agent --conf /etc/ocsinventory-ng.conf

  Send inventory to server https://ocsinventory-ng/ocsinventory which requires http basic authentication :
    ocsinventory-agent --server https://user:password@ocsinventory-ng/ocsinventory

  Save a local inventory to /var/tmp/inventoryFile.xml :
    ocsinventory-agent --local /var/tmp/inventoryFile.xml

  Save a local inventory to /var/tmp/<device_id>.xml :
    ocsinventory-agent --local /var/tmp/

About

Lite OCSInventory-NG Agent for Linux (Unofficial)

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • HTML 60.2%
  • C++ 23.3%
  • C 5.9%
  • Objective-C 4.8%
  • JavaScript 2.7%
  • CSS 1.9%
  • Other 1.2%