permaweb-deploy 1.0.1 → 1.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/.eslintrc.js CHANGED
@@ -22,7 +22,7 @@ module.exports = {
22
22
  {
23
23
  groups: [
24
24
  ['^react', '^@?\\w'],
25
- ['^arweave', '@irys/sdk', '^warp', '^@?\\w'],
25
+ ['^arweave', '@irys/sdk', '@permaweb/aoconnect', '^@?\\w'],
26
26
  ['^\\u0000'],
27
27
  ['^\\.\\.(?!/?$)', '^\\.\\./?$'],
28
28
  ['^\\./(?=.*/)(?!/?$)', '^\\.(?!/?$)', '^\\./?$'],
package/README.md CHANGED
@@ -1,3 +1,64 @@
1
- #### permaweb-deploy
1
+ # Permaweb deployment package
2
2
 
3
- Permaweb app deployment package
3
+ Inspired by the [cookbook github action deployment guide](https://cookbook.arweave.dev/guides/deployment/github-action.html), `permaweb-deploy` is a Node.js command-line tool designed to streamline the deployment of JavaScript bundles to the permaweb using Arweave. It simplifies the process by bundling JS code, deploying it as a transaction to Arweave, and updating ArNS (Arweave Name Service) with the transaction ID.
4
+
5
+ ### Features
6
+ - **Bundle Deployment:** Automatically bundles your JS code and deploys it to Arweave.
7
+ - **ArNS Update:** Updates ArNS with the new transaction ID each time new content is deployed.
8
+ - **Automated Workflow:** Integrates with GitHub Actions for continuous deployment directly from your repository.
9
+
10
+ ### Installation
11
+ Install the package using npm:
12
+ ```bash
13
+ npm install permaweb-deploy
14
+ ```
15
+
16
+ ### Prerequisites
17
+ Before using `permaweb-deploy`, you must:
18
+ 1. Encode your Arweave wallet key in base64 format and set it as a GitHub secret:
19
+
20
+ ```bash
21
+ base64 -i wallet.json | pbcopy
22
+ ```
23
+ 3. Ensure that the secret name for the encoded wallet is `DEPLOY_KEY`.
24
+
25
+ ### Usage
26
+ To deploy your application, ensure you have a build script and a deployment script in your `package.json`:
27
+
28
+ ```json
29
+ "scripts": {
30
+ "build": "your-build-command",
31
+ "deploy-main": "npm run build && permaweb-deploy --ant-process <ANT_PROCESS>"
32
+ }
33
+ ```
34
+
35
+ Replace `<ANT_PROCESS>` with your actual ANT process.
36
+
37
+ ### GitHub Actions Workflow
38
+ To automate the deployment, set up a GitHub Actions workflow as follows:
39
+ ```yaml
40
+ name: publish
41
+
42
+ on:
43
+ push:
44
+ branches:
45
+ - 'main'
46
+
47
+ jobs:
48
+ publish:
49
+ runs-on: ubuntu-latest
50
+ steps:
51
+ - uses: actions/checkout@v2
52
+ - uses: actions/setup-node@v1
53
+ with:
54
+ node-version: 20.x
55
+ - run: npm install
56
+ - run: npm run deploy-main
57
+ env:
58
+ DEPLOY_KEY: ${{ secrets.DEPLOY_KEY }}
59
+ ```
60
+
61
+ ### Important Notes
62
+ - **Security:** Always use a dedicated wallet for deployments to minimize risk.
63
+ - **Wallet Key:** The wallet must be base64 encoded to be used in the deployment script.
64
+ - **ANT Process:** The ANT process must be passed at runtime to associate your deployment with a specific ANT process on AO.
package/dist/index.js CHANGED
@@ -2,26 +2,39 @@
2
2
  "use strict";
3
3
 
4
4
  function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.getTagValue = getTagValue;
5
9
  var _yargs = _interopRequireDefault(require("yargs"));
6
10
  var _helpers = require("yargs/helpers");
7
- var _arweave = _interopRequireDefault(require("arweave"));
8
11
  var _sdk = _interopRequireDefault(require("@irys/sdk"));
9
- var _warpContracts = require("warp-contracts");
10
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
11
- function _regeneratorRuntime() { "use strict"; /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/facebook/regenerator/blob/main/LICENSE */ _regeneratorRuntime = function _regeneratorRuntime() { return e; }; var t, e = {}, r = Object.prototype, n = r.hasOwnProperty, o = Object.defineProperty || function (t, e, r) { t[e] = r.value; }, i = "function" == typeof Symbol ? Symbol : {}, a = i.iterator || "@@iterator", c = i.asyncIterator || "@@asyncIterator", u = i.toStringTag || "@@toStringTag"; function define(t, e, r) { return Object.defineProperty(t, e, { value: r, enumerable: !0, configurable: !0, writable: !0 }), t[e]; } try { define({}, ""); } catch (t) { define = function define(t, e, r) { return t[e] = r; }; } function wrap(t, e, r, n) { var i = e && e.prototype instanceof Generator ? e : Generator, a = Object.create(i.prototype), c = new Context(n || []); return o(a, "_invoke", { value: makeInvokeMethod(t, r, c) }), a; } function tryCatch(t, e, r) { try { return { type: "normal", arg: t.call(e, r) }; } catch (t) { return { type: "throw", arg: t }; } } e.wrap = wrap; var h = "suspendedStart", l = "suspendedYield", f = "executing", s = "completed", y = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} var p = {}; define(p, a, function () { return this; }); var d = Object.getPrototypeOf, v = d && d(d(values([]))); v && v !== r && n.call(v, a) && (p = v); var g = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(p); function defineIteratorMethods(t) { ["next", "throw", "return"].forEach(function (e) { define(t, e, function (t) { return this._invoke(e, t); }); }); } function AsyncIterator(t, e) { function invoke(r, o, i, a) { var c = tryCatch(t[r], t, o); if ("throw" !== c.type) { var u = c.arg, h = u.value; return h && "object" == _typeof(h) && n.call(h, "__await") ? e.resolve(h.__await).then(function (t) { invoke("next", t, i, a); }, function (t) { invoke("throw", t, i, a); }) : e.resolve(h).then(function (t) { u.value = t, i(u); }, function (t) { return invoke("throw", t, i, a); }); } a(c.arg); } var r; o(this, "_invoke", { value: function value(t, n) { function callInvokeWithMethodAndArg() { return new e(function (e, r) { invoke(t, n, e, r); }); } return r = r ? r.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg(); } }); } function makeInvokeMethod(e, r, n) { var o = h; return function (i, a) { if (o === f) throw new Error("Generator is already running"); if (o === s) { if ("throw" === i) throw a; return { value: t, done: !0 }; } for (n.method = i, n.arg = a;;) { var c = n.delegate; if (c) { var u = maybeInvokeDelegate(c, n); if (u) { if (u === y) continue; return u; } } if ("next" === n.method) n.sent = n._sent = n.arg;else if ("throw" === n.method) { if (o === h) throw o = s, n.arg; n.dispatchException(n.arg); } else "return" === n.method && n.abrupt("return", n.arg); o = f; var p = tryCatch(e, r, n); if ("normal" === p.type) { if (o = n.done ? s : l, p.arg === y) continue; return { value: p.arg, done: n.done }; } "throw" === p.type && (o = s, n.method = "throw", n.arg = p.arg); } }; } function maybeInvokeDelegate(e, r) { var n = r.method, o = e.iterator[n]; if (o === t) return r.delegate = null, "throw" === n && e.iterator["return"] && (r.method = "return", r.arg = t, maybeInvokeDelegate(e, r), "throw" === r.method) || "return" !== n && (r.method = "throw", r.arg = new TypeError("The iterator does not provide a '" + n + "' method")), y; var i = tryCatch(o, e.iterator, r.arg); if ("throw" === i.type) return r.method = "throw", r.arg = i.arg, r.delegate = null, y; var a = i.arg; return a ? a.done ? (r[e.resultName] = a.value, r.next = e.nextLoc, "return" !== r.method && (r.method = "next", r.arg = t), r.delegate = null, y) : a : (r.method = "throw", r.arg = new TypeError("iterator result is not an object"), r.delegate = null, y); } function pushTryEntry(t) { var e = { tryLoc: t[0] }; 1 in t && (e.catchLoc = t[1]), 2 in t && (e.finallyLoc = t[2], e.afterLoc = t[3]), this.tryEntries.push(e); } function resetTryEntry(t) { var e = t.completion || {}; e.type = "normal", delete e.arg, t.completion = e; } function Context(t) { this.tryEntries = [{ tryLoc: "root" }], t.forEach(pushTryEntry, this), this.reset(!0); } function values(e) { if (e || "" === e) { var r = e[a]; if (r) return r.call(e); if ("function" == typeof e.next) return e; if (!isNaN(e.length)) { var o = -1, i = function next() { for (; ++o < e.length;) if (n.call(e, o)) return next.value = e[o], next.done = !1, next; return next.value = t, next.done = !0, next; }; return i.next = i; } } throw new TypeError(_typeof(e) + " is not iterable"); } return GeneratorFunction.prototype = GeneratorFunctionPrototype, o(g, "constructor", { value: GeneratorFunctionPrototype, configurable: !0 }), o(GeneratorFunctionPrototype, "constructor", { value: GeneratorFunction, configurable: !0 }), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, u, "GeneratorFunction"), e.isGeneratorFunction = function (t) { var e = "function" == typeof t && t.constructor; return !!e && (e === GeneratorFunction || "GeneratorFunction" === (e.displayName || e.name)); }, e.mark = function (t) { return Object.setPrototypeOf ? Object.setPrototypeOf(t, GeneratorFunctionPrototype) : (t.__proto__ = GeneratorFunctionPrototype, define(t, u, "GeneratorFunction")), t.prototype = Object.create(g), t; }, e.awrap = function (t) { return { __await: t }; }, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, c, function () { return this; }), e.AsyncIterator = AsyncIterator, e.async = function (t, r, n, o, i) { void 0 === i && (i = Promise); var a = new AsyncIterator(wrap(t, r, n, o), i); return e.isGeneratorFunction(r) ? a : a.next().then(function (t) { return t.done ? t.value : a.next(); }); }, defineIteratorMethods(g), define(g, u, "Generator"), define(g, a, function () { return this; }), define(g, "toString", function () { return "[object Generator]"; }), e.keys = function (t) { var e = Object(t), r = []; for (var n in e) r.push(n); return r.reverse(), function next() { for (; r.length;) { var t = r.pop(); if (t in e) return next.value = t, next.done = !1, next; } return next.done = !0, next; }; }, e.values = values, Context.prototype = { constructor: Context, reset: function reset(e) { if (this.prev = 0, this.next = 0, this.sent = this._sent = t, this.done = !1, this.delegate = null, this.method = "next", this.arg = t, this.tryEntries.forEach(resetTryEntry), !e) for (var r in this) "t" === r.charAt(0) && n.call(this, r) && !isNaN(+r.slice(1)) && (this[r] = t); }, stop: function stop() { this.done = !0; var t = this.tryEntries[0].completion; if ("throw" === t.type) throw t.arg; return this.rval; }, dispatchException: function dispatchException(e) { if (this.done) throw e; var r = this; function handle(n, o) { return a.type = "throw", a.arg = e, r.next = n, o && (r.method = "next", r.arg = t), !!o; } for (var o = this.tryEntries.length - 1; o >= 0; --o) { var i = this.tryEntries[o], a = i.completion; if ("root" === i.tryLoc) return handle("end"); if (i.tryLoc <= this.prev) { var c = n.call(i, "catchLoc"), u = n.call(i, "finallyLoc"); if (c && u) { if (this.prev < i.catchLoc) return handle(i.catchLoc, !0); if (this.prev < i.finallyLoc) return handle(i.finallyLoc); } else if (c) { if (this.prev < i.catchLoc) return handle(i.catchLoc, !0); } else { if (!u) throw new Error("try statement without catch or finally"); if (this.prev < i.finallyLoc) return handle(i.finallyLoc); } } } }, abrupt: function abrupt(t, e) { for (var r = this.tryEntries.length - 1; r >= 0; --r) { var o = this.tryEntries[r]; if (o.tryLoc <= this.prev && n.call(o, "finallyLoc") && this.prev < o.finallyLoc) { var i = o; break; } } i && ("break" === t || "continue" === t) && i.tryLoc <= e && e <= i.finallyLoc && (i = null); var a = i ? i.completion : {}; return a.type = t, a.arg = e, i ? (this.method = "next", this.next = i.finallyLoc, y) : this.complete(a); }, complete: function complete(t, e) { if ("throw" === t.type) throw t.arg; return "break" === t.type || "continue" === t.type ? this.next = t.arg : "return" === t.type ? (this.rval = this.arg = t.arg, this.method = "return", this.next = "end") : "normal" === t.type && e && (this.next = e), y; }, finish: function finish(t) { for (var e = this.tryEntries.length - 1; e >= 0; --e) { var r = this.tryEntries[e]; if (r.finallyLoc === t) return this.complete(r.completion, r.afterLoc), resetTryEntry(r), y; } }, "catch": function _catch(t) { for (var e = this.tryEntries.length - 1; e >= 0; --e) { var r = this.tryEntries[e]; if (r.tryLoc === t) { var n = r.completion; if ("throw" === n.type) { var o = n.arg; resetTryEntry(r); } return o; } } throw new Error("illegal catch attempt"); }, delegateYield: function delegateYield(e, r, n) { return this.delegate = { iterator: values(e), resultName: r, nextLoc: n }, "next" === this.method && (this.arg = t), y; } }, e; }
12
- function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }
13
- function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; }
14
- var DEPLOY_FOLDER = './dist';
15
- var DEPLOY_KEY = process.env.DEPLOY_KEY;
16
- var argv = (0, _yargs["default"])((0, _helpers.hideBin)(process.argv)).option('ant-contract', {
12
+ var _aoconnect = require("@permaweb/aoconnect");
13
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { "default": e }; }
14
+ function _regeneratorRuntime() { "use strict"; /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/facebook/regenerator/blob/main/LICENSE */ _regeneratorRuntime = function _regeneratorRuntime() { return e; }; var t, e = {}, r = Object.prototype, n = r.hasOwnProperty, o = Object.defineProperty || function (t, e, r) { t[e] = r.value; }, i = "function" == typeof Symbol ? Symbol : {}, a = i.iterator || "@@iterator", c = i.asyncIterator || "@@asyncIterator", u = i.toStringTag || "@@toStringTag"; function define(t, e, r) { return Object.defineProperty(t, e, { value: r, enumerable: !0, configurable: !0, writable: !0 }), t[e]; } try { define({}, ""); } catch (t) { define = function define(t, e, r) { return t[e] = r; }; } function wrap(t, e, r, n) { var i = e && e.prototype instanceof Generator ? e : Generator, a = Object.create(i.prototype), c = new Context(n || []); return o(a, "_invoke", { value: makeInvokeMethod(t, r, c) }), a; } function tryCatch(t, e, r) { try { return { type: "normal", arg: t.call(e, r) }; } catch (t) { return { type: "throw", arg: t }; } } e.wrap = wrap; var h = "suspendedStart", l = "suspendedYield", f = "executing", s = "completed", y = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} var p = {}; define(p, a, function () { return this; }); var d = Object.getPrototypeOf, v = d && d(d(values([]))); v && v !== r && n.call(v, a) && (p = v); var g = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(p); function defineIteratorMethods(t) { ["next", "throw", "return"].forEach(function (e) { define(t, e, function (t) { return this._invoke(e, t); }); }); } function AsyncIterator(t, e) { function invoke(r, o, i, a) { var c = tryCatch(t[r], t, o); if ("throw" !== c.type) { var u = c.arg, h = u.value; return h && "object" == _typeof(h) && n.call(h, "__await") ? e.resolve(h.__await).then(function (t) { invoke("next", t, i, a); }, function (t) { invoke("throw", t, i, a); }) : e.resolve(h).then(function (t) { u.value = t, i(u); }, function (t) { return invoke("throw", t, i, a); }); } a(c.arg); } var r; o(this, "_invoke", { value: function value(t, n) { function callInvokeWithMethodAndArg() { return new e(function (e, r) { invoke(t, n, e, r); }); } return r = r ? r.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg(); } }); } function makeInvokeMethod(e, r, n) { var o = h; return function (i, a) { if (o === f) throw Error("Generator is already running"); if (o === s) { if ("throw" === i) throw a; return { value: t, done: !0 }; } for (n.method = i, n.arg = a;;) { var c = n.delegate; if (c) { var u = maybeInvokeDelegate(c, n); if (u) { if (u === y) continue; return u; } } if ("next" === n.method) n.sent = n._sent = n.arg;else if ("throw" === n.method) { if (o === h) throw o = s, n.arg; n.dispatchException(n.arg); } else "return" === n.method && n.abrupt("return", n.arg); o = f; var p = tryCatch(e, r, n); if ("normal" === p.type) { if (o = n.done ? s : l, p.arg === y) continue; return { value: p.arg, done: n.done }; } "throw" === p.type && (o = s, n.method = "throw", n.arg = p.arg); } }; } function maybeInvokeDelegate(e, r) { var n = r.method, o = e.iterator[n]; if (o === t) return r.delegate = null, "throw" === n && e.iterator["return"] && (r.method = "return", r.arg = t, maybeInvokeDelegate(e, r), "throw" === r.method) || "return" !== n && (r.method = "throw", r.arg = new TypeError("The iterator does not provide a '" + n + "' method")), y; var i = tryCatch(o, e.iterator, r.arg); if ("throw" === i.type) return r.method = "throw", r.arg = i.arg, r.delegate = null, y; var a = i.arg; return a ? a.done ? (r[e.resultName] = a.value, r.next = e.nextLoc, "return" !== r.method && (r.method = "next", r.arg = t), r.delegate = null, y) : a : (r.method = "throw", r.arg = new TypeError("iterator result is not an object"), r.delegate = null, y); } function pushTryEntry(t) { var e = { tryLoc: t[0] }; 1 in t && (e.catchLoc = t[1]), 2 in t && (e.finallyLoc = t[2], e.afterLoc = t[3]), this.tryEntries.push(e); } function resetTryEntry(t) { var e = t.completion || {}; e.type = "normal", delete e.arg, t.completion = e; } function Context(t) { this.tryEntries = [{ tryLoc: "root" }], t.forEach(pushTryEntry, this), this.reset(!0); } function values(e) { if (e || "" === e) { var r = e[a]; if (r) return r.call(e); if ("function" == typeof e.next) return e; if (!isNaN(e.length)) { var o = -1, i = function next() { for (; ++o < e.length;) if (n.call(e, o)) return next.value = e[o], next.done = !1, next; return next.value = t, next.done = !0, next; }; return i.next = i; } } throw new TypeError(_typeof(e) + " is not iterable"); } return GeneratorFunction.prototype = GeneratorFunctionPrototype, o(g, "constructor", { value: GeneratorFunctionPrototype, configurable: !0 }), o(GeneratorFunctionPrototype, "constructor", { value: GeneratorFunction, configurable: !0 }), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, u, "GeneratorFunction"), e.isGeneratorFunction = function (t) { var e = "function" == typeof t && t.constructor; return !!e && (e === GeneratorFunction || "GeneratorFunction" === (e.displayName || e.name)); }, e.mark = function (t) { return Object.setPrototypeOf ? Object.setPrototypeOf(t, GeneratorFunctionPrototype) : (t.__proto__ = GeneratorFunctionPrototype, define(t, u, "GeneratorFunction")), t.prototype = Object.create(g), t; }, e.awrap = function (t) { return { __await: t }; }, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, c, function () { return this; }), e.AsyncIterator = AsyncIterator, e.async = function (t, r, n, o, i) { void 0 === i && (i = Promise); var a = new AsyncIterator(wrap(t, r, n, o), i); return e.isGeneratorFunction(r) ? a : a.next().then(function (t) { return t.done ? t.value : a.next(); }); }, defineIteratorMethods(g), define(g, u, "Generator"), define(g, a, function () { return this; }), define(g, "toString", function () { return "[object Generator]"; }), e.keys = function (t) { var e = Object(t), r = []; for (var n in e) r.push(n); return r.reverse(), function next() { for (; r.length;) { var t = r.pop(); if (t in e) return next.value = t, next.done = !1, next; } return next.done = !0, next; }; }, e.values = values, Context.prototype = { constructor: Context, reset: function reset(e) { if (this.prev = 0, this.next = 0, this.sent = this._sent = t, this.done = !1, this.delegate = null, this.method = "next", this.arg = t, this.tryEntries.forEach(resetTryEntry), !e) for (var r in this) "t" === r.charAt(0) && n.call(this, r) && !isNaN(+r.slice(1)) && (this[r] = t); }, stop: function stop() { this.done = !0; var t = this.tryEntries[0].completion; if ("throw" === t.type) throw t.arg; return this.rval; }, dispatchException: function dispatchException(e) { if (this.done) throw e; var r = this; function handle(n, o) { return a.type = "throw", a.arg = e, r.next = n, o && (r.method = "next", r.arg = t), !!o; } for (var o = this.tryEntries.length - 1; o >= 0; --o) { var i = this.tryEntries[o], a = i.completion; if ("root" === i.tryLoc) return handle("end"); if (i.tryLoc <= this.prev) { var c = n.call(i, "catchLoc"), u = n.call(i, "finallyLoc"); if (c && u) { if (this.prev < i.catchLoc) return handle(i.catchLoc, !0); if (this.prev < i.finallyLoc) return handle(i.finallyLoc); } else if (c) { if (this.prev < i.catchLoc) return handle(i.catchLoc, !0); } else { if (!u) throw Error("try statement without catch or finally"); if (this.prev < i.finallyLoc) return handle(i.finallyLoc); } } } }, abrupt: function abrupt(t, e) { for (var r = this.tryEntries.length - 1; r >= 0; --r) { var o = this.tryEntries[r]; if (o.tryLoc <= this.prev && n.call(o, "finallyLoc") && this.prev < o.finallyLoc) { var i = o; break; } } i && ("break" === t || "continue" === t) && i.tryLoc <= e && e <= i.finallyLoc && (i = null); var a = i ? i.completion : {}; return a.type = t, a.arg = e, i ? (this.method = "next", this.next = i.finallyLoc, y) : this.complete(a); }, complete: function complete(t, e) { if ("throw" === t.type) throw t.arg; return "break" === t.type || "continue" === t.type ? this.next = t.arg : "return" === t.type ? (this.rval = this.arg = t.arg, this.method = "return", this.next = "end") : "normal" === t.type && e && (this.next = e), y; }, finish: function finish(t) { for (var e = this.tryEntries.length - 1; e >= 0; --e) { var r = this.tryEntries[e]; if (r.finallyLoc === t) return this.complete(r.completion, r.afterLoc), resetTryEntry(r), y; } }, "catch": function _catch(t) { for (var e = this.tryEntries.length - 1; e >= 0; --e) { var r = this.tryEntries[e]; if (r.tryLoc === t) { var n = r.completion; if ("throw" === n.type) { var o = n.arg; resetTryEntry(r); } return o; } } throw Error("illegal catch attempt"); }, delegateYield: function delegateYield(e, r, n) { return this.delegate = { iterator: values(e), resultName: r, nextLoc: n }, "next" === this.method && (this.arg = t), y; } }, e; }
15
+ function asyncGeneratorStep(n, t, e, r, o, a, c) { try { var i = n[a](c), u = i.value; } catch (n) { return void e(n); } i.done ? t(u) : Promise.resolve(u).then(r, o); }
16
+ function _asyncToGenerator(n) { return function () { var t = this, e = arguments; return new Promise(function (r, o) { var a = n.apply(t, e); function _next(n) { asyncGeneratorStep(a, r, o, _next, _throw, "next", n); } function _throw(n) { asyncGeneratorStep(a, r, o, _next, _throw, "throw", n); } _next(void 0); }); }; }
17
+ var argv = (0, _yargs["default"])((0, _helpers.hideBin)(process.argv)).option('ant-process', {
17
18
  alias: 'a',
18
19
  type: 'string',
19
- description: 'The ANT contract address',
20
+ description: 'The ANT process',
20
21
  demandOption: true
21
22
  }).argv;
22
- var ANT_CONTRACT = argv.antContract;
23
+ var DEPLOY_FOLDER = './dist';
24
+ var DEPLOY_KEY = process.env.DEPLOY_KEY;
25
+ var ANT_PROCESS = argv.antProcess;
26
+ function getTagValue(list, name) {
27
+ for (var i = 0; i < list.length; i++) {
28
+ if (list[i]) {
29
+ if (list[i].name === name) {
30
+ return list[i].value;
31
+ }
32
+ }
33
+ }
34
+ return STORAGE.none;
35
+ }
23
36
  _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee() {
24
- var jwk, irys, arweave, warp, warpContract, contractState, txResult;
37
+ var jwk, irys, txResult, response, _yield$result, Messages, responseAction;
25
38
  return _regeneratorRuntime().wrap(function _callee$(_context) {
26
39
  while (1) switch (_context.prev = _context.next) {
27
40
  case 0:
@@ -32,11 +45,11 @@ _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee() {
32
45
  console.error('DEPLOY_KEY not configured');
33
46
  return _context.abrupt("return");
34
47
  case 3:
35
- if (ANT_CONTRACT) {
48
+ if (ANT_PROCESS) {
36
49
  _context.next = 6;
37
50
  break;
38
51
  }
39
- console.error('ANT_CONTRACT not configured');
52
+ console.error('ANT_PROCESS not configured');
40
53
  return _context.abrupt("return");
41
54
  case 6:
42
55
  jwk = JSON.parse(Buffer.from(DEPLOY_KEY, 'base64').toString('utf-8'));
@@ -45,51 +58,59 @@ _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee() {
45
58
  token: 'arweave',
46
59
  key: jwk
47
60
  });
48
- arweave = _arweave["default"].init({
49
- host: 'arweave.net',
50
- port: 443,
51
- protocol: 'https'
52
- });
53
- warp = _warpContracts.WarpFactory.custom(arweave, _warpContracts.defaultCacheOptions, 'mainnet').useArweaveGateway().build();
54
- warpContract = warp.contract(ANT_CONTRACT).connect(jwk);
55
- _context.next = 13;
56
- return warpContract.readState();
57
- case 13:
58
- contractState = _context.sent.cachedValue.state;
59
- _context.prev = 14;
60
- console.log(contractState);
61
+ _context.prev = 8;
61
62
  console.log("Deploying ".concat(DEPLOY_FOLDER, " folder"));
62
- _context.next = 19;
63
+ _context.next = 12;
63
64
  return irys.uploadFolder(DEPLOY_FOLDER, {
64
65
  indexFile: 'index.html'
65
66
  });
66
- case 19:
67
+ case 12:
67
68
  txResult = _context.sent;
68
- _context.next = 22;
69
- return new Promise(function (r) {
70
- return setTimeout(r, 1000);
69
+ _context.next = 15;
70
+ return (0, _aoconnect.message)({
71
+ process: ANT_PROCESS,
72
+ signer: (0, _aoconnect.createDataItemSigner)(jwk),
73
+ tags: [{
74
+ name: 'Action',
75
+ value: 'Set-Record'
76
+ }, {
77
+ name: 'Sub-Domain',
78
+ value: '@'
79
+ }, {
80
+ name: 'Transaction-Id',
81
+ value: txResult.id
82
+ }, {
83
+ name: 'TTL-Seconds',
84
+ value: '3600'
85
+ }]
71
86
  });
72
- case 22:
73
- _context.next = 24;
74
- return warpContract.writeInteraction({
75
- "function": 'setRecord',
76
- subDomain: '@',
77
- transactionId: txResult.id,
78
- ttlSeconds: 3600
79
- }, {
80
- disableBundling: true
87
+ case 15:
88
+ response = _context.sent;
89
+ _context.next = 18;
90
+ return (0, _aoconnect.result)({
91
+ message: response,
92
+ process: ANT_PROCESS
81
93
  });
82
- case 24:
83
- console.log("Deployed [".concat(txResult.id, "] to [").concat(contractState.name, "]"));
84
- _context.next = 30;
94
+ case 18:
95
+ _yield$result = _context.sent;
96
+ Messages = _yield$result.Messages;
97
+ if (Messages && Messages.length > 0) {
98
+ responseAction = getTagValue(Messages[0].Tags, 'Action');
99
+ if (responseAction) {
100
+ if (responseAction === 'Set-Record-Notice') console.log("Deployed Tx [".concat(txResult.id, "] to ANT process [").concat(ANT_PROCESS, "]"));else if (responseAction === 'Invalid-Set-Record-Notice') console.log('Error deploying bundle');else console.error('Error deploying bundle');
101
+ }
102
+ } else {
103
+ console.error('Error deploying bundle');
104
+ }
105
+ _context.next = 26;
85
106
  break;
86
- case 27:
87
- _context.prev = 27;
88
- _context.t0 = _context["catch"](14);
107
+ case 23:
108
+ _context.prev = 23;
109
+ _context.t0 = _context["catch"](8);
89
110
  console.error(_context.t0);
90
- case 30:
111
+ case 26:
91
112
  case "end":
92
113
  return _context.stop();
93
114
  }
94
- }, _callee, null, [[14, 27]]);
115
+ }, _callee, null, [[8, 23]]);
95
116
  }))();
package/package.json CHANGED
@@ -1,11 +1,10 @@
1
1
  {
2
2
  "name": "permaweb-deploy",
3
- "version": "1.0.1",
3
+ "version": "1.1.0",
4
4
  "description": "Permaweb app deployment package",
5
5
  "main": "index.js",
6
+ "type": "module",
6
7
  "scripts": {
7
- "format": "eslint --fix . && npx prettier --write .",
8
- "start": "node src/index.js",
9
8
  "build": "babel src --out-dir dist"
10
9
  },
11
10
  "bin": {
@@ -13,8 +12,7 @@
13
12
  },
14
13
  "dependencies": {
15
14
  "@irys/sdk": "0.1.0-a1",
16
- "arweave": "1.13.7",
17
- "warp-contracts": "1.4.26",
15
+ "@permaweb/aoconnect": "^0.0.56",
18
16
  "yargs": "^17.7.2"
19
17
  },
20
18
  "devDependencies": {
package/src/index.js CHANGED
@@ -3,64 +3,80 @@
3
3
  import yargs from 'yargs';
4
4
  import { hideBin } from 'yargs/helpers';
5
5
 
6
- import Arweave from 'arweave';
7
6
  import Irys from '@irys/sdk';
8
- import { defaultCacheOptions, WarpFactory } from 'warp-contracts';
7
+ import { createDataItemSigner, message, result } from '@permaweb/aoconnect';
8
+
9
+ const argv = yargs(hideBin(process.argv))
10
+ .option('ant-process', {
11
+ alias: 'a',
12
+ type: 'string',
13
+ description: 'The ANT process',
14
+ demandOption: true,
15
+ })
16
+ .argv;
9
17
 
10
18
  const DEPLOY_FOLDER = './dist';
11
19
  const DEPLOY_KEY = process.env.DEPLOY_KEY;
20
+ const ANT_PROCESS = argv.antProcess;
12
21
 
13
- const argv = yargs(hideBin(process.argv))
14
- .option('ant-contract', {
15
- alias: 'a',
16
- type: 'string',
17
- description: 'The ANT contract address',
18
- demandOption: true,
19
- })
20
- .argv;
21
-
22
- const ANT_CONTRACT = argv.antContract;
22
+ export function getTagValue(list, name) {
23
+ for (let i = 0; i < list.length; i++) {
24
+ if (list[i]) {
25
+ if (list[i].name === name) {
26
+ return list[i].value;
27
+ }
28
+ }
29
+ }
30
+ return STORAGE.none;
31
+ }
23
32
 
24
33
  (async () => {
25
- if (!DEPLOY_KEY) {
26
- console.error('DEPLOY_KEY not configured');
27
- return;
28
- }
34
+ if (!DEPLOY_KEY) {
35
+ console.error('DEPLOY_KEY not configured');
36
+ return;
37
+ }
29
38
 
30
- if (!ANT_CONTRACT) {
31
- console.error('ANT_CONTRACT not configured');
32
- return;
33
- }
39
+ if (!ANT_PROCESS) {
40
+ console.error('ANT_PROCESS not configured');
41
+ return;
42
+ }
34
43
 
35
- const jwk = JSON.parse(Buffer.from(DEPLOY_KEY, 'base64').toString('utf-8'));
36
- const irys = new Irys({ url: 'https://turbo.ardrive.io', token: 'arweave', key: jwk });
37
- const arweave = Arweave.init({ host: 'arweave.net', port: 443, protocol: 'https' });
38
-
39
- const warp = WarpFactory.custom(arweave, defaultCacheOptions, 'mainnet').useArweaveGateway().build();
40
- const warpContract = warp.contract(ANT_CONTRACT).connect(jwk);
41
- const contractState = (await warpContract.readState()).cachedValue.state;
44
+ let jwk = JSON.parse(Buffer.from(DEPLOY_KEY, 'base64').toString('utf-8'));
45
+
46
+ const irys = new Irys({ url: 'https://turbo.ardrive.io', token: 'arweave', key: jwk });
42
47
 
43
- try {
44
- console.log(contractState);
45
- console.log(`Deploying ${DEPLOY_FOLDER} folder`);
48
+ try {
49
+ console.log(`Deploying ${DEPLOY_FOLDER} folder`);
46
50
 
47
- const txResult = await irys.uploadFolder(DEPLOY_FOLDER, {
48
- indexFile: 'index.html',
49
- });
51
+ const txResult = await irys.uploadFolder(DEPLOY_FOLDER, {
52
+ indexFile: 'index.html',
53
+ });
50
54
 
51
- await new Promise((r) => setTimeout(r, 1000));
52
- await warpContract.writeInteraction(
53
- {
54
- function: 'setRecord',
55
- subDomain: '@',
56
- transactionId: txResult.id,
57
- ttlSeconds: 3600,
58
- },
59
- { disableBundling: true }
60
- );
55
+ const response = await message({
56
+ process: ANT_PROCESS,
57
+ signer: createDataItemSigner(jwk),
58
+ tags: [
59
+ { name: 'Action', value: 'Set-Record' },
60
+ { name: 'Sub-Domain', value: '@' },
61
+ { name: 'Transaction-Id', value: txResult.id },
62
+ { name: 'TTL-Seconds', value: '3600' },
63
+ ],
64
+ });
61
65
 
62
- console.log(`Deployed [${txResult.id}] to [${contractState.name}]`);
63
- } catch (e) {
64
- console.error(e);
65
- }
66
+ const { Messages } = await result({ message: response, process: ANT_PROCESS });
67
+
68
+ if (Messages && Messages.length > 0) {
69
+ const responseAction = getTagValue(Messages[0].Tags, 'Action');
70
+ if (responseAction) {
71
+ if (responseAction === 'Set-Record-Notice') console.log(`Deployed Tx [${txResult.id}] to ANT process [${ANT_PROCESS}]`);
72
+ else if (responseAction === 'Invalid-Set-Record-Notice') console.log('Error deploying bundle');
73
+ else console.error('Error deploying bundle');
74
+ }
75
+ }
76
+ else {
77
+ console.error('Error deploying bundle')
78
+ }
79
+ } catch (e) {
80
+ console.error(e);
81
+ }
66
82
  })();