| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301 | "use strict";Object.defineProperty(exports, "__esModule", {  value: true});exports.default = void 0;function ownKeys(object, enumerableOnly) {  var keys = Object.keys(object);  if (Object.getOwnPropertySymbols) {    var symbols = Object.getOwnPropertySymbols(object);    enumerableOnly && (symbols = symbols.filter(function (sym) {      return Object.getOwnPropertyDescriptor(object, sym).enumerable;    })), keys.push.apply(keys, symbols);  }  return keys;}function _objectSpread(target) {  for (var i = 1; i < arguments.length; i++) {    var source = null != arguments[i] ? arguments[i] : {};    i % 2 ? ownKeys(Object(source), !0).forEach(function (key) {      _defineProperty(target, key, source[key]);    }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) {      Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));    });  }  return target;}function _defineProperty(obj, key, value) {  if (key in obj) {    Object.defineProperty(obj, key, {      value: value,      enumerable: true,      configurable: true,      writable: true    });  } else {    obj[key] = value;  }  return obj;}/** * Automatically generated code, via genSolanaAPI.js * Do not modify manually */const axios = require('axios');class SolanaApi {  // URL will be changed when api is deployed  static initialize({    apiKey,    serverUrl,    Moralis = null  }) {    if (!serverUrl && !apiKey) {      throw new Error('SolanaApi.initialize failed: initialize with apiKey or serverUrl');    }    if (apiKey) this.apiKey = apiKey;    if (serverUrl) this.serverUrl = serverUrl;    this.Moralis = Moralis;  }  static getBody(params, bodyParams) {    if (!params || !bodyParams || !bodyParams.length) {      return undefined;    }    let body = {};    bodyParams.forEach(({      key,      type,      required    }) => {      if (params[key] === undefined) {        if (required) throw new Error(`param ${key} is required!`);      } else if (type === this.BodyParamTypes.setBody) {        body = params[key];      } else {        body[key] = params[key];      } // remove the param so it doesn't also get added as a query param      delete params[key];    });    return body;  }  static getParameterizedUrl(url, params) {    if (!Object.keys(params).length) return url; // find url params, they start with :    const requiredParams = url.split('/').filter(s => s && s.includes(':'));    if (!requiredParams.length) return url;    let parameterizedUrl = url;    requiredParams.forEach(p => {      // strip the : and replace with param value      const key = p.substr(1);      const value = params[key];      if (!value) {        throw new Error(`required param ${key} not provided`);      }      parameterizedUrl = parameterizedUrl.replace(p, value); // remove required param from param list      // so it doesn't become part of the query params      delete params[key];    });    return parameterizedUrl;  }  static getApiRateLimitInfo(headers) {    return {      'x-rate-limit-limit': headers['x-rate-limit-limit'],      'x-rate-limit-remaining-ttl': headers['x-rate-limit-remaining-ttl'],      'x-rate-limit-used': headers['x-rate-limit-used'],      'x-rate-limit-remaining-ip-ttl': headers['x-rate-limit-remaining-ip-ttl'],      'x-rate-limit-ip-used': headers['x-rate-limit-ip-used']    };  }  static getErrorMessage(error, url) {    var _error$response, _error$response$data;    return (error === null || error === void 0 ? void 0 : (_error$response = error.response) === null || _error$response === void 0 ? void 0 : (_error$response$data = _error$response.data) === null || _error$response$data === void 0 ? void 0 : _error$response$data.message) || (error === null || error === void 0 ? void 0 : error.message) || (error === null || error === void 0 ? void 0 : error.toString()) || `Solana API error while calling ${url}`;  }  static async fetch({    endpoint,    params: providedParams  }) {    // Make a shallow copy to prevent modification of original params    const params = _objectSpread({}, providedParams);    if (this.Moralis) {      const {        User      } = this.Moralis;      const user = User.current();      if (!params.address) {        if (user) {          params.address = user.get('solAddress');        }      }    }    if (!params.network) params.network = 'mainnet';    if (!params.responseType) params.responseType = 'native';    if (!this.apiKey) {      return this.fetchFromServer(endpoint.name, params);    }    return this.fetchFromApi(endpoint, params);  }  static async fetchFromApi(endpoint, params) {    const {      method = 'GET',      url,      bodyParams    } = endpoint;    try {      const parameterizedUrl = this.getParameterizedUrl(url, params);      const body = this.getBody(params, bodyParams);      const response = await axios(this.baseURL + parameterizedUrl, {        params,        method,        body,        headers: {          Accept: 'application/json',          'Content-Type': 'application/json',          'x-api-key': this.apiKey        }      }); // Perform type regularization before return depending on response type option      return response.data;    } catch (error) {      const {        status,        headers,        data      } = error.response;      let msg;      if (status === 429) {        msg = `This Moralis Server is rate-limited because of the plan restrictions. See the details about the current rate and throttle limits: ${JSON.stringify(this.getApiRateLimitInfo(headers))}`;      } else {        msg = this.getApiErrorMessage(error, url);      }      throw new Error(msg);    }  }  static async fetchFromServer(name, options) {    if (!this.serverUrl) {      throw new Error('SolanaAPI not initialized, run Moralis.start() first');    }    try {      const http = axios.create({        baseURL: this.serverUrl      });      const user = this.Moralis.User.current();      if (user) {        options._SessionToken = user.attributes.sessionToken;        options._ApplicationId = this.Moralis.applicationId;      }      const response = await http.post(`/functions/sol-${name}`, options, {        headers: {          Accept: 'application/json',          'Content-Type': 'application/json'        }      });      return response.data.result;    } catch (error) {      var _error$response2, _error$response2$data;      if ((_error$response2 = error.response) !== null && _error$response2 !== void 0 && (_error$response2$data = _error$response2.data) !== null && _error$response2$data !== void 0 && _error$response2$data.error) {        throw new Error(error.response.data.error);      }      throw error;    }  }}_defineProperty(SolanaApi, "baseURL", 'https://solana-gateway.moralis.io');_defineProperty(SolanaApi, "BodyParamTypes", {  setBody: 'set body',  property: 'property'});_defineProperty(SolanaApi, "account", {  balance: async (options = {}) => SolanaApi.fetch({    endpoint: {      "method": "GET",      "group": "account",      "name": "balance",      "url": "/account/:network/:address/balance"    },    params: options  }),  getSPL: async (options = {}) => SolanaApi.fetch({    endpoint: {      "method": "GET",      "group": "account",      "name": "getSPL",      "url": "/account/:network/:address/tokens"    },    params: options  }),  getNFTs: async (options = {}) => SolanaApi.fetch({    endpoint: {      "method": "GET",      "group": "account",      "name": "getNFTs",      "url": "/account/:network/:address/nft"    },    params: options  }),  getPortfolio: async (options = {}) => SolanaApi.fetch({    endpoint: {      "method": "GET",      "group": "account",      "name": "getPortfolio",      "url": "/account/:network/:address/portfolio"    },    params: options  })});_defineProperty(SolanaApi, "nft", {  getNFTMetadata: async (options = {}) => SolanaApi.fetch({    endpoint: {      "method": "GET",      "group": "nft",      "name": "getNFTMetadata",      "url": "/nft/:network/:address/metadata"    },    params: options  })});var _default = SolanaApi;exports.default = _default;
 |