/* * Copyright 2016 Red Hat, Inc. and/or its affiliates * and other contributors as indicated by the @author tags. * * 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. */ package org.keycloak.protocol; import org.keycloak.events.EventBuilder; import org.keycloak.models.ClientModel; import org.keycloak.models.ClientTemplateModel; import org.keycloak.models.ProtocolMapperModel; import org.keycloak.models.RealmModel; import org.keycloak.provider.ProviderFactory; import org.keycloak.representations.idm.ClientRepresentation; import org.keycloak.representations.idm.ClientTemplateRepresentation; import java.util.List; /** * @author <a href="mailto:bill@burkecentral.com">Bill Burke</a> * @version $Revision: 1 $ */ public interface LoginProtocolFactory extends ProviderFactory<LoginProtocol> { /** * List of built in protocol mappers that can be used to apply to clients. * * @return */ List<ProtocolMapperModel> getBuiltinMappers(); /** * List of mappers, which are added to new clients by default * @return */ List<ProtocolMapperModel> getDefaultBuiltinMappers(); Object createProtocolEndpoint(RealmModel realm, EventBuilder event); /** * Setup default values for new clients. This expects that the representation has already set up the client * * @param rep * @param newClient */ void setupClientDefaults(ClientRepresentation rep, ClientModel newClient); /** * Setup default values for new templates. This expects that the representation has already set up the template * * @param clientRep * @param newClient */ void setupTemplateDefaults(ClientTemplateRepresentation clientRep, ClientTemplateModel newClient); }