Skip to content

Sample CloudMine Snippet project which supports a CI-CD style build workflow with CloudMine server code deployment capability. Includes a configuration file for supporting multiple environments and secret/token injection at build time before the snippets are uploaded to the server.

cloudmine/CloudMine-JSDeployments

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

14 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

CloudMine JS Snippet Deployment Utility

Sample CloudMine Snippet project which demonstrates a build workflow with CloudMine server code execution. Includes a configuration file for supporting multiple environments and secret/token injection at build time.

##Project Initialization

  1. Clone the repository locally.

  2. Install the node modules which are pinned to the correct versions.

    npm install

  3. Follow the configuration, build, and deployment instructions for establishing a workflow.

##Configuration Managing the configuration of the snippets for an application resides in the config.js file. There is two variables at the top for configurations specific to third party libraries which then get inserted into the configuration JSON shapes for the environments. This snippet library has three environments for which application ID, API keys and a master key can be setup.

##Building The values in the config.js get injected to the individual snippet files via the Grunt build procedure found in GruntFile.js. To import a variable from the configuration the variable needed is referenced in the snippet like so:

var applicationID = "<%= appId %>";

Members referenced such as appId are replaced with the value on the environment object when built. Render commands are used in conjunction with the environment from the command line to build the files. Rendering a snippet to an environment is done with the following command:

grunt render:production
grunt render:staging
grunt render:

Output from the build is placed in the /bin/ENVIRONMENT_NAME directory and the snippets can be run and debugged from there. Notice that the variables in the snippet with the syntax for injection are now replaced with the members of the configuration file.

##Deploying Deploying the code works in the same way as building the code. The deployment script works off the environment variables and is why the master key is a member of each configuration. It is advised to locally ignore changes to the config.js file in order to keey the master keys and application id off of the git repository. Locally ignoring changes to a git tracked file can be done with the following command:

git update-index --assume-unchanged config.js

Deploying snippets to an environment is done with the following command:

grunt deploy:pruduction
grunt deploy:staging
grunt deploy:dev

If you ever accidentally commit the master key, it is good practice to invalidate the key and redeploy with the newly created keys.

Running the examples

For this project, it's basically a repository of common use cases for snippets. A script in the test folder for each environment should corresspond to a snippet in the src folder by naming convention. I've tried my best to also document in each snippet the corresponding test script and visa versa. If not, please submit a pull request if you can identify or submit an issue if not.

For example, the snippet titled userCreation can be debugged on request and response with the test file userCreationWithSnippet. This file when run will create a user and run a snippet which does some user initialization and returns the results.

Some of the snippet which involve 3rd party integrations don't have a client side call because their run commands are dependent on 3rd party accounts outside the scope of CloudMine. These are meant to be for visual reference when integrating libraries from other developers and companies. However feel free to submit a pull request which illustrates the examples end-to-end.

About

Sample CloudMine Snippet project which supports a CI-CD style build workflow with CloudMine server code deployment capability. Includes a configuration file for supporting multiple environments and secret/token injection at build time before the snippets are uploaded to the server.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published