Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/trinitycore/wowpacketparser
World of Warcraft Packet Parser
https://github.com/trinitycore/wowpacketparser
c-sharp dotnet hacktoberfest parser sniff wow wpp
Last synced: 1 day ago
JSON representation
World of Warcraft Packet Parser
- Host: GitHub
- URL: https://github.com/trinitycore/wowpacketparser
- Owner: TrinityCore
- License: gpl-3.0
- Created: 2011-06-29T00:08:26.000Z (over 13 years ago)
- Default Branch: master
- Last Pushed: 2025-01-12T20:24:08.000Z (9 days ago)
- Last Synced: 2025-01-13T06:00:30.532Z (8 days ago)
- Topics: c-sharp, dotnet, hacktoberfest, parser, sniff, wow, wpp
- Language: C#
- Homepage:
- Size: 67 MB
- Stars: 438
- Watchers: 101
- Forks: 363
- Open Issues: 57
-
Metadata Files:
- Readme: README.md
- License: COPYING
Awesome Lists containing this project
README
WowPacketParser (WPP)
=====================[![GitHub license](https://img.shields.io/github/license/TrinityCore/WowPacketParser.svg?style=flat-square)](https://github.com/TrinityCore/WowPacketParser/blob/WowPacketParser/COPYING)
[![Build Status AppVeyor](https://img.shields.io/appveyor/ci/DDuarte/wowpacketparser-191/master.svg?style=flat-square)](https://ci.appveyor.com/project/DDuarte/wowpacketparser-191)Usage
-----* Compile WowPacketParser using Visual Studio 2022 (with .NET 9.0 SDK) or .NET 9.0 SDK.
Alternatively you can download compiled binaries from the links [below](#nightly-builds).
* Edit `WowPacketParser.dll.config` to fit your needs.
* Drag one or more files (.pkt or .bin) to `WowPacketParser.exe`.
* Command line usage: `WowPacketParser.exe [--ConfigFile path --Option1 value1 ...] filetoparse1 ...`##### Databases
Optionally, WPP can connect to two kinds of MySQL databases: `world` from [TrinityCore](https://github.com/TrinityCore/TrinityCore)
and its own database, `WPP`. This can be enabled by setting ``
in the `.config` file. Remember to set `` in accordance with the targeted version of the core.The `world` database is used when creating SQL files after parsing to produce the minimum number of
changes needed to update the database. For example, if only the faction of a creature that appears
in the sniff needs to be updated, the produced SQL files will contain an UPDATE query, instead of
a full INSERT to the table `creature_template`. WPP does not modify this database directly, all the
tentative changes will be written to the output SQL files.The `WPP` database is used to feed additional data that WPP may use while parsing. For example, in
the output text files, the spell name can be displayed next to spell ids:> ServerToClient: SMSG_SPELL_START (0x2BB8) Length: 96 ConnIdx: 0 Time: 01/01/2016 00:22:33.235 Number: 701
> (Cast) CasterGUID: Full: 0x03691F00000000000000000000000001 Player/0 R3558/S0 Map: 0 Low: 1
> (Cast) SpellID: **2479 (Honorless Target)**
> (Cast) CastFlags: 15This is available for a lot of other named entities (achievements, creatures, quests, etc.). The SQL
files required for this database is in the `SQL` directory. `create_WPP.sql` creates the database
and `wpp_data_objectnames.sql` has some data to fill the database.Nightly Builds
--------------
.NET 9.0 SDK or .NET 9.0 Runtime is needed![Download .NET 9.0 here!](https://dotnet.microsoft.com/download/dotnet/9.0)
##### Windows
- Visual Studio 2022
- [Debug](https://nightly.link/TrinityCore/WowPacketParser/workflows/gh-build/master/WPP-windows-latest-Debug.zip)
- [Release](https://nightly.link/TrinityCore/WowPacketParser/workflows/gh-build/master/WPP-windows-latest-Release.zip)
##### Linux (Ubuntu)
- [Debug](https://nightly.link/TrinityCore/WowPacketParser/workflows/gh-build/master/WPP-ubuntu-latest-Debug.zip)
- [Release](https://nightly.link/TrinityCore/WowPacketParser/workflows/gh-build/master/WPP-ubuntu-latest-Release.zip)
##### macOS (Arm64)
- [Debug](https://nightly.link/TrinityCore/WowPacketParser/workflows/gh-build/master/WPP-macos-14-Debug.zip)
- [Release](https://nightly.link/TrinityCore/WowPacketParser/workflows/gh-build/master/WPP-macos-14-Release.zip)
Docker (experimental)
---------------------It is possible run WPP on Docker using the `trinitycore/wpp` image.
To build image:
```
DOCKER_BUILDKIT=1 docker build . -t trinitycore/wpp
```To configure:
Copy WowPacketParser/App.config as template and edit as your needs.
To run:
```
docker run -it --rm -v /place/where/sniffs/are/kept:/sniffs -v /full/path/App.config:/app/WowPacketParser.dll.config trinitycore/wpp /sniffs/sniffname.pkt
```*/place/where/sniffs/are/kept* should your local directory containing the .pkt file and *sniffname.pkt* the file to be parsed.
Output (.txt/.sql) of the parser will be added to */place/where/sniffs/are/kept*.
Copyright & Third Party
-----------------------
##### WowPacketParser
License: GPLv3Read file [COPYING](COPYING).
##### Third Party
The third party libraries have their own way of addressing authorship, and the authorship of commits importing/ updating
a third party library reflects who did the importing instead of who wrote the code within the commit.###### NuGet libraries:
Copyright information of third party libraries provided through NuGet can be obtained by checking https://www.nuget.org/
###### Provided third party libraries:
DBFileReaderLib, 2019-2022 wowdev, located at https://github.com/wowdev/DBCD