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

org.apache.camel.component.zendesk.ZendeskEndpointUriFactory Maven / Gradle / Ivy

/* Generated by camel build tools - do NOT edit this file! */
package org.apache.camel.component.zendesk;

import javax.annotation.processing.Generated;
import java.net.URISyntaxException;
import java.util.Collections;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Map;
import java.util.Set;

import org.apache.camel.spi.EndpointUriFactory;

/**
 * Generated by camel build tools - do NOT edit this file!
 */
@Generated("org.apache.camel.maven.packaging.GenerateEndpointUriFactoryMojo")
public class ZendeskEndpointUriFactory extends org.apache.camel.support.component.EndpointUriFactorySupport implements EndpointUriFactory {

    private static final String BASE = ":methodName";

    private static final Set PROPERTY_NAMES;
    private static final Set SECRET_PROPERTY_NAMES;
    private static final Set MULTI_VALUE_PREFIXES;
    static {
        Set props = new HashSet<>(149);
        props.add("active");
        props.add("article");
        props.add("articleAttachments");
        props.add("articleId");
        props.add("articleId0");
        props.add("attachment");
        props.add("attachments");
        props.add("audit");
        props.add("auditId");
        props.add("automation");
        props.add("automationId");
        props.add("automationId0");
        props.add("backoffErrorThreshold");
        props.add("backoffIdleThreshold");
        props.add("backoffMultiplier");
        props.add("bridgeErrorHandler");
        props.add("category");
        props.add("categoryId");
        props.add("categoryId0");
        props.add("categoryId1");
        props.add("category_id");
        props.add("comment");
        props.add("commentId");
        props.add("content");
        props.add("contentTag");
        props.add("contentTagId");
        props.add("contentType");
        props.add("delay");
        props.add("email");
        props.add("endTime");
        props.add("exceptionHandler");
        props.add("exchangePattern");
        props.add("externalId");
        props.add("externalId0");
        props.add("externalId0s");
        props.add("externalIds");
        props.add("field");
        props.add("file");
        props.add("fileName");
        props.add("forum");
        props.add("forum_id");
        props.add("greedy");
        props.add("group");
        props.add("groupMembership");
        props.add("group_id");
        props.add("group_membership_id");
        props.add("id");
        props.add("idArticle");
        props.add("identity");
        props.add("identityId");
        props.add("ids");
        props.add("inBody");
        props.add("includeArchived");
        props.add("initialDelay");
        props.add("inline");
        props.add("installationId");
        props.add("item");
        props.add("itemId");
        props.add("json");
        props.add("labels");
        props.add("lazyStartProducer");
        props.add("locale");
        props.add("macro");
        props.add("macroId");
        props.add("macroId0");
        props.add("methodName");
        props.add("monitorId");
        props.add("name");
        props.add("namePrefix");
        props.add("newPassword");
        props.add("notifySubscribers");
        props.add("oauthToken");
        props.add("oldPassword");
        props.add("order");
        props.add("organization");
        props.add("organizationId");
        props.add("organizationList");
        props.add("organizationMembership");
        props.add("organizationMembershipList");
        props.add("organizationMemberships");
        props.add("organization_id");
        props.add("organization_membership_id");
        props.add("organizations");
        props.add("page");
        props.add("pageSize");
        props.add("password");
        props.add("permissionGroup");
        props.add("pollStrategy");
        props.add("query");
        props.add("queryParams");
        props.add("repeatCount");
        props.add("request");
        props.add("requestId");
        props.add("role");
        props.add("roles");
        props.add("runLoggingLevel");
        props.add("satisfactionRating");
        props.add("schedule");
        props.add("scheduleId");
        props.add("scheduledExecutorService");
        props.add("scheduler");
        props.add("schedulerProperties");
        props.add("searchTerm");
        props.add("section");
        props.add("sectionId");
        props.add("sectionId0");
        props.add("sendEmptyMessageWhenIdle");
        props.add("serverUrl");
        props.add("sortBy");
        props.add("sortOrder");
        props.add("startScheduler");
        props.add("startTime");
        props.add("status");
        props.add("statuses");
        props.add("suspendedTicket");
        props.add("tags");
        props.add("target");
        props.add("targetId");
        props.add("ticket");
        props.add("ticketForm");
        props.add("ticketId");
        props.add("ticketId0");
        props.add("ticketImport");
        props.add("ticketList");
        props.add("tickets");
        props.add("timeUnit");
        props.add("token");
        props.add("topic");
        props.add("translation");
        props.add("translationId");
        props.add("trigger");
        props.add("triggerId");
        props.add("triggerId0");
        props.add("tweetId");
        props.add("unixEpochTime");
        props.add("upload");
        props.add("useFixedDelay");
        props.add("user");
        props.add("userId");
        props.add("userId0");
        props.add("userIdThatWillBeMerged");
        props.add("userIdThatWillRemain");
        props.add("userList");
        props.add("userSegment");
        props.add("user_id");
        props.add("username");
        props.add("users");
        props.add("usersList");
        props.add("variant");
        PROPERTY_NAMES = Collections.unmodifiableSet(props);
        Set secretProps = new HashSet<>(4);
        secretProps.add("oauthToken");
        secretProps.add("password");
        secretProps.add("token");
        secretProps.add("username");
        SECRET_PROPERTY_NAMES = Collections.unmodifiableSet(secretProps);
        Set prefixes = new HashSet<>(1);
        prefixes.add("scheduler.");
        MULTI_VALUE_PREFIXES = Collections.unmodifiableSet(prefixes);
    }

    @Override
    public boolean isEnabled(String scheme) {
        return "zendesk".equals(scheme);
    }

    @Override
    public String buildUri(String scheme, Map properties, boolean encode) throws URISyntaxException {
        String syntax = scheme + BASE;
        String uri = syntax;

        Map copy = new HashMap<>(properties);

        uri = buildPathParameter(syntax, uri, "methodName", null, true, copy);
        uri = buildQueryParameters(uri, copy, encode);
        return uri;
    }

    @Override
    public Set propertyNames() {
        return PROPERTY_NAMES;
    }

    @Override
    public Set secretPropertyNames() {
        return SECRET_PROPERTY_NAMES;
    }

    @Override
    public Set multiValuePrefixes() {
        return MULTI_VALUE_PREFIXES;
    }

    @Override
    public boolean isLenientProperties() {
        return false;
    }
}





© 2015 - 2025 Weber Informatics LLC | Privacy Policy