Class: Brief::Briefcase
- Inherits:
-
Object
show all
- Includes:
- Documentation, DSL
- Defined in:
- lib/brief/briefcase.rb,
lib/brief/briefcase/initializer.rb,
lib/brief/briefcase/documentation.rb
Defined Under Namespace
Modules: Documentation
Classes: Initializer
Instance Attribute Summary collapse
Class Method Summary
collapse
Instance Method Summary
collapse
#render_documentation, #schema_map
Methods included from DSL
#action, #command, #define, #extend, #href_builder, #view
Constructor Details
#initialize(options = {}) ⇒ Briefcase
Returns a new instance of Briefcase.
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
# File 'lib/brief/briefcase.rb', line 9
def initialize(options = {})
@options = options.to_mash
load_configuration
use(:app, options[:app]) if options[:app]
load_model_definitions
if Brief.case(false).nil?
Brief.case = self
end
Brief.cases[root.basename.to_s] ||= self
end
|
Dynamic Method Handling
This class handles dynamic methods through the method_missing method
#method_missing(meth, *args, &block) ⇒ Object
306
307
308
309
310
311
312
313
314
315
|
# File 'lib/brief/briefcase.rb', line 306
def method_missing(meth, *args, &block)
if Brief.views.key?(meth.to_sym)
block = Brief.views[meth.to_sym]
block.call(self, args.)
elsif repository.respond_to?(meth)
repository.send(meth, *args, &block)
else
super
end
end
|
Instance Attribute Details
#model_definitions ⇒ Object
Returns the value of attribute model_definitions.
6
7
8
|
# File 'lib/brief/briefcase.rb', line 6
def model_definitions
@model_definitions
end
|
#options ⇒ Object
Returns the value of attribute options.
6
7
8
|
# File 'lib/brief/briefcase.rb', line 6
def options
@options
end
|
Class Method Details
.create_new_briefcase(options = {}) ⇒ Object
317
318
319
|
# File 'lib/brief/briefcase.rb', line 317
def self.create_new_briefcase(options={})
Brief::Briefcase::Initializer.new(options).run
end
|
Instance Method Details
#app_config_path ⇒ Object
202
203
204
|
# File 'lib/brief/briefcase.rb', line 202
def app_config_path
uses_app? && app_path.join("config.rb")
end
|
#app_models ⇒ Object
214
215
216
|
# File 'lib/brief/briefcase.rb', line 214
def app_models
app_namespace.constants.map {|c| app_namespace.const_get(c) }
end
|
#app_models_folder ⇒ Object
206
207
208
|
# File 'lib/brief/briefcase.rb', line 206
def app_models_folder
uses_app? && app_path.join("models")
end
|
#app_namespace ⇒ Object
210
211
212
|
# File 'lib/brief/briefcase.rb', line 210
def app_namespace
Brief::Apps.find_namespace(options[:app])
end
|
#app_path ⇒ Object
198
199
200
|
# File 'lib/brief/briefcase.rb', line 198
def app_path
uses_app? && Brief::Apps.path_for(options[:app]).to_pathname
end
|
#as_default(params = {}) ⇒ Object
TODO The serialization of an entire briefcase at once is important enough to be its own module
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
|
# File 'lib/brief/briefcase.rb', line 100
def as_default(params={})
params.symbolize_keys!
base = info_hash
if params[:include_data] || params[:data]
base[:data] = data.as_json
end
if params[:include_schema] || params[:schema]
base[:schema] = schema_map(!!(params[:include_schema] == "full"))
end
if params[:include_documentation] || params[:documentation]
base[:documentation] = render_documentation
end
if params[:include_models] || params[:models]
model_settings = {
docs_path: docs_path
}
%w(urls content rendered attachments).each do |opt|
model_settings[opt.to_sym] = !!(params[opt.to_sym] || params["include_#{opt}".to_sym])
end
all = all_models.compact
base[:models] = all.map do |m|
m.document.refresh! if params[:refresh_models]
m.as_json(model_settings)
end
end
base
end
|
#as_full_export(options = {}) ⇒ Object
137
138
139
140
141
142
143
144
145
|
# File 'lib/brief/briefcase.rb', line 137
def as_full_export(options={})
options.reverse_merge!(content: true,
rendered: true,
models: true,
schema: true,
documentation: true,
attachments: true)
as_default(options)
end
|
#assets_path ⇒ Object
256
257
258
|
# File 'lib/brief/briefcase.rb', line 256
def assets_path
root.join(options.fetch(:assets_path) { config.assets_path }).expand_path
end
|
#assets_trail ⇒ Object
268
269
270
271
272
273
|
# File 'lib/brief/briefcase.rb', line 268
def assets_trail
@assets_trail ||= Hike::Trail.new(assets_path).tap do |trail|
trail.append_extensions '.svg', '.png', '.pdf', '.jpg', '.gif', '.mov'
assets_path.children.select(&:directory?).each {|dir| trail.prepend_path(assets_path); trail.append_path(assets_path.join(dir)) }
end
end
|
#cache_key ⇒ Object
56
57
58
|
# File 'lib/brief/briefcase.rb', line 56
def cache_key
"#{slug}:#{repository.cache_key}"
end
|
#config(&block) ⇒ Object
161
162
163
164
165
|
# File 'lib/brief/briefcase.rb', line 161
def config(&block)
Brief::Configuration.instance.tap do |cfg|
cfg.instance_eval(&block) if block.respond_to?(:call)
end
end
|
#data ⇒ Object
153
154
155
|
# File 'lib/brief/briefcase.rb', line 153
def data
@data ||= data!
end
|
#data! ⇒ Object
157
158
159
|
# File 'lib/brief/briefcase.rb', line 157
def data!
@data = Brief::Data::Wrapper.new(root: data_path)
end
|
#data_path ⇒ Object
264
265
266
|
# File 'lib/brief/briefcase.rb', line 264
def data_path
root.join(options.fetch(:data_path) { config.data_path }).expand_path
end
|
#data_trail ⇒ Object
283
284
285
286
287
288
|
# File 'lib/brief/briefcase.rb', line 283
def data_trail
@docs_trail ||= Hike::Trail.new(data_path).tap do |trail|
trail.append_extensions '.yaml', '.js', '.json', '.xls', '.xlsx', '.csv', '.txt'
trail.append_path(data_path)
end
end
|
#docs_path ⇒ Object
260
261
262
|
# File 'lib/brief/briefcase.rb', line 260
def docs_path
root.join(options.fetch(:docs_path) { config.docs_path }).expand_path
end
|
#docs_trail ⇒ Object
275
276
277
278
279
280
|
# File 'lib/brief/briefcase.rb', line 275
def docs_trail
@docs_trail ||= Hike::Trail.new(docs_path).tap do |trail|
trail.append_extensions '.md', '.html.md', '.markdown'
docs_path.children.select(&:directory?).each {|dir| trail.prepend_path(docs_path); trail.append_path(docs_path.join(dir)) }
end
end
|
#find_asset(needle) ⇒ Object
251
252
253
254
|
# File 'lib/brief/briefcase.rb', line 251
def find_asset(needle)
found = assets_trail.find(needle)
found && Pathname(found)
end
|
#folder_name ⇒ Object
171
172
173
|
# File 'lib/brief/briefcase.rb', line 171
def folder_name
root.basename
end
|
#generic_model_class_for(document) ⇒ Object
223
224
225
|
# File 'lib/brief/briefcase.rb', line 223
def generic_model_class_for(document)
Brief::Model.for_type(document.document_type) || Brief::Model.for_folder_name(document.parent_folder_name)
end
|
#get_href_for(brief_uri) ⇒ Object
93
94
95
|
# File 'lib/brief/briefcase.rb', line 93
def get_href_for(brief_uri)
Brief.href_builder.call(brief_uri)
end
|
#info_hash ⇒ Object
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
|
# File 'lib/brief/briefcase.rb', line 75
def info_hash
{
BRIEF_VERSION: Brief::VERSION,
views: Brief.views.keys,
key: folder_name.to_s.parameterize,
name: folder_name.to_s.titlecase,
settings: settings,
cache_key: cache_key,
root: root.to_s,
paths:{
docs_path: docs_path.to_s,
assets_path: assets_path.to_s,
models_path: models_path.to_s,
data_path: data_path.to_s
}
}
end
|
#load_configuration ⇒ Object
Loads the configuration for this briefcase, either from the current working directory or the configured path for the configuration file.
177
178
179
180
181
182
183
184
185
186
187
|
# File 'lib/brief/briefcase.rb', line 177
def load_configuration
config_path = options.fetch(:config_path) do
root.join('brief.rb')
end
if config_path.is_a?(String)
config_path = root.join(config_path)
end
run(config_path) if config_path.exist?
end
|
#load_model_definitions ⇒ Object
227
228
229
230
231
232
233
234
|
# File 'lib/brief/briefcase.rb', line 227
def load_model_definitions
if uses_app?
Brief.load_modules_from(app_path.join("models"))
end
Brief.load_modules_from(models_path) if models_path.exist?
Brief::Model.finalize
end
|
#model(name_or_type) ⇒ Object
Returns a model name by its human readable description or its type alias
237
238
239
240
241
242
243
244
245
|
# File 'lib/brief/briefcase.rb', line 237
def model(name_or_type)
table = Brief::Model.table
table.fetch(name_or_type) do
table.values.find do |k|
k.name == name_or_type
end
end
end
|
#model_class_for(document) ⇒ Object
218
219
220
221
|
# File 'lib/brief/briefcase.rb', line 218
def model_class_for(document)
return generic_model_class_for(document) unless uses_app?
app_models.find {|k| k.type_alias == document.document_type } || generic_model_class_for(document)
end
|
#models_path ⇒ Object
290
291
292
293
294
295
296
297
298
299
300
|
# File 'lib/brief/briefcase.rb', line 290
def models_path
value = options.fetch(:models_path) { config.models_path }
if value.to_s.match(/\./)
Pathname(Brief.pwd).join(value)
elsif value.to_s.match(/\//)
Pathname(value)
else
root.join(value)
end
end
|
#present(style = "default", params = {}) ⇒ Object
Returns a Hash object which presents some view of the briefcase. Accepts a params hash of options that will be passed to the presenter.
The default presenter is Brief::Briefcase#as_default
45
46
47
48
49
50
51
52
53
54
|
# File 'lib/brief/briefcase.rb', line 45
def present(style="default", params={})
style = "default" if style.nil?
if respond_to?("as_#{style}")
send("as_#{style}", params)
elsif Brief.views.key?(style.to_sym)
block = Brief.views[style.to_sym]
block.call(self, params)
end
end
|
#repository ⇒ Object
302
303
304
|
# File 'lib/brief/briefcase.rb', line 302
def repository
@repository ||= Brief::Repository.new(self, options)
end
|
#root ⇒ Object
247
248
249
|
# File 'lib/brief/briefcase.rb', line 247
def root
Pathname(options.fetch(:root) { Brief.pwd }).expand_path
end
|
#run(code_or_file) ⇒ Object
189
190
191
192
|
# File 'lib/brief/briefcase.rb', line 189
def run(code_or_file)
code = code_or_file.is_a?(Pathname) ? code_or_file.read : code
instance_eval(code) rescue nil
end
|
#run_command(name, *args) ⇒ Object
Runs a command
Commands are defined in the briefcase configuration.
You define a command by passing a block. This block will get called with the briefcase, and whatever other arguments
30
31
32
33
34
35
36
37
38
|
# File 'lib/brief/briefcase.rb', line 30
def run_command(name, *args)
if handler = Brief.commands.fetch(name.to_sym)
block = handler[:handler]
args.unshift(self)
block.call(*args)
else
raise 'Command not found'
end
end
|
#server(options = {}) ⇒ Object
167
168
169
|
# File 'lib/brief/briefcase.rb', line 167
def server(options={})
@server ||= Brief::Server.new(self, options)
end
|
#settings ⇒ Object
64
65
66
|
# File 'lib/brief/briefcase.rb', line 64
def settings
@settings ||= settings!
end
|
#settings! ⇒ Object
68
69
70
71
72
73
|
# File 'lib/brief/briefcase.rb', line 68
def settings!
if root.join("settings.yml").exist?
y = YAML.load(root.join("settings.yml").read) rescue nil
(y || {}).to_mash
end
end
|
#slug ⇒ Object
60
61
62
|
# File 'lib/brief/briefcase.rb', line 60
def slug
options.fetch(:slug) { root.basename.to_s.parameterize }
end
|
#use(module_type = :app, module_id) ⇒ Object
147
148
149
150
151
|
# File 'lib/brief/briefcase.rb', line 147
def use(module_type=:app, module_id)
options[:app] = module_id.to_s
run(app_config_path) if app_path.try(&:exist?)
end
|
#uses_app? ⇒ Boolean
194
195
196
|
# File 'lib/brief/briefcase.rb', line 194
def uses_app?
options.key?(:app) && Brief::Apps.available?(options[:app].to_s)
end
|