https://github.com/lifailon/get-invent-sqlite
Module for remote and local hardware inventory via WMI and out to database SQLite
https://github.com/lifailon/get-invent-sqlite
hardware inventory powershell powershell-module sqlite windows wmi
Last synced: 6 months ago
JSON representation
Module for remote and local hardware inventory via WMI and out to database SQLite
- Host: GitHub
- URL: https://github.com/lifailon/get-invent-sqlite
- Owner: Lifailon
- Created: 2023-02-26T11:44:51.000Z (over 2 years ago)
- Default Branch: rsa
- Last Pushed: 2023-03-03T15:45:04.000Z (over 2 years ago)
- Last Synced: 2025-01-16T09:03:43.181Z (9 months ago)
- Topics: hardware, inventory, powershell, powershell-module, sqlite, windows, wmi
- Language: PowerShell
- Homepage:
- Size: 1.41 MB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Get-Invent
Модуль для удаленного и локального просмотра характеристик физического оборудования: **OS, Mother Board, CPU, RAM, Physical Disk, Logical Disk, Video Card, Network Adapter**.`Get-Help Get-Invent` \
`Get-Module Get-Invent | fl Description` \
`Get-Invent localhost` по умолчанию \
`Get-Invent -srv server-01` \
`Get-Invent -Full server-01` полный отчет (версия 1.1) \
`Get-Invent -Full -SQL server-01` вывод в базу данных SQLite (версия 1.2)
## Out to database SQLite
* Зависимости: **модуль [MySQLite](https://github.com/jdhitsolutions/MySQLite)**
При создании БД проверяется наличие бд по указанному пути (по умолчанию рабочий стол текущего пользователя и файл с именем **Get-Invent.db**) , если она отсутствует, то создается новая база данных, по такому же принципу проверяются и создаются таблицы для **CPU** (базовый отчет), **Memory**, **PhysicalDisk** и **VideoCard**, и заполняются соответствующими значениями из полного отчета (**-Full**). При последующем наполнении БД информаций с других хостов, необходимо в ручную прописать в к ней путь (ключ **-Path**), в каждой таблице первое значение **Host** присваивается имя компьютера, по которому при фильтрации по нужной модели можно легко индентифицировать имя хоста.
### Для опраса сразу нескольких хостов, и наполнения базы данных используйте слующую конструкцию:
Создать лист, который можно использовать в будущем: \
`$HostsList = "$home\desktop\Host-List.txt"` \
`@("server-01","server-02","server-03") | Out-File $HostsList`Прочитать список серверов и добавить его в цикл: \
`$Hosts = Get-Content $HostsList` \
`foreach ($srv in $hosts) {` \
`Get-Invent -srv $srv -Full -SQL` \
`}`**Пример базы данных: [Get-Invent.db](https://github.com/Lifailon/Get-Invent-SQLite/blob/rsa/Database/Get-Invent.db)**



