isomorfeus-data 1.0.0.epsilon1 → 1.0.0.epsilon2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/lib/isomorfeus/data/handler/array_load_handler.rb +13 -7
- data/lib/isomorfeus/data/handler/collection_load_handler.rb +14 -8
- data/lib/isomorfeus/data/handler/graph_load_handler.rb +14 -8
- data/lib/isomorfeus/data/handler/hash_load_handler.rb +13 -7
- data/lib/isomorfeus/data/props.rb +0 -1
- data/lib/isomorfeus/data/version.rb +1 -1
- data/lib/lucid_array/base.rb +0 -1
- data/lib/lucid_array/mixin.rb +0 -1
- data/lib/lucid_collection/base.rb +0 -1
- data/lib/lucid_collection/mixin.rb +0 -1
- data/lib/lucid_graph/base.rb +0 -1
- data/lib/lucid_graph/mixin.rb +0 -1
- data/lib/lucid_hash/base.rb +0 -1
- data/lib/lucid_hash/mixin.rb +0 -1
- metadata +34 -6
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 5e3c0008c0b7a6498ba52310bfd8c72ddad9317f86b37a636ce587a4bd849a97
|
4
|
+
data.tar.gz: 4ff296d8cc02db814adf92d00cae08f202a2dd0d29926552393eb4e4213b1179
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: bd56a019dda4749778351430f28cfb8d46caf718ceeb068adc43e240b18d1f3b78a3a4d04465f8cd62080379719d6aedb82e97672cb4ed62d56ea428d8ee4706
|
7
|
+
data.tar.gz: d5e97819f76f229c9c320645cec97dd69570f54c4ce13b7a6d21e3a95563597a8f2cd82b87a744c47284a9591fb148140f14304a97ea7469faab54088fbe17e2
|
@@ -1,8 +1,10 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
module Isomorfeus
|
2
4
|
module Data
|
3
5
|
module Handler
|
4
6
|
class ArrayLoadHandler < LucidHandler::Base
|
5
|
-
on_request do |pub_sub_client,
|
7
|
+
on_request do |pub_sub_client, current_user, request, response|
|
6
8
|
result = { error: 'No such thing' }
|
7
9
|
# promise_send_path('Isomorfeus::Data::Handler::CollectionLoadHandler', self.to_s, props_hash)
|
8
10
|
request.each_key do |array_class_name|
|
@@ -12,13 +14,17 @@ module Isomorfeus
|
|
12
14
|
props_json = request[array_class_name]
|
13
15
|
begin
|
14
16
|
props = Oj.load(props_json, mode: :strict)
|
15
|
-
props.merge!({pub_sub_client: pub_sub_client,
|
16
|
-
|
17
|
-
|
18
|
-
|
17
|
+
props.merge!({pub_sub_client: pub_sub_client, current_user: current_user})
|
18
|
+
if current_user.authorized?(array_class, :load, *props)
|
19
|
+
array = array_class.load(props)
|
20
|
+
array.instance_exec do
|
21
|
+
array_class.on_load_block.call(pub_sub_client, current_user) if array_class.on_load_block
|
22
|
+
end
|
23
|
+
response.deep_merge!(data: array.to_transport)
|
24
|
+
result = { success: 'ok' }
|
25
|
+
else
|
26
|
+
result = { error: 'Access denied!' }
|
19
27
|
end
|
20
|
-
response.deep_merge!(data: array.to_transport)
|
21
|
-
result = { success: 'ok' }
|
22
28
|
rescue Exception => e
|
23
29
|
result = if Isomorfeus.production?
|
24
30
|
{ error: { array_class_name => 'No such thing!' }}
|
@@ -1,8 +1,10 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
module Isomorfeus
|
2
4
|
module Data
|
3
5
|
module Handler
|
4
6
|
class CollectionLoadHandler < LucidHandler::Base
|
5
|
-
on_request do |pub_sub_client,
|
7
|
+
on_request do |pub_sub_client, current_user, request, response|
|
6
8
|
result = { error: 'No such thing' }
|
7
9
|
# promise_send_path('Isomorfeus::Data::Handler::CollectionLoadHandler', self.to_s, props_hash)
|
8
10
|
request.each_key do |collection_class_name|
|
@@ -12,14 +14,18 @@ module Isomorfeus
|
|
12
14
|
props_json = request[collection_class_name]
|
13
15
|
begin
|
14
16
|
props = Oj.load(props_json, mode: :strict)
|
15
|
-
props.merge!({pub_sub_client: pub_sub_client,
|
16
|
-
|
17
|
-
|
18
|
-
|
17
|
+
props.merge!({pub_sub_client: pub_sub_client, current_user: current_user})
|
18
|
+
if current_user.authorized?(collection_class, :load, *props)
|
19
|
+
collection = collection_class.load(props)
|
20
|
+
collection.instance_exec do
|
21
|
+
collection_class.on_load_block.call(pub_sub_client, current_user) if collection_class.on_load_block
|
22
|
+
end
|
23
|
+
response.deep_merge!(data: collection.to_transport)
|
24
|
+
response.deep_merge!(data: collection.included_items_to_transport)
|
25
|
+
result = { success: 'ok' }
|
26
|
+
else
|
27
|
+
result = { error: 'Access denied!' }
|
19
28
|
end
|
20
|
-
response.deep_merge!(data: collection.to_transport)
|
21
|
-
response.deep_merge!(data: collection.included_items_to_transport)
|
22
|
-
result = { success: 'ok' }
|
23
29
|
rescue Exception => e
|
24
30
|
result = if Isomorfeus.production?
|
25
31
|
{ error: { collection_class_name => 'No such thing!' }}
|
@@ -1,8 +1,10 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
module Isomorfeus
|
2
4
|
module Data
|
3
5
|
module Handler
|
4
6
|
class GraphLoadHandler < LucidHandler::Base
|
5
|
-
on_request do |pub_sub_client,
|
7
|
+
on_request do |pub_sub_client, current_user, request, response|
|
6
8
|
result = { error: 'No such thing' }
|
7
9
|
# promise_send_path('Isomorfeus::Data::Handler::GraphLoadHandler', self.to_s, props_hash)
|
8
10
|
request.each_key do |graph_class_name|
|
@@ -12,14 +14,18 @@ module Isomorfeus
|
|
12
14
|
props_json = request[graph_class_name]
|
13
15
|
begin
|
14
16
|
props = Oj.load(props_json, mode: :strict)
|
15
|
-
props.merge!({pub_sub_client: pub_sub_client,
|
16
|
-
|
17
|
-
|
18
|
-
|
17
|
+
props.merge!({pub_sub_client: pub_sub_client, current_user: current_user})
|
18
|
+
if current_user.authorized?(graph_class, :load, *props)
|
19
|
+
graph = graph_class.load(props)
|
20
|
+
graph.instance_exec do
|
21
|
+
graph_class.on_load_block.call(pub_sub_client, current_user) if graph_class.on_load_block
|
22
|
+
end
|
23
|
+
response.deep_merge!(data: graph.to_transport)
|
24
|
+
response.deep_merge!(data: graph.included_items_to_transport)
|
25
|
+
result = { success: 'ok' }
|
26
|
+
else
|
27
|
+
result = { error: 'Access denied!' }
|
19
28
|
end
|
20
|
-
response.deep_merge!(data: graph.to_transport)
|
21
|
-
response.deep_merge!(data: graph.included_items_to_transport)
|
22
|
-
result = { success: 'ok' }
|
23
29
|
rescue Exception => e
|
24
30
|
result = if Isomorfeus.production?
|
25
31
|
{ error: { graph_class_name => 'No such thing!' }}
|
@@ -1,8 +1,10 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
module Isomorfeus
|
2
4
|
module Data
|
3
5
|
module Handler
|
4
6
|
class HashLoadHandler < LucidHandler::Base
|
5
|
-
on_request do |pub_sub_client,
|
7
|
+
on_request do |pub_sub_client, current_user, request, response|
|
6
8
|
result = { error: 'No such thing' }
|
7
9
|
# promise_send_path('Isomorfeus::Data::Handler::HashLoadHandler', self.to_s, props_hash)
|
8
10
|
request.each_key do |hash_class_name|
|
@@ -12,13 +14,17 @@ module Isomorfeus
|
|
12
14
|
props_json = request[hash_class_name]
|
13
15
|
begin
|
14
16
|
props = Oj.load(props_json, mode: :strict)
|
15
|
-
props.merge!({pub_sub_client: pub_sub_client,
|
16
|
-
|
17
|
-
|
18
|
-
|
17
|
+
props.merge!({pub_sub_client: pub_sub_client, current_user: current_user})
|
18
|
+
if current_user.authorized?(hash_class, :load, *props)
|
19
|
+
hash = hash_class.load(props)
|
20
|
+
hash.instance_exec do
|
21
|
+
hash_class.on_load_block.call(pub_sub_client, current_user) if hash_class.on_load_block
|
22
|
+
end
|
23
|
+
response.deep_merge!(data: hash.to_transport)
|
24
|
+
result = { success: 'ok' }
|
25
|
+
else
|
26
|
+
result = { error: 'Access denied!' }
|
19
27
|
end
|
20
|
-
response.deep_merge!(data: hash.to_transport)
|
21
|
-
result = { success: 'ok' }
|
22
28
|
rescue Exception => e
|
23
29
|
result = if Isomorfeus.production?
|
24
30
|
{ error: { hash_class_name => 'No such thing!' }}
|
data/lib/lucid_array/base.rb
CHANGED
data/lib/lucid_array/mixin.rb
CHANGED
data/lib/lucid_graph/base.rb
CHANGED
data/lib/lucid_graph/mixin.rb
CHANGED
data/lib/lucid_hash/base.rb
CHANGED
data/lib/lucid_hash/mixin.rb
CHANGED
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: isomorfeus-data
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 1.0.0.
|
4
|
+
version: 1.0.0.epsilon2
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Jan Biedermann
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2019-08-
|
11
|
+
date: 2019-08-18 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: activesupport
|
@@ -86,14 +86,14 @@ dependencies:
|
|
86
86
|
requirements:
|
87
87
|
- - ">="
|
88
88
|
- !ruby/object:Gem::Version
|
89
|
-
version: 16.9.
|
89
|
+
version: 16.9.4
|
90
90
|
type: :runtime
|
91
91
|
prerelease: false
|
92
92
|
version_requirements: !ruby/object:Gem::Requirement
|
93
93
|
requirements:
|
94
94
|
- - ">="
|
95
95
|
- !ruby/object:Gem::Version
|
96
|
-
version: 16.9.
|
96
|
+
version: 16.9.4
|
97
97
|
- !ruby/object:Gem::Dependency
|
98
98
|
name: isomorfeus-redux
|
99
99
|
requirement: !ruby/object:Gem::Requirement
|
@@ -114,14 +114,42 @@ dependencies:
|
|
114
114
|
requirements:
|
115
115
|
- - '='
|
116
116
|
- !ruby/object:Gem::Version
|
117
|
-
version: 1.0.0.
|
117
|
+
version: 1.0.0.epsilon2
|
118
118
|
type: :runtime
|
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: 1.0.0.
|
124
|
+
version: 1.0.0.epsilon2
|
125
|
+
- !ruby/object:Gem::Dependency
|
126
|
+
name: isomorfeus-installer
|
127
|
+
requirement: !ruby/object:Gem::Requirement
|
128
|
+
requirements:
|
129
|
+
- - '='
|
130
|
+
- !ruby/object:Gem::Version
|
131
|
+
version: 1.0.0.epsilon2
|
132
|
+
type: :development
|
133
|
+
prerelease: false
|
134
|
+
version_requirements: !ruby/object:Gem::Requirement
|
135
|
+
requirements:
|
136
|
+
- - '='
|
137
|
+
- !ruby/object:Gem::Version
|
138
|
+
version: 1.0.0.epsilon2
|
139
|
+
- !ruby/object:Gem::Dependency
|
140
|
+
name: opal-webpack-loader
|
141
|
+
requirement: !ruby/object:Gem::Requirement
|
142
|
+
requirements:
|
143
|
+
- - ">="
|
144
|
+
- !ruby/object:Gem::Version
|
145
|
+
version: 0.9.4
|
146
|
+
type: :development
|
147
|
+
prerelease: false
|
148
|
+
version_requirements: !ruby/object:Gem::Requirement
|
149
|
+
requirements:
|
150
|
+
- - ">="
|
151
|
+
- !ruby/object:Gem::Version
|
152
|
+
version: 0.9.4
|
125
153
|
- !ruby/object:Gem::Dependency
|
126
154
|
name: rake
|
127
155
|
requirement: !ruby/object:Gem::Requirement
|