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",
 | |
| });
 |