Freeradius + Google เจชเฉเจฐเจฎเจพเจฃเจ• + LDAP + Fortigate

เจ•เฉ€ เจนเฉ‹เจตเฉ‡เจ—เจพ เจœเฉ‡เจ•เจฐ เจฆเฉ‹-เจ•เจพเจฐเจ• เจชเฉเจฐเจฎเจพเจฃเจฟเจ•เจคเจพ เจฆเฉ‹เจตเฉ‡เจ‚ เจซเจพเจ‡เจฆเฉ‡เจฎเฉฐเจฆ เจ…เจคเฉ‡ เจšเฉเฉฐเจเจฆเจพเจฐ เจนเจจ, เจชเจฐ เจนเจพเจฐเจกเจตเฉ‡เจ…เจฐ เจŸเฉ‹เจ•เจจเจพเจ‚ เจฒเจˆ เจ•เฉ‹เจˆ เจชเฉˆเจธเจพ เจจเจนเฉ€เจ‚ เจนเฉˆ เจ…เจคเฉ‡ เจ†เจฎ เจคเฉŒเจฐ 'เจคเฉ‡ เจ‰เจน เจšเฉฐเจ—เฉ‡ เจฎเฉ‚เจก เจตเจฟเฉฑเจš เจฐเจนเจฟเจฃ เจฆเฉ€ เจชเฉ‡เจธเจผเจ•เจธเจผ เจ•เจฐเจฆเฉ‡ เจนเจจเฅค

เจ‡เจน เจนเฉฑเจฒ เจ•เฉเจ เจฌเจนเฉเจค เจ…เจธเจฒเฉ€ เจจเจนเฉ€เจ‚ เจนเฉˆ, เจธเจ—เฉ‹เจ‚ เจ‡เฉฐเจŸเจฐเจจเฉˆเฉฑเจŸ 'เจคเฉ‡ เจฎเจฟเจฒเฉ‡ เจตเฉฑเจ–-เจตเฉฑเจ– เจนเฉฑเจฒเจพเจ‚ เจฆเจพ เจฎเจฟเจธเจผเจฐเจฃ เจนเฉˆเฅค

เจ‡เจธ เจฒเจˆ เจฆเจฟเฉฑเจคเจพ

เจกเฉ‹เจฎเฉˆเจจ เจเจ•เจŸเจฟเจต เจกเจพเจ‡เจฐเฉˆเจ•เจŸเจฐเฉ€.

VPN เจฐเจพเจนเฉ€เจ‚ เจ•เฉฐเจฎ เจ•เจฐเจจ เจตเจพเจฒเฉ‡ เจกเฉ‹เจฎเฉ‡เจจ เจ‰เจชเจญเฉ‹เจ—เจคเจพ, เจœเจฟเจตเฉ‡เจ‚ เจ•เจฟ เจ…เฉฑเจœ เจฌเจนเฉเจค เจธเจพเจฐเฉ‡เฅค

VPN เจ—เฉ‡เจŸเจตเฉ‡ เจตเจœเฉ‹เจ‚ เจ•เฉฐเจฎ เจ•เจฐเจฆเจพ เจนเฉˆ เจคเจ•เจฆเฉ€เจฐ.

เจธเฉเจฐเฉฑเจ–เจฟเจ† เจจเฉ€เจคเฉ€ เจฆเฉเจ†เจฐเจพ VPN เจ•เจฒเจพเจ‡เฉฐเจŸ เจฒเจˆ เจชเจพเจธเจตเจฐเจก เจธเฉเจฐเฉฑเจ–เจฟเจ…เจค เจ•เจฐเจจ เจฆเฉ€ เจฎเจจเจพเจนเฉ€ เจนเฉˆเฅค

เจฐเจพเจœเจจเฉ€เจคเฉ€ Fortinet เจคเฉเจนเจพเจกเฉ‡ เจ†เจชเจฃเฉ‡ เจŸเฉ‹เจ•เจจเจพเจ‚ เจฆเฉ‡ เจธเจฌเฉฐเจง เจตเจฟเฉฑเจš, เจคเฉเจธเฉ€เจ‚ เจ‡เจธเจจเฉ‚เฉฐ เจ‡เฉฑเจ• เจœเจผเจฒเฉ‹เจฌ เจคเฉ‹เจ‚ เจ˜เฉฑเจŸ เจจเจนเฉ€เจ‚ เจ•เจนเจฟ เจธเจ•เจฆเฉ‡ - เจ‡เฉฑเจฅเฉ‡ 10 เจคเฉ‹เจ‚ เจตเฉฑเจง เจฎเฉเจซเจผเจค เจŸเฉ‹เจ•เจจ เจนเจจ, เจฌเจพเจ•เฉ€ - เจ‡เฉฑเจ• เจฌเจนเฉเจค เจนเฉ€ เจ—เฉˆเจฐ-เจ•เฉ‹เจธเจผเจฐ เจ•เฉ€เจฎเจค 'เจคเฉ‡เฅค เจฎเฉˆเจ‚ RSASecureID, Duo เจ…เจคเฉ‡ เจ‡เจธ เจคเจฐเฉเจนเจพเจ‚ เจฆเฉ‡ เจตเจฟเจšเจพเจฐ เจจเจนเฉ€เจ‚ เจ•เฉ€เจคเฉ‡, เจ•เจฟเจ‰เจ‚เจ•เจฟ เจฎเฉˆเจ‚ เจ“เจชเจจ เจธเฉ‹เจฐเจธ เจšเจพเจนเฉเฉฐเจฆเจพ เจนเจพเจ‚เฅค

เจฒเฉ‹เฉœเจพเจ‚: เจฎเฉ‡เจœเจผเจฌเจพเจจ * เจจเจฟเฉฑเจ• เจธเจฅเจพเจชเจฟเจค เจฆเฉ‡ เจจเจพเจฒ freeradius, เจเจธเจเจธเจกเฉ€ - เจกเฉ‹เจฎเฉ‡เจจ เจตเจฟเฉฑเจš เจฆเจพเจ–เจฒ เจนเฉ‹เจ, เจกเฉ‹เจฎเฉ‡เจจ เจ‰เจชเจญเฉ‹เจ—เจคเจพ เจ‡เจธ 'เจคเฉ‡ เจ†เจธเจพเจจเฉ€ เจจเจพเจฒ เจชเฉเจฐเจฎเจพเจฃเจฟเจค เจ•เจฐ เจธเจ•เจฆเฉ‡ เจนเจจ.

เจตเจพเจงเฉ‚ เจชเฉˆเจ•เฉ‡เจœ: เจธเจผเฉˆเจฒเฉ€เจจเจพ เจฌเจพเจ•เจธ, เจ…เฉฐเจœเฉ€เจฐ, freeradius-ldap, เจซเฉŒเจ‚เจŸ rebel.tlf เจฐเจฟเจชเฉ‹เจœเจผเจŸเจฐเฉ€ เจคเฉฑเจ• https://github.com/xero/figlet-fonts.

เจฎเฉ‡เจฐเฉ€ เจ‰เจฆเจพเจนเจฐเจฃ เจตเจฟเฉฑเจš - CentOS 7.8.

เจ•เฉฐเจฎ เจฆเจพ เจคเจฐเจ• เจนเฉ‡เจ  เจฒเจฟเจ–เฉ‡ เจ…เจจเฉเจธเจพเจฐ เจนเฉ‹เจฃเจพ เจšเจพเจนเฉ€เจฆเจพ เจนเฉˆ: VPN เจจเจพเจฒ เจ•เจจเฉˆเจ•เจŸ เจ•เจฐเจฆเฉ‡ เจธเจฎเฉ‡เจ‚, เจ‰เจชเจญเฉ‹เจ—เจคเจพ เจจเฉ‚เฉฐ เจ‡เฉฑเจ• เจชเจพเจธเจตเจฐเจก เจฆเฉ€ เจฌเจœเจพเจ เจ‡เฉฑเจ• เจกเฉ‹เจฎเฉ‡เจจ เจฒเฉŒเจ—เจ‡เจจ เจ…เจคเฉ‡ OTP เจฆเจฐเจœ เจ•เจฐเจจเจพ เจšเจพเจนเฉ€เจฆเจพ เจนเฉˆเฅค

เจธเฉ‡เจตเจพเจตเจพเจ‚ เจฆเจพ เจธเฉˆเฉฑเจŸเจ…เฉฑเจช

ะ’ /etc/raddb/radiusd.conf เจธเจฟเจฐเจซเจผ เจ‰เจชเจญเฉ‹เจ—เจคเจพ เจ…เจคเฉ‡ เจธเจฎเฉ‚เจน เจœเจฟเจธ เจฆเฉ€ เจคเจฐเจซเจผเฉ‹เจ‚ เจธเจผเฉเจฐเฉ‚ เจนเฉเฉฐเจฆเจพ เจนเฉˆ freeradius, เจธเฉ‡เจตเจพ เจฆเฉ‡ เจฌเจพเจ…เจฆ radiusd เจธเจพเจฐเฉ€เจ†เจ‚ เจธเจฌ-เจกเจพเจ‡เจฐเฉˆเจ•เจŸเจฐเฉ€เจ†เจ‚ เจตเจฟเฉฑเจš เจซเจพเจˆเจฒเจพเจ‚ เจจเฉ‚เฉฐ เจชเฉœเฉเจนเจจ เจฆเฉ‡ เจฏเฉ‹เจ— เจนเฉ‹เจฃเจพ เจšเจพเจนเฉ€เจฆเจพ เจนเฉˆ / เจ˜เจฐ /.

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 เจญเจพเจ— เจตเจฟเฉฑเจš เจ…เจงเจฟเจ•เจพเจฐเจค เจฎเฉˆเจ‚ เจตเจฐเจคเฉ€ เจœเจพเจฃ เจตเจพเจฒเฉ€ เจจเฉ€เจคเฉ€ เจฆเจพ เจจเจพเจฎ เจœเฉ‹เฉœเจฆเจพ เจนเจพเจ‚ - group_authorization. เจ‡เฉฑเจ• เจฎเจนเฉฑเจคเจตเจชเฉ‚เจฐเจฃ เจจเฉเจ•เจคเจพ - เจจเฉ€เจคเฉ€ เจฆเจพ เจจเจพเจฎ เจกเจพเจ‡เจฐเฉˆเจ•เจŸเจฐเฉ€ เจตเจฟเฉฑเจš เจซเจพเจˆเจฒ เจฆเฉ‡ เจจเจพเจฎ เจฆเฉเจ†เจฐเจพ เจจเจฟเจฐเจงเจพเจฐเจค เจจเจนเฉ€เจ‚ เจ•เฉ€เจคเจพ เจœเจพเจ‚เจฆเจพ เจนเฉˆ เจชเจพเจฒเจฟเจธเฉ€.เจกเฉ€, เจชเจฐ เจ•เจฐเจฒเฉ€ เจฌเจฐเฉ‡เจธ เจคเฉ‹เจ‚ เจชเจนเจฟเจฒเจพเจ‚ เจซเจพเจˆเจฒ เจฆเฉ‡ เจ…เฉฐเจฆเจฐ เจ‡เฉฑเจ• เจจเจฟเจฐเจฆเฉ‡เจธเจผ เจฆเฉเจ†เจฐเจพเฅค
เจญเจพเจ— เจตเจฟเฉฑเจš เจชเฉเจฐเจฎเจพเจฃเจฟเจค เจ‰เจนเฉ€ เจซเจพเจˆเจฒเจพเจ‚ เจตเจฟเฉฑเจš เจคเฉเจนเจพเจจเฉ‚เฉฐ เจฒเจพเจˆเจจ เจจเฉ‚เฉฐ เจ…เจจเจ•เจฎเฉ‡เจ‚เจŸ เจ•เจฐเจจ เจฆเฉ€ เจฒเฉ‹เฉœ เจนเฉˆ เจชเฉˆเจฎ.

เจซเจพเจˆเจฒ เจตเจฟเฉฑเจš clients.conf เจ‰เจน เจฎเจพเจชเจฆเฉฐเจก เจฒเจฟเจ–เฉ‹ เจœเจฟเจธ เจจเจพเจฒ เจ‡เจน เจœเฉเฉœ เจœเจพเจตเฉ‡เจ—เจพ เจคเจ•เจฆเฉ€เจฐ:

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

เจฎเฉ‹เจกเฉ€uleเจฒ เจธเฉฐเจฐเจšเจจเจพ 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

เจชเฉ‚เจฐเจต-เจจเจฟเจฐเจงเจพเจฐเจค เจฌเฉฐเจกเจฒ เจฒเจพเจ—เฉ‚ เจ•เจฐเจจ เจฆเฉ‡ เจตเจฟเจ•เจฒเจช freeradius ั เจ—เฉ‚เจ—เจฒ เจชเฉเจฐเจฎเจพเจฃเจ•เจฐเจคเจพ เจ‰เจชเจญเฉ‹เจ—เจคเจพ เจจเฉ‚เฉฐ เจซเจพเจฐเจฎเฉˆเจŸ เจตเจฟเฉฑเจš เจชเฉเจฐเจฎเจพเจฃ เจชเฉฑเจคเจฐ เจฆเจพเจ–เจฒ เจ•เจฐเจจ เจฆเฉ€ เจฒเฉ‹เฉœ เจนเฉˆ: เจ‰เจชเจญเฉ‹เจ—เจคเจพ เจจเจพเจฎ/เจชเจพเจธเจตเจฐเจก+OTP.

เจกเจฟเจซเจพเจฒเจŸ เจฌเฉฐเจกเจฒ เจฆเฉ€ เจตเจฐเจคเฉ‹เจ‚ เจ•เจฐเจจ เจฆเฉ‡ เจฎเจพเจฎเจฒเฉ‡ เจตเจฟเฉฑเจš, เจธเจฟเจฐ 'เจคเฉ‡ เจกเจฟเฉฑเจ—เจฃ เจตเจพเจฒเฉ‡ เจธเจฐเจพเจชเจพเจ‚ เจฆเฉ€ เจ—เจฟเจฃเจคเฉ€ เจฆเฉ€ เจ•เจฒเจชเจจเจพ เจ•เจฐเจ•เฉ‡. freeradius ั Google Authenticator, เจฎเฉ‹เจกเฉ€เจŠเจฒ เจธเฉฐเจฐเจšเจจเจพ เจฆเฉ€ เจตเจฐเจคเฉ‹เจ‚ เจ•เจฐเจจ เจฆเจพ เจซเฉˆเจธเจฒเจพ เจ•เฉ€เจคเจพ เจ—เจฟเจ† เจธเฉ€ เจชเฉˆเจฎ เจคเจพเจ‚ เจœเฉ‹ เจธเจฟเจฐเจซ เจŸเฉ‹เจ•เจจ เจฆเฉ€ เจœเจพเจ‚เจš เจ•เฉ€เจคเฉ€ เจœเจพ เจธเจ•เฉ‡ Google Authenticator.

เจœเจฆเฉ‹เจ‚ เจ•เฉ‹เจˆ เจ‰เจชเจญเฉ‹เจ—เจคเจพ เจ•เจจเฉˆเจ•เจŸ เจ•เจฐเจฆเจพ เจนเฉˆ, เจคเจพเจ‚ เจ‡เจน เจตเจพเจชเจฐเจฆเจพ เจนเฉˆ:

  • Freeradius เจœเจพเจ‚เจš เจ•เจฐเจฆเจพ เจนเฉˆ เจ•เจฟ เจ•เฉ€ เจ‰เจชเจญเฉ‹เจ—เจคเจพ เจกเฉ‹เจฎเฉ‡เจจ เจตเจฟเฉฑเจš เจนเฉˆ เจ…เจคเฉ‡ เจ‡เฉฑเจ• เจ–เจพเจธ เจธเจฎเฉ‚เจน เจตเจฟเฉฑเจš เจนเฉˆ เจ…เจคเฉ‡, เจœเฉ‡เจ•เจฐ เจธเจซเจฒ เจนเฉเฉฐเจฆเจพ เจนเฉˆ, เจคเจพเจ‚ OTP เจŸเฉ‹เจ•เจจ เจฆเฉ€ เจœเจพเจ‚เจš เจ•เจฐเจฆเจพ เจนเฉˆเฅค

เจธเจญ เจ•เฉเจ เจ‰เจธ เจชเจฒ เจคเฉฑเจ• เจ•เจพเจซเจผเฉ€ เจตเจงเฉ€เจ† เจฒเฉฑเจ— เจฐเจฟเจนเจพ เจธเฉ€ เจœเจฆเฉ‹เจ‚ เจฎเฉˆเจ‚ เจธเฉ‹เจšเจฟเจ† เจ•เจฟ "เจฎเฉˆเจ‚ 300+ เจ‰เจชเจญเฉ‹เจ—เจคเจพเจตเจพเจ‚ เจฒเจˆ OTP เจ•เจฟเจตเฉ‡เจ‚ เจฐเจœเจฟเจธเจŸเจฐ เจ•เจฐ เจธเจ•เจฆเจพ เจนเจพเจ‚?"

เจ‰เจชเจญเฉ‹เจ—เจคเจพ เจจเฉ‚เฉฐ เจธเจฐเจตเจฐ เจจเจพเจฒ เจฒเจพเจ—เจ‡เจจ เจ•เจฐเจจเจพ เจšเจพเจนเฉ€เจฆเจพ เจนเฉˆ freeradius เจ…เจคเฉ‡ เจ†เจชเจฃเฉ‡ เจ–เจพเจคเฉ‡ เจฆเฉ‡ เจนเฉ‡เจ เจพเจ‚ เจคเฉ‹เจ‚ เจ…เจคเฉ‡ เจเจชเจฒเฉ€เจ•เฉ‡เจธเจผเจจ เจšเจฒเจพเจ“ เจ—เฉ‚เจ—เจฒ เจชเฉเจฐเจฎเจพเจฃเฉ€เจ•เจฐเจคเจพ, เจœเฉ‹ เจ‰เจชเจญเฉ‹เจ—เจคเจพ เจฒเจˆ เจเจชเจฒเฉ€เจ•เฉ‡เจธเจผเจจ เจฒเจˆ เจ‡เฉฑเจ• QR เจ•เฉ‹เจก เจคเจฟเจ†เจฐ เจ•เจฐเฉ‡เจ—เจพเฅค เจ‡เจน เจ‰เจน เจฅเจพเจ‚ เจนเฉˆ เจœเจฟเฉฑเจฅเฉ‡ เจฎเจฆเจฆ เจ†เจ‰เจ‚เจฆเฉ€ เจนเฉˆเฅค เจธเจผเฉˆเจฒเฉ€เจจเจพ เจฌเจพเจ•เจธ เจฆเฉ‡ เจจเจพเจฒ เจธเฉเจฎเฉ‡เจฒ เจตเจฟเฉฑเจš .bash_profile.

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

เจกเฉˆเจฎเจจ เจธเฉฐเจฐเจšเจจเจพ เจซเจพเจ‡เจฒ 'เจคเฉ‡ เจธเจฅเจฟเจค เจนเฉˆ /etc/sysconfig/shellinabox.
เจฎเฉˆเจ‚ เจ‰เฉฑเจฅเฉ‡ เจชเฉ‹เจฐเจŸ 443 เจจเจฟเจฐเจงเจพเจฐเจฟเจค เจ•เจฐเจฆเจพ เจนเจพเจ‚ เจ…เจคเฉ‡ เจคเฉเจธเฉ€เจ‚ เจ†เจชเจฃเจพ เจธเจฐเจŸเฉ€เจซเจฟเจ•เฉ‡เจŸ เจจเจฟเจฐเจงเจพเจฐเจค เจ•เจฐ เจธเจ•เจฆเฉ‡ เจนเฉ‹เฅค

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

เจ‰เจชเจญเฉ‹เจ—เจคเจพ เจจเฉ‚เฉฐ เจธเจฟเจฐเจซ เจฒเจฟเฉฐเจ• เจฆเฉ€ เจชเจพเจฒเจฃเจพ เจ•เจฐเจจ, เจกเฉ‹เจฎเฉ‡เจจ เจ•เฉเจฐเฉˆเจกเจฟเจŸ เจฆเจพเจ–เจฒ เจ•เจฐเจจ เจ…เจคเฉ‡ เจเจชเจฒเฉ€เจ•เฉ‡เจธเจผเจจ เจฒเจˆ เจ‡เฉฑเจ• QR เจ•เฉ‹เจก เจชเฉเจฐเจพเจชเจค เจ•เจฐเจจ เจฆเฉ€ เจฒเฉ‹เฉœ เจนเฉเฉฐเจฆเฉ€ เจนเฉˆเฅค

เจเจฒเจ—เฉ‹เจฐเจฟเจฆเจฎ เจนเฉ‡เจ  เจฒเจฟเจ–เฉ‡ เจ…เจจเฉเจธเจพเจฐ เจนเฉˆ:

  • เจ‰เจชเจญเฉ‹เจ—เจคเจพ เจ‡เฉฑเจ• เจฌเฉเจฐเจพเจŠเจœเจผเจฐ เจฐเจพเจนเฉ€เจ‚ เจฎเจธเจผเฉ€เจจ เจตเจฟเฉฑเจš เจฒเฉŒเจ—เจ‡เจจ เจ•เจฐเจฆเจพ เจนเฉˆเฅค
  • เจ•เฉ€ เจกเฉ‹เจฎเฉ‡เจจ เจ‰เจชเจญเฉ‹เจ—เจคเจพ เจฆเฉ€ เจœเจพเจ‚เจš เจ•เฉ€เจคเฉ€ เจ—เจˆ เจนเฉˆเฅค เจœเฉ‡เจ•เจฐ เจจเจนเฉ€เจ‚ เจคเจพเจ‚ เจ•เฉ‹เจˆ เจ•เจพเจฐเจตเจพเจˆ เจจเจนเฉ€เจ‚ เจ•เฉ€เจคเฉ€ เจœเจพเจ‚เจฆเฉ€เฅค
  • เจœเฉ‡เจ•เจฐ เจ‰เจชเจญเฉ‹เจ—เจคเจพ เจ‡เฉฑเจ• เจกเฉ‹เจฎเฉ‡เจจ เจ‰เจชเจญเฉ‹เจ—เจคเจพ เจนเฉˆ, เจคเจพเจ‚ เจชเฉเจฐเจธเจผเจพเจธเจ• เจธเจฎเฉ‚เจน เจตเจฟเฉฑเจš เจธเจฆเฉฑเจธเจคเจพ เจฆเฉ€ เจœเจพเจ‚เจš เจ•เฉ€เจคเฉ€ เจœเจพเจ‚เจฆเฉ€ เจนเฉˆ.
  • เจœเฉ‡เจ•เจฐ เจ•เฉ‹เจˆ เจชเฉเจฐเจธเจผเจพเจธเจ• เจจเจนเฉ€เจ‚ เจนเฉˆ, เจคเจพเจ‚ เจ‡เจน เจœเจพเจ‚เจš เจ•เจฐเจฆเจพ เจนเฉˆ เจ•เจฟ เจ•เฉ€ Google Authenticator เจ•เฉŒเจ‚เจซเจฟเจ—เจฐ เจ•เฉ€เจคเจพ เจ—เจฟเจ† เจนเฉˆเฅค เจœเฉ‡เจ•เจฐ เจจเจนเฉ€เจ‚, เจคเจพเจ‚ เจ‡เฉฑเจ• QR เจ•เฉ‹เจก เจ…เจคเฉ‡ เจ‰เจชเจญเฉ‹เจ—เจคเจพ เจฒเฉŒเจ—เจ†เจ‰เจŸ เจคเจฟเจ†เจฐ เจ•เฉ€เจคเจพ เจœเจพเจ‚เจฆเจพ เจนเฉˆเฅค
  • เจœเฉ‡เจ•เจฐ เจ•เฉ‹เจˆ เจชเฉเจฐเจธเจผเจพเจธเจ• เจจเจนเฉ€เจ‚ เจนเฉˆ เจ…เจคเฉ‡ Google เจชเฉเจฐเจฎเจพเจฃเจ• เจธเฉฐเจฐเจšเจฟเจค เจนเฉˆ, เจคเจพเจ‚ เจธเจฟเจฐเจซเจผ เจฒเฉŒเจ—เจ†เจŠเจŸ เจ•เจฐเฉ‹เฅค
  • เจœเฉ‡เจ•เจฐ เจชเฉเจฐเจธเจผเจพเจธเจ•, เจคเจพเจ‚ Google Authenticator เจจเฉ‚เฉฐ เจฆเฉเจฌเจพเจฐเจพ เจฆเฉ‡เจ–เฉ‹เฅค เจœเฉ‡เจ•เจฐ เจ•เฉŒเจ‚เจซเจฟเจ—เจฐ เจจเจนเฉ€เจ‚ เจ•เฉ€เจคเจพ เจ—เจฟเจ† เจนเฉˆ, เจคเจพเจ‚ เจ‡เฉฑเจ• 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

เจซเฉ‹เจฐเจŸเฉ€เจ—เฉ‡เจŸ เจธเฉˆเฉฑเจŸเจ…เฉฑเจช:

  • เจ…เจธเฉ€เจ‚ เจฌเจฃเจพเจ‰เจ‚เจฆเฉ‡ เจนเจพเจ‚ เจตเจฟเจ†เจธ-เจธเจฐเจตเจฐ

    Freeradius + Google เจชเฉเจฐเจฎเจพเจฃเจ• + LDAP + Fortigate

  • เจ…เจธเฉ€เจ‚ เจฒเฉ‹เฉœเฉ€เจ‚เจฆเฉ‡ เจธเจฎเฉ‚เจน เจฌเจฃเจพเจ‰เจ‚เจฆเฉ‡ เจนเจพเจ‚, เจœเฉ‡ เจฒเฉ‹เฉœ เจนเฉ‹เจตเฉ‡, เจธเจฎเฉ‚เจนเจพเจ‚ เจฆเฉเจ†เจฐเจพ เจชเจนเฉเฉฐเจš เจจเจฟเจฏเฉฐเจคเจฐเจฃ. เจ—เจฐเฉเฉฑเจช เจฆเจพ เจจเจพเจฎ เจšเจพเจฒเฉ‚ เจนเฉˆ เจคเจ•เจฆเฉ€เจฐ เจชเจพเจธ เจ•เฉ€เจคเฉ‡ เจ—เจ เจธเจฎเฉ‚เจน เจจเจพเจฒ เจฎเฉ‡เจฒ เจ–เจพเจ‚เจฆเจพ เจนเฉ‹เจฃเจพ เจšเจพเจนเฉ€เจฆเจพ เจนเฉˆ เจตเจฟเจ•เจฐเฉ‡เจคเจพ เจตเจฟเจธเจผเฉ‡เจธเจผ เจ—เฉเจฃ Fortinet-เจธเจฎเฉ‚เจน-เจจเจพเจฎ.

    Freeradius + Google เจชเฉเจฐเจฎเจพเจฃเจ• + LDAP + Fortigate

  • เจœเจผเจฐเฉ‚เจฐเฉ€ เจธเฉฐเจชเจพเจฆเจจ SSL เจจเฉ‚เฉฐ-เจชเฉ‹เจฐเจŸเจฒเฅค

    Freeradius + Google เจชเฉเจฐเจฎเจพเจฃเจ• + LDAP + Fortigate

  • เจจเฉ€เจคเฉ€เจ†เจ‚ เจตเจฟเฉฑเจš เจ—เจฐเฉเฉฑเจชเจพเจ‚ เจจเฉ‚เฉฐ เจธเจผเจพเจฎเจฒ เจ•เจฐเจจเจพเฅค

    Freeradius + Google เจชเฉเจฐเจฎเจพเจฃเจ• + LDAP + Fortigate

เจ‡เจธ เจนเฉฑเจฒ เจฆเฉ‡ เจซเจพเจ‡เจฆเฉ‡:

  • 'เจคเฉ‡ OTP เจฆเฉเจ†เจฐเจพ เจชเฉเจฐเจฎเจพเจฃเจฟเจค เจ•เจฐเจจเจพ เจธเฉฐเจญเจต เจนเฉˆ เจคเจ•เจฆเฉ€เจฐ เจ“เจชเจจ เจธเฉ‹เจฐเจธ เจนเฉฑเจฒ.
  • 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 เจ•เจฒเจพเจ‡เฉฐเจŸ เจตเจฟเฉฑเจš เจกเฉ‹เจฎเฉ‡เจจ เจ•เฉเจฐเฉˆเจกเจฟเจŸ เจฆเจพเจ–เจฒ เจ•เจฐเจฆเจพ เจนเฉˆเฅค
  • Freeradius เจ–เจพเจคเฉ‡ เจ…เจคเฉ‡ เจชเจพเจธเจตเจฐเจก เจฆเฉ€ เจตเฉˆเจงเจคเจพ เจฆเฉ€ เจœเจพเจ‚เจš เจ•เจฐเจฆเจพ เจนเฉˆ
  • เจœเฉ‡เจ•เจฐ เจชเจพเจธเจตเจฐเจก เจธเจนเฉ€ เจนเฉˆ, เจคเจพเจ‚ เจŸเฉ‹เจ•เจจ เจฒเจˆ เจฌเฉ‡เจจเจคเฉ€ เจญเฉ‡เจœเฉ€ เจœเจพเจ‚เจฆเฉ€ เจนเฉˆเฅค
  • เจŸเฉ‹เจ•เจจ เจฆเฉ€ เจชเฉเจธเจผเจŸเฉ€ เจ•เฉ€เจคเฉ€ เจœเจพ เจฐเจนเฉ€ เจนเฉˆเฅค
  • เจฒเจพเจญ).

เจธเจฐเฉ‹เจค: www.habr.com

เจ‡เฉฑเจ• เจŸเจฟเฉฑเจชเจฃเฉ€ เจœเฉ‹เฉœเฉ‹