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