Building the workshop site for a customer
We will use Hugo for this website.
The code for workshop is available on github: pcf-hugo-workshop.
Five easy steps to create a custom workshop website in less than 10 minutes. Use the power of Hugo + Wercker + PCF
Dev Process
Step 1: Create a branch per customer
When you create a branch, update the wercker.yml file on the branch to reflect the CF app name/route.
````
box: debian
build:
steps:
- arjen/hugo-build:
version: 0.15
theme: material-design
flags: --destination=public --buildDrafts=false
deploy:
steps:
- script:
name: Install packages
code: |
apt-get update --fix-missing
- install-packages:
packages: wget
- joshuamckenty/cloud-foundry-deploy:
api: $CF_API
username: $CF_USER
password: $CF_PASS
organization: $CF_ORG
space: $CF_SPACE
appname: pcf-<customer>-workshop-blue
alt_appname: pcf-<customer>-workshop-green
domain: cfapps.io
hostname: pcf-<customer>-workshop
````
You could create your own wercker app and target to PCF, or you could Update the wercker application https://app.wercker.com/#applications/56f1931f368950932900a530 to reflect the new branch and target deployment. I can add you quickly as a collaborator on this project and you can create your own custom target (PWS or Internal PCF) For this, send me a note (rajesh.jain@pivotal.io) to add to the wercker project.
Step 2: Add customer logo and update the config.toml
Get a customer logo and drop in the static/images folder Update the config.toml
````
baseurl = "http://pcf-<customer>-workshop.cfapps.io/"
.....
customer = "<customer>"
````
Step 3: Update intro.md
Update the content\post\intro.md with your workshop details.
Date, Location, Agenda, Speakers and Prerequisites
Step 4: Add Video/Slides
If you want to include youtube videos and slides (google or speakerdeck) add them as short-codes
See the example videos and slide includes a. Onsi's circle of code b. Josh Mckenty's PCF couple's therapy c. Intro to PCF Slidedeck d. Intro to PCF Google Slide
Step 5: Commit the changes and kick back and relax
Commit the changes to git and wercker takes off the code and deploy's to PCF. And voila you are done.
Learning Hugo and PCF Deployment process
In case you are interested in learning and testing the site locally here are the steps of how to install and configure Hugo. All this is automatically done by wercker above, so this is not required unless you want to learn hugo
Step 1: Getting started with Hugo
Go to https://github.com/spf13/hugo/releases and download Hugo for your operating system. If you are on Mac, the you can install using brew
package manager as well.
$ brew update && brew install hugo
Once hugo
is installed, make sure to run the help
command to verify hugo
installation. Below I am only showing part of the output of the help
command for brevity.
$ hugo help
hugo is the main command, used to build your Hugo site.
Hugo is a Fast and Flexible Static Site Generator
built with love by spf13 and friends in Go.
Complete documentation is available at http://gohugo.io/.
You can check hugo
version using the command shown below.
$ hugo version
Hugo Static Site Generator v0.15 BuildDate: 2015-11-26T11:59:00+05:30
Step 2: Clone this Website to get the Workshop website
$ git clone https://github.com/stwomack/pcf-hugo-workshop
Step 3: Build the website and test it locally
Hugo has inbuilt server that can serve content so that you can preview it. You can also use the inbuilt Hugo server in production as well. To serve content, execute the following command.
$ cd pcf-hugo-workshop
$ hugo server --buildDrafts
1 of 1 draft rendered
0 future content
1 pages created
0 paginator pages created
0 tags created
0 categories created
in 6 ms
Watching for changes in /Users/swomack/pcf-hugo-workshop/{data,content,layouts,static}
Serving pages from memory
Web Server is available at http://localhost:1313/ (bind address 127.0.0.1)
Press Ctrl+C to stop
Step 4: Push it to cloud foundry
$cf push
Step 5: Add content
Anytime you make changes in the content, delete the public directory, hugo will rebuild the directory.
Let's now add a post to our workshop
. We will use the hugo new
command to add a post.
$ hugo new post/lab-1.md
The above command will create a new directory post
inside the content
directory and create lab-1.md
file inside it.
$ tree -a content
content
`-- post
`-- lab-1.md
1 directory, 1 file
The content inside the lab-1.md
looks like as shown below.
+++
date = "2016-02-14T16:11:58+05:30"
draft = true
title = "lab-1"
+++
The content inside +++
is the TOML configuration for the post. This configuration is called front matter. It enables you to define about the post along with the content. Every post has three configuration properties shown above.
- date specifies the date and time at which post was created.
- draft specifies that post is not ready for publication yet so it will not be in the generated site
- title specifies title for the post
Let's add some content for Lab-1 .
+++
date = "2016-02-14T16:11:58+05:30"
draft = true
title = "Lab-1 Content"
+++
You can add Categories, Tags and Weight. The theme material-design in this repo has been modified to add new partials for different type of content.
Categories = ["lab"]
Tags = ["cf","microservices","cloudfoundry"]
date = "2016-03-15T14:54:11-04:00"
title = "Lab 1: Build and Deploy Apps on PCF"
weight = 2
Example if the categories is lab, the index.html will use the themes\material-design\partials\labs.html
Step 6: Make new partials and CSS
If you want to add new partials in Hugo theme, you and add them in the themes<theme>\partials directory.
{{ $baseurl := .Site.BaseURL }}
<div class="col s6">
<div class="card-panel hoverable blue-grey darken-1">
<div class="card-content white-text">
<!-- Card Content -->
<h4><a href="{{ .Permalink }}">{{ .Title }}</a></h4>
<p>{{ .Summary }}</p>
<p>
{{if .Params.tags }}
{{ range $index, $tag := .Params.tags }}
<a href="{{$baseurl}}/tags/{{ $tag | urlize }}/">#{{ $tag }}</a>
{{ end }}
{{end}}
</p>
</div>
</div>
</div>
If you want new colors for you cards, then you can refer to the Material Design CSS Color cards and change them
<div class="card-panel hoverable blue-grey darken-1">
<div class="card-content white-text">
Or
<div class="card-panel hoverable blue-grey darken-1">
<div class="card-content white-text">
You can also add completely new themes, but you will have to modify the config.toml, index.html, shortcodes, header.html to carry forward those changes.
Step 7: Make posts public
New posts we have written are in draft status. To make a draft public, you can either run a command or manually change the draft status in the post to True.
$ hugo undraft content/post/lab-1.md
Now, you can start the server without buildDrafts
option.
$ hugo server --theme=material-design
Step 8: Generate website in public folder
To generate Hugo website code that you can use to deploy your website, type the following command.
$ hugo --theme=material-design
0 draft content
0 future content
5 pages created
2 paginator pages created
0 tags created
0 categories created
in 17 ms
After you run the hugo command, a public directory will be created with the generated website source.
Step 8: Deploy to Cloud foundry
Create a Staticfile in public folder before pushing to Cloud Foundry.
$touch public/Staticfile
$cf push
Make sure you commit all your changes back to the git repo.
$ git add --all
$ git commit -am "New Content Added"
$ git push origin master
In couple of minutes, your website will be live https://pcf-hugo-workshop.cfapps.io