เชซเซเชฐเซ€เชฐเซ‡เชกเชฟเชฏเชธ + เช—เซ‚เช—เชฒ เช“เชฅเซ‡เชจเซเชŸเชฟเช•เซ‡เชŸเชฐ + LDAP + เชซเซ‹เชฐเซเชŸเซ€เช—เซ‡เชŸ

เชถเซเช‚ เชœเซ‹ เชฆเซเชตเชฟ-เชชเชฐเชฟเชฌเชณ เชชเซเชฐเชฎเชพเชฃเซ€เช•เชฐเชฃ เชฌเช‚เชจเซ‡ เช‡เชšเซเช›เชจเซ€เชฏ เช…เชจเซ‡ เช•เชพเช‚เชŸเชพเชฆเชพเชฐ เชนเซ‹เชฏ, เชชเชฐเช‚เชคเซ เชนเชพเชฐเซเชกเชตเซ‡เชฐ เชŸเซ‹เช•เชจเซเชธ เชฎเชพเชŸเซ‡ เชชเซˆเชธเชพ เชจเชฅเซ€ เช…เชจเซ‡ เชธเชพเชฎเชพเชจเซเชฏ เชฐเซ€เชคเซ‡ เชคเซ‡เช“ เชธเชพเชฐเชพ เชฎเซ‚เชกเชฎเชพเช‚ เชฐเชนเซ‡เชตเชพเชจเซ€ เช“เชซเชฐ เช•เชฐเซ‡ เช›เซ‡.

เช† เชธเซ‹เชฒเซเชฏเซเชถเชจ เช•เช‚เชˆ เชธเซเชชเชฐ เช“เชฐเชฟเชœเชฟเชจเชฒ เชจเชฅเซ€, เชชเชฐเช‚เชคเซ เชˆเชจเซเชŸเชฐเชจเซ‡เชŸ เชชเชฐ เชœเซ‹เชตเชพ เชฎเชณเชคเชพ เชตเชฟเชตเชฟเชง เช‰เช•เซ‡เชฒเซ‹เชจเซเช‚ เชฎเชฟเชถเซเชฐเชฃ เช›เซ‡.

เชคเซ‡เชฅเซ€ เช†เชชเชตเชพเชฎเชพเช‚ เช†เชตเซ‡ เช›เซ‡

เชกเซ‹เชฎเซ‡เชจ เชธเช•เซเชฐเชฟเชฏ เชฎเชพเชฐเซเช—เชฆเชฐเซเชถเชจ.

VPN เชฆเซเชตเชพเชฐเชพ เช•เชพเชฎ เช•เชฐเชคเชพ เชกเซ‹เชฎเซ‡เชจ เชตเชชเชฐเชพเชถเช•เชฐเซเชคเชพเช“, เชœเซ‡เชฎ เช•เซ‡ เช†เชœเซ‡ เช˜เชฃเชพ.

VPN เช—เซ‡เชŸเชตเซ‡ เชคเชฐเซ€เช•เซ‡ เช•เชพเชฎ เช•เชฐเซ‡ เช›เซ‡ เชซเซ‹เชฐเซเชŸเชฟเช—เซ‡เชŸ.

เชธเซเชฐเช•เซเชทเชพ เชจเซ€เชคเชฟ เชฆเซเชตเชพเชฐเชพ VPN เช•เซเชฒเชพเชฏเช‚เชŸ เชฎเชพเชŸเซ‡ เชชเชพเชธเชตเชฐเซเชก เชธเชพเชšเชตเชตเชพ เชชเชฐ เชชเซเชฐเชคเชฟเชฌเช‚เชง เช›เซ‡.

เชฐเชพเชœเชจเซ€เชคเชฟ เชซเซ‹เชฐเซเชŸเซ€เชจเซ‡เชŸ เชคเชฎเชพเชฐเชพ เชชเซ‹เชคเชพเชจเชพ เชŸเซ‹เช•เชจเซเชธเชจเชพ เชธเช‚เชฌเช‚เชงเชฎเชพเช‚, เชคเชฎเซ‡ เชคเซ‡เชจเซ‡ เชเซเชฒเซ‹เชฌ เช•เชฐเชคเชพเช‚ เช“เช›เซเช‚ เช•เชนเซ€ เชถเช•เชคเชพ เชจเชฅเซ€ - เชคเซเชฏเชพเช‚ 10 เชœเซ‡เชŸเชฒเชพ เชฎเชซเชค เชŸเซ‹เช•เชจเซเชธ เช›เซ‡, เชฌเชพเช•เซ€เชจเชพ - เช–เซ‚เชฌ เชœ เชฌเชฟเชจ-เช•เซ‹เชถเซ‡เชฐ เช•เชฟเช‚เชฎเชคเซ‡. เชฎเซ‡เช‚ RSASecureID, Duo เช…เชจเซ‡ เชคเซ‡เชจเชพ เชœเซ‡เชตเชพเชจเซ‡ เชงเซเชฏเชพเชจเชฎเชพเช‚ เชฒเซ€เชงเชพ เชจเชฅเซ€, เช•เชพเชฐเชฃ เช•เซ‡ เชฎเชจเซ‡ เช“เชชเชจ เชธเซ‹เชฐเซเชธ เชœเซ‹เชˆเช เช›เซ‡.

เชชเซ‚เชฐเซเชตเชœเชฐเซ‚เชฐเซ€เชฏเชพเชคเซ‹: เชฏเชœเชฎเชพเชจ * เชจเชฟเช• เชธเซเชฅเชพเชชเชฟเชค เชธเชพเชฅเซ‡ เชซเซเชฐเซ€เชฐเซ‡เชกเชฟเชฏเชธ, เชเชธเชเชธเชกเซ€ - เชกเซ‹เชฎเซ‡เชจเชฎเชพเช‚ เชฆเชพเช–เชฒ เชฅเชฏเชพ เชชเช›เซ€, เชกเซ‹เชฎเซ‡เชจ เชตเชชเชฐเชพเชถเช•เชฐเซเชคเชพเช“ เชคเซ‡เชจเชพ เชชเชฐ เชธเชฐเชณเชคเชพเชฅเซ€ เชชเซเชฐเชฎเชพเชฃเชฟเชค เช•เชฐเซ€ เชถเช•เซ‡ เช›เซ‡.

เชตเชงเชพเชฐเชพเชจเชพ เชชเซ‡เช•เซ‡เชœเซ‹: เชถเซ‡เชฒเชฟเชจเชพ เชฌเซ‹เช•เซเชธ, เชซเชฟเช—เชฒเซ‡เชŸ, freeradius-ldap, เชซเซ‹เชจเซเชŸ rebel.tlf เชฐเซ€เชชเซ‹เชเซ€เชŸเชฐเซ€เชฎเชพเช‚เชฅเซ€ https://github.com/xero/figlet-fonts.

เชฎเชพเชฐเชพ เช‰เชฆเชพเชนเชฐเชฃเชฎเชพเช‚ - CentOS 7.8.

เช•เชพเชฐเซเชฏเชจเซ‹ เชคเชฐเซเช• เชจเซ€เชšเซ‡ เชฎเซเชœเชฌ เชนเซ‹เชตเชพเชจเซเช‚ เชฎเชพเชจเชตเชพเชฎเชพเช‚ เช†เชตเซ‡ เช›เซ‡: VPN เชธเชพเชฅเซ‡ เช•เชจเซ‡เช•เซเชŸ เช•เชฐเชคเซ€ เชตเช–เชคเซ‡, เชตเชชเชฐเชพเชถเช•เชฐเซเชคเชพเช เชชเชพเชธเชตเชฐเซเชกเชจเซ‡ เชฌเชฆเชฒเซ‡ เชกเซ‹เชฎเซ‡เชจ เชฒเซ‹เช—เชฟเชจ เช…เชจเซ‡ OTP เชฆเชพเช–เชฒ เช•เชฐเชตเซ‹ เช†เชตเชถเซเชฏเช• เช›เซ‡.

เชธเซ‡เชตเชพเช“ เชธเซ‡เชŸเช…เชช

ะ’ /etc/raddb/radiusd.conf เชซเช•เซเชค เชตเชชเชฐเชพเชถเช•เชฐเซเชคเชพ เช…เชจเซ‡ เชœเซ‚เชฅ เชœเซ‡เชจเชพ เชตเชคเซ€ เชถเชฐเซ‚ เชฅเชพเชฏ เช›เซ‡ เชซเซเชฐเซ€เชฐเซ‡เชกเชฟเชฏเชธ, เชธเซ‡เชตเชพ เชฅเซ€ เชคเซเชฐเชฟเชœเซเชฏเชพ เชฌเชงเซ€ เชธเชฌเชกเชฟเชฐเซ‡เช•เซเชŸเชฐเซ€เชเชฎเชพเช‚ เชซเชพเช‡เชฒเซ‹ เชตเชพเช‚เชšเชตเชพ เชฎเชพเชŸเซ‡ เชธเช•เซเชทเชฎ เชนเซ‹เชตเชพ เชœเซ‹เชˆเช / เช˜เชฐ /.

user = root
group = root

เชธเซ‡เชŸเชฟเช‚เช—เซเชธเชฎเชพเช‚ เชœเซ‚เชฅเซ‹เชจเซ‹ เช‰เชชเชฏเซ‹เช— เช•เชฐเชตเชพ เชฎเชพเชŸเซ‡ เชธเช•เซเชทเชฎ เชฅเชตเชพ เชฎเชพเชŸเซ‡ เชซเซ‹เชฐเซเชŸเชฟเช—เซ‡เชŸ, เชชเซเชฐเชธเชพเชฐเชฟเชค เช•เชฐเชตเซเช‚ เช†เชตเชถเซเชฏเช• เช›เซ‡ เชตเชฟเช•เซเชฐเซ‡เชคเชพ เชตเชฟเชถเชฟเชทเซเชŸ เชตเชฟเชถเซ‡เชทเชคเชพ. เช† เช•เชฐเชตเชพ เชฎเชพเชŸเซ‡, เชกเชฟเชฐเซ‡เช•เซเชŸเชฐเซ€เชฎเชพเช‚ raddb/policy.d เชนเซเช‚ เชจเซ€เชšเซ‡เชจเซ€ เชธเชพเชฎเช—เซเชฐเซ€ เชธเชพเชฅเซ‡ เชซเชพเช‡เชฒ เชฌเชจเชพเชตเซเช‚ เช›เซเช‚:

group_authorization {
    if (&LDAP-Group[*] == "CN=vpn_admins,OU=vpn-groups,DC=domain,DC=local") {
            update reply {
                &Fortinet-Group-Name = "vpn_admins" }
            update control {
                &Auth-Type := PAM
                &Reply-Message := "Welcome Admin"
                }
        }
    else {
        update reply {
        &Reply-Message := "Not authorized for vpn"
            }
        reject
        }
}

เชธเซเชฅเชพเชชเชจ เชชเช›เซ€ freeradius-ldap เชกเชฟเชฐเซ‡เช•เซเชŸเชฐเซ€เชฎเชพเช‚ raddb/mods-เช‰เชชเชฒเชฌเซเชง เชซเชพเชˆเชฒ เชฌเชจเชพเชตเชตเชพเชฎเชพเช‚ เช†เชตเซ‡ เช›เซ‡ ldap.

เชกเชฟเชฐเซ‡เช•เซเชŸเชฐเซ€เชฎเชพเช‚ เชธเชพเช‚เช•เซ‡เชคเชฟเช• เชฒเชฟเช‚เช• เชฌเชจเชพเชตเชตเชพเชจเซ€ เชœเชฐเซ‚เชฐ เช›เซ‡ raddb/mods-เชธเช•เซเชทเชฎ.

ln -s /etc/raddb/mods-available/ldap /etc/raddb/mods-enabled/ldap

เชนเซเช‚ เชคเซ‡เชจเซ€ เชธเชพเชฎเช—เซเชฐเซ€เชจเซ‡ เช† เชซเซ‹เชฐเซเชฎเชฎเชพเช‚ เชฒเชพเชตเซ€ เช›เซเช‚:

ldap {
        server = 'domain.local'
        identity = 'CN=freerad_user,OU=users,DC=domain,DC=local'
        password = "SupeSecretP@ssword"
        base_dn = 'dc=domain,dc=local'
        sasl {
        }
        user {
                base_dn = "${..base_dn}"
                filter = "(sAMAccountname=%{%{Stripped-User-Name}:-%{User-Name}})"
                sasl {
                }
                scope = 'sub'
        }
        group {
                base_dn = "${..base_dn}"
                filter = '(objectClass=Group)'
                scope = 'sub'
                name_attribute = cn
                membership_filter = "(|(member=%{control:Ldap-UserDn})(memberUid=%{%{Stripped-User-Name}:-%{User-Name}}))"
                membership_attribute = 'memberOf'
        }
}

เชซเชพเช‡เชฒเซ‹เชฎเชพเช‚ raddb/sites-enabled/default ะธ raddb/sites-enabled/inner-tunnel เชตเชฟเชญเชพเช—เชฎเชพเช‚ เช…เชงเชฟเช•เซƒเชค เชนเซเช‚ เช‰เชชเชฏเซ‹เช— เช•เชฐเชตเชพ เชฎเชพเชŸเซ‡เชจเซ€ เชจเซ€เชคเชฟเชจเซเช‚ เชจเชพเชฎ เช‰เชฎเซ‡เชฐเซเช‚ เช›เซเช‚ - เชœเซ‚เชฅ_เช…เชงเชฟเช•เซƒเชคเชคเชพ. เชเช• เชฎเชนเชคเซเชตเชชเซ‚เชฐเซเชฃ เชฎเซเชฆเซเชฆเซ‹ - เชจเซ€เชคเชฟเชจเซเช‚ เชจเชพเชฎ เชกเชฟเชฐเซ‡เช•เซเชŸเชฐเซ€เชฎเชพเช‚ เชซเชพเช‡เชฒเชจเชพ เชจเชพเชฎ เชฆเซเชตเชพเชฐเชพ เชจเช•เซเช•เซ€ เช•เชฐเชตเชพเชฎเชพเช‚ เช†เชตเชคเซเช‚ เชจเชฅเซ€ เชจเซ€เชคเชฟ.เชกเซ€, เชชเชฐเช‚เชคเซ เชตเชพเช‚เช•เชกเชฟเชฏเชพ เช•เซŒเช‚เชธ เชชเชนเซ‡เชฒเชพเช‚ เชซเชพเช‡เชฒเชจเซ€ เช…เช‚เชฆเชฐเชจเชพ เชจเชฟเชฐเซเชฆเซ‡เชถ เชฆเซเชตเชพเชฐเชพ.
เชตเชฟเชญเชพเช—เชฎเชพเช‚ เชชเซเชฐเชฎเชพเชฃเชฟเชค เช•เชฐเชตเซเช‚ เชธเชฎเชพเชจ เชซเชพเช‡เชฒเซ‹เชฎเชพเช‚ เชคเชฎเชพเชฐเซ‡ เชฒเชพเช‡เชจเชจเซ‡ เช…เชจเช•เซ‹เชฎเซ‡เชจเซเชŸ เช•เชฐเชตเชพเชจเซ€ เชœเชฐเซ‚เชฐ เช›เซ‡ เชชเซ…เชฎ.

เชซเชพเชˆเชฒเชฎเชพเช‚ clients.conf เชชเชฐเชฟเชฎเชพเชฃเซ‹ เชธเซ‚เชšเชตเซ‹ เชœเซ‡เชจเซ€ เชธเชพเชฅเซ‡ เชคเซ‡ เช•เชจเซ‡เช•เซเชŸ เชฅเชถเซ‡ เชซเซ‹เชฐเซเชŸเชฟเช—เซ‡เชŸ:

client fortigate {
    ipaddr = 192.168.1.200
    secret = testing123
    require_message_authenticator = no
    nas_type = other
}

เชฎเซ‹เชกเซเชฏเซเชฒ เชฐเซ‚เชชเชฐเซ‡เช–เชพเช‚เช•เชจ pam.d/radiusd:

#%PAM-1.0
auth       sufficient   pam_google_authenticator.so
auth       include      password-auth
account    required     pam_nologin.so
account    include      password-auth
password   include      password-auth
session    include      password-auth

เชกเชฟเชซเซ‰เชฒเซเชŸ เชฌเช‚เชกเชฒ เช…เชฎเชฒเซ€เช•เชฐเชฃ เชตเชฟเช•เชฒเซเชชเซ‹ เชซเซเชฐเซ€เชฐเซ‡เชกเชฟเชฏเชธ ั เช—เซ‚เช—เชฒ เช…เชงเชฟเช•เซƒเชคเช•เชฐเซเชคเชพ เชตเชชเชฐเชพเชถเช•เชฐเซเชคเชพเชจเซ‡ เชซเซ‹เชฐเซเชฎเซ‡เชŸเชฎเชพเช‚ เช“เชณเช–เชชเชคเซเชฐ เชฆเชพเช–เชฒ เช•เชฐเชตเชพเชจเซ€ เชœเชฐเซ‚เชฐ เช›เซ‡: เชตเชชเชฐเชพเชถเช•เชฐเซเชคเชพ เชจเชพเชฎ เชชเชพเชธเชตเชฐเซเชก+OTP.

เชกเชฟเชซเซ‰เชฒเซเชŸ เชฌเช‚เชกเชฒเชจเซ‹ เช‰เชชเชฏเซ‹เช— เช•เชฐเชตเชพเชจเชพ เช•เชฟเชธเซเชธเชพเชฎเชพเช‚, เชฎเชพเชฅเชพ เชชเชฐ เชชเชกเซ‡เชฒเชพ เชถเซเชฐเชพเชชเชจเซ€ เชธเช‚เช–เซเชฏเชพเชจเซ€ เช•เชฒเซเชชเชจเชพ เช•เชฐเซ€เชจเซ‡ เชซเซเชฐเซ€เชฐเซ‡เชกเชฟเชฏเชธ ั Google เชชเซเชฐเชฎเชพเชฃเช•เชฐเซเชคเชพ, เชฎเซ‹เชกเซเชฏเซเชฒ เชฐเซ‚เชชเชฐเซ‡เช–เชพเช‚เช•เชจเชจเซ‹ เช‰เชชเชฏเซ‹เช— เช•เชฐเชตเชพเชจเซเช‚ เชจเช•เซเช•เซ€ เช•เชฐเชตเชพเชฎเชพเช‚ เช†เชตเซเชฏเซเช‚ เชนเชคเซเช‚ เชชเซ…เชฎ เชœเซ‡เชฅเซ€ เชฎเชพเชคเซเชฐ เชŸเซ‹เช•เชจ เชšเซ‡เช• เช•เชฐเซ€ เชถเช•เชพเชฏ Google เชชเซเชฐเชฎเชพเชฃเช•เชฐเซเชคเชพ.

เชœเซเชฏเชพเชฐเซ‡ เชตเชชเชฐเชพเชถเช•เชฐเซเชคเชพ เช•เชจเซ‡เช•เซเชŸ เช•เชฐเซ‡ เช›เซ‡, เชคเซเชฏเชพเชฐเซ‡ เชจเซ€เชšเซ‡ เชฎเซเชœเชฌ เชฅเชพเชฏ เช›เซ‡:

  • เชซเซเชฐเซ€เชฐเซ‡เชกเชฟเชฏเชธ เชคเชชเชพเชธ เช•เชฐเซ‡ เช›เซ‡ เช•เซ‡ เชถเซเช‚ เชตเชชเชฐเชพเชถเช•เชฐเซเชคเชพ เชกเซ‹เชฎเซ‡เชจเชฎเชพเช‚ เช›เซ‡ เช…เชจเซ‡ เชšเซ‹เช•เซเช•เชธ เชœเซ‚เชฅเชฎเชพเช‚ เช›เซ‡ เช…เชจเซ‡, เชœเซ‹ เชธเชซเชณ เชฅเชพเชฏ เช›เซ‡, เชคเซ‹ OTP เชŸเซ‹เช•เชจ เชคเชชเชพเชธเซ‡ เช›เซ‡.

เชœเซเชฏเชพเชฐเซ‡ เชฎเซ‡เช‚ เชตเชฟเชšเชพเชฐเซเชฏเซเช‚ เช•เซ‡ "เชนเซเช‚ 300+ เชตเชชเชฐเชพเชถเช•เชฐเซเชคเชพเช“ เชฎเชพเชŸเซ‡ OTP เช•เซ‡เชตเซ€ เชฐเซ€เชคเซ‡ เชฐเชœเซ€เชธเซเชŸเชฐ เช•เชฐเซ€ เชถเช•เซเช‚?"

เชตเชชเชฐเชพเชถเช•เชฐเซเชคเชพเช เชธเชฐเซเชตเชฐ เชธเชพเชฅเซ‡ เชฒเซ‰เช—เชฟเชจ เช•เชฐเชตเซเช‚ เช†เชตเชถเซเชฏเช• เช›เซ‡ เชซเซเชฐเซ€เชฐเซ‡เชกเชฟเชฏเชธ เช…เชจเซ‡ เชคเชฎเชพเชฐเชพ เช–เชพเชคเชพเชจเซ€ เชจเซ€เชšเซ‡เชฅเซ€ เช…เชจเซ‡ เชเชชเซเชฒเชฟเช•เซ‡เชถเชจ เชšเชฒเชพเชตเซ‹ เช—เซ‚เช—เชฒ เช“เชฅเซ‡เชจเซเชŸเซ€เช•เซ‡เชŸเชฐ, เชœเซ‡ เชตเชชเชฐเชพเชถเช•เชฐเซเชคเชพ เชฎเชพเชŸเซ‡ เชเชชเซเชฒเชฟเช•เซ‡เชถเชจ เชฎเชพเชŸเซ‡ QR เช•เซ‹เชก เชœเชจเชฐเซ‡เชŸ เช•เชฐเชถเซ‡. เช† เชคเซ‡ เช›เซ‡ เชœเซเชฏเชพเช‚ เชฎเชฆเชฆ เช†เชตเซ‡ เช›เซ‡. เชถเซ‡เชฒเชฟเชจเชพ เชฌเซ‹เช•เซเชธ เชธเชพเชฅเซ‡ เชธเช‚เชฏเซ‹เชœเชจเชฎเชพเช‚ .bash_profile.

[root@freeradius ~]# yum install -y shellinabox

เชกเชฟเชฎเชจ เชฐเซ‚เชชเชฐเซ‡เช–เชพเช‚เช•เชจ เชซเชพเชˆเชฒ เชชเชฐ เชธเซเชฅเชฟเชค เชฅเชฏเซ‡เชฒ เช›เซ‡ /etc/sysconfig/shellinabox.
เชนเซเช‚ เชคเซเชฏเชพเช‚ เชชเซ‹เชฐเซเชŸ 443 เชจเซ‹ เช‰เชฒเซเชฒเซ‡เช– เช•เชฐเซเช‚ เช›เซเช‚ เช…เชจเซ‡ เชคเชฎเซ‡ เชคเชฎเชพเชฐเซเช‚ เชชเซเชฐเชฎเชพเชฃเชชเชคเซเชฐ เชธเซเชชเชทเซเชŸ เช•เชฐเซ€ เชถเช•เซ‹ เช›เซ‹.

[root@freeradius ~]#systemctl enable --now shellinaboxd

เชตเชชเชฐเชพเชถเช•เชฐเซเชคเชพเช เชซเช•เซเชค เชฒเชฟเช‚เช•เชจเซ‡ เช…เชจเซเชธเชฐเชตเชพเชจเซ€, เชกเซ‹เชฎเซ‡เชจ เช•เซเชฐเซ‡เชกเชฟเชŸเซเชธ เชฆเชพเช–เชฒ เช•เชฐเชตเชพเชจเซ€ เช…เชจเซ‡ เชเชชเซเชฒเชฟเช•เซ‡เชถเชจ เชฎเชพเชŸเซ‡ QR เช•เซ‹เชก เชชเซเชฐเชพเชชเซเชค เช•เชฐเชตเชพเชจเซ€ เชœเชฐเซ‚เชฐ เช›เซ‡.

เช…เชฒเซเช—เซ‹เชฐเชฟเชงเชฎ เชจเซ€เชšเซ‡ เชฎเซเชœเชฌ เช›เซ‡:

  • เชตเชชเชฐเชพเชถเช•เชฐเซเชคเชพ เชฌเซเชฐเชพเช‰เชเชฐ เชฆเซเชตเชพเชฐเชพ เชฎเชถเซ€เชจเชฎเชพเช‚ เชฒเซ‹เช— เช‡เชจ เช•เชฐเซ‡ เช›เซ‡.
  • เชกเซ‹เชฎเซ‡เชจ เชตเชชเชฐเชพเชถเช•เชฐเซเชคเชพ เชคเชชเชพเชธเซ‡เชฒ เช›เซ‡ เช•เซ‡ เช•เซ‡เชฎ. เชœเซ‹ เชจเชนเซ€เช‚, เชคเซ‹ เชชเช›เซ€ เช•เซ‹เชˆ เช•เชพเชฐเซเชฏเชตเชพเชนเซ€ เช•เชฐเชตเชพเชฎเชพเช‚ เช†เชตเชคเซ€ เชจเชฅเซ€.
  • เชœเซ‹ เชตเชชเชฐเชพเชถเช•เชฐเซเชคเชพ เชกเซ‹เชฎเซ‡เชจ เชตเชชเชฐเชพเชถเช•เชฐเซเชคเชพ เช›เซ‡, เชคเซ‹ เชธเช‚เชšเชพเชฒเช• เชœเซ‚เชฅเชฎเชพเช‚ เชธเชญเซเชฏเชชเชฆ เชคเชชเชพเชธเชตเชพเชฎเชพเช‚ เช†เชตเซ‡ เช›เซ‡.
  • เชœเซ‹ เชเชกเชฎเชฟเชจ เชจเชฅเซ€, เชคเซ‹ เชคเซ‡ เชคเชชเชพเชธเซ‡ เช›เซ‡ เช•เซ‡ Google เชชเซเชฐเชฎเชพเชฃเช•เชฐเซเชคเชพ เช—เซ‹เช เชตเซ‡เชฒ เช›เซ‡ เช•เซ‡ เช•เซ‡เชฎ. เชœเซ‹ เชจเชนเซ€เช‚, เชคเซ‹ QR เช•เซ‹เชก เช…เชจเซ‡ เชตเชชเชฐเชพเชถเช•เชฐเซเชคเชพ เชฒเซ‹เช—เช†เช‰เชŸ เชœเชจเชฐเซ‡เชŸ เชฅเชพเชฏ เช›เซ‡.
  • เชœเซ‹ เชเชกเชฎเชฟเชจ เชจเชฅเซ€ เช…เชจเซ‡ Google เชชเซเชฐเชฎเชพเชฃเช•เชฐเซเชคเชพ เช—เซ‹เช เชตเซ‡เชฒ เช›เซ‡, เชคเซ‹ เชชเช›เซ€ เชซเช•เซเชค เชฒเซ‹เช—เช†เช‰เชŸ เช•เชฐเซ‹.
  • เชœเซ‹ เชเชกเชฎเชฟเชจ เชนเซ‹เชฏ, เชคเซ‹ เชชเช›เซ€ เชซเชฐเซ€เชฅเซ€ Google เชชเซเชฐเชฎเชพเชฃเช•เชฐเซเชคเชพ เชคเชชเชพเชธเซ‹. เชœเซ‹ เช—เซ‹เช เชตเซ‡เชฒ เชจ เชนเซ‹เชฏ, เชคเซ‹ QR เช•เซ‹เชก เชœเชจเชฐเซ‡เชŸ เชฅเชพเชฏ เช›เซ‡.

เชฌเชงเชพ เชคเชฐเซเช•เชจเซ‹ เช‰เชชเชฏเซ‹เช— เช•เชฐเซ€เชจเซ‡ เช•เชฐเชตเชพเชฎเชพเช‚ เช†เชตเซ‡ เช›เซ‡ /etc/skel/.bash_profile.

cat /etc/skel/.bash_profile

# .bash_profile

# Get the aliases and functions
if [ -f ~/.bashrc ]; then
        . ~/.bashrc
fi

# User specific environment and startup programs
# Make several commands available from user shell

if [[ -z $(id $USER | grep "admins") || -z $(cat /etc/passwd | grep $USER) ]]
  then
    [[ ! -d $HOME/bin ]] && mkdir $HOME/bin
    [[ ! -f $HOME/bin/id ]] && ln -s /usr/bin/id $HOME/bin/id
    [[ ! -f $HOME/bin/google-auth ]] && ln -s /usr/bin/google-authenticator $HOME/bin/google-auth
    [[ ! -f $HOME/bin/grep ]] && ln -s /usr/bin/grep $HOME/bin/grep
    [[ ! -f $HOME/bin/figlet ]] && ln -s /usr/bin/figlet $HOME/bin/figlet
    [[ ! -f $HOME/bin/rebel.tlf ]] && ln -s /usr/share/figlet/rebel.tlf $HOME/bin/rebel.tlf
    [[ ! -f $HOME/bin/sleep ]] && ln -s /usr/bin/sleep $HOME/bin/sleep
  # Set PATH env to <home user directory>/bin
    PATH=$HOME/bin
    export PATH
  else
    PATH=PATH=$PATH:$HOME/.local/bin:$HOME/bin
    export PATH
fi


if [[ -n $(id $USER | grep "domain users") ]]
  then
    if [[ ! -e $HOME/.google_authenticator ]]
      then
        if [[ -n $(id $USER | grep "admins") ]]
          then
            figlet -t -f $HOME/bin/rebel.tlf "Welcome to Company GAuth setup portal"
            sleep 1.5
            echo "Please, run any of these software on your device, where you would like to setup OTP:
Google Autheticator:
AppStore - https://apps.apple.com/us/app/google-authenticator/id388497605
Play Market - https://play.google.com/stor/apps/details?id=com.google.android.apps.authenticator2&hl=en
FreeOTP:
AppStore - https://apps.apple.com/us/app/freeotp-authenticator/id872559395
Play Market - https://play.google.com/store/apps/details?id=org.fedorahosted.freeotp&hl=en

And prepare to scan QR code.

"
            sleep 5
            google-auth -f -t -w 3 -r 3 -R 30 -d -e 1
            echo "Congratulations, now you can use an OTP token from application as a password connecting to VPN."
          else
            figlet -t -f $HOME/bin/rebel.tlf "Welcome to Company GAuth setup portal"
            sleep 1.5
            echo "Please, run any of these software on your device, where you would like to setup OTP:
Google Autheticator:
AppStore - https://apps.apple.com/us/app/google-authenticator/id388497605
Play Market - https://play.google.com/store/apps/details?id=com.google.android.apps.authenticator2&hl=en
FreeOTP:
AppStore - https://apps.apple.com/us/app/freeotp-authenticator/id872559395
Play Market - https://play.google.com/store/apps/details?id=org.fedorahosted.freeotp&hl=en

And prepare to scan QR code.

"
            sleep 5
            google-auth -f -t -w 3 -r 3 -R 30 -d -e 1
            echo "Congratulations, now you can use an OTP token from application as a password to VPN."
            logout
        fi
      else
        echo "You have already setup a Google Authenticator"
        if [[ -z $(id $USER | grep "admins") ]]
          then
          logout
        fi
    fi
  else
    echo "You don't need to set up a Google Authenticator"
fi

เชซเซ‹เชฐเซเชŸเชฟเช—เซ‡เชŸ เชธเซ‡เชŸเช…เชช:

  • เช…เชฎเซ‡ เชฌเชจเชพเชตเซ€เช เช›เซ€เช เชคเซเชฐเชฟเชœเซเชฏเชพ-เชธเชฐเซเชตเชฐ

    เชซเซเชฐเซ€เชฐเซ‡เชกเชฟเชฏเชธ + เช—เซ‚เช—เชฒ เช“เชฅเซ‡เชจเซเชŸเชฟเช•เซ‡เชŸเชฐ + LDAP + เชซเซ‹เชฐเซเชŸเซ€เช—เซ‡เชŸ

  • เช…เชฎเซ‡ เชœเชฐเซ‚เชฐเซ€ เชœเซ‚เชฅเซ‹ เชฌเชจเชพเชตเซ€เช เช›เซ€เช, เชœเซ‹ เชœเชฐเซ‚เชฐเซ€ เชนเซ‹เชฏ เชคเซ‹, เชœเซ‚เชฅเซ‹ เชฆเซเชตเชพเชฐเชพ เชเช•เซเชธเซ‡เชธ เชจเชฟเชฏเช‚เชคเซเชฐเชฃ. เชœเซ‚เชฅเชจเซเช‚ เชจเชพเชฎ เชšเชพเชฒเซ เชซเซ‹เชฐเซเชŸเชฟเช—เซ‡เชŸ เชชเชพเชธ เชฅเชฏเซ‡เชฒ เชœเซ‚เชฅ เชธเชพเชฅเซ‡ เชฎเซ‡เชณ เช–เชพเชคเซ‹ เชนเซ‹เชตเซ‹ เชœเซ‹เชˆเช เชตเชฟเช•เซเชฐเซ‡เชคเชพ เชตเชฟเชถเชฟเชทเซเชŸ เชตเชฟเชถเซ‡เชทเชคเชพ Fortinet-เชœเซ‚เชฅ-เชจเชพเชฎ.

    เชซเซเชฐเซ€เชฐเซ‡เชกเชฟเชฏเชธ + เช—เซ‚เช—เชฒ เช“เชฅเซ‡เชจเซเชŸเชฟเช•เซ‡เชŸเชฐ + LDAP + เชซเซ‹เชฐเซเชŸเซ€เช—เซ‡เชŸ

  • เชœเชฐเซ‚เชฐเซ€ เชธเช‚เชชเชพเชฆเชจ SSL-เชชเซ‹เชฐเซเชŸเชฒ.

    เชซเซเชฐเซ€เชฐเซ‡เชกเชฟเชฏเชธ + เช—เซ‚เช—เชฒ เช“เชฅเซ‡เชจเซเชŸเชฟเช•เซ‡เชŸเชฐ + LDAP + เชซเซ‹เชฐเซเชŸเซ€เช—เซ‡เชŸ

  • เชจเซ€เชคเชฟเช“เชฎเชพเช‚ เชœเซ‚เชฅเซ‹ เช‰เชฎเซ‡เชฐเชตเชพ.

    เชซเซเชฐเซ€เชฐเซ‡เชกเชฟเชฏเชธ + เช—เซ‚เช—เชฒ เช“เชฅเซ‡เชจเซเชŸเชฟเช•เซ‡เชŸเชฐ + LDAP + เชซเซ‹เชฐเซเชŸเซ€เช—เซ‡เชŸ

เช† เชธเซ‹เชฒเซเชฏเซเชถเชจเชจเชพ เชซเชพเชฏเชฆเชพ:

  • เช“เชŸเซ€เชชเซ€ เช“เชจ เช•เชฐเซ€เชจเซ‡ เช“เชฅเซ‡เชจเซเชŸเชฟเช•เซ‡เชถเชจ เชถเช•เซเชฏ เช›เซ‡ เชซเซ‹เชฐเซเชŸเชฟเช—เซ‡เชŸ เช“เชชเชจ เชธเซ‹เชฐเซเชธ เชธเซ‹เชฒเซเชฏเซเชถเชจ.
  • VPN เชฆเซเชตเชพเชฐเชพ เช•เชจเซ‡เช•เซเชŸ เช•เชฐเชคเซ€ เชตเช–เชคเซ‡ เชตเชชเชฐเชพเชถเช•เชฐเซเชคเชพ เชกเซ‹เชฎเซ‡เชจ เชชเชพเชธเชตเชฐเซเชก เชฆเชพเช–เชฒ เช•เชฐเชคเชพ เชจเชฅเซ€, เชœเซ‡ เช•เชจเซ‡เช•เซเชถเชจ เชชเซเชฐเช•เซเชฐเชฟเชฏเชพเชจเซ‡ เช•เช‚เชˆเช• เช…เช‚เชถเซ‡ เชธเชฐเชณ เชฌเชจเชพเชตเซ‡ เช›เซ‡. เชธเซเชฐเช•เซเชทเชพ เชจเซ€เชคเชฟ เชฆเซเชตเชพเชฐเชพ เช†เชชเชตเชพเชฎเชพเช‚ เช†เชตเซ‡เชฒ เชชเชพเชธเชตเชฐเซเชก เช•เชฐเชคเชพเช‚ 6-เช…เช‚เช•เชจเซ‹ เชชเชพเชธเชตเชฐเซเชก เชฆเชพเช–เชฒ เช•เชฐเชตเซ‹ เชตเชงเซ เชธเชฐเชณ เช›เซ‡. เชชเชฐเชฟเชฃเชพเชฎเซ‡, เชตเชฟเชทเชฏ เชธเชพเชฅเซ‡เชจเซ€ เชŸเชฟเช•เชฟเชŸเซ‹เชจเซ€ เชธเช‚เช–เซเชฏเชพ: "เชนเซเช‚ VPN เชธเชพเชฅเซ‡ เช•เชจเซ‡เช•เซเชŸ เช•เชฐเซ€ เชถเช•เชคเซ‹ เชจเชฅเซ€" เช˜เชŸเซ‡ เช›เซ‡.

PS เช…เชฎเซ‡ เช† เชธเซ‹เชฒเซเชฏเซเชถเชจเชจเซ‡ เชชเชกเช•เชพเชฐ-เชชเซเชฐเชคเชฟเชธเชพเชฆ เชธเชพเชฅเซ‡ เชธเช‚เชชเซ‚เชฐเซเชฃ เชธเซเชตเชฟเชงเชพเชฏเซเช•เซเชค เชฆเซเชตเชฟ-เชชเชฐเชฟเชฌเชณ เชชเซเชฐเชฎเชพเชฃเซ€เช•เชฐเชฃเชฎเชพเช‚ เช…เชชเช—เซเชฐเซ‡เชก เช•เชฐเชตเชพเชจเซ€ เชฏเซ‹เชœเชจเชพ เชฌเชจเชพเชตเซ€เช เช›เซ€เช.

เชธเซเชงเชพเชฐเชพเชจเซ€ เชคเชพเชฐเซ€เช–:

เชตเชšเชจ เชฎเซเชœเชฌ, เชฎเซ‡เช‚ เชคเซ‡เชจเซ‡ เชชเชกเช•เชพเชฐ-เชชเซเชฐเชคเชฟเชญเชพเชต เชตเชฟเช•เชฒเซเชชเชฎเชพเช‚ เชŸเซเชตเชฟเช• เช•เชฐเซเชฏเซเช‚.
เชคเซ‡เชฅเซ€:
เชซเชพเชˆเชฒเชฎเชพเช‚ /etc/raddb/sites-enabled/default เชตเชฟเชญเชพเช— เช…เชงเชฟเช•เซƒเชค เช†เชจเชพ เชœเซ‡เชตเซเช‚ เชฒเชพเช—เซ‡ เช›เซ‡:

authorize {
    filter_username
    preprocess
    auth_log
    chap
    mschap
    suffix
    eap {
        ok = return
    }
    files
    -sql
    #-ldap
    expiration
    logintime
    if (!State) {
        if (&User-Password) {
            # If !State and User-Password (PAP), then force LDAP:
            update control {
                Ldap-UserDN := "%{User-Name}"
                Auth-Type := LDAP
            }
        }
        else {
            reject
        }
    }
    else {
        # If State, then proxy request:
        group_authorization
    }
pap
}

เชตเชฟเชญเชพเช— เชชเซเชฐเชฎเชพเชฃเชฟเชค เช•เชฐเชตเซเช‚ เชนเชตเซ‡ เช†เชจเชพ เชœเซ‡เชตเซ‹ เชฆเซ‡เช–เชพเชฏ เช›เซ‡:

authenticate {
        Auth-Type PAP {
                pap
        }
        Auth-Type CHAP {
                chap
        }
        Auth-Type MS-CHAP {
                mschap
        }
        mschap
        digest
        # Attempt authentication with a direct LDAP bind:
        Auth-Type LDAP {
        ldap
        if (ok) {
            update reply {
                # Create a random State attribute:
                State := "%{randstr:aaaaaaaaaaaaaaaa}"
                Reply-Message := "Please enter OTP"
                }
            # Return Access-Challenge:
            challenge
            }
        }
        pam
        eap
}

เชนเชตเซ‡ เชตเชชเชฐเชพเชถเช•เชฐเซเชคเชพ เชšเช•เชพเชธเชฃเซ€ เชจเซ€เชšเซ‡เชจเชพ เช…เชฒเซเช—เซ‹เชฐเชฟเชงเชฎ เชฎเซเชœเชฌ เชฅเชพเชฏ เช›เซ‡:

  • เชตเชชเชฐเชพเชถเช•เชฐเซเชคเชพ VPN เช•เซเชฒเชพเชฏเช‚เชŸเชฎเชพเช‚ เชกเซ‹เชฎเซ‡เชจ เช•เซเชฐเซ‡เชกเชฟเชŸ เชฆเชพเช–เชฒ เช•เชฐเซ‡ เช›เซ‡.
  • เชซเซเชฐเซ€เชฐเซ‡เชกเชฟเชฏเชธ เชเช•เชพเช‰เชจเซเชŸ เช…เชจเซ‡ เชชเชพเชธเชตเชฐเซเชกเชจเซ€ เชฎเชพเชจเซเชฏเชคเชพ เชคเชชเชพเชธเซ‡ เช›เซ‡
  • เชœเซ‹ เชชเชพเชธเชตเชฐเซเชก เชธเชพเชšเซ‹ เชนเซ‹เชฏ, เชคเซ‹ เชŸเซ‹เช•เชจ เชฎเชพเชŸเซ‡ เชตเชฟเชจเช‚เชคเซ€ เชฎเซ‹เช•เชฒเชตเชพเชฎเชพเช‚ เช†เชตเซ‡ เช›เซ‡.
  • เชŸเซ‹เช•เชจ เชšเช•เชพเชธเชตเชพเชฎเชพเช‚ เช†เชตเซ€ เชฐเชนเซเชฏเซเช‚ เช›เซ‡.
  • เชจเชซเซ‹).

เชธเซ‹เชฐเซเชธ: www.habr.com

เชเช• เชŸเชฟเชชเซเชชเชฃเซ€ เช‰เชฎเซ‡เชฐเซ‹