Welcome to Open Liberty! In order to contribute a guide for Open Liberty, follow the steps in this README.
-
Install Git and become familiar with the Git triangular workflow.
-
Install a text editor with the AsciiDoc compiler plugin and learn the syntax of AsciiDoc.
Use the guides on openliberty.io as examples.
If you’re not sure where to start, try the Creating a RESTful web service guide followed by the Injecting dependencies into microservices guide.
-
Know your audience!
-
If the guide is introductory, explain the basic concepts of the technology. At the same time, try to avoid overwhelming the reader with too much information. If you’re not sure if you’ve included the correct amount of info, consider asking a new user to try your guide.
-
-
Know the guide structure and the writing styles!
-
Take a look at the Guidelines for Structure and Styles.
-
-
Clone the
guides-template
to your own workspace. -
Develop your guide in your own workspace.
-
Develop code and write tests that are based on the project structure in the
guides-template
. To start, create your project in thefinish
directory. Make a simple application that demonstrates how to use your topic. -
Copy the code from the
finish
directory to thestart
directory. Then, from the copy in thestart
directory, remove the code that you want the user to focus on. -
Write a guide that follows the
README.adoc
template (APPENDIX A) in theguides-template
repository. Introduce and explain the parts of code that you removed during the last step and tell the users where to copy and paste the code. Walk through how to build thefinish
directory, run the tests, and perform any other steps that users need to run your project on their own.
-
-
Before proceeding further, you should review the checklist.
-
Open a new issue in the guides-commons repository. Describe the topic you wrote, add a link to the repository that contains the complete draft of your guide, and the Open Liberty team will be notified.
-
You must sign the Individual Contributor License Agreement (CLA) in order to contribute. If you are writing the guide as part of your job, you might also want your employer to sign a Corporate Contributor License Agreement (CCLA). Instructions for how to sign and submit these agreements are provided in each document. You should send your signed CLA document (in PDF) to the email address cla@openliberty.io before you move on to the next step.
-
After the Open Liberty team approves your guide and obtains your signed CLA, they will create a draft guide repository in the Open Liberty GitHub for you. Your new repository will be named as
draft-guide-{projectid}
. Then, you can open a pull request that contains your commits for the guide, and the team will be notified for review.
-
You can see your feedback from the
Issues
section in yourdraft-guide-{projectid}
repository when it’s ready. -
Follow up with the team’s review discussions.
Please remove all the instructions before APPENDIX A
prior to commit. Most comments should be removed, although not the copyright.
// INSTRUCTION: The copyright statement must appear at the top of the file
//
// Copyright (c) 2018 IBM Corporation and others.
// Licensed under Creative Commons Attribution-NoDerivatives
// 4.0 International (CC BY-ND 4.0)
// https://creativecommons.org/licenses/by-nd/4.0/
//
// Contributors:
// IBM Corporation
//
:page-layout: guide
// INSTRUCTION: The project id is the part of the git repository after the guide- and must be specified
// :projectid: github repo name without the `guide-` prefix
:projectid: template
// INSTRUCTION: Provide an estimate of how long the guide will take to go through.
:page-duration: 15 minutes
// INSTRUCTION: Provide the date when the guide is published. Format is YYYY-MM-DD.
:page-releasedate: 2018-05-14
// INSTRUCTION: Provide a description for the guide index page.
:page-description: Learn how to create a todo list API as a REST service using JAX-RS, and Open Liberty.
// INSTUCTION: Please provide relevant tags, try to avoid inventing new ones.
:page-tags: ['REST', 'Getting Started', 'CDI', 'JAX-RS']
// INSTRUCTION: Specify the unique name of the guide that is used in the permalink.
:page-related-guides: ['cdi-intro', 'rest-intro']
// INSTRUCTION: Specify the slug in the website. This must be unique.
:page-permalink: /guides/{projectid}
// INSTRUCTION: Source the common page elements, clone git@github.com:OpenLiberty/guides-common.git.
:common-includes: https://raw.githubusercontent.com/OpenLiberty/guides-common/master
// INSTRUCTION: You can't have a new line between the attributes and the title.
= Title of guide, starting with a gerund (Creating, Administering, and so on)
// EXAMPLE: Creating a REST API for a todo list application
[.hidden]
NOTE: This repository contains the guide documentation source. To view the guide in published form, view it on the https://openliberty.io/guides/{projectid}.html[Open Liberty website].
// Start the introduction with "You'll explore how to..." or something similarly catchy.
// Write no more than two sentences, with meaningful information on what the user can accomplish
// with this guide.
// Do not start the introduction with "This guide...".
// EXAMPLE: Learn how to create a todo list API as a REST service using JAX-RS, CDI, and Open Liberty.
== What you'll learn
// Write about what the user will learn in a meaningful intro paragraph.
// Follow the intro paragraph with more details of what the user will learn, but still keep it brief.
// See the REST guide at as an exemplar guide.
// https://openliberty.io/guides/rest-intro.html
// https://github.com/OpenLiberty/guide-rest-intro
== Getting started
// Add this getting started section to your guide if it is applicable.
// Use the following include to pull in the git clone instructions from the guides-common repo.
include::{common-includes}/gitclone.adoc[]
=== Try what you’ll build
// This is a subsection of the "Getting started" section above. It should briefly walk the user
// through how to setup everything in the "finish" directory and try out the finished version of
// what they will be building.
include::{common-includes}/trywhatyoubuild-intro.adoc[]
// Brief explanation on how to use the finished application.
// Describe what user expects to see after running the complete version of the application.
include::{common-includes}/trywhatyoubuild-end.adoc[]
== Section title for this section, starting with a gerund like Creating, Building, etc
// Add the various sections that are needed for a particular guide.
// Start each additional section title with a meaningful gerund such as Creating, Building, Testing.
// Follow the gerund with a meaningful noun phrase. For example: Creating a JAX-RS application
// Have as many sections and section titles as needed.
// EXAMPLE: * Learning to use JAX-RS and CDI
// EXAMPLE: * Learning how to build a REST service for a todo list application
// Write a sentence with the context like "Navigate to the `start` directory to begin." in the section
// where user starts working with the implementation.
// What to add for each section:
// Start each section with a meaningful description about what the user is doing in the section.
// Include code snippets.
// Avoid making all the documentation a series of steps and tasks, bullets, or numbered lists.
// Use tick marks around directories, files, values, class names, method names, and so on.
// Example: `this-is-a-file`, `this/is/a/path`, `thisIsAMethod`.
// EXAMPLE: The following block demostrates how different sections look like for a todo application.
======================================================================================================
== Building the model
* Navigate to the `start` directory
* Represent an entry in a todo list
Create the todo model class in the
`src/main/java/io/openliberty/guides/todolistSample/models/TodoModel.java` file:
[source, Java]
----
link:finish/src/main/java/io/openliberty/guides/todolistSample/models/TodoModel.java[role=include]
----
* Getters, setters, and default constructor such that the model can be serialized/deserialized easily
== Creating the Manager
* Create a manager that is injected into the JAX-RS resource
Create the todo manager interface in the
`src/main/java/io/openliberty/guides/todo/managers/TodoManager.java` file:
[source, Java]
----
link:finish/src/main/java/io/openliberty/guides/todolistSample/managers/TodoManager.java[role=include]
----
Next, create the sample todo manager class in the
`src/main/java/io/openliberty/guides/todolistSample/managers/samples/SampleTodoManager.java` file:
[source, Java]
----
link:finish/src/main/java/io/openliberty/guides/todo/managers/samples/SampleTodoManager.java[role=include]
----
* Implemented basic CRUD (Create, Read, Update, and Delete) operations.
* Manager is ApplicationScoped, which essentially means that it is a singleton.
== Creating the JAX-RS resource
* Description of the technology, possibly with a link to learn more.
* Use CDI to inject the todo manager into the resource
Create the todo resource class in the
`src/main/java/io/openliberty/guides/todolistSample/resources/TodoResource.java` file:
[source, Java]
----
link:finish/src/main/java/io/openliberty/guides/todolistSample/resources/TodoResource.java[role=include]
----
* The resource methods are accessible via HTTP
* Use GET, POST, PUT, and DELETE verbs to handle reading, creating, updating, and deleting resources
* Validate data models and send appropriate response accordingly
======================================================================================================
== Building and running the application
// Use the following include to pull in the Maven build instructions from the guides-common repo.
include::{common-includes}/mvnbuild.adoc[]
// In between here, you should state where you application can be found now that its running. ie. urls
// Sample usage of the application
// Suggestions for what changes the reader can make to explore the code
// Use the following include to pull in the Maven rebuild instructions from the
// guides-common repo.
include::{common-includes}/mvncompile.adoc[]
== Testing the application
// Show how to test your application.
// EXAMPLE:
======================================================================================================
Create the todo test class in the
`finish/src/test/java/it/io/openliberty/guides/todo/TodoTest.java` file:
[source, Java]
----
link:finish/src/test/java/it/io/openliberty/guides/todo/TodoTest.java[role=include]
----
* Explain what each test case is testing
* Explain key methods
======================================================================================================
// Include this for info on how to run the tests
include::{common-includes}/mvnverify.adoc[]
// Including a listing block with test results here
// Show console output of the test results
// OPTIONAL: after listing the test results, mention a simple change a user can make/introduce that
// will cause the tests to fail. Be brief and don't give the users all of the instructions.
// At this point, they should be comfortable enough to figure it out on their own.
== Great work! You're done!
// Briefly summarize what the user achieved in this guide (1-2 sentences).
// OPTIONAL: briefly state what the user could do next now that they've learned the
// technologies in this guide.
// Include the below from the guides-common repo to tell users how they can contribute to the guide
include::{common-includes}/finish.adoc[]
// DO NO CREATE ANYMORE SECTIONS AT THIS POINT
// Related guides will be added in automatically here if you included them in ":page-related-guides"