-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathconfig.rb
113 lines (92 loc) · 3.25 KB
/
config.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
###
# Compass
###
# Change Compass configuration
# compass_config do |config|
# config.output_style = :compact
# end
###
# Page options, layouts, aliases and proxies
###
# Per-page layout changes:
#
# With no layout
# page "/path/to/file.html", :layout => false
#
# With alternative layout
# page "/path/to/file.html", :layout => :otherlayout
#
# A path which all have the same layout
# with_layout :admin do
# page "/admin/*"
# end
# Proxy pages (https://middlemanapp.com/advanced/dynamic_pages/)
# proxy "/this-page-has-no-template.html", "/template-file.html", :locals => {
# :which_fake_page => "Rendering a fake page with a local variable" }
###
# Helpers
###
# Automatic image dimensions on image_tag helper
# activate :automatic_image_sizes
# Reload the browser automatically whenever files change
# configure :development do
# activate :livereload
# end
# Methods defined in the helpers block are available in templates
# helpers do
# def some_helper
# "Helping"
# end
# end
set :css_dir, 'assets/stylesheets'
set :js_dir, 'assets/javascripts'
set :images_dir, 'assets/images'
# Build-specific configuration
configure :build do
# For example, change the Compass output style for deployment
# activate :minify_css
# Minify Javascript on build
# activate :minify_javascript
# Enable cache buster
# activate :asset_hash
# Use relative URLs
# activate :relative_assets
# Or use a different image path
# set :http_prefix, "/Content/images/"
end
# Example Prismic Api Query:
# api = Prismic.api('https://prismic-project-example.prismic.io/api')
# # Prismic response for all blogs
# response_news = api
# .form('everything')
# .query('[[:d = at(document.type, "document-mask-name")]]')
# .submit(api.master_ref)
#
# @something_to_put_in_view = response.results
# Uncomment the line below to test deployment to AWS from your console
# ENV = YAML::load(File.open('aws.yml'))
# Configuration code for Middleman AWS S3 Sync
# See middleman-s3_sync documentation: https://github.com/fredjean/middleman-s3_sync
activate :s3_sync do |s3_sync|
# The name of the S3 bucket you are targeting. This is globally unique.
s3_sync.bucket = ENV['AWS_S3_BUCKET_NAME']
# The AWS region code for your bucket.
# For region codes: http://www.bucketexplorer.com/documentation/amazon-s3--amazon-s3-buckets-and-regions.html
s3_sync.region = ENV['AWS_REGION']
s3_sync.aws_access_key_id = ENV['AWS_ACCESS_KEY_ID']
s3_sync.aws_secret_access_key = ENV['AWS_SECRET_KEY']
#s3_sync.delete = true # We delete stray files by default.
#s3_sync.after_build = true # We do not chain after the build step by default.
end
# CloudFront cache invalidation
# See middleman-cloudfront gem documentation: https://github.com/andrusha/middleman-cloudfront
activate :cloudfront do |cf|
cf.access_key_id = ENV['AWS_ACCESS_KEY_ID']
cf.secret_access_key = ENV['AWS_SECRET_KEY']
cf.distribution_id = ENV['PRODUCTION_CLOUDFRONT_DISTRIBUTION_ID']
cf.filter = /\.html$/i
#cf.after_build = false # default is false
end
after_s3_sync do |files_by_status|
invalidate files_by_status[:updated]
end