aws_api
for Deno
From-scratch Typescript AWS API client built for Deno.
A leading focus of this library is to be as lean as possible
on the number of files downloaded to use a specific service.
Each service has its own isolated mod.ts
;
you'll need to make an ApiFactory
from client/mod.ts
and then pass it to the service you want to use.
Package layout:
client/
: A handwritten generic AWS API client (credentials, signing, etc)encoding/
: Shared modules for dealing with XML, JSON, & querystringsservices/
: Generated Typescript classes and interfaces for all supported AWS servicesdemo.ts
: A trivial example of using this libraryexamples/
: Several full examples of using individual servicesSERVICES.md
: A complete list of all AWS APIs and their build status
Please reach out on Github Issues about missing features, weird exceptions, or API issues,
or ping dantheman#8546
in the Deno Discord if you just wanna chat about this effort.
Usage
Basic example: (a subset of demo.ts
)
import {ApiFactory} from 'https://deno.land/x/aws_api/client/mod.ts';
const factory = new ApiFactory();
import STS from 'https://deno.land/x/aws_api/services/sts@2011-06-15/mod.ts';
const sts = new STS(factory);
const identity = await sts.getCallerIdentity();
console.log('You are', identity.UserId, 'in account', identity.Account);
console.log('Identity ARN:', identity.Arn);
A couple more-detailed examples are in examples/
and show concepts such as
managing an EC2 instance's lifecycle, redriving SQS messages,
and working directly with a Kinesis stream.
Changelog
v0.1.0
on2020-10-15
: Initial publication with about half of the services bound.- Using definitions from
aws-sdk-js@2.768.0
- Using definitions from
v0.1.1
on2020-11-02
: Generation improvements, most services have been generated.- Using definitions from
aws-sdk-js@2.780.0
- Using definitions from
v0.2.0
on2020-11-07
: Completed bindings for all API services.- Using definitions from
aws-sdk-js@2.784.0
- Using definitions from
v0.2.1
on2020-12-21
: Add EC2 instance metadata integration (IMDSv2)- Now supports using EC2 Instance IAM Roles automatically.
- Using definitions from
aws-sdk-js@2.814.0
v0.3.0
on2021-02-14
: Clean up generation, rename modules to match AWS-SDK- Using definitions from
aws-sdk-js@2.839.0
- Using definitions from
v0.3.1
on2021-03-28
: Fix ini-parsing edgecase. Remove zero-field API types.- Using definitions from
aws-sdk-js@2.874.0
- Using definitions from
Disclaimer
This is NOT a port of the official AWS SDK JS. Though every AWS service has an API module here, most have not actually been used yet and the bindings might make bad assumptions about the API contracts.
Do not use this module in mission critical stuff. It's supposed to be for automation scripts, quick & dirty pieces of infrastructure, and prototype microservices and so on.
If you just want the real, full-fat AWS SDK, a port of it has been uploaded at /x/aws_sdk.
The generated source code is still pretty messy. I used this project to learn more about the practicallity of API codegen. I'll be going through and neatening up the services/ source which shouldn't affect the published APIs.
Finally, the APIs within client/
and encoding/
are liable to change.
For best upgradability, stick to making an ApiFactory
object
and passing it to the services.
At some point (before 1.0.0) the APIs should be ready to lock in.
Methodology
All of the clients are compiled from aws-sdk-js
's JSON data files.
The code to generate clients isn't uploaded to /x/
,
so if you want to read through it, make sure you're in the source Git repo.
"Most" of the heavy lifting (such as compiling waiter JMESPaths) runs in the generation step so that the modules on /x/ are ready to run.
Completeness
The following clients have been used in actual scripts and should work quite well:
- SQS
- STS
- EC2
- S3
- Kinesis
- DynamoDB
The following credential sources are supported:
- Environment variables
- Static credentials in
~/.aws/credentials
- EKS Pod Identity (web identity token files)
- EC2 instance credentials
Some individual features that are implemented:
- Waiters (as
.waitForXYZ({...})
) - Automatic credential detection / loading
- EC2 instance metadata server v2
Multiple bits are missing:
- Automatic pagination (#1)
- AssumeRole credentials (#4)
- Debug logging/tracing of API calls
- Automatic retries
- Getting EKS credentials from regional STS endpoints (#2)
- AWS endpoints other than
**.amazonaws.com
(#3)- govcloud, China AWS, IPv6, etc.
List of Typechecked API Clients
All API definitions are current as of aws-sdk-js v2.874.0
.
Module | File size | Approx check time |
---|---|---|
accessanalyzer@2019-11-01 |
48 KiB | 1.7 sec |
acm@2015-12-08 |
23 KiB | 1.5 sec |
acmpca@2017-08-22 |
39 KiB | 2.1 sec |
alexaforbusiness@2017-11-09 |
108 KiB | 2.6 sec |
amp@2020-08-01 |
7 KiB | 1.4 sec |
amplify@2017-07-25 |
50 KiB | 2.0 sec |
amplifybackend@2020-08-11 |
49 KiB | 3.1 sec |
apigateway@2015-07-09 |
150 KiB | 3.7 sec |
apigatewaymanagementapi@2018-11-29 |
3 KiB | 1.3 sec |
apigatewayv2@2018-11-29 |
120 KiB | 2.7 sec |
appconfig@2019-10-09 |
42 KiB | 1.8 sec |
appflow@2020-08-23 |
95 KiB | 2.1 sec |
appintegrations@2020-07-29 |
10 KiB | 1.1 sec |
applicationautoscaling@2016-02-06 |
25 KiB | 2.8 sec |
applicationinsights@2018-11-25 |
33 KiB | 1.6 sec |
appmesh@2018-10-01 |
30 KiB | 1.8 sec |
appmesh@2019-01-25 |
122 KiB | 3.2 sec |
appstream@2016-12-01 |
66 KiB | 2.3 sec |
appsync@2017-07-25 |
59 KiB | 2.1 sec |
athena@2017-05-18 |
43 KiB | 1.7 sec |
auditmanager@2017-07-25 |
79 KiB | 2.3 sec |
augmentedairuntime@2019-11-07 |
8 KiB | 1.3 sec |
autoscaling@2011-01-01 |
103 KiB | 2.4 sec |
autoscalingplans@2018-01-06 |
22 KiB | 1.9 sec |
backup@2018-11-15 |
70 KiB | 2.1 sec |
batch@2016-08-10 |
52 KiB | 1.9 sec |
braket@2019-09-01 |
13 KiB | 1.3 sec |
budgets@2016-10-20 |
36 KiB | 1.6 sec |
chime@2018-05-01 |
217 KiB | 3.8 sec |
cloud9@2017-09-23 |
14 KiB | 1.6 sec |
clouddirectory@2016-05-10 |
118 KiB | 3.5 sec |
clouddirectory@2017-01-11 |
121 KiB | 4.2 sec |
cloudformation@2010-05-15 |
131 KiB | 2.8 sec |
cloudfront@2016-11-25 |
83 KiB | 2.6 sec |
cloudfront@2017-03-25 |
84 KiB | 2.5 sec |
cloudfront@2017-10-30 |
119 KiB | 2.8 sec |
cloudfront@2018-06-18 |
119 KiB | 3.3 sec |
cloudfront@2018-11-05 |
124 KiB | 2.5 sec |
cloudfront@2019-03-26 |
125 KiB | 3.4 sec |
cloudfront@2020-05-31 |
183 KiB | 3.4 sec |
cloudhsm@2014-05-30 |
19 KiB | 1.5 sec |
cloudhsmv2@2017-04-28 |
18 KiB | 4.4 sec |
cloudsearch@2011-02-01 |
35 KiB | 2.8 sec |
cloudsearch@2013-01-01 |
58 KiB | 2.1 sec |
cloudsearchdomain@2013-01-01 |
10 KiB | 2.1 sec |
cloudtrail@2013-11-01 |
27 KiB | 1.6 sec |
cloudwatch@2010-08-01 |
60 KiB | 1.9 sec |
cloudwatchevents@2015-10-07 |
83 KiB | 2.8 sec |
cloudwatchlogs@2014-03-28 |
44 KiB | 1.8 sec |
codeartifact@2018-09-22 |
55 KiB | 2.0 sec |
codebuild@2016-10-06 |
89 KiB | 2.1 sec |
codecommit@2015-04-13 |
109 KiB | 4.0 sec |
codedeploy@2014-10-06 |
86 KiB | 2.3 sec |
codeguruprofiler@2019-07-18 |
36 KiB | 1.7 sec |
codegurureviewer@2019-09-19 |
26 KiB | 5.7 sec |
codepipeline@2015-07-09 |
74 KiB | 2.3 sec |
codestar@2017-04-19 |
21 KiB | 1.7 sec |
codestarconnections@2019-12-01 |
12 KiB | 1.5 sec |
codestarnotifications@2019-10-15 |
16 KiB | 1.5 sec |
cognitoidentity@2014-06-30 |
27 KiB | 1.6 sec |
cognitoidentityserviceprovider@2016-04-18 |
145 KiB | 3.3 sec |
cognitosync@2014-06-30 |
22 KiB | 1.6 sec |
comprehend@2017-11-27 |
98 KiB | 2.1 sec |
comprehendmedical@2018-10-30 |
33 KiB | 1.8 sec |
computeoptimizer@2019-11-01 |
36 KiB | 1.6 sec |
configservice@2014-11-12 |
140 KiB | 2.9 sec |
connect@2017-08-08 |
127 KiB | 2.5 sec |
connectcontactlens@2020-08-21 |
5 KiB | 1.1 sec |
connectparticipant@2018-09-07 |
13 KiB | 1.3 sec |
costexplorer@2017-10-25 |
88 KiB | 2.3 sec |
cur@2017-01-06 |
7 KiB | 1.3 sec |
customerprofiles@2020-08-15 |
52 KiB | 2.2 sec |
databrew@2017-07-25 |
59 KiB | 1.9 sec |
dataexchange@2017-07-25 |
39 KiB | 1.7 sec |
datapipeline@2012-10-29 |
22 KiB | 1.9 sec |
datasync@2018-11-09 |
46 KiB | 1.7 sec |
dax@2017-04-19 |
28 KiB | 1.7 sec |
detective@2018-10-26 |
12 KiB | 1.5 sec |
devicefarm@2015-06-23 |
99 KiB | 2.5 sec |
devopsguru@2020-12-01 |
44 KiB | 1.9 sec |
directconnect@2012-10-25 |
70 KiB | 4.7 sec |
directoryservice@2015-04-16 |
70 KiB | 2.0 sec |
discovery@2015-11-01 |
32 KiB | 1.7 sec |
dlm@2018-01-12 |
22 KiB | 1.6 sec |
dms@2016-01-01 |
125 KiB | 3.0 sec |
docdb@2014-10-31 |
87 KiB | 2.5 sec |
dynamodb@2011-12-05 |
25 KiB | 1.7 sec |
dynamodb@2012-08-10 |
123 KiB | 2.8 sec |
dynamodbstreams@2012-08-10 |
10 KiB | 1.4 sec |
ebs@2019-11-02 |
11 KiB | 1.3 sec |
ec2@2016-11-15 |
1113 KiB | 9.0 sec |
ec2instanceconnect@2018-04-02 |
2 KiB | 1.2 sec |
ecr@2015-09-21 |
49 KiB | 1.8 sec |
ecrpublic@2020-10-30 |
30 KiB | 1.6 sec |
ecs@2014-11-13 |
129 KiB | 4.1 sec |
efs@2015-02-01 |
32 KiB | 1.8 sec |
eks@2017-11-01 |
61 KiB | 2.6 sec |
elasticache@2015-02-02 |
148 KiB | 3.3 sec |
elasticbeanstalk@2010-12-01 |
101 KiB | 2.8 sec |
elasticinference@2017-07-25 |
9 KiB | 1.3 sec |
elastictranscoder@2012-09-25 |
42 KiB | 2.3 sec |
elb@2012-06-01 |
46 KiB | 1.6 sec |
elbv2@2015-12-01 |
77 KiB | 2.7 sec |
emr@2009-03-31 |
110 KiB | 4.5 sec |
emrcontainers@2020-10-01 |
27 KiB | 1.5 sec |
es@2015-01-01 |
90 KiB | 3.0 sec |
eventbridge@2015-10-07 |
83 KiB | 2.7 sec |
firehose@2015-08-04 |
65 KiB | 3.1 sec |
fis@2020-12-01 |
28 KiB | 1.8 sec |
fms@2018-01-01 |
40 KiB | 1.7 sec |
forecastqueryservice@2018-06-26 |
3 KiB | 1.7 sec |
forecastservice@2018-06-26 |
54 KiB | 2.3 sec |
frauddetector@2019-11-15 |
62 KiB | 2.1 sec |
fsx@2018-03-01 |
42 KiB | 2.0 sec |
gamelift@2015-10-01 |
136 KiB | 5.2 sec |
glacier@2012-06-01 |
48 KiB | 2.3 sec |
globalaccelerator@2018-08-08 |
56 KiB | 1.8 sec |
glue@2017-03-31 |
245 KiB | 4.0 sec |
greengrass@2017-06-07 |
128 KiB | 4.3 sec |
greengrassv2@2020-11-30 |
45 KiB | 1.5 sec |
groundstation@2019-05-23 |
45 KiB | 2.6 sec |
guardduty@2017-11-28 |
84 KiB | 2.1 sec |
health@2016-08-04 |
24 KiB | 1.7 sec |
healthlake@2017-07-01 |
14 KiB | 2.0 sec |
honeycode@2020-03-01 |
26 KiB | 1.7 sec |
iam@2010-05-08 |
186 KiB | 4.0 sec |
identitystore@2020-06-15 |
5 KiB | 1.8 sec |
imagebuilder@2019-12-02 |
84 KiB | 2.2 sec |
importexport@2010-06-01 |
11 KiB | 1.7 sec |
inspector@2016-02-16 |
51 KiB | 2.1 sec |
iot@2015-05-28 |
345 KiB | 4.8 sec |
iot1clickdevicesservice@2018-05-14 |
14 KiB | 1.5 sec |
iot1clickprojects@2018-05-14 |
16 KiB | 1.3 sec |
iotanalytics@2017-11-27 |
74 KiB | 2.4 sec |
iotdata@2015-05-28 |
5 KiB | 1.2 sec |
iotdeviceadvisor@2020-09-18 |
22 KiB | 1.5 sec |
iotevents@2018-07-27 |
43 KiB | 3.1 sec |
ioteventsdata@2018-10-23 |
11 KiB | 1.5 sec |
iotfleethub@2020-11-03 |
9 KiB | 1.3 sec |
iotjobsdataplane@2017-09-29 |
8 KiB | 1.9 sec |
iotsecuretunneling@2018-10-05 |
10 KiB | 1.4 sec |
iotsitewise@2019-12-02 |
101 KiB | 3.8 sec |
iotthingsgraph@2018-09-06 |
40 KiB | 1.7 sec |
iotwireless@2020-11-22 |
67 KiB | 2.0 sec |
ivs@2020-07-14 |
22 KiB | 1.5 sec |
kafka@2018-11-14 |
54 KiB | 2.1 sec |
kendra@2019-02-03 |
94 KiB | 2.5 sec |
kinesis@2013-12-02 |
31 KiB | 1.5 sec |
kinesisanalytics@2015-08-14 |
45 KiB | 1.8 sec |
kinesisanalyticsv2@2018-05-23 |
81 KiB | 2.2 sec |
kinesisvideo@2017-09-30 |
21 KiB | 1.6 sec |
kinesisvideoarchivedmedia@2017-09-30 |
13 KiB | 1.1 sec |
kinesisvideomedia@2017-09-30 |
3 KiB | 1.0 sec |
kinesisvideosignalingchannels@2019-12-04 |
3 KiB | 1.1 sec |
kms@2014-11-01 |
47 KiB | 1.9 sec |
lakeformation@2017-03-31 |
23 KiB | 1.4 sec |
lambda@2014-11-11 |
15 KiB | 2.3 sec |
lambda@2015-03-31 |
100 KiB | 2.9 sec |
lexmodelbuildingservice@2017-04-19 |
69 KiB | 2.1 sec |
lexmodelsv2@2020-08-07 |
100 KiB | 2.3 sec |
lexruntime@2016-11-28 |
19 KiB | 1.5 sec |
lexruntimev2@2020-08-07 |
18 KiB | 1.2 sec |
licensemanager@2018-08-01 |
64 KiB | 3.0 sec |
lightsail@2016-11-28 |
199 KiB | 3.6 sec |
location@2020-11-19 |
44 KiB | 1.7 sec |
lookoutmetrics@2017-07-25 |
48 KiB | 1.8 sec |
lookoutvision@2020-11-20 |
28 KiB | 1.6 sec |
machinelearning@2014-12-12 |
48 KiB | 2.1 sec |
macie@2017-12-19 |
10 KiB | 1.4 sec |
macie2@2020-01-01 |
105 KiB | 3.0 sec |
managedblockchain@2018-09-24 |
43 KiB | 1.7 sec |
marketplacecatalog@2018-09-17 |
12 KiB | 1.6 sec |
marketplacecommerceanalytics@2015-07-01 |
5 KiB | 1.5 sec |
marketplaceentitlementservice@2017-01-11 |
3 KiB | 1.1 sec |
marketplacemetering@2016-01-14 |
7 KiB | 1.2 sec |
mediaconnect@2018-11-14 |
42 KiB | 1.9 sec |
mediaconvert@2017-08-29 |
251 KiB | 3.8 sec |
medialive@2017-10-14 |
311 KiB | 4.2 sec |
mediapackage@2017-10-12 |
46 KiB | 2.0 sec |
mediapackagevod@2018-11-07 |
33 KiB | 1.6 sec |
mediastore@2017-09-01 |
16 KiB | 1.4 sec |
mediastoredata@2017-09-01 |
7 KiB | 1.4 sec |
mediatailor@2018-04-23 |
54 KiB | 1.8 sec |
migrationhub@2017-05-31 |
20 KiB | 1.3 sec |
migrationhubconfig@2019-06-30 |
5 KiB | 1.1 sec |
mobile@2017-07-01 |
11 KiB | 1.6 sec |
mobileanalytics@2014-06-05 |
3 KiB | 1.1 sec |
mq@2017-11-27 |
40 KiB | 1.8 sec |
mturk@2017-01-17 |
49 KiB | 2.0 sec |
mwaa@2020-07-01 |
21 KiB | 1.3 sec |
neptune@2014-10-31 |
139 KiB | 3.3 sec |
networkfirewall@2020-11-12 |
54 KiB | 1.8 sec |
networkmanager@2019-07-05 |
47 KiB | 1.8 sec |
opsworks@2013-02-18 |
105 KiB | 2.7 sec |
opsworkscm@2016-11-01 |
24 KiB | 1.6 sec |
organizations@2016-11-28 |
51 KiB | 2.0 sec |
outposts@2019-12-03 |
10 KiB | 1.3 sec |
personalize@2018-05-22 |
65 KiB | 2.6 sec |
personalizeevents@2018-03-22 |
4 KiB | 1.1 sec |
personalizeruntime@2018-05-22 |
4 KiB | 1.2 sec |
pi@2018-02-27 |
7 KiB | 1.4 sec |
pinpoint@2016-12-01 |
243 KiB | 3.7 sec |
pinpointemail@2018-07-26 |
57 KiB | 2.2 sec |
pinpointsmsvoice@2018-09-05 |
13 KiB | 1.7 sec |
polly@2016-06-10 |
15 KiB | 1.3 sec |
pricing@2017-10-15 |
5 KiB | 1.4 sec |
qldb@2019-01-02 |
24 KiB | 1.4 sec |
qldbsession@2019-07-11 |
10 KiB | 1.7 sec |
quicksight@2018-04-01 |
201 KiB | 7.1 sec |
ram@2018-01-04 |
33 KiB | 1.8 sec |
rds@2013-01-10 |
94 KiB | 3.5 sec |
rds@2013-02-12 |
101 KiB | 4.9 sec |
rds@2013-09-09 |
109 KiB | 3.7 sec |
rds@2014-09-01 |
112 KiB | 3.3 sec |
rds@2014-10-31 |
321 KiB | 5.6 sec |
rdsdataservice@2018-08-01 |
14 KiB | 1.7 sec |
redshift@2012-12-01 |
181 KiB | 3.3 sec |
redshiftdata@2019-12-20 |
14 KiB | 1.7 sec |
rekognition@2016-06-27 |
92 KiB | 2.4 sec |
resourcegroups@2017-11-27 |
22 KiB | 1.5 sec |
resourcegroupstaggingapi@2017-01-26 |
11 KiB | 1.2 sec |
robomaker@2018-06-29 |
104 KiB | 2.6 sec |
route53@2013-04-01 |
98 KiB | 2.8 sec |
route53domains@2014-05-15 |
35 KiB | 2.3 sec |
route53resolver@2018-04-01 |
43 KiB | 1.8 sec |
s3@2006-03-01 |
259 KiB | 4.1 sec |
s3control@2018-08-20 |
107 KiB | 2.9 sec |
s3outposts@2017-07-25 |
5 KiB | 1.5 sec |
sagemaker@2017-07-24 |
536 KiB | 7.5 sec |
sagemakeredge@2020-09-23 |
4 KiB | 2.2 sec |
sagemakerfeaturestoreruntime@2020-07-01 |
4 KiB | 2.1 sec |
sagemakerruntime@2017-05-13 |
3 KiB | 1.4 sec |
savingsplans@2019-06-28 |
21 KiB | 1.4 sec |
schemas@2019-12-02 |
37 KiB | 1.6 sec |
secretsmanager@2017-10-17 |
28 KiB | 1.7 sec |
securityhub@2018-10-26 |
305 KiB | 5.1 sec |
serverlessapplicationrepository@2017-09-08 |
25 KiB | 1.8 sec |
servicecatalog@2015-12-10 |
124 KiB | 2.5 sec |
servicecatalogappregistry@2020-06-24 |
22 KiB | 1.5 sec |
servicediscovery@2017-03-14 |
34 KiB | 1.7 sec |
servicequotas@2019-06-24 |
22 KiB | 1.5 sec |
ses@2010-12-01 |
92 KiB | 2.3 sec |
sesv2@2019-09-27 |
110 KiB | 2.7 sec |
shield@2016-06-02 |
33 KiB | 1.8 sec |
signer@2017-08-25 |
33 KiB | 1.8 sec |
simpledb@2009-04-15 |
13 KiB | 1.8 sec |
sms@2016-10-24 |
53 KiB | 2.0 sec |
snowball@2016-06-30 |
35 KiB | 1.7 sec |
sns@2010-03-31 |
32 KiB | 1.4 sec |
sqs@2012-11-05 |
29 KiB | 1.6 sec |
ssm@2014-11-06 |
263 KiB | 4.5 sec |
sso@2019-06-10 |
6 KiB | 1.5 sec |
ssoadmin@2020-07-20 |
37 KiB | 1.6 sec |
ssooidc@2019-06-10 |
5 KiB | 1.1 sec |
stepfunctions@2016-11-23 |
45 KiB | 4.5 sec |
storagegateway@2013-06-30 |
100 KiB | 2.9 sec |
sts@2011-06-15 |
14 KiB | 1.4 sec |
support@2013-04-15 |
21 KiB | 1.4 sec |
swf@2012-01-25 |
102 KiB | 2.9 sec |
synthetics@2017-10-11 |
20 KiB | 3.6 sec |
textract@2018-06-27 |
15 KiB | 1.4 sec |
timestreamquery@2018-11-01 |
6 KiB | 1.2 sec |
timestreamwrite@2018-11-01 |
15 KiB | 1.4 sec |
transcribeservice@2017-10-26 |
44 KiB | 1.8 sec |
transfer@2018-11-05 |
26 KiB | 1.5 sec |
translate@2017-07-01 |
24 KiB | 1.6 sec |
waf@2015-08-24 |
90 KiB | 2.4 sec |
wafregional@2016-11-28 |
93 KiB | 2.5 sec |
wafv2@2019-07-29 |
71 KiB | 2.1 sec |
wellarchitected@2020-03-31 |
47 KiB | 2.5 sec |
workdocs@2016-05-01 |
64 KiB | 3.4 sec |
worklink@2018-09-25 |
31 KiB | 1.9 sec |
workmail@2017-10-01 |
48 KiB | 1.8 sec |
workmailmessageflow@2019-05-01 |
3 KiB | 1.1 sec |
workspaces@2015-04-08 |
65 KiB | 2.2 sec |
xray@2016-04-12 |
55 KiB | 2.0 sec |
If something new is missing from this list, feel free to open an issue!