18e745fdaSopenharmony_ci/* 28e745fdaSopenharmony_ci * Copyright (c) 2024 Huawei Device Co., Ltd. 38e745fdaSopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); 48e745fdaSopenharmony_ci * you may not use this file except in compliance with the License. 58e745fdaSopenharmony_ci * You may obtain a copy of the License at 68e745fdaSopenharmony_ci * 78e745fdaSopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 88e745fdaSopenharmony_ci * 98e745fdaSopenharmony_ci * Unless required by applicable law or agreed to in writing, software 108e745fdaSopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, 118e745fdaSopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 128e745fdaSopenharmony_ci * See the License for the specific language governing permissions and 138e745fdaSopenharmony_ci * limitations under the License. 148e745fdaSopenharmony_ci */ 158e745fdaSopenharmony_ci 168e745fdaSopenharmony_ci#ifndef IPSEC_VPN_CTL_H 178e745fdaSopenharmony_ci#define IPSEC_VPN_CTL_H 188e745fdaSopenharmony_ci 198e745fdaSopenharmony_ci#include <cstdint> 208e745fdaSopenharmony_ci 218e745fdaSopenharmony_ci#include "ipsecvpn_config.h" 228e745fdaSopenharmony_ci#include "l2tpvpn_config.h" 238e745fdaSopenharmony_ci#include "net_vpn_impl.h" 248e745fdaSopenharmony_ci#include "netsys_controller.h" 258e745fdaSopenharmony_ci 268e745fdaSopenharmony_ci#define IPSEC_PIDDIR "/data/service/el1/public/vpn" 278e745fdaSopenharmony_ci 288e745fdaSopenharmony_cinamespace OHOS { 298e745fdaSopenharmony_cinamespace NetManagerStandard { 308e745fdaSopenharmony_cinamespace { 318e745fdaSopenharmony_ciconst std::string SWAN_CTL_FILE = IPSEC_PIDDIR "/swanctl.conf"; 328e745fdaSopenharmony_ciconst std::string SWAN_CONFIG_FILE = IPSEC_PIDDIR "/strongswan.conf"; 338e745fdaSopenharmony_ciconst std::string L2TP_IPSEC_CFG = IPSEC_PIDDIR "/ipsec.conf"; 348e745fdaSopenharmony_ciconst std::string L2TP_CFG = IPSEC_PIDDIR "/xl2tpd.conf"; 358e745fdaSopenharmony_ciconst std::string L2TP_IPSEC_SECRETS_CFG = IPSEC_PIDDIR "/ipsec.secrets.conf"; 368e745fdaSopenharmony_ciconst std::string OPTIONS_L2TP_CLIENT = IPSEC_PIDDIR "/options.l2tpd.client.conf"; 378e745fdaSopenharmony_ciconst std::string IPSEC_START_TAG = "start"; 388e745fdaSopenharmony_ciconst std::string SWANCTL_START_TAG = "config"; 398e745fdaSopenharmony_ciconst std::string IPSEC_CONNECT_TAG = "connect"; 408e745fdaSopenharmony_ci} // namespace 418e745fdaSopenharmony_ciusing namespace NetsysNative; 428e745fdaSopenharmony_cienum IpsecVpnStateCode { 438e745fdaSopenharmony_ci STATE_INIT = 0, 448e745fdaSopenharmony_ci STATE_STARTED, // ipsec restart compelete 458e745fdaSopenharmony_ci STATE_CONFIGED, // swanctl load files compelete or xl2tpd start 468e745fdaSopenharmony_ci STATE_CONTROLLED, // control pppd startup 478e745fdaSopenharmony_ci STATE_CONNECTED, // ipsec up home or pppd started 488e745fdaSopenharmony_ci STATE_DISCONNECTED, // stop 498e745fdaSopenharmony_ci}; 508e745fdaSopenharmony_ci 518e745fdaSopenharmony_cienum IpsecVpnCertType : int32_t { 528e745fdaSopenharmony_ci CA_CERT = 0, 538e745fdaSopenharmony_ci USER_CERT, 548e745fdaSopenharmony_ci SERVER_CERT, 558e745fdaSopenharmony_ci}; 568e745fdaSopenharmony_ci 578e745fdaSopenharmony_ciclass IpsecVpnCtl : public NetVpnImpl { 588e745fdaSopenharmony_cipublic: 598e745fdaSopenharmony_ci IpsecVpnCtl(sptr<VpnConfig> config, const std::string &pkg, int32_t userId, std::vector<int32_t> &activeUserIds); 608e745fdaSopenharmony_ci virtual ~IpsecVpnCtl(); 618e745fdaSopenharmony_ci 628e745fdaSopenharmony_ci sptr<IpsecVpnConfig> ipsecVpnConfig_ = nullptr; 638e745fdaSopenharmony_ci sptr<L2tpVpnConfig> l2tpVpnConfig_ = nullptr; 648e745fdaSopenharmony_ci 658e745fdaSopenharmony_ci bool IsInternalVpn() override; 668e745fdaSopenharmony_ci int32_t SetUp() override; 678e745fdaSopenharmony_ci int32_t Destroy() override; 688e745fdaSopenharmony_ci int32_t GetConnectedSysVpnConfig(sptr<SysVpnConfig> &sysVpnConfig) override; 698e745fdaSopenharmony_ci int32_t NotifyConnectStage(const std::string &stage, const int32_t &result) override; 708e745fdaSopenharmony_ci int32_t GetSysVpnCertUri(const int32_t certType, std::string &certUri) override; 718e745fdaSopenharmony_ci 728e745fdaSopenharmony_ciprotected: 738e745fdaSopenharmony_ci int32_t state_ = STATE_INIT; 748e745fdaSopenharmony_ci virtual int32_t StartSysVpn(); 758e745fdaSopenharmony_ci virtual int32_t StopSysVpn(); 768e745fdaSopenharmony_ci virtual int32_t InitConfigFile(); 778e745fdaSopenharmony_ci void CleanTempFiles(); 788e745fdaSopenharmony_ci void DeleteTempFile(const std::string &fileName); 798e745fdaSopenharmony_ci}; 808e745fdaSopenharmony_ci} // namespace NetManagerStandard 818e745fdaSopenharmony_ci} // namespace OHOS 828e745fdaSopenharmony_ci#endif // IPSEC_VPN_CTL_H 83