Go Cookbook
Getting Started
To get started with the Go driver, visit the Github Page or Package Page to view the source code, tests and basic usage examples.
You can install the driver via the command line:
go get github.com/gitana/cloudcms-go-driver
Connecting to Gitana
There are two ways to connect with the Go driver: By finding a gitana.json
file in your working directory, or by providing a config configuration.
// Connect to Gitana using gitana.json in working directory
session, err := cloudcms.ConnectDefault()
session, err := cloudcms.Connect(&cloudcms.CloudcmsConfig{
Client_id: "clientId",
Client_secret: "clientSecret",
Username: "username",
Password: "password",
BaseURL: "baseURL",
})
Code Samples
Here are some code samples to help you get started. In these scenarios, we assume you're using the most simple connection method (providing the path to gitana.json
).
In Gitana, you can have as many repositories as you'd like. And each repository can multiple branches (similar to Git). The first thing you should do is connect and get the branch that you want to work on.
For the purpose of most of these examples, we'll assume the repository ID is 1234567890abcdef1234
and the branch is master
.
Node creation
{
"title": "Custom Article",
"_qname": "custom:article",
"type": "object",
"properties": {
"title": {
"type": "string"
},
"body": {
"type": "string"
},
"categories": {
"type": "array",
"items": {
"type": "string"
}
},
"rating": {
"type": "number"
}
}
}
Create a content instance of this type like this:
session, _ := cloudcms.ConnectDefault()
repositoryId := "1234567890abcdef1234"
branchId := "master"
nodeObj := cloudcms.JsonObject{
"_type": "custom:article",
"title": "Article #1",
"body": "A still more glorious dawn awaits",
"categories": []string{
"category1",
"category2",
"category3",
},
"rating": 5,
}
node1Id, _ := session.CreateNode(repositoryId, branchId, nodeObj, nil)
Create a Folder
In Gitana, folders are just nodes with the f:container
feature on them. It must be associated to the root node to be considered part of file folder tree.
session, _ := cloudcms.ConnectDefault()
repositoryId := "1234567890abcdef1234"
branchId := "master"
nodeObj := cloudcms.JsonObject{
"title": "My Folder",
}
optsObj := cloudcms.JsonObject{
"parentPath": "/",
}
node := session.CreateNode(repositoryId, branchId, nodeObj, optsObj)
session.AddNodeFeature(repositoryId, branchId, nodeId, "f:container", JsonObject{})
Associations
In Gitana, any two nodes can be connected via an association. You can use an out-of-the-box association type, such as a:linked
or a:owned
or you can create your own.
Let's imagine that we have two articles that look like this:
- Article #1
{
"_doc": "1234567890abcdef1111",
"_type": "custom:article",
"title": "Article #1",
"body": "a mote of dust suspended in a sunbeam",
"categories": ["category1", "category2"],
"rating": 1
}
- Article #2
{
"_doc": "1234567890abcdef2222",
"_doc": "",
"_type": "custom:article",
"title": "Article #2",
"body": "harvesting star light",
"categories": ["category2", "category3"],
"rating": 2
}
Let's create an association that points from the first article (1234567890abcdef1111
) to the second article (1234567890abcdef2222
), like this:
session, _ := cloudcms.ConnectDefault()
repositoryId := "1234567890abcdef1234"
branchId := "master"
article1Id := "1234567890abcdef1111"
article2Id := "1234567890abcdef2222"
association, _ := session.Associate(repositoryId, branchId, article1Id, article2Id, "a:linked", "OUTGOING", nil)
You can also find all associations around article1
. This will include associations that are INCOMING
, OUTGOING
and MUTUAL
.
associations, err := session.ListNodeAssociations(repositoryId, branchId, node1Id, "", "", nil)
Or find only the INCOMING
associations:
associations, err := session.ListIncomingAssociations(repositoryId, branchId, node1Id, "", nil)
Or find only the OUTGOING
associations of type a:linked:
associations, err := session.ListOutgoingAssociations(repositoryId, branchId, node1Id, "a:linked", nil)
Query
Let's now look at querying for content. This makes use of MongoDB's query language to express some pretty powerful queries. We recommend further reading on Query Strings.
Let's assume that we have the following:
- Article #1
{
"_type": "custom:article",
"title": "Article #1",
"body": "a mote of dust suspended in a sunbeam",
"categories": ["category1", "category2"],
"rating": 1
}
- Article #2
{
"_type": "custom:article",
"title": "Article #2",
"body": "harvesting star light",
"categories": ["category2", "category3"],
"rating": 2
}
- Article 3
{
"_type": "custom:article",
"title": "Article #3",
"body": "we are star stuff",
"categories": ["category3", "category1"],
"rating": 3
}
Basic Querying
Find all of the nodes that have a category
with the value category1
.
session, _ := cloudcms.ConnectDefault()
repositoryId := "1234567890abcdef1234"
branchId := "master"
query := cloudcms.JsonObject{
"_type": "custom:article",
"category": "category1",
}
nodes, _ := session.QueryNodes(repositoryId, branchId, query, nil)
Pagination
If you have a lot of potential query hits, you'll want to paginate. Here is an example where we return results starting at index 2 and hand back at most 5 results.
session, _ := cloudcms.ConnectDefault()
repositoryId := "1234567890abcdef1234"
branchId := "master"
query := cloudcms.JsonObject{
"_type": "custom:article",
"category": "category1",
}
pagination := cloudcms.JsonObject{
"skip": 2,
"limit": 5,
}
nodes, _ := session.QueryNodes(repositoryId, branchId, query, pagination)
Sorting
Use the pagination option to sort the results as you see fit. Here we sort descending on rating
.
session, _ := cloudcms.ConnectDefault()
repositoryId := "1234567890abcdef1234"
branchId := "master"
query := cloudcms.JsonObject{
"_type": "custom:article",
"category": "category1",
}
pagination := cloudcms.JsonObject{
"sort": cloudcms.JsonObject{
"rating": -1
}
}
nodes, _ := session.QueryNodes(repositoryId, branchId, query, pagination)
Query for values in a range
Find all of the articles where the rating is greater than or equal to 2.
This demonstrates the power of MongoDB's query language.
session, _ := cloudcms.ConnectDefault()
repositoryId := "1234567890abcdef1234"
branchId := "master"
query := cloudcms.JsonObject{
"_type": "custom:article",
"rating": cloudcms.JsonObject{
"$gte": 2,
},
}
nodes, _ := session.QueryNodes(repositoryId, branchId, query, nil)
Search for Nodes
Let's now look at searching for content. This makes use of Elastic Search's DSL to express some very powerful full text and structured searches. We recommend further reading on Search within Gitana.
We also suggest reading up on Query Strings to understand how you can write searches textually (in addition to structuring them as JSON objects):
Let's assume that we have the following:
- Article #1
{
"_type": "custom:article",
"title": "Article #1",
"body": "a mote of dust suspended in a sunbeam",
"categories": ["category1", "category2"],
"rating": 1
}
- Article #2
{
"_type": "custom:article",
"title": "Article #2",
"body": "harvesting star light",
"categories": ["category2", "category3"],
"rating": 2
}
- Article 3
{
"_type": "custom:article",
"title": "Article #3",
"body": "we are star stuff",
"categories": ["category3", "category1"],
"rating": 3
}
Full Text Search
Find all of the nodes with the word star
. Simple enough!
session, _ := cloudcms.ConnectDefault()
repositoryId := "1234567890abcdef1234"
branchId := "master"
searchNodes, _ := session.SearchNodes(repositoryId, branchId, "star", nil)
GraphQL
You can make queries for specific fields or content in related items by using GraphQL. Here we do a simple query for just the title and body of our article type:
session, _ := cloudcms.ConnectDefault()
repositoryId := "1234567890abcdef1234"
branchId := "master"
query := `
query{
n_nodes {
title
}
}`
result, _ := session.GraphQLQuery(repositoryId, branchId, query, "", nil)