Merge pull request #24 from brendandburns/docs
Add a generic client (read-only for now)
This commit is contained in:
1
examples/generic/.gitignore
vendored
Normal file
1
examples/generic/.gitignore
vendored
Normal file
@@ -0,0 +1 @@
|
|||||||
|
generic_bin
|
||||||
8
examples/generic/Makefile
Normal file
8
examples/generic/Makefile
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
INCLUDE:=-I../../kubernetes/include -I../../kubernetes/model -I../../kubernetes/api -I../../kubernetes/config
|
||||||
|
LIBS:=-L../../kubernetes/build -lkubernetes -lcurl -lyaml -lpthread -lssl -lz
|
||||||
|
CFLAGS:=-g
|
||||||
|
|
||||||
|
all:
|
||||||
|
gcc main.c $(CFLAGS) $(INCLUDE) $(LIBS) -o generic_bin
|
||||||
|
clean:
|
||||||
|
rm ./generic_bin
|
||||||
44
examples/generic/main.c
Normal file
44
examples/generic/main.c
Normal file
@@ -0,0 +1,44 @@
|
|||||||
|
#include <kube_config.h>
|
||||||
|
#include <apiClient.h>
|
||||||
|
#include <generic.h>
|
||||||
|
#include <malloc.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <errno.h>
|
||||||
|
|
||||||
|
int main(int argc, char *argv[])
|
||||||
|
{
|
||||||
|
char *basePath = NULL;
|
||||||
|
sslConfig_t *sslConfig = NULL;
|
||||||
|
list_t *apiKeys = NULL;
|
||||||
|
int rc = load_kube_config(&basePath, &sslConfig, &apiKeys, NULL); /* NULL means loading configuration from $HOME/.kube/config */
|
||||||
|
if (rc != 0) {
|
||||||
|
printf("Cannot load kubernetes configuration.\n");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
apiClient_t *apiClient = apiClient_create_with_base_path(basePath, sslConfig, apiKeys);
|
||||||
|
if (!apiClient) {
|
||||||
|
printf("Cannot create a kubernetes client.\n");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
genericClient_t *genericClient = genericClient_create(apiClient, "apps", "v1", "deployments");
|
||||||
|
|
||||||
|
char *list = Generic_listNamespaced(genericClient, "default");
|
||||||
|
printf("%s\n", list);
|
||||||
|
free(list);
|
||||||
|
|
||||||
|
char *result = Generic_readNamespacedResource(genericClient, "default", "camera-gc");
|
||||||
|
printf("%s\n", result);
|
||||||
|
free(result);
|
||||||
|
|
||||||
|
genericClient_free(genericClient);
|
||||||
|
genericClient = NULL;
|
||||||
|
apiClient_free(apiClient);
|
||||||
|
apiClient = NULL;
|
||||||
|
free_client_config(basePath, sslConfig, apiKeys);
|
||||||
|
basePath = NULL;
|
||||||
|
sslConfig = NULL;
|
||||||
|
apiKeys = NULL;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
@@ -41,6 +41,7 @@ set(SRCS
|
|||||||
src/apiKey.c
|
src/apiKey.c
|
||||||
src/apiClient.c
|
src/apiClient.c
|
||||||
src/binary.c
|
src/binary.c
|
||||||
|
src/generic.c
|
||||||
external/cJSON.c
|
external/cJSON.c
|
||||||
model/object.c
|
model/object.c
|
||||||
model/admissionregistration_v1_service_reference.c
|
model/admissionregistration_v1_service_reference.c
|
||||||
|
|||||||
22
kubernetes/include/generic.h
Normal file
22
kubernetes/include/generic.h
Normal file
@@ -0,0 +1,22 @@
|
|||||||
|
#ifndef __GENERIC_H__
|
||||||
|
#define __GENERIC_H__
|
||||||
|
|
||||||
|
#include "../include/apiClient.h"
|
||||||
|
|
||||||
|
typedef struct genericClient_t {
|
||||||
|
apiClient_t *client;
|
||||||
|
char *apiGroup;
|
||||||
|
char *apiVersion;
|
||||||
|
char *resourcePlural;
|
||||||
|
} genericClient_t;
|
||||||
|
|
||||||
|
genericClient_t* genericClient_create(apiClient_t *client, const char *apiGroup, const char* apiVersion, const char* resourcePlural);
|
||||||
|
void genericClient_free(genericClient_t* client);
|
||||||
|
|
||||||
|
char* Generic_readNamespacedResource(genericClient_t *client, const char *ns, const char *name);
|
||||||
|
char* Generic_readResource(genericClient_t *client, const char *name);
|
||||||
|
|
||||||
|
char* Generic_listNamespaced(genericClient_t *client, const char *ns);
|
||||||
|
char* Generic_list(genericClient_t *client);
|
||||||
|
|
||||||
|
#endif
|
||||||
91
kubernetes/src/generic.c
Normal file
91
kubernetes/src/generic.c
Normal file
@@ -0,0 +1,91 @@
|
|||||||
|
#include "../include/apiClient.h"
|
||||||
|
#include "../include/generic.h"
|
||||||
|
|
||||||
|
genericClient_t* genericClient_create(apiClient_t *client, const char *apiGroup, const char* apiVersion, const char* resourcePlural) {
|
||||||
|
genericClient_t *result = malloc(sizeof(genericClient_t));
|
||||||
|
result->client = client;
|
||||||
|
result->apiGroup = strdup(apiGroup);
|
||||||
|
result->apiVersion = strdup(apiVersion);
|
||||||
|
result->resourcePlural = strdup(resourcePlural);
|
||||||
|
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
void genericClient_free(genericClient_t* client) {
|
||||||
|
free(client->apiGroup);
|
||||||
|
free(client->apiVersion);
|
||||||
|
free(client->resourcePlural);
|
||||||
|
free(client);
|
||||||
|
}
|
||||||
|
|
||||||
|
void makeNamespacedResourcePath(char* path, genericClient_t *client, const char* namespace, const char* name) {
|
||||||
|
snprintf(
|
||||||
|
path, 128,
|
||||||
|
"/apis/%s/%s/namespaces/%s/%s/%s",
|
||||||
|
client->apiGroup,
|
||||||
|
client->apiVersion,
|
||||||
|
namespace,
|
||||||
|
client->resourcePlural,
|
||||||
|
name
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
void makeResourcePath(char* path, genericClient_t *client, const char* name) {
|
||||||
|
snprintf(
|
||||||
|
path, 128,
|
||||||
|
"/apis/%s/%s/%s/%s",
|
||||||
|
client->apiGroup,
|
||||||
|
client->apiVersion,
|
||||||
|
client->resourcePlural,
|
||||||
|
name
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
char* readInternal(genericClient_t *client, const char* path) {
|
||||||
|
apiClient_invoke(client->client, path, NULL, NULL, NULL, NULL, NULL, NULL, "GET");
|
||||||
|
|
||||||
|
if (client->client->response_code == 200) {
|
||||||
|
printf("%s\n","OK");
|
||||||
|
}
|
||||||
|
if (client->client->response_code == 401) {
|
||||||
|
printf("%s\n","Unauthorized");
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
char* elementToReturn = strndup((char*)client->client->dataReceived, client->client->dataReceivedLen);
|
||||||
|
|
||||||
|
if (client->client->dataReceived) {
|
||||||
|
free(client->client->dataReceived);
|
||||||
|
client->client->dataReceived = NULL;
|
||||||
|
client->client->dataReceivedLen = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
return elementToReturn;
|
||||||
|
}
|
||||||
|
|
||||||
|
char* Generic_readNamespacedResource(genericClient_t *client, const char *namespace, const char *name) {
|
||||||
|
char path[128];
|
||||||
|
|
||||||
|
makeNamespacedResourcePath(path, client, namespace, name);
|
||||||
|
return readInternal(client, path);
|
||||||
|
}
|
||||||
|
|
||||||
|
char* Generic_readResource(genericClient_t *client, const char *name) {
|
||||||
|
char path[128];
|
||||||
|
|
||||||
|
makeResourcePath(path, client, name);
|
||||||
|
return readInternal(client, path);
|
||||||
|
}
|
||||||
|
|
||||||
|
char *Generic_listNamespaced(genericClient_t *client, const char *namespace) {
|
||||||
|
char path[128];
|
||||||
|
snprintf(path, 128, "/apis/%s/%s/namespaces/%s/%s",
|
||||||
|
client->apiGroup, client->apiVersion, namespace, client->resourcePlural);
|
||||||
|
readInternal(client, path);
|
||||||
|
}
|
||||||
|
|
||||||
|
char *Generic_list(genericClient_t *client) {
|
||||||
|
char path[128];
|
||||||
|
snprintf(path, 128, "/apis/%s/%s", client->apiGroup, client->apiVersion, client->resourcePlural);
|
||||||
|
readInternal(client, path);
|
||||||
|
}
|
||||||
|
|
||||||
Reference in New Issue
Block a user