Add writing config to file, modal for validation
This commit is contained in:
parent
c7513199df
commit
8aa18a29a8
4 changed files with 43 additions and 44 deletions
|
@ -1,6 +1,8 @@
|
||||||
import logging
|
import logging
|
||||||
from flask import abort, request
|
|
||||||
|
|
||||||
|
from flask import request, make_response
|
||||||
|
|
||||||
|
from config_app.c_app import config_provider
|
||||||
from config_app.config_endpoints.api import resource, ApiResource, nickname, validate_json_request
|
from config_app.config_endpoints.api import resource, ApiResource, nickname, validate_json_request
|
||||||
|
|
||||||
logger = logging.getLogger(__name__)
|
logger = logging.getLogger(__name__)
|
||||||
|
@ -8,40 +10,16 @@ logger = logging.getLogger(__name__)
|
||||||
@resource('/v1/configapp/tarconfig')
|
@resource('/v1/configapp/tarconfig')
|
||||||
class TarConfigLoader(ApiResource):
|
class TarConfigLoader(ApiResource):
|
||||||
""" Resource for validating a block of configuration against an external service. """
|
""" Resource for validating a block of configuration against an external service. """
|
||||||
schemas = {
|
|
||||||
'ValidateUploadConfig': {
|
|
||||||
'type': 'object',
|
|
||||||
'description': '',
|
|
||||||
'required': [
|
|
||||||
'config'
|
|
||||||
],
|
|
||||||
'properties': {
|
|
||||||
'config': {
|
|
||||||
'type': 'object'
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
}
|
|
||||||
|
|
||||||
@nickname('uploadTarballConfig')
|
@nickname('uploadTarballConfig')
|
||||||
# @validate_json_request('ValidateUploadConfig')
|
|
||||||
def post(self):
|
def post(self):
|
||||||
""" Extracts and validates all configuration from """
|
""" Loads tarball config into the config provider """
|
||||||
logger.debug('hello world!')
|
input_stream = request.stream
|
||||||
logger.debug(request)
|
|
||||||
logger.debug('hello world!')
|
|
||||||
logger.debug(request.files)
|
|
||||||
# logger.debug('hello world!')
|
|
||||||
# logger.debug(request.body)
|
|
||||||
# logger.debug(request.data)
|
|
||||||
logger.debug('hello world!')
|
|
||||||
logger.debug(request.files)
|
|
||||||
logger.debug('hello world!')
|
|
||||||
logger.debug(request.mimetype)
|
|
||||||
logger.debug('hello world!')
|
|
||||||
logger.debug(request.get_data())
|
|
||||||
logger.debug('hello world!')
|
|
||||||
logger.debug(request.get_json())
|
|
||||||
logger.debug('hello world!')
|
|
||||||
|
|
||||||
abort(418)
|
# since we're working with a tar file, shouldn't be larger than ~20KB, so just read the whole thing into mem
|
||||||
|
buf = input_stream.read(-1)
|
||||||
|
|
||||||
|
# TODO(sam): refactor config provider to accept a stream write to avoid loading into memory
|
||||||
|
config_provider.write_volume_file('test_tar.tar.gz', buf)
|
||||||
|
|
||||||
|
return make_response('OK')
|
||||||
|
|
|
@ -1,10 +1,7 @@
|
||||||
import { Input, Component, Inject } from 'ng-metadata/core';
|
import { Component, Inject } from 'ng-metadata/core';
|
||||||
const templateUrl = require('./load-config.html');
|
const templateUrl = require('./load-config.html');
|
||||||
const styleUrl = require('./load-config.css');
|
const styleUrl = require('./load-config.css');
|
||||||
|
|
||||||
declare let bootbox: any;
|
|
||||||
declare let window: any;
|
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'load-config',
|
selector: 'load-config',
|
||||||
templateUrl,
|
templateUrl,
|
||||||
|
@ -13,6 +10,7 @@ declare let window: any;
|
||||||
export class LoadConfigComponent {
|
export class LoadConfigComponent {
|
||||||
private isReady: boolean = false;
|
private isReady: boolean = false;
|
||||||
private uploadFunc: Function;
|
private uploadFunc: Function;
|
||||||
|
private state: 'load' | 'validate' = 'load';
|
||||||
|
|
||||||
private constructor(@Inject('ApiService') private apiService: any) {
|
private constructor(@Inject('ApiService') private apiService: any) {
|
||||||
}
|
}
|
||||||
|
@ -27,9 +25,14 @@ export class LoadConfigComponent {
|
||||||
}
|
}
|
||||||
|
|
||||||
private uploadTarball() {
|
private uploadTarball() {
|
||||||
this.uploadFunc(resp => {
|
this.uploadFunc(success => {
|
||||||
console.log('hi')
|
if (success) {
|
||||||
console.log(resp)
|
this.state = 'validate';
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
this.apiService.errorDisplay('Could not upload configuration. Please reload the page and try again.\n' +
|
||||||
|
'If this problem persists, please contact support')();
|
||||||
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -42,6 +45,4 @@ export class LoadConfigComponent {
|
||||||
private filesValidated(files, uploadFiles) {
|
private filesValidated(files, uploadFiles) {
|
||||||
this.uploadFunc = uploadFiles;
|
this.uploadFunc = uploadFiles;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
|
@ -1,4 +1,4 @@
|
||||||
<div>
|
<div ng-if="$ctrl.state === 'load'">
|
||||||
<div class="co-dialog modal fade initial-setup-modal in" id="setupModal" style="display: block;">
|
<div class="co-dialog modal fade initial-setup-modal in" id="setupModal" style="display: block;">
|
||||||
<div class="modal-backdrop fade in" style="height: 1000px;"></div>
|
<div class="modal-backdrop fade in" style="height: 1000px;"></div>
|
||||||
<div class="modal-dialog fade in">
|
<div class="modal-dialog fade in">
|
||||||
|
@ -26,3 +26,22 @@
|
||||||
</div><!-- /.modal-dialog -->
|
</div><!-- /.modal-dialog -->
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<div ng-if="$ctrl.state === 'validate'">
|
||||||
|
<div class="co-dialog modal fade initial-setup-modal in" id="validateModal" style="display: block;">
|
||||||
|
<div class="modal-backdrop fade in" style="height: 1000px;"></div>
|
||||||
|
<div class="modal-dialog fade in">
|
||||||
|
<div class="modal-content">
|
||||||
|
<!-- Header -->
|
||||||
|
<div class="modal-header">
|
||||||
|
<h4 class="modal-title"><span>Validate Config</span></h4>
|
||||||
|
</div>
|
||||||
|
<!-- Body -->
|
||||||
|
<div class="modal-body">
|
||||||
|
<span>Validating Config...</span>
|
||||||
|
spinner here...
|
||||||
|
</div>
|
||||||
|
</div><!-- /.modal-content -->
|
||||||
|
</div><!-- /.modal-dialog -->
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
|
@ -19,6 +19,7 @@
|
||||||
<tr>
|
<tr>
|
||||||
<td>Upload certificates:</td>
|
<td>Upload certificates:</td>
|
||||||
<td>
|
<td>
|
||||||
|
<!--TODO(sam): fix this upload box to pass in the url it needs for custom certs (file-upload-box hardcodes right now)-->
|
||||||
<div class="file-upload-box"
|
<div class="file-upload-box"
|
||||||
select-message="Select custom certificate to add to configuration. Must be in PEM format and end extension '.crt'"
|
select-message="Select custom certificate to add to configuration. Must be in PEM format and end extension '.crt'"
|
||||||
files-selected="handleCertsSelected(files, callback)"
|
files-selected="handleCertsSelected(files, callback)"
|
||||||
|
|
Reference in a new issue