mirror of https://github.com/portainer/portainer
Fix csrf, send tokens back in header, pass token instead of cookie back to server.
parent
7267516363
commit
0244bc7317
12
app/app.js
12
app/app.js
|
@ -26,7 +26,7 @@ angular.module('dockerui', [
|
||||||
.config(['$routeProvider', '$httpProvider', function ($routeProvider, $httpProvider) {
|
.config(['$routeProvider', '$httpProvider', function ($routeProvider, $httpProvider) {
|
||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
$httpProvider.defaults.xsrfCookieName = '_gorilla_csrf';
|
$httpProvider.defaults.xsrfCookieName = 'csrfToken';
|
||||||
$httpProvider.defaults.xsrfHeaderName = 'X-CSRF-Token';
|
$httpProvider.defaults.xsrfHeaderName = 'X-CSRF-Token';
|
||||||
|
|
||||||
$routeProvider.when('/', {
|
$routeProvider.when('/', {
|
||||||
|
@ -83,13 +83,11 @@ angular.module('dockerui', [
|
||||||
time: 10000
|
time: 10000
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
console.log('response', response);
|
var csrfToken = response.headers('X-Csrf-Token');
|
||||||
|
if (csrfToken) {
|
||||||
|
document.cookie = 'csrfToken=' + csrfToken;
|
||||||
|
}
|
||||||
return response;
|
return response;
|
||||||
},
|
|
||||||
request: function(config) {
|
|
||||||
console.log(document.cookie);
|
|
||||||
console.log('request', config);
|
|
||||||
return config;
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
});
|
});
|
||||||
|
|
15
dockerui.go
15
dockerui.go
|
@ -93,22 +93,13 @@ func createHandler(dir string, e string) http.Handler {
|
||||||
|
|
||||||
mux.Handle("/dockerapi/", http.StripPrefix("/dockerapi", h))
|
mux.Handle("/dockerapi/", http.StripPrefix("/dockerapi", h))
|
||||||
mux.Handle("/", fileHandler)
|
mux.Handle("/", fileHandler)
|
||||||
return logWrapper(CSRF(mux))
|
return CSRF(csrfWrapper(mux))
|
||||||
}
|
}
|
||||||
|
|
||||||
func logWrapper(h http.Handler) http.Handler {
|
func csrfWrapper(h http.Handler) http.Handler {
|
||||||
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
||||||
log.Println("Request starting: " + r.URL.Path)
|
w.Header().Set("X-CSRF-Token", csrf.Token(r))
|
||||||
c, err := r.Cookie ("_gorilla_csrf")
|
|
||||||
if err != nil {
|
|
||||||
log.Println("Unable to find session cookie _gorilla_csrf")
|
|
||||||
h.ServeHTTP(w, r)
|
h.ServeHTTP(w, r)
|
||||||
} else {
|
|
||||||
log.Println("Cookie:" + c.Value)
|
|
||||||
log.Println("Header:" + r.Header.Get("X-CSRF-Token"))
|
|
||||||
h.ServeHTTP(w, r)
|
|
||||||
log.Println("Request ending")
|
|
||||||
}
|
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue