Search in sources :

Example 1 with ResourcesNode

use of com.redhat.devtools.intellij.tektoncd.tree.ResourcesNode in project intellij-tekton by redhat-developer.

the class CreateResourceAction method actionPerformed.

@Override
public void actionPerformed(AnActionEvent anActionEvent, TreePath path, Object selected, Tkn tkncli) {
    ActionMessage telemetry = TelemetryService.instance().action(NAME_PREFIX_CRUD + "create resource");
    ResourcesNode item = getElement(selected);
    String namespace = item.getParent().getName();
    String content = getSnippet("Tekton: PipelineResource");
    if (Strings.isNullOrEmpty(content)) {
        telemetry.error("snippet content empty").send();
    } else {
        String name = namespace + "-newresource.yaml";
        try {
            VirtualFileHelper.createAndOpenVirtualFile(anActionEvent.getProject(), namespace, name, content, KIND_RESOURCES, item);
            telemetry.success().send();
        } catch (IOException e) {
            telemetry.error(anonymizeResource(name, namespace, e.getMessage())).send();
            logger.warn("Could not create resource: " + e.getLocalizedMessage(), e);
        }
    }
}
Also used : ActionMessage(com.redhat.devtools.intellij.telemetry.core.service.TelemetryMessageBuilder.ActionMessage) IOException(java.io.IOException) ResourcesNode(com.redhat.devtools.intellij.tektoncd.tree.ResourcesNode)

Example 2 with ResourcesNode

use of com.redhat.devtools.intellij.tektoncd.tree.ResourcesNode in project intellij-tekton by redhat-developer.

the class WatchNodes method setWatchByNode.

public void setWatchByNode(ParentableNode<?> element) {
    String namespace = element.getNamespace();
    String watchId = getWatchId(element);
    Watch watch = null;
    WatchNodes wn = null;
    // (e.g a taskRuns watcher, when a change happens, could update multiple nodes such as a single Task node and the TaskRuns node)
    if (this.watches.containsKey(watchId)) {
        wn = this.watches.get(watchId);
        if (wn.getNodes().stream().noneMatch(item -> item.getName().equalsIgnoreCase(element.getName()) && ((ParentableNode) item.getParent()).getName().equalsIgnoreCase(((ParentableNode) element.getParent()).getName()))) {
            wn.getNodes().add(element);
        }
        return;
    }
    Watcher watcher = getWatcher(watchId, element.getRoot().getProject());
    try {
        if (element instanceof PipelinesNode) {
            watch = tkn.watchPipelines(namespace, watcher);
        } else if (element instanceof PipelineNode) {
            // we are expanding a single pipeline node and we want it to refresh if its children (pipelineruns) change
            watch = tkn.watchPipelineRuns(namespace, watcher);
        } else if (element instanceof PipelineRunsNode) {
            watch = tkn.watchPipelineRuns(namespace, watcher);
        } else if (element instanceof PipelineRunNode) {
            // we are expanding a single pipelinerun node and we want it to refresh if its children (taskruns) change
            watch = tkn.watchTaskRuns(namespace, watcher);
        } else if (element instanceof ResourcesNode) {
            watch = tkn.watchPipelineResources(namespace, watcher);
        } else if (element instanceof TasksNode) {
            watch = tkn.watchTasks(namespace, watcher);
        } else if (element instanceof TaskNode) {
            // we are expanding a single task node and we want it to refresh if its children (taskruns) change
            watch = tkn.watchTaskRuns(namespace, watcher);
        } else if (element instanceof TaskRunsNode) {
            watch = tkn.watchTaskRuns(namespace, watcher);
        } else if (element instanceof ClusterTasksNode) {
            watch = tkn.watchClusterTasks(watcher);
        } else if (element instanceof ConditionsNode) {
            watch = tkn.watchConditions(namespace, watcher);
        } else if (element instanceof TriggerTemplatesNode) {
            watch = tkn.watchTriggerTemplates(namespace, watcher);
        } else if (element instanceof TriggerBindingsNode) {
            watch = tkn.watchTriggerBindings(namespace, watcher);
        } else if (element instanceof ClusterTriggerBindingsNode) {
            watch = tkn.watchClusterTriggerBindings(watcher);
        } else if (element instanceof EventListenersNode) {
            watch = tkn.watchEventListeners(namespace, watcher);
        }
        wn = new WatchNodes(watch, element);
    } catch (IOException e) {
        logger.warn("Error: " + e.getLocalizedMessage(), e);
    }
    if (wn != null) {
        watches.put(watchId, wn);
    }
}
Also used : PipelinesNode(com.redhat.devtools.intellij.tektoncd.tree.PipelinesNode) TaskNode(com.redhat.devtools.intellij.tektoncd.tree.TaskNode) ClusterTriggerBindingsNode(com.redhat.devtools.intellij.tektoncd.tree.ClusterTriggerBindingsNode) Watcher(io.fabric8.kubernetes.client.Watcher) IOException(java.io.IOException) PipelineNode(com.redhat.devtools.intellij.tektoncd.tree.PipelineNode) ResourcesNode(com.redhat.devtools.intellij.tektoncd.tree.ResourcesNode) ClusterTriggerBindingsNode(com.redhat.devtools.intellij.tektoncd.tree.ClusterTriggerBindingsNode) TriggerBindingsNode(com.redhat.devtools.intellij.tektoncd.tree.TriggerBindingsNode) PipelineRunsNode(com.redhat.devtools.intellij.tektoncd.tree.PipelineRunsNode) PipelineRunNode(com.redhat.devtools.intellij.tektoncd.tree.PipelineRunNode) TasksNode(com.redhat.devtools.intellij.tektoncd.tree.TasksNode) ClusterTasksNode(com.redhat.devtools.intellij.tektoncd.tree.ClusterTasksNode) EventListenersNode(com.redhat.devtools.intellij.tektoncd.tree.EventListenersNode) Watch(io.fabric8.kubernetes.client.Watch) TriggerTemplatesNode(com.redhat.devtools.intellij.tektoncd.tree.TriggerTemplatesNode) ConditionsNode(com.redhat.devtools.intellij.tektoncd.tree.ConditionsNode) TaskRunsNode(com.redhat.devtools.intellij.tektoncd.tree.TaskRunsNode) ClusterTasksNode(com.redhat.devtools.intellij.tektoncd.tree.ClusterTasksNode)

Aggregations

ResourcesNode (com.redhat.devtools.intellij.tektoncd.tree.ResourcesNode)2 IOException (java.io.IOException)2 ClusterTasksNode (com.redhat.devtools.intellij.tektoncd.tree.ClusterTasksNode)1 ClusterTriggerBindingsNode (com.redhat.devtools.intellij.tektoncd.tree.ClusterTriggerBindingsNode)1 ConditionsNode (com.redhat.devtools.intellij.tektoncd.tree.ConditionsNode)1 EventListenersNode (com.redhat.devtools.intellij.tektoncd.tree.EventListenersNode)1 PipelineNode (com.redhat.devtools.intellij.tektoncd.tree.PipelineNode)1 PipelineRunNode (com.redhat.devtools.intellij.tektoncd.tree.PipelineRunNode)1 PipelineRunsNode (com.redhat.devtools.intellij.tektoncd.tree.PipelineRunsNode)1 PipelinesNode (com.redhat.devtools.intellij.tektoncd.tree.PipelinesNode)1 TaskNode (com.redhat.devtools.intellij.tektoncd.tree.TaskNode)1 TaskRunsNode (com.redhat.devtools.intellij.tektoncd.tree.TaskRunsNode)1 TasksNode (com.redhat.devtools.intellij.tektoncd.tree.TasksNode)1 TriggerBindingsNode (com.redhat.devtools.intellij.tektoncd.tree.TriggerBindingsNode)1 TriggerTemplatesNode (com.redhat.devtools.intellij.tektoncd.tree.TriggerTemplatesNode)1 ActionMessage (com.redhat.devtools.intellij.telemetry.core.service.TelemetryMessageBuilder.ActionMessage)1 Watch (io.fabric8.kubernetes.client.Watch)1 Watcher (io.fabric8.kubernetes.client.Watcher)1