orientea 0.2.2 → 0.2.3
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/VERSION +1 -1
- data/lib/orientea/changing_command.rb +12 -10
- data/lib/orientea/creating_command.rb +7 -0
- data/orientea.gemspec +2 -2
- metadata +2 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: ac09a25dc5a0d87505b9c426e0dec5a8276ae5dd
|
4
|
+
data.tar.gz: d14e7f6e8bf8182afc75b52ab75e65154319db59
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 0abc6c0cc937ca7bb6ca742a327546fb67bfd6ef399efa3bd8d707269a55e7aab2d8df3b8f8ef31ba3aa4d6dc39224bdc55b148ea6bfacafb4899601a6023b0c
|
7
|
+
data.tar.gz: 6b4cc20ea8ecb6d087a9d828da3ed2b4ea219fe15eb3db0b831622613dd9a5bff2feb7b92d65b64c44fd85ee3a1992bb057679d134f35def2f3d5190e07283f6
|
data/VERSION
CHANGED
@@ -1 +1 @@
|
|
1
|
-
0.2.
|
1
|
+
0.2.3
|
@@ -12,27 +12,29 @@ module Orientea
|
|
12
12
|
command
|
13
13
|
end
|
14
14
|
|
15
|
-
|
15
|
+
def record_changes
|
16
|
+
data['changes']
|
17
|
+
end
|
18
|
+
|
19
|
+
def get_record(old = false)
|
16
20
|
cls = self.data['cls_str'].constantize
|
17
21
|
id = self.data['cls_id']
|
18
22
|
object = cls.find(id)
|
19
23
|
JSON.load(self.data['changes']).each do |key, value|
|
20
|
-
object.send("#{key}=", value.last)
|
24
|
+
object.send("#{key}=", (old ? value.first : value.last))
|
21
25
|
end
|
22
|
-
|
26
|
+
object
|
27
|
+
end
|
28
|
+
|
29
|
+
action do
|
30
|
+
if get_record(false).save
|
23
31
|
self.done = true
|
24
32
|
self.save
|
25
33
|
end
|
26
34
|
end
|
27
35
|
|
28
36
|
undo do
|
29
|
-
|
30
|
-
id = self.data['cls_id']
|
31
|
-
object = cls.find(id)
|
32
|
-
JSON.load(self.data['changes']).each do |key, value|
|
33
|
-
object.send("#{key}=", value.first)
|
34
|
-
end
|
35
|
-
if object.save
|
37
|
+
if get_record(true).save
|
36
38
|
self.done = false
|
37
39
|
self.save
|
38
40
|
end
|
@@ -2,6 +2,8 @@ require 'orientea/command.rb'
|
|
2
2
|
module Orientea
|
3
3
|
class CreatingCommand < Orientea::Command
|
4
4
|
|
5
|
+
validates :data, presence: true
|
6
|
+
|
5
7
|
def self.build(record)
|
6
8
|
command = self.new
|
7
9
|
command.data = Hash.new
|
@@ -11,6 +13,11 @@ module Orientea
|
|
11
13
|
command
|
12
14
|
end
|
13
15
|
|
16
|
+
def get_record
|
17
|
+
cls = self.data['cls_str'].constantize
|
18
|
+
self.done ? cls.find(self.data['cls_id']): cls.new(JSON.load(self.data['changes']), without_protection: true)
|
19
|
+
end
|
20
|
+
|
14
21
|
action do
|
15
22
|
cls = self.data['cls_str'].constantize
|
16
23
|
new_object = cls.new(JSON.load(self.data['changes']), without_protection: true)
|
data/orientea.gemspec
CHANGED
@@ -5,11 +5,11 @@
|
|
5
5
|
|
6
6
|
Gem::Specification.new do |s|
|
7
7
|
s.name = "orientea"
|
8
|
-
s.version = "0.2.
|
8
|
+
s.version = "0.2.3"
|
9
9
|
|
10
10
|
s.required_rubygems_version = Gem::Requirement.new(">= 0") if s.respond_to? :required_rubygems_version=
|
11
11
|
s.authors = ["Vincent Zhu"]
|
12
|
-
s.date = "2013-09-
|
12
|
+
s.date = "2013-09-21"
|
13
13
|
s.description = "Command Pattern Implementation for easy use with rails"
|
14
14
|
s.email = "zhu1230@gmail.com"
|
15
15
|
s.extra_rdoc_files = [
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: orientea
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.2.
|
4
|
+
version: 0.2.3
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Vincent Zhu
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2013-09-
|
11
|
+
date: 2013-09-21 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: activerecord
|