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

com.sitewhere.microservice.grpc.GrpcTenantEngineProvider Maven / Gradle / Ivy

The newest version!
/**
 * Copyright © 2014-2021 The SiteWhere Authors
 *
 * 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.sitewhere.microservice.grpc;

import java.util.List;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import com.sitewhere.microservice.security.SiteWhereAuthentication;
import com.sitewhere.microservice.security.UserContext;
import com.sitewhere.spi.SiteWhereException;
import com.sitewhere.spi.microservice.grpc.ITenantEngineCallback;
import com.sitewhere.spi.microservice.multitenant.IMicroserviceTenantEngine;
import com.sitewhere.spi.microservice.multitenant.IMultitenantMicroservice;

import io.grpc.stub.StreamObserver;
import io.jsonwebtoken.Claims;

/**
 * Uses context tenant token and JWT to execute a call in the user context
 * passed in the JWT using the tenant engine specified by the token.
 * 
 * @param 
 */
public class GrpcTenantEngineProvider> {

    /** Static logger instance */
    private static Logger LOGGER = LoggerFactory.getLogger(GrpcTenantEngineProvider.class);

    /** Microservice */
    private IMultitenantMicroservice microservice;

    public GrpcTenantEngineProvider(IMultitenantMicroservice microservice) {
	this.microservice = microservice;
    }

    /**
     * Execute callback in context of a tenant engine.
     * 
     * @param callback
     */
    public void executeInTenantEngine(ITenantEngineCallback callback, StreamObserver observer) {
	SiteWhereAuthentication previous = UserContext.getCurrentUser();
	try {
	    // Get JWT and tenant token from context.
	    String jwt = GrpcKeys.JWT_CONTEXT_KEY.get();
	    String tenantToken = GrpcKeys.TENANT_CONTEXT_KEY.get();

	    // Parse username and granted authorities.
	    Claims claims = getMicroservice().getTokenManagement().getClaimsForToken(jwt);
	    String username = getMicroservice().getTokenManagement().getUsernameFromClaims(claims);
	    List auths = getMicroservice().getTokenManagement().getGrantedAuthoritiesFromClaims(claims);

	    // Set user context.
	    SiteWhereAuthentication auth = new SiteWhereAuthentication(username, auths, jwt);
	    auth.setTenantToken(tenantToken);
	    UserContext.setContext(auth);
	    LOGGER.debug(String.format("Executing gRPC call in context of user '%s'.", username));

	    // Execute callback on tenant engine within user context.
	    T engine = getMicroservice().assureTenantEngineAvailable(tenantToken);
	    callback.executeInTenantEngine(engine);
	} catch (SiteWhereException e) {
	    LOGGER.error("Unable to execute tenant engine method.", e);
	    observer.onError(GrpcUtils.convertServerException(e));
	} finally {
	    UserContext.setContext(previous);
	}
    }

    protected IMultitenantMicroservice getMicroservice() {
	return microservice;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy