Skip to content

Latest commit

 

History

History
31 lines (20 loc) · 1.97 KB

post-login-hook.md

File metadata and controls

31 lines (20 loc) · 1.97 KB

Post-login hook

This hook is executed after a login or after closing a connection for authentication timeout. Defining an appropriate post_login_scope you can get notifications for failed logins, successful logins or both.

Please keep in mind that executing a hook after each login can be heavy.

The post-login-hook can be defined as the absolute path of your program or an HTTP URL.

If the hook defines an external program it can reads the following environment variables:

  • SFTPGO_LOGIND_USER, it contains the user serialized as JSON. The username is empty if the connection is closed for authentication timeout
  • SFTPGO_LOGIND_IP
  • SFTPGO_LOGIND_METHOD, possible values are publickey, password, keyboard-interactive, publickey+password, publickey+keyboard-interactive, TLSCertificate, TLSCertificate+password or no_auth_tryed, IDP (external identity provider)
  • SFTPGO_LOGIND_STATUS, 1 means login OK, 0 login KO
  • SFTPGO_LOGIND_PROTOCOL, possible values are SSH, FTP, DAV, HTTP, OIDC (OpenID Connect)

Previous global environment variables aren't cleared when the script is called. The program must finish within 20 seconds.

If the hook is an HTTP URL then it will be invoked as HTTP POST. The login method, the used protocol, the ip address and the status of the user are added to the query string, for example <http_url>?login_method=password&ip=1.2.3.4&protocol=SSH&status=1. The request body will contain the user serialized as JSON.

The structure for SFTPGo users can be found within the OpenAPI schema.

The HTTP hook will use the global configuration for HTTP clients and will respect the retry configurations.

The post_login_scope supports the following configuration values:

  • 0 means notify both failed and successful logins
  • 1 means notify failed logins. Connections closed for authentication timeout are notified as failed logins. You will get an empty username in this case
  • 2 means notify successful logins