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

org.llorllale.youtrack.api.package-info Maven / Gradle / Ivy

/*
 * Copyright 2017 George Aristy
 *
 * 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.
 */

/**
 * Fluent, object-oriented API for YouTrack.
 * 
 * 

Login

* YouTrack supports various authentication strategies. {@code youtrack-api} implements: *
    *
  • Username/password
  • *
  • Permanent tokens
  • *
  • Anonymous sessions (ie. the guest user)
  • *
* *

Example: * {@code final Session session = new PermanentToken(youtrackUrl, myToken).login();}
* See the {@link org.llorllale.youtrack.api.session} package for more info. * *

Main Entry Point

* The main entrypoint for the API is the {@link org.llorllale.youtrack.api.YouTrack} interface. * Obtain an instance of the default implementation like this:
* {@code final YouTrack yt = new DefaultYouTrack(session);}. * *

Projects

* The {@link org.llorllale.youtrack.api.Projects} interface is used to find * {@link org.llorllale.youtrack.api.Project projects}.
* Example: *
  {@code final Optional project = new DefaultYoutrack(session)
 *       .projects()          //returns the Projects interface
 *       .get("projectId");   //returns an Optional}
* See interfaces {@link org.llorllale.youtrack.api.Projects} and * {@link org.llorllale.youtrack.api.Project}. * *

Issues

* You can find an {@link org.llorllale.youtrack.api.Issue issue} like this:
*
  {@code final Optional issue = project.issues().get("issueId");}
* To create an issue, use * {@link org.llorllale.youtrack.api.Issues#create(String, String)}: *
  {@code final Issue is = project.issues().create("summary", "description");}
 * 
See {@link org.llorllale.youtrack.api.Issues} for more info. * *

Fields of an Issue

* Note:
* It is important to know that some fields typically found in most issue tracking software - like * State and Priority - are not first class citizens in * YouTrack, although they are typically present in project configurations on most teams. First * class attributes of issues in YouTrack include properties such as {@code creationDate}, * {@code summary}, and {@code description} (although optional). Behind the scenes, YouTrack * supports fields like State and Priority through the use of * custom fields that are configured (sometimes preconfigured) through a project's * settings.

* Usage:
* To access a project's preconfigured {@link org.llorllale.youtrack.api.Field fields}: *
  {@code final Stream fields = project.fields().stream();}
* To access all possible {@link org.llorllale.youtrack.api.FieldValue values} for a field: *
  {@code final Stream values = projectField.values();}
* Updating an issue's fields can be done via {@link org.llorllale.youtrack.api.Issue#update()}. * Example: *
  {@code final ProjectField state = project.fields().stream()
 *        .filter(f -> "State".equals(f.name()))
 *        .findAny().get();
 *  final FieldValue done = state.values()
 *        .filter(v -> "Done".equals(v.asString())
 *        .findAny().get();
 *  final Issue issueUpdated = issue.update().field(state, done);}
* * @since 0.9.0 * @see Project Site. */ package org.llorllale.youtrack.api;




© 2015 - 2025 Weber Informatics LLC | Privacy Policy