Skip to content

Commit

Permalink
jekyll build from Action ad9770c
Browse files Browse the repository at this point in the history
  • Loading branch information
jodygarnett committed Aug 5, 2023
0 parents commit 12e9228
Show file tree
Hide file tree
Showing 1,308 changed files with 423,297 additions and 0 deletions.
Empty file added .nojekyll
Empty file.
573 changes: 573 additions & 0 deletions 2006/11/17/about.html

Large diffs are not rendered by default.

561 changes: 561 additions & 0 deletions 2006/11/22/geoserver.html

Large diffs are not rendered by default.

588 changes: 588 additions & 0 deletions 2006/11/27/client-applications.html

Large diffs are not rendered by default.

628 changes: 628 additions & 0 deletions 2006/11/27/the-wfs-and-wms-services.html

Large diffs are not rendered by default.

648 changes: 648 additions & 0 deletions 2006/11/27/why-us-open-source.html

Large diffs are not rendered by default.

573 changes: 573 additions & 0 deletions 2006/11/27/why-use-open-standards.html

Large diffs are not rendered by default.

565 changes: 565 additions & 0 deletions 2008/09/09/near-south-africa-stop-by-foss4g.html

Large diffs are not rendered by default.

561 changes: 561 additions & 0 deletions 2008/09/22/geoserver-170-rc3-even-more-almost-there.html

Large diffs are not rendered by default.

581 changes: 581 additions & 0 deletions 2009/07/03/geoserver-175-critical-wms-patch.html

Large diffs are not rendered by default.

563 changes: 563 additions & 0 deletions 2009/08/26/geoserver-and-jboss-5-x.html

Large diffs are not rendered by default.

561 changes: 561 additions & 0 deletions 2009/11/12/a-mailing-list-for-japanese-users.html

Large diffs are not rendered by default.

Large diffs are not rendered by default.

582 changes: 582 additions & 0 deletions 2011/06/06/getting-a-job-with-geoserver.html

Large diffs are not rendered by default.

569 changes: 569 additions & 0 deletions 2011/06/08/geoserver-may-switch-to-java-6.html

Large diffs are not rendered by default.

615 changes: 615 additions & 0 deletions 2012/06/04/geoserver-2-1-4-released.html

Large diffs are not rendered by default.

581 changes: 581 additions & 0 deletions 2012/09/03/geoserver-2-2-rc3-released.html

Large diffs are not rendered by default.

565 changes: 565 additions & 0 deletions 2012/10/16/what-browsers-do-you-use-with-geoserver.html

Large diffs are not rendered by default.

588 changes: 588 additions & 0 deletions 2012/10/24/geoserver-2-2-1-released.html

Large diffs are not rendered by default.

577 changes: 577 additions & 0 deletions 2012/10/30/month-in-review-october-2012.html

Large diffs are not rendered by default.

605 changes: 605 additions & 0 deletions 2012/12/24/geoserver-2-2-3-released.html

Large diffs are not rendered by default.

623 changes: 623 additions & 0 deletions 2013/01/23/geoserver-2-2-4-released.html

Large diffs are not rendered by default.

711 changes: 711 additions & 0 deletions 2013/01/29/geoserver-2-3-beta-released.html

Large diffs are not rendered by default.

614 changes: 614 additions & 0 deletions 2013/03/18/geoserver-2-3-0-released-first-official-osgeo-release.html

Large diffs are not rendered by default.

612 changes: 612 additions & 0 deletions 2013/04/23/geoserver-2-3-1-released.html

Large diffs are not rendered by default.

565 changes: 565 additions & 0 deletions 2013/05/03/geoserver-training-in-milan-67-june-2013.html

Large diffs are not rendered by default.

569 changes: 569 additions & 0 deletions 2013/05/13/new-geoserver-community-on-google.html

Large diffs are not rendered by default.

584 changes: 584 additions & 0 deletions 2013/05/20/geoserver-2-3-2-released.html

Large diffs are not rendered by default.

572 changes: 572 additions & 0 deletions 2013/05/28/job-offer-geoserver.html

Large diffs are not rendered by default.

583 changes: 583 additions & 0 deletions 2013/07/23/geoserver-bug-fix-online-code-sprint-this-friday.html

Large diffs are not rendered by default.

646 changes: 646 additions & 0 deletions 2013/08/19/geoserver-2-4-rc1-released.html

Large diffs are not rendered by default.

659 changes: 659 additions & 0 deletions 2013/11/19/geoserver-2-4-2-released.html

Large diffs are not rendered by default.

Large diffs are not rendered by default.

651 changes: 651 additions & 0 deletions 2014/01/21/geoserver-2-5-beta-released.html

Large diffs are not rendered by default.

658 changes: 658 additions & 0 deletions 2014/07/23/geoserver-2-5-2-release.html

Large diffs are not rendered by default.

592 changes: 592 additions & 0 deletions 2014/07/25/geoserver-sunday-sprint-foss4g.html

Large diffs are not rendered by default.

667 changes: 667 additions & 0 deletions 2014/10/01/geoserver-at-foss4g.html

Large diffs are not rendered by default.

664 changes: 664 additions & 0 deletions 2014/10/24/geoserver-2-5-3-released.html

Large diffs are not rendered by default.

634 changes: 634 additions & 0 deletions 2014/11/18/geoserver-2-6-1-released.html

Large diffs are not rendered by default.

634 changes: 634 additions & 0 deletions 2015/01/20/geoserver-2-6-2-released.html

Large diffs are not rendered by default.

636 changes: 636 additions & 0 deletions 2015/03/23/cite-tests-at-foss4g-na.html

Large diffs are not rendered by default.

592 changes: 592 additions & 0 deletions 2015/11/21/geoserver-code-sprint-2016.html

Large diffs are not rendered by default.

680 changes: 680 additions & 0 deletions 2016/11/14/the-new-and-improved-geoserver-style-editor.html

Large diffs are not rendered by default.

616 changes: 616 additions & 0 deletions 2018/09/24/java-2018-code-sprint.html

Large diffs are not rendered by default.

747 changes: 747 additions & 0 deletions 2019/01/03/java-2018-code-sprint-results.html

Large diffs are not rendered by default.

606 changes: 606 additions & 0 deletions 2019/09/18/join-me-in-funding-an-important-geoserver-initiative.html

Large diffs are not rendered by default.

596 changes: 596 additions & 0 deletions 2019/11/14/cite-test-automation-request-for-proposal.html

Large diffs are not rendered by default.

1 change: 1 addition & 0 deletions CNAME
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
geoserver.org
275 changes: 275 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,275 @@
# http://geoserver.org

This repository contains the source for the GitHub generated [GeoServer home page](http://geoserver.org/).

## Reporting issues

If you stumble into any issue with the GeoServer web site please report it in our [Jira issue tracker](https://osgeo-org.atlassian.net/projects/GEOS/summary) using the ``website`` component.

## Developing

The site is built with [Jekyll](https://github.com/jekyll/jekyll):

#. Before you start:

gem install bundler jekyll jekyll-feed jekyll-paginate jekyll-sitemap

If anything is missed:

bundle install

On macOS with apple silicon:

bundle update ffi

#. Jekyll can be run in "watch" mode for development:

bundle exec jekyll serve --watch

The site contents will be served at [http://localhost:4000](http://localhost:4000).

See [TEST.md](TEST.md) for more details.

#. Commit to ``main`` branch and the result is published to http://geoserver.org

## Blog

Blog posts are managed as part of the website.

To create a new blog post:

1. Create a new markdown page in ``_posts`` following the filename convention for sort order:

``_posts/2021-05-04-may-the-fork-be-with-you.md``

2. The post is published using the metadata included at the top of your file.

```
---
author: Andrea Aime
date: 2021-05-04
layout: post
title: May the fork be with you!
categories:
- Developer notes
---
```

3. Popular categories include:

* ``Developer notes``
* ``Announcements`` -- used for project team and release announcements
* ``Tips and Tricks``
* ``Tutorials``
* ``User perspectives``

## Releases

When a release is performed, the site contents are updated to reflect the new release. Below is the
process of updating site contents for a stable release.

1. Write a blog post announcing the new release:

```
cd bin
python3 announcement.py username password 2.23.2 --geotools 29.2 --geowebcache 1.23.2
```

A post is generated to stdout for your review.

If everything looks good generate a post using (the date for the generated post is supplied by Jira):

```
python3 announcement.py username password 2.23.2 --geotools 29.2 --geowebcache 1.23.2 --post
```

See [script instructions](bin/README.md) for more information.

2. Release posts have the following format

```
---
author: Andrea Aime
layout: post
title: GeoServer 2.19.3 Released
categories:
- Announcements
tags:
- Release
release: release_219
version: 2.19.3
jira_version: 16816
---
```
The following information is used to generate a ``release/<version>/index.html`` page:

* ``release``: This is the `_layout` used for the generated release page

* Tags are used to indicate ``Release``, ``Release Candidate``, ``Milestone``.

The ``Vulnerability`` tag is used to highlight blog posts and release announcements covering a security topic.

* ``version``: The GeoServer version being announced

* ``jira_version``: Used to link to the release notes

The value for ``jira_version`` can be found by navigating to that version on [Jira](https://osgeo-org.atlassian.net/projects/GEOS?selectedItem=com.atlassian.jira.jira-projects-plugin:release-page) and examining the URL. For example, for example, ``2.7.2`` links to ``https://osgeo-org.atlassian.net/projects/GEOS/versions/10601``, giving a ``jira_version`` of ``10601``. For a maintenance or development release, instead modify ``release/maintain/index.html`` or ``release/dev/index.html`` respectively.

3. Check one of the previous blog posts so we end up with a consistent format.

* GeoTools and GeoWebCache version numbers will need to be supplied on the command line
* Check the "about section" at end of post with links to documentation / proposals / presentations

4. Update ``_config.yml`` (this change will be reflected in ``index.html`` and ``download/index.html``):

* Update ``stable_jira`` to be the same as the next release, this is used for the Nightly build page.

```
stable_jira: 16821
```

* For a maintenance instead change ``maintain_jira``.

```
maintain_jira: 16819
```

### Dev Releases

When publishing the first milestone, beta or release candidate for a series:

1. Create a new ``_layouts/release_<version>.html`` template by copying the previous template and adding an entry for any new extensions that have been released on the new branch.

This is the value used for ``release`` when making your announcement blog posts.

Create ``bin/templates/about_XXX.md`` highlighting new features.

2. Update ``_config.yml`` update ``dev_series`` and ``dev_branch``, the matching release announcement post will be used to generate `release/dev/index.html` page.

```
dev_series: 2.21.x
dev_branch: 2.21.x
```

3. Update the `main_series`, and `main_jira` to reflect the new version number for `main` branch, this will be used to generate a placeholder for `release/main/index.html` page.
```
main_series: 2.22.x
main_jira: 16829
```

### Final Release

When creating the final release:

1. Update the ``_config.yml`` properties:

* Update the `maintain_branch` using the values from `stable`.
* Update the `stable_branch`.

2. Update the `main_series` and `main_series` information. For example, when starting the series `2.22.x`:

```
main_series: 2.22.x
main_jira: 16829_
```

3. The ``dev_series`` and ``dev_branch`` property in ``_config.yml`` to the new series, these will no longer match any posts as the development period is over:

```
dev_series: main
dev_branch: 2.22.x
```

## Technical Details

### Jekyll Build

The Jekyll build process [goes through several steps](https://jekyllrb.com/tutorials/orderofinterpretation/):

1. The file `_config.yml` is parsed into [Jekyll::Site](https://github.com/jekyll/jekyll/blob/master/lib/jekyll/site.rb)

* ``site.data``

1. Makes an inventory of existing content:

* ``site.pages`` contains instances of [Jekyll::Page](https://github.com/jekyll/jekyll/blob/master/lib/jekyll/page.rb) for each page (and post) defined.

* ``site.static_files`` contains [Jekyll::StaticFile](https://github.com/jekyll/jekyll/blob/master/lib/jekyll/static_file.rb)

2. Our custom plugin `_plugins/release.rb` generator is run:

* Processes the posts in ``site.pages``, add additional [Jekyll::PageWithoutAFile](https://github.com/jekyll/jekyll/blob/master/lib/jekyll/page_without_a_file.rb) entries to ``site.pages``
* Creates a ``site.data.releases`` data structure listing all the releases found for use by the `download/index.html` page.

3. Additional plugins are run:

* jekyll-feed: generates an Atom feed of all the posts
* jekyll-sitemap: generates a sitemap of all the pages
* jekyll-paginate: uses `_blog/index.html` as a template to generate `page2.html`, `page3.html`, ... `page80.html`

4. At this point all the ``site.pages`` are created each containing:

* ``page.title``
* ``page.content``
* ``page.url``
* ``page.date``
* ``page.id``
* ``page.dir``
* ``page.name``
* ``page.data`` provided by front-matter at the top of the file

Release pages have:

* ``page.data.version``
* ``page.data.jira_version``
* ``page.data.release_date``
* ``page.data.announce``

4. Jekyll process any pages with [Liquid](https://jekyllrb.com/docs/liquid/) into static files in the `_site` folder.

* Variable reference use ``{{`` and ``}}``:

```
Download the latest [GeoServer {{site.stable_version}}](/release/stable/index.html) release.
```
* Variable filters use ``|`` pipe character to define a processing chain:

```
Released {{ page.date | date_to_long_string }}.
```

* Tags used to define control flow:

```
{% for release in site.data.releases | where: "series", "2.19" %}
{{ release.version }}
{% endfor %}
```

Here is a decent [cheatsheet](https://gist.github.com/JJediny/a466eed62cee30ad45e2) for reference.

### Publishing

Commit to `main` and the result is published.

Technical details:

1. Commit to the `main` branch.

2. Workflow [.github/workflows/build-jekyll.yml](.github/workflows/build-jekyll.yml) action is triggered.

* Uses ``ubuntu-latest`` environment

* Uses [JEKYLL DEPLOY ACTION](https://github.com/jeffreytse/jekyll-deploy-action)

* Runs Jekyll build to generate static files (just like normal)

* Commits the resulting static files to the [gh-pages](https://github.com/geoserver/geoserver.github.io/tree/gh-pages) branch

3. GitHub pages settings is configured to publish the `gh-pages` branch to `https://geoserver.github.io`.

* The CNAME `geoserver.org` is used but we have yet to obtain the domain from Planet Federal.

The content is available as the https:/geoserver.org website
21 changes: 21 additions & 0 deletions TEST.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
Testing the site locally
------------------------

It is possible to test the web site before committing, full instructions available here: [Testing your GitHub Pages site locally with Jekyll](
https://docs.github.com/en/github/working-with-github-pages/testing-your-github-pages-site-locally-with-jekyll)

If you have already installed all the dependencies, just run:

```
bundle exec jekyll serve --watch
```

Then navigate to [http://localhost:4000](http://localhost:4000).

Not finding the blog post you just wrote? It could be, because it's labelled for a future date (and you are preparing in advance).
If that's the case, it can be shown by adding ``--future`` to the jekyll startup:

```
bundle exec jekyll serve --watch --future
```

Loading

0 comments on commit 12e9228

Please sign in to comment.