safrano 0.6.6 → 0.6.7
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/lib/odata/collection_media.rb +1 -1
- data/lib/odata/function_import.rb +55 -13
- data/lib/odata/model_ext.rb +2 -1
- data/lib/odata/request/json.rb +7 -1
- data/lib/safrano/core.rb +4 -4
- data/lib/safrano/multipart.rb +6 -6
- data/lib/safrano/service.rb +9 -2
- data/lib/safrano/version.rb +1 -1
- metadata +6 -6
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: a93263d81a1f266029f7aac03d6b7226477f10d27d33255462e08133955ab759
|
4
|
+
data.tar.gz: 894a0bfab2eeeee57543bee7dd0c1ec93b5bc73e0afc6fe5f979c7b7e7067039
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: f0900d4f692a9139226d4fb84703f8a0c47a071b97b0a46c8455016f6a7d0d09caf2b12f32e616c9880a10a0b50e09917ca22afc4af7fc0f4cddac690193b25c
|
7
|
+
data.tar.gz: 30a623f667830e0dc4342bcf240843d313173ef12c0e877dc1814e779fc7f53459e7ec7e958aedd22b4387c9390907844a0c2c84a639db8d98dc62805203a671
|
@@ -21,7 +21,7 @@ module Safrano
|
|
21
21
|
class Static < Handler
|
22
22
|
def initialize(root: nil, mediaklass:)
|
23
23
|
@root = File.absolute_path(root || Dir.pwd)
|
24
|
-
@file_server = ::Rack::
|
24
|
+
@file_server = ::Rack::Files.new(@root)
|
25
25
|
@media_class = mediaklass
|
26
26
|
@media_dir_name = mediaklass.to_s
|
27
27
|
register
|
@@ -10,6 +10,21 @@ module Safrano
|
|
10
10
|
end
|
11
11
|
|
12
12
|
module FunctionImport
|
13
|
+
# error classes
|
14
|
+
class DefinitionMissing < StandardError
|
15
|
+
def initialize(fnam)
|
16
|
+
msg = "Function import #{fnam}: definition is missing. Provide definition either as a return code block or with .definition(lambda)"
|
17
|
+
super(msg)
|
18
|
+
end
|
19
|
+
end
|
20
|
+
class ProcRedefinition < StandardError
|
21
|
+
def initialize(fnam)
|
22
|
+
msg = "Function import #{fnam}: Block/lambda Redefinition . Provide definition either as a return code block or with .definition(lambda) but not both"
|
23
|
+
super(msg)
|
24
|
+
end
|
25
|
+
end
|
26
|
+
|
27
|
+
# Function import object
|
13
28
|
class Function
|
14
29
|
@allowed_transitions = [Safrano::TransitionEnd]
|
15
30
|
attr_reader :name
|
@@ -18,7 +33,6 @@ module Safrano
|
|
18
33
|
def initialize(name)
|
19
34
|
@name = name
|
20
35
|
@http_method = 'GET'
|
21
|
-
@use_contract = false
|
22
36
|
end
|
23
37
|
|
24
38
|
def allowed_transitions
|
@@ -53,13 +67,7 @@ module Safrano
|
|
53
67
|
end
|
54
68
|
alias auto_query_params auto_query_parameters
|
55
69
|
|
56
|
-
def use_contract
|
57
|
-
@use_contract = true
|
58
|
-
end
|
59
|
-
|
60
70
|
def return(klassmod, &proc)
|
61
|
-
raise('Please provide a code block') unless block_given?
|
62
|
-
|
63
71
|
@returning = if klassmod.respond_to? :return_as_instance_descriptor
|
64
72
|
klassmod.return_as_instance_descriptor
|
65
73
|
else
|
@@ -67,13 +75,35 @@ module Safrano
|
|
67
75
|
# --> assume it is a Primitive
|
68
76
|
ResultDefinition.asPrimitiveType(klassmod)
|
69
77
|
end
|
70
|
-
|
78
|
+
# block is optional since 0.6.7
|
79
|
+
# the function definition can now also be made with .definition(lambda)
|
80
|
+
# consistency check that there is a single definition either as a
|
81
|
+
# return-block or a definition lambda is made on publish finalise
|
82
|
+
|
83
|
+
if block_given?
|
84
|
+
# proc already defined...
|
85
|
+
raise Redefinition.new(@name) if @proc
|
86
|
+
|
87
|
+
@proc = proc
|
88
|
+
end
|
89
|
+
|
71
90
|
self
|
72
91
|
end
|
73
92
|
|
74
|
-
def
|
75
|
-
raise('Please provide a
|
93
|
+
def definition(lambda)
|
94
|
+
raise('Please provide a lambda') unless lambda
|
95
|
+
# proc already defined...
|
96
|
+
raise ProcRedefinition.new(@name) if @proc
|
97
|
+
|
98
|
+
@proc = lambda
|
99
|
+
end
|
100
|
+
|
101
|
+
# this is called from service.finalize_publishing
|
102
|
+
def check_definition
|
103
|
+
raise DefinitionMissing.new(@name) unless @proc
|
104
|
+
end
|
76
105
|
|
106
|
+
def return_collection(klassmod, lambda: nil, &proc)
|
77
107
|
@returning = if klassmod.respond_to? :return_as_collection_descriptor
|
78
108
|
klassmod.return_as_collection_descriptor
|
79
109
|
else
|
@@ -82,7 +112,14 @@ module Safrano
|
|
82
112
|
# ResultAsPrimitiveTypeColl.new(klassmod)
|
83
113
|
ResultDefinition.asPrimitiveTypeColl(klassmod)
|
84
114
|
end
|
85
|
-
|
115
|
+
# block is optional since 0.6.7
|
116
|
+
if block_given?
|
117
|
+
# proc already defined...
|
118
|
+
raise ProcRedefinition.new(@name) if @proc
|
119
|
+
|
120
|
+
@proc = proc
|
121
|
+
end
|
122
|
+
|
86
123
|
self
|
87
124
|
end
|
88
125
|
# def initialize_params
|
@@ -156,8 +193,13 @@ module Safrano
|
|
156
193
|
def with_transition_validated(req)
|
157
194
|
# initialize_params
|
158
195
|
@params = req.params
|
159
|
-
|
160
|
-
|
196
|
+
unless (@error = check_url_func_params)
|
197
|
+
begin
|
198
|
+
return yield
|
199
|
+
rescue LocalJumpError => e
|
200
|
+
@error = Safrano::ServiceOperationReturnError.new
|
201
|
+
end
|
202
|
+
end
|
161
203
|
[nil, :error, @error] if @error
|
162
204
|
end
|
163
205
|
|
data/lib/odata/model_ext.rb
CHANGED
@@ -753,7 +753,8 @@ module Safrano
|
|
753
753
|
# json is default content type so we dont need to specify it here again
|
754
754
|
# TODO quirks array mode !
|
755
755
|
# [201, EMPTY_HASH, new_entity.to_odata_post_json(service: req.service)]
|
756
|
-
[201, {
|
756
|
+
[201, { Safrano::LOCATION => new_entity.uri },
|
757
|
+
new_entity.to_odata_create_json(request: req)]
|
757
758
|
else # TODO: other formats
|
758
759
|
415
|
759
760
|
end
|
data/lib/odata/request/json.rb
CHANGED
@@ -1,9 +1,15 @@
|
|
1
1
|
require 'json'
|
2
2
|
require 'time'
|
3
|
-
|
3
|
+
require 'base64'
|
4
4
|
# client parsing functionality to ease testing
|
5
5
|
|
6
6
|
module Safrano
|
7
|
+
module RFC2047
|
8
|
+
def self.encode(str)
|
9
|
+
"=?utf-8?b?#{Base64.strict_encode64(str)}?="
|
10
|
+
end
|
11
|
+
end
|
12
|
+
|
7
13
|
module OData
|
8
14
|
# this is used to parse inbound json payload on POST / PUT & co
|
9
15
|
# it does not do symbolize but proper (hopefully) type casting when needed
|
data/lib/safrano/core.rb
CHANGED
@@ -13,10 +13,10 @@ module Safrano
|
|
13
13
|
|
14
14
|
# some prominent constants... probably already defined elsewhere eg in Rack
|
15
15
|
# but lets KISS
|
16
|
-
CONTENT_TYPE = '
|
17
|
-
CONTENT_LENGTH = '
|
18
|
-
LOCATION = '
|
19
|
-
|
16
|
+
CONTENT_TYPE = 'content-type'
|
17
|
+
CONTENT_LENGTH = 'content-length'
|
18
|
+
LOCATION = 'location'
|
19
|
+
|
20
20
|
TEXTPLAIN_UTF8 = 'text/plain;charset=utf-8'
|
21
21
|
APPJSON = 'application/json'
|
22
22
|
APPXML = 'application/xml'
|
data/lib/safrano/multipart.rb
CHANGED
@@ -142,12 +142,12 @@ module MIME
|
|
142
142
|
@lines = inpstr.readlines(@sep)
|
143
143
|
else
|
144
144
|
# rack input wrapper only has gets but not readlines
|
145
|
-
|
146
|
-
|
147
|
-
|
148
|
-
|
149
|
-
|
150
|
-
|
145
|
+
# BUT the rack SPEC says it only supports gets without argument!
|
146
|
+
# --> finally we end up using read and split into lines...
|
147
|
+
# normally should be ok for $batch POST payloads
|
148
|
+
|
149
|
+
# inpstr.read should be a String
|
150
|
+
@lines = inpstr.read.lines(@sep)
|
151
151
|
|
152
152
|
end
|
153
153
|
# tmp hack for test-tools that convert CRLF in payload to LF :-(
|
data/lib/safrano/service.rb
CHANGED
@@ -375,7 +375,7 @@ module Safrano
|
|
375
375
|
def finalize_publishing
|
376
376
|
# build the cmap
|
377
377
|
@cmap = {}
|
378
|
-
@collections
|
378
|
+
@collections&.each do |klass|
|
379
379
|
@cmap[klass.entity_set_name] = klass
|
380
380
|
# set namespace needed to have qualified type name
|
381
381
|
copy_namespace_to(klass)
|
@@ -393,7 +393,7 @@ module Safrano
|
|
393
393
|
set_uribase
|
394
394
|
|
395
395
|
# finalize the uri's and include NoMappingBeforeOutput or MappingBeforeOutput as needed
|
396
|
-
@collections
|
396
|
+
@collections&.each do |klass|
|
397
397
|
klass.finalize_publishing(self)
|
398
398
|
|
399
399
|
klass.build_uri(@uribase)
|
@@ -448,9 +448,14 @@ module Safrano
|
|
448
448
|
Safrano::Filter::DateTimeLit.include Safrano::Filter::DateTimeDefault
|
449
449
|
Safrano::Filter::DateTimeOffsetLit.include Safrano::Filter::DateTimeDefault
|
450
450
|
end
|
451
|
+
|
452
|
+
# check function import definition
|
453
|
+
function_imports.each_value { |func| func.check_definition }
|
451
454
|
end
|
452
455
|
|
453
456
|
def execute_deferred_iblocks
|
457
|
+
return unless @collections
|
458
|
+
|
454
459
|
@collections.each do |k|
|
455
460
|
k.instance_eval(&k.deferred_iblock) if k.deferred_iblock
|
456
461
|
end
|
@@ -460,6 +465,8 @@ module Safrano
|
|
460
465
|
## evaluated after '@collections' is filled !
|
461
466
|
# A regexp matching all allowed base entities (eg product|categories )
|
462
467
|
def base_url_regexp
|
468
|
+
return unless @collections
|
469
|
+
|
463
470
|
@collections.map(&:entity_set_name).join('|')
|
464
471
|
end
|
465
472
|
|
data/lib/safrano/version.rb
CHANGED
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: safrano
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.6.
|
4
|
+
version: 0.6.7
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- oz
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2023-
|
11
|
+
date: 2023-02-11 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: rack
|
@@ -30,14 +30,14 @@ dependencies:
|
|
30
30
|
requirements:
|
31
31
|
- - "~>"
|
32
32
|
- !ruby/object:Gem::Version
|
33
|
-
version: '1.
|
33
|
+
version: '1.1'
|
34
34
|
type: :runtime
|
35
35
|
prerelease: false
|
36
36
|
version_requirements: !ruby/object:Gem::Requirement
|
37
37
|
requirements:
|
38
38
|
- - "~>"
|
39
39
|
- !ruby/object:Gem::Version
|
40
|
-
version: '1.
|
40
|
+
version: '1.1'
|
41
41
|
- !ruby/object:Gem::Dependency
|
42
42
|
name: rfc2047
|
43
43
|
requirement: !ruby/object:Gem::Requirement
|
@@ -114,14 +114,14 @@ dependencies:
|
|
114
114
|
requirements:
|
115
115
|
- - "~>"
|
116
116
|
- !ruby/object:Gem::Version
|
117
|
-
version: '
|
117
|
+
version: '2.0'
|
118
118
|
type: :development
|
119
119
|
prerelease: false
|
120
120
|
version_requirements: !ruby/object:Gem::Requirement
|
121
121
|
requirements:
|
122
122
|
- - "~>"
|
123
123
|
- !ruby/object:Gem::Version
|
124
|
-
version: '
|
124
|
+
version: '2.0'
|
125
125
|
- !ruby/object:Gem::Dependency
|
126
126
|
name: rake
|
127
127
|
requirement: !ruby/object:Gem::Requirement
|