Introduction
This project primarily leverages Graph Convolutional Networks (GCN) to detect unchecked external call vulnerabilities in DApps. By analyzing the structure and code of smart contracts, we can identify potential security incidents and enhance the security of DApps. The process involves converting smart contracts into Abstract Syntax Trees (ASTs) to extract syntactic and semantic information from the source code. Based on this information, we derive the call graph of the source code, transform it into a graph structure, and input it into the deep learning network we developed for training.

Features
AST Generation: Use py-solc-x to convert the source code into an AST and analyze it to obtain the source code call graph.
Vulnerability Detection: Build a GCN network to detect unchecked external call vulnerabilities in DApps.
GCN Analysis: Analyze the structure of the source code and contextual information using the GCN network.

Folder Structure
Data: Contains call graph data derived from the source code.
Model: Includes the GCN model and baseline comparison models.

Usage
Run the script in different modes: train, test. Below are the examples of how to use each mode.
1. Run Mode
python main_file.py
3. Arguments
All arguments data in pares_1.py
