mirror of
https://github.com/zero-peak/ZeroOmega.git
synced 2025-01-22 15:08:12 -05:00
Add number conversion, validation and fallback for parsing conditions.
Fix #710.
This commit is contained in:
parent
eb3951512d
commit
4bdc62ddff
@ -524,7 +524,10 @@ module.exports = exports =
|
|||||||
fromStr: (str, condition) ->
|
fromStr: (str, condition) ->
|
||||||
[ip, prefixLength] = str.split('/')
|
[ip, prefixLength] = str.split('/')
|
||||||
condition.ip = ip
|
condition.ip = ip
|
||||||
condition.prefixLength = parseInt(prefixLength)
|
addr = @parseIp ip
|
||||||
|
condition.ip = '0.0.0.0' unless addr?
|
||||||
|
condition.prefixLength = parseInt(prefixLength, 10)
|
||||||
|
condition.prefixLength = 0 unless condition.prefixLength >= 0
|
||||||
condition
|
condition
|
||||||
|
|
||||||
'HostLevelsCondition':
|
'HostLevelsCondition':
|
||||||
@ -555,8 +558,10 @@ module.exports = exports =
|
|||||||
str: (condition) -> condition.minValue + '~' + condition.maxValue
|
str: (condition) -> condition.minValue + '~' + condition.maxValue
|
||||||
fromStr: (str, condition) ->
|
fromStr: (str, condition) ->
|
||||||
[minValue, maxValue] = str.split('~')
|
[minValue, maxValue] = str.split('~')
|
||||||
condition.minValue = minValue
|
condition.minValue = parseInt(minValue, 10)
|
||||||
condition.maxValue = maxValue
|
condition.maxValue = parseInt(maxValue, 10)
|
||||||
|
condition.minValue = 1 unless condition.minValue > 0
|
||||||
|
condition.maxValue = 1 unless condition.maxValue > 0
|
||||||
condition
|
condition
|
||||||
|
|
||||||
'WeekdayCondition':
|
'WeekdayCondition':
|
||||||
@ -580,8 +585,10 @@ module.exports = exports =
|
|||||||
str: (condition) -> condition.startDay + '~' + condition.endDay
|
str: (condition) -> condition.startDay + '~' + condition.endDay
|
||||||
fromStr: (str, condition) ->
|
fromStr: (str, condition) ->
|
||||||
[startDay, endDay] = str.split('~')
|
[startDay, endDay] = str.split('~')
|
||||||
condition.startDay = startDay
|
condition.startDay = parseInt(startDay, 10)
|
||||||
condition.endDay = endDay
|
condition.endDay = parseInt(endDay, 10)
|
||||||
|
condition.startDay = 0 unless 0 <= condition.startDay <= 6
|
||||||
|
condition.endDay = 0 unless 0 <= condition.endDay <= 6
|
||||||
condition
|
condition
|
||||||
'TimeCondition':
|
'TimeCondition':
|
||||||
abbrs: ['T', 'Time', 'Hour']
|
abbrs: ['T', 'Time', 'Hour']
|
||||||
@ -604,7 +611,9 @@ module.exports = exports =
|
|||||||
str: (condition) -> condition.startHour + '~' + condition.endHour
|
str: (condition) -> condition.startHour + '~' + condition.endHour
|
||||||
fromStr: (str, condition) ->
|
fromStr: (str, condition) ->
|
||||||
[startHour, endHour] = str.split('~')
|
[startHour, endHour] = str.split('~')
|
||||||
condition.startHour = startHour
|
condition.startHour = parseInt(startHour, 10)
|
||||||
condition.endHour = endHour
|
condition.endHour = parseInt(endHour, 10)
|
||||||
|
condition.startHour = 0 unless 0 <= condition.startHour < 24
|
||||||
|
condition.endHour = 0 unless 0 <= condition.endHour < 24
|
||||||
condition
|
condition
|
||||||
# coffeelint: enable=missing_fat_arrows
|
# coffeelint: enable=missing_fat_arrows
|
||||||
|
@ -383,7 +383,98 @@ describe 'Conditions', ->
|
|||||||
result = Conditions.str(condition)
|
result = Conditions.str(condition)
|
||||||
result.should.equal('Ip: 127.0.0.1/16')
|
result.should.equal('Ip: 127.0.0.1/16')
|
||||||
cond = Conditions.fromStr(result)
|
cond = Conditions.fromStr(result)
|
||||||
|
console.log typeof cond.prefixLength
|
||||||
cond.should.eql(condition)
|
cond.should.eql(condition)
|
||||||
|
it 'should provide sensible fallbacks for invalid IpCondition', ->
|
||||||
|
cond = Conditions.fromStr('Ip: foo/-233')
|
||||||
|
cond.should.eql(
|
||||||
|
conditionType: 'IpCondition'
|
||||||
|
ip: '0.0.0.0'
|
||||||
|
prefixLength: 0
|
||||||
|
)
|
||||||
|
|
||||||
|
cond = Conditions.fromStr('Ip: nonsense stuff')
|
||||||
|
cond.should.eql(
|
||||||
|
conditionType: 'IpCondition'
|
||||||
|
ip: '0.0.0.0'
|
||||||
|
prefixLength: 0
|
||||||
|
)
|
||||||
|
it 'should provide sensible fallbacks for invalid IpCondition', ->
|
||||||
|
cond = Conditions.fromStr('Ip: 0.0.0.0/-233')
|
||||||
|
cond.should.eql(
|
||||||
|
conditionType: 'IpCondition'
|
||||||
|
ip: '0.0.0.0'
|
||||||
|
prefixLength: 0
|
||||||
|
)
|
||||||
|
it 'should encode & decode HostLevelsCondition correctly', ->
|
||||||
|
condition =
|
||||||
|
conditionType: 'HostLevelsCondition'
|
||||||
|
minValue: 4
|
||||||
|
maxValue: 7
|
||||||
|
result = Conditions.str(condition)
|
||||||
|
result.should.equal('HostLevels: 4~7')
|
||||||
|
cond = Conditions.fromStr(result)
|
||||||
|
cond.should.eql(condition)
|
||||||
|
it 'should provide sensible fallbacks for HostLevels out of range', ->
|
||||||
|
cond = Conditions.fromStr('HostLevels: A~-1')
|
||||||
|
cond.should.eql(
|
||||||
|
conditionType: 'HostLevelsCondition'
|
||||||
|
minValue: 1
|
||||||
|
maxValue: 1
|
||||||
|
)
|
||||||
|
|
||||||
|
cond = Conditions.fromStr('HostLevels: nonsense')
|
||||||
|
cond.should.eql(
|
||||||
|
conditionType: 'HostLevelsCondition'
|
||||||
|
minValue: 1
|
||||||
|
maxValue: 1
|
||||||
|
)
|
||||||
|
it 'should encode & decode WeekdayCondition correctly', ->
|
||||||
|
condition =
|
||||||
|
conditionType: 'WeekdayCondition'
|
||||||
|
startDay: 3
|
||||||
|
endDay: 6
|
||||||
|
result = Conditions.str(condition)
|
||||||
|
result.should.equal('Weekday: 3~6')
|
||||||
|
cond = Conditions.fromStr(result)
|
||||||
|
cond.should.eql(condition)
|
||||||
|
it 'should provide sensible fallbacks for Weekday out of range', ->
|
||||||
|
cond = Conditions.fromStr('Weekday: -1~100')
|
||||||
|
cond.should.eql(
|
||||||
|
conditionType: 'WeekdayCondition'
|
||||||
|
startDay: 0
|
||||||
|
endDay: 0
|
||||||
|
)
|
||||||
|
|
||||||
|
cond = Conditions.fromStr('Weekday: nonsense')
|
||||||
|
cond.should.eql(
|
||||||
|
conditionType: 'WeekdayCondition'
|
||||||
|
startDay: 0
|
||||||
|
endDay: 0
|
||||||
|
)
|
||||||
|
it 'should encode & decode TimeCondition correctly', ->
|
||||||
|
condition =
|
||||||
|
conditionType: 'TimeCondition'
|
||||||
|
startHour: 7
|
||||||
|
endHour: 23
|
||||||
|
result = Conditions.str(condition)
|
||||||
|
result.should.equal('Hour: 7~23')
|
||||||
|
cond = Conditions.fromStr(result)
|
||||||
|
cond.should.eql(condition)
|
||||||
|
it 'should provide sensible fallbacks for Hour out of range', ->
|
||||||
|
cond = Conditions.fromStr('Hour: -1~100')
|
||||||
|
cond.should.eql(
|
||||||
|
conditionType: 'TimeCondition'
|
||||||
|
startHour: 0
|
||||||
|
endHour: 0
|
||||||
|
)
|
||||||
|
|
||||||
|
cond = Conditions.fromStr('Hour: nonsense')
|
||||||
|
cond.should.eql(
|
||||||
|
conditionType: 'TimeCondition'
|
||||||
|
startHour: 0
|
||||||
|
endHour: 0
|
||||||
|
)
|
||||||
it 'should parse conditions with extra spaces correctly', ->
|
it 'should parse conditions with extra spaces correctly', ->
|
||||||
Conditions.fromStr('url: *abcde* ').should.eql({
|
Conditions.fromStr('url: *abcde* ').should.eql({
|
||||||
conditionType: 'UrlWildcardCondition'
|
conditionType: 'UrlWildcardCondition'
|
||||||
|
Loading…
Reference in New Issue
Block a user