Gateway
Semantiek van authenticatiegegevens
Dit document definieert de canonieke semantiek voor geschiktheid en resolutie van referenties die wordt gebruikt in:
resolveAuthProfileOrderresolveApiKeyForProfilemodels status --probedoctor-auth
Het doel is om gedrag tijdens selectie en runtime op elkaar afgestemd te houden.
Stabiele reden-codes voor probes
okexcluded_by_auth_ordermissing_credentialinvalid_expiresexpiredunresolved_refno_model
Tokenreferenties
Tokenreferenties (type: "token") ondersteunen inline token en/of tokenRef.
Geschiktheidsregels
- Een tokenprofiel is niet geschikt wanneer zowel
tokenalstokenRefontbreken. expiresis optioneel.- Als
expiresaanwezig is, moet dit een eindig getal groter dan0zijn. - Als
expiresongeldig is (NaN,0, negatief, niet-eindig of van het verkeerde type), is het profiel niet geschikt metinvalid_expires. - Als
expiresin het verleden ligt, is het profiel niet geschikt metexpired. tokenRefomzeilt de validatie vanexpiresniet.
Resolutieregels
- Resolversemantiek komt overeen met geschiktheidssemantiek voor
expires. - Voor geschikte profielen kan tokenmateriaal worden opgelost vanuit een inline waarde of
tokenRef. - Niet-oplosbare referenties produceren
unresolved_refin de uitvoer vanmodels status --probe.
Overdraagbaarheid van agentkopieën
Overerving van agentverificatie is read-through. Wanneer een agent geen lokaal profiel heeft, kan deze tijdens runtime profielen oplossen vanuit de standaard-/hoofdopslag van de agent zonder geheim materiaal naar zijn eigen auth-profiles.json te kopiëren.
Expliciete kopieerstromen, zoals openclaw agents add, gebruiken dit overdraagbaarheidsbeleid:
api_key-profielen zijn overdraagbaar, tenzijcopyToAgents: false.token-profielen zijn overdraagbaar, tenzijcopyToAgents: false.oauth-profielen zijn standaard niet overdraagbaar omdat refreshtokens eenmalig bruikbaar of rotatiegevoelig kunnen zijn.- OAuth-stromen die eigendom zijn van providers kunnen zich aanmelden met
copyToAgents: truealleen wanneer bekend is dat het kopiëren van refreshmateriaal tussen agents veilig is.
Niet-overdraagbare profielen blijven beschikbaar via read-through overerving, tenzij de doelagent afzonderlijk inlogt en zijn eigen lokale profiel maakt.
Config-only verificatieroutes
auth.profiles-vermeldingen met mode: "aws-sdk" zijn routeringsmetadata, geen opgeslagen referenties. Ze zijn geldig wanneer de doelprovider models.providers.<id>.auth: "aws-sdk" gebruikt of de ingebouwde standaard AWS SDK-route van Amazon Bedrock. Deze profiel-id's mogen voorkomen in auth.order en sessie-overschrijvingen, zelfs wanneer er geen overeenkomende vermelding bestaat in auth-profiles.json.
Schrijf type: "aws-sdk" niet naar auth-profiles.json. Als een verouderde installatie zo'n markering heeft, verplaatst openclaw doctor --fix deze naar auth.profiles en verwijdert de markering uit de referentieopslag.
Expliciete filtering op verificatievolgorde
- Wanneer
auth.order.<provider>of de volgorde-overschrijving van de auth-store is ingesteld voor een provider, probetmodels status --probealleen profiel-id's die in de opgeloste verificatievolgorde voor die provider blijven. - Een opgeslagen profiel voor die provider dat is weggelaten uit de expliciete volgorde, wordt later niet stilzwijgend geprobeerd. Probe-uitvoer rapporteert dit met
reasonCode: excluded_by_auth_orderen de detailsExcluded by auth.order for this provider.
Resolutie van probedoelen
- Probedoelen kunnen afkomstig zijn van verificatieprofielen, omgevingsreferenties of
models.json. - Als een provider referenties heeft maar OpenClaw geen probeerbare modelkandidaat ervoor kan oplossen, rapporteert
models status --probestatus: no_modelmetreasonCode: no_model.
Externe CLI-referentiedetectie
- Runtime-only referenties die eigendom zijn van externe CLI's worden alleen ontdekt wanneer de provider, runtime of het verificatieprofiel binnen bereik is voor de huidige bewerking, of wanneer er al een opgeslagen lokaal profiel voor die externe bron bestaat.
- Auth-store-aanroepers moeten een expliciete detectiemodus voor externe CLI's kiezen:
nonevoor alleen persistente/plugin-verificatie,existingvoor het vernieuwen van al opgeslagen externe CLI-profielen, ofscopedvoor een concrete provider-/profielset. - Alleen-lezen/statuspaden geven
allowKeychainPrompt: falsedoor; ze gebruiken alleen bestandsgebaseerde externe CLI-referenties en lezen of hergebruiken geen macOS Keychain-resultaten.
OAuth SecretRef-beleidsbescherming
- SecretRef-invoer is alleen voor statische referenties.
- Als een profielreferentie
type: "oauth"is, worden SecretRef-objecten niet ondersteund voor dat profielreferentiemateriaal. - Als
auth.profiles.<id>.mode"oauth"is, wordt SecretRef-gebaseerdekeyRef/tokenRef-invoer voor dat profiel geweigerd. - Schendingen zijn harde fouten in verificatieresolutiepaden voor opstarten/herladen.
Legacy-compatibele berichten
Voor scriptcompatibiliteit behouden probe-fouten deze eerste regel ongewijzigd:
Auth profile credentials are missing or expired.
Mensvriendelijke details en stabiele reden-codes kunnen op volgende regels worden toegevoegd.