mirror of
https://github.com/Qv2ray/Qv2ray.git
synced 2025-05-20 19:00:22 +08:00
327 lines
11 KiB
C++
327 lines
11 KiB
C++
#ifndef V2CONFIG_H
|
|
#define V2CONFIG_H
|
|
#include <list>
|
|
#include <string>
|
|
|
|
#include <x2struct/x2struct.hpp>
|
|
using namespace x2struct;
|
|
using namespace std;
|
|
|
|
/* ----------------------------------------- * ---------------------
|
|
* --------------------- * ----------------------------------------- */
|
|
|
|
namespace Qv2ray
|
|
{
|
|
namespace V2ConfigModels
|
|
{
|
|
//
|
|
// Used in config generation
|
|
struct AccountObject {
|
|
string user;
|
|
string pass;
|
|
XTOSTRUCT(O(user, pass))
|
|
};
|
|
//
|
|
//
|
|
struct ApiObject {
|
|
string tag;
|
|
list<string> services;
|
|
ApiObject() : tag("api"), services() {}
|
|
XTOSTRUCT(O(tag, services))
|
|
};
|
|
//
|
|
//
|
|
struct SystemPolicyObject {
|
|
bool statsInboundUplink;
|
|
bool statsInboundDownlink;
|
|
SystemPolicyObject() : statsInboundUplink(), statsInboundDownlink() {}
|
|
XTOSTRUCT(O(statsInboundUplink, statsInboundDownlink))
|
|
};
|
|
//
|
|
//
|
|
struct LevelPolicyObject {
|
|
int handshake;
|
|
int connIdle;
|
|
int uplinkOnly;
|
|
int downlinkOnly;
|
|
bool statsUserUplink;
|
|
bool statsUserDownlink;
|
|
int bufferSize;
|
|
LevelPolicyObject(): handshake(), connIdle(), uplinkOnly(), downlinkOnly(), statsUserUplink(), statsUserDownlink(), bufferSize() {}
|
|
XTOSTRUCT(O(handshake, connIdle, uplinkOnly, downlinkOnly, statsUserUplink, statsUserDownlink, bufferSize))
|
|
};
|
|
//
|
|
//
|
|
struct PolicyObject {
|
|
map<string, LevelPolicyObject> level;
|
|
list<SystemPolicyObject> system;
|
|
PolicyObject(): level(), system() {}
|
|
XTOSTRUCT(O(level, system))
|
|
};
|
|
//
|
|
//
|
|
struct RuleObject {
|
|
// Added due to the request of @aliyuchang33
|
|
bool QV2RAY_RULE_ENABLED;
|
|
bool QV2RAY_RULE_USE_BALANCER;
|
|
//
|
|
string type;
|
|
list<string> domain;
|
|
list<string> ip;
|
|
string port;
|
|
string network;
|
|
list<string> source;
|
|
list<string> user;
|
|
list<string> inboundTag;
|
|
list<string> protocol;
|
|
string attrs;
|
|
string outboundTag;
|
|
string balancerTag;
|
|
RuleObject() : QV2RAY_RULE_ENABLED(true), QV2RAY_RULE_USE_BALANCER(false), type("field"), domain(), ip(), port(""), network(""), source(), user(), inboundTag(), protocol(), attrs(), outboundTag(""), balancerTag("") {}
|
|
XTOSTRUCT(O(QV2RAY_RULE_ENABLED, QV2RAY_RULE_USE_BALANCER, type, domain, ip, port, network, source, user, inboundTag, protocol, attrs, outboundTag, balancerTag))
|
|
};
|
|
//
|
|
//
|
|
struct BalancerObject {
|
|
string tag ;
|
|
list<string> selector;
|
|
BalancerObject() : tag(), selector() {}
|
|
XTOSTRUCT(O(tag, selector))
|
|
};
|
|
//
|
|
//
|
|
namespace TSObjects
|
|
{
|
|
struct HTTPRequestObject {
|
|
string version;
|
|
string method;
|
|
list<string> path;
|
|
map<string, list<string>> headers;
|
|
HTTPRequestObject(): version("1.1"), method("GET"), path(), headers() {}
|
|
XTOSTRUCT(O(version, method, path, headers))
|
|
};
|
|
//
|
|
//
|
|
struct HTTPResponseObject {
|
|
string version;
|
|
string status;
|
|
string reason;
|
|
map<string, list<string>> headers;
|
|
HTTPResponseObject(): version("1.1"), status("200"), reason("OK"), headers() {}
|
|
XTOSTRUCT(O(version, status, reason, headers))
|
|
};
|
|
//
|
|
//
|
|
struct TCPHeader_M_Object {
|
|
string type;
|
|
HTTPRequestObject request;
|
|
HTTPResponseObject response;
|
|
TCPHeader_M_Object(): type("none"), request(), response() {}
|
|
XTOSTRUCT(O(type, request, response))
|
|
};
|
|
//
|
|
//
|
|
struct HeaderObject {
|
|
string type;
|
|
HeaderObject(): type("none") {}
|
|
XTOSTRUCT(O(type))
|
|
};
|
|
//
|
|
//
|
|
struct TCPObject {
|
|
TCPHeader_M_Object header;
|
|
TCPObject(): header() {}
|
|
XTOSTRUCT(O(header))
|
|
};
|
|
//
|
|
//
|
|
struct KCPObject {
|
|
int mtu = 1350;
|
|
int tti = 20;
|
|
int uplinkCapacity = 5;
|
|
int downlinkCapacity = 20;
|
|
bool congestion = false;
|
|
int readBufferSize = 1;
|
|
int writeBufferSize = 1;
|
|
HeaderObject header;
|
|
KCPObject(): header() {}
|
|
XTOSTRUCT(O(mtu, tti, uplinkCapacity, downlinkCapacity, congestion, readBufferSize, writeBufferSize, header))
|
|
};
|
|
//
|
|
//
|
|
struct WebSocketObject {
|
|
string path;
|
|
map<string, string> headers;
|
|
WebSocketObject(): path("/"), headers() {}
|
|
XTOSTRUCT(O(path, headers))
|
|
};
|
|
//
|
|
//
|
|
struct HttpObject {
|
|
list<string> host;
|
|
string path;
|
|
HttpObject() : host(), path("/") {}
|
|
XTOSTRUCT(O(host, path))
|
|
};
|
|
//
|
|
//
|
|
struct DomainSocketObject {
|
|
string path;
|
|
DomainSocketObject(): path("/") {}
|
|
XTOSTRUCT(O(path))
|
|
};
|
|
//
|
|
//
|
|
struct QuicObject {
|
|
string security;
|
|
string key;
|
|
HeaderObject header;
|
|
QuicObject(): security(""), key(""), header() {}
|
|
XTOSTRUCT(O(security, key, header))
|
|
};
|
|
//
|
|
//
|
|
struct SockoptObject {
|
|
int mark;
|
|
bool tcpFastOpen;
|
|
string tproxy;
|
|
SockoptObject(): mark(0), tcpFastOpen(false), tproxy("off") {}
|
|
XTOSTRUCT(O(mark, tcpFastOpen, tproxy))
|
|
};
|
|
//
|
|
//
|
|
struct CertificateObject {
|
|
string usage;
|
|
string certificateFile;
|
|
string keyFile;
|
|
list<string> certificate;
|
|
list<string> key;
|
|
CertificateObject(): usage(), certificateFile(), keyFile(), certificate(), key() {}
|
|
XTOSTRUCT(O(usage, certificateFile, keyFile, certificate, key))
|
|
};
|
|
//
|
|
//
|
|
struct TLSObject {
|
|
string serverName;
|
|
bool allowInsecure;
|
|
list<string> alpn;
|
|
list<CertificateObject> certificates;
|
|
bool disableSystemRoot;
|
|
TLSObject(): serverName(), allowInsecure(), certificates(), disableSystemRoot() {}
|
|
XTOSTRUCT(O(serverName, allowInsecure, alpn, certificates, disableSystemRoot))
|
|
};
|
|
}
|
|
//
|
|
//
|
|
struct SniffingObject {
|
|
bool enabled = false;
|
|
list<string> destOverride;
|
|
SniffingObject(): enabled(), destOverride() {}
|
|
XTOSTRUCT(O(enabled, destOverride))
|
|
};
|
|
//
|
|
//
|
|
struct StreamSettingsObject {
|
|
string network;
|
|
string security;
|
|
TSObjects::SockoptObject sockopt;
|
|
TSObjects::TLSObject tlsSettings;
|
|
TSObjects::TCPObject tcpSettings;
|
|
TSObjects::KCPObject kcpSettings;
|
|
TSObjects::WebSocketObject wsSettings;
|
|
TSObjects::HttpObject httpSettings;
|
|
TSObjects::DomainSocketObject dsSettings;
|
|
TSObjects::QuicObject quicSettings;
|
|
StreamSettingsObject(): network("tcp"), security("none"), sockopt(), tlsSettings(), tcpSettings(), kcpSettings(), wsSettings(), httpSettings(), dsSettings(), quicSettings() {}
|
|
XTOSTRUCT(O(network, security, sockopt, tcpSettings, tlsSettings, kcpSettings, wsSettings, httpSettings, dsSettings, quicSettings))
|
|
};
|
|
//
|
|
//
|
|
struct MuxObject {
|
|
bool enabled;
|
|
int concurrency;
|
|
MuxObject(): enabled(), concurrency() {}
|
|
XTOSTRUCT(O(enabled, concurrency))
|
|
};
|
|
//
|
|
// Some protocols from: https://v2ray.com/chapter_02/02_protocols.html
|
|
namespace Protocols
|
|
{
|
|
// DNS, OutBound
|
|
struct DNSOut {
|
|
string network;
|
|
string address;
|
|
int port;
|
|
DNSOut(): network(""), address("0.0.0.0"), port(0) {}
|
|
XTOSTRUCT(O(network, address, port))
|
|
};
|
|
//
|
|
// MTProto, InBound || OutBound
|
|
struct MTProtoIn {
|
|
struct UserObject {
|
|
string email;
|
|
int level;
|
|
string secret;
|
|
UserObject() : email("user@domain.com"), level(0), secret("") {}
|
|
XTOSTRUCT(O(email, level, secret))
|
|
};
|
|
list<UserObject> users;
|
|
XTOSTRUCT(O(users))
|
|
};
|
|
//
|
|
// Socks, OutBound
|
|
struct SocksServerObject {
|
|
struct UserObject {
|
|
string user;
|
|
string pass;
|
|
int level;
|
|
UserObject(): user("username"), pass("password"), level(0) {}
|
|
XTOSTRUCT(O(user, pass, level))
|
|
};
|
|
|
|
string address;
|
|
int port;
|
|
list<UserObject> users;
|
|
SocksServerObject(): address("0.0.0.0"), port(0), users() {}
|
|
XTOSTRUCT(O(address, port, users))
|
|
};
|
|
//
|
|
// VMess Server
|
|
struct VMessServerObject {
|
|
struct UserObject {
|
|
string id;
|
|
int alterId;
|
|
string security;
|
|
int level;
|
|
UserObject() : id(""), alterId(64), security("auto"), level(0) {}
|
|
XTOSTRUCT(O(id, alterId, security, level))
|
|
};
|
|
|
|
string address;
|
|
int port;
|
|
list<UserObject> users;
|
|
VMessServerObject(): address(""), port(0), users() {}
|
|
XTOSTRUCT(O(address, port, users))
|
|
};
|
|
//
|
|
// ShadowSocks Server
|
|
struct ShadowSocksServerObject {
|
|
string email;
|
|
string address;
|
|
string method;
|
|
string password;
|
|
bool ota;
|
|
int level;
|
|
int port;
|
|
ShadowSocksServerObject(): email("user@domain.com"), address("0.0.0.0"), method("aes-256-cfb"), password(""), ota(false), level(0), port(0) {}
|
|
XTOSTRUCT(O(email, address, port, method, password, ota, level))
|
|
};
|
|
}
|
|
}
|
|
}
|
|
|
|
using namespace Qv2ray::V2ConfigModels;
|
|
using namespace Qv2ray::V2ConfigModels::Protocols;
|
|
|
|
#endif
|