All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.holonplatform.jaxrs.examples.ExampleAuth Maven / Gradle / Ivy

There is a newer version: 5.7.0
Show newest version
/*
 * Copyright 2000-2017 Holon TDCN.
 * 
 * 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 com.holonplatform.jaxrs.examples;

import java.util.Optional;

import javax.ws.rs.GET;
import javax.ws.rs.Path;
import javax.ws.rs.Produces;
import javax.ws.rs.core.MediaType;
import javax.ws.rs.ext.ContextResolver;

import com.holonplatform.auth.Account;
import com.holonplatform.auth.Account.AccountProvider;
import com.holonplatform.auth.AuthenticationToken;
import com.holonplatform.auth.Credentials;
import com.holonplatform.auth.Realm;
import com.holonplatform.auth.annotations.Authenticate;
import com.holonplatform.http.HttpHeaders;
import com.holonplatform.jaxrs.server.auth.AuthenticationFeature;

@SuppressWarnings("unused")
public class ExampleAuth {

	// tag::auth[]
	@Authenticate(schemes = HttpHeaders.SCHEME_BASIC) // <1>
	@Path("protected")
	class ProtectedResource {

		@GET
		@Path("test")
		@Produces(MediaType.TEXT_PLAIN)
		public String test() {
			return "test";
		}
	}

	@Path("semiprotected")
	class SemiProtectedResource { // <2>

		@GET
		@Path("public")
		@Produces(MediaType.TEXT_PLAIN)
		public String publicMethod() { // <3>
			return "public";
		}

		@Authenticate(schemes = HttpHeaders.SCHEME_BASIC) // <4>
		@GET
		@Path("protected")
		@Produces(MediaType.TEXT_PLAIN)
		public String protectedMethod() {
			return "protected";
		}

	}

	// configuration
	public void configureJaxrsApplication() {

		AccountProvider provider = id -> { // <5>
			// a test provider wich always returns an Account with given id and s3cr3t as password
			return Optional.ofNullable(Account.builder(id).credentials(Credentials.builder().secret("s3cr3t").build())
					.enabled(true).build());
		};

		Realm realm = Realm.builder() // <6>
				.resolver(AuthenticationToken.httpBasicResolver()) // <7>
				.authenticator(Account.authenticator(provider)) // <8>
				.withDefaultAuthorizer().build();

		ContextResolver realmContextResolver = new ContextResolver() { // <9>

			@Override
			public Realm getContext(Class type) {
				return realm;
			}
		};

		register(realmContextResolver); // <10>
	}
	// end::auth[]

	private void register(Class resource) {

	}

	private void register(Object resource) {

	}

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy