1#!/usr/bin/env python3
2#
3#   Copyright 2016 - Google
4#
5#   Licensed under the Apache License, Version 2.0 (the "License");
6#   you may not use this file except in compliance with the License.
7#   You may obtain a copy of the License at
8#
9#       http://www.apache.org/licenses/LICENSE-2.0
10#
11#   Unless required by applicable law or agreed to in writing, software
12#   distributed under the License is distributed on an "AS IS" BASIS,
13#   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14#   See the License for the specific language governing permissions and
15#   limitations under the License.
16
17import enum
18
19######################################################
20# ConnectivityManager.NetworkCallback events
21######################################################
22EVENT_NETWORK_CALLBACK = "NetworkCallback"
23
24# event types
25NETWORK_CB_PRE_CHECK = "PreCheck"
26NETWORK_CB_AVAILABLE = "Available"
27NETWORK_CB_LOSING = "Losing"
28NETWORK_CB_LOST = "Lost"
29NETWORK_CB_UNAVAILABLE = "Unavailable"
30NETWORK_CB_CAPABILITIES_CHANGED = "CapabilitiesChanged"
31NETWORK_CB_SUSPENDED = "Suspended"
32NETWORK_CB_RESUMED = "Resumed"
33NETWORK_CB_LINK_PROPERTIES_CHANGED = "LinkPropertiesChanged"
34NETWORK_CB_INVALID = "Invalid"
35
36# event data keys
37NETWORK_CB_KEY_ID = "id"
38NETWORK_CB_KEY_EVENT = "networkCallbackEvent"
39NETWORK_CB_KEY_MAX_MS_TO_LIVE = "maxMsToLive"
40NETWORK_CB_KEY_RSSI = "rssi"
41NETWORK_CB_KEY_INTERFACE_NAME = "interfaceName"
42NETWORK_CB_KEY_CREATE_TS = "creation_timestamp"
43NETWORK_CB_KEY_CURRENT_TS = "current_timestamp"
44NETWORK_CB_KEY_NETWORK_SPECIFIER = "network_specifier"
45
46# Constants for VPN connection status
47VPN_STATE_DISCONNECTED = 0
48VPN_STATE_INITIALIZING = 1
49VPN_STATE_CONNECTING = 2
50VPN_STATE_CONNECTED = 3
51VPN_STATE_TIMEOUT = 4
52VPN_STATE_FAILED = 5
53# TODO gmoturu: determine the exact timeout value
54# This is a random value as of now
55VPN_TIMEOUT = 30
56
57# Connectiivty Manager constants
58TYPE_MOBILE = 0
59TYPE_WIFI = 1
60
61# Multipath preference constants
62MULTIPATH_PREFERENCE_NONE = 0
63MULTIPATH_PREFERENCE_HANDOVER = 1 << 0
64MULTIPATH_PREFERENCE_RELIABILITY = 1 << 1
65MULTIPATH_PREFERENCE_PERFORMANCE = 1 << 2
66
67# Private DNS constants
68DNS_GOOGLE = "dns.google"
69PRIVATE_DNS_MODE_OFF = "off"
70PRIVATE_DNS_MODE_OPPORTUNISTIC = "opportunistic"
71PRIVATE_DNS_MODE_STRICT = "hostname"
72
73# IpSec constants
74SOCK_STREAM = 1
75SOCK_DGRAM = 2
76AF_INET = 2
77AF_INET6 = 10
78DIRECTION_IN = 0
79DIRECTION_OUT = 1
80MODE_TRANSPORT = 0
81MODE_TUNNEL = 1
82CRYPT_NULL = "ecb(cipher_null)"
83CRYPT_AES_CBC = "cbc(aes)"
84AUTH_HMAC_MD5 = "hmac(md5)"
85AUTH_HMAC_SHA1 = "hmac(sha1)"
86AUTH_HMAC_SHA256 = "hmac(sha256)"
87AUTH_HMAC_SHA384 = "hmac(sha384)"
88AUTH_HMAC_SHA512 = "hmac(sha512)"
89AUTH_CRYPT_AES_GCM = "rfc4106(gcm(aes))"
90
91
92# Constants for VpnProfile
93class VpnProfile(object):
94    """ This class contains all the possible
95        parameters required for VPN connection
96    """
97    NAME = "name"
98    TYPE = "type"
99    SERVER = "server"
100    USER = "username"
101    PWD = "password"
102    DNS = "dnsServers"
103    SEARCH_DOMAINS = "searchDomains"
104    ROUTES = "routes"
105    MPPE = "mppe"
106    L2TP_SECRET = "l2tpSecret"
107    IPSEC_ID = "ipsecIdentifier"
108    IPSEC_SECRET = "ipsecSecret"
109    IPSEC_USER_CERT = "ipsecUserCert"
110    IPSEC_CA_CERT = "ipsecCaCert"
111    IPSEC_SERVER_CERT = "ipsecServerCert"
112
113
114# Enums for VPN profile types
115class VpnProfileType(enum.Enum):
116    """ Integer constant for each type of VPN
117    """
118    PPTP = 0
119    L2TP_IPSEC_PSK = 1
120    L2TP_IPSEC_RSA = 2
121    IPSEC_XAUTH_PSK = 3
122    IPSEC_XAUTH_RSA = 4
123    IPSEC_HYBRID_RSA = 5
124
125
126# Constants for config file
127class VpnReqParams(object):
128    """ Config file parameters required for
129        VPN connection
130    """
131    vpn_server_addresses = "vpn_server_addresses"
132    vpn_verify_addresses = "vpn_verify_addresses"
133    vpn_username = "vpn_username"
134    vpn_password = "vpn_password"
135    psk_secret = "psk_secret"
136    client_pkcs_file_name = "client_pkcs_file_name"
137    cert_path_vpnserver = "cert_path_vpnserver"
138    cert_password = "cert_password"
139    pptp_mppe = "pptp_mppe"
140    ipsec_server_type = "ipsec_server_type"
141