Greasy Fork is available in English.

Auto Click SSO Continue

在 SSO 认证页自动点击 Continue 按钮

За да инсталирате този скрипт, трябва да имате инсталирано разширение като Tampermonkey, Greasemonkey или Violentmonkey.

За да инсталирате този скрипт, трябва да инсталирате разширение, като например Tampermonkey .

За да инсталирате този скрипт, трябва да имате инсталирано разширение като Tampermonkey или Violentmonkey.

За да инсталирате този скрипт, трябва да имате инсталирано разширение като Tampermonkey или Userscripts.

За да инсталирате скрипта, трябва да инсталирате разширение като Tampermonkey.

За да инсталирате този скрипт, трябва да имате инсталиран скриптов мениджър.

(Вече имам скриптов мениджър, искам да го инсталирам!)

Advertisement:

За да инсталирате този стил, трябва да инсталирате разширение като Stylus.

За да инсталирате този стил, трябва да инсталирате разширение като Stylus.

За да инсталирате този стил, трябва да инсталирате разширение като Stylus.

За да инсталирате този стил, трябва да имате инсталиран мениджър на потребителски стилове.

За да инсталирате този стил, трябва да имате инсталиран мениджър на потребителски стилове.

За да инсталирате този стил, трябва да имате инсталиран мениджър на потребителски стилове.

(Вече имам инсталиран мениджър на стиловете, искам да го инсталирам!)

Advertisement:

// ==UserScript==
// @name         Auto Click SSO Continue
// @namespace    local-auto-sso-continue
// @version      1.0
// @description  在 SSO 认证页自动点击 Continue 按钮
// @match        https://github.com/*
// @match        https://*.okta.com/*
// @match        https://*.pingidentity.com/*
// @match        https://*/sso/*
// @match        https://*/saml/*
// @run-at       document-idle
// @grant        none
// @license MIT
// ==/UserScript==

(function () {
  'use strict';

  // 关键词:按钮文字匹配,避免依赖具体 class(SSO 模板可能变化)
  const BUTTON_TEXT = 'continue';

  function findContinueButton() {
    const candidates = document.querySelectorAll('button, a, input[type="submit"]');
    for (const el of candidates) {
      const text = (el.innerText || el.value || '').trim().toLowerCase();
      if (text === BUTTON_TEXT) {
        return el;
      }
    }
    return null;
  }

  function tryClick() {
    const btn = findContinueButton();
    if (btn && !btn.disabled) {
      btn.click();
      return true;
    }
    return false;
  }

  // 页面加载后立即尝试一次
  if (tryClick()) return;

  // 用 MutationObserver 监听 SSO 页面动态渲染(很多 SSO 页面是 SPA,按钮可能延迟出现)
  const observer = new MutationObserver(() => {
    if (tryClick()) {
      observer.disconnect();
    }
  });

  observer.observe(document.body, { childList: true, subtree: true });

  // 兜底:10秒后停止监听,避免无限占用资源
  setTimeout(() => observer.disconnect(), 10000);
})();