Skip to content

Commit

Permalink
Add documentation to config (#1007)
Browse files Browse the repository at this point in the history
* Add documentation to config

Signed-off-by: Yuri Shkuro <github@ysh.us>

* corrections

Signed-off-by: Yuri Shkuro <github@ysh.us>

Signed-off-by: Yuri Shkuro <github@ysh.us>
  • Loading branch information
yurishkuro authored Oct 23, 2022
1 parent 3f6fbc0 commit d38bccc
Show file tree
Hide file tree
Showing 2 changed files with 98 additions and 16 deletions.
13 changes: 8 additions & 5 deletions packages/jaeger-ui/src/constants/default-config.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -27,11 +27,6 @@ export default deepFreeze(
dagMaxNumServices: FALLBACK_DAG_MAX_NUM_SERVICES,
menuEnabled: true,
},
linkPatterns: [],
qualityMetrics: {
menuEnabled: false,
menuLabel: 'Trace Quality',
},
menu: [
{
label: 'About Jaeger',
Expand Down Expand Up @@ -87,6 +82,7 @@ export default deepFreeze(
trackErrors: true,
customWebAnalytics: null,
},
linkPatterns: [],
monitor: {
menuEnabled: true,
emptyState: {
Expand All @@ -106,6 +102,13 @@ export default deepFreeze(
},
docsLink: 'https://www.jaegertracing.io/docs/latest/spm/',
},
deepDependencies: {
menuEnabled: false,
},
qualityMetrics: {
menuEnabled: false,
menuLabel: 'Trace Quality',
},
},
// fields that should be individually merged vs wholesale replaced
'__mergeFields',
Expand Down
101 changes: 90 additions & 11 deletions packages/jaeger-ui/src/types/config.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@
// limitations under the License.

import { TPathAgnosticDecorationSchema } from '../model/path-agnostic-decorations/types';
import { IWebAnalyticsFunc } from './tracking';
import { TNil } from '.';

export type ConfigMenuItem = {
Expand All @@ -32,9 +33,22 @@ export type TScript = {
};

export type LinkPatternsConfig = {
// type defines the entity that the pattern applies to.
// 'traces' patterns apply to the whole trace, and have access to 'traceID' value.
// Other patterns apply to tags at different levels. They have access to the value
// of the respective tag, for example:
// "linkPatterns": [{
// "type": "process",
// "key": "jaeger.version",
// "url": "https://github.com/jaegertracing/jaeger-client-java/releases/tag/#{jaeger.version}",
// "text": "Information about Jaeger SDK release #{jaeger.version}"
// }]
type: 'process' | 'tags' | 'logs' | 'traces';
// key of the tag for tag-level patterns.
key?: string;
// url of the link, with variable extrapoliation, e.g. "#{jaeger.version}".
url: string;
// tooltip of the link, with variable extrapoliation, e.g. "#{jaeger.version}".
text: string;
};

Expand All @@ -61,28 +75,93 @@ export type MonitorConfig = {

// Default values are provided in packages/jaeger-ui/src/constants/default-config.tsx
export type Config = {
// archiveEnabled enables the Archive Trace button in the trace view.
// Requires Query Service to be configured with "archive" storage backend.
archiveEnabled?: boolean;
deepDependencies?: {

// dependencies controls the behavior of System Architecture tab.
dependencies?: {
// menuEnabled enables or disables the System Architecture tab.
menuEnabled?: boolean;

// dagMaxServicesLen defines the maximum number of services allowed
// before the DAG dependency view is disabled. Too many services
// cause the DAG view to be non-responsive.
dagMaxServicesLen?: number;
};
dependencies?: { dagMaxServicesLen?: number; menuEnabled?: boolean };

// menu controls the dropdown menu in the top-right corner of the UI.
// When populated, this element completely overrides the default menu.
menu: (ConfigMenuGroup | ConfigMenuItem)[];
pathAgnosticDecorations?: TPathAgnosticDecorationSchema[];
qualityMetrics?: {
menuEnabled?: boolean;
menuLabel?: string;

// search section controls some aspects of the Search panel.
search?: {
// maxLookback controls how far back in time the search may apply.
// By default the Lookback dropdown contains values from "last hour"
// to "last 2 days". Setting maxLookback to a shorter time range,
// such as "6h" disables the longer ranges.
maxLookback: {
// label to be displayed in the search form dropdown, e.g. "Last 2 days".
label: string;

// The value submitted in the search query if the label is selected.
// Examples: "6h", "2d".
value: string;
};
// maxLimit configures the "search depth" parameter.
// The interpretation of search depth varies between different backends.
maxLimit: number;
};
search?: { maxLookback: { label: string; value: string }; maxLimit: number };

// scripts is an array of URLs of additional JavaScript files to be loaded.
// TODO when is it useful?
scripts?: TScript[];

// topTagPrefixes defines a set of prefixes for span tag names that are considered
// "important" and cause the matching tags to appear higher in the list of tags.
// For example, topTagPrefixes=['http.'] would cause all span tags that begin with
// "http." to be shown above all other tags.
// See https://github.com/jaegertracing/jaeger-ui/issues/218 for background.
topTagPrefixes?: string[];

// tracking section controls the collection of usage metrics as analytics events.
// By default, Jaeger uses Google Analytics for event tracking (if enabled).
tracking?: {
cookieToDimension?: {
cookie: string;
dimension: string;
}[];
// gaID is the Google Analytics account ID.
gaID: string | TNil;

// trackErrors enables the use of Raven SDK to capture rich details
// about the exceptions and report them as analytics events.
// See https://github.com/jaegertracing/jaeger-ui/issues/39 for background.
trackErrors: boolean | TNil;

// customWebAnalytics allows using custom implementation of event reporting,
// as an alternative to Google Analytics.
// This only works when using a JavaScript-based configuration file,
// which allows passing functions to the configuration.
// See https://github.com/jaegertracing/jaeger-ui/issues/652 for background.
customWebAnalytics: IWebAnalyticsFunc | TNil;
};

// linkPatterns allow customizing the display of traces with external links.
// The patterns can apply either at trace level, or at individual tag level.
// When a matching pattern is found, a link is rendered, whose URL and tooltip
// strings support variable substitution.
// A trace level link is displayed as an icon at the top of the trace view.
// A tag-level link converts the tag value into a hyperlink.
linkPatterns?: LinkPatternsConfig;

// monitor section controls Service Performance Monitoring tab.
monitor?: MonitorConfig;

// The following features are experimental / undocumented.

deepDependencies?: {
menuEnabled?: boolean;
};
pathAgnosticDecorations?: TPathAgnosticDecorationSchema[];
qualityMetrics?: {
menuEnabled?: boolean;
menuLabel?: string;
};
};

0 comments on commit d38bccc

Please sign in to comment.