74 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			TypeScript
		
	
	
			
		
		
	
	
			74 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			TypeScript
		
	
	
/*
 | 
						|
Copyright 2024 New Vector Ltd.
 | 
						|
Copyright 2023 The Matrix.org Foundation C.I.C.
 | 
						|
 | 
						|
SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only
 | 
						|
Please see LICENSE files in the repository root for full details.
 | 
						|
*/
 | 
						|
 | 
						|
export interface HomeserverConfig {
 | 
						|
    readonly configDir: string;
 | 
						|
    readonly baseUrl: string;
 | 
						|
    readonly port: number;
 | 
						|
    readonly registrationSecret: string;
 | 
						|
    readonly dockerUrl: string;
 | 
						|
}
 | 
						|
 | 
						|
export interface HomeserverInstance {
 | 
						|
    readonly config: HomeserverConfig;
 | 
						|
 | 
						|
    /**
 | 
						|
     * Register a user on the given Homeserver using the shared registration secret.
 | 
						|
     * @param username the username of the user to register
 | 
						|
     * @param password the password of the user to register
 | 
						|
     * @param displayName optional display name to set on the newly registered user
 | 
						|
     */
 | 
						|
    registerUser(username: string, password: string, displayName?: string): Promise<Credentials>;
 | 
						|
 | 
						|
    /**
 | 
						|
     * Logs into synapse with the given username/password
 | 
						|
     * @param userId login username
 | 
						|
     * @param password login password
 | 
						|
     */
 | 
						|
    loginUser(userId: string, password: string): Promise<Credentials>;
 | 
						|
 | 
						|
    /**
 | 
						|
     * Sets a third party identifier for the given user. This only supports setting a single 3pid and will
 | 
						|
     * replace any others.
 | 
						|
     * @param userId The full ID of the user to edit (as returned from registerUser)
 | 
						|
     * @param medium The medium of the 3pid to set
 | 
						|
     * @param address The address of the 3pid to set
 | 
						|
     */
 | 
						|
    setThreepid(userId: string, medium: string, address: string): Promise<void>;
 | 
						|
}
 | 
						|
 | 
						|
export interface StartHomeserverOpts {
 | 
						|
    /** path to template within playwright/plugins/{homeserver}docker/template/ directory. */
 | 
						|
    template: string;
 | 
						|
 | 
						|
    /** Port of an OAuth server to configure the homeserver to use */
 | 
						|
    oAuthServerPort?: number;
 | 
						|
 | 
						|
    /** Additional variables to inject into the configuration template **/
 | 
						|
    variables?: Record<string, string | number>;
 | 
						|
}
 | 
						|
 | 
						|
export interface Homeserver {
 | 
						|
    start(opts: StartHomeserverOpts): Promise<HomeserverInstance>;
 | 
						|
    /**
 | 
						|
     * Stop this test homeserver instance.
 | 
						|
     *
 | 
						|
     * @returns A list of paths relative to the cwd for logfiles generated during this test run.
 | 
						|
     */
 | 
						|
    stop(): Promise<string[]>;
 | 
						|
}
 | 
						|
 | 
						|
export interface Credentials {
 | 
						|
    accessToken: string;
 | 
						|
    userId: string;
 | 
						|
    deviceId: string;
 | 
						|
    homeServer: string;
 | 
						|
    password: string | null; // null for password-less users
 | 
						|
    displayName?: string;
 | 
						|
}
 |