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

com.palantir.conjure.java.util.JavaNameSanitizer Maven / Gradle / Ivy

The newest version!
/*
 * (c) Copyright 2018 Palantir Technologies Inc. All rights reserved.
 *
 * 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.palantir.conjure.java.util;

import com.google.common.collect.ImmutableSet;
import com.palantir.conjure.CaseConverter;
import com.palantir.conjure.java.ConjureTags;
import com.palantir.conjure.java.services.Auth;
import com.palantir.conjure.spec.AuthType;
import com.palantir.conjure.spec.CookieAuthType;
import com.palantir.conjure.spec.EndpointDefinition;
import com.palantir.conjure.spec.FieldName;
import com.palantir.conjure.spec.HeaderAuthType;
import com.palantir.logsafe.SafeArg;
import com.palantir.logsafe.exceptions.SafeIllegalArgumentException;
import java.util.Optional;
import javax.lang.model.SourceVersion;

public final class JavaNameSanitizer {

    private static final ImmutableSet RESERVED_FIELD_NAMES = ImmutableSet.of("memoizedHashCode");

    private static final ImmutableSet RESERVED_METHOD_NAMES = ImmutableSet.of("getClass");

    /** Sanitizes the given {@link FieldName} for use as a java specifier. */
    public static String sanitize(FieldName fieldName) {
        String identifier = null;
        try {
            identifier = CaseConverter.toCase(fieldName.get(), CaseConverter.Case.LOWER_CAMEL_CASE);
        } catch (IllegalArgumentException e) {
            identifier =
                    CaseConverter.Case.LOWER_CAMEL_CASE.convertTo(fieldName.get(), CaseConverter.Case.LOWER_CAMEL_CASE);
        }
        return sanitizeFieldName(identifier);
    }

    /** Returns a valid java name based on the input. */
    public static String sanitize(String name) {
        return SourceVersion.isName(name) ? name : escape(name);
    }

    /** Returns a valid java method name based on the input. */
    public static String sanitizeMethod(String name) {
        return RESERVED_METHOD_NAMES.contains(name) ? escape(name) : name;
    }

    /** Sanitizes parameter names taking into account default auth type parameter names. */
    public static String sanitizeParameterName(String input, EndpointDefinition endpoint) {
        String value = sanitize(input);
        Optional maybeAuthParamName = endpoint.getAuth()
                .map(authType -> authType.accept(new AuthType.Visitor() {
                    @Override
                    public String visitHeader(HeaderAuthType _header) {
                        return Auth.AUTH_HEADER_PARAM_NAME;
                    }

                    @Override
                    public String visitCookie(CookieAuthType _cookie) {
                        return Auth.COOKIE_AUTH_PARAM_NAME;
                    }

                    @Override
                    public String visitUnknown(String unknownType) {
                        throw new SafeIllegalArgumentException(
                                "Unknown auth type", SafeArg.of("authType", unknownType));
                    }
                }));
        if (maybeAuthParamName.isPresent() && maybeAuthParamName.get().equals(value)) {
            return sanitizeParameterName(escape(value), endpoint);
        }
        if (ConjureTags.hasServerRequestContext(endpoint) && ConjureTags.SERVER_REQUEST_CONTEXT_NAME.equals(value)) {
            return sanitizeParameterName(escape(value), endpoint);
        }
        return value;
    }

    private static String sanitizeFieldName(String name) {
        return SourceVersion.isName(name) && !RESERVED_FIELD_NAMES.contains(name) ? name : escape(name);
    }

    private static String escape(String input) {
        return input + '_';
    }

    private JavaNameSanitizer() {}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy