aerogear
This commit is contained in:
parent
b1a480c20d
commit
eb9335f706
19 changed files with 197 additions and 49 deletions
26
forms/common-themes/src/main/java/org/keycloak/theme/ClassLoaderTheme.java
Normal file → Executable file
26
forms/common-themes/src/main/java/org/keycloak/theme/ClassLoaderTheme.java
Normal file → Executable file
|
@ -12,25 +12,29 @@ import java.util.Properties;
|
|||
*/
|
||||
public class ClassLoaderTheme implements Theme {
|
||||
|
||||
private final String name;
|
||||
private String name;
|
||||
|
||||
private final String parentName;
|
||||
private String parentName;
|
||||
|
||||
private final String importName;
|
||||
private String importName;
|
||||
|
||||
private final Type type;
|
||||
private Type type;
|
||||
|
||||
private final ClassLoader classLoader;
|
||||
private ClassLoader classLoader;
|
||||
|
||||
private final String templateRoot;
|
||||
private String templateRoot;
|
||||
|
||||
private final String resourceRoot;
|
||||
private String resourceRoot;
|
||||
|
||||
private final String messages;
|
||||
private String messages;
|
||||
|
||||
private final Properties properties;
|
||||
private Properties properties;
|
||||
|
||||
public ClassLoaderTheme(String name, Type type, ClassLoader classLoader) throws IOException {
|
||||
init(name, type, classLoader);
|
||||
}
|
||||
|
||||
public void init(String name, Type type, ClassLoader classLoader) throws IOException {
|
||||
this.name = name;
|
||||
this.type = type;
|
||||
this.classLoader = classLoader;
|
||||
|
@ -53,6 +57,10 @@ public class ClassLoaderTheme implements Theme {
|
|||
}
|
||||
}
|
||||
|
||||
public ClassLoaderTheme() {
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
public String getName() {
|
||||
return name;
|
||||
|
|
3
forms/common-themes/src/main/resources/theme/admin/keycloak/resources/css/styles.css
Normal file → Executable file
3
forms/common-themes/src/main/resources/theme/admin/keycloak/resources/css/styles.css
Normal file → Executable file
|
@ -31,4 +31,5 @@
|
|||
border-bottom: none;
|
||||
border-right-color: rgba(255,255,255,0.15);
|
||||
border-top-color: rgba(255,255,255,0.05);
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -85,7 +85,7 @@
|
|||
</dependencies>
|
||||
|
||||
<build>
|
||||
<finalName>app</finalName>
|
||||
<finalName>aerogear-ups</finalName>
|
||||
<plugins>
|
||||
<plugin>
|
||||
<groupId>org.jboss.as.plugins</groupId>
|
||||
|
|
|
@ -15,8 +15,8 @@ public class BootstrapListener implements ServletContextListener {
|
|||
public void contextInitialized(ServletContextEvent sce) {
|
||||
AdapterDeploymentContext deploymentContext = (AdapterDeploymentContext)sce.getServletContext().getAttribute(AdapterDeploymentContext.class.getName());
|
||||
AdapterConfig config = new AdapterConfig();
|
||||
config.setRealm("demo");
|
||||
config.setResource("customer-portal");
|
||||
config.setRealm("aerogear");
|
||||
config.setResource("unified-push-server");
|
||||
config.setAuthServerUrl("/auth");
|
||||
config.setSslNotRequired(true);
|
||||
config.setPublicClient(true);
|
||||
|
|
|
@ -4,7 +4,7 @@
|
|||
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
|
||||
version="3.0">
|
||||
|
||||
<module-name>app</module-name>
|
||||
<module-name>aerogear-ups</module-name>
|
||||
|
||||
<listener>
|
||||
<listener-class>org.keycloak.example.BootstrapListener</listener-class>
|
||||
|
@ -13,28 +13,8 @@
|
|||
|
||||
<security-constraint>
|
||||
<web-resource-collection>
|
||||
<web-resource-name>Customers</web-resource-name>
|
||||
<url-pattern>/customers/*</url-pattern>
|
||||
</web-resource-collection>
|
||||
<auth-constraint>
|
||||
<role-name>user</role-name>
|
||||
</auth-constraint>
|
||||
</security-constraint>
|
||||
|
||||
<security-constraint>
|
||||
<web-resource-collection>
|
||||
<web-resource-name>AdminConsole</web-resource-name>
|
||||
<url-pattern>/admin/*</url-pattern>
|
||||
</web-resource-collection>
|
||||
<auth-constraint>
|
||||
<role-name>admin</role-name>
|
||||
</auth-constraint>
|
||||
</security-constraint>
|
||||
|
||||
<security-constraint>
|
||||
<web-resource-collection>
|
||||
<web-resource-name>Database</web-resource-name>
|
||||
<url-pattern>/rest/*</url-pattern>
|
||||
<web-resource-name>UPS</web-resource-name>
|
||||
<url-pattern>/ups/*</url-pattern>
|
||||
</web-resource-collection>
|
||||
<auth-constraint>
|
||||
<role-name>user</role-name>
|
||||
|
@ -46,7 +26,22 @@
|
|||
-->
|
||||
</security-constraint>
|
||||
|
||||
<login-config>
|
||||
<security-constraint>
|
||||
<web-resource-collection>
|
||||
<web-resource-name>AdminConsole</web-resource-name>
|
||||
<url-pattern>/admin/*</url-pattern>
|
||||
</web-resource-collection>
|
||||
<auth-constraint>
|
||||
<role-name>admin</role-name>
|
||||
</auth-constraint>
|
||||
<!--
|
||||
<user-data-constraint>
|
||||
<transport-guarantee>CONFIDENTIAL</transport-guarantee>
|
||||
</user-data-constraint>
|
||||
-->
|
||||
</security-constraint>
|
||||
|
||||
<login-config>
|
||||
<auth-method>BASIC</auth-method>
|
||||
<realm-name>demo</realm-name>
|
||||
</login-config>
|
||||
|
|
|
@ -5,9 +5,9 @@
|
|||
<title></title>
|
||||
</head>
|
||||
<body bgcolor="#E3F6CE">
|
||||
<h1>Customer Portal</h1>
|
||||
<h1>Aerogear UPS Portal</h1>
|
||||
|
||||
<p><a href="customers/view.jsp">Customer Listing</a></p>
|
||||
<p><a href="ups/view.jsp">Play with Aerogear UPS</a></p>
|
||||
|
||||
</body>
|
||||
</html>
|
|
@ -2,7 +2,7 @@
|
|||
pageEncoding="ISO-8859-1" %>
|
||||
<html>
|
||||
<head>
|
||||
<title>Customer View Page</title>
|
||||
<title>Aerogear - UPS View Page</title>
|
||||
</head>
|
||||
<body bgcolor="#E3F6CE">
|
||||
|
|
@ -0,0 +1,62 @@
|
|||
package org.aerogear.ups.security;
|
||||
|
||||
import org.keycloak.freemarker.Theme;
|
||||
import org.keycloak.freemarker.ThemeProvider;
|
||||
import org.keycloak.theme.ClassLoaderTheme;
|
||||
|
||||
import java.io.IOException;
|
||||
import java.util.Collections;
|
||||
import java.util.HashSet;
|
||||
import java.util.Set;
|
||||
|
||||
/**
|
||||
* @author <a href="mailto:sthorger@redhat.com">Stian Thorgersen</a>
|
||||
*/
|
||||
public class AerogearThemeProvider implements ThemeProvider {
|
||||
|
||||
public static final String AEROGEAR = "aerogear";
|
||||
|
||||
private static Set<String> ACCOUNT_THEMES = new HashSet<String>();
|
||||
private static Set<String> LOGIN_THEMES = new HashSet<String>();
|
||||
private static Set<String> ADMIN_THEMES = new HashSet<String>();
|
||||
|
||||
static {
|
||||
Collections.addAll(ACCOUNT_THEMES, AEROGEAR);
|
||||
Collections.addAll(LOGIN_THEMES, AEROGEAR);
|
||||
Collections.addAll(ADMIN_THEMES, AEROGEAR);
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getProviderPriority() {
|
||||
return 0;
|
||||
}
|
||||
|
||||
@Override
|
||||
public Theme createTheme(String name, Theme.Type type) throws IOException {
|
||||
if (hasTheme(name, type)) {
|
||||
return new ClassLoaderTheme(name, type, getClass().getClassLoader());
|
||||
} else {
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public Set<String> nameSet(Theme.Type type) {
|
||||
switch (type) {
|
||||
case LOGIN:
|
||||
return LOGIN_THEMES;
|
||||
case ACCOUNT:
|
||||
return ACCOUNT_THEMES;
|
||||
case ADMIN:
|
||||
return ADMIN_THEMES;
|
||||
default:
|
||||
return Collections.emptySet();
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean hasTheme(String name, Theme.Type type) {
|
||||
return nameSet(type).contains(name);
|
||||
}
|
||||
|
||||
}
|
|
@ -0,0 +1 @@
|
|||
org.aerogear.ups.security.AerogearThemeProvider
|
|
@ -0,0 +1,8 @@
|
|||
.navbar-title {
|
||||
background-image: url('../img/logo.png');
|
||||
height: 65px;
|
||||
background-repeat: no-repeat;
|
||||
width: 203px;
|
||||
margin: 3px 10px 5px;
|
||||
text-indent: -99999px;
|
||||
}
|
Binary file not shown.
After Width: | Height: | Size: 6.2 KiB |
|
@ -0,0 +1,4 @@
|
|||
parent=keycloak
|
||||
import=common/keycloak
|
||||
|
||||
styles= ../patternfly/lib/patternfly/css/patternfly.css ../patternfly/css/account.css ../keycloak/css/account.css css/account.css
|
|
@ -0,0 +1,45 @@
|
|||
@import url("../lib/patternfly/css/patternfly.css");
|
||||
@import url("../lib/select2-3.4.1/select2.css");
|
||||
|
||||
@import url("admin-console.css");
|
||||
@import url("tables.css");
|
||||
@import url("sprites.css");
|
||||
|
||||
.navbar-pf {
|
||||
background-image: url('../img/header-bkgrnd.png');
|
||||
border-top: 3px solid rgba(255, 255, 255, 0.15);
|
||||
}
|
||||
|
||||
.navbar-pf .navbar-primary {
|
||||
font-size: 13px;
|
||||
background-image: -webkit-linear-gradient(top, rgba(0,0,0,0.1) 0%, rgba(0,0,0,.4) 100%);
|
||||
background-image: linear-gradient(to bottom, rgba(0,0,0,.1) 0%, rgba(0,0,0,.4) 100%);
|
||||
}
|
||||
|
||||
.navbar-pf .navbar-header {
|
||||
border-bottom: 1px solid rgba(255,255,255,.15);
|
||||
}
|
||||
|
||||
.navbar-pf .navbar-primary li.dropdown.context > a,
|
||||
.navbar-pf .navbar-primary li.dropdown.context > a:hover,
|
||||
.navbar-pf .navbar-primary li.dropdown.context.open > a,
|
||||
.navbar-pf .navbar-primary > .active > a,
|
||||
.navbar-pf .navbar-primary > .active > a:hover{
|
||||
background-color: rgba(0,0,0,0.1);
|
||||
background-image: -webkit-linear-gradient(top, rgba(0,0,0,0.1) 0%, rgba(0,0,0,0.1) 100%);
|
||||
background-image: linear-gradient(to bottom, rgba(0,0,0,0.1) 0%, rgba(0,0,0,0.1) 100%);
|
||||
border-bottom: none;
|
||||
border-right-color: rgba(255,255,255,0.15);
|
||||
border-top-color: rgba(255,255,255,0.05);
|
||||
}
|
||||
|
||||
/* this is what I added */
|
||||
|
||||
.navbar-title {
|
||||
background-image: url('../img/logo.png');
|
||||
height: 65px;
|
||||
background-repeat: no-repeat;
|
||||
width: 203px;
|
||||
margin: 3px 10px 5px;
|
||||
text-indent: -99999px;
|
||||
}
|
Binary file not shown.
After Width: | Height: | Size: 6.2 KiB |
|
@ -0,0 +1,4 @@
|
|||
parent=keycloak
|
||||
import=common/keycloak
|
||||
|
||||
styles= ../keycloak/css/styles.css css/styles.css
|
|
@ -0,0 +1,9 @@
|
|||
#kc-logo-wrapper {
|
||||
background-image: url("../img/logo.png");
|
||||
background-repeat: no-repeat;
|
||||
background-position: top right;
|
||||
|
||||
height: 65px;
|
||||
|
||||
margin: 100px;
|
||||
}
|
Binary file not shown.
After Width: | Height: | Size: 6.2 KiB |
|
@ -0,0 +1,4 @@
|
|||
parent=keycloak
|
||||
import=common/keycloak
|
||||
|
||||
styles= ../patternfly/lib/patternfly/css/patternfly.css ../patternfly/css/login.css ../patternfly/lib/zocial/zocial.css ../keycloak/css/login.css css/login.css
|
|
@ -1,5 +1,5 @@
|
|||
{
|
||||
"realm": "demo",
|
||||
"realm": "aerogear",
|
||||
"enabled": true,
|
||||
"accessTokenLifespan": 3000,
|
||||
"accessCodeLifespan": 10,
|
||||
|
@ -7,6 +7,9 @@
|
|||
"sslNotRequired": true,
|
||||
"registrationAllowed": false,
|
||||
"social": false,
|
||||
"adminTheme": "aerogear",
|
||||
"accountTheme": "aerogear",
|
||||
"loginTheme": "aerogear",
|
||||
"updateProfileOnInitialSocialLogin": false,
|
||||
"requiredCredentials": [ "password" ],
|
||||
"users" : [
|
||||
|
@ -24,7 +27,7 @@
|
|||
{
|
||||
"username" : "admin",
|
||||
"enabled": true,
|
||||
"firstName": "Bill",
|
||||
"firstName": "Meister",
|
||||
"lastName": "Burke",
|
||||
"credentials" : [
|
||||
{ "type" : "password",
|
||||
|
@ -59,19 +62,19 @@
|
|||
],
|
||||
"scopeMappings": [
|
||||
{
|
||||
"client": "customer-portal",
|
||||
"roles": ["user"]
|
||||
"client": "unified-push-server",
|
||||
"roles": ["user", "admin"]
|
||||
}
|
||||
],
|
||||
"applications": [
|
||||
{
|
||||
"name": "customer-portal",
|
||||
"name": "unified-push-server",
|
||||
"enabled": true,
|
||||
"publicClient": true,
|
||||
"adminUrl": "/app",
|
||||
"baseUrl": "/app",
|
||||
"adminUrl": "/aerogear-ups",
|
||||
"baseUrl": "/aerogear-ups",
|
||||
"redirectUris": [
|
||||
"/app/*"
|
||||
"/aerogear-ups/*"
|
||||
]
|
||||
}
|
||||
],
|
||||
|
@ -80,9 +83,13 @@
|
|||
{
|
||||
"username": "bburke@redhat.com",
|
||||
"roles": ["manage-account"]
|
||||
},
|
||||
{
|
||||
"username": "admin",
|
||||
"roles": ["manage-account"]
|
||||
}
|
||||
],
|
||||
"demo-realm": [
|
||||
"aerogear-realm": [
|
||||
{
|
||||
"username": "admin",
|
||||
"roles": ["realm-admin"]
|
||||
|
|
Loading…
Reference in a new issue