Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
N
nexpie-grafana-theme
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Registry
Registry
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Kornkitt Poolsup
nexpie-grafana-theme
Commits
da833cbc
Commit
da833cbc
authored
Mar 25, 2015
by
Torkel Ödegaard
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Small progress on influxdb 0.9 query editor, #1525
parent
9268ecf3
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
199 additions
and
331 deletions
+199
-331
src/app/directives/graphiteSegment.js
+3
-1
src/app/plugins/datasource/graphite/queryCtrl.js
+9
-10
src/app/plugins/datasource/influxdb/datasource.js
+25
-47
src/app/plugins/datasource/influxdb/partials/query.editor.html
+47
-209
src/app/plugins/datasource/influxdb/queryCtrl.js
+115
-64
No files found.
src/app/directives/graphiteSegment.js
View file @
da833cbc
...
...
@@ -37,12 +37,14 @@ function (angular, app, _, $) {
if
(
selected
)
{
segment
.
value
=
selected
.
value
;
segment
.
html
=
selected
.
html
;
segment
.
fake
=
false
;
segment
.
expandable
=
selected
.
expandable
;
}
else
{
segment
.
value
=
value
;
segment
.
html
=
$sce
.
trustAsHtml
(
value
);
segment
.
expandable
=
true
;
segment
.
fake
=
false
;
}
$scope
.
segmentValueChanged
(
segment
,
$scope
.
$index
);
});
...
...
@@ -71,7 +73,7 @@ function (angular, app, _, $) {
options
=
_
.
map
(
$scope
.
altSegments
,
function
(
alt
)
{
return
alt
.
value
;
});
// add custom values
if
(
segment
.
value
!==
'select metric'
&&
_
.
indexOf
(
options
,
segment
.
value
)
===
-
1
)
{
if
(
!
segment
.
fake
&&
_
.
indexOf
(
options
,
segment
.
value
)
===
-
1
)
{
options
.
unshift
(
segment
.
value
);
}
...
...
src/app/plugins/datasource/graphite/queryCtrl.js
View file @
da833cbc
...
...
@@ -113,7 +113,7 @@ function (angular, _, config, gfunc, Parser) {
function
checkOtherSegments
(
fromIndex
)
{
if
(
fromIndex
===
0
)
{
$scope
.
segments
.
push
(
new
MetricSegment
(
'select metric'
));
$scope
.
segments
.
push
(
MetricSegment
.
newSelectMetric
(
));
return
;
}
...
...
@@ -123,13 +123,13 @@ function (angular, _, config, gfunc, Parser) {
if
(
segments
.
length
===
0
)
{
if
(
path
!==
''
)
{
$scope
.
segments
=
$scope
.
segments
.
splice
(
0
,
fromIndex
);
$scope
.
segments
.
push
(
new
MetricSegment
(
'select metric'
));
$scope
.
segments
.
push
(
MetricSegment
.
newSelectMetric
(
));
}
return
;
}
if
(
segments
[
0
].
expandable
)
{
if
(
$scope
.
segments
.
length
===
fromIndex
)
{
$scope
.
segments
.
push
(
new
MetricSegment
(
'select metric'
));
$scope
.
segments
.
push
(
MetricSegment
.
newSelectMetric
(
));
}
else
{
return
checkOtherSegments
(
fromIndex
+
1
);
...
...
@@ -238,7 +238,7 @@ function (angular, _, config, gfunc, Parser) {
$scope
.
moveAliasFuncLast
();
$scope
.
smartlyHandleNewAliasByNode
(
newFunc
);
if
(
$scope
.
segments
.
length
===
1
&&
$scope
.
segments
[
0
].
value
===
'select metric'
)
{
if
(
$scope
.
segments
.
length
===
1
&&
$scope
.
segments
[
0
].
fake
)
{
$scope
.
segments
=
[];
}
...
...
@@ -298,18 +298,17 @@ function (angular, _, config, gfunc, Parser) {
return
;
}
if
(
_
.
isString
(
options
))
{
this
.
value
=
options
;
this
.
html
=
$sce
.
trustAsHtml
(
this
.
value
);
return
;
}
this
.
fake
=
options
.
fake
;
this
.
value
=
options
.
value
;
this
.
type
=
options
.
type
;
this
.
expandable
=
options
.
expandable
;
this
.
html
=
$sce
.
trustAsHtml
(
templateSrv
.
highlightVariablesAsHtml
(
this
.
value
));
}
MetricSegment
.
newSelectMetric
=
function
()
{
return
new
MetricSegment
({
value
:
'select metric'
,
fake
:
true
});
};
});
module
.
directive
(
'focusMe'
,
function
(
$timeout
,
$parse
)
{
...
...
src/app/plugins/datasource/influxdb/datasource.js
View file @
da833cbc
...
...
@@ -36,7 +36,7 @@ function (angular, _, kbn, InfluxSeries, InfluxQueryBuilder) {
var
timeFilter
=
getTimeFilter
(
options
);
var
promises
=
_
.
map
(
options
.
targets
,
function
(
target
)
{
if
(
target
.
hide
||
!
((
target
.
series
&&
target
.
column
)
||
target
.
query
)
)
{
if
(
target
.
hide
||
!
target
.
query
)
{
return
[];
}
...
...
@@ -73,40 +73,7 @@ function (angular, _, kbn, InfluxSeries, InfluxQueryBuilder) {
});
};
InfluxDatasource
.
prototype
.
listColumns
=
function
(
seriesName
)
{
seriesName
=
templateSrv
.
replace
(
seriesName
);
if
(
!
seriesName
.
match
(
'^/.*/'
)
&&
!
seriesName
.
match
(
/^merge
\(
.*
\)
/
))
{
seriesName
=
'"'
+
seriesName
+
'"'
;
}
return
this
.
_seriesQuery
(
'select * from '
+
seriesName
+
' limit 1'
).
then
(
function
(
data
)
{
if
(
!
data
)
{
return
[];
}
return
data
[
0
].
columns
.
map
(
function
(
item
)
{
return
/^
\w
+$/
.
test
(
item
)
?
item
:
(
'"'
+
item
+
'"'
);
});
});
};
InfluxDatasource
.
prototype
.
listSeries
=
function
(
query
)
{
// wrap in regex
if
(
query
&&
query
.
length
>
0
&&
query
[
0
]
!==
'/'
)
{
query
=
'/'
+
query
+
'/'
;
}
return
this
.
_seriesQuery
(
'SHOW MEASUREMENTS'
).
then
(
function
(
data
)
{
if
(
!
data
||
data
.
length
===
0
)
{
return
[];
}
return
_
.
map
(
data
[
0
].
points
,
function
(
point
)
{
return
point
[
1
];
});
});
};
InfluxDatasource
.
prototype
.
metricFindQuery
=
function
(
query
)
{
InfluxDatasource
.
prototype
.
metricFindQuery
=
function
(
query
,
queryType
)
{
var
interpolated
;
try
{
interpolated
=
templateSrv
.
replace
(
query
);
...
...
@@ -115,16 +82,29 @@ function (angular, _, kbn, InfluxSeries, InfluxQueryBuilder) {
return
$q
.
reject
(
err
);
}
return
this
.
_seriesQuery
(
interpolated
)
.
then
(
function
(
results
)
{
if
(
!
results
||
results
.
length
===
0
)
{
return
[];
}
console
.
log
(
'metricFindQuery called with: '
+
[
query
,
queryType
].
join
(
', '
));
return
_
.
map
(
results
[
0
].
points
,
function
(
metric
)
{
return
{
text
:
metric
[
1
],
expandable
:
false
};
});
return
this
.
_seriesQuery
(
interpolated
,
queryType
).
then
(
function
(
results
)
{
if
(
!
results
||
results
.
results
.
length
===
0
)
{
return
[];
}
var
influxResults
=
results
.
results
[
0
];
if
(
!
influxResults
.
series
)
{
return
[];
}
console
.
log
(
'metric find query response'
,
results
);
var
series
=
influxResults
.
series
[
0
];
switch
(
queryType
)
{
case
'MEASUREMENTS'
:
return
_
.
map
(
series
.
values
,
function
(
value
)
{
return
{
text
:
value
[
0
],
expandable
:
true
};
});
case
'TAG_KEYS'
:
var
tagKeys
=
_
.
flatten
(
series
.
values
);
return
_
.
map
(
tagKeys
,
function
(
tagKey
)
{
return
{
text
:
tagKey
,
expandable
:
true
};
});
case
'TAG_VALUES'
:
var
tagValues
=
_
.
flatten
(
series
.
values
);
return
_
.
map
(
tagValues
,
function
(
tagValue
)
{
return
{
text
:
tagValue
,
expandable
:
true
};
});
}
});
};
...
...
@@ -143,9 +123,7 @@ function (angular, _, kbn, InfluxSeries, InfluxQueryBuilder) {
}
InfluxDatasource
.
prototype
.
_seriesQuery
=
function
(
query
)
{
return
this
.
_influxRequest
(
'GET'
,
'/query'
,
{
q
:
query
,
});
return
this
.
_influxRequest
(
'GET'
,
'/query'
,
{
q
:
query
});
};
InfluxDatasource
.
prototype
.
_influxRequest
=
function
(
method
,
url
,
data
)
{
...
...
src/app/plugins/datasource/influxdb/partials/query.editor.html
View file @
da833cbc
This diff is collapsed.
Click to expand it.
src/app/plugins/datasource/influxdb/queryCtrl.js
View file @
da833cbc
...
...
@@ -7,102 +7,153 @@ function (angular, _) {
var
module
=
angular
.
module
(
'grafana.controllers'
);
var
seriesList
=
null
;
module
.
controller
(
'InfluxQueryCtrl'
,
function
(
$scope
,
$timeout
)
{
module
.
controller
(
'InfluxQueryCtrl'
,
function
(
$scope
,
$timeout
,
$sce
,
templateSrv
,
$q
)
{
$scope
.
init
=
function
()
{
var
target
=
$scope
.
target
;
target
.
function
=
target
.
function
||
'mean'
;
target
.
column
=
target
.
column
||
'value'
;
// backward compatible correction of schema
if
(
target
.
condition_value
)
{
target
.
condition
=
target
.
condition_key
+
' '
+
target
.
condition_op
+
' '
+
target
.
condition_value
;
delete
target
.
condition_key
;
delete
target
.
condition_op
;
delete
target
.
condition_value
;
}
if
(
target
.
groupby_field_add
===
false
)
{
target
.
groupby_field
=
''
;
delete
target
.
groupby_field_add
;
}
$scope
.
segments
=
$scope
.
target
.
segments
||
[];
$scope
.
rawQuery
=
true
;
$scope
.
functions
=
[
$scope
.
functionsSelect
=
[
'count'
,
'mean'
,
'sum'
,
'min'
,
'max'
,
'mode'
,
'distinct'
,
'median'
,
'derivative'
,
'stddev'
,
'first'
,
'last'
,
'difference'
];
$scope
.
operators
=
[
'='
,
'=~'
,
'>'
,
'<'
,
'!~'
,
'<>'
];
$scope
.
oldSeries
=
target
.
series
;
$scope
.
$on
(
'typeahead-updated'
,
function
()
{
$timeout
(
$scope
.
get_data
);
});
checkOtherSegments
(
0
);
};
$scope
.
showQuery
=
function
()
{
$scope
.
target
.
rawQuery
=
true
;
$scope
.
toggleQueryMode
=
function
()
{
$scope
.
target
.
rawQuery
=
!
$scope
.
target
.
rawQuery
;
};
$scope
.
hideQuery
=
function
(
)
{
$scope
.
target
.
rawQuery
=
false
;
$scope
.
moveMetricQuery
=
function
(
fromIndex
,
toIndex
)
{
_
.
move
(
$scope
.
panel
.
targets
,
fromIndex
,
toIndex
)
;
};
// Cannot use typeahead and ng-change on blur at the same time
$scope
.
seriesBlur
=
function
()
{
if
(
$scope
.
oldSeries
!==
$scope
.
target
.
series
)
{
$scope
.
oldSeries
=
$scope
.
target
.
series
;
$scope
.
columnList
=
null
;
$scope
.
get_data
();
}
$scope
.
duplicate
=
function
()
{
var
clone
=
angular
.
copy
(
$scope
.
target
);
$scope
.
panel
.
targets
.
push
(
clone
);
};
$scope
.
changeFunction
=
function
(
func
)
{
$scope
.
target
.
function
=
func
;
$scope
.
get_data
();
};
$scope
.
getAltSegments
=
function
(
index
)
{
$scope
.
altSegments
=
[];
var
measurement
=
$scope
.
segments
[
0
].
value
;
var
queryType
,
query
;
if
(
index
===
0
)
{
queryType
=
'MEASUREMENTS'
;
query
=
'SHOW MEASUREMENTS'
;
}
else
if
(
index
%
2
===
1
)
{
queryType
=
'TAG_KEYS'
;
query
=
'SHOW TAG KEYS FROM '
+
measurement
;
}
else
{
queryType
=
'TAG_VALUES'
;
query
=
"SHOW TAG VALUES FROM "
+
measurement
+
" WITH KEY = "
+
$scope
.
segments
[
$scope
.
segments
.
length
-
2
].
value
;
}
console
.
log
(
'getAltSegments: query'
,
query
);
return
$scope
.
datasource
.
metricFindQuery
(
query
,
queryType
).
then
(
function
(
results
)
{
console
.
log
(
'get alt segments: response'
,
results
);
$scope
.
altSegments
=
_
.
map
(
results
,
function
(
segment
)
{
return
new
MetricSegment
({
value
:
segment
.
text
,
expandable
:
segment
.
expandable
});
});
// called outside of digest
$scope
.
listColumns
=
function
(
query
,
callback
)
{
if
(
!
$scope
.
columnList
)
{
$scope
.
$apply
(
function
()
{
$scope
.
datasource
.
listColumns
(
$scope
.
target
.
series
).
then
(
function
(
columns
)
{
$scope
.
columnList
=
columns
;
callback
(
columns
);
_
.
each
(
templateSrv
.
variables
,
function
(
variable
)
{
$scope
.
altSegments
.
unshift
(
new
MetricSegment
({
type
:
'template'
,
value
:
'$'
+
variable
.
name
,
expandable
:
true
,
}));
});
},
function
(
err
)
{
$scope
.
parserError
=
err
.
message
||
'Failed to issue metric query'
;
});
};
$scope
.
segmentValueChanged
=
function
(
segment
,
segmentIndex
)
{
delete
$scope
.
parserError
;
if
(
segment
.
expandable
)
{
return
checkOtherSegments
(
segmentIndex
+
1
).
then
(
function
()
{
setSegmentFocus
(
segmentIndex
+
1
);
$scope
.
targetChanged
();
});
}
else
{
return
$scope
.
columnList
;
$scope
.
segments
=
$scope
.
segments
.
splice
(
0
,
segmentIndex
+
1
)
;
}
setSegmentFocus
(
segmentIndex
+
1
);
$scope
.
targetChanged
();
};
$scope
.
listSeries
=
function
(
query
,
callback
)
{
if
(
query
!==
''
)
{
seriesList
=
[];
$scope
.
datasource
.
listSeries
(
query
).
then
(
function
(
series
)
{
seriesList
=
series
;
callback
(
seriesList
);
$scope
.
targetChanged
=
function
()
{
if
(
$scope
.
parserError
)
{
return
;
}
$scope
.
$parent
.
get_data
();
};
function
checkOtherSegments
(
fromIndex
)
{
if
(
fromIndex
===
0
)
{
$scope
.
segments
.
push
(
MetricSegment
.
newSelectMetric
());
return
;
}
if
(
$scope
.
segments
.
length
===
0
)
{
throw
(
'should always have a scope segment?'
);
}
if
(
_
.
last
(
$scope
.
segments
).
fake
)
{
return
$q
.
when
([]);
}
else
if
(
$scope
.
segments
.
length
%
2
===
1
)
{
$scope
.
segments
.
push
(
MetricSegment
.
newSelectTag
());
return
$q
.
when
([]);
}
else
{
$scope
.
segments
.
push
(
MetricSegment
.
newSelectTagValue
());
return
$q
.
when
([]);
}
}
function
setSegmentFocus
(
segmentIndex
)
{
_
.
each
(
$scope
.
segments
,
function
(
segment
,
index
)
{
segment
.
focus
=
segmentIndex
===
index
;
});
}
else
{
return
seriesList
;
function
MetricSegment
(
options
)
{
if
(
options
===
'*'
||
options
.
value
===
'*'
)
{
this
.
value
=
'*'
;
this
.
html
=
$sce
.
trustAsHtml
(
'<i class="fa fa-asterisk"><i>'
);
this
.
expandable
=
true
;
return
;
}
if
(
_
.
isString
(
options
))
{
this
.
value
=
options
;
this
.
html
=
$sce
.
trustAsHtml
(
this
.
value
);
return
;
}
this
.
fake
=
options
.
fake
;
this
.
value
=
options
.
value
;
this
.
type
=
options
.
type
;
this
.
expandable
=
options
.
expandable
;
this
.
html
=
$sce
.
trustAsHtml
(
templateSrv
.
highlightVariablesAsHtml
(
this
.
value
));
}
MetricSegment
.
newSelectMetric
=
function
()
{
return
new
MetricSegment
({
value
:
'select metric'
,
fake
:
true
});
};
$scope
.
moveMetricQuery
=
function
(
fromIndex
,
toIndex
)
{
_
.
move
(
$scope
.
panel
.
targets
,
fromIndex
,
toIndex
);
MetricSegment
.
newSelectTag
=
function
(
)
{
return
new
MetricSegment
({
value
:
'select tag'
,
fake
:
true
}
);
};
$scope
.
duplicate
=
function
()
{
var
clone
=
angular
.
copy
(
$scope
.
target
);
$scope
.
panel
.
targets
.
push
(
clone
);
MetricSegment
.
newSelectTagValue
=
function
()
{
return
new
MetricSegment
({
value
:
'select tag value'
,
fake
:
true
});
};
});
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment