mirror of https://github.com/vector-im/riot-web
				
				
				
			
		
			
				
	
	
		
			55 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			TypeScript
		
	
	
			
		
		
	
	
			55 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			TypeScript
		
	
	
/*
 | 
						|
Copyright 2023 The Matrix.org Foundation C.I.C.
 | 
						|
 | 
						|
Licensed under the Apache License, Version 2.0 (the "License");
 | 
						|
you may not use this file except in compliance with the License.
 | 
						|
You may obtain a copy of the License at
 | 
						|
 | 
						|
    http://www.apache.org/licenses/LICENSE-2.0
 | 
						|
 | 
						|
Unless required by applicable law or agreed to in writing, software
 | 
						|
distributed under the License is distributed on an "AS IS" BASIS,
 | 
						|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
						|
See the License for the specific language governing permissions and
 | 
						|
limitations under the License.
 | 
						|
*/
 | 
						|
 | 
						|
import { OidcClientConfig } from "matrix-js-sdk/src/matrix";
 | 
						|
import { ValidatedIssuerMetadata } from "matrix-js-sdk/src/oidc/validate";
 | 
						|
 | 
						|
/**
 | 
						|
 * Makes a valid OidcClientConfig with minimum valid values
 | 
						|
 * @param issuer used as the base for all other urls
 | 
						|
 * @returns OidcClientConfig
 | 
						|
 */
 | 
						|
export const makeDelegatedAuthConfig = (issuer = "https://auth.org/"): OidcClientConfig => {
 | 
						|
    const metadata = mockOpenIdConfiguration(issuer);
 | 
						|
 | 
						|
    return {
 | 
						|
        accountManagementEndpoint: issuer + "account",
 | 
						|
        registrationEndpoint: metadata.registration_endpoint,
 | 
						|
        authorizationEndpoint: metadata.authorization_endpoint,
 | 
						|
        tokenEndpoint: metadata.token_endpoint,
 | 
						|
        metadata,
 | 
						|
    };
 | 
						|
};
 | 
						|
 | 
						|
/**
 | 
						|
 * Useful for mocking <issuer>/.well-known/openid-configuration
 | 
						|
 * @param issuer used as the base for all other urls
 | 
						|
 * @returns ValidatedIssuerMetadata
 | 
						|
 */
 | 
						|
export const mockOpenIdConfiguration = (issuer = "https://auth.org/"): ValidatedIssuerMetadata => ({
 | 
						|
    issuer,
 | 
						|
    revocation_endpoint: issuer + "revoke",
 | 
						|
    token_endpoint: issuer + "token",
 | 
						|
    authorization_endpoint: issuer + "auth",
 | 
						|
    registration_endpoint: issuer + "registration",
 | 
						|
    device_authorization_endpoint: issuer + "device",
 | 
						|
    jwks_uri: issuer + "jwks",
 | 
						|
    response_types_supported: ["code"],
 | 
						|
    grant_types_supported: ["authorization_code", "refresh_token"],
 | 
						|
    code_challenge_methods_supported: ["S256"],
 | 
						|
    account_management_uri: issuer + "account",
 | 
						|
});
 |