Initial import (#1670656).
This commit is contained in:
parent
97f8dbd59f
commit
1f64cbeaf4
2
.gitignore
vendored
Normal file
2
.gitignore
vendored
Normal file
@ -0,0 +1,2 @@
|
||||
/grafana-6.1.4.tar.gz
|
||||
/grafana_webpack-6.1.4.tar.gz
|
141
000-go-test-fixes.patch
Normal file
141
000-go-test-fixes.patch
Normal file
@ -0,0 +1,141 @@
|
||||
diff --git a/pkg/tsdb/azuremonitor/azuremonitor-datasource_test.go b/pkg/tsdb/azuremonitor/azuremonitor-datasource_test.go
|
||||
index b8d1d6cc2..39cfe3f76 100644
|
||||
--- a/pkg/tsdb/azuremonitor/azuremonitor-datasource_test.go
|
||||
+++ b/pkg/tsdb/azuremonitor/azuremonitor-datasource_test.go
|
||||
@@ -107,19 +107,19 @@ func TestAzureMonitorDatasource(t *testing.T) {
|
||||
So(len(res.Series[0].Points), ShouldEqual, 5)
|
||||
|
||||
So(res.Series[0].Points[0][0].Float64, ShouldEqual, 2.0875)
|
||||
- So(res.Series[0].Points[0][1].Float64, ShouldEqual, 1549620780000)
|
||||
+ So(res.Series[0].Points[0][1].Float64, ShouldEqual, int64(1549620780000))
|
||||
|
||||
So(res.Series[0].Points[1][0].Float64, ShouldEqual, 2.1525)
|
||||
- So(res.Series[0].Points[1][1].Float64, ShouldEqual, 1549620840000)
|
||||
+ So(res.Series[0].Points[1][1].Float64, ShouldEqual, int64(1549620840000))
|
||||
|
||||
So(res.Series[0].Points[2][0].Float64, ShouldEqual, 2.155)
|
||||
- So(res.Series[0].Points[2][1].Float64, ShouldEqual, 1549620900000)
|
||||
+ So(res.Series[0].Points[2][1].Float64, ShouldEqual, int64(1549620900000))
|
||||
|
||||
So(res.Series[0].Points[3][0].Float64, ShouldEqual, 3.6925)
|
||||
- So(res.Series[0].Points[3][1].Float64, ShouldEqual, 1549620960000)
|
||||
+ So(res.Series[0].Points[3][1].Float64, ShouldEqual, int64(1549620960000))
|
||||
|
||||
So(res.Series[0].Points[4][0].Float64, ShouldEqual, 2.44)
|
||||
- So(res.Series[0].Points[4][1].Float64, ShouldEqual, 1549621020000)
|
||||
+ So(res.Series[0].Points[4][1].Float64, ShouldEqual, int64(1549621020000))
|
||||
})
|
||||
|
||||
Convey("when data from query aggregated as total to one time series", func() {
|
||||
@@ -139,7 +139,7 @@ func TestAzureMonitorDatasource(t *testing.T) {
|
||||
So(err, ShouldBeNil)
|
||||
|
||||
So(res.Series[0].Points[0][0].Float64, ShouldEqual, 8.26)
|
||||
- So(res.Series[0].Points[0][1].Float64, ShouldEqual, 1549718940000)
|
||||
+ So(res.Series[0].Points[0][1].Float64, ShouldEqual, int64(1549718940000))
|
||||
})
|
||||
|
||||
Convey("when data from query aggregated as maximum to one time series", func() {
|
||||
@@ -159,7 +159,7 @@ func TestAzureMonitorDatasource(t *testing.T) {
|
||||
So(err, ShouldBeNil)
|
||||
|
||||
So(res.Series[0].Points[0][0].Float64, ShouldEqual, 3.07)
|
||||
- So(res.Series[0].Points[0][1].Float64, ShouldEqual, 1549722360000)
|
||||
+ So(res.Series[0].Points[0][1].Float64, ShouldEqual, int64(1549722360000))
|
||||
})
|
||||
|
||||
Convey("when data from query aggregated as minimum to one time series", func() {
|
||||
@@ -179,7 +179,7 @@ func TestAzureMonitorDatasource(t *testing.T) {
|
||||
So(err, ShouldBeNil)
|
||||
|
||||
So(res.Series[0].Points[0][0].Float64, ShouldEqual, 1.51)
|
||||
- So(res.Series[0].Points[0][1].Float64, ShouldEqual, 1549723380000)
|
||||
+ So(res.Series[0].Points[0][1].Float64, ShouldEqual, int64(1549723380000))
|
||||
})
|
||||
|
||||
Convey("when data from query aggregated as Count to one time series", func() {
|
||||
@@ -199,7 +199,7 @@ func TestAzureMonitorDatasource(t *testing.T) {
|
||||
So(err, ShouldBeNil)
|
||||
|
||||
So(res.Series[0].Points[0][0].Float64, ShouldEqual, 4)
|
||||
- So(res.Series[0].Points[0][1].Float64, ShouldEqual, 1549723440000)
|
||||
+ So(res.Series[0].Points[0][1].Float64, ShouldEqual, int64(1549723440000))
|
||||
})
|
||||
|
||||
Convey("when data from query aggregated as total and has dimension filter", func() {
|
||||
diff --git a/pkg/tsdb/mssql/mssql_test.go b/pkg/tsdb/mssql/mssql_test.go
|
||||
index c3d447060..cc27304fc 100644
|
||||
--- a/pkg/tsdb/mssql/mssql_test.go
|
||||
+++ b/pkg/tsdb/mssql/mssql_test.go
|
||||
@@ -162,7 +162,7 @@ func TestMSSQL(t *testing.T) {
|
||||
So(column[19].(time.Time), ShouldEqual, dt.Truncate(time.Minute))
|
||||
So(column[20].(time.Time), ShouldEqual, dt.Truncate(24*time.Hour))
|
||||
So(column[21].(time.Time), ShouldEqual, time.Date(1, 1, 1, dt.Hour(), dt.Minute(), dt.Second(), dt.Nanosecond(), time.UTC))
|
||||
- So(column[22].(time.Time), ShouldEqual, dt2.In(time.FixedZone("UTC", int(-7*time.Hour))))
|
||||
+ So(column[22].(time.Time), ShouldEqual, dt2.In(time.FixedZone("UTC-7", int(-7*60*60))))
|
||||
})
|
||||
})
|
||||
|
||||
diff --git a/pkg/tsdb/stackdriver/stackdriver_test.go b/pkg/tsdb/stackdriver/stackdriver_test.go
|
||||
index 78c3086a9..1ab1e099f 100644
|
||||
--- a/pkg/tsdb/stackdriver/stackdriver_test.go
|
||||
+++ b/pkg/tsdb/stackdriver/stackdriver_test.go
|
||||
@@ -236,13 +236,13 @@ func TestStackdriver(t *testing.T) {
|
||||
|
||||
Convey("timestamps should be in ascending order", func() {
|
||||
So(res.Series[0].Points[0][0].Float64, ShouldEqual, 0.05)
|
||||
- So(res.Series[0].Points[0][1].Float64, ShouldEqual, 1536670020000)
|
||||
+ So(res.Series[0].Points[0][1].Float64, ShouldEqual, int64(1536670020000))
|
||||
|
||||
So(res.Series[0].Points[1][0].Float64, ShouldEqual, 1.05)
|
||||
- So(res.Series[0].Points[1][1].Float64, ShouldEqual, 1536670080000)
|
||||
+ So(res.Series[0].Points[1][1].Float64, ShouldEqual, int64(1536670080000))
|
||||
|
||||
So(res.Series[0].Points[2][0].Float64, ShouldEqual, 1.0666666666667)
|
||||
- So(res.Series[0].Points[2][1].Float64, ShouldEqual, 1536670260000)
|
||||
+ So(res.Series[0].Points[2][1].Float64, ShouldEqual, int64(1536670260000))
|
||||
})
|
||||
})
|
||||
|
||||
@@ -365,9 +365,9 @@ func TestStackdriver(t *testing.T) {
|
||||
}
|
||||
|
||||
Convey("timestamps should be in ascending order", func() {
|
||||
- So(res.Series[0].Points[0][1].Float64, ShouldEqual, 1536668940000)
|
||||
- So(res.Series[0].Points[1][1].Float64, ShouldEqual, 1536669000000)
|
||||
- So(res.Series[0].Points[2][1].Float64, ShouldEqual, 1536669060000)
|
||||
+ So(res.Series[0].Points[0][1].Float64, ShouldEqual, int64(1536668940000))
|
||||
+ So(res.Series[0].Points[1][1].Float64, ShouldEqual, int64(1536669000000))
|
||||
+ So(res.Series[0].Points[2][1].Float64, ShouldEqual, int64(1536669060000))
|
||||
})
|
||||
|
||||
Convey("bucket bounds should be correct", func() {
|
||||
@@ -410,8 +410,8 @@ func TestStackdriver(t *testing.T) {
|
||||
}
|
||||
|
||||
Convey("timestamps should be in ascending order", func() {
|
||||
- So(res.Series[0].Points[0][1].Float64, ShouldEqual, 1550859086000)
|
||||
- So(res.Series[0].Points[1][1].Float64, ShouldEqual, 1550859146000)
|
||||
+ So(res.Series[0].Points[0][1].Float64, ShouldEqual, int64(1550859086000))
|
||||
+ So(res.Series[0].Points[1][1].Float64, ShouldEqual, int64(1550859146000))
|
||||
})
|
||||
|
||||
Convey("bucket bounds should be correct", func() {
|
||||
diff --git a/pkg/tsdb/time_range_test.go b/pkg/tsdb/time_range_test.go
|
||||
index 37ced412e..38b147689 100644
|
||||
--- a/pkg/tsdb/time_range_test.go
|
||||
+++ b/pkg/tsdb/time_range_test.go
|
||||
@@ -70,11 +70,11 @@ func TestTimeRange(t *testing.T) {
|
||||
|
||||
res, err := tr.ParseFrom()
|
||||
So(err, ShouldBeNil)
|
||||
- So(res.UnixNano()/int64(time.Millisecond), ShouldEqual, 1474973725473)
|
||||
+ So(res.UnixNano()/int64(time.Millisecond), ShouldEqual, int64(1474973725473))
|
||||
|
||||
res, err = tr.ParseTo()
|
||||
So(err, ShouldBeNil)
|
||||
- So(res.UnixNano()/int64(time.Millisecond), ShouldEqual, 1474975757930)
|
||||
+ So(res.UnixNano()/int64(time.Millisecond), ShouldEqual, int64(1474975757930))
|
||||
})
|
||||
|
||||
Convey("Cannot parse asdf", func() {
|
219
001-man-pages.patch
Normal file
219
001-man-pages.patch
Normal file
@ -0,0 +1,219 @@
|
||||
diff --git a/docs/man/man1/grafana-cli.1 b/docs/man/man1/grafana-cli.1
|
||||
new file mode 100644
|
||||
index 000000000..171748fcd
|
||||
--- /dev/null
|
||||
+++ b/docs/man/man1/grafana-cli.1
|
||||
@@ -0,0 +1,51 @@
|
||||
+.TH GRAFANA "1" "February 2019" "Grafana cli version 5.4.3" "User Commands"
|
||||
+.SH NAME
|
||||
+grafana-cli \- command line administration for the Grafana metrics dashboard and graph editor
|
||||
+.SH DESCRIPTION
|
||||
+.SS "NAME:"
|
||||
+.IP
|
||||
+grafana-cli
|
||||
+.SS "USAGE:"
|
||||
+.IP
|
||||
+\fBgrafana\-cli\fP [\fIglobal options\fP] \fIcommand\fP [\fIcommand options\fP] [\fIarguments\fP...]
|
||||
+.SS "COMMANDS:"
|
||||
+.TP
|
||||
+plugins
|
||||
+Manage plugins for grafana
|
||||
+.TP
|
||||
+admin
|
||||
+Grafana admin commands
|
||||
+.TP
|
||||
+help, h
|
||||
+Shows a list of commands or help for one command
|
||||
+.SS "GLOBAL OPTIONS:"
|
||||
+.TP
|
||||
+\fB\-\-pluginsDir\fR value
|
||||
+path to the grafana plugin directory (default: "/var/lib/grafana/plugins") [$GF_PLUGIN_DIR]
|
||||
+.TP
|
||||
+\fB\-\-repo\fR value
|
||||
+url to the plugin repository (default: "https://grafana.com/api/plugins") [$GF_PLUGIN_REPO]
|
||||
+.TP
|
||||
+\fB\-\-pluginUrl\fR value
|
||||
+Full url to the plugin zip file instead of downloading the plugin from grafana.com/api [$GF_PLUGIN_URL]
|
||||
+.TP
|
||||
+\fB\-\-insecure\fR
|
||||
+Skip TLS verification (insecure)
|
||||
+.TP
|
||||
+\fB\-\-debug\fR, \fB\-d\fR
|
||||
+enable debug logging
|
||||
+.TP
|
||||
+\fB\-\-help\fR, \fB\-h\fR
|
||||
+show help
|
||||
+.TP
|
||||
+\fB\-\-version\fR, \fB\-v\fR
|
||||
+print the version
|
||||
+.SH "SEE ALSO"
|
||||
+Additional documentation for
|
||||
+.B grafana-cli
|
||||
+is available on-line at
|
||||
+.BR http://docs.grafana.org/administration/cli/ .
|
||||
+The full documentation for
|
||||
+.B Grafana
|
||||
+is available on-line at
|
||||
+.BR http://docs.grafana.org/ .
|
||||
diff --git a/docs/man/man1/grafana-server.1 b/docs/man/man1/grafana-server.1
|
||||
new file mode 100644
|
||||
index 000000000..30b7c1306
|
||||
--- /dev/null
|
||||
+++ b/docs/man/man1/grafana-server.1
|
||||
@@ -0,0 +1,156 @@
|
||||
+.TH VERSION "1" "February 2019" "Version 5.4.3" "User Commands"
|
||||
+.SH NAME
|
||||
+grafana-server \- back-end server for the Grafana metrics dashboard and graph editor
|
||||
+.SH DESCRIPTION
|
||||
+.B grafana-server
|
||||
+is the back-end server for the Grafana metrics dashboard and graph editor.
|
||||
+The
|
||||
+.B grafana-server
|
||||
+program should not normally be run from the command line,
|
||||
+except when testing or for development purposes.
|
||||
+Rather it should be managed by
|
||||
+.BR systemd .
|
||||
+After installing Grafana, the systemd service should be enabled and started as follows:
|
||||
+.P
|
||||
+.in 1i
|
||||
+.B systemctl daemon-reload
|
||||
+.br
|
||||
+.B systemctl enable grafana-server.service
|
||||
+.br
|
||||
+.B systemctl start grafana-server.service
|
||||
+.in
|
||||
+.P
|
||||
+.SH OPTIONS
|
||||
+The
|
||||
+.B gafana-server
|
||||
+configuration is specified in
|
||||
+.BR /etc/grafana/grafana.ini
|
||||
+and is well documented with comments.
|
||||
+The command-line options listed below override options of
|
||||
+the same (or similar) name in the configuration file and also provide
|
||||
+additional options for testing Grafana.
|
||||
+.P
|
||||
+.HP
|
||||
+\fB\-config\fR string
|
||||
+.IP
|
||||
+path to config file
|
||||
+.HP
|
||||
+\fB\-homepath\fR string
|
||||
+.IP
|
||||
+path to grafana install/home path, defaults to working directory
|
||||
+.HP
|
||||
+\fB\-packaging\fR string
|
||||
+.IP
|
||||
+describes the way Grafana was installed (default "unknown")
|
||||
+.HP
|
||||
+\fB\-pidfile\fR string
|
||||
+.IP
|
||||
+path to pid file
|
||||
+.HP
|
||||
+\fB\-profile\fR
|
||||
+.IP
|
||||
+Turn on pprof profiling
|
||||
+.HP
|
||||
+\fB\-profile\-port\fR int
|
||||
+.IP
|
||||
+Define custom port for profiling (default 6060)
|
||||
+.HP
|
||||
+\fB\-test\fR.bench regexp
|
||||
+.IP
|
||||
+run only benchmarks matching regexp
|
||||
+.HP
|
||||
+\fB\-test\fR.benchmem
|
||||
+.IP
|
||||
+print memory allocations for benchmarks
|
||||
+.HP
|
||||
+\fB\-test\fR.benchtime d
|
||||
+.IP
|
||||
+run each benchmark for duration d (default 1s)
|
||||
+.HP
|
||||
+\fB\-test\fR.blockprofile file
|
||||
+.IP
|
||||
+write a goroutine blocking profile to file
|
||||
+.HP
|
||||
+\fB\-test\fR.blockprofilerate rate
|
||||
+.IP
|
||||
+set blocking profile rate (see runtime.SetBlockProfileRate) (default 1)
|
||||
+.HP
|
||||
+\fB\-test\fR.count n
|
||||
+.IP
|
||||
+run tests and benchmarks n times (default 1)
|
||||
+.HP
|
||||
+\fB\-test\fR.coverprofile file
|
||||
+.IP
|
||||
+write a coverage profile to file
|
||||
+.HP
|
||||
+\fB\-test\fR.cpu list
|
||||
+.IP
|
||||
+comma\-separated list of cpu counts to run each test with
|
||||
+.HP
|
||||
+\fB\-test\fR.cpuprofile file
|
||||
+.IP
|
||||
+write a cpu profile to file
|
||||
+.HP
|
||||
+\fB\-test\fR.failfast
|
||||
+.IP
|
||||
+do not start new tests after the first test failure
|
||||
+.HP
|
||||
+\fB\-test\fR.list regexp
|
||||
+.IP
|
||||
+list tests, examples, and benchmarks matching regexp then exit
|
||||
+.HP
|
||||
+\fB\-test\fR.memprofile file
|
||||
+.IP
|
||||
+write a memory profile to file
|
||||
+.HP
|
||||
+\fB\-test\fR.memprofilerate rate
|
||||
+.IP
|
||||
+set memory profiling rate (see runtime.MemProfileRate)
|
||||
+.HP
|
||||
+\fB\-test\fR.mutexprofile string
|
||||
+.IP
|
||||
+write a mutex contention profile to the named file after execution
|
||||
+.HP
|
||||
+\fB\-test\fR.mutexprofilefraction int
|
||||
+.IP
|
||||
+if >= 0, calls runtime.SetMutexProfileFraction() (default 1)
|
||||
+.HP
|
||||
+\fB\-test\fR.outputdir dir
|
||||
+.IP
|
||||
+write profiles to dir
|
||||
+.HP
|
||||
+\fB\-test\fR.parallel n
|
||||
+.IP
|
||||
+run at most n tests in parallel (default 8)
|
||||
+.HP
|
||||
+\fB\-test\fR.run regexp
|
||||
+.IP
|
||||
+run only tests and examples matching regexp
|
||||
+.HP
|
||||
+\fB\-test\fR.short
|
||||
+.IP
|
||||
+run smaller test suite to save time
|
||||
+.HP
|
||||
+\fB\-test\fR.testlogfile file
|
||||
+.IP
|
||||
+write test action log to file (for use only by cmd/go)
|
||||
+.HP
|
||||
+\fB\-test\fR.timeout d
|
||||
+.IP
|
||||
+panic test binary after duration d (default 0, timeout disabled)
|
||||
+.HP
|
||||
+\fB\-test\fR.trace file
|
||||
+.IP
|
||||
+write an execution trace to file
|
||||
+.HP
|
||||
+\fB\-test\fR.v
|
||||
+.IP
|
||||
+verbose: print additional output
|
||||
+.TP
|
||||
+\fB\-v\fR
|
||||
+prints current version and exits
|
||||
+.SH "SEE ALSO"
|
||||
+The full documentation for
|
||||
+.B Grafana
|
||||
+is available on-line at
|
||||
+.BR http://docs.grafana.org/ .
|
26
002-update-golang-oauth2-vendor-sources.patch
Normal file
26
002-update-golang-oauth2-vendor-sources.patch
Normal file
@ -0,0 +1,26 @@
|
||||
diff --git a/pkg/api/login_oauth.go b/pkg/api/login_oauth.go
|
||||
index a3599bc7a..0c6579847 100644
|
||||
--- a/pkg/api/login_oauth.go
|
||||
+++ b/pkg/api/login_oauth.go
|
||||
@@ -125,7 +125,7 @@ func (hs *HTTPServer) OAuthLogin(ctx *m.ReqContext) {
|
||||
oauthCtx := context.WithValue(context.Background(), oauth2.HTTPClient, oauthClient)
|
||||
|
||||
// get token from provider
|
||||
- token, err := connect.Exchange(oauthCtx, code)
|
||||
+ token, err := connect.Exchange(oauthCtx, code, oauth2.AccessTypeOnline)
|
||||
if err != nil {
|
||||
ctx.Handle(500, "login.OAuthLogin(NewTransportWithCode)", err)
|
||||
return
|
||||
diff --git a/pkg/login/social/social.go b/pkg/login/social/social.go
|
||||
index 3ec0e2c96..72807d73e 100644
|
||||
--- a/pkg/login/social/social.go
|
||||
+++ b/pkg/login/social/social.go
|
||||
@@ -29,7 +29,7 @@ type SocialConnector interface {
|
||||
IsSignupAllowed() bool
|
||||
|
||||
AuthCodeURL(state string, opts ...oauth2.AuthCodeOption) string
|
||||
- Exchange(ctx context.Context, code string) (*oauth2.Token, error)
|
||||
+ Exchange(ctx context.Context, code string, opts ...oauth2.AuthCodeOption) (*oauth2.Token, error)
|
||||
Client(ctx context.Context, t *oauth2.Token) *http.Client
|
||||
TokenSource(ctx context.Context, t *oauth2.Token) oauth2.TokenSource
|
||||
}
|
27
003-file-mode-updates.patch
Normal file
27
003-file-mode-updates.patch
Normal file
@ -0,0 +1,27 @@
|
||||
diff --git a/public/app/features/dashboard/components/DashboardSettings/SettingsCtrl.ts b/public/app/features/dashboard/components/DashboardSettings/SettingsCtrl.ts
|
||||
old mode 100755
|
||||
new mode 100644
|
||||
diff --git a/public/app/features/folders/services/FolderPageLoader.ts b/public/app/features/folders/services/FolderPageLoader.ts
|
||||
old mode 100755
|
||||
new mode 100644
|
||||
diff --git a/public/app/plugins/datasource/elasticsearch/img/elasticsearch.svg b/public/app/plugins/datasource/elasticsearch/img/elasticsearch.svg
|
||||
old mode 100755
|
||||
new mode 100644
|
||||
diff --git a/public/app/plugins/datasource/graphite/partials/query.editor.html b/public/app/plugins/datasource/graphite/partials/query.editor.html
|
||||
old mode 100755
|
||||
new mode 100644
|
||||
diff --git a/public/app/plugins/datasource/stackdriver/partials/query.editor.html b/public/app/plugins/datasource/stackdriver/partials/query.editor.html
|
||||
old mode 100755
|
||||
new mode 100644
|
||||
diff --git a/public/app/plugins/panel/graph/graph.ts b/public/app/plugins/panel/graph/graph.ts
|
||||
old mode 100755
|
||||
new mode 100644
|
||||
diff --git a/public/fonts/grafana-icons.svg b/public/fonts/grafana-icons.svg
|
||||
old mode 100755
|
||||
new mode 100644
|
||||
diff --git a/public/sass/components/_panel_text.scss b/public/sass/components/_panel_text.scss
|
||||
index e69de29bb..cd0183132 100644
|
||||
--- a/public/sass/components/_panel_text.scss
|
||||
+++ b/public/sass/components/_panel_text.scss
|
||||
@@ -0,0 +1 @@
|
||||
+// nothing here
|
616
004-grafana.ini-for-Linux-distros.patch
Normal file
616
004-grafana.ini-for-Linux-distros.patch
Normal file
@ -0,0 +1,616 @@
|
||||
diff --git a/conf/distro-defaults.ini b/conf/distro-defaults.ini
|
||||
new file mode 100644
|
||||
index 000000000..b75e4c839
|
||||
--- /dev/null
|
||||
+++ b/conf/distro-defaults.ini
|
||||
@@ -0,0 +1,610 @@
|
||||
+##################### Grafana Configuration Defaults for distros #####################
|
||||
+#
|
||||
+# Do not modify this file in grafana installs
|
||||
+#
|
||||
+
|
||||
+# possible values : production, development
|
||||
+app_mode = production
|
||||
+
|
||||
+# instance name, defaults to HOSTNAME environment variable value or hostname if HOSTNAME var is empty
|
||||
+instance_name = ${HOSTNAME}
|
||||
+
|
||||
+#################################### Paths ###############################
|
||||
+[paths]
|
||||
+# Path to where grafana can store temp files, sessions, and the sqlite3 db (if that is used)
|
||||
+data = /var/lib/grafana
|
||||
+
|
||||
+# Temporary files in `data` directory older than given duration will be removed
|
||||
+temp_data_lifetime = 24h
|
||||
+
|
||||
+# Directory where grafana can store logs
|
||||
+logs = /var/log/grafana
|
||||
+
|
||||
+# Directory where grafana will automatically scan and look for plugins
|
||||
+plugins = /var/lib/grafana/plugins
|
||||
+
|
||||
+# folder that contains provisioning config files that grafana will apply on startup and while running.
|
||||
+provisioning = conf/provisioning
|
||||
+
|
||||
+#################################### Server ##############################
|
||||
+[server]
|
||||
+# Protocol (http, https, socket)
|
||||
+protocol = http
|
||||
+
|
||||
+# The ip address to bind to, empty will bind to all interfaces
|
||||
+http_addr =
|
||||
+
|
||||
+# The http port to use
|
||||
+http_port = 3000
|
||||
+
|
||||
+# The public facing domain name used to access grafana from a browser
|
||||
+domain = localhost
|
||||
+
|
||||
+# Redirect to correct domain if host header does not match domain
|
||||
+# Prevents DNS rebinding attacks
|
||||
+enforce_domain = false
|
||||
+
|
||||
+# The full public facing url
|
||||
+root_url = %(protocol)s://%(domain)s:%(http_port)s/
|
||||
+
|
||||
+# Log web requests
|
||||
+router_logging = false
|
||||
+
|
||||
+# the path relative working path
|
||||
+static_root_path = public
|
||||
+
|
||||
+# enable gzip
|
||||
+enable_gzip = false
|
||||
+
|
||||
+# https certs & key file
|
||||
+cert_file =
|
||||
+cert_key =
|
||||
+
|
||||
+# Unix socket path
|
||||
+socket = /tmp/grafana.sock
|
||||
+
|
||||
+#################################### Database ############################
|
||||
+[database]
|
||||
+# You can configure the database connection by specifying type, host, name, user and password
|
||||
+# as separate properties or as on string using the url property.
|
||||
+
|
||||
+# Either "mysql", "postgres" or "sqlite3", it's your choice
|
||||
+type = sqlite3
|
||||
+host = 127.0.0.1:3306
|
||||
+name = grafana
|
||||
+user = root
|
||||
+# If the password contains # or ; you have to wrap it with triple quotes. Ex """#password;"""
|
||||
+password =
|
||||
+# Use either URL or the previous fields to configure the database
|
||||
+# Example: mysql://user:secret@host:port/database
|
||||
+url =
|
||||
+
|
||||
+# Max idle conn setting default is 2
|
||||
+max_idle_conn = 2
|
||||
+
|
||||
+# Max conn setting default is 0 (mean not set)
|
||||
+max_open_conn =
|
||||
+
|
||||
+# Connection Max Lifetime default is 14400 (means 14400 seconds or 4 hours)
|
||||
+conn_max_lifetime = 14400
|
||||
+
|
||||
+# Set to true to log the sql calls and execution times.
|
||||
+log_queries =
|
||||
+
|
||||
+# For "postgres", use either "disable", "require" or "verify-full"
|
||||
+# For "mysql", use either "true", "false", or "skip-verify".
|
||||
+ssl_mode = disable
|
||||
+
|
||||
+ca_cert_path =
|
||||
+client_key_path =
|
||||
+client_cert_path =
|
||||
+server_cert_name =
|
||||
+
|
||||
+# For "sqlite3" only, path relative to data_path setting
|
||||
+path = grafana.db
|
||||
+
|
||||
+# For "sqlite3" only. cache mode setting used for connecting to the database
|
||||
+cache_mode = private
|
||||
+
|
||||
+#################################### Cache server #############################
|
||||
+[remote_cache]
|
||||
+# Either "redis", "memcached" or "database" default is "database"
|
||||
+type = database
|
||||
+
|
||||
+# cache connectionstring options
|
||||
+# database: will use Grafana primary database.
|
||||
+# redis: config like redis server e.g. `addr=127.0.0.1:6379,pool_size=100,db=grafana`
|
||||
+# memcache: 127.0.0.1:11211
|
||||
+connstr =
|
||||
+
|
||||
+#################################### Session #############################
|
||||
+[session]
|
||||
+# Either "memory", "file", "redis", "mysql", "postgres", "memcache", default is "file"
|
||||
+provider = file
|
||||
+
|
||||
+# Provider config options
|
||||
+# memory: not have any config yet
|
||||
+# file: session dir path, is relative to grafana data_path
|
||||
+# redis: config like redis server e.g. `addr=127.0.0.1:6379,pool_size=100,db=grafana`
|
||||
+# postgres: user=a password=b host=localhost port=5432 dbname=c sslmode=disable
|
||||
+# mysql: go-sql-driver/mysql dsn config string, examples:
|
||||
+# `user:password@tcp(127.0.0.1:3306)/database_name`
|
||||
+# `user:password@unix(/var/run/mysqld/mysqld.sock)/database_name`
|
||||
+# memcache: 127.0.0.1:11211
|
||||
+
|
||||
+
|
||||
+provider_config = sessions
|
||||
+
|
||||
+# Session cookie name
|
||||
+cookie_name = grafana_sess
|
||||
+
|
||||
+# If you use session in https only, default is false
|
||||
+cookie_secure = false
|
||||
+
|
||||
+# Session life time, default is 86400
|
||||
+session_life_time = 86400
|
||||
+gc_interval_time = 86400
|
||||
+
|
||||
+# Connection Max Lifetime default is 14400 (means 14400 seconds or 4 hours)
|
||||
+conn_max_lifetime = 14400
|
||||
+
|
||||
+#################################### Data proxy ###########################
|
||||
+[dataproxy]
|
||||
+
|
||||
+# This enables data proxy logging, default is false
|
||||
+logging = false
|
||||
+
|
||||
+# How long the data proxy should wait before timing out default is 30 (seconds)
|
||||
+timeout = 30
|
||||
+
|
||||
+# If enabled and user is not anonymous, data proxy will add X-Grafana-User header with username into the request, default is false.
|
||||
+send_user_header = false
|
||||
+
|
||||
+#################################### Analytics ###########################
|
||||
+[analytics]
|
||||
+# Server reporting, sends usage counters to stats.grafana.org every 24 hours.
|
||||
+# No ip addresses are being tracked, only simple counters to track
|
||||
+# running instances, dashboard and error counts. It is very helpful to us.
|
||||
+# Change this option to false to disable reporting.
|
||||
+reporting_enabled = false
|
||||
+
|
||||
+# Set to false to disable all checks to https://grafana.com
|
||||
+# for new versions (grafana itself and plugins), check is used
|
||||
+# in some UI views to notify that grafana or plugin update exists
|
||||
+# This option does not cause any auto updates, nor send any information
|
||||
+# only a GET request to https://grafana.com to get latest versions
|
||||
+check_for_updates = false
|
||||
+
|
||||
+# Google Analytics universal tracking code, only enabled if you specify an id here
|
||||
+google_analytics_ua_id =
|
||||
+
|
||||
+# Google Tag Manager ID, only enabled if you specify an id here
|
||||
+google_tag_manager_id =
|
||||
+
|
||||
+#################################### Security ############################
|
||||
+[security]
|
||||
+# default admin user, created on startup
|
||||
+admin_user = admin
|
||||
+
|
||||
+# default admin password, can be changed before first start of grafana, or in profile settings
|
||||
+admin_password = admin
|
||||
+
|
||||
+# used for signing
|
||||
+secret_key = SW2YcwTIb9zpOOhoPsMm
|
||||
+
|
||||
+# disable gravatar profile images
|
||||
+disable_gravatar = false
|
||||
+
|
||||
+# data source proxy whitelist (ip_or_domain:port separated by spaces)
|
||||
+data_source_proxy_whitelist =
|
||||
+
|
||||
+# disable protection against brute force login attempts
|
||||
+disable_brute_force_login_protection = false
|
||||
+
|
||||
+# set to true if you host Grafana behind HTTPS. default is false.
|
||||
+cookie_secure = false
|
||||
+
|
||||
+# set cookie SameSite attribute. defaults to `lax`. can be set to "lax", "strict" and "none"
|
||||
+cookie_samesite = lax
|
||||
+
|
||||
+#################################### Snapshots ###########################
|
||||
+[snapshots]
|
||||
+# snapshot sharing options
|
||||
+external_enabled = false
|
||||
+external_snapshot_url = https://snapshots-origin.raintank.io
|
||||
+external_snapshot_name = Publish to snapshot.raintank.io
|
||||
+
|
||||
+# remove expired snapshot
|
||||
+snapshot_remove_expired = true
|
||||
+
|
||||
+#################################### Dashboards ##################
|
||||
+
|
||||
+[dashboards]
|
||||
+# Number dashboard versions to keep (per dashboard). Default: 20, Minimum: 1
|
||||
+versions_to_keep = 20
|
||||
+
|
||||
+#################################### Users ###############################
|
||||
+[users]
|
||||
+# disable user signup / registration
|
||||
+allow_sign_up = false
|
||||
+
|
||||
+# Allow non admin users to create organizations
|
||||
+allow_org_create = false
|
||||
+
|
||||
+# Set to true to automatically assign new users to the default organization (id 1)
|
||||
+auto_assign_org = true
|
||||
+
|
||||
+# Set this value to automatically add new users to the provided organization (if auto_assign_org above is set to true)
|
||||
+auto_assign_org_id = 1
|
||||
+
|
||||
+# Default role new users will be automatically assigned (if auto_assign_org above is set to true)
|
||||
+auto_assign_org_role = Viewer
|
||||
+
|
||||
+# Require email validation before sign up completes
|
||||
+verify_email_enabled = false
|
||||
+
|
||||
+# Background text for the user field on the login page
|
||||
+login_hint = email or username
|
||||
+password_hint = password
|
||||
+
|
||||
+# Default UI theme ("dark" or "light")
|
||||
+default_theme = dark
|
||||
+
|
||||
+# External user management
|
||||
+external_manage_link_url =
|
||||
+external_manage_link_name =
|
||||
+external_manage_info =
|
||||
+
|
||||
+# Viewers can edit/inspect dashboard settings in the browser. But not save the dashboard.
|
||||
+viewers_can_edit = false
|
||||
+
|
||||
+# Editors can administrate dashboard, folders and teams they create
|
||||
+editors_can_admin = false
|
||||
+
|
||||
+[auth]
|
||||
+# Login cookie name
|
||||
+login_cookie_name = grafana_session
|
||||
+
|
||||
+# The lifetime (days) an authenticated user can be inactive before being required to login at next visit. Default is 7 days.
|
||||
+login_maximum_inactive_lifetime_days = 7
|
||||
+
|
||||
+# The maximum lifetime (days) an authenticated user can be logged in since login time before being required to login. Default is 30 days.
|
||||
+login_maximum_lifetime_days = 30
|
||||
+
|
||||
+# How often should auth tokens be rotated for authenticated users when being active. The default is each 10 minutes.
|
||||
+token_rotation_interval_minutes = 10
|
||||
+
|
||||
+# Set to true to disable (hide) the login form, useful if you use OAuth
|
||||
+disable_login_form = false
|
||||
+
|
||||
+# Set to true to disable the signout link in the side menu. useful if you use auth.proxy
|
||||
+disable_signout_menu = false
|
||||
+
|
||||
+# URL to redirect the user to after sign out
|
||||
+signout_redirect_url =
|
||||
+
|
||||
+# Set to true to attempt login with OAuth automatically, skipping the login screen.
|
||||
+# This setting is ignored if multiple OAuth providers are configured.
|
||||
+oauth_auto_login = false
|
||||
+
|
||||
+#################################### Anonymous Auth ######################
|
||||
+[auth.anonymous]
|
||||
+# enable anonymous access
|
||||
+enabled = false
|
||||
+
|
||||
+# specify organization name that should be used for unauthenticated users
|
||||
+org_name = Main Org.
|
||||
+
|
||||
+# specify role for unauthenticated users
|
||||
+org_role = Viewer
|
||||
+
|
||||
+#################################### Github Auth #########################
|
||||
+[auth.github]
|
||||
+enabled = false
|
||||
+allow_sign_up = true
|
||||
+client_id = some_id
|
||||
+client_secret = some_secret
|
||||
+scopes = user:email,read:org
|
||||
+auth_url = https://github.com/login/oauth/authorize
|
||||
+token_url = https://github.com/login/oauth/access_token
|
||||
+api_url = https://api.github.com/user
|
||||
+team_ids =
|
||||
+allowed_organizations =
|
||||
+
|
||||
+#################################### GitLab Auth #########################
|
||||
+[auth.gitlab]
|
||||
+enabled = false
|
||||
+allow_sign_up = true
|
||||
+client_id = some_id
|
||||
+client_secret = some_secret
|
||||
+scopes = api
|
||||
+auth_url = https://gitlab.com/oauth/authorize
|
||||
+token_url = https://gitlab.com/oauth/token
|
||||
+api_url = https://gitlab.com/api/v4
|
||||
+allowed_groups =
|
||||
+
|
||||
+#################################### Google Auth #########################
|
||||
+[auth.google]
|
||||
+enabled = false
|
||||
+allow_sign_up = true
|
||||
+client_id = some_client_id
|
||||
+client_secret = some_client_secret
|
||||
+scopes = https://www.googleapis.com/auth/userinfo.profile https://www.googleapis.com/auth/userinfo.email
|
||||
+auth_url = https://accounts.google.com/o/oauth2/auth
|
||||
+token_url = https://accounts.google.com/o/oauth2/token
|
||||
+api_url = https://www.googleapis.com/oauth2/v1/userinfo
|
||||
+allowed_domains =
|
||||
+hosted_domain =
|
||||
+
|
||||
+#################################### Grafana.com Auth ####################
|
||||
+# legacy key names (so they work in env variables)
|
||||
+[auth.grafananet]
|
||||
+enabled = false
|
||||
+allow_sign_up = true
|
||||
+client_id = some_id
|
||||
+client_secret = some_secret
|
||||
+scopes = user:email
|
||||
+allowed_organizations =
|
||||
+
|
||||
+[auth.grafana_com]
|
||||
+enabled = false
|
||||
+allow_sign_up = true
|
||||
+client_id = some_id
|
||||
+client_secret = some_secret
|
||||
+scopes = user:email
|
||||
+allowed_organizations =
|
||||
+
|
||||
+#################################### Generic OAuth #######################
|
||||
+[auth.generic_oauth]
|
||||
+name = OAuth
|
||||
+enabled = false
|
||||
+allow_sign_up = true
|
||||
+client_id = some_id
|
||||
+client_secret = some_secret
|
||||
+scopes = user:email
|
||||
+email_attribute_name = email:primary
|
||||
+auth_url =
|
||||
+token_url =
|
||||
+api_url =
|
||||
+team_ids =
|
||||
+allowed_organizations =
|
||||
+tls_skip_verify_insecure = false
|
||||
+tls_client_cert =
|
||||
+tls_client_key =
|
||||
+tls_client_ca =
|
||||
+send_client_credentials_via_post = false
|
||||
+
|
||||
+#################################### Basic Auth ##########################
|
||||
+[auth.basic]
|
||||
+enabled = true
|
||||
+
|
||||
+#################################### Auth Proxy ##########################
|
||||
+[auth.proxy]
|
||||
+enabled = false
|
||||
+header_name = X-WEBAUTH-USER
|
||||
+header_property = username
|
||||
+auto_sign_up = true
|
||||
+ldap_sync_ttl = 60
|
||||
+whitelist =
|
||||
+headers =
|
||||
+
|
||||
+#################################### Auth LDAP ###########################
|
||||
+[auth.ldap]
|
||||
+enabled = false
|
||||
+config_file = /etc/grafana/ldap.toml
|
||||
+allow_sign_up = true
|
||||
+
|
||||
+#################################### SMTP / Emailing #####################
|
||||
+[smtp]
|
||||
+enabled = false
|
||||
+host = localhost:25
|
||||
+user =
|
||||
+# If the password contains # or ; you have to wrap it with triple quotes. Ex """#password;"""
|
||||
+password =
|
||||
+cert_file =
|
||||
+key_file =
|
||||
+skip_verify = false
|
||||
+from_address = admin@grafana.localhost
|
||||
+from_name = Grafana
|
||||
+ehlo_identity =
|
||||
+
|
||||
+[emails]
|
||||
+welcome_email_on_sign_up = false
|
||||
+templates_pattern = emails/*.html
|
||||
+
|
||||
+#################################### Logging ##########################
|
||||
+[log]
|
||||
+# Either "console", "file", "syslog". Default is console and file
|
||||
+# Use space to separate multiple modes, e.g. "console file"
|
||||
+mode = console file
|
||||
+
|
||||
+# Either "debug", "info", "warn", "error", "critical", default is "info"
|
||||
+level = info
|
||||
+
|
||||
+# optional settings to set different levels for specific loggers. Ex filters = sqlstore:debug
|
||||
+filters =
|
||||
+
|
||||
+# For "console" mode only
|
||||
+[log.console]
|
||||
+level =
|
||||
+
|
||||
+# log line format, valid options are text, console and json
|
||||
+format = console
|
||||
+
|
||||
+# For "file" mode only
|
||||
+[log.file]
|
||||
+level =
|
||||
+
|
||||
+# log line format, valid options are text, console and json
|
||||
+format = text
|
||||
+
|
||||
+# This enables automated log rotate(switch of following options), default is true
|
||||
+log_rotate = true
|
||||
+
|
||||
+# Max line number of single file, default is 1000000
|
||||
+max_lines = 1000000
|
||||
+
|
||||
+# Max size shift of single file, default is 28 means 1 << 28, 256MB
|
||||
+max_size_shift = 28
|
||||
+
|
||||
+# Segment log daily, default is true
|
||||
+daily_rotate = true
|
||||
+
|
||||
+# Expired days of log file(delete after max days), default is 7
|
||||
+max_days = 7
|
||||
+
|
||||
+[log.syslog]
|
||||
+level =
|
||||
+
|
||||
+# log line format, valid options are text, console and json
|
||||
+format = text
|
||||
+
|
||||
+# Syslog network type and address. This can be udp, tcp, or unix. If left blank, the default unix endpoints will be used.
|
||||
+network =
|
||||
+address =
|
||||
+
|
||||
+# Syslog facility. user, daemon and local0 through local7 are valid.
|
||||
+facility =
|
||||
+
|
||||
+# Syslog tag. By default, the process' argv[0] is used.
|
||||
+tag =
|
||||
+
|
||||
+#################################### Usage Quotas ########################
|
||||
+[quota]
|
||||
+enabled = false
|
||||
+
|
||||
+#### set quotas to -1 to make unlimited. ####
|
||||
+# limit number of users per Org.
|
||||
+org_user = 10
|
||||
+
|
||||
+# limit number of dashboards per Org.
|
||||
+org_dashboard = 100
|
||||
+
|
||||
+# limit number of data_sources per Org.
|
||||
+org_data_source = 10
|
||||
+
|
||||
+# limit number of api_keys per Org.
|
||||
+org_api_key = 10
|
||||
+
|
||||
+# limit number of orgs a user can create.
|
||||
+user_org = 10
|
||||
+
|
||||
+# Global limit of users.
|
||||
+global_user = -1
|
||||
+
|
||||
+# global limit of orgs.
|
||||
+global_org = -1
|
||||
+
|
||||
+# global limit of dashboards
|
||||
+global_dashboard = -1
|
||||
+
|
||||
+# global limit of api_keys
|
||||
+global_api_key = -1
|
||||
+
|
||||
+# global limit on number of logged in users.
|
||||
+global_session = -1
|
||||
+
|
||||
+#################################### Alerting ############################
|
||||
+[alerting]
|
||||
+# Disable alerting engine & UI features
|
||||
+enabled = true
|
||||
+# Makes it possible to turn off alert rule execution but alerting UI is visible
|
||||
+execute_alerts = true
|
||||
+
|
||||
+# Default setting for new alert rules. Defaults to categorize error and timeouts as alerting. (alerting, keep_state)
|
||||
+error_or_timeout = alerting
|
||||
+
|
||||
+# Default setting for how Grafana handles nodata or null values in alerting. (alerting, no_data, keep_state, ok)
|
||||
+nodata_or_nullvalues = no_data
|
||||
+
|
||||
+# Alert notifications can include images, but rendering many images at the same time can overload the server
|
||||
+# This limit will protect the server from render overloading and make sure notifications are sent out quickly
|
||||
+concurrent_render_limit = 5
|
||||
+
|
||||
+#################################### Explore #############################
|
||||
+[explore]
|
||||
+# Enable the Explore section
|
||||
+enabled = true
|
||||
+
|
||||
+#################################### Internal Grafana Metrics ############
|
||||
+# Metrics available at HTTP API Url /metrics
|
||||
+[metrics]
|
||||
+enabled = true
|
||||
+interval_seconds = 10
|
||||
+
|
||||
+#If both are set, basic auth will be required for the metrics endpoint.
|
||||
+basic_auth_username =
|
||||
+basic_auth_password =
|
||||
+
|
||||
+# Send internal Grafana metrics to graphite
|
||||
+[metrics.graphite]
|
||||
+# Enable by setting the address setting (ex localhost:2003)
|
||||
+address =
|
||||
+prefix = prod.grafana.%(instance_name)s.
|
||||
+
|
||||
+[grafana_net]
|
||||
+url = https://grafana.org
|
||||
+
|
||||
+[grafana_com]
|
||||
+url = https://grafana.com
|
||||
+
|
||||
+#################################### Distributed tracing ############
|
||||
+[tracing.jaeger]
|
||||
+# jaeger destination (ex localhost:6831)
|
||||
+address =
|
||||
+# tag that will always be included in when creating new spans. ex (tag1:value1,tag2:value2)
|
||||
+always_included_tag =
|
||||
+# Type specifies the type of the sampler: const, probabilistic, rateLimiting, or remote
|
||||
+sampler_type = const
|
||||
+# jaeger samplerconfig param
|
||||
+# for "const" sampler, 0 or 1 for always false/true respectively
|
||||
+# for "probabilistic" sampler, a probability between 0 and 1
|
||||
+# for "rateLimiting" sampler, the number of spans per second
|
||||
+# for "remote" sampler, param is the same as for "probabilistic"
|
||||
+# and indicates the initial sampling rate before the actual one
|
||||
+# is received from the mothership
|
||||
+sampler_param = 1
|
||||
+
|
||||
+#################################### External Image Storage ##############
|
||||
+[external_image_storage]
|
||||
+# You can choose between (s3, webdav, gcs, azure_blob, local)
|
||||
+provider =
|
||||
+
|
||||
+[external_image_storage.s3]
|
||||
+bucket_url =
|
||||
+bucket =
|
||||
+region =
|
||||
+path =
|
||||
+access_key =
|
||||
+secret_key =
|
||||
+
|
||||
+[external_image_storage.webdav]
|
||||
+url =
|
||||
+username =
|
||||
+password =
|
||||
+public_url =
|
||||
+
|
||||
+[external_image_storage.gcs]
|
||||
+key_file =
|
||||
+bucket =
|
||||
+path =
|
||||
+
|
||||
+[external_image_storage.azure_blob]
|
||||
+account_name =
|
||||
+account_key =
|
||||
+container_name =
|
||||
+
|
||||
+[external_image_storage.local]
|
||||
+# does not require any configuration
|
||||
+
|
||||
+[rendering]
|
||||
+# Options to configure external image rendering server like https://github.com/grafana/grafana-image-renderer
|
||||
+server_url =
|
||||
+callback_url =
|
||||
+
|
||||
+[panels]
|
||||
+enable_alpha = false
|
||||
+disable_sanitize_html = false
|
||||
+
|
||||
+[enterprise]
|
||||
+license_path =
|
189
005-remove-jaeger-tracing.patch
Normal file
189
005-remove-jaeger-tracing.patch
Normal file
@ -0,0 +1,189 @@
|
||||
diff --git a/pkg/cmd/grafana-server/server.go b/pkg/cmd/grafana-server/server.go
|
||||
index c10212329..a29d14c85 100644
|
||||
--- a/pkg/cmd/grafana-server/server.go
|
||||
+++ b/pkg/cmd/grafana-server/server.go
|
||||
@@ -31,7 +31,6 @@ import (
|
||||
_ "github.com/grafana/grafana/pkg/infra/metrics"
|
||||
_ "github.com/grafana/grafana/pkg/infra/remotecache"
|
||||
_ "github.com/grafana/grafana/pkg/infra/serverlock"
|
||||
- _ "github.com/grafana/grafana/pkg/infra/tracing"
|
||||
_ "github.com/grafana/grafana/pkg/infra/usagestats"
|
||||
_ "github.com/grafana/grafana/pkg/plugins"
|
||||
_ "github.com/grafana/grafana/pkg/services/alerting"
|
||||
diff --git a/pkg/infra/tracing/tracing.go b/pkg/infra/tracing/tracing.go
|
||||
deleted file mode 100644
|
||||
index fd7258b7a..000000000
|
||||
--- a/pkg/infra/tracing/tracing.go
|
||||
+++ /dev/null
|
||||
@@ -1,129 +0,0 @@
|
||||
-package tracing
|
||||
-
|
||||
-import (
|
||||
- "context"
|
||||
- "io"
|
||||
- "strings"
|
||||
-
|
||||
- "github.com/grafana/grafana/pkg/log"
|
||||
- "github.com/grafana/grafana/pkg/registry"
|
||||
- "github.com/grafana/grafana/pkg/setting"
|
||||
-
|
||||
- opentracing "github.com/opentracing/opentracing-go"
|
||||
- jaegercfg "github.com/uber/jaeger-client-go/config"
|
||||
-)
|
||||
-
|
||||
-func init() {
|
||||
- registry.RegisterService(&TracingService{})
|
||||
-}
|
||||
-
|
||||
-type TracingService struct {
|
||||
- enabled bool
|
||||
- address string
|
||||
- customTags map[string]string
|
||||
- samplerType string
|
||||
- samplerParam float64
|
||||
- log log.Logger
|
||||
- closer io.Closer
|
||||
-
|
||||
- Cfg *setting.Cfg `inject:""`
|
||||
-}
|
||||
-
|
||||
-func (ts *TracingService) Init() error {
|
||||
- ts.log = log.New("tracing")
|
||||
- ts.parseSettings()
|
||||
-
|
||||
- if ts.enabled {
|
||||
- ts.initGlobalTracer()
|
||||
- }
|
||||
-
|
||||
- return nil
|
||||
-}
|
||||
-
|
||||
-func (ts *TracingService) parseSettings() {
|
||||
- var section, err = ts.Cfg.Raw.GetSection("tracing.jaeger")
|
||||
- if err != nil {
|
||||
- return
|
||||
- }
|
||||
-
|
||||
- ts.address = section.Key("address").MustString("")
|
||||
- if ts.address != "" {
|
||||
- ts.enabled = true
|
||||
- }
|
||||
-
|
||||
- ts.customTags = splitTagSettings(section.Key("always_included_tag").MustString(""))
|
||||
- ts.samplerType = section.Key("sampler_type").MustString("")
|
||||
- ts.samplerParam = section.Key("sampler_param").MustFloat64(1)
|
||||
-}
|
||||
-
|
||||
-func (ts *TracingService) initGlobalTracer() error {
|
||||
- cfg := jaegercfg.Configuration{
|
||||
- ServiceName: "grafana",
|
||||
- Disabled: !ts.enabled,
|
||||
- Sampler: &jaegercfg.SamplerConfig{
|
||||
- Type: ts.samplerType,
|
||||
- Param: ts.samplerParam,
|
||||
- },
|
||||
- Reporter: &jaegercfg.ReporterConfig{
|
||||
- LogSpans: false,
|
||||
- LocalAgentHostPort: ts.address,
|
||||
- },
|
||||
- }
|
||||
-
|
||||
- jLogger := &jaegerLogWrapper{logger: log.New("jaeger")}
|
||||
-
|
||||
- options := []jaegercfg.Option{}
|
||||
- options = append(options, jaegercfg.Logger(jLogger))
|
||||
-
|
||||
- for tag, value := range ts.customTags {
|
||||
- options = append(options, jaegercfg.Tag(tag, value))
|
||||
- }
|
||||
-
|
||||
- tracer, closer, err := cfg.NewTracer(options...)
|
||||
- if err != nil {
|
||||
- return err
|
||||
- }
|
||||
-
|
||||
- opentracing.InitGlobalTracer(tracer)
|
||||
-
|
||||
- ts.closer = closer
|
||||
-
|
||||
- return nil
|
||||
-}
|
||||
-
|
||||
-func (ts *TracingService) Run(ctx context.Context) error {
|
||||
- <-ctx.Done()
|
||||
-
|
||||
- if ts.closer != nil {
|
||||
- ts.log.Info("Closing tracing")
|
||||
- ts.closer.Close()
|
||||
- }
|
||||
-
|
||||
- return nil
|
||||
-}
|
||||
-
|
||||
-func splitTagSettings(input string) map[string]string {
|
||||
- res := map[string]string{}
|
||||
-
|
||||
- tags := strings.Split(input, ",")
|
||||
- for _, v := range tags {
|
||||
- kv := strings.Split(v, ":")
|
||||
- if len(kv) > 1 {
|
||||
- res[kv[0]] = kv[1]
|
||||
- }
|
||||
- }
|
||||
-
|
||||
- return res
|
||||
-}
|
||||
-
|
||||
-type jaegerLogWrapper struct {
|
||||
- logger log.Logger
|
||||
-}
|
||||
-
|
||||
-func (jlw *jaegerLogWrapper) Error(msg string) {
|
||||
- jlw.logger.Error(msg)
|
||||
-}
|
||||
-
|
||||
-func (jlw *jaegerLogWrapper) Infof(msg string, args ...interface{}) {
|
||||
- jlw.logger.Info(msg, args)
|
||||
-}
|
||||
diff --git a/pkg/infra/tracing/tracing_test.go b/pkg/infra/tracing/tracing_test.go
|
||||
deleted file mode 100644
|
||||
index 27e4de777..000000000
|
||||
--- a/pkg/infra/tracing/tracing_test.go
|
||||
+++ /dev/null
|
||||
@@ -1,36 +0,0 @@
|
||||
-package tracing
|
||||
-
|
||||
-import "testing"
|
||||
-
|
||||
-func TestGroupSplit(t *testing.T) {
|
||||
- tests := []struct {
|
||||
- input string
|
||||
- expected map[string]string
|
||||
- }{
|
||||
- {
|
||||
- input: "tag1:value1,tag2:value2",
|
||||
- expected: map[string]string{
|
||||
- "tag1": "value1",
|
||||
- "tag2": "value2",
|
||||
- },
|
||||
- },
|
||||
- {
|
||||
- input: "",
|
||||
- expected: map[string]string{},
|
||||
- },
|
||||
- {
|
||||
- input: "tag1",
|
||||
- expected: map[string]string{},
|
||||
- },
|
||||
- }
|
||||
-
|
||||
- for _, test := range tests {
|
||||
- tags := splitTagSettings(test.input)
|
||||
- for k, v := range test.expected {
|
||||
- value, exists := tags[k]
|
||||
- if !exists || value != v {
|
||||
- t.Errorf("tags does not match %v ", test)
|
||||
- }
|
||||
- }
|
||||
- }
|
||||
-}
|
597
006-native-RPM-spec-and-webpack-build-script.patch
Normal file
597
006-native-RPM-spec-and-webpack-build-script.patch
Normal file
@ -0,0 +1,597 @@
|
||||
diff --git a/packaging/rpm/spec/README b/packaging/rpm/spec/README
|
||||
new file mode 100644
|
||||
index 000000000..f97c2a26b
|
||||
--- /dev/null
|
||||
+++ b/packaging/rpm/spec/README
|
||||
@@ -0,0 +1,7 @@
|
||||
+The make_webpack.sh script in this directory can be used to create
|
||||
+a webpack tarball of all the nodejs dependencies needed to build a
|
||||
+particular tagged version of grafana, along with the grafana tarball
|
||||
+itself. After running the script, the two tarballs should be copied
|
||||
+to your rpmbuild SOURCES. You can then run a native rpm spec build
|
||||
+using grafana.spec.
|
||||
+
|
||||
diff --git a/packaging/rpm/spec/grafana.spec b/packaging/rpm/spec/grafana.spec
|
||||
new file mode 100644
|
||||
index 000000000..9d69b105e
|
||||
--- /dev/null
|
||||
+++ b/packaging/rpm/spec/grafana.spec
|
||||
@@ -0,0 +1,511 @@
|
||||
+%global grafana_arches %{lua: go_arches = {}
|
||||
+ for arch in rpm.expand("%{go_arches}"):gmatch("%S+") do
|
||||
+ go_arches[arch] = 1
|
||||
+ end
|
||||
+ for arch in rpm.expand("%{nodejs_arches}"):gmatch("%S+") do
|
||||
+ if go_arches[arch] then
|
||||
+ print(arch .. " ")
|
||||
+ end
|
||||
+end}
|
||||
+
|
||||
+Name: grafana
|
||||
+Version: 6.1.4
|
||||
+Release: 1%{?dist}
|
||||
+Summary: Metrics dashboard and graph editor
|
||||
+License: ASL 2.0
|
||||
+URL: https://grafana.org
|
||||
+
|
||||
+# Source0 contains the tagged upstream sources
|
||||
+Source0: https://github.com/grafana/grafana/archive/v%{version}/%{name}-%{version}.tar.gz
|
||||
+
|
||||
+# Source1 contains the front-end javascript modules bundled into a webpack
|
||||
+Source1: grafana_webpack-%{version}.tar.gz
|
||||
+
|
||||
+# Source2 is the script to create the above webpack from grafana sources
|
||||
+Source2: make_webpack.sh
|
||||
+
|
||||
+# Patches for upstream (except Patch5)
|
||||
+Patch0: 000-go-test-fixes.patch
|
||||
+Patch1: 001-man-pages.patch
|
||||
+Patch2: 002-update-golang-oauth2-vendor-sources.patch
|
||||
+Patch3: 003-file-mode-updates.patch
|
||||
+Patch4: 004-grafana.ini-for-Linux-distros.patch
|
||||
+Patch5: 005-remove-jaeger-tracing.patch
|
||||
+Patch6: 006-native-RPM-spec-and-webpack-build-script.patch
|
||||
+
|
||||
+# Intersection of go_arches and nodejs_arches
|
||||
+ExclusiveArch: %{grafana_arches}
|
||||
+
|
||||
+%global GRAFANA_USER %{name}
|
||||
+%global GRAFANA_GROUP %{name}
|
||||
+%global GRAFANA_HOME %{_datadir}/%{name}
|
||||
+
|
||||
+# grafana-server service daemon uses systemd
|
||||
+%{?systemd_requires}
|
||||
+Requires(pre): shadow-utils
|
||||
+
|
||||
+BuildRequires: systemd, golang, compiler(go-compiler)
|
||||
+
|
||||
+# golang build deps. These allow us to unbundle vendor golang source.
|
||||
+BuildRequires: golang(github.com/aws/aws-sdk-go)
|
||||
+BuildRequires: golang(github.com/benbjohnson/clock)
|
||||
+BuildRequires: golang(github.com/beorn7/perks/quantile)
|
||||
+BuildRequires: golang(github.com/bmizerany/assert)
|
||||
+BuildRequires: golang(github.com/bradfitz/gomemcache/memcache)
|
||||
+BuildRequires: golang(github.com/BurntSushi/toml)
|
||||
+BuildRequires: golang(github.com/codahale/hdrhistogram)
|
||||
+BuildRequires: golang(github.com/codegangsta/cli)
|
||||
+BuildRequires: golang(github.com/davecgh/go-spew/spew)
|
||||
+BuildRequires: golang(github.com/denisenkom/go-mssqldb)
|
||||
+BuildRequires: golang(github.com/facebookgo/inject)
|
||||
+BuildRequires: golang(github.com/facebookgo/structtag)
|
||||
+BuildRequires: golang(github.com/fatih/color)
|
||||
+BuildRequires: golang(github.com/go-ini/ini)
|
||||
+BuildRequires: golang(google.golang.org/appengine)
|
||||
+BuildRequires: golang(golang.org/x/sys/unix)
|
||||
+BuildRequires: golang(github.com/go-macaron/binding)
|
||||
+BuildRequires: golang(github.com/go-macaron/gzip)
|
||||
+BuildRequires: golang(github.com/go-macaron/inject)
|
||||
+BuildRequires: golang(github.com/go-macaron/session)
|
||||
+BuildRequires: golang(google.golang.org/genproto/googleapis/rpc/status)
|
||||
+BuildRequires: golang(github.com/gopherjs/gopherjs/js)
|
||||
+BuildRequires: golang(github.com/gorilla/websocket)
|
||||
+BuildRequires: golang(github.com/gosimple/slug)
|
||||
+BuildRequires: golang(github.com/go-sql-driver/mysql)
|
||||
+BuildRequires: golang(github.com/go-stack/stack)
|
||||
+BuildRequires: golang(github.com/go-xorm/builder)
|
||||
+BuildRequires: golang(github.com/go-xorm/core)
|
||||
+BuildRequires: golang(github.com/go-xorm/xorm)
|
||||
+BuildRequires: golang(google.golang.org/grpc)
|
||||
+BuildRequires: golang(github.com/hashicorp/go-hclog)
|
||||
+# need grpc_broker in go-plugin >= 1.0.0-1
|
||||
+BuildRequires: golang(github.com/hashicorp/go-plugin)
|
||||
+BuildRequires: golang(github.com/hashicorp/go-version)
|
||||
+BuildRequires: golang(github.com/hashicorp/yamux)
|
||||
+BuildRequires: golang(github.com/inconshreveable/log15)
|
||||
+BuildRequires: golang(github.com/jmespath/go-jmespath)
|
||||
+BuildRequires: golang(github.com/jtolds/gls)
|
||||
+BuildRequires: golang(github.com/klauspost/compress/flate)
|
||||
+BuildRequires: golang(github.com/klauspost/compress/gzip)
|
||||
+BuildRequires: golang(github.com/klauspost/compress/snappy)
|
||||
+BuildRequires: golang(github.com/klauspost/cpuid)
|
||||
+BuildRequires: golang(github.com/klauspost/crc32)
|
||||
+BuildRequires: golang(github.com/kr/pretty)
|
||||
+BuildRequires: golang(github.com/kr/text)
|
||||
+BuildRequires: golang(github.com/lib/pq)
|
||||
+BuildRequires: golang(github.com/mattn/go-colorable)
|
||||
+BuildRequires: golang(github.com/mattn/go-isatty)
|
||||
+BuildRequires: golang(github.com/mattn/go-sqlite3)
|
||||
+BuildRequires: golang(github.com/matttproud/golang_protobuf_extensions/pbutil)
|
||||
+BuildRequires: golang(github.com/mitchellh/go-testing-interface)
|
||||
+BuildRequires: golang(github.com/oklog/run)
|
||||
+BuildRequires: golang(github.com/opentracing/opentracing-go)
|
||||
+BuildRequires: golang(github.com/patrickmn/go-cache)
|
||||
+BuildRequires: golang(github.com/pkg/errors)
|
||||
+BuildRequires: golang(github.com/prometheus/client_golang/api)
|
||||
+BuildRequires: golang(github.com/prometheus/client_golang/api/prometheus/v1)
|
||||
+BuildRequires: golang(github.com/prometheus/client_model/go)
|
||||
+BuildRequires: golang-github-prometheus-common-devel
|
||||
+BuildRequires: golang(github.com/prometheus/common/expfmt)
|
||||
+BuildRequires: golang(github.com/prometheus/common/model)
|
||||
+BuildRequires: golang(github.com/prometheus/common/expfmt)
|
||||
+BuildRequires: golang(github.com/prometheus/procfs)
|
||||
+BuildRequires: golang(github.com/prometheus/procfs/internal/util)
|
||||
+BuildRequires: golang(github.com/prometheus/procfs)
|
||||
+BuildRequires: golang(github.com/prometheus/procfs/internal/util)
|
||||
+BuildRequires: golang(github.com/prometheus/procfs/nfs)
|
||||
+BuildRequires: golang(github.com/prometheus/procfs/xfs)
|
||||
+BuildRequires: golang(github.com/rainycape/unidecode)
|
||||
+BuildRequires: golang(github.com/sergi/go-diff/diffmatchpatch)
|
||||
+BuildRequires: golang(github.com/smartystreets/assertions)
|
||||
+BuildRequires: golang(github.com/smartystreets/goconvey/convey)
|
||||
+BuildRequires: golang(github.com/smartystreets/goconvey/convey/gotest)
|
||||
+BuildRequires: golang(github.com/smartystreets/goconvey/convey/reporting)
|
||||
+BuildRequires: golang(github.com/teris-io/shortid)
|
||||
+BuildRequires: golang(github.com/Unknwon/com)
|
||||
+BuildRequires: golang(github.com/VividCortex/mysqlerr)
|
||||
+BuildRequires: golang(github.com/yudai/gojsondiff)
|
||||
+BuildRequires: golang(github.com/yudai/golcs)
|
||||
+BuildRequires: golang(golang.org/x/crypto/pbkdf2)
|
||||
+BuildRequires: golang(golang.org/x/crypto/ed25519)
|
||||
+BuildRequires: golang(golang.org/x/crypto/md4)
|
||||
+BuildRequires: golang(golang.org/x/net/context)
|
||||
+BuildRequires: golang(golang.org/x/net/context/ctxhttp)
|
||||
+BuildRequires: golang(golang.org/x/net/http2)
|
||||
+BuildRequires: golang(golang.org/x/net/http2/hpack)
|
||||
+BuildRequires: golang(golang.org/x/net/http/httpguts)
|
||||
+BuildRequires: golang(golang.org/x/net/idna)
|
||||
+BuildRequires: golang(golang.org/x/net/internal/timeseries)
|
||||
+BuildRequires: golang(golang.org/x/net/trace)
|
||||
+BuildRequires: golang(golang.org/x/text/collate)
|
||||
+BuildRequires: golang(golang.org/x/text/collate/build)
|
||||
+BuildRequires: golang(golang.org/x/text/internal/colltab)
|
||||
+BuildRequires: golang(golang.org/x/text/internal/gen)
|
||||
+BuildRequires: golang(golang.org/x/text/internal/tag)
|
||||
+BuildRequires: golang(golang.org/x/text/internal/triegen)
|
||||
+BuildRequires: golang(golang.org/x/text/internal/ucd)
|
||||
+BuildRequires: golang(golang.org/x/oauth2)
|
||||
+BuildRequires: golang(golang.org/x/oauth2/google)
|
||||
+BuildRequires: golang(golang.org/x/oauth2/internal)
|
||||
+BuildRequires: golang(golang.org/x/oauth2/jws)
|
||||
+BuildRequires: golang(golang.org/x/oauth2/jwt)
|
||||
+BuildRequires: golang(github.com/golang/protobuf/proto)
|
||||
+BuildRequires: golang(github.com/golang/protobuf/ptypes)
|
||||
+BuildRequires: golang(github.com/golang/protobuf/ptypes)
|
||||
+BuildRequires: golang(github.com/golang/protobuf/ptypes/duration)
|
||||
+BuildRequires: golang(github.com/golang/protobuf/ptypes/any)
|
||||
+BuildRequires: golang(github.com/golang/protobuf/ptypes/timestamp)
|
||||
+BuildRequires: golang(cloud.google.com/go/compute/metadata)
|
||||
+BuildRequires: golang(gopkg.in/alexcesaro/quotedprintable.v3)
|
||||
+BuildRequires: golang(gopkg.in/asn1-ber.v1)
|
||||
+BuildRequires: golang(github.com/go-bufio/bufio)
|
||||
+BuildRequires: golang(github.com/go-ini/ini)
|
||||
+BuildRequires: golang(github.com/go-macaron/macaron)
|
||||
+BuildRequires: golang(github.com/go-redis/redis)
|
||||
+BuildRequires: golang(gopkg.in/square/go-jose.v2)
|
||||
+BuildRequires: golang(gopkg.in/square/go-jose.v2/cipher)
|
||||
+BuildRequires: golang(gopkg.in/square/go-jose.v2/json)
|
||||
+BuildRequires: golang(github.com/go-yaml/yaml)
|
||||
+BuildRequires: golang(golang.org/x/sync/errgroup)
|
||||
+BuildRequires: golang(gopkg.in/ldap.v3)
|
||||
+BuildRequires: golang(gopkg.in/mail.v2)
|
||||
+
|
||||
+# Declare all nodejs modules bundled in the webpack - this is for security
|
||||
+# purposes so if nodejs-foo ever needs an update, affected packages can be
|
||||
+# easily identified. This is generated from package-lock.json once the webpack
|
||||
+# has been built with make_webpack.sh.
|
||||
+Provides: bundled(nodejs-abbrev) = 1.1.1
|
||||
+Provides: bundled(nodejs-ansi-regex) = 2.1.1
|
||||
+Provides: bundled(nodejs-ansi-styles) = 2.2.1
|
||||
+Provides: bundled(nodejs-argparse) = 1.0.10
|
||||
+Provides: bundled(nodejs-array-find-index) = 1.0.2
|
||||
+Provides: bundled(nodejs-async) = 1.5.2
|
||||
+Provides: bundled(nodejs-balanced-match) = 1.0.0
|
||||
+Provides: bundled(nodejs-brace-expansion) = 1.1.11
|
||||
+Provides: bundled(nodejs-builtin-modules) = 1.1.1
|
||||
+Provides: bundled(nodejs-camelcase) = 2.1.1
|
||||
+Provides: bundled(nodejs-camelcase-keys) = 2.1.0
|
||||
+Provides: bundled(nodejs-chalk) = 1.1.3
|
||||
+Provides: bundled(nodejs-coffee-script) = 1.10.0
|
||||
+Provides: bundled(nodejs-colors) = 1.1.2
|
||||
+Provides: bundled(nodejs-concat-map) = 0.0.1
|
||||
+Provides: bundled(nodejs-currently-unhandled) = 0.4.1
|
||||
+Provides: bundled(nodejs-dateformat) = 1.0.12
|
||||
+Provides: bundled(nodejs-decamelize) = 1.2.0
|
||||
+Provides: bundled(nodejs-error-ex) = 1.3.2
|
||||
+Provides: bundled(nodejs-escape-string-regexp) = 1.0.5
|
||||
+Provides: bundled(nodejs-esprima) = 2.7.3
|
||||
+Provides: bundled(nodejs-eventemitter2) = 0.4.14
|
||||
+Provides: bundled(nodejs-exit) = 0.1.2
|
||||
+Provides: bundled(nodejs-find-up) = 1.1.2
|
||||
+Provides: bundled(nodejs-findup-sync) = 0.3.0
|
||||
+Provides: bundled(nodejs-fs.realpath) = 1.0.0
|
||||
+Provides: bundled(nodejs-get-stdin) = 4.0.1
|
||||
+Provides: bundled(nodejs-getobject) = 0.1.0
|
||||
+Provides: bundled(nodejs-glob) = 7.0.6
|
||||
+Provides: bundled(nodejs-graceful-fs) = 4.1.15
|
||||
+Provides: bundled(nodejs-grunt) = 1.0.1
|
||||
+Provides: bundled(nodejs-grunt-cli) = 1.2.0
|
||||
+Provides: bundled(nodejs-grunt-known-options) = 1.1.1
|
||||
+Provides: bundled(nodejs-grunt-legacy-log) = 1.0.2
|
||||
+Provides: bundled(nodejs-lodash) = 4.17.11
|
||||
+Provides: bundled(nodejs-grunt-legacy-log-utils) = 1.0.0
|
||||
+Provides: bundled(nodejs-grunt-legacy-util) = 1.0.0
|
||||
+Provides: bundled(nodejs-has-ansi) = 2.0.0
|
||||
+Provides: bundled(nodejs-hooker) = 0.2.3
|
||||
+Provides: bundled(nodejs-hosted-git-info) = 2.7.1
|
||||
+Provides: bundled(nodejs-iconv-lite) = 0.4.24
|
||||
+Provides: bundled(nodejs-indent-string) = 2.1.0
|
||||
+Provides: bundled(nodejs-inflight) = 1.0.6
|
||||
+Provides: bundled(nodejs-inherits) = 2.0.3
|
||||
+Provides: bundled(nodejs-is-arrayish) = 0.2.1
|
||||
+Provides: bundled(nodejs-is-builtin-module) = 1.0.0
|
||||
+Provides: bundled(nodejs-is-finite) = 1.0.2
|
||||
+Provides: bundled(nodejs-is-utf8) = 0.2.1
|
||||
+Provides: bundled(nodejs-isexe) = 2.0.0
|
||||
+Provides: bundled(nodejs-js-yaml) = 3.5.5
|
||||
+Provides: bundled(nodejs-load-json-file) = 1.1.0
|
||||
+Provides: bundled(nodejs-loud-rejection) = 1.6.0
|
||||
+Provides: bundled(nodejs-map-obj) = 1.0.1
|
||||
+Provides: bundled(nodejs-meow) = 3.7.0
|
||||
+Provides: bundled(nodejs-minimatch) = 3.0.4
|
||||
+Provides: bundled(nodejs-minimist) = 1.2.0
|
||||
+Provides: bundled(nodejs-nopt) = 3.0.6
|
||||
+Provides: bundled(nodejs-normalize-package-data) = 2.4.2
|
||||
+Provides: bundled(nodejs-number-is-nan) = 1.0.1
|
||||
+Provides: bundled(nodejs-object-assign) = 4.1.1
|
||||
+Provides: bundled(nodejs-once) = 1.4.0
|
||||
+Provides: bundled(nodejs-parse-json) = 2.2.0
|
||||
+Provides: bundled(nodejs-path-exists) = 2.1.0
|
||||
+Provides: bundled(nodejs-path-is-absolute) = 1.0.1
|
||||
+Provides: bundled(nodejs-path-type) = 1.1.0
|
||||
+Provides: bundled(nodejs-pify) = 2.3.0
|
||||
+Provides: bundled(nodejs-pinkie) = 2.0.4
|
||||
+Provides: bundled(nodejs-pinkie-promise) = 2.0.1
|
||||
+Provides: bundled(nodejs-read-pkg) = 1.1.0
|
||||
+Provides: bundled(nodejs-read-pkg-up) = 1.0.1
|
||||
+Provides: bundled(nodejs-redent) = 1.0.0
|
||||
+Provides: bundled(nodejs-repeating) = 2.0.1
|
||||
+Provides: bundled(nodejs-resolve) = 1.1.7
|
||||
+Provides: bundled(nodejs-rimraf) = 2.2.8
|
||||
+Provides: bundled(nodejs-safer-buffer) = 2.1.2
|
||||
+Provides: bundled(nodejs-semver) = 5.6.0
|
||||
+Provides: bundled(nodejs-signal-exit) = 3.0.2
|
||||
+Provides: bundled(nodejs-spdx-correct) = 3.1.0
|
||||
+Provides: bundled(nodejs-spdx-exceptions) = 2.2.0
|
||||
+Provides: bundled(nodejs-spdx-expression-parse) = 3.0.0
|
||||
+Provides: bundled(nodejs-spdx-license-ids) = 3.0.3
|
||||
+Provides: bundled(nodejs-sprintf-js) = 1.0.3
|
||||
+Provides: bundled(nodejs-strip-ansi) = 3.0.1
|
||||
+Provides: bundled(nodejs-strip-bom) = 2.0.0
|
||||
+Provides: bundled(nodejs-strip-indent) = 1.0.1
|
||||
+Provides: bundled(nodejs-supports-color) = 2.0.0
|
||||
+Provides: bundled(nodejs-trim-newlines) = 1.0.0
|
||||
+Provides: bundled(nodejs-underscore.string) = 3.2.3
|
||||
+Provides: bundled(nodejs-validate-npm-package-license) = 3.0.4
|
||||
+Provides: bundled(nodejs-which) = 1.2.14
|
||||
+Provides: bundled(nodejs-wrappy) = 1.0.2
|
||||
+Provides: bundled(nodejs-yarn) = 1.13.0
|
||||
+
|
||||
+
|
||||
+%description
|
||||
+Grafana is an open source, feature rich metrics dashboard and graph editor for
|
||||
+Graphite, InfluxDB & OpenTSDB.
|
||||
+
|
||||
+
|
||||
+%prep
|
||||
+%setup -q -T -D -b 0
|
||||
+%setup -q -T -D -b 1
|
||||
+%patch0 -p1
|
||||
+%patch1 -p1
|
||||
+%patch2 -p1
|
||||
+%patch3 -p1
|
||||
+%patch4 -p1
|
||||
+%patch5 -p1
|
||||
+%patch6 -p1
|
||||
+
|
||||
+# Set up build subdirs and links
|
||||
+mkdir -p %{_builddir}/src/github.com/grafana
|
||||
+ln -sf %{_builddir}/%{name}-%{version} \
|
||||
+ %{_builddir}/src/github.com/grafana/grafana
|
||||
+
|
||||
+# remove some (apparent) development files, for rpmlint
|
||||
+rm -f %{_builddir}/src/github.com/grafana/grafana/public/sass/.sass-lint.yml
|
||||
+rm -f %{_builddir}/src/github.com/grafana/grafana/public/test/.jshintrc
|
||||
+
|
||||
+# Unbundle all grafana vendor sources, as per BuildRequires above.
|
||||
+# An exception is grafana-plugin-model, which is part of grafana.
|
||||
+cp --parents -a vendor/github.com/grafana %{_builddir}
|
||||
+rm -r vendor # remove all vendor sources
|
||||
+mv %{_builddir}/vendor vendor # put back what we're keeping
|
||||
+
|
||||
+
|
||||
+%build
|
||||
+# Build the server-side binaries: grafana-server and grafana-cli
|
||||
+export GOPATH=%{_builddir}:%{gopath}
|
||||
+%gobuild -o grafana-cli ./pkg/cmd/grafana-cli
|
||||
+%gobuild -o grafana-server ./pkg/cmd/grafana-server
|
||||
+
|
||||
+
|
||||
+%install
|
||||
+# binaries
|
||||
+install -d %{buildroot}%{_sbindir}
|
||||
+install -p -m 755 %{name}-server %{name}-cli %{buildroot}%{_sbindir}
|
||||
+
|
||||
+# other shared files, public html, webpack
|
||||
+install -d %{buildroot}%{_datadir}/%{name}
|
||||
+cp -a conf public %{buildroot}%{_datadir}/%{name}
|
||||
+
|
||||
+# man pages
|
||||
+install -d %{buildroot}%{_mandir}/man1
|
||||
+install -p -m 644 docs/man/man1/* %{buildroot}%{_mandir}/man1
|
||||
+
|
||||
+# config dirs
|
||||
+install -d %{buildroot}%{_sysconfdir}/%{name}
|
||||
+install -d %{buildroot}%{_sysconfdir}/sysconfig
|
||||
+
|
||||
+# config defaults
|
||||
+install -p -m 644 conf/distro-defaults.ini \
|
||||
+ %{buildroot}%{_sysconfdir}/%{name}/grafana.ini
|
||||
+install -p -m 644 conf/distro-defaults.ini \
|
||||
+ %{buildroot}%{_datadir}/%{name}/conf/defaults.ini
|
||||
+install -p -m 644 conf/ldap.toml %{buildroot}%{_sysconfdir}/%{name}/ldap.toml
|
||||
+install -p -m 644 packaging/rpm/sysconfig/grafana-server \
|
||||
+ %{buildroot}%{_sysconfdir}/sysconfig/grafana-server
|
||||
+
|
||||
+# config database directory and plugins
|
||||
+install -d %{buildroot}%{_sharedstatedir}/%{name}
|
||||
+install -d -m 755 %{buildroot}%{_sharedstatedir}/%{name}
|
||||
+install -d -m 755 %{buildroot}%{_sharedstatedir}/%{name}/plugins
|
||||
+
|
||||
+# log directory
|
||||
+install -d %{buildroot}%{_localstatedir}/log/%{name}
|
||||
+
|
||||
+# systemd service files
|
||||
+install -d %{buildroot}%{_unitdir} # only needed for manual rpmbuilds
|
||||
+install -p -m 644 packaging/rpm/systemd/grafana-server.service \
|
||||
+ %{buildroot}%{_unitdir}
|
||||
+
|
||||
+# daemon run pid file config for using tmpfs
|
||||
+install -d %{buildroot}%{_tmpfilesdir}
|
||||
+echo "d %{_rundir}/%{name} 0755 %{GRAFANA_USER} %{GRAFANA_GROUP} -" \
|
||||
+ > %{buildroot}%{_tmpfilesdir}/%{name}.conf
|
||||
+
|
||||
+%pre
|
||||
+getent group %{GRAFANA_GROUP} >/dev/null || groupadd -r %{GRAFANA_GROUP}
|
||||
+getent passwd %{GRAFANA_USER} >/dev/null || \
|
||||
+ useradd -r -g %{GRAFANA_GROUP} -d %{GRAFANA_HOME} -s /sbin/nologin \
|
||||
+ -c "%{GRAFANA_USER} user account" %{GRAFANA_USER}
|
||||
+exit 0
|
||||
+
|
||||
+%preun
|
||||
+%systemd_preun grafana-server.service
|
||||
+
|
||||
+%post
|
||||
+%systemd_post grafana-server.service
|
||||
+
|
||||
+%postun
|
||||
+%systemd_postun_with_restart grafana-server.service
|
||||
+
|
||||
+
|
||||
+%check
|
||||
+cd %{_builddir}/src/github.com/grafana/grafana
|
||||
+export GOPATH=%{_builddir}:%{gopath}
|
||||
+# this test fails for some reason
|
||||
+rm -f pkg/services/provisioning/dashboards/file_reader_linux_test.go
|
||||
+# should be using %%gochecks here, but it doesn't work
|
||||
+go test ./pkg/...
|
||||
+
|
||||
+
|
||||
+%files
|
||||
+# binaries
|
||||
+%{_sbindir}/%{name}-server
|
||||
+%{_sbindir}/%{name}-cli
|
||||
+
|
||||
+# config files
|
||||
+%dir %{_sysconfdir}/%{name}
|
||||
+%config(noreplace) %attr(644, root, %{GRAFANA_GROUP}) %{_sysconfdir}/%{name}/grafana.ini
|
||||
+%config(noreplace) %attr(644, root, %{GRAFANA_GROUP}) %{_sysconfdir}/%{name}/ldap.toml
|
||||
+%config(noreplace) %{_sysconfdir}/sysconfig/grafana-server
|
||||
+
|
||||
+# Grafana configuration to dynamically create /run/grafana/grafana.pid on tmpfs
|
||||
+%{_tmpfilesdir}/%{name}.conf
|
||||
+
|
||||
+# config database directory and plugins (actual db files are created by grafana-server)
|
||||
+%attr(-, %{GRAFANA_USER}, %{GRAFANA_GROUP}) %dir %{_sharedstatedir}/%{name}
|
||||
+%attr(-, %{GRAFANA_USER}, %{GRAFANA_GROUP}) %dir %{_sharedstatedir}/%{name}/plugins
|
||||
+
|
||||
+# shared directory and all files therein
|
||||
+%dir %{_datadir}/%{name}
|
||||
+%{_datadir}/%{name}/public
|
||||
+%dir %{_datadir}/%{name}/conf
|
||||
+%attr(-, root, %{GRAFANA_GROUP}) %{_datadir}/%{name}/conf/*
|
||||
+
|
||||
+# systemd service file
|
||||
+%{_unitdir}/grafana-server.service
|
||||
+
|
||||
+# log directory - grafana.log is created by grafana-server, and it does it's own log rotation
|
||||
+%attr(0755, %{GRAFANA_USER}, %{GRAFANA_GROUP}) %dir %{_localstatedir}/log/%{name}
|
||||
+
|
||||
+# man pages for grafana binaries
|
||||
+%{_mandir}/man1/%{name}-server.1*
|
||||
+%{_mandir}/man1/%{name}-cli.1*
|
||||
+
|
||||
+# other docs and license
|
||||
+%license LICENSE
|
||||
+%doc CHANGELOG.md CODE_OF_CONDUCT.md CONTRIBUTING.md NOTICE.md
|
||||
+%doc PLUGIN_DEV.md README.md ROADMAP.md UPGRADING_DEPENDENCIES.md
|
||||
+
|
||||
+
|
||||
+%changelog
|
||||
+* Wed Apr 24 2019 Mark Goodwin <mgoodwin@redhat.com> 6.1.4-1
|
||||
+- update to latest upstream stable release 6.1.4, see CHANGELOG
|
||||
+- use gobuild and gochecks macros, eliminate arch symlinks
|
||||
+- re-enable grafana-debugsource package
|
||||
+- fix GRAFANA_GROUP typo
|
||||
+- fix more modes for brp-mangle-shebangs
|
||||
+- vendor source unbundling now done in prep after patches
|
||||
+- remove all rhel and fedora conditional guff
|
||||
+
|
||||
+* Tue Apr 16 2019 Mark Goodwin <mgoodwin@redhat.com> 6.1.3-1
|
||||
+- update to latest upstream stable release 6.1.3, see CHANGELOG
|
||||
+- unbundle all vendor sources, replace with BuildRequires, see
|
||||
+ the long list of blocker BZs linked to BZ#1670656
|
||||
+- BuildRequires go-plugin >= v1.0.0 for grpc_broker (thanks eclipseo)
|
||||
+- tweak make_webpack to no longer use grunt, switch to prod build
|
||||
+- add ExclusiveArch lua script (thanks quantum.analyst)
|
||||
+- move db directory and plugins to /var/lib/grafana
|
||||
+- split out into 6 patches, ready for upstream PRs
|
||||
+- add check to run go tests for gating checks
|
||||
+
|
||||
+* Thu Apr 04 2019 Mark Goodwin <mgoodwin@redhat.com> 6.1.0-1
|
||||
+- update to latest upstream stable release 6.1.0, see CHANGELOG
|
||||
+
|
||||
+* Thu Mar 21 2019 Mark Goodwin <mgoodwin@redhat.com> 6.0.2-1
|
||||
+- bump to latest upstream stable release 6.0.2-1
|
||||
+- unbundle almost all remaining vendor code, see linked blockers in BZ#1670656
|
||||
+
|
||||
+* Fri Mar 15 2019 Mark Goodwin <mgoodwin@redhat.com> 6.0.1-3
|
||||
+- bump to latest upstream stable release 6.0.1-1
|
||||
+
|
||||
+* Thu Mar 14 2019 Mark Goodwin <mgoodwin@redhat.com> 6.0.1-2
|
||||
+- unbundle and add BuildRequires for golang-github-rainycape-unidecode-devel
|
||||
+
|
||||
+* Thu Mar 07 2019 Mark Goodwin <mgoodwin@redhat.com> 6.0.1-1
|
||||
+- update to v6.0.1 upstream sources, tweak distro config, re-do patch
|
||||
+- simplify make_webpack.sh script (Elliott Sales de Andrade)
|
||||
+- vendor/github.com/go-ldap is now gone, so don't unbundle it
|
||||
+
|
||||
+* Thu Mar 07 2019 Mark Goodwin <mgoodwin@redhat.com> 5.4.3-11
|
||||
+- tweak after latest feedback, bump to 5.4.3-11 (BZ 1670656)
|
||||
+- build debuginfo package again
|
||||
+- unbundle BuildRequires for golang-github-hashicorp-version-devel
|
||||
+- remove some unneeded development files
|
||||
+- remove macros from changelog and other rpmlint tweaks
|
||||
+
|
||||
+* Fri Feb 22 2019 Mark Goodwin <mgoodwin@redhat.com> 5.4.3-10
|
||||
+- tweak spec for available and unavailable (bundled) golang packages
|
||||
+
|
||||
+* Wed Feb 20 2019 Xavier Bachelot <xavier@bachelot.org> 5.4.3-9
|
||||
+- Remove extraneous slash (cosmetic)
|
||||
+- Create directories just before moving stuff in them
|
||||
+- Truncate long lines
|
||||
+- Group all golang stuff
|
||||
+- Simplify BuildRequires/bundled Provides
|
||||
+- Sort BuildRequires/bundled Provides
|
||||
+- Fix bundled go packages Provides
|
||||
+
|
||||
+* Fri Feb 15 2019 Mark Goodwin <mgoodwin@redhat.com> 5.4.3-8
|
||||
+- add BuildRequires (and unbundle) vendor sources available in Fedora
|
||||
+- declare Provides for remaining (bundled) vendor go sources
|
||||
+- do not attempt to unbundle anything on RHEL < 7 or Fedora < 28
|
||||
+
|
||||
+* Thu Feb 07 2019 Mark Goodwin <mgoodwin@redhat.com> 5.4.3-7
|
||||
+- further refinement for spec doc section from Xavier Bachelot
|
||||
+- disable debug_package to avoid empty debugsourcefiles.list
|
||||
+
|
||||
+* Wed Feb 06 2019 Mark Goodwin <mgoodwin@redhat.com> 5.4.3-6
|
||||
+- further refinement following review by Xavier Bachelot
|
||||
+
|
||||
+* Tue Feb 05 2019 Mark Goodwin <mgoodwin@redhat.com> 5.4.3-5
|
||||
+- further refinement following review by Xavier Bachelot
|
||||
+
|
||||
+* Fri Feb 01 2019 Mark Goodwin <mgoodwin@redhat.com> 5.4.3-4
|
||||
+- further spec updates after packaging review
|
||||
+- reworked post-install scriplets
|
||||
+
|
||||
+* Thu Jan 31 2019 Mark Goodwin <mgoodwin@redhat.com> 5.4.3-3
|
||||
+- tweak FHS patch, update spec after packaging review
|
||||
+
|
||||
+* Wed Jan 30 2019 Mark Goodwin <mgoodwin@redhat.com> 5.4.3-2
|
||||
+- add patch to be standard FHS compliant, remove phantomjs
|
||||
+- update to v5.4.3 upstream community sources
|
||||
+
|
||||
+* Wed Jan 09 2019 Mark Goodwin <mgoodwin@redhat.com> 5.4.2-1
|
||||
+- update to v5.4.2 upstream community sources
|
||||
+
|
||||
+* Thu Oct 18 2018 Mark Goodwin <mgoodwin@redhat.com> 5.3.1-1
|
||||
+- update to v5.3.1 upstream community sources
|
||||
+
|
||||
+* Tue Oct 02 2018 Mark Goodwin <mgoodwin@redhat.com> 5.2.5-1
|
||||
+- native RPM spec build with current tagged v5.2.5 sources
|
||||
diff --git a/packaging/rpm/spec/make_webpack.sh b/packaging/rpm/spec/make_webpack.sh
|
||||
new file mode 100755
|
||||
index 000000000..47a8025ff
|
||||
--- /dev/null
|
||||
+++ b/packaging/rpm/spec/make_webpack.sh
|
||||
@@ -0,0 +1,61 @@
|
||||
+#! /bin/bash
|
||||
+#
|
||||
+# Copyright (c) 2019 Red Hat.
|
||||
+#
|
||||
+# This program is free software; you can redistribute it and/or modify it
|
||||
+# under the terms of the GNU General Public License as published by the
|
||||
+# Free Software Foundation; either version 2 of the License, or (at your
|
||||
+# option) any later version.
|
||||
+#
|
||||
+# This program is distributed in the hope that it will be useful, but
|
||||
+# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
+# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||
+# for more details.
|
||||
+#
|
||||
+
|
||||
+[ $# -ne 1 ] && echo "Usage: $0 version" && exit 1
|
||||
+
|
||||
+# grafana version (must be tagged on github.com/grafana/grafana as "v$VER")
|
||||
+VER=$1
|
||||
+BUILDDIR=`mktemp -d buildXXXXXX`
|
||||
+
|
||||
+[ ! -f /usr/bin/npm ] && echo Error, please install \"npm\" package && exit 1
|
||||
+
|
||||
+# get src tree and set cwd
|
||||
+echo Fetching pristine upstream git tagged branch for grafana version v$VER ...
|
||||
+git clone https://github.com/grafana/grafana grafana-$VER
|
||||
+cd grafana-$VER
|
||||
+git checkout -b v$VER v$VER
|
||||
+
|
||||
+# exclude the phantomjs-prebuilt binary module from the webpack
|
||||
+sed -i '/phantomjs-prebuilt/d' package.json
|
||||
+
|
||||
+# nuke grunt task for copying phantomjs
|
||||
+rm -f scripts/grunt/options/phantomjs.js
|
||||
+sed -i '/phantomjs/d' scripts/grunt/*.js
|
||||
+
|
||||
+# populate node_modules using package.json
|
||||
+echo Running yarn to populate local node_modules ....
|
||||
+npm install yarn
|
||||
+node_modules/yarn/bin/yarn --non-interactive --no-progress --ignore-engines install --pure-lockfile > yarn.out 2>&1
|
||||
+node_modules/yarn/bin/yarn --non-interactive -W add webpack-cli
|
||||
+
|
||||
+# build the webpack
|
||||
+echo;echo Building production webpack ....
|
||||
+node_modules/webpack/bin/webpack.js --display errors-only --mode production --config scripts/webpack/webpack.prod.js
|
||||
+
|
||||
+cd ..
|
||||
+
|
||||
+# webpack tarball. Includes public/views because index.html references the webpack
|
||||
+tar czf grafana_webpack-$VER.tar.gz grafana-$VER/public/build grafana-$VER/public/views
|
||||
+
|
||||
+# source tarball (if needed)
|
||||
+if [ ! -f grafana-$VER.tar.gz ]; then
|
||||
+ wget --quiet -O grafana-$VER.tar.gz https://github.com/grafana/grafana/archive/v$VER/grafana-$VER.tar.gz
|
||||
+fi
|
||||
+
|
||||
+# done
|
||||
+echo Both grafana-$VER.tar.gz and grafana_webpack-$VER.tar.gz
|
||||
+echo should now be copied to your \$HOME/rpmbuild/SOURCES
|
||||
+
|
||||
+exit 0
|
511
grafana.spec
Normal file
511
grafana.spec
Normal file
@ -0,0 +1,511 @@
|
||||
%global grafana_arches %{lua: go_arches = {}
|
||||
for arch in rpm.expand("%{go_arches}"):gmatch("%S+") do
|
||||
go_arches[arch] = 1
|
||||
end
|
||||
for arch in rpm.expand("%{nodejs_arches}"):gmatch("%S+") do
|
||||
if go_arches[arch] then
|
||||
print(arch .. " ")
|
||||
end
|
||||
end}
|
||||
|
||||
Name: grafana
|
||||
Version: 6.1.4
|
||||
Release: 1%{?dist}
|
||||
Summary: Metrics dashboard and graph editor
|
||||
License: ASL 2.0
|
||||
URL: https://grafana.org
|
||||
|
||||
# Source0 contains the tagged upstream sources
|
||||
Source0: https://github.com/grafana/grafana/archive/v%{version}/%{name}-%{version}.tar.gz
|
||||
|
||||
# Source1 contains the front-end javascript modules bundled into a webpack
|
||||
Source1: grafana_webpack-%{version}.tar.gz
|
||||
|
||||
# Source2 is the script to create the above webpack from grafana sources
|
||||
Source2: make_webpack.sh
|
||||
|
||||
# Patches for upstream (except Patch5)
|
||||
Patch0: 000-go-test-fixes.patch
|
||||
Patch1: 001-man-pages.patch
|
||||
Patch2: 002-update-golang-oauth2-vendor-sources.patch
|
||||
Patch3: 003-file-mode-updates.patch
|
||||
Patch4: 004-grafana.ini-for-Linux-distros.patch
|
||||
Patch5: 005-remove-jaeger-tracing.patch
|
||||
Patch6: 006-native-RPM-spec-and-webpack-build-script.patch
|
||||
|
||||
# Intersection of go_arches and nodejs_arches
|
||||
ExclusiveArch: %{grafana_arches}
|
||||
|
||||
%global GRAFANA_USER %{name}
|
||||
%global GRAFANA_GROUP %{name}
|
||||
%global GRAFANA_HOME %{_datadir}/%{name}
|
||||
|
||||
# grafana-server service daemon uses systemd
|
||||
%{?systemd_requires}
|
||||
Requires(pre): shadow-utils
|
||||
|
||||
BuildRequires: systemd, golang, compiler(go-compiler)
|
||||
|
||||
# golang build deps. These allow us to unbundle vendor golang source.
|
||||
BuildRequires: golang(github.com/aws/aws-sdk-go)
|
||||
BuildRequires: golang(github.com/benbjohnson/clock)
|
||||
BuildRequires: golang(github.com/beorn7/perks/quantile)
|
||||
BuildRequires: golang(github.com/bmizerany/assert)
|
||||
BuildRequires: golang(github.com/bradfitz/gomemcache/memcache)
|
||||
BuildRequires: golang(github.com/BurntSushi/toml)
|
||||
BuildRequires: golang(github.com/codahale/hdrhistogram)
|
||||
BuildRequires: golang(github.com/codegangsta/cli)
|
||||
BuildRequires: golang(github.com/davecgh/go-spew/spew)
|
||||
BuildRequires: golang(github.com/denisenkom/go-mssqldb)
|
||||
BuildRequires: golang(github.com/facebookgo/inject)
|
||||
BuildRequires: golang(github.com/facebookgo/structtag)
|
||||
BuildRequires: golang(github.com/fatih/color)
|
||||
BuildRequires: golang(github.com/go-ini/ini)
|
||||
BuildRequires: golang(google.golang.org/appengine)
|
||||
BuildRequires: golang(golang.org/x/sys/unix)
|
||||
BuildRequires: golang(github.com/go-macaron/binding)
|
||||
BuildRequires: golang(github.com/go-macaron/gzip)
|
||||
BuildRequires: golang(github.com/go-macaron/inject)
|
||||
BuildRequires: golang(github.com/go-macaron/session)
|
||||
BuildRequires: golang(google.golang.org/genproto/googleapis/rpc/status)
|
||||
BuildRequires: golang(github.com/gopherjs/gopherjs/js)
|
||||
BuildRequires: golang(github.com/gorilla/websocket)
|
||||
BuildRequires: golang(github.com/gosimple/slug)
|
||||
BuildRequires: golang(github.com/go-sql-driver/mysql)
|
||||
BuildRequires: golang(github.com/go-stack/stack)
|
||||
BuildRequires: golang(github.com/go-xorm/builder)
|
||||
BuildRequires: golang(github.com/go-xorm/core)
|
||||
BuildRequires: golang(github.com/go-xorm/xorm)
|
||||
BuildRequires: golang(google.golang.org/grpc)
|
||||
BuildRequires: golang(github.com/hashicorp/go-hclog)
|
||||
# need grpc_broker in go-plugin >= 1.0.0-1
|
||||
BuildRequires: golang(github.com/hashicorp/go-plugin)
|
||||
BuildRequires: golang(github.com/hashicorp/go-version)
|
||||
BuildRequires: golang(github.com/hashicorp/yamux)
|
||||
BuildRequires: golang(github.com/inconshreveable/log15)
|
||||
BuildRequires: golang(github.com/jmespath/go-jmespath)
|
||||
BuildRequires: golang(github.com/jtolds/gls)
|
||||
BuildRequires: golang(github.com/klauspost/compress/flate)
|
||||
BuildRequires: golang(github.com/klauspost/compress/gzip)
|
||||
BuildRequires: golang(github.com/klauspost/compress/snappy)
|
||||
BuildRequires: golang(github.com/klauspost/cpuid)
|
||||
BuildRequires: golang(github.com/klauspost/crc32)
|
||||
BuildRequires: golang(github.com/kr/pretty)
|
||||
BuildRequires: golang(github.com/kr/text)
|
||||
BuildRequires: golang(github.com/lib/pq)
|
||||
BuildRequires: golang(github.com/mattn/go-colorable)
|
||||
BuildRequires: golang(github.com/mattn/go-isatty)
|
||||
BuildRequires: golang(github.com/mattn/go-sqlite3)
|
||||
BuildRequires: golang(github.com/matttproud/golang_protobuf_extensions/pbutil)
|
||||
BuildRequires: golang(github.com/mitchellh/go-testing-interface)
|
||||
BuildRequires: golang(github.com/oklog/run)
|
||||
BuildRequires: golang(github.com/opentracing/opentracing-go)
|
||||
BuildRequires: golang(github.com/patrickmn/go-cache)
|
||||
BuildRequires: golang(github.com/pkg/errors)
|
||||
BuildRequires: golang(github.com/prometheus/client_golang/api)
|
||||
BuildRequires: golang(github.com/prometheus/client_golang/api/prometheus/v1)
|
||||
BuildRequires: golang(github.com/prometheus/client_model/go)
|
||||
BuildRequires: golang-github-prometheus-common-devel
|
||||
BuildRequires: golang(github.com/prometheus/common/expfmt)
|
||||
BuildRequires: golang(github.com/prometheus/common/model)
|
||||
BuildRequires: golang(github.com/prometheus/common/expfmt)
|
||||
BuildRequires: golang(github.com/prometheus/procfs)
|
||||
BuildRequires: golang(github.com/prometheus/procfs/internal/util)
|
||||
BuildRequires: golang(github.com/prometheus/procfs)
|
||||
BuildRequires: golang(github.com/prometheus/procfs/internal/util)
|
||||
BuildRequires: golang(github.com/prometheus/procfs/nfs)
|
||||
BuildRequires: golang(github.com/prometheus/procfs/xfs)
|
||||
BuildRequires: golang(github.com/rainycape/unidecode)
|
||||
BuildRequires: golang(github.com/sergi/go-diff/diffmatchpatch)
|
||||
BuildRequires: golang(github.com/smartystreets/assertions)
|
||||
BuildRequires: golang(github.com/smartystreets/goconvey/convey)
|
||||
BuildRequires: golang(github.com/smartystreets/goconvey/convey/gotest)
|
||||
BuildRequires: golang(github.com/smartystreets/goconvey/convey/reporting)
|
||||
BuildRequires: golang(github.com/teris-io/shortid)
|
||||
BuildRequires: golang(github.com/Unknwon/com)
|
||||
BuildRequires: golang(github.com/VividCortex/mysqlerr)
|
||||
BuildRequires: golang(github.com/yudai/gojsondiff)
|
||||
BuildRequires: golang(github.com/yudai/golcs)
|
||||
BuildRequires: golang(golang.org/x/crypto/pbkdf2)
|
||||
BuildRequires: golang(golang.org/x/crypto/ed25519)
|
||||
BuildRequires: golang(golang.org/x/crypto/md4)
|
||||
BuildRequires: golang(golang.org/x/net/context)
|
||||
BuildRequires: golang(golang.org/x/net/context/ctxhttp)
|
||||
BuildRequires: golang(golang.org/x/net/http2)
|
||||
BuildRequires: golang(golang.org/x/net/http2/hpack)
|
||||
BuildRequires: golang(golang.org/x/net/http/httpguts)
|
||||
BuildRequires: golang(golang.org/x/net/idna)
|
||||
BuildRequires: golang(golang.org/x/net/internal/timeseries)
|
||||
BuildRequires: golang(golang.org/x/net/trace)
|
||||
BuildRequires: golang(golang.org/x/text/collate)
|
||||
BuildRequires: golang(golang.org/x/text/collate/build)
|
||||
BuildRequires: golang(golang.org/x/text/internal/colltab)
|
||||
BuildRequires: golang(golang.org/x/text/internal/gen)
|
||||
BuildRequires: golang(golang.org/x/text/internal/tag)
|
||||
BuildRequires: golang(golang.org/x/text/internal/triegen)
|
||||
BuildRequires: golang(golang.org/x/text/internal/ucd)
|
||||
BuildRequires: golang(golang.org/x/oauth2)
|
||||
BuildRequires: golang(golang.org/x/oauth2/google)
|
||||
BuildRequires: golang(golang.org/x/oauth2/internal)
|
||||
BuildRequires: golang(golang.org/x/oauth2/jws)
|
||||
BuildRequires: golang(golang.org/x/oauth2/jwt)
|
||||
BuildRequires: golang(github.com/golang/protobuf/proto)
|
||||
BuildRequires: golang(github.com/golang/protobuf/ptypes)
|
||||
BuildRequires: golang(github.com/golang/protobuf/ptypes)
|
||||
BuildRequires: golang(github.com/golang/protobuf/ptypes/duration)
|
||||
BuildRequires: golang(github.com/golang/protobuf/ptypes/any)
|
||||
BuildRequires: golang(github.com/golang/protobuf/ptypes/timestamp)
|
||||
BuildRequires: golang(cloud.google.com/go/compute/metadata)
|
||||
BuildRequires: golang(gopkg.in/alexcesaro/quotedprintable.v3)
|
||||
BuildRequires: golang(gopkg.in/asn1-ber.v1)
|
||||
BuildRequires: golang(github.com/go-bufio/bufio)
|
||||
BuildRequires: golang(github.com/go-ini/ini)
|
||||
BuildRequires: golang(github.com/go-macaron/macaron)
|
||||
BuildRequires: golang(github.com/go-redis/redis)
|
||||
BuildRequires: golang(gopkg.in/square/go-jose.v2)
|
||||
BuildRequires: golang(gopkg.in/square/go-jose.v2/cipher)
|
||||
BuildRequires: golang(gopkg.in/square/go-jose.v2/json)
|
||||
BuildRequires: golang(github.com/go-yaml/yaml)
|
||||
BuildRequires: golang(golang.org/x/sync/errgroup)
|
||||
BuildRequires: golang(gopkg.in/ldap.v3)
|
||||
BuildRequires: golang(gopkg.in/mail.v2)
|
||||
|
||||
# Declare all nodejs modules bundled in the webpack - this is for security
|
||||
# purposes so if nodejs-foo ever needs an update, affected packages can be
|
||||
# easily identified. This is generated from package-lock.json once the webpack
|
||||
# has been built with make_webpack.sh.
|
||||
Provides: bundled(nodejs-abbrev) = 1.1.1
|
||||
Provides: bundled(nodejs-ansi-regex) = 2.1.1
|
||||
Provides: bundled(nodejs-ansi-styles) = 2.2.1
|
||||
Provides: bundled(nodejs-argparse) = 1.0.10
|
||||
Provides: bundled(nodejs-array-find-index) = 1.0.2
|
||||
Provides: bundled(nodejs-async) = 1.5.2
|
||||
Provides: bundled(nodejs-balanced-match) = 1.0.0
|
||||
Provides: bundled(nodejs-brace-expansion) = 1.1.11
|
||||
Provides: bundled(nodejs-builtin-modules) = 1.1.1
|
||||
Provides: bundled(nodejs-camelcase) = 2.1.1
|
||||
Provides: bundled(nodejs-camelcase-keys) = 2.1.0
|
||||
Provides: bundled(nodejs-chalk) = 1.1.3
|
||||
Provides: bundled(nodejs-coffee-script) = 1.10.0
|
||||
Provides: bundled(nodejs-colors) = 1.1.2
|
||||
Provides: bundled(nodejs-concat-map) = 0.0.1
|
||||
Provides: bundled(nodejs-currently-unhandled) = 0.4.1
|
||||
Provides: bundled(nodejs-dateformat) = 1.0.12
|
||||
Provides: bundled(nodejs-decamelize) = 1.2.0
|
||||
Provides: bundled(nodejs-error-ex) = 1.3.2
|
||||
Provides: bundled(nodejs-escape-string-regexp) = 1.0.5
|
||||
Provides: bundled(nodejs-esprima) = 2.7.3
|
||||
Provides: bundled(nodejs-eventemitter2) = 0.4.14
|
||||
Provides: bundled(nodejs-exit) = 0.1.2
|
||||
Provides: bundled(nodejs-find-up) = 1.1.2
|
||||
Provides: bundled(nodejs-findup-sync) = 0.3.0
|
||||
Provides: bundled(nodejs-fs.realpath) = 1.0.0
|
||||
Provides: bundled(nodejs-get-stdin) = 4.0.1
|
||||
Provides: bundled(nodejs-getobject) = 0.1.0
|
||||
Provides: bundled(nodejs-glob) = 7.0.6
|
||||
Provides: bundled(nodejs-graceful-fs) = 4.1.15
|
||||
Provides: bundled(nodejs-grunt) = 1.0.1
|
||||
Provides: bundled(nodejs-grunt-cli) = 1.2.0
|
||||
Provides: bundled(nodejs-grunt-known-options) = 1.1.1
|
||||
Provides: bundled(nodejs-grunt-legacy-log) = 1.0.2
|
||||
Provides: bundled(nodejs-lodash) = 4.17.11
|
||||
Provides: bundled(nodejs-grunt-legacy-log-utils) = 1.0.0
|
||||
Provides: bundled(nodejs-grunt-legacy-util) = 1.0.0
|
||||
Provides: bundled(nodejs-has-ansi) = 2.0.0
|
||||
Provides: bundled(nodejs-hooker) = 0.2.3
|
||||
Provides: bundled(nodejs-hosted-git-info) = 2.7.1
|
||||
Provides: bundled(nodejs-iconv-lite) = 0.4.24
|
||||
Provides: bundled(nodejs-indent-string) = 2.1.0
|
||||
Provides: bundled(nodejs-inflight) = 1.0.6
|
||||
Provides: bundled(nodejs-inherits) = 2.0.3
|
||||
Provides: bundled(nodejs-is-arrayish) = 0.2.1
|
||||
Provides: bundled(nodejs-is-builtin-module) = 1.0.0
|
||||
Provides: bundled(nodejs-is-finite) = 1.0.2
|
||||
Provides: bundled(nodejs-is-utf8) = 0.2.1
|
||||
Provides: bundled(nodejs-isexe) = 2.0.0
|
||||
Provides: bundled(nodejs-js-yaml) = 3.5.5
|
||||
Provides: bundled(nodejs-load-json-file) = 1.1.0
|
||||
Provides: bundled(nodejs-loud-rejection) = 1.6.0
|
||||
Provides: bundled(nodejs-map-obj) = 1.0.1
|
||||
Provides: bundled(nodejs-meow) = 3.7.0
|
||||
Provides: bundled(nodejs-minimatch) = 3.0.4
|
||||
Provides: bundled(nodejs-minimist) = 1.2.0
|
||||
Provides: bundled(nodejs-nopt) = 3.0.6
|
||||
Provides: bundled(nodejs-normalize-package-data) = 2.4.2
|
||||
Provides: bundled(nodejs-number-is-nan) = 1.0.1
|
||||
Provides: bundled(nodejs-object-assign) = 4.1.1
|
||||
Provides: bundled(nodejs-once) = 1.4.0
|
||||
Provides: bundled(nodejs-parse-json) = 2.2.0
|
||||
Provides: bundled(nodejs-path-exists) = 2.1.0
|
||||
Provides: bundled(nodejs-path-is-absolute) = 1.0.1
|
||||
Provides: bundled(nodejs-path-type) = 1.1.0
|
||||
Provides: bundled(nodejs-pify) = 2.3.0
|
||||
Provides: bundled(nodejs-pinkie) = 2.0.4
|
||||
Provides: bundled(nodejs-pinkie-promise) = 2.0.1
|
||||
Provides: bundled(nodejs-read-pkg) = 1.1.0
|
||||
Provides: bundled(nodejs-read-pkg-up) = 1.0.1
|
||||
Provides: bundled(nodejs-redent) = 1.0.0
|
||||
Provides: bundled(nodejs-repeating) = 2.0.1
|
||||
Provides: bundled(nodejs-resolve) = 1.1.7
|
||||
Provides: bundled(nodejs-rimraf) = 2.2.8
|
||||
Provides: bundled(nodejs-safer-buffer) = 2.1.2
|
||||
Provides: bundled(nodejs-semver) = 5.6.0
|
||||
Provides: bundled(nodejs-signal-exit) = 3.0.2
|
||||
Provides: bundled(nodejs-spdx-correct) = 3.1.0
|
||||
Provides: bundled(nodejs-spdx-exceptions) = 2.2.0
|
||||
Provides: bundled(nodejs-spdx-expression-parse) = 3.0.0
|
||||
Provides: bundled(nodejs-spdx-license-ids) = 3.0.3
|
||||
Provides: bundled(nodejs-sprintf-js) = 1.0.3
|
||||
Provides: bundled(nodejs-strip-ansi) = 3.0.1
|
||||
Provides: bundled(nodejs-strip-bom) = 2.0.0
|
||||
Provides: bundled(nodejs-strip-indent) = 1.0.1
|
||||
Provides: bundled(nodejs-supports-color) = 2.0.0
|
||||
Provides: bundled(nodejs-trim-newlines) = 1.0.0
|
||||
Provides: bundled(nodejs-underscore.string) = 3.2.3
|
||||
Provides: bundled(nodejs-validate-npm-package-license) = 3.0.4
|
||||
Provides: bundled(nodejs-which) = 1.2.14
|
||||
Provides: bundled(nodejs-wrappy) = 1.0.2
|
||||
Provides: bundled(nodejs-yarn) = 1.13.0
|
||||
|
||||
|
||||
%description
|
||||
Grafana is an open source, feature rich metrics dashboard and graph editor for
|
||||
Graphite, InfluxDB & OpenTSDB.
|
||||
|
||||
|
||||
%prep
|
||||
%setup -q -T -D -b 0
|
||||
%setup -q -T -D -b 1
|
||||
%patch0 -p1
|
||||
%patch1 -p1
|
||||
%patch2 -p1
|
||||
%patch3 -p1
|
||||
%patch4 -p1
|
||||
%patch5 -p1
|
||||
%patch6 -p1
|
||||
|
||||
# Set up build subdirs and links
|
||||
mkdir -p %{_builddir}/src/github.com/grafana
|
||||
ln -sf %{_builddir}/%{name}-%{version} \
|
||||
%{_builddir}/src/github.com/grafana/grafana
|
||||
|
||||
# remove some (apparent) development files, for rpmlint
|
||||
rm -f %{_builddir}/src/github.com/grafana/grafana/public/sass/.sass-lint.yml
|
||||
rm -f %{_builddir}/src/github.com/grafana/grafana/public/test/.jshintrc
|
||||
|
||||
# Unbundle all grafana vendor sources, as per BuildRequires above.
|
||||
# An exception is grafana-plugin-model, which is part of grafana.
|
||||
cp --parents -a vendor/github.com/grafana %{_builddir}
|
||||
rm -r vendor # remove all vendor sources
|
||||
mv %{_builddir}/vendor vendor # put back what we're keeping
|
||||
|
||||
|
||||
%build
|
||||
# Build the server-side binaries: grafana-server and grafana-cli
|
||||
export GOPATH=%{_builddir}:%{gopath}
|
||||
%gobuild -o grafana-cli ./pkg/cmd/grafana-cli
|
||||
%gobuild -o grafana-server ./pkg/cmd/grafana-server
|
||||
|
||||
|
||||
%install
|
||||
# binaries
|
||||
install -d %{buildroot}%{_sbindir}
|
||||
install -p -m 755 %{name}-server %{name}-cli %{buildroot}%{_sbindir}
|
||||
|
||||
# other shared files, public html, webpack
|
||||
install -d %{buildroot}%{_datadir}/%{name}
|
||||
cp -a conf public %{buildroot}%{_datadir}/%{name}
|
||||
|
||||
# man pages
|
||||
install -d %{buildroot}%{_mandir}/man1
|
||||
install -p -m 644 docs/man/man1/* %{buildroot}%{_mandir}/man1
|
||||
|
||||
# config dirs
|
||||
install -d %{buildroot}%{_sysconfdir}/%{name}
|
||||
install -d %{buildroot}%{_sysconfdir}/sysconfig
|
||||
|
||||
# config defaults
|
||||
install -p -m 644 conf/distro-defaults.ini \
|
||||
%{buildroot}%{_sysconfdir}/%{name}/grafana.ini
|
||||
install -p -m 644 conf/distro-defaults.ini \
|
||||
%{buildroot}%{_datadir}/%{name}/conf/defaults.ini
|
||||
install -p -m 644 conf/ldap.toml %{buildroot}%{_sysconfdir}/%{name}/ldap.toml
|
||||
install -p -m 644 packaging/rpm/sysconfig/grafana-server \
|
||||
%{buildroot}%{_sysconfdir}/sysconfig/grafana-server
|
||||
|
||||
# config database directory and plugins
|
||||
install -d %{buildroot}%{_sharedstatedir}/%{name}
|
||||
install -d -m 755 %{buildroot}%{_sharedstatedir}/%{name}
|
||||
install -d -m 755 %{buildroot}%{_sharedstatedir}/%{name}/plugins
|
||||
|
||||
# log directory
|
||||
install -d %{buildroot}%{_localstatedir}/log/%{name}
|
||||
|
||||
# systemd service files
|
||||
install -d %{buildroot}%{_unitdir} # only needed for manual rpmbuilds
|
||||
install -p -m 644 packaging/rpm/systemd/grafana-server.service \
|
||||
%{buildroot}%{_unitdir}
|
||||
|
||||
# daemon run pid file config for using tmpfs
|
||||
install -d %{buildroot}%{_tmpfilesdir}
|
||||
echo "d %{_rundir}/%{name} 0755 %{GRAFANA_USER} %{GRAFANA_GROUP} -" \
|
||||
> %{buildroot}%{_tmpfilesdir}/%{name}.conf
|
||||
|
||||
%pre
|
||||
getent group %{GRAFANA_GROUP} >/dev/null || groupadd -r %{GRAFANA_GROUP}
|
||||
getent passwd %{GRAFANA_USER} >/dev/null || \
|
||||
useradd -r -g %{GRAFANA_GROUP} -d %{GRAFANA_HOME} -s /sbin/nologin \
|
||||
-c "%{GRAFANA_USER} user account" %{GRAFANA_USER}
|
||||
exit 0
|
||||
|
||||
%preun
|
||||
%systemd_preun grafana-server.service
|
||||
|
||||
%post
|
||||
%systemd_post grafana-server.service
|
||||
|
||||
%postun
|
||||
%systemd_postun_with_restart grafana-server.service
|
||||
|
||||
|
||||
%check
|
||||
cd %{_builddir}/src/github.com/grafana/grafana
|
||||
export GOPATH=%{_builddir}:%{gopath}
|
||||
# this test fails for some reason
|
||||
rm -f pkg/services/provisioning/dashboards/file_reader_linux_test.go
|
||||
# should be using %%gochecks here, but it doesn't work
|
||||
go test ./pkg/...
|
||||
|
||||
|
||||
%files
|
||||
# binaries
|
||||
%{_sbindir}/%{name}-server
|
||||
%{_sbindir}/%{name}-cli
|
||||
|
||||
# config files
|
||||
%dir %{_sysconfdir}/%{name}
|
||||
%config(noreplace) %attr(644, root, %{GRAFANA_GROUP}) %{_sysconfdir}/%{name}/grafana.ini
|
||||
%config(noreplace) %attr(644, root, %{GRAFANA_GROUP}) %{_sysconfdir}/%{name}/ldap.toml
|
||||
%config(noreplace) %{_sysconfdir}/sysconfig/grafana-server
|
||||
|
||||
# Grafana configuration to dynamically create /run/grafana/grafana.pid on tmpfs
|
||||
%{_tmpfilesdir}/%{name}.conf
|
||||
|
||||
# config database directory and plugins (actual db files are created by grafana-server)
|
||||
%attr(-, %{GRAFANA_USER}, %{GRAFANA_GROUP}) %dir %{_sharedstatedir}/%{name}
|
||||
%attr(-, %{GRAFANA_USER}, %{GRAFANA_GROUP}) %dir %{_sharedstatedir}/%{name}/plugins
|
||||
|
||||
# shared directory and all files therein
|
||||
%dir %{_datadir}/%{name}
|
||||
%{_datadir}/%{name}/public
|
||||
%dir %{_datadir}/%{name}/conf
|
||||
%attr(-, root, %{GRAFANA_GROUP}) %{_datadir}/%{name}/conf/*
|
||||
|
||||
# systemd service file
|
||||
%{_unitdir}/grafana-server.service
|
||||
|
||||
# log directory - grafana.log is created by grafana-server, and it does it's own log rotation
|
||||
%attr(0755, %{GRAFANA_USER}, %{GRAFANA_GROUP}) %dir %{_localstatedir}/log/%{name}
|
||||
|
||||
# man pages for grafana binaries
|
||||
%{_mandir}/man1/%{name}-server.1*
|
||||
%{_mandir}/man1/%{name}-cli.1*
|
||||
|
||||
# other docs and license
|
||||
%license LICENSE
|
||||
%doc CHANGELOG.md CODE_OF_CONDUCT.md CONTRIBUTING.md NOTICE.md
|
||||
%doc PLUGIN_DEV.md README.md ROADMAP.md UPGRADING_DEPENDENCIES.md
|
||||
|
||||
|
||||
%changelog
|
||||
* Wed Apr 24 2019 Mark Goodwin <mgoodwin@redhat.com> 6.1.4-1
|
||||
- update to latest upstream stable release 6.1.4, see CHANGELOG
|
||||
- use gobuild and gochecks macros, eliminate arch symlinks
|
||||
- re-enable grafana-debugsource package
|
||||
- fix GRAFANA_GROUP typo
|
||||
- fix more modes for brp-mangle-shebangs
|
||||
- vendor source unbundling now done in prep after patches
|
||||
- remove all rhel and fedora conditional guff
|
||||
|
||||
* Tue Apr 16 2019 Mark Goodwin <mgoodwin@redhat.com> 6.1.3-1
|
||||
- update to latest upstream stable release 6.1.3, see CHANGELOG
|
||||
- unbundle all vendor sources, replace with BuildRequires, see
|
||||
the long list of blocker BZs linked to BZ#1670656
|
||||
- BuildRequires go-plugin >= v1.0.0 for grpc_broker (thanks eclipseo)
|
||||
- tweak make_webpack to no longer use grunt, switch to prod build
|
||||
- add ExclusiveArch lua script (thanks quantum.analyst)
|
||||
- move db directory and plugins to /var/lib/grafana
|
||||
- split out into 6 patches, ready for upstream PRs
|
||||
- add check to run go tests for gating checks
|
||||
|
||||
* Thu Apr 04 2019 Mark Goodwin <mgoodwin@redhat.com> 6.1.0-1
|
||||
- update to latest upstream stable release 6.1.0, see CHANGELOG
|
||||
|
||||
* Thu Mar 21 2019 Mark Goodwin <mgoodwin@redhat.com> 6.0.2-1
|
||||
- bump to latest upstream stable release 6.0.2-1
|
||||
- unbundle almost all remaining vendor code, see linked blockers in BZ#1670656
|
||||
|
||||
* Fri Mar 15 2019 Mark Goodwin <mgoodwin@redhat.com> 6.0.1-3
|
||||
- bump to latest upstream stable release 6.0.1-1
|
||||
|
||||
* Thu Mar 14 2019 Mark Goodwin <mgoodwin@redhat.com> 6.0.1-2
|
||||
- unbundle and add BuildRequires for golang-github-rainycape-unidecode-devel
|
||||
|
||||
* Thu Mar 07 2019 Mark Goodwin <mgoodwin@redhat.com> 6.0.1-1
|
||||
- update to v6.0.1 upstream sources, tweak distro config, re-do patch
|
||||
- simplify make_webpack.sh script (Elliott Sales de Andrade)
|
||||
- vendor/github.com/go-ldap is now gone, so don't unbundle it
|
||||
|
||||
* Thu Mar 07 2019 Mark Goodwin <mgoodwin@redhat.com> 5.4.3-11
|
||||
- tweak after latest feedback, bump to 5.4.3-11 (BZ 1670656)
|
||||
- build debuginfo package again
|
||||
- unbundle BuildRequires for golang-github-hashicorp-version-devel
|
||||
- remove some unneeded development files
|
||||
- remove macros from changelog and other rpmlint tweaks
|
||||
|
||||
* Fri Feb 22 2019 Mark Goodwin <mgoodwin@redhat.com> 5.4.3-10
|
||||
- tweak spec for available and unavailable (bundled) golang packages
|
||||
|
||||
* Wed Feb 20 2019 Xavier Bachelot <xavier@bachelot.org> 5.4.3-9
|
||||
- Remove extraneous slash (cosmetic)
|
||||
- Create directories just before moving stuff in them
|
||||
- Truncate long lines
|
||||
- Group all golang stuff
|
||||
- Simplify BuildRequires/bundled Provides
|
||||
- Sort BuildRequires/bundled Provides
|
||||
- Fix bundled go packages Provides
|
||||
|
||||
* Fri Feb 15 2019 Mark Goodwin <mgoodwin@redhat.com> 5.4.3-8
|
||||
- add BuildRequires (and unbundle) vendor sources available in Fedora
|
||||
- declare Provides for remaining (bundled) vendor go sources
|
||||
- do not attempt to unbundle anything on RHEL < 7 or Fedora < 28
|
||||
|
||||
* Thu Feb 07 2019 Mark Goodwin <mgoodwin@redhat.com> 5.4.3-7
|
||||
- further refinement for spec doc section from Xavier Bachelot
|
||||
- disable debug_package to avoid empty debugsourcefiles.list
|
||||
|
||||
* Wed Feb 06 2019 Mark Goodwin <mgoodwin@redhat.com> 5.4.3-6
|
||||
- further refinement following review by Xavier Bachelot
|
||||
|
||||
* Tue Feb 05 2019 Mark Goodwin <mgoodwin@redhat.com> 5.4.3-5
|
||||
- further refinement following review by Xavier Bachelot
|
||||
|
||||
* Fri Feb 01 2019 Mark Goodwin <mgoodwin@redhat.com> 5.4.3-4
|
||||
- further spec updates after packaging review
|
||||
- reworked post-install scriplets
|
||||
|
||||
* Thu Jan 31 2019 Mark Goodwin <mgoodwin@redhat.com> 5.4.3-3
|
||||
- tweak FHS patch, update spec after packaging review
|
||||
|
||||
* Wed Jan 30 2019 Mark Goodwin <mgoodwin@redhat.com> 5.4.3-2
|
||||
- add patch to be standard FHS compliant, remove phantomjs
|
||||
- update to v5.4.3 upstream community sources
|
||||
|
||||
* Wed Jan 09 2019 Mark Goodwin <mgoodwin@redhat.com> 5.4.2-1
|
||||
- update to v5.4.2 upstream community sources
|
||||
|
||||
* Thu Oct 18 2018 Mark Goodwin <mgoodwin@redhat.com> 5.3.1-1
|
||||
- update to v5.3.1 upstream community sources
|
||||
|
||||
* Tue Oct 02 2018 Mark Goodwin <mgoodwin@redhat.com> 5.2.5-1
|
||||
- native RPM spec build with current tagged v5.2.5 sources
|
61
make_webpack.sh
Normal file
61
make_webpack.sh
Normal file
@ -0,0 +1,61 @@
|
||||
#! /bin/bash
|
||||
#
|
||||
# Copyright (c) 2019 Red Hat.
|
||||
#
|
||||
# This program is free software; you can redistribute it and/or modify it
|
||||
# under the terms of the GNU General Public License as published by the
|
||||
# Free Software Foundation; either version 2 of the License, or (at your
|
||||
# option) any later version.
|
||||
#
|
||||
# This program is distributed in the hope that it will be useful, but
|
||||
# WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||
# or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||
# for more details.
|
||||
#
|
||||
|
||||
[ $# -ne 1 ] && echo "Usage: $0 version" && exit 1
|
||||
|
||||
# grafana version (must be tagged on github.com/grafana/grafana as "v$VER")
|
||||
VER=$1
|
||||
BUILDDIR=`mktemp -d buildXXXXXX`
|
||||
|
||||
[ ! -f /usr/bin/npm ] && echo Error, please install \"npm\" package && exit 1
|
||||
|
||||
# get src tree and set cwd
|
||||
echo Fetching pristine upstream git tagged branch for grafana version v$VER ...
|
||||
git clone https://github.com/grafana/grafana grafana-$VER
|
||||
cd grafana-$VER
|
||||
git checkout -b v$VER v$VER
|
||||
|
||||
# exclude the phantomjs-prebuilt binary module from the webpack
|
||||
sed -i '/phantomjs-prebuilt/d' package.json
|
||||
|
||||
# nuke grunt task for copying phantomjs
|
||||
rm -f scripts/grunt/options/phantomjs.js
|
||||
sed -i '/phantomjs/d' scripts/grunt/*.js
|
||||
|
||||
# populate node_modules using package.json
|
||||
echo Running yarn to populate local node_modules ....
|
||||
npm install yarn
|
||||
node_modules/yarn/bin/yarn --non-interactive --no-progress --ignore-engines install --pure-lockfile > yarn.out 2>&1
|
||||
node_modules/yarn/bin/yarn --non-interactive -W add webpack-cli
|
||||
|
||||
# build the webpack
|
||||
echo;echo Building production webpack ....
|
||||
node_modules/webpack/bin/webpack.js --display errors-only --mode production --config scripts/webpack/webpack.prod.js
|
||||
|
||||
cd ..
|
||||
|
||||
# webpack tarball. Includes public/views because index.html references the webpack
|
||||
tar czf grafana_webpack-$VER.tar.gz grafana-$VER/public/build grafana-$VER/public/views
|
||||
|
||||
# source tarball (if needed)
|
||||
if [ ! -f grafana-$VER.tar.gz ]; then
|
||||
wget --quiet -O grafana-$VER.tar.gz https://github.com/grafana/grafana/archive/v$VER/grafana-$VER.tar.gz
|
||||
fi
|
||||
|
||||
# done
|
||||
echo Both grafana-$VER.tar.gz and grafana_webpack-$VER.tar.gz
|
||||
echo should now be copied to your \$HOME/rpmbuild/SOURCES
|
||||
|
||||
exit 0
|
2
sources
Normal file
2
sources
Normal file
@ -0,0 +1,2 @@
|
||||
SHA512 (grafana-6.1.4.tar.gz) = 75ed40232182d33484ecaeb58539d465bfcbd0ba7d03901925e8256a40fb6c87292ec0b324e97dce89ddb3b87505090f730eb12f77d987de5fe6e3b31ffb1782
|
||||
SHA512 (grafana_webpack-6.1.4.tar.gz) = a8895d14213cbe43adb3585969a6b23c1016d39bdcee9b48bd544f31f84a51bb4eb9b942ef68450910bd73ad9c03f89870782a230bba098197e7ce32000b8058
|
Loading…
Reference in New Issue
Block a user