akinoncli 1.0.23

Creator: codyrutscher

Last updated:

Add to Cart

Description:

akinoncli 1.0.23

Akinon Cloud Commerce CLI
Akinon CLI is an application designed to manage projects and applications
in Akinon Cloud Commerce through a command line interface.
Installation
After installing python 3.8+, run the following command.
Then the Akinon CLI would be ready to be used.
$ pip install --user akinoncli

Usage
Every cloud commerce user is registered to an Account. For a fresh user an Account would be
created automatically. The authorized users who are registered to Account can create users
for the same Account using the CLI or UI. (Registration is not currently available on the CLI)
-h command argument can be used in order to know more about the command.
(Command's required parameters, information about what it does, etc.)
Example:
akinoncli user -h

Commands
Authentication
In order to use Akinon CLI, the user must authenticate first.


akinoncli login

Authentication is achieved by submitting e-mail and password.


akinoncli logout

By logging out the previous credentials can be deleted.

Public Keys
In order to access the ProjectApp's repositories, public keys are required.


akinoncli publickey create {key}

Creates public key.



Parameter
Description
Required




key
the text inside .ssh/id_rsa.pub
Yes



Example
akinoncli publickey create "ssh-rsa AAAAB..."


akinoncli publickey list

Lists the public keys.


akinoncli publickey delete {ID}

Deletes the public key.



Parameter
Description
Required




ID
Public Key ID
Yes



Applications
Users can create their own application and publish it so other users
can set up for their project and use it.
The application which you'd like to publish needs to be managed by GIT version control system.
In order to have read/write access to application's repository, the application needed to be
created in the Akinon Cloud Commerce and a public key must be created.
For an application to be distributed and compiled by the Akinon Cloud Commerce, it needed to have
a file named akinon.json in its home directory.
TODO: add the link to documentation of akinon.json


akinoncli applicationtype list

Lists the application types.


akinoncli application create {name} {slug} {application_type_id}

Creates an application.



Parameter
Description
Required




name
Application Name
Yes


slug
Application Slug (must be unique)
Yes


application_type_id
Application Type ID (akinoncli applicationtype list)
Yes



To see the git address you should run the list after creation of the application.
It can be seen as Clone URL column.


akinoncli application list

Lists the applications.


akinoncli application get {app_id}

Prints the details of an application.

In order to upload the source code of application run the following commands:
$ git remote add akinon {CLONE_URL}
$ git push akinon {branch_name}

In order to deploy an application for a project, it needs to be built by Akinon Cloud
Commerce. A stable version is required for such an action. One can create a tag
using git tag commands. After that, the tag needs to be pushed to the
remote repository in the Akinon Cloud Commerce system.
Example
$ git tag 1.0
$ git push akinon --tags

The building process can be started by CLI when the tag is pushed.


akinoncli application build {app_id} {tag} {--note}

Starts the building process for the given tag.



Parameter
Description
Required




app_id
Application ID
Yes


tag
Tag
Yes


--note
Note
No



Example
$ akinoncli application build 1 1.0 --note="test note for the build"



akinoncli application versions {app_id}

Lists the built versions of the application.



Parameter
Description
Required




app_id
Application ID
Yes



The status of version being completed indicates that the version is ready for deployment.


akinoncli application version-logs <app_id> <version_id>

Lists application version logs.



Parameter
Description
Required




id
Application ID
Yes


version_id
Version ID
Yes



Example
$ akinoncli application version-logs 27 518


Projects
The projects are the ecosystem of applications working together and integrated. When a project is created
Omnitron application is automatically being added to project and starts running.


akinoncli project list
Lists the projects.



akinoncli project create {name} {slug}

Creates project.



Parameter
Description
Required




name
Project Name
Yes


slug
Project Slug (Must be unique.)
Yes



Project Applications
The applications cannot be run without a project in the Akinon Cloud Commerce.
They should be related to a project and that relation can be assured with the
creation of a ProjectApp.


akinoncli projectapp add {project_id} {app_id}

Adds the application to project by creating ProjectApp.



Parameter
Description
Required




project_id
Project ID
Yes


app_id
App ID
Yes




akinoncli projectapp list {project_id}

Lists the applications of the relevant project.



Parameter
Description
Required




project_id
Project ID
Yes



Environment Parameters
The applications are able to run with different configurations on the various projects.
The same application running with different default language on two different projects can be given as example.
For this kind of requirements, Environment Parameters can be used.
These parameters could be seen in the ENV Variables column when listing the applications.


akinoncli projectapp add-env {project_id} {project_app_id} {ENV_KEY}={ENV_VALUE} {ANOTHER_ENV_KEY}={ANOTHER_ENV_VALUE}

Adds the environment parameter on the application.



Parameter
Description
Required




project_id
Project ID
Yes


project_app_id
Application ID
Yes


ENV_KEY
The key of relevant environment parameter
Yes


ENV_VALUE
The value of relevant environment parameter
Yes


--deploy
Redeploy the current version to activate environment variable changes.
No



The same command can also be used for updating.
Example
$ akinoncli projectapp add-env 1 32 LANGUAGE_CODE=en-us

It's also possible to use complex (i.e. non-string) values by encoding them as JSON. The value must be quoted properly
to function correctly.
$ akinoncli projectapp add-env 1 32 MIDDLEWARE='["my.custom.MiddlewareClass", "django.middleware.security.SecurityMiddleware", "whitenoise.middleware.WhiteNoiseMiddleware", "django.contrib.sessions.middleware.SessionMiddleware"]'
$ akinoncli projectapp add-env 1 32 THUMBNAIL_OPTIONS='{"product-list": {"width": 273, "height": 210}, "product-detail__slider_zoom": {"quality": 90}}'

For larger or dynamic payloads you can use EOF operator in sh-based terminals. This also allows string interpolation without having to escape
double quotes.
img_quality=90
opts=$(cat <<EOF
{
"product-list": {
"width": 273,
"height": 210,
"quality": $img_quality
},
"product-detail__slider_zoom": {
"quality": $img_quality
}
}
EOF
)

akinoncli projectapp add-env 1 32 THUMBNAIL_OPTIONS="$opts"

This environment variable can then be deserialized using django-environ package, or json.loads:
from environ import Env

env = Env()

DEFAULT_MIDDLEWARE = [
"django.middleware.security.SecurityMiddleware",
"whitenoise.middleware.WhiteNoiseMiddleware",
"django.middleware.common.CommonMiddleware",
]
MIDDLEWARE = env.json('MIDDLEWARE', default=DEFAULT_MIDDLEWARE) # omit `default` to throw an error if it's not set

THUMBNAIL_OPTIONS = env.json('THUMBNAIL_OPTIONS') # throws error if THUMBNAIL_OPTIONS is not set

# print(MIDDLEWARE[0]) # prints "my.custom.MiddlewareClass"
# print(list(THUMBNAIL_OPTIONS)) # prints ["product-list", "product-detail__slider_zoom"]

Refer to django-environ documentation for further information.



akinoncli projectapp remove-env {project_id} {app_id} {ENV_KEY} {ANOTHER_ENV_KEY}

Deletes the environment parameter from the application.



Parameter
Description
Required




project_id
Project ID
Yes


project_app_id
Application ID
Yes


ENV_KEY
The key of relevant environment parameter
Yes


--deploy
Redeploy the current version to activate environment variable changes.
No



Deploying the Application
In order to deploy an application it needed to be built firstly.
(Those steps are explained in Applications section.)


akinoncli projectapp deploy {project_id} {project_app_id} {tag}

Deploys the relevant tag to the relevant project application. (That process
might take some time.)



Parameter
Description
Required




project_id
Project ID
Yes


project_app_id
Application ID
Yes


tag
Tag of the version
Yes





akinoncli projectapp deploy-multiple {app_id} {tag}

Deploys multiple project applications with given tag



Parameter
Description
Required




app_id
Application ID
Yes


tag
Tag of the version
Yes


--project-apps
Project App IDs
If --deploy-all is not used Yes otherwise No


--deploy-all
Deploys all project apps with given tag
If --project-apps is not used Yes otherwise No




akinoncli projectapp deployments list {project_id} {app_id}

Lists the deployments of the relevant application.
The status of deployment can be seen in the status column.



Parameter
Description
Required




project_id
Project ID
Yes


project_app_id
Application ID
Yes





akinoncli projectapp deployment-logs project_id project_app_id deployment_id

Lists deployment logs.



Parameter
Description
Required




project_id
Project ID
Yes


project_app_id
Project App ID
Yes


deployment_id
Deployment ID
Yes



Example
$ akinoncli projectapp deployment-logs 1 1 1


Application Log
The applications logs can be seen following commands.
process type parameter is optional.


akinoncli projectapp logs {project_id} {project_app_id}




Parameter
Description
Required




project_id
Project ID
Yes


project_app_id
Application ID
Yes


-p
Process type (If that parameter is passed the relevant process typed logs would be returned) (By default returns logs with any process types )
No



Example
The following command returns a hundred logs created in the last minute.

akinoncli projectapp logs 1 1

The following command returns a hundred logs created in the last minute.

akinoncli projectapp logs 1 1 -p web

Exporting Application Logs
The application logs can be exported with following commands.




Parameter
Description
Required




project_id
Project ID
Yes


app_id
Application ID
Yes


-d
Filters logs that were created on the specified dates. Dates must be separated by commas. Date format must be YYYY-MM-DD.
No


-s
Filters logs that were created after the given specified date. Date format must be YYYY-MM-DD.
No


-e
Filters logs that were created before the given specified date. Date format must be YYYY-MM-DD.
No


-p
Process type (If that parameter is passed the relevant process typed logs would be returned) (By default returns logs with any process types )
No



Example
The following command exports all the logs of the given application.

akinoncli projectapp export-logs 1 1

The following command exports all the logs of the given application which were created in 2021-09-23 and 2021-09-24 dates.*
akinoncli projectapp export-logs 1 1 -d 2021-09-23,2021-09-24
The following command exports all the logs of the given application which were created with web and beat process types.

akinoncli projectapp export-logs 1 1 -p web,beat

The following command exports all the logs of the given application which were created between 2021-09-23 and 2021-09-28 dates.

akinoncli projectapp export-logs 1 1 -s 2021-09-23 -e 2021-09-28


Attaching certificate to Project Application
In order to deploy an application with certain domain and ssl certificate, that command can be used.
One certificate can only be attached to one Project Application.

Attaches certificate to Project Application.

akinoncli projectapp attach-certificate {project_id} {project_app_id} {certificate_id}




Parameter
Description
Required




project_id
Project ID
Yes


project_app_id
Application ID
Yes


certificate_id
Certificate ID
Yes



Example
$ akinoncli projectapp attach-certificate 1 1 1


Domain and Certificate
Akinon Cloud Commerce sistemine bir uygulamayı dağıtıma çıkarırken uygulamanın ssl sertifikası ile belirli bir alan adı ile çalışmasını istediğimiz durumlarda alan adı ve sertifika oluşturarak oluşturulan sertifikayı proje uygulamasına bağlayabiliriz.
Domain

Lists the domains.

akinoncli domain list


Creates domain.

akinoncli domain create {hostname} {is_managed}




Parameter
Description
Required




hostname
Hostname
Yes


is_managed
Alan adının akinon cloud tarafından yönetilmesini belirtir. (true, false değerlerinden biri olmalıdır)
Yes



Example
$ akinoncli domain create akinoncloud.net true

Certificate

Lists the certificates of the relevant domain.

akinoncli certificate list {domain_id}


Creates a certificate.

akinoncli certificate create {domain_id} {fqdn}




Parameter
Description
Required




domain_id
Domain ID
Yes


fqdn
Fully Qualified Domain Name
Yes



Example
$ akinoncli certificate create 1 test.akinoncloud.net

Addons
Addons are the third-party technologies such as Redis, Sentry, PostgreSQL etc.

Lists the addons.

akinoncli addon list {project_id} {project_app_id}





Parameter
Description
Required




project_id
Project ID
Yes


project_app_id
Project Application ID
Yes



Example
$ akinoncli addon list 1 1

Kube Metric Monitor
CPU and memory metrics of the applications running in the relevant Kubernetes cluster and namespace
can be seen with the following command.

Lists the metrics.

akinoncli addon list {project_id} {project_app_id}





Parameter
Description
Required




cluster
Cluster Name
Yes


namespace
Namespace
Yes



Example
$ akinoncli metrics list cluster1 namespace1

License

For personal and professional use. You cannot resell or redistribute these repositories in their original state.

Customer Reviews

There are no reviews.