1.1.0 • Published 5 years ago

@hsolg/in-deploy v1.1.0

Weekly downloads
-
License
MIT
Repository
github
Last release
5 years ago

in-deploy

Simple deployment utility.

Deploy any type of software archive via Amazon S3. Convenient if the build machine and the deployment target cannot communicate directly because of NAT etc.

in-deploy is an interactive utility with a number of commands.

  • login
  • add
  • push
  • pull

AWS setup

Create IAM user

  1. Go to IAM -> Users.
  2. Press "Add user".
  3. Enter user name.
  4. Enable "Programmatic access".
  5. Press "Next" a few times and then "Create user".

Create access key

  1. Select the new user in the user overview and select the "Security credentials" tab.
  2. Press "Create access key".
  3. Click on "Show" and save the Access key ID and Secret access key in a safe place.

Create bucket

  1. Go to S3.
  2. Press "Create bucket".
  3. Enter bucket name.
  4. Select a region. Find the corresponding region id here (e.g. eu-west-1) and write it down: https://docs.aws.amazon.com/AmazonRDS/latest/UserGuide/Concepts.RegionsAndAvailabilityZones.html
  5. Press "Next" a few times and then "Create bucket".

Configure bucket access

  1. Select the bucket in the bucket overview.
  2. Select the "Permissions" tab.
  3. Press "Bucket policy".
  4. Enter the policy below.
    • Replace IAM_USER_ID and IAM_USER_NAME with the id and username of the user created above.
    • Replace BUCKET_NAME with the name of the bucket.
{
    "Version": "2012-10-17",
    "Statement": [
        {
            "Effect": "Allow",
            "Principal": {
                "AWS": "arn:aws:iam::IAM_USER_ID:user/IAM_USER_NAME"
            },
            "Action": "s3:*",
            "Resource": [
                "arn:aws:s3:::BUCKET_NAME",
                "arn:aws:s3:::BUCKET_NAME/*"
            ]
        }
    ]
}

Usage

login

Enter and store Amazon AWS credentials. The credentials will be stored in a file called .in-deploy-user in the directory where you run the in-deploy executable. You have to run the executable from the same directory if you want to use the credentials later. Make sure you don't commit the credentials file to a public source code repository.

$ in-deploy 
Commands: login | add | push | pull | quit
? Command: login
? Region: <the region where your bucket was created>
? Access key ID: ********************
? Secret access key: ****************************************

add

If you are on a build machine, use this command to register a directory with builds. If you are on a deployment machine, use this command to register a directory where you will store application archives for deployment. The mappings from application names to directories and buckets will be stored in a file called .in-deploy-app in the directory where you run the in-deploy executable. You have to run the executable from the same directory if you want to use the mappings later.

$ in-deploy 
Commands: login | add | push | pull | quit
? Command: add
? Name: <typically an application name>
? Directory: <directory with application archives (relative to current directory)>
? Bucket name: <name of the S3 bucket>

push

Use this command to push an application archive from a build machine to an S3 bucket.

$ in-deploy 
Commands: login | add | push | pull | quit
? Command: push
? Name: <typically an application name>
? File: SomeApplication-x.y.z.zip
Upload <full path>/SomeApplication-x.y.z.zip to <bucket name>
ETag: "********************************"

pull

Use this command to pull an application archive from an S3 bucket to a deployment machine.

$ in-deploy 
Commands: login | add | push | pull | quit
? Command: pull
? Name: <typically an application name>
? File: 
❯ SomeApplication-x.y.z.zip 

quit

Quit in-deploy and return to the shell.

$ in-deploy 
Commands: login | add | push | pull | quit
? Command: quit
$
1.1.0

5 years ago

1.0.5

5 years ago

1.0.4

5 years ago

1.0.3

5 years ago

1.0.2

5 years ago

1.0.1

5 years ago

1.0.0

5 years ago

0.0.1

5 years ago