@nlabs/reaktor 0.1.4 → 0.1.6

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/lib/data/s3.js CHANGED
@@ -100,4 +100,4 @@ export var s3DeleteList = function s3DeleteList(params) {
100
100
  });
101
101
  });
102
102
  };
103
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/s3.ts"],"names":["aws","S3","Config","s3Get","params","Promise","resolve","reject","config","update","get","s3","Bucket","getObject","error","output","s3Head","headObject","s3Put","StorageClass","putObject","s3Delete","deleteObject","s3DeleteList","deleteObjects"],"mappings":"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","sourcesContent":["/**\n * Copyright (c) 2019-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport aws, {S3} from 'aws-sdk';\nimport {\n  DeleteObjectOutput,\n  DeleteObjectRequest,\n  DeleteObjectsOutput,\n  DeleteObjectsRequest,\n  GetObjectOutput,\n  GetObjectRequest,\n  HeadObjectOutput,\n  HeadObjectRequest,\n  PutObjectOutput,\n  PutObjectRequest\n} from 'aws-sdk/clients/s3';\n\nimport {Config} from '../config';\n\n// AWS S3\n// const eventCategory: string = 's3';\n\nexport const s3Get = (params: GetObjectRequest): Promise<GetObjectOutput> => {\n  return new Promise((resolve, reject) => {\n    aws.config.update(Config.get('aws'));\n    const s3: S3 = new S3();\n\n    if(!params.Bucket) {\n      params.Bucket = Config.get('aws.Bucket');\n    }\n\n    s3.getObject(params, (error: Error, output: GetObjectOutput) => {\n      if(error) {\n        return reject(error);\n      }\n\n      return resolve(output);\n    });\n  });\n};\n\nexport const s3Head = (params: HeadObjectRequest): Promise<HeadObjectOutput> => {\n  return new Promise((resolve, reject) => {\n    aws.config.update(Config.get('aws'));\n    const s3: S3 = new S3();\n\n    if(!params.Bucket) {\n      params.Bucket = Config.get('aws.Bucket');\n    }\n\n    s3.headObject(params, (error: Error, output: HeadObjectOutput) => {\n      if(error) {\n        return reject(error);\n      }\n      return resolve(output);\n    });\n  });\n};\n\nexport const s3Put = (params: PutObjectRequest): Promise<PutObjectOutput> => {\n  return new Promise((resolve, reject) => {\n    aws.config.update(Config.get('aws'));\n    const s3 = new aws.S3();\n\n    if(!params.Bucket) {\n      params.Bucket = Config.get('aws.Bucket');\n    }\n\n    if(!params.StorageClass) {\n      params.StorageClass = 'REDUCED_REDUNDANCY';\n    }\n\n    s3.putObject(params, (error: Error, output: PutObjectOutput) => {\n      if(error) {\n        return reject(error);\n      }\n      return resolve(output);\n    });\n  });\n};\n\nexport const s3Delete = (params: DeleteObjectRequest): Promise<DeleteObjectOutput> => {\n  return new Promise((resolve, reject) => {\n    aws.config.update(Config.get('aws'));\n    const s3: S3 = new S3();\n\n    if(!params.Bucket) {\n      params.Bucket = Config.get('aws.Bucket');\n    }\n\n    s3.deleteObject(params, (error, output: DeleteObjectOutput) => {\n      if(error) {\n        return reject(error);\n      }\n      return resolve(output);\n    });\n  });\n};\n\nexport const s3DeleteList = (params: DeleteObjectsRequest): Promise<DeleteObjectsOutput> => {\n  return new Promise((resolve, reject) => {\n    aws.config.update(Config.get('aws'));\n    const s3: S3 = new S3();\n\n    if(!params.Bucket) {\n      params.Bucket = Config.get('aws.Bucket');\n    }\n\n    s3.deleteObjects(params, (error: Error, output: DeleteObjectsOutput) => {\n      if(error) {\n        return reject(error);\n      }\n      return resolve(output);\n    });\n  });\n};\n"]}
103
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/s3.ts"],"names":["aws","S3","Config","s3Get","params","Promise","resolve","reject","config","update","get","s3","Bucket","getObject","error","output","s3Head","headObject","s3Put","StorageClass","putObject","s3Delete","deleteObject","s3DeleteList","deleteObjects"],"mappings":"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","sourcesContent":["/**\n * Copyright (c) 2019-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport aws, {S3} from 'aws-sdk';\nimport {\n  DeleteObjectOutput,\n  DeleteObjectRequest,\n  DeleteObjectsOutput,\n  DeleteObjectsRequest,\n  GetObjectOutput,\n  GetObjectRequest,\n  HeadObjectOutput,\n  HeadObjectRequest,\n  PutObjectOutput,\n  PutObjectRequest\n} from 'aws-sdk/clients/s3';\n\nimport {Config} from '../config';\n\n// AWS S3\n// const eventCategory: string = 's3';\n\nexport const s3Get = (params: GetObjectRequest): Promise<GetObjectOutput> =>\n  new Promise((resolve, reject) => {\n    aws.config.update(Config.get('aws'));\n    const s3: S3 = new S3();\n\n    if(!params.Bucket) {\n      params.Bucket = Config.get('aws.Bucket');\n    }\n\n    s3.getObject(params, (error: Error, output: GetObjectOutput) => {\n      if(error) {\n        return reject(error);\n      }\n\n      return resolve(output);\n    });\n  });\n\nexport const s3Head = (params: HeadObjectRequest): Promise<HeadObjectOutput> =>\n  new Promise((resolve, reject) => {\n    aws.config.update(Config.get('aws'));\n    const s3: S3 = new S3();\n\n    if(!params.Bucket) {\n      params.Bucket = Config.get('aws.Bucket');\n    }\n\n    s3.headObject(params, (error: Error, output: HeadObjectOutput) => {\n      if(error) {\n        return reject(error);\n      }\n      return resolve(output);\n    });\n  });\n\n\nexport const s3Put = (params: PutObjectRequest): Promise<PutObjectOutput> =>\n  new Promise((resolve, reject) => {\n    aws.config.update(Config.get('aws'));\n    const s3 = new aws.S3();\n\n    if(!params.Bucket) {\n      params.Bucket = Config.get('aws.Bucket');\n    }\n\n    if(!params.StorageClass) {\n      params.StorageClass = 'REDUCED_REDUNDANCY';\n    }\n\n    s3.putObject(params, (error: Error, output: PutObjectOutput) => {\n      if(error) {\n        return reject(error);\n      }\n      return resolve(output);\n    });\n  });\n\nexport const s3Delete = (params: DeleteObjectRequest): Promise<DeleteObjectOutput> =>\n  new Promise((resolve, reject) => {\n    aws.config.update(Config.get('aws'));\n    const s3: S3 = new S3();\n\n    if(!params.Bucket) {\n      params.Bucket = Config.get('aws.Bucket');\n    }\n\n    s3.deleteObject(params, (error, output: DeleteObjectOutput) => {\n      if(error) {\n        return reject(error);\n      }\n      return resolve(output);\n    });\n  });\n\nexport const s3DeleteList = (params: DeleteObjectsRequest): Promise<DeleteObjectsOutput> =>\n  new Promise((resolve, reject) => {\n    aws.config.update(Config.get('aws'));\n    const s3: S3 = new S3();\n\n    if(!params.Bucket) {\n      params.Bucket = Config.get('aws.Bucket');\n    }\n\n    s3.deleteObjects(params, (error: Error, output: DeleteObjectsOutput) => {\n      if(error) {\n        return reject(error);\n      }\n      return resolve(output);\n    });\n  });\n"]}
@@ -281,4 +281,4 @@ export var deleteSubscription = function deleteSubscription(context, endDate) {
281
281
  });
282
282
  });
283
283
  };
284
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/subscription.ts"],"names":["createHash","parseChar","parseId","parseNum","parseVarChar","aql","DateTime","stripe","Config","getLimit","logError","logException","useDb","getUser","eventCategory","getPlanList","context","from","to","action","database","limit","aqlQry","query","then","cursor","all","list","catch","error","category","label","Promise","reject","getSubscription","sessionId","userId","next","subscription","addPlan","item","userType","isAdmin","value","now","Date","formatId","id","planId","amount","currency","description","interval","intervalCount","name","formatAmount","formatInterval","toLowerCase","formatIntervalCnt","formatName","formatDesc","insert","_key","added","modified","plan","stripeClient","get","plans","create","interval_count","metadata","statement_descriptor","addSubscription","subscriptionId","tax","trialEnd","trialPeriod","formatPlanId","formatTaxPercent","formatTrialPeriod","formatTrialEnd","local","plus","days","toMillis","user","cancelDate","subscriptions","customer","stripeCustomerId","items","tax_percent","trial_end","deleteSubscription","endDate","formatEndDate","del","transactionId","stripeResponse","cancelled","cancel_at_period_end","update"],"mappings":"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","sourcesContent":["/**\n * Copyright (c) 2019-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {createHash, parseChar, parseId, parseNum, parseVarChar} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\nimport {DateTime} from 'luxon';\nimport * as stripe from 'stripe';\n\nimport {Config} from '../config';\nimport {ArangoDBLimit} from '../types/arangodb';\nimport {ApiContext} from '../types/auth';\nimport {PaymentInterval, PaymentPlan, PaymentSubscription} from '../types/payments';\nimport {getLimit, logError, logException, useDb} from '../utils';\nimport {getUser} from './users';\n\nconst eventCategory: string = 'subscription';\n\nexport const getPlanList = (context: ApiContext, from: number = 0, to: number = 30): Promise<PaymentPlan[]> => {\n  const action: string = 'getList';\n  const {database} = context;\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const aqlQry: string = `FOR p IN plans\n      ${limit.aql}\n      SORT p.amount\n      RETURN p`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((list = []) => list)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const getSubscription = (context: ApiContext): Promise<PaymentSubscription> => {\n  const action: string = 'getItem';\n  const {database, userId: sessionId} = context;\n  const aqlQry: string = `FOR s IN subscriptions\n      FILTER s.userId == ${sessionId} && s.cancelled > 0\n      LET plan = FIRST(\n        FOR p IN plans\n        FILTER p._key == s.planId\n      )\n      LIMIT 1\n      RETURN MERGE(s, {plan: plan})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((subscription = {}) => subscription)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n}\n\nexport const addPlan = (context: ApiContext, item: PaymentPlan): Promise<PaymentPlan> => {\n  const action: string = 'addPlan';\n  const {database, userId: sessionId, userType} = context;\n  const isAdmin: boolean = userType > 2;\n\n  if(!isAdmin) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const now: number = Date.now();\n  const formatId: string = parseId(item.id);\n  const planId: string = formatId === '' ? createHash(`tag-${sessionId}`) : formatId;\n  const {amount, currency = 'USD', description, interval, intervalCount, name} = item;\n  const formatAmount: number = parseNum(amount);\n  const formatInterval: PaymentInterval = parseChar(interval, 5).toLowerCase() as PaymentInterval;\n  const formatIntervalCnt: number = parseNum(intervalCount, 5);\n  const formatName: string = parseVarChar(name, 32);\n  const formatDesc: string = parseVarChar(description, 32);\n\n  const insert: PaymentPlan = {\n    _key: planId,\n    added: now,\n    amount: formatAmount,\n    currency,\n    description: formatDesc,\n    interval: formatInterval,\n    intervalCount: formatIntervalCnt,\n    modified: now,\n    name: formatName\n  };\n  const aqlQry: AqlQuery = aql`INSERT ${insert} IN plans RETURN NEW`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((plan: PaymentPlan = {}) => {\n      // Stripe\n      const stripeClient = stripe(Config.get('stripe.token'));\n      return stripeClient.plans\n        .create({\n          amount: formatAmount * 100,\n          currency,\n          id: planId,\n          interval: formatInterval,\n          interval_count: formatIntervalCnt,\n          metadata: {\n          },\n          name: formatName,\n          statement_descriptor: formatDesc\n        })\n        .then(() => plan);\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const addSubscription = (context: ApiContext, item): Promise<PaymentSubscription> => {\n  const action: string = 'addSubscription';\n  const {database, userId: sessionId, userType} = context;\n  const isAdmin: boolean = userType > 2;\n\n  if(!isAdmin) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const now: number = Date.now();\n  const formatId: string = parseId(item.id);\n  const subscriptionId: string = formatId === '' ? createHash(`tag-${sessionId}`) : formatId;\n  const {planId, tax, trialEnd, trialPeriod} = item;\n  const formatPlanId: string = parseId(planId);\n  const formatTaxPercent: number = parseNum(tax) || 0;\n  const formatTrialPeriod: number = parseNum(tax) || 0;\n  let formatTrialEnd: number = trialEnd || Date.now();\n\n  if(formatTrialPeriod) {\n    formatTrialEnd = DateTime.local().plus({days: trialPeriod}).toMillis();\n  }\n\n  return getUser(context, sessionId)\n    .then((user) => {\n      const insert: PaymentSubscription = {\n        _key: subscriptionId,\n        added: now,\n        cancelDate: 0,\n        modified: now,\n        planId: formatPlanId,\n        tax: formatTaxPercent,\n        trialEnd: formatTrialEnd,\n        userId: sessionId\n      };\n      const aqlQry: AqlQuery = aql`INSERT ${insert} IN plans RETURN NEW`;\n\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then((subscription: PaymentSubscription = {}) => {\n          // Stripe\n          const stripeClient = stripe(Config.get('stripe.token'));\n          return stripeClient.subscriptions\n            .create({\n              customer: user.stripeCustomerId,\n              items: [\n                {plan: formatPlanId}\n              ],\n              metadata: {\n                userId: sessionId\n              },\n              tax_percent: formatTaxPercent * 100,\n              trial_end: formatTrialEnd\n            })\n            .then(() => subscription);\n        })\n        .catch((error: Error) => logError({\n          action,\n          category: eventCategory,\n          label: 'db_error'\n        }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n    });\n};\n\nexport const deleteSubscription = (context: ApiContext, endDate: number): Promise<boolean> => {\n  const action: string = 'deleteSubscription';\n  const {database} = context;\n  const now: number = Date.now();\n  const formatEndDate: number = parseNum(endDate) || now;\n\n  return getSubscription(context)\n    .then((subscription) => {\n      // Stripe\n      const stripeClient = stripe(Config.get('stripe.token'));\n      return stripeClient.subscriptions\n        .del(subscription.transactionId, {\n          subscription: formatEndDate\n        })\n        .then((stripeResponse) => {\n          // Make sure we cancelled on Stripe before updating the db\n          if(stripeResponse.cancelled || stripeResponse.cancel_at_period_end) {\n            const update: PaymentSubscription = {\n              cancelDate: formatEndDate,\n              modified: now,\n              planId: ''\n            };\n            const aqlQry: AqlQuery = aql`UPDATE s WITH ${update} IN subscriptions`;\n\n            return useDb(database).query(aqlQry)\n              .then(() => true)\n              .catch((error: Error) => logError({\n                action,\n                category: eventCategory,\n                label: 'db_error'\n              }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n          }\n          return false;\n        });\n    });\n};\n"]}
284
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/subscription.ts"],"names":["createHash","parseChar","parseId","parseNum","parseVarChar","aql","DateTime","stripe","Config","getLimit","logError","logException","useDb","getUser","eventCategory","getPlanList","context","from","to","action","database","limit","aqlQry","query","then","cursor","all","list","catch","error","category","label","Promise","reject","getSubscription","sessionId","userId","next","subscription","addPlan","item","userType","isAdmin","value","now","Date","formatId","id","planId","amount","currency","description","interval","intervalCount","name","formatAmount","formatInterval","toLowerCase","formatIntervalCnt","formatName","formatDesc","insert","_key","added","modified","plan","stripeClient","get","plans","create","interval_count","metadata","statement_descriptor","addSubscription","subscriptionId","tax","trialEnd","trialPeriod","formatPlanId","formatTaxPercent","formatTrialPeriod","formatTrialEnd","local","plus","days","toMillis","user","cancelDate","subscriptions","customer","stripeCustomerId","items","tax_percent","trial_end","deleteSubscription","endDate","formatEndDate","del","transactionId","stripeResponse","cancelled","cancel_at_period_end","update"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;;;AAIA,SAAQA,UAAR,EAAoBC,SAApB,EAA+BC,OAA/B,EAAwCC,QAAxC,EAAkDC,YAAlD,QAAqE,cAArE;AACA,SAAQC,GAAR,QAAkB,UAAlB;AAGA,SAAQC,QAAR,QAAuB,OAAvB;AACA,OAAO,KAAKC,MAAZ,MAAwB,QAAxB;AAEA,SAAQC,MAAR,QAAqB,WAArB;AAIA,SAAQC,QAAR,EAAkBC,QAAlB,EAA4BC,YAA5B,EAA0CC,KAA1C,QAAsD,UAAtD;AACA,SAAQC,OAAR,QAAsB,SAAtB;AAEA,IAAMC,aAAqB,GAAG,cAA9B;AAEA,OAAO,IAAMC,WAAW,GAAG,SAAdA,WAAc,CAACC,OAAD,EAAoF;AAAA,MAA9DC,IAA8D,uEAA/C,CAA+C;AAAA,MAA5CC,EAA4C,uEAA/B,EAA+B;AAC7G,MAAMC,MAAc,GAAG,SAAvB;AAD6G,MAEtGC,QAFsG,GAE1FJ,OAF0F,CAEtGI,QAFsG;AAG7G,MAAMC,KAAoB,GAAGZ,QAAQ,CAACQ,IAAD,EAAOC,EAAP,CAArC;AACA,MAAMI,MAAc,mCACdD,KAAK,CAAChB,GADQ,0CAApB;AAKA,SAAOO,KAAK,CAACQ,QAAD,CAAL,CAAgBG,KAAhB,CAAsBD,MAAtB,EACJE,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACC,GAAP,EAAzB;AAAA,GADD,EAEJF,IAFI,CAEC;AAAA,QAACG,IAAD,uEAAQ,EAAR;AAAA,WAAeA,IAAf;AAAA,GAFD,EAGJC,KAHI,CAGE,UAACC,KAAD;AAAA,WAAkBnB,QAAQ,CAAC;AAChCS,MAAAA,MAAM,EAANA,MADgC;AAEhCW,MAAAA,QAAQ,EAAEhB,aAFsB;AAGhCiB,MAAAA,KAAK,EAAE;AAHyB,KAAD,EAI9BF,KAJ8B,EAIvB,EAJuB,CAAR,CAIXL,IAJW,CAIN;AAAA,aAAM,IAAN;AAAA,KAJM,EAIMI,KAJN,CAIY,UAACC,KAAD;AAAA,aAAWG,OAAO,CAACC,MAAR,CAAeJ,KAAf,CAAX;AAAA,KAJZ,CAAlB;AAAA,GAHF,CAAP;AAQD,CAjBM;AAmBP,OAAO,IAAMK,eAAe,GAAG,SAAlBA,eAAkB,CAAClB,OAAD,EAAuD;AACpF,MAAMG,MAAc,GAAG,SAAvB;AADoF,MAE7EC,QAF6E,GAE9CJ,OAF8C,CAE7EI,QAF6E;AAAA,MAE3De,SAF2D,GAE9CnB,OAF8C,CAEnEoB,MAFmE;AAGpF,MAAMd,MAAc,8DACKa,SADL,yKAApB;AASA,SAAOvB,KAAK,CAACQ,QAAD,CAAL,CAAgBG,KAAhB,CAAsBD,MAAtB,EACJE,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACY,IAAP,EAAzB;AAAA,GADD,EAEJb,IAFI,CAEC;AAAA,QAACc,YAAD,uEAAgB,EAAhB;AAAA,WAAuBA,YAAvB;AAAA,GAFD,EAGJV,KAHI,CAGE,UAACC,KAAD;AAAA,WAAkBnB,QAAQ,CAAC;AAChCS,MAAAA,MAAM,EAANA,MADgC;AAEhCW,MAAAA,QAAQ,EAAEhB,aAFsB;AAGhCiB,MAAAA,KAAK,EAAE;AAHyB,KAAD,EAI9BF,KAJ8B,EAIvB,EAJuB,CAAR,CAIXL,IAJW,CAIN;AAAA,aAAM,IAAN;AAAA,KAJM,EAIMI,KAJN,CAIY,UAACC,KAAD;AAAA,aAAWG,OAAO,CAACC,MAAR,CAAeJ,KAAf,CAAX;AAAA,KAJZ,CAAlB;AAAA,GAHF,CAAP;AAQD,CApBM;AAsBP,OAAO,IAAMU,OAAO,GAAG,SAAVA,OAAU,CAACvB,OAAD,EAAsBwB,IAAtB,EAAkE;AACvF,MAAMrB,MAAc,GAAG,SAAvB;AADuF,MAEhFC,QAFgF,GAEvCJ,OAFuC,CAEhFI,QAFgF;AAAA,MAE9De,SAF8D,GAEvCnB,OAFuC,CAEtEoB,MAFsE;AAAA,MAEnDK,QAFmD,GAEvCzB,OAFuC,CAEnDyB,QAFmD;AAGvF,MAAMC,OAAgB,GAAGD,QAAQ,GAAG,CAApC;;AAEA,MAAG,CAACC,OAAJ,EAAa;AACX,WAAO/B,YAAY,CAAC;AAClBQ,MAAAA,MAAM,EAANA,MADkB;AAElBW,MAAAA,QAAQ,EAAEhB,aAFQ;AAGlBiB,MAAAA,KAAK,EAAE,cAHW;AAIlBY,MAAAA,KAAK,EAAE;AAJW,KAAD,EAKhB3B,OALgB,CAAZ,CAKKQ,IALL,CAKU;AAAA,aAAM,IAAN;AAAA,KALV,CAAP;AAMD;;AAED,MAAMoB,GAAW,GAAGC,IAAI,CAACD,GAAL,EAApB;AACA,MAAME,QAAgB,GAAG5C,OAAO,CAACsC,IAAI,CAACO,EAAN,CAAhC;AACA,MAAMC,MAAc,GAAGF,QAAQ,KAAK,EAAb,GAAkB9C,UAAU,eAAQmC,SAAR,EAA5B,GAAmDW,QAA1E;AAhBuF,MAiBhFG,MAjBgF,GAiBRT,IAjBQ,CAiBhFS,MAjBgF;AAAA,uBAiBRT,IAjBQ,CAiBxEU,QAjBwE;AAAA,MAiBxEA,QAjBwE,+BAiB7D,KAjB6D;AAAA,MAiBtDC,WAjBsD,GAiBRX,IAjBQ,CAiBtDW,WAjBsD;AAAA,MAiBzCC,QAjByC,GAiBRZ,IAjBQ,CAiBzCY,QAjByC;AAAA,MAiB/BC,aAjB+B,GAiBRb,IAjBQ,CAiB/Ba,aAjB+B;AAAA,MAiBhBC,IAjBgB,GAiBRd,IAjBQ,CAiBhBc,IAjBgB;AAkBvF,MAAMC,YAAoB,GAAGpD,QAAQ,CAAC8C,MAAD,CAArC;AACA,MAAMO,cAA+B,GAAGvD,SAAS,CAACmD,QAAD,EAAW,CAAX,CAAT,CAAuBK,WAAvB,EAAxC;AACA,MAAMC,iBAAyB,GAAGvD,QAAQ,CAACkD,aAAD,EAAgB,CAAhB,CAA1C;AACA,MAAMM,UAAkB,GAAGvD,YAAY,CAACkD,IAAD,EAAO,EAAP,CAAvC;AACA,MAAMM,UAAkB,GAAGxD,YAAY,CAAC+C,WAAD,EAAc,EAAd,CAAvC;AAEA,MAAMU,MAAmB,GAAG;AAC1BC,IAAAA,IAAI,EAAEd,MADoB;AAE1Be,IAAAA,KAAK,EAAEnB,GAFmB;AAG1BK,IAAAA,MAAM,EAAEM,YAHkB;AAI1BL,IAAAA,QAAQ,EAARA,QAJ0B;AAK1BC,IAAAA,WAAW,EAAES,UALa;AAM1BR,IAAAA,QAAQ,EAAEI,cANgB;AAO1BH,IAAAA,aAAa,EAAEK,iBAPW;AAQ1BM,IAAAA,QAAQ,EAAEpB,GARgB;AAS1BU,IAAAA,IAAI,EAAEK;AAToB,GAA5B;AAWA,MAAMrC,MAAgB,GAAGjB,GAAH,oBAAgBwD,MAAhB,CAAtB;AAEA,SAAOjD,KAAK,CAACQ,QAAD,CAAL,CAAgBG,KAAhB,CAAsBD,MAAtB,EACJE,IADI,CACC,UAACC,MAAD;AAAA,WAAyBA,MAAM,CAACY,IAAP,EAAzB;AAAA,GADD,EAEJb,IAFI,CAEC,YAA4B;AAAA,QAA3ByC,IAA2B,uEAAP,EAAO;AAChC;AACA,QAAMC,YAAY,GAAG3D,MAAM,CAACC,MAAM,CAAC2D,GAAP,CAAW,cAAX,CAAD,CAA3B;AACA,WAAOD,YAAY,CAACE,KAAb,CACJC,MADI,CACG;AACNpB,MAAAA,MAAM,EAAEM,YAAY,GAAG,GADjB;AAENL,MAAAA,QAAQ,EAARA,QAFM;AAGNH,MAAAA,EAAE,EAAEC,MAHE;AAINI,MAAAA,QAAQ,EAAEI,cAJJ;AAKNc,MAAAA,cAAc,EAAEZ,iBALV;AAMNa,MAAAA,QAAQ,EAAE,EANJ;AAQNjB,MAAAA,IAAI,EAAEK,UARA;AASNa,MAAAA,oBAAoB,EAAEZ;AAThB,KADH,EAYJpC,IAZI,CAYC;AAAA,aAAMyC,IAAN;AAAA,KAZD,CAAP;AAaD,GAlBI,EAmBJrC,KAnBI,CAmBE,UAACC,KAAD;AAAA,WAAkBnB,QAAQ,CAAC;AAChCS,MAAAA,MAAM,EAANA,MADgC;AAEhCW,MAAAA,QAAQ,EAAEhB,aAFsB;AAGhCiB,MAAAA,KAAK,EAAE;AAHyB,KAAD,EAI9BF,KAJ8B,EAIvB,EAJuB,CAAR,CAIXL,IAJW,CAIN;AAAA,aAAM,IAAN;AAAA,KAJM,EAIMI,KAJN,CAIY,UAACC,KAAD;AAAA,aAAWG,OAAO,CAACC,MAAR,CAAeJ,KAAf,CAAX;AAAA,KAJZ,CAAlB;AAAA,GAnBF,CAAP;AAwBD,CA7DM;AA+DP,OAAO,IAAM4C,eAAe,GAAG,SAAlBA,eAAkB,CAACzD,OAAD,EAAsBwB,IAAtB,EAA6D;AAC1F,MAAMrB,MAAc,GAAG,iBAAvB;AAD0F,MAEnFC,QAFmF,GAE1CJ,OAF0C,CAEnFI,QAFmF;AAAA,MAEjEe,SAFiE,GAE1CnB,OAF0C,CAEzEoB,MAFyE;AAAA,MAEtDK,QAFsD,GAE1CzB,OAF0C,CAEtDyB,QAFsD;AAG1F,MAAMC,OAAgB,GAAGD,QAAQ,GAAG,CAApC;;AAEA,MAAG,CAACC,OAAJ,EAAa;AACX,WAAO/B,YAAY,CAAC;AAClBQ,MAAAA,MAAM,EAANA,MADkB;AAElBW,MAAAA,QAAQ,EAAEhB,aAFQ;AAGlBiB,MAAAA,KAAK,EAAE,cAHW;AAIlBY,MAAAA,KAAK,EAAE;AAJW,KAAD,EAKhB3B,OALgB,CAAZ,CAKKQ,IALL,CAKU;AAAA,aAAM,IAAN;AAAA,KALV,CAAP;AAMD;;AAED,MAAMoB,GAAW,GAAGC,IAAI,CAACD,GAAL,EAApB;AACA,MAAME,QAAgB,GAAG5C,OAAO,CAACsC,IAAI,CAACO,EAAN,CAAhC;AACA,MAAM2B,cAAsB,GAAG5B,QAAQ,KAAK,EAAb,GAAkB9C,UAAU,eAAQmC,SAAR,EAA5B,GAAmDW,QAAlF;AAhB0F,MAiBnFE,MAjBmF,GAiB7CR,IAjB6C,CAiBnFQ,MAjBmF;AAAA,MAiB3E2B,GAjB2E,GAiB7CnC,IAjB6C,CAiB3EmC,GAjB2E;AAAA,MAiBtEC,QAjBsE,GAiB7CpC,IAjB6C,CAiBtEoC,QAjBsE;AAAA,MAiB5DC,WAjB4D,GAiB7CrC,IAjB6C,CAiB5DqC,WAjB4D;AAkB1F,MAAMC,YAAoB,GAAG5E,OAAO,CAAC8C,MAAD,CAApC;AACA,MAAM+B,gBAAwB,GAAG5E,QAAQ,CAACwE,GAAD,CAAR,IAAiB,CAAlD;AACA,MAAMK,iBAAyB,GAAG7E,QAAQ,CAACwE,GAAD,CAAR,IAAiB,CAAnD;AACA,MAAIM,cAAsB,GAAGL,QAAQ,IAAI/B,IAAI,CAACD,GAAL,EAAzC;;AAEA,MAAGoC,iBAAH,EAAsB;AACpBC,IAAAA,cAAc,GAAG3E,QAAQ,CAAC4E,KAAT,GAAiBC,IAAjB,CAAsB;AAACC,MAAAA,IAAI,EAAEP;AAAP,KAAtB,EAA2CQ,QAA3C,EAAjB;AACD;;AAED,SAAOxE,OAAO,CAACG,OAAD,EAAUmB,SAAV,CAAP,CACJX,IADI,CACC,UAAC8D,IAAD,EAAU;AACd,QAAMzB,MAA2B,GAAG;AAClCC,MAAAA,IAAI,EAAEY,cAD4B;AAElCX,MAAAA,KAAK,EAAEnB,GAF2B;AAGlC2C,MAAAA,UAAU,EAAE,CAHsB;AAIlCvB,MAAAA,QAAQ,EAAEpB,GAJwB;AAKlCI,MAAAA,MAAM,EAAE8B,YAL0B;AAMlCH,MAAAA,GAAG,EAAEI,gBAN6B;AAOlCH,MAAAA,QAAQ,EAAEK,cAPwB;AAQlC7C,MAAAA,MAAM,EAAED;AAR0B,KAApC;AAUA,QAAMb,MAAgB,GAAGjB,GAAH,qBAAgBwD,MAAhB,CAAtB;AAEA,WAAOjD,KAAK,CAACQ,QAAD,CAAL,CAAgBG,KAAhB,CAAsBD,MAAtB,EACJE,IADI,CACC,UAACC,MAAD;AAAA,aAAyBA,MAAM,CAACY,IAAP,EAAzB;AAAA,KADD,EAEJb,IAFI,CAEC,YAA4C;AAAA,UAA3Cc,YAA2C,uEAAP,EAAO;AAChD;AACA,UAAM4B,YAAY,GAAG3D,MAAM,CAACC,MAAM,CAAC2D,GAAP,CAAW,cAAX,CAAD,CAA3B;AACA,aAAOD,YAAY,CAACsB,aAAb,CACJnB,MADI,CACG;AACNoB,QAAAA,QAAQ,EAAEH,IAAI,CAACI,gBADT;AAENC,QAAAA,KAAK,EAAE,CACL;AAAC1B,UAAAA,IAAI,EAAEa;AAAP,SADK,CAFD;AAKNP,QAAAA,QAAQ,EAAE;AACRnC,UAAAA,MAAM,EAAED;AADA,SALJ;AAQNyD,QAAAA,WAAW,EAAEb,gBAAgB,GAAG,GAR1B;AASNc,QAAAA,SAAS,EAAEZ;AATL,OADH,EAYJzD,IAZI,CAYC;AAAA,eAAMc,YAAN;AAAA,OAZD,CAAP;AAaD,KAlBI,EAmBJV,KAnBI,CAmBE,UAACC,KAAD;AAAA,aAAkBnB,QAAQ,CAAC;AAChCS,QAAAA,MAAM,EAANA,MADgC;AAEhCW,QAAAA,QAAQ,EAAEhB,aAFsB;AAGhCiB,QAAAA,KAAK,EAAE;AAHyB,OAAD,EAI9BF,KAJ8B,EAIvB,EAJuB,CAAR,CAIXL,IAJW,CAIN;AAAA,eAAM,IAAN;AAAA,OAJM,EAIMI,KAJN,CAIY,UAACC,KAAD;AAAA,eAAWG,OAAO,CAACC,MAAR,CAAeJ,KAAf,CAAX;AAAA,OAJZ,CAAlB;AAAA,KAnBF,CAAP;AAwBD,GAtCI,CAAP;AAuCD,CAlEM;AAoEP,OAAO,IAAMiE,kBAAkB,GAAG,SAArBA,kBAAqB,CAAC9E,OAAD,EAAsB+E,OAAtB,EAA4D;AAC5F,MAAM5E,MAAc,GAAG,oBAAvB;AAD4F,MAErFC,QAFqF,GAEzEJ,OAFyE,CAErFI,QAFqF;AAG5F,MAAMwB,GAAW,GAAGC,IAAI,CAACD,GAAL,EAApB;AACA,MAAMoD,aAAqB,GAAG7F,QAAQ,CAAC4F,OAAD,CAAR,IAAqBnD,GAAnD;AAEA,SAAOV,eAAe,CAAClB,OAAD,CAAf,CACJQ,IADI,CACC,UAACc,YAAD,EAAkB;AACtB;AACA,QAAM4B,YAAY,GAAG3D,MAAM,CAACC,MAAM,CAAC2D,GAAP,CAAW,cAAX,CAAD,CAA3B;AACA,WAAOD,YAAY,CAACsB,aAAb,CACJS,GADI,CACA3D,YAAY,CAAC4D,aADb,EAC4B;AAC/B5D,MAAAA,YAAY,EAAE0D;AADiB,KAD5B,EAIJxE,IAJI,CAIC,UAAC2E,cAAD,EAAoB;AACxB;AACA,UAAGA,cAAc,CAACC,SAAf,IAA4BD,cAAc,CAACE,oBAA9C,EAAoE;AAClE,YAAMC,MAA2B,GAAG;AAClCf,UAAAA,UAAU,EAAES,aADsB;AAElChC,UAAAA,QAAQ,EAAEpB,GAFwB;AAGlCI,UAAAA,MAAM,EAAE;AAH0B,SAApC;AAKA,YAAM1B,MAAgB,GAAGjB,GAAH,qBAAuBiG,MAAvB,CAAtB;AAEA,eAAO1F,KAAK,CAACQ,QAAD,CAAL,CAAgBG,KAAhB,CAAsBD,MAAtB,EACJE,IADI,CACC;AAAA,iBAAM,IAAN;AAAA,SADD,EAEJI,KAFI,CAEE,UAACC,KAAD;AAAA,iBAAkBnB,QAAQ,CAAC;AAChCS,YAAAA,MAAM,EAANA,MADgC;AAEhCW,YAAAA,QAAQ,EAAEhB,aAFsB;AAGhCiB,YAAAA,KAAK,EAAE;AAHyB,WAAD,EAI9BF,KAJ8B,EAIvB,EAJuB,CAAR,CAIXL,IAJW,CAIN;AAAA,mBAAM,IAAN;AAAA,WAJM,EAIMI,KAJN,CAIY,UAACC,KAAD;AAAA,mBAAWG,OAAO,CAACC,MAAR,CAAeJ,KAAf,CAAX;AAAA,WAJZ,CAAlB;AAAA,SAFF,CAAP;AAOD;;AACD,aAAO,KAAP;AACD,KAvBI,CAAP;AAwBD,GA5BI,CAAP;AA6BD,CAnCM","sourcesContent":["/**\n * Copyright (c) 2019-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {createHash, parseChar, parseId, parseNum, parseVarChar} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\nimport {DateTime} from 'luxon';\nimport * as stripe from 'stripe';\n\nimport {Config} from '../config';\nimport {ArangoDBLimit} from '../types/arangodb';\nimport {ApiContext} from '../types/auth';\nimport {PaymentInterval, PaymentPlan, PaymentSubscription} from '../types/payments';\nimport {getLimit, logError, logException, useDb} from '../utils';\nimport {getUser} from './users';\n\nconst eventCategory: string = 'subscription';\n\nexport const getPlanList = (context: ApiContext, from: number = 0, to: number = 30): Promise<PaymentPlan[]> => {\n  const action: string = 'getList';\n  const {database} = context;\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const aqlQry: string = `FOR p IN plans\n      ${limit.aql}\n      SORT p.amount\n      RETURN p`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((list = []) => list)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const getSubscription = (context: ApiContext): Promise<PaymentSubscription> => {\n  const action: string = 'getItem';\n  const {database, userId: sessionId} = context;\n  const aqlQry: string = `FOR s IN subscriptions\n      FILTER s.userId == ${sessionId} && s.cancelled > 0\n      LET plan = FIRST(\n        FOR p IN plans\n        FILTER p._key == s.planId\n      )\n      LIMIT 1\n      RETURN MERGE(s, {plan: plan})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((subscription = {}) => subscription)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const addPlan = (context: ApiContext, item: PaymentPlan): Promise<PaymentPlan> => {\n  const action: string = 'addPlan';\n  const {database, userId: sessionId, userType} = context;\n  const isAdmin: boolean = userType > 2;\n\n  if(!isAdmin) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const now: number = Date.now();\n  const formatId: string = parseId(item.id);\n  const planId: string = formatId === '' ? createHash(`tag-${sessionId}`) : formatId;\n  const {amount, currency = 'USD', description, interval, intervalCount, name} = item;\n  const formatAmount: number = parseNum(amount);\n  const formatInterval: PaymentInterval = parseChar(interval, 5).toLowerCase() as PaymentInterval;\n  const formatIntervalCnt: number = parseNum(intervalCount, 5);\n  const formatName: string = parseVarChar(name, 32);\n  const formatDesc: string = parseVarChar(description, 32);\n\n  const insert: PaymentPlan = {\n    _key: planId,\n    added: now,\n    amount: formatAmount,\n    currency,\n    description: formatDesc,\n    interval: formatInterval,\n    intervalCount: formatIntervalCnt,\n    modified: now,\n    name: formatName\n  };\n  const aqlQry: AqlQuery = aql`INSERT ${insert} IN plans RETURN NEW`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((plan: PaymentPlan = {}) => {\n      // Stripe\n      const stripeClient = stripe(Config.get('stripe.token'));\n      return stripeClient.plans\n        .create({\n          amount: formatAmount * 100,\n          currency,\n          id: planId,\n          interval: formatInterval,\n          interval_count: formatIntervalCnt,\n          metadata: {\n          },\n          name: formatName,\n          statement_descriptor: formatDesc\n        })\n        .then(() => plan);\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const addSubscription = (context: ApiContext, item): Promise<PaymentSubscription> => {\n  const action: string = 'addSubscription';\n  const {database, userId: sessionId, userType} = context;\n  const isAdmin: boolean = userType > 2;\n\n  if(!isAdmin) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const now: number = Date.now();\n  const formatId: string = parseId(item.id);\n  const subscriptionId: string = formatId === '' ? createHash(`tag-${sessionId}`) : formatId;\n  const {planId, tax, trialEnd, trialPeriod} = item;\n  const formatPlanId: string = parseId(planId);\n  const formatTaxPercent: number = parseNum(tax) || 0;\n  const formatTrialPeriod: number = parseNum(tax) || 0;\n  let formatTrialEnd: number = trialEnd || Date.now();\n\n  if(formatTrialPeriod) {\n    formatTrialEnd = DateTime.local().plus({days: trialPeriod}).toMillis();\n  }\n\n  return getUser(context, sessionId)\n    .then((user) => {\n      const insert: PaymentSubscription = {\n        _key: subscriptionId,\n        added: now,\n        cancelDate: 0,\n        modified: now,\n        planId: formatPlanId,\n        tax: formatTaxPercent,\n        trialEnd: formatTrialEnd,\n        userId: sessionId\n      };\n      const aqlQry: AqlQuery = aql`INSERT ${insert} IN plans RETURN NEW`;\n\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then((subscription: PaymentSubscription = {}) => {\n          // Stripe\n          const stripeClient = stripe(Config.get('stripe.token'));\n          return stripeClient.subscriptions\n            .create({\n              customer: user.stripeCustomerId,\n              items: [\n                {plan: formatPlanId}\n              ],\n              metadata: {\n                userId: sessionId\n              },\n              tax_percent: formatTaxPercent * 100,\n              trial_end: formatTrialEnd\n            })\n            .then(() => subscription);\n        })\n        .catch((error: Error) => logError({\n          action,\n          category: eventCategory,\n          label: 'db_error'\n        }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n    });\n};\n\nexport const deleteSubscription = (context: ApiContext, endDate: number): Promise<boolean> => {\n  const action: string = 'deleteSubscription';\n  const {database} = context;\n  const now: number = Date.now();\n  const formatEndDate: number = parseNum(endDate) || now;\n\n  return getSubscription(context)\n    .then((subscription) => {\n      // Stripe\n      const stripeClient = stripe(Config.get('stripe.token'));\n      return stripeClient.subscriptions\n        .del(subscription.transactionId, {\n          subscription: formatEndDate\n        })\n        .then((stripeResponse) => {\n          // Make sure we cancelled on Stripe before updating the db\n          if(stripeResponse.cancelled || stripeResponse.cancel_at_period_end) {\n            const update: PaymentSubscription = {\n              cancelDate: formatEndDate,\n              modified: now,\n              planId: ''\n            };\n            const aqlQry: AqlQuery = aql`UPDATE s WITH ${update} IN subscriptions`;\n\n            return useDb(database).query(aqlQry)\n              .then(() => true)\n              .catch((error: Error) => logError({\n                action,\n                category: eventCategory,\n                label: 'db_error'\n              }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n          }\n          return false;\n        });\n    });\n};\n"]}
@@ -8,7 +8,7 @@ export declare const addTag: (context: ApiContext, tag: TagType) => Promise<TagT
8
8
  export declare const tagPost: (context: ApiContext, tagId: any, postId: any) => Promise<PostType>;
9
9
  export declare const updateTag: (context: ApiContext, item?: TagType) => Promise<TagType>;
10
10
  export declare const deleteTag: (context: ApiContext, tagId: string) => Promise<TagType>;
11
- export declare const extractTags: (db: Database, itemType: string, itemId: any, content: any) => Promise<TagType[]>;
12
11
  export declare const createTag: (db: Database, tagName: string) => Promise<TagType>;
13
12
  export declare const createTagEdge: (db: Database, tag: TagType, itemType: string, itemId: string) => Promise<TagType>;
14
13
  export declare const linkTags: (db: Database, tagNames: string[], itemType: string, itemId: string) => Promise<TagType[]>;
14
+ export declare const extractTags: (db: Database, itemType: string, itemId: any, content: any) => Promise<TagType[]>;
package/lib/data/tags.js CHANGED
@@ -1,5 +1,5 @@
1
1
  function _templateObject5() {
2
- var data = _taggedTemplateLiteral(["UPSERT {_key: ", "}\n INSERT ", "\n UPDATE {}\n IN tags RETURN NEW"]);
2
+ var data = _taggedTemplateLiteral(["REMOVE {_key:", "} IN isTagged"]);
3
3
 
4
4
  _templateObject5 = function _templateObject5() {
5
5
  return data;
@@ -9,7 +9,7 @@ function _templateObject5() {
9
9
  }
10
10
 
11
11
  function _templateObject4() {
12
- var data = _taggedTemplateLiteral(["REMOVE {_key:", "} IN isTagged"]);
12
+ var data = _taggedTemplateLiteral(["UPSERT {_key: ", "}\n INSERT ", "\n UPDATE {}\n IN tags RETURN NEW"]);
13
13
 
14
14
  _templateObject4 = function _templateObject4() {
15
15
  return data;
@@ -231,38 +231,6 @@ export var deleteTag = function deleteTag(context, tagId) {
231
231
  });
232
232
  });
233
233
  };
234
- export var extractTags = function extractTags(db, itemType, itemId, content) {
235
- var tags = words(content, /#[a-zA-Z\d-]+/g).map(function (tag) {
236
- return parseId(tag);
237
- });
238
- var edgeCollection = db.edgeCollection('isTagged');
239
- return edgeCollection.inEdges(itemId).then(function (edges) {
240
- if (edges.length) {
241
- // Remove linked edges
242
- return Promise.all(edges.map(function (edge) {
243
- var edgeKey = edge._key;
244
- var aqlQry = aql(_templateObject4(), edgeKey);
245
- return db.query(aqlQry).catch(function (error) {
246
- throw error;
247
- });
248
- })).then(function () {
249
- if (tags.length) {
250
- // Create tags
251
- return linkTags(db, tags, itemType, itemId);
252
- }
253
-
254
- return [];
255
- });
256
- } else if (tags.length) {
257
- // Create tags
258
- return linkTags(db, tags, itemType, itemId);
259
- }
260
-
261
- return [];
262
- }).catch(function (error) {
263
- throw error;
264
- });
265
- };
266
234
  export var createTag = function createTag(db, tagName) {
267
235
  var tagId = createHash("tag-".concat(tagName));
268
236
  var insert = {
@@ -270,7 +238,7 @@ export var createTag = function createTag(db, tagName) {
270
238
  added: Date.now(),
271
239
  name: tagName
272
240
  };
273
- var aqlQry = aql(_templateObject5(), tagId, insert);
241
+ var aqlQry = aql(_templateObject4(), tagId, insert);
274
242
  return db.query(aqlQry).then(function (cursor) {
275
243
  return cursor.next();
276
244
  }).then(function () {
@@ -301,4 +269,36 @@ export var linkTags = function linkTags(db, tagNames, itemType, itemId) {
301
269
  });
302
270
  }));
303
271
  };
304
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/tags.ts"],"names":["createHash","parseId","parseVarChar","aql","words","getLimit","logError","useDb","eventCategory","getTagList","context","from","to","action","database","sessionId","userId","limit","aqlQry","query","then","cursor","all","list","catch","error","category","label","Promise","reject","getTag","tagId","formatId","JSON","stringify","next","tag","addTag","now","Date","description","name","insert","_key","added","modified","tagPost","postId","edgeId","edgeCollection","edge","save","post","updateTag","item","id","formatName","update","toLowerCase","deleteTag","formatTagId","extractTags","db","itemType","itemId","content","tags","map","inEdges","edges","length","edgeKey","linkTags","createTag","tagName","createTagEdge","_id","tagKey","type","tagNames"],"mappings":"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","sourcesContent":["/**\n * Copyright (c) 2019-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {createHash, parseId, parseVarChar} from '@nlabs/utils';\nimport {aql, Database, EdgeCollection} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\nimport words from 'lodash/words';\n\nimport {ArangoDBLimit} from '../types/arangodb';\nimport {ApiContext} from '../types/auth';\nimport {PostType} from '../types/posts';\nimport {TagType} from '../types/tags';\nimport {getLimit, logError, useDb} from '../utils';\n\nconst eventCategory: string = 'tags';\n\nexport const getTagList = (context: ApiContext, from: number = 0, to: number = 30): Promise<TagType[]> => {\n  const action: string = 'getList';\n  const {database, userId: sessionId} = context;\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const aqlQry: string = `FOR t IN tagList\n      FILTER t.userId == \"${sessionId}\"\n      ${limit.aql}\n      SORT t.added\n      RETURN t`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((list = []) => list)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const getTag = (context: ApiContext, tagId: string): Promise<TagType> => {\n  const action: string = 'getItem';\n  const {database} = context;\n  const formatId: string = JSON.stringify(parseId(tagId));\n  const aqlQry: string = `FOR t IN tags\n      FILTER t._key == ${formatId}\n      LIMIT 1\n      RETURN t`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((tag = {}) => tag)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const addTag = (context: ApiContext, tag: TagType): Promise<TagType> => {\n  const action: string = 'add';\n  const {database, userId: sessionId} = context;\n  const now: number = Date.now();\n  const formatId: string = createHash(`tag-${sessionId}`);\n  const {description, name} = tag;\n\n  const insert: any = {\n    _key: formatId,\n    added: now,\n    description: parseVarChar(description, 64),\n    modified: now,\n    name: parseVarChar(name, 32)\n  };\n\n  const aqlQry: AqlQuery = aql`INSERT ${insert} IN tags RETURN NEW`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((tag: TagType = {}) => tag)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const tagPost = (context: ApiContext, tagId, postId): Promise<PostType> => {\n  const action: string = 'tagPost';\n  const {database, userId: sessionId} = context;\n  const added: number = Date.now();\n  const edgeId: string = createHash(`tagPost-${sessionId}`);\n  const edgeCollection: EdgeCollection = useDb(database).edgeCollection('isTagged');\n  const edge: any = {_key: edgeId, added};\n\n  return edgeCollection.save(edge, `tags/${tagId}`, `posts/${postId}`)\n    .then((post: PostType = {}) => post)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const updateTag = (context: ApiContext, item: TagType = {}): Promise<TagType> => {\n  const action: string = 'update';\n  const {database} = context;\n  const now: number = Date.now();\n  const {description, id, name} = item;\n  const formatName: string = parseVarChar(name, 32);\n\n  const update: TagType = {\n    description: parseVarChar(description, 64),\n    modified: now,\n    name: formatName\n  };\n\n  const formatId: string = parseId(id);\n  const tagId: string = !formatId ? createHash(`tag-${formatName.toLowerCase()}`, null) : formatId;\n\n  const insert: TagType = {\n    ...update,\n    _key: tagId,\n    added: now\n  };\n  const aqlQry: AqlQuery = aql`UPSERT {_key: ${tagId}}\n      INSERT ${insert}\n      UPDATE ${update}\n      IN tags RETURN NEW`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((tag = {}) => tag)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const deleteTag = (context: ApiContext, tagId: string): Promise<TagType> => {\n  const action: string = 'delete';\n  const {database} = context;\n  const formatTagId: string = parseId(tagId);\n  const aqlQry: AqlQuery = aql`FOR t IN tags\n    FILTER t._key == ${formatTagId}\n    REMOVE t IN tags\n    RETURN OLD`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((tag: TagType = {}) => tag)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const extractTags = (db: Database, itemType: string, itemId, content): Promise<TagType[]> => {\n  const tags: string[] = words(content, /#[a-zA-Z\\d-]+/g).map((tag: string) => parseId(tag));\n  const edgeCollection = db.edgeCollection('isTagged');\n\n  return edgeCollection.inEdges(itemId)\n    .then((edges) => {\n      if(edges.length) {\n        // Remove linked edges\n        return Promise.all(\n          edges.map((edge) => {\n            const {_key: edgeKey} = edge;\n            const aqlQry = aql`REMOVE {_key:${edgeKey}} IN isTagged`;\n            return db.query(aqlQry).catch((error: Error) => {\n              throw error;\n            });\n          }))\n          .then(() => {\n            if(tags.length) {\n              // Create tags\n              return linkTags(db, tags, itemType, itemId);\n            }\n            return [];\n          });\n      } else if(tags.length) {\n        // Create tags\n        return linkTags(db, tags, itemType, itemId);\n      }\n      return [];\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const createTag = (db: Database, tagName: string): Promise<TagType> => {\n  const tagId: string = createHash(`tag-${tagName}`);\n  const insert: TagType = {\n    _key: tagId,\n    added: Date.now(),\n    name: tagName\n  };\n\n  const aqlQry = aql`UPSERT {_key: ${tagId}}\n    INSERT ${insert}\n    UPDATE {}\n    IN tags RETURN NEW`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((tag = {}) => tag)\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const createTagEdge = (db: Database, tag: TagType, itemType: string, itemId: string): Promise<TagType> => {\n  const edgeCollection = db.edgeCollection('isTagged');\n  const {_id: tagId, _key: tagKey} = tag;\n  const edgeId = createHash(`tag-${itemType}-${tagKey}-${itemId}`);\n  const edge: any = {\n    _key: edgeId,\n    added: Date.now(),\n    type: itemType\n  };\n\n  return edgeCollection.save(edge, tagId, `${itemType}/${itemId}`).then(() => tag);\n};\n\nexport const linkTags = (db: Database, tagNames: string[], itemType: string, itemId: string): Promise<TagType[]> => {\n  return Promise.all(\n    tagNames.map((tagId: string) => createTag(db, tagId)\n      .then((tag: TagType) => createTagEdge(db, tag, itemType, itemId)))\n  );\n};\n"]}
272
+ export var extractTags = function extractTags(db, itemType, itemId, content) {
273
+ var tags = words(content, /#[a-zA-Z\d-]+/g).map(function (tag) {
274
+ return parseId(tag);
275
+ });
276
+ var edgeCollection = db.edgeCollection('isTagged');
277
+ return edgeCollection.inEdges(itemId).then(function (edges) {
278
+ if (edges.length) {
279
+ // Remove linked edges
280
+ return Promise.all(edges.map(function (edge) {
281
+ var edgeKey = edge._key;
282
+ var aqlQry = aql(_templateObject5(), edgeKey);
283
+ return db.query(aqlQry).catch(function (error) {
284
+ throw error;
285
+ });
286
+ })).then(function () {
287
+ if (tags.length) {
288
+ // Create tags
289
+ return linkTags(db, tags, itemType, itemId);
290
+ }
291
+
292
+ return [];
293
+ });
294
+ } else if (tags.length) {
295
+ // Create tags
296
+ return linkTags(db, tags, itemType, itemId);
297
+ }
298
+
299
+ return [];
300
+ }).catch(function (error) {
301
+ throw error;
302
+ });
303
+ };
304
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/tags.ts"],"names":["createHash","parseId","parseVarChar","aql","words","getLimit","logError","useDb","eventCategory","getTagList","context","from","to","action","database","sessionId","userId","limit","aqlQry","query","then","cursor","all","list","catch","error","category","label","Promise","reject","getTag","tagId","formatId","JSON","stringify","next","tag","addTag","now","Date","description","name","insert","_key","added","modified","tagPost","postId","edgeId","edgeCollection","edge","save","post","updateTag","item","id","formatName","update","toLowerCase","deleteTag","formatTagId","createTag","db","tagName","createTagEdge","itemType","itemId","_id","tagKey","type","linkTags","tagNames","map","extractTags","content","tags","inEdges","edges","length","edgeKey"],"mappings":"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","sourcesContent":["/**\n * Copyright (c) 2019-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {createHash, parseId, parseVarChar} from '@nlabs/utils';\nimport {aql, Database, EdgeCollection} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\nimport words from 'lodash/words';\n\nimport {ArangoDBLimit} from '../types/arangodb';\nimport {ApiContext} from '../types/auth';\nimport {PostType} from '../types/posts';\nimport {TagType} from '../types/tags';\nimport {getLimit, logError, useDb} from '../utils';\n\nconst eventCategory: string = 'tags';\n\nexport const getTagList = (context: ApiContext, from: number = 0, to: number = 30): Promise<TagType[]> => {\n  const action: string = 'getList';\n  const {database, userId: sessionId} = context;\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const aqlQry: string = `FOR t IN tagList\n      FILTER t.userId == \"${sessionId}\"\n      ${limit.aql}\n      SORT t.added\n      RETURN t`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((list = []) => list)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const getTag = (context: ApiContext, tagId: string): Promise<TagType> => {\n  const action: string = 'getItem';\n  const {database} = context;\n  const formatId: string = JSON.stringify(parseId(tagId));\n  const aqlQry: string = `FOR t IN tags\n      FILTER t._key == ${formatId}\n      LIMIT 1\n      RETURN t`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((tag = {}) => tag)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const addTag = (context: ApiContext, tag: TagType): Promise<TagType> => {\n  const action: string = 'add';\n  const {database, userId: sessionId} = context;\n  const now: number = Date.now();\n  const formatId: string = createHash(`tag-${sessionId}`);\n  const {description, name} = tag;\n\n  const insert: any = {\n    _key: formatId,\n    added: now,\n    description: parseVarChar(description, 64),\n    modified: now,\n    name: parseVarChar(name, 32)\n  };\n\n  const aqlQry: AqlQuery = aql`INSERT ${insert} IN tags RETURN NEW`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((tag: TagType = {}) => tag)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const tagPost = (context: ApiContext, tagId, postId): Promise<PostType> => {\n  const action: string = 'tagPost';\n  const {database, userId: sessionId} = context;\n  const added: number = Date.now();\n  const edgeId: string = createHash(`tagPost-${sessionId}`);\n  const edgeCollection: EdgeCollection = useDb(database).edgeCollection('isTagged');\n  const edge: any = {_key: edgeId, added};\n\n  return edgeCollection.save(edge, `tags/${tagId}`, `posts/${postId}`)\n    .then((post: PostType = {}) => post)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const updateTag = (context: ApiContext, item: TagType = {}): Promise<TagType> => {\n  const action: string = 'update';\n  const {database} = context;\n  const now: number = Date.now();\n  const {description, id, name} = item;\n  const formatName: string = parseVarChar(name, 32);\n\n  const update: TagType = {\n    description: parseVarChar(description, 64),\n    modified: now,\n    name: formatName\n  };\n\n  const formatId: string = parseId(id);\n  const tagId: string = !formatId ? createHash(`tag-${formatName.toLowerCase()}`, null) : formatId;\n\n  const insert: TagType = {\n    ...update,\n    _key: tagId,\n    added: now\n  };\n  const aqlQry: AqlQuery = aql`UPSERT {_key: ${tagId}}\n      INSERT ${insert}\n      UPDATE ${update}\n      IN tags RETURN NEW`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((tag = {}) => tag)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const deleteTag = (context: ApiContext, tagId: string): Promise<TagType> => {\n  const action: string = 'delete';\n  const {database} = context;\n  const formatTagId: string = parseId(tagId);\n  const aqlQry: AqlQuery = aql`FOR t IN tags\n    FILTER t._key == ${formatTagId}\n    REMOVE t IN tags\n    RETURN OLD`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((tag: TagType = {}) => tag)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, {}).then(() => null).catch((error) => Promise.reject(error)));\n};\n\nexport const createTag = (db: Database, tagName: string): Promise<TagType> => {\n  const tagId: string = createHash(`tag-${tagName}`);\n  const insert: TagType = {\n    _key: tagId,\n    added: Date.now(),\n    name: tagName\n  };\n\n  const aqlQry = aql`UPSERT {_key: ${tagId}}\n    INSERT ${insert}\n    UPDATE {}\n    IN tags RETURN NEW`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((tag = {}) => tag)\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const createTagEdge = (db: Database, tag: TagType, itemType: string, itemId: string): Promise<TagType> => {\n  const edgeCollection = db.edgeCollection('isTagged');\n  const {_id: tagId, _key: tagKey} = tag;\n  const edgeId = createHash(`tag-${itemType}-${tagKey}-${itemId}`);\n  const edge: any = {\n    _key: edgeId,\n    added: Date.now(),\n    type: itemType\n  };\n\n  return edgeCollection.save(edge, tagId, `${itemType}/${itemId}`).then(() => tag);\n};\n\nexport const linkTags = (db: Database, tagNames: string[], itemType: string, itemId: string): Promise<TagType[]> =>\n  Promise.all(\n    tagNames.map((tagId: string) => createTag(db, tagId)\n      .then((tag: TagType) => createTagEdge(db, tag, itemType, itemId)))\n  );\n\n\nexport const extractTags = (db: Database, itemType: string, itemId, content): Promise<TagType[]> => {\n  const tags: string[] = words(content, /#[a-zA-Z\\d-]+/g).map((tag: string) => parseId(tag));\n  const edgeCollection = db.edgeCollection('isTagged');\n\n  return edgeCollection.inEdges(itemId)\n    .then((edges) => {\n      if(edges.length) {\n        // Remove linked edges\n        return Promise.all(\n          edges.map((edge) => {\n            const {_key: edgeKey} = edge;\n            const aqlQry = aql`REMOVE {_key:${edgeKey}} IN isTagged`;\n            return db.query(aqlQry).catch((error: Error) => {\n              throw error;\n            });\n          }))\n          .then(() => {\n            if(tags.length) {\n              // Create tags\n              return linkTags(db, tags, itemType, itemId);\n            }\n            return [];\n          });\n      } else if(tags.length) {\n        // Create tags\n        return linkTags(db, tags, itemType, itemId);\n      }\n      return [];\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n"]}
@@ -3,10 +3,12 @@ import { UserRelationType, UserType } from '../types/users';
3
3
  export declare const addUser: (context: ApiContext, user: UserType) => Promise<UserType>;
4
4
  export declare const deleteUser: (context: ApiContext, userId: string) => Promise<UserType>;
5
5
  export declare const deactivateUser: (context: ApiContext, userId: string) => Promise<UserType>;
6
+ export declare const getSessionUser: (context: ApiContext) => Promise<UserType>;
6
7
  export declare const getUser: (context: ApiContext, userId: any) => Promise<UserType>;
7
8
  export declare const getUserList: (context: ApiContext, from?: number, to?: number) => Promise<UserType>;
8
9
  export declare const addUserRelation: (context: ApiContext, userId: any, value: any) => Promise<UserRelationType>;
9
10
  export declare const deleteUserRelation: (context: ApiContext, userId: string, value: string) => Promise<UserRelationType>;
10
11
  export declare const getUsersByRelations: (context: ApiContext, userId: string, type: string, from: number, to: number) => Promise<UserType[]>;
11
12
  export declare const getRelationsByUser: (context: ApiContext, userId: string) => Promise<UserRelationType[]>;
13
+ export declare const getRelationship: (context: ApiContext, userId: string) => Promise<UserRelationType>;
12
14
  export declare const getDisplayName: (user?: UserType) => string;