mushorg / conpot

ICS/SCADA honeypot
GNU General Public License v2.0
1.24k stars 414 forks source link

Flatten template directory structure? #536

Open srenfo opened 3 years ago

srenfo commented 3 years ago

For simplifications beyond #534 the template directories could be flattened a bit.

Currently:

conpot/templates
├── default
│   ├── bacnet
│   │   └── bacnet.xml
│   ├── enip
│   │   └── enip.xml
│   ├── ftp
│   │   └── ftp.xml
│   ├── http
│   │   ├── htdocs
│   │   │   ├── tests
│   │   │   └── ...
│   │   ├── statuscodes
│   │   │   └── ...
│   │   └── http.xml
│   ├── ipmi
│   │   └── ipmi.xml
│   ├── ...
│   └── template.xml
...

Suggestion: Move the protocol XMLs up by one level. Keep the subdirectories for protocols that want auxiliary files.

conpot/templates
├── default
│   ├── bacnet.xml
│   ├── enip.xml
│   ├── ftp.xml
│   ├── http
│   │   ├── htdocs
│   │   │   ├── tests
│   │   │   └── ...
│   │   ├── statuscodes
│   │   │   └── ...
│   ├── http.xml
│   ├── ipmi.xml
│   ├── ...
│   └── template.xml
...

Pros: Easier to navigate and thus easier to modify and to keep track of.

Cons: It may look odd to have both an http.xml and an http directory. Also, template.xml is now on the same level as the protocol XMLs despite being one level above them hierarchically.

glaslos commented 3 years ago

How about stuffing all protocols into a flat protocol folder with http as suggested? Kind of a middle ground?

srenfo commented 3 years ago

Do you mean their XMLs or their auxiliary data?

Either way this is not a big deal, but we were talking about simplifying things anyway :see_no_evil:

glaslos commented 3 years ago

This was my suggestion. It would keep the visibility for the template.xml

conpot/templates
├── default
│   ├── protocols
│   │   ├── bacnet.xml
│   │   ├── enip.xml
│   │   ├── ftp.xml
│   │   ├── http
│   │   │   ├── htdocs
│   │   │   │   ├── tests
│   │   │   │   └── ...
│   │   │   ├── statuscodes
│   │   │   │   └── ...
│   │   ├── http.xml
│   │   ├── ipmi.xml
│   │   ├── ...
│   └── template.xml