mirror of
https://github.com/grafana/grafana.git
synced 2025-02-25 18:55:37 -06:00
Merge branch 'master' into postgres-query-builder
This commit is contained in:
commit
5b3b0295e8
@ -147,6 +147,12 @@ jobs:
|
|||||||
- run:
|
- run:
|
||||||
name: sign packages
|
name: sign packages
|
||||||
command: './scripts/build/sign_packages.sh'
|
command: './scripts/build/sign_packages.sh'
|
||||||
|
- run:
|
||||||
|
name: verify signed packages
|
||||||
|
command: |
|
||||||
|
mkdir -p ~/.rpmdb/pubkeys
|
||||||
|
curl -s https://grafanarel.s3.amazonaws.com/RPM-GPG-KEY-grafana > ~/.rpmdb/pubkeys/grafana.key
|
||||||
|
./scripts/build/verify_signed_packages.sh dist/*.rpm
|
||||||
- run:
|
- run:
|
||||||
name: sha-sum packages
|
name: sha-sum packages
|
||||||
command: 'go run build.go sha-dist'
|
command: 'go run build.go sha-dist'
|
||||||
|
6
.github/CONTRIBUTING.md
vendored
6
.github/CONTRIBUTING.md
vendored
@ -2,12 +2,12 @@ Follow the setup guide in README.md
|
|||||||
|
|
||||||
### Rebuild frontend assets on source change
|
### Rebuild frontend assets on source change
|
||||||
```
|
```
|
||||||
grunt && grunt watch
|
yarn watch
|
||||||
```
|
```
|
||||||
|
|
||||||
### Rerun tests on source change
|
### Rerun tests on source change
|
||||||
```
|
```
|
||||||
grunt karma:dev
|
yarn jest
|
||||||
```
|
```
|
||||||
|
|
||||||
### Run tests for backend assets before commit
|
### Run tests for backend assets before commit
|
||||||
@ -17,6 +17,6 @@ test -z "$(gofmt -s -l . | grep -v -E 'vendor/(github.com|golang.org|gopkg.in)'
|
|||||||
|
|
||||||
### Run tests for frontend assets before commit
|
### Run tests for frontend assets before commit
|
||||||
```
|
```
|
||||||
npm test
|
yarn test
|
||||||
go test -v ./pkg/...
|
go test -v ./pkg/...
|
||||||
```
|
```
|
||||||
|
@ -61,6 +61,10 @@ These are new features that's still being worked on and are in an experimental p
|
|||||||
|
|
||||||
* **Dashboard**: Auto fit dashboard panels to optimize space used for current TV / Monitor [#12768](https://github.com/grafana/grafana/issues/12768)
|
* **Dashboard**: Auto fit dashboard panels to optimize space used for current TV / Monitor [#12768](https://github.com/grafana/grafana/issues/12768)
|
||||||
|
|
||||||
|
### Tech
|
||||||
|
|
||||||
|
* **Frontend**: Convert all Frontend Karma tests to Jest tests [#12224](https://github.com/grafana/grafana/issues/12224)
|
||||||
|
|
||||||
# 5.2.2 (2018-07-25)
|
# 5.2.2 (2018-07-25)
|
||||||
|
|
||||||
### Minor
|
### Minor
|
||||||
|
21
README.md
21
README.md
@ -43,7 +43,7 @@ To build the assets, rebuild on file change, and serve them by Grafana's webserv
|
|||||||
```bash
|
```bash
|
||||||
npm install -g yarn
|
npm install -g yarn
|
||||||
yarn install --pure-lockfile
|
yarn install --pure-lockfile
|
||||||
yarn run watch
|
yarn watch
|
||||||
```
|
```
|
||||||
|
|
||||||
Build the assets, rebuild on file change with Hot Module Replacement (HMR), and serve them by webpack-dev-server (http://localhost:3333):
|
Build the assets, rebuild on file change with Hot Module Replacement (HMR), and serve them by webpack-dev-server (http://localhost:3333):
|
||||||
@ -56,12 +56,7 @@ Note: HMR for Angular is not supported. If you edit files in the Angular part of
|
|||||||
|
|
||||||
Run tests
|
Run tests
|
||||||
```bash
|
```bash
|
||||||
yarn run jest
|
yarn jest
|
||||||
```
|
|
||||||
|
|
||||||
Run karma tests
|
|
||||||
```bash
|
|
||||||
yarn run karma
|
|
||||||
```
|
```
|
||||||
|
|
||||||
### Recompile backend on source change
|
### Recompile backend on source change
|
||||||
@ -98,17 +93,13 @@ In your custom.ini uncomment (remove the leading `;`) sign. And set `app_mode =
|
|||||||
#### Frontend
|
#### Frontend
|
||||||
Execute all frontend tests
|
Execute all frontend tests
|
||||||
```bash
|
```bash
|
||||||
yarn run test
|
yarn test
|
||||||
```
|
```
|
||||||
|
|
||||||
Writing & watching frontend tests (we have two test runners)
|
Writing & watching frontend tests
|
||||||
|
|
||||||
- jest for all new tests that do not require browser context (React+more)
|
- Start watcher: `yarn jest`
|
||||||
- Start watcher: `yarn run jest`
|
- Jest will run all test files that end with the name ".test.ts"
|
||||||
- Jest will run all test files that end with the name ".jest.ts"
|
|
||||||
- karma + mocha is used for testing angularjs components. We do want to migrate these test to jest over time (if possible).
|
|
||||||
- Start watcher: `yarn run karma`
|
|
||||||
- Karma+Mocha runs all files that end with the name "_specs.ts".
|
|
||||||
|
|
||||||
#### Backend
|
#### Backend
|
||||||
```bash
|
```bash
|
||||||
|
@ -270,6 +270,18 @@ api_url = https://api.github.com/user
|
|||||||
team_ids =
|
team_ids =
|
||||||
allowed_organizations =
|
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 #########################
|
#################################### Google Auth #########################
|
||||||
[auth.google]
|
[auth.google]
|
||||||
enabled = false
|
enabled = false
|
||||||
|
@ -84,7 +84,7 @@ command line in the init.d script or the systemd service file.
|
|||||||
|
|
||||||
### temp_data_lifetime
|
### temp_data_lifetime
|
||||||
|
|
||||||
How long temporary images in `data` directory should be kept. Defaults to: `24h`. Supported modifiers: `h` (hours),
|
How long temporary images in `data` directory should be kept. Defaults to: `24h`. Supported modifiers: `h` (hours),
|
||||||
`m` (minutes), for example: `168h`, `30m`, `10h30m`. Use `0` to never clean up temporary files.
|
`m` (minutes), for example: `168h`, `30m`, `10h30m`. Use `0` to never clean up temporary files.
|
||||||
|
|
||||||
### logs
|
### logs
|
||||||
@ -430,6 +430,108 @@ allowed_organizations = github google
|
|||||||
|
|
||||||
<hr>
|
<hr>
|
||||||
|
|
||||||
|
## [auth.gitlab]
|
||||||
|
|
||||||
|
> Only available in Grafana v5.3+.
|
||||||
|
|
||||||
|
You need to [create a GitLab OAuth
|
||||||
|
application](https://docs.gitlab.com/ce/integration/oauth_provider.html).
|
||||||
|
Choose a descriptive *Name*, and use the following *Redirect URI*:
|
||||||
|
|
||||||
|
```
|
||||||
|
https://grafana.example.com/login/gitlab
|
||||||
|
```
|
||||||
|
|
||||||
|
where `https://grafana.example.com` is the URL you use to connect to Grafana.
|
||||||
|
Adjust it as needed if you don't use HTTPS or if you use a different port; for
|
||||||
|
instance, if you access Grafana at `http://203.0.113.31:3000`, you should use
|
||||||
|
|
||||||
|
```
|
||||||
|
http://203.0.113.31:3000/login/gitlab
|
||||||
|
```
|
||||||
|
|
||||||
|
Finally, select *api* as the *Scope* and submit the form. Note that if you're
|
||||||
|
not going to use GitLab groups for authorization (i.e. not setting
|
||||||
|
`allowed_groups`, see below), you can select *read_user* instead of *api* as
|
||||||
|
the *Scope*, thus giving a more restricted access to your GitLab API.
|
||||||
|
|
||||||
|
You'll get an *Application Id* and a *Secret* in return; we'll call them
|
||||||
|
`GITLAB_APPLICATION_ID` and `GITLAB_SECRET` respectively for the rest of this
|
||||||
|
section.
|
||||||
|
|
||||||
|
Add the following to your Grafana configuration file to enable GitLab
|
||||||
|
authentication:
|
||||||
|
|
||||||
|
```ini
|
||||||
|
[auth.gitlab]
|
||||||
|
enabled = false
|
||||||
|
allow_sign_up = false
|
||||||
|
client_id = GITLAB_APPLICATION_ID
|
||||||
|
client_secret = GITLAB_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 =
|
||||||
|
```
|
||||||
|
|
||||||
|
Restart the Grafana backend for your changes to take effect.
|
||||||
|
|
||||||
|
If you use your own instance of GitLab instead of `gitlab.com`, adjust
|
||||||
|
`auth_url`, `token_url` and `api_url` accordingly by replacing the `gitlab.com`
|
||||||
|
hostname with your own.
|
||||||
|
|
||||||
|
With `allow_sign_up` set to `false`, only existing users will be able to login
|
||||||
|
using their GitLab account, but with `allow_sign_up` set to `true`, *any* user
|
||||||
|
who can authenticate on GitLab will be able to login on your Grafana instance;
|
||||||
|
if you use the public `gitlab.com`, it means anyone in the world would be able
|
||||||
|
to login on your Grafana instance.
|
||||||
|
|
||||||
|
You can can however limit access to only members of a given group or list of
|
||||||
|
groups by setting the `allowed_groups` option.
|
||||||
|
|
||||||
|
### allowed_groups
|
||||||
|
|
||||||
|
To limit access to authenticated users that are members of one or more [GitLab
|
||||||
|
groups](https://docs.gitlab.com/ce/user/group/index.html), set `allowed_groups`
|
||||||
|
to a comma- or space-separated list of groups. For instance, if you want to
|
||||||
|
only give access to members of the `example` group, set
|
||||||
|
|
||||||
|
|
||||||
|
```ini
|
||||||
|
allowed_groups = example
|
||||||
|
```
|
||||||
|
|
||||||
|
If you want to also give access to members of the subgroup `bar`, which is in
|
||||||
|
the group `foo`, set
|
||||||
|
|
||||||
|
```ini
|
||||||
|
allowed_groups = example, foo/bar
|
||||||
|
```
|
||||||
|
|
||||||
|
Note that in GitLab, the group or subgroup name doesn't always match its
|
||||||
|
display name, especially if the display name contains spaces or special
|
||||||
|
characters. Make sure you always use the group or subgroup name as it appears
|
||||||
|
in the URL of the group or subgroup.
|
||||||
|
|
||||||
|
Here's a complete example with `alloed_sign_up` enabled, and access limited to
|
||||||
|
the `example` and `foo/bar` groups:
|
||||||
|
|
||||||
|
```ini
|
||||||
|
[auth.gitlab]
|
||||||
|
enabled = false
|
||||||
|
allow_sign_up = true
|
||||||
|
client_id = GITLAB_APPLICATION_ID
|
||||||
|
client_secret = GITLAB_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 = example, foo/bar
|
||||||
|
```
|
||||||
|
|
||||||
|
<hr>
|
||||||
|
|
||||||
## [auth.google]
|
## [auth.google]
|
||||||
|
|
||||||
First, you need to create a Google OAuth Client:
|
First, you need to create a Google OAuth Client:
|
||||||
|
@ -57,7 +57,7 @@ For this you need nodejs (v.6+).
|
|||||||
```bash
|
```bash
|
||||||
npm install -g yarn
|
npm install -g yarn
|
||||||
yarn install --pure-lockfile
|
yarn install --pure-lockfile
|
||||||
npm run watch
|
yarn watch
|
||||||
```
|
```
|
||||||
|
|
||||||
## Running Grafana Locally
|
## Running Grafana Locally
|
||||||
@ -83,21 +83,18 @@ go get github.com/Unknwon/bra
|
|||||||
bra run
|
bra run
|
||||||
```
|
```
|
||||||
|
|
||||||
You'll also need to run `npm run watch` to watch for changes to the front-end (typescript, html, sass)
|
You'll also need to run `yarn watch` to watch for changes to the front-end (typescript, html, sass)
|
||||||
|
|
||||||
### Running tests
|
### Running tests
|
||||||
|
|
||||||
- You can run backend Golang tests using "go test ./pkg/...".
|
- You can run backend Golang tests using `go test ./pkg/...`.
|
||||||
- Execute all frontend tests with "npm run test"
|
- Execute all frontend tests with `yarn test`
|
||||||
|
|
||||||
Writing & watching frontend tests (we have two test runners)
|
Writing & watching frontend tests
|
||||||
|
|
||||||
|
- Start watcher: `yarn jest`
|
||||||
|
- Jest will run all test files that end with the name ".test.ts"
|
||||||
|
|
||||||
- jest for all new tests that do not require browser context (React+more)
|
|
||||||
- Start watcher: `npm run jest`
|
|
||||||
- Jest will run all test files that end with the name ".jest.ts"
|
|
||||||
- karma + mocha is used for testing angularjs components. We do want to migrate these test to jest over time (if possible).
|
|
||||||
- Start watcher: `npm run karma`
|
|
||||||
- Karma+Mocha runs all files that end with the name "_specs.ts".
|
|
||||||
|
|
||||||
## Creating optimized release packages
|
## Creating optimized release packages
|
||||||
|
|
||||||
|
@ -13,7 +13,7 @@ module.exports = {
|
|||||||
"roots": [
|
"roots": [
|
||||||
"<rootDir>/public"
|
"<rootDir>/public"
|
||||||
],
|
],
|
||||||
"testRegex": "(\\.|/)(jest)\\.(jsx?|tsx?)$",
|
"testRegex": "(\\.|/)(test)\\.(jsx?|tsx?)$",
|
||||||
"moduleFileExtensions": [
|
"moduleFileExtensions": [
|
||||||
"ts",
|
"ts",
|
||||||
"tsx",
|
"tsx",
|
||||||
|
@ -1,40 +0,0 @@
|
|||||||
var webpack = require('webpack');
|
|
||||||
var path = require('path');
|
|
||||||
var webpackTestConfig = require('./scripts/webpack/webpack.test.js');
|
|
||||||
|
|
||||||
module.exports = function(config) {
|
|
||||||
|
|
||||||
'use strict';
|
|
||||||
|
|
||||||
config.set({
|
|
||||||
frameworks: ['mocha', 'expect', 'sinon'],
|
|
||||||
|
|
||||||
// list of files / patterns to load in the browser
|
|
||||||
files: [
|
|
||||||
{ pattern: 'public/test/index.ts', watched: false }
|
|
||||||
],
|
|
||||||
|
|
||||||
preprocessors: {
|
|
||||||
'public/test/index.ts': ['webpack', 'sourcemap'],
|
|
||||||
},
|
|
||||||
|
|
||||||
webpack: webpackTestConfig,
|
|
||||||
webpackMiddleware: {
|
|
||||||
stats: 'minimal',
|
|
||||||
},
|
|
||||||
|
|
||||||
// list of files to exclude
|
|
||||||
exclude: [],
|
|
||||||
reporters: ['dots'],
|
|
||||||
port: 9876,
|
|
||||||
colors: true,
|
|
||||||
logLevel: config.LOG_INFO,
|
|
||||||
autoWatch: true,
|
|
||||||
browsers: ['PhantomJS'],
|
|
||||||
captureTimeout: 20000,
|
|
||||||
singleRun: true,
|
|
||||||
// autoWatchBatchDelay: 1000,
|
|
||||||
// browserNoActivityTimeout: 60000,
|
|
||||||
});
|
|
||||||
|
|
||||||
};
|
|
10
package.json
10
package.json
@ -46,7 +46,6 @@
|
|||||||
"grunt-contrib-copy": "~1.0.0",
|
"grunt-contrib-copy": "~1.0.0",
|
||||||
"grunt-contrib-cssmin": "~1.0.2",
|
"grunt-contrib-cssmin": "~1.0.2",
|
||||||
"grunt-exec": "^1.0.1",
|
"grunt-exec": "^1.0.1",
|
||||||
"grunt-karma": "~2.0.0",
|
|
||||||
"grunt-notify": "^0.4.5",
|
"grunt-notify": "^0.4.5",
|
||||||
"grunt-postcss": "^0.8.0",
|
"grunt-postcss": "^0.8.0",
|
||||||
"grunt-sass": "^2.0.0",
|
"grunt-sass": "^2.0.0",
|
||||||
@ -58,14 +57,6 @@
|
|||||||
"html-webpack-plugin": "^3.2.0",
|
"html-webpack-plugin": "^3.2.0",
|
||||||
"husky": "^0.14.3",
|
"husky": "^0.14.3",
|
||||||
"jest": "^22.0.4",
|
"jest": "^22.0.4",
|
||||||
"karma": "1.7.0",
|
|
||||||
"karma-chrome-launcher": "~2.2.0",
|
|
||||||
"karma-expect": "~1.1.3",
|
|
||||||
"karma-mocha": "~1.3.0",
|
|
||||||
"karma-phantomjs-launcher": "1.0.4",
|
|
||||||
"karma-sinon": "^1.0.5",
|
|
||||||
"karma-sourcemap-loader": "^0.3.7",
|
|
||||||
"karma-webpack": "^3.0.0",
|
|
||||||
"lint-staged": "^6.0.0",
|
"lint-staged": "^6.0.0",
|
||||||
"load-grunt-tasks": "3.5.2",
|
"load-grunt-tasks": "3.5.2",
|
||||||
"mini-css-extract-plugin": "^0.4.0",
|
"mini-css-extract-plugin": "^0.4.0",
|
||||||
@ -112,7 +103,6 @@
|
|||||||
"test": "grunt test",
|
"test": "grunt test",
|
||||||
"test:coverage": "grunt test --coverage=true",
|
"test:coverage": "grunt test --coverage=true",
|
||||||
"lint": "tslint -c tslint.json --project tsconfig.json --type-check",
|
"lint": "tslint -c tslint.json --project tsconfig.json --type-check",
|
||||||
"karma": "grunt karma:dev",
|
|
||||||
"jest": "jest --notify --watch",
|
"jest": "jest --notify --watch",
|
||||||
"api-tests": "jest --notify --watch --config=tests/api/jest.js",
|
"api-tests": "jest --notify --watch --config=tests/api/jest.js",
|
||||||
"precommit": "lint-staged && grunt precommit"
|
"precommit": "lint-staged && grunt precommit"
|
||||||
|
@ -8,4 +8,5 @@ const (
|
|||||||
TWITTER
|
TWITTER
|
||||||
GENERIC
|
GENERIC
|
||||||
GRAFANA_COM
|
GRAFANA_COM
|
||||||
|
GITLAB
|
||||||
)
|
)
|
||||||
|
132
pkg/social/gitlab_oauth.go
Normal file
132
pkg/social/gitlab_oauth.go
Normal file
@ -0,0 +1,132 @@
|
|||||||
|
package social
|
||||||
|
|
||||||
|
import (
|
||||||
|
"encoding/json"
|
||||||
|
"fmt"
|
||||||
|
"net/http"
|
||||||
|
"regexp"
|
||||||
|
|
||||||
|
"github.com/grafana/grafana/pkg/models"
|
||||||
|
|
||||||
|
"golang.org/x/oauth2"
|
||||||
|
)
|
||||||
|
|
||||||
|
type SocialGitlab struct {
|
||||||
|
*SocialBase
|
||||||
|
allowedDomains []string
|
||||||
|
allowedGroups []string
|
||||||
|
apiUrl string
|
||||||
|
allowSignup bool
|
||||||
|
}
|
||||||
|
|
||||||
|
var (
|
||||||
|
ErrMissingGroupMembership = &Error{"User not a member of one of the required groups"}
|
||||||
|
)
|
||||||
|
|
||||||
|
func (s *SocialGitlab) Type() int {
|
||||||
|
return int(models.GITLAB)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (s *SocialGitlab) IsEmailAllowed(email string) bool {
|
||||||
|
return isEmailAllowed(email, s.allowedDomains)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (s *SocialGitlab) IsSignupAllowed() bool {
|
||||||
|
return s.allowSignup
|
||||||
|
}
|
||||||
|
|
||||||
|
func (s *SocialGitlab) IsGroupMember(client *http.Client) bool {
|
||||||
|
if len(s.allowedGroups) == 0 {
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
|
||||||
|
for groups, url := s.GetGroups(client, s.apiUrl+"/groups"); groups != nil; groups, url = s.GetGroups(client, url) {
|
||||||
|
for _, allowedGroup := range s.allowedGroups {
|
||||||
|
for _, group := range groups {
|
||||||
|
if group == allowedGroup {
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
func (s *SocialGitlab) GetGroups(client *http.Client, url string) ([]string, string) {
|
||||||
|
type Group struct {
|
||||||
|
FullPath string `json:"full_path"`
|
||||||
|
}
|
||||||
|
|
||||||
|
var (
|
||||||
|
groups []Group
|
||||||
|
next string
|
||||||
|
)
|
||||||
|
|
||||||
|
if url == "" {
|
||||||
|
return nil, next
|
||||||
|
}
|
||||||
|
|
||||||
|
response, err := HttpGet(client, url)
|
||||||
|
if err != nil {
|
||||||
|
s.log.Error("Error getting groups from GitLab API", "err", err)
|
||||||
|
return nil, next
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := json.Unmarshal(response.Body, &groups); err != nil {
|
||||||
|
s.log.Error("Error parsing JSON from GitLab API", "err", err)
|
||||||
|
return nil, next
|
||||||
|
}
|
||||||
|
|
||||||
|
fullPaths := make([]string, len(groups))
|
||||||
|
for i, group := range groups {
|
||||||
|
fullPaths[i] = group.FullPath
|
||||||
|
}
|
||||||
|
|
||||||
|
if link, ok := response.Headers["Link"]; ok {
|
||||||
|
pattern := regexp.MustCompile(`<([^>]+)>; rel="next"`)
|
||||||
|
if matches := pattern.FindStringSubmatch(link[0]); matches != nil {
|
||||||
|
next = matches[1]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return fullPaths, next
|
||||||
|
}
|
||||||
|
|
||||||
|
func (s *SocialGitlab) UserInfo(client *http.Client, token *oauth2.Token) (*BasicUserInfo, error) {
|
||||||
|
|
||||||
|
var data struct {
|
||||||
|
Id int
|
||||||
|
Username string
|
||||||
|
Email string
|
||||||
|
Name string
|
||||||
|
State string
|
||||||
|
}
|
||||||
|
|
||||||
|
response, err := HttpGet(client, s.apiUrl+"/user")
|
||||||
|
if err != nil {
|
||||||
|
return nil, fmt.Errorf("Error getting user info: %s", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
err = json.Unmarshal(response.Body, &data)
|
||||||
|
if err != nil {
|
||||||
|
return nil, fmt.Errorf("Error getting user info: %s", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
if data.State != "active" {
|
||||||
|
return nil, fmt.Errorf("User %s is inactive", data.Username)
|
||||||
|
}
|
||||||
|
|
||||||
|
userInfo := &BasicUserInfo{
|
||||||
|
Id: fmt.Sprintf("%d", data.Id),
|
||||||
|
Name: data.Name,
|
||||||
|
Login: data.Username,
|
||||||
|
Email: data.Email,
|
||||||
|
}
|
||||||
|
|
||||||
|
if !s.IsGroupMember(client) {
|
||||||
|
return nil, ErrMissingGroupMembership
|
||||||
|
}
|
||||||
|
|
||||||
|
return userInfo, nil
|
||||||
|
}
|
@ -55,7 +55,7 @@ func NewOAuthService() {
|
|||||||
setting.OAuthService = &setting.OAuther{}
|
setting.OAuthService = &setting.OAuther{}
|
||||||
setting.OAuthService.OAuthInfos = make(map[string]*setting.OAuthInfo)
|
setting.OAuthService.OAuthInfos = make(map[string]*setting.OAuthInfo)
|
||||||
|
|
||||||
allOauthes := []string{"github", "google", "generic_oauth", "grafananet", "grafana_com"}
|
allOauthes := []string{"github", "gitlab", "google", "generic_oauth", "grafananet", "grafana_com"}
|
||||||
|
|
||||||
for _, name := range allOauthes {
|
for _, name := range allOauthes {
|
||||||
sec := setting.Raw.Section("auth." + name)
|
sec := setting.Raw.Section("auth." + name)
|
||||||
@ -115,6 +115,20 @@ func NewOAuthService() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// GitLab.
|
||||||
|
if name == "gitlab" {
|
||||||
|
SocialMap["gitlab"] = &SocialGitlab{
|
||||||
|
SocialBase: &SocialBase{
|
||||||
|
Config: &config,
|
||||||
|
log: logger,
|
||||||
|
},
|
||||||
|
allowedDomains: info.AllowedDomains,
|
||||||
|
apiUrl: info.ApiUrl,
|
||||||
|
allowSignup: info.AllowSignup,
|
||||||
|
allowedGroups: util.SplitString(sec.Key("allowed_groups").String()),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Google.
|
// Google.
|
||||||
if name == "google" {
|
if name == "google" {
|
||||||
SocialMap["google"] = &SocialGoogle{
|
SocialMap["google"] = &SocialGoogle{
|
||||||
|
@ -51,6 +51,10 @@
|
|||||||
<i class="btn-service-icon fa fa-github"></i>
|
<i class="btn-service-icon fa fa-github"></i>
|
||||||
Sign in with GitHub
|
Sign in with GitHub
|
||||||
</a>
|
</a>
|
||||||
|
<a class="btn btn-medium btn-service btn-service--gitlab login-btn" href="login/gitlab" target="_self" ng-if="oauth.gitlab">
|
||||||
|
<i class="btn-service-icon fa fa-gitlab"></i>
|
||||||
|
Sign in with GitLab
|
||||||
|
</a>
|
||||||
<a class="btn btn-medium btn-inverse btn-service btn-service--grafanacom login-btn" href="login/grafana_com" target="_self"
|
<a class="btn btn-medium btn-inverse btn-service btn-service--grafanacom login-btn" href="login/grafana_com" target="_self"
|
||||||
ng-if="oauth.grafana_com">
|
ng-if="oauth.grafana_com">
|
||||||
<i class="btn-service-icon"></i>
|
<i class="btn-service-icon"></i>
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user