add save functionality to ssh-keys
This commit is contained in:
parent
87ddf9979a
commit
7293e06c0e
|
@ -1,4 +1,4 @@
|
||||||
`import Ember from 'ember'`
|
# `import Ember from 'ember'`
|
||||||
|
|
||||||
AddSshKeyComponent = Ember.Component.extend
|
AddSshKeyComponent = Ember.Component.extend
|
||||||
|
|
||||||
|
@ -7,52 +7,63 @@ AddSshKeyComponent = Ember.Component.extend
|
||||||
store: Ember.inject.service()
|
store: Ember.inject.service()
|
||||||
isSaving: false
|
isSaving: false
|
||||||
|
|
||||||
|
didInsertElement: () ->
|
||||||
|
id = @get('repo.id')
|
||||||
|
model = @get('store').recordForId('sshKey', id)
|
||||||
|
# TODO: this can be removed in favor of simply unloading record
|
||||||
|
# once https://github.com/emberjs/data/pull/2867
|
||||||
|
# and https://github.com/emberjs/data/pull/2870 are merged
|
||||||
|
if model
|
||||||
|
@get('store').dematerializeRecord(model)
|
||||||
|
typeMap = @get('store').typeMapFor('sshKey')
|
||||||
|
idToRecord = typeMap.idToRecord
|
||||||
|
delete idToRecord[id]
|
||||||
|
|
||||||
|
model = @get('store').createRecord('sshKey', id: id)
|
||||||
|
@set('model', model)
|
||||||
|
|
||||||
isValid: () ->
|
isValid: () ->
|
||||||
true
|
if Ember.isBlank(@get('value'))
|
||||||
|
this.set('valueError', 'Value can\'t be blank.')
|
||||||
|
false
|
||||||
|
else
|
||||||
|
true
|
||||||
|
|
||||||
reset: ->
|
reset: ->
|
||||||
@setProperties(description: null, value: null)
|
@setProperties(description: null, value: null)
|
||||||
|
|
||||||
|
valueChanged: (->
|
||||||
|
this.set('valueError', false)
|
||||||
|
).observes('value')
|
||||||
|
|
||||||
|
addErrorsFromResponse: (errArr) ->
|
||||||
|
error = errArr[0]
|
||||||
|
if error.code == 'not_a_private_key'
|
||||||
|
this.set('valueError', 'This key is not a private key.')
|
||||||
|
else if error.code == 'key_with_a_passphrase'
|
||||||
|
this.set('valueError', 'We can\'t use key with a passphrase.')
|
||||||
|
|
||||||
actions:
|
actions:
|
||||||
|
|
||||||
add: ->
|
|
||||||
# not sure how to integrate that with 'save' in the compotent
|
|
||||||
id = @get('repo.id')
|
|
||||||
model = @store.recordForId('sshKey', id)
|
|
||||||
# TODO: this can be removed in favor of simply unloading record
|
|
||||||
# once https://github.com/emberjs/data/pull/2867
|
|
||||||
# and https://github.com/emberjs/data/pull/2870 are merged
|
|
||||||
if model
|
|
||||||
@store.dematerializeRecord(model)
|
|
||||||
typeMap = @store.typeMapFor('sshKey')
|
|
||||||
idToRecord = typeMap.idToRecord
|
|
||||||
delete idToRecord[id]
|
|
||||||
|
|
||||||
model = @store.createRecord('sshKey', id: id)
|
|
||||||
@set('model', model)
|
|
||||||
@set('isEditing', true)
|
|
||||||
|
|
||||||
save: ->
|
save: ->
|
||||||
|
this.set('valueError', false)
|
||||||
return if @get('isSaving')
|
return if @get('isSaving')
|
||||||
@set('isSaving', true)
|
@set('isSaving', true)
|
||||||
|
|
||||||
if @isValid()
|
if @isValid()
|
||||||
|
|
||||||
ssh_key = @get('store').createRecord('ssh_key',
|
ssh_key = @get('model').setProperties(
|
||||||
description: @get('description')
|
description: @get('description')
|
||||||
value: @get('value')
|
value: @get('value')
|
||||||
fingerprint: 'I dont know?'
|
|
||||||
repo: @get('repo')
|
|
||||||
)
|
)
|
||||||
self = this
|
self = this
|
||||||
ssh_key.save().then =>
|
ssh_key.save().then =>
|
||||||
@set('isSaving', false)
|
@set('isSaving', false)
|
||||||
@reset()
|
@reset()
|
||||||
, =>
|
, (error) =>
|
||||||
@set('isSaving', false)
|
@set('isSaving', false)
|
||||||
|
if error.errors
|
||||||
|
@addErrorsFromResponse(error.errors)
|
||||||
|
|
||||||
# if error.errors
|
|
||||||
# @addErrorsFromResponse(error.errors)
|
|
||||||
else
|
else
|
||||||
@set('isSaving', false)
|
@set('isSaving', false)
|
||||||
|
|
||||||
|
|
|
@ -4,6 +4,9 @@
|
||||||
</div>
|
</div>
|
||||||
<div class="form-elem">
|
<div class="form-elem">
|
||||||
{{textarea value=value class="ssh-value" rows="10" placeholder="SSH Key"}}
|
{{textarea value=value class="ssh-value" rows="10" placeholder="SSH Key"}}
|
||||||
|
{{#if valueError}}
|
||||||
|
<p>{{valueError}}</p>
|
||||||
|
{{/if}}
|
||||||
</div>
|
</div>
|
||||||
<div class="form-elem">
|
<div class="form-elem">
|
||||||
{{#if isSaving}}
|
{{#if isSaving}}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user