/* tslint:disable */ /* eslint-disable */ /** * authentik * Making authentication simple. * * The version of the OpenAPI document: 2025.6.3 * Contact: hello@goauthentik.io * * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). * https://openapi-generator.tech * Do not edit the class manually. */ import { mapValues } from '../runtime'; import type { PolicyEngineMode } from './PolicyEngineMode'; import { PolicyEngineModeFromJSON, PolicyEngineModeFromJSONTyped, PolicyEngineModeToJSON, PolicyEngineModeToJSONTyped, } from './PolicyEngineMode'; import type { UserMatchingModeEnum } from './UserMatchingModeEnum'; import { UserMatchingModeEnumFromJSON, UserMatchingModeEnumFromJSONTyped, UserMatchingModeEnumToJSON, UserMatchingModeEnumToJSONTyped, } from './UserMatchingModeEnum'; import type { GroupMatchingModeEnum } from './GroupMatchingModeEnum'; import { GroupMatchingModeEnumFromJSON, GroupMatchingModeEnumFromJSONTyped, GroupMatchingModeEnumToJSON, GroupMatchingModeEnumToJSONTyped, } from './GroupMatchingModeEnum'; /** * Plex Source Serializer * @export * @interface PlexSource */ export interface PlexSource { /** * * @type {string} * @memberof PlexSource */ readonly pk: string; /** * Source's display Name. * @type {string} * @memberof PlexSource */ name: string; /** * Internal source name, used in URLs. * @type {string} * @memberof PlexSource */ slug: string; /** * * @type {boolean} * @memberof PlexSource */ enabled?: boolean; /** * Flow to use when authenticating existing users. * @type {string} * @memberof PlexSource */ authenticationFlow?: string | null; /** * Flow to use when enrolling new users. * @type {string} * @memberof PlexSource */ enrollmentFlow?: string | null; /** * * @type {Array} * @memberof PlexSource */ userPropertyMappings?: Array; /** * * @type {Array} * @memberof PlexSource */ groupPropertyMappings?: Array; /** * Get object component so that we know how to edit the object * @type {string} * @memberof PlexSource */ readonly component: string; /** * Return object's verbose_name * @type {string} * @memberof PlexSource */ readonly verboseName: string; /** * Return object's plural verbose_name * @type {string} * @memberof PlexSource */ readonly verboseNamePlural: string; /** * Return internal model name * @type {string} * @memberof PlexSource */ readonly metaModelName: string; /** * * @type {PolicyEngineMode} * @memberof PlexSource */ policyEngineMode?: PolicyEngineMode; /** * How the source determines if an existing user should be authenticated or a new user enrolled. * @type {UserMatchingModeEnum} * @memberof PlexSource */ userMatchingMode?: UserMatchingModeEnum; /** * Objects that are managed by authentik. These objects are created and updated automatically. This flag only indicates that an object can be overwritten by migrations. You can still modify the objects via the API, but expect changes to be overwritten in a later update. * @type {string} * @memberof PlexSource */ readonly managed: string | null; /** * * @type {string} * @memberof PlexSource */ userPathTemplate?: string; /** * * @type {string} * @memberof PlexSource */ readonly icon: string; /** * How the source determines if an existing group should be used or a new group created. * @type {GroupMatchingModeEnum} * @memberof PlexSource */ groupMatchingMode?: GroupMatchingModeEnum; /** * Client identifier used to talk to Plex. * @type {string} * @memberof PlexSource */ clientId?: string; /** * Which servers a user has to be a member of to be granted access. Empty list allows every server. * @type {Array} * @memberof PlexSource */ allowedServers?: Array; /** * Allow friends to authenticate, even if you don't share a server. * @type {boolean} * @memberof PlexSource */ allowFriends?: boolean; /** * Plex token used to check friends * @type {string} * @memberof PlexSource */ plexToken: string; } /** * Check if a given object implements the PlexSource interface. */ export function instanceOfPlexSource(value: object): value is PlexSource { if (!('pk' in value) || value['pk'] === undefined) return false; if (!('name' in value) || value['name'] === undefined) return false; if (!('slug' in value) || value['slug'] === undefined) return false; if (!('component' in value) || value['component'] === undefined) return false; if (!('verboseName' in value) || value['verboseName'] === undefined) return false; if (!('verboseNamePlural' in value) || value['verboseNamePlural'] === undefined) return false; if (!('metaModelName' in value) || value['metaModelName'] === undefined) return false; if (!('managed' in value) || value['managed'] === undefined) return false; if (!('icon' in value) || value['icon'] === undefined) return false; if (!('plexToken' in value) || value['plexToken'] === undefined) return false; return true; } export function PlexSourceFromJSON(json: any): PlexSource { return PlexSourceFromJSONTyped(json, false); } export function PlexSourceFromJSONTyped(json: any, ignoreDiscriminator: boolean): PlexSource { if (json == null) { return json; } return { 'pk': json['pk'], 'name': json['name'], 'slug': json['slug'], 'enabled': json['enabled'] == null ? undefined : json['enabled'], 'authenticationFlow': json['authentication_flow'] == null ? undefined : json['authentication_flow'], 'enrollmentFlow': json['enrollment_flow'] == null ? undefined : json['enrollment_flow'], 'userPropertyMappings': json['user_property_mappings'] == null ? undefined : json['user_property_mappings'], 'groupPropertyMappings': json['group_property_mappings'] == null ? undefined : json['group_property_mappings'], 'component': json['component'], 'verboseName': json['verbose_name'], 'verboseNamePlural': json['verbose_name_plural'], 'metaModelName': json['meta_model_name'], 'policyEngineMode': json['policy_engine_mode'] == null ? undefined : PolicyEngineModeFromJSON(json['policy_engine_mode']), 'userMatchingMode': json['user_matching_mode'] == null ? undefined : UserMatchingModeEnumFromJSON(json['user_matching_mode']), 'managed': json['managed'], 'userPathTemplate': json['user_path_template'] == null ? undefined : json['user_path_template'], 'icon': json['icon'], 'groupMatchingMode': json['group_matching_mode'] == null ? undefined : GroupMatchingModeEnumFromJSON(json['group_matching_mode']), 'clientId': json['client_id'] == null ? undefined : json['client_id'], 'allowedServers': json['allowed_servers'] == null ? undefined : json['allowed_servers'], 'allowFriends': json['allow_friends'] == null ? undefined : json['allow_friends'], 'plexToken': json['plex_token'], }; } export function PlexSourceToJSON(json: any): PlexSource { return PlexSourceToJSONTyped(json, false); } export function PlexSourceToJSONTyped(value?: Omit | null, ignoreDiscriminator: boolean = false): any { if (value == null) { return value; } return { 'name': value['name'], 'slug': value['slug'], 'enabled': value['enabled'], 'authentication_flow': value['authenticationFlow'], 'enrollment_flow': value['enrollmentFlow'], 'user_property_mappings': value['userPropertyMappings'], 'group_property_mappings': value['groupPropertyMappings'], 'policy_engine_mode': PolicyEngineModeToJSON(value['policyEngineMode']), 'user_matching_mode': UserMatchingModeEnumToJSON(value['userMatchingMode']), 'user_path_template': value['userPathTemplate'], 'group_matching_mode': GroupMatchingModeEnumToJSON(value['groupMatchingMode']), 'client_id': value['clientId'], 'allowed_servers': value['allowedServers'], 'allow_friends': value['allowFriends'], 'plex_token': value['plexToken'], }; }