Class: NotionRubyMapping::Base

Inherits:
Object
  • Object
show all
Defined in:
lib/notion_ruby_mapping/base.rb

Overview

Notion Base object (Parent of Page / Database / List)

Direct Known Subclasses

Block, Database, List, Page

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(json: nil, id: nil, assign: [], parent: nil) ⇒ Base

Returns a new instance of Base.

Parameters:

  • json (Hash, nil) (defaults to: nil)
  • id (String, nil) (defaults to: nil)
  • assign (Array<Property, Class, String>) (defaults to: [])

Raises:

  • (StandardError)


11
12
13
14
15
16
17
18
19
20
21
22
23
# File 'lib/notion_ruby_mapping/base.rb', line 11

def initialize(json: nil, id: nil, assign: [], parent: nil)
  @nc = NotionCache.instance
  @json = json
  @id = @nc.hex_id(id || json && @json["id"])
  @new_record = true unless parent.nil?
  raise StandardError, "Unknown id" if !is_a?(List) && @id.nil? && parent.nil?

  @payload = Payload.new(parent && {"parent" => parent})
  @property_cache = nil
  @created_time = nil
  @last_edited_time = nil
  assign.each_slice(2) { |(klass, key)| assign_property(klass, key) }
end

Instance Attribute Details

#idObject (readonly)

Returns the value of attribute id.



24
25
26
# File 'lib/notion_ruby_mapping/base.rb', line 24

def id
  @id
end

#jsonObject (readonly)

Returns the value of attribute json.



24
25
26
# File 'lib/notion_ruby_mapping/base.rb', line 24

def json
  @json
end

Class Method Details

.create_from_json(json) ⇒ NotionRubyMapping::Base

Parameters:

  • json (Hash, Notion::Messages)

Returns:



109
110
111
112
113
114
115
116
117
118
119
120
121
122
# File 'lib/notion_ruby_mapping/base.rb', line 109

def self.create_from_json(json)
  case json["object"]
  when "page"
    Page.new json: json
  when "database"
    Database.new json: json
  when "list"
    List.new json: json
  when "block"
    Block.new json: json
  else
    raise StandardError, json.inspect
  end
end

.dry_run_script(method, path, json = nil) ⇒ Object

Parameters:

  • method (Object)
  • path (Object)
  • json (nil) (defaults to: nil)


188
189
190
191
192
193
194
195
196
197
# File 'lib/notion_ruby_mapping/base.rb', line 188

def self.dry_run_script(method, path, json = nil)
  shell = [
    "#!/bin/sh\ncurl #{method == :get ? "" : "-X #{method.to_s.upcase}"} 'https://api.notion.com/#{path}'",
    "  -H 'Notion-Version: 2022-02-22'",
    "  -H 'Authorization: Bearer '\"$NOTION_API_KEY\"''"
  ]
  shell << "  -H 'Content-Type: application/json'" unless path == :get
  shell << "  --data '#{JSON.generate json}'" if json
  shell.join("\\ \n")
end

Instance Method Details

#[](key) ⇒ NotionRubyMapping::PropertyCache, Hash

Returns obtained Page value or PropertyCache.

Parameters:

  • key (String)

Returns:



28
29
30
31
32
33
34
35
36
37
38
39
40
# File 'lib/notion_ruby_mapping/base.rb', line 28

def [](key)
  unless @json
    raise StandardError, "Unknown id" if @id.nil?

    reload
  end
  case key
  when "properties"
    properties
  else
    @json[key]
  end
end

#assign_property(klass, title) ⇒ NotionRubyMapping::Property

Returns generated property.

Parameters:

Returns:



127
128
129
130
131
132
133
134
135
136
137
# File 'lib/notion_ruby_mapping/base.rb', line 127

def assign_property(klass, title)
  @property_cache ||= PropertyCache.new({}, base_type: database? ? :database : :page)

  property = if database?
               klass.new(title, will_update: new_record?, base_type: :database)
             else
               klass.new(title, will_update: true, base_type: :page)
             end
  @property_cache.add_property property
  property
end

#childrenNotionRubyMapping::List



140
141
142
# File 'lib/notion_ruby_mapping/base.rb', line 140

def children
  @children ||= @nc.block_children(id)
end

#created_timeNotionRubyMapping::CreatedTimeProperty



43
44
45
# File 'lib/notion_ruby_mapping/base.rb', line 43

def created_time
  @created_time ||= CreatedTimeProperty.new("title")
end

#database?TrueClass, FalseClass

Returns true if Database object.

Returns:

  • (TrueClass, FalseClass)

    true if Database object



48
49
50
# File 'lib/notion_ruby_mapping/base.rb', line 48

def database?
  is_a? Database
end

#iconHash?

Returns obtained Hash.

Returns:

  • (Hash, nil)

    obtained Hash



53
54
55
# File 'lib/notion_ruby_mapping/base.rb', line 53

def icon
  self["icon"]
end

#json_propertiesHash

protected

Returns:

  • (Hash)

    json properties



181
182
183
# File 'lib/notion_ruby_mapping/base.rb', line 181

def json_properties
  @json && @json["properties"]
end

#new_record?Boolean

Returns true if new record.

Returns:

  • (Boolean)

    true if new record



58
59
60
# File 'lib/notion_ruby_mapping/base.rb', line 58

def new_record?
  @new_record
end

#page?TrueClass, FalseClass

Returns true if Page object.

Returns:

  • (TrueClass, FalseClass)

    true if Page object



63
64
65
# File 'lib/notion_ruby_mapping/base.rb', line 63

def page?
  is_a? Page
end

#propertiesNotionRubyMapping::PropertyCache

Returns get or created PropertyCache object.

Returns:



68
69
70
71
72
73
74
75
76
77
78
# File 'lib/notion_ruby_mapping/base.rb', line 68

def properties
  unless @property_cache
    unless @json
      raise StandardError, "Unknown id" if @id.nil?

      reload
    end
    @property_cache = PropertyCache.new json_properties, base_type: database? ? :database : :page
  end
  @property_cache
end

#property_values_jsonHash

Returns created json for update page.

Returns:

  • (Hash)

    created json for update page



145
146
147
# File 'lib/notion_ruby_mapping/base.rb', line 145

def property_values_json
  @payload.property_values_json @property_cache
end

#reloadNotionRubyMapping::Base

Returns reloaded self.

Returns:



150
151
152
153
# File 'lib/notion_ruby_mapping/base.rb', line 150

def reload
  update_json reload_json
  self
end

#restore_from_jsonNotionRubyMapping::Base



156
157
158
159
160
161
162
163
164
165
166
# File 'lib/notion_ruby_mapping/base.rb', line 156

def restore_from_json
  return if (ps = @json["properties"]).nil?

  properties.json = json_properties
  return unless is_a?(Page) || is_a?(Database)

  ps.each do |key, json|
    properties[key].update_from_json json
  end
  self
end

#save(dry_run: false) ⇒ NotionRubyMapping::Base, String

Returns:



81
82
83
84
85
86
87
88
89
90
# File 'lib/notion_ruby_mapping/base.rb', line 81

def save(dry_run: false)
  if dry_run
    @new_record ? create(dry_run: true) : update(dry_run: true)
  else
    @new_record ? create : update
    @property_cache.clear_will_update
    @payload.clear
    self
  end
end

#set_icon(emoji: nil, url: nil) ⇒ NotionRubyMapping::Base

Parameters:

  • emoji (String) (defaults to: nil)
  • url (String) (defaults to: nil)

Returns:



95
96
97
98
# File 'lib/notion_ruby_mapping/base.rb', line 95

def set_icon(emoji: nil, url: nil)
  @payload.set_icon(emoji: emoji, url: url) if page? || database?
  self
end

#titleString

Returns title.

Returns:

  • (String)

    title



101
102
103
# File 'lib/notion_ruby_mapping/base.rb', line 101

def title
  properties.select { |p| p.is_a? TitleProperty }.map(&:full_text).join ""
end

#update_json(json) ⇒ NotionRubyMapping::Base

Parameters:

  • json (Hash)

Returns:

Raises:

  • (StandardError)


170
171
172
173
174
175
176
177
# File 'lib/notion_ruby_mapping/base.rb', line 170

def update_json(json)
  raise StandardError, json.inspect unless json["object"] != "error" && @json.nil? || @json["type"] == json["type"]

  @json = json
  @id = @nc.hex_id(@json["id"])
  restore_from_json
  self
end