saleor-apps-redis_apl/apps/taxes/scripts/migrations/run-generate-dummy-data.ts
Adrian Pilarczyk f96563fc2b
feat: redesign taxes app with macaw-ui (#433)
* refactor: ♻️ replace material-ui with macaw-ui; remove all views

* add apps-ui

* feat: add configuration screen (#514)

* feat:  add basic layout

* refactor: 🔥 enabled field

* refactor: ♻️ move part of config to credentials

* refactor: ♻️ move address from channel to provider

* feat:  add all states for providers

* refactor: ♻️ merge redesign with refactor

* refactor: ♻️ replace material-ui with macaw-ui; remove all views

* fix: 🐛 text-decoration on breadcrumb link

* feat:  add stripe icon

* feat:  add AppCard

* feat:  add AppBreadcrumbs and new provider pages

* refactor: ♻️ add gridRatio to support two app grids

* refactor: 🔥 theme-synchronizer test

* refactor: ♻️ make breadcrumbs bulletproof

* fix: 🐛 failing build

* feat:  add app-layout

* build: ⬆️ upgrade macaw-ui

* feat: redesign provider forms (#533)

* build:  add @saleor/react-hook-form-macaw

* feat: add binding for Toggle in react-hook-form-macaw

* feat:  add AppToggle component

* feat:  add create-avatax-configuration and edit-avatax-configuration

* feat:  add taxjar-validation-service with address validation

* feat:  add AvataxValidationService

* feat:  add edit/create taxjar config

* feat:  add delete configuration

* refactor: ♻️ change invalid address error message

* refactor: ♻️ throw in validation services instead of authenticated: true/false

* docs: 💡 add todo comments

* refactor: ♻️ better variable naming in parse error

* fix: 🐛 disable button when loading

* refactor: ♻️ make defaultValues required

* refactor: 🔥 remove custom fontWeights

* fix: 🐛 toggle form submission bug

* feat:  extract provider-label and use in forms

* feat:  use new Section component and change copy

* refactor: ♻️ use ProviderLabel in ProvidersTable

* build: 💚 fix lockfile

* fix: 🐛 address feedback

* feat: channel provider table (#538)

* refactor: 🔥 providers-config-input-schema

* refactor: ♻️ move providers

* feat:  add basic channel-list

* refactor: 🚚 move around

* feat:  add ChannelConfigurationService

* feat:  add select provider in channel table

* refactor: 🔥 logger traces

* refactor: 🔊 refine logs

* feat:  add avatax-config-mock-generator and use in webhooks mock generators

* refactor: ♻️ split up avatax-validation.service and add tests for response resolver

* feat:  add avatax-validation-error-resolver tests

* refactor: 🚚 move taxjar-validation.service to separate folder

* feat:  extract taxjar-validation-error-resolver and add tests

* feat:  add channel-config-mock-generator

* feat:  add ChannelFetcherMockGenerator

* test:  add tests for channel-configuration-merge

* test:  add tests for crud-settings.service

* fix: 💬 channel copy

* refactor: 🔊 remove data from logs

* refactor: 🚚 move configuration & validation to configuration folder

* fix: 🐛 imports

* fix: 🐛 showing loading & add at the same time

* refactor: ♻️ public configurations & obfuscation rework

* refactor: 🚚 extract repositories from services

* refactor: 🚚 instance -> connection (#544)

* refactor: ♻️ move creating configuration service to procedure

* fix: 🐛 some paths & names while renaming

* Update apps/taxes/src/pages/api/webhooks/order-calculate-taxes.ts

* Update apps/taxes/src/pages/api/webhooks/checkout-calculate-taxes.ts

* feat: shipping tax code (#555)

* fix: 💄 minor visual issues

* feat:  add shipping tax code

* fix: 🐛 fix toggle

* refactor: ♻️ use common table in providers-table

* docs: 💡 add comment to obfuscator

* feat:  sort countries by label not code

* Taxes 💸: Add runtime migrations to schema v2 (#545)

* build:  add dotenv

* feat: 🚧 add draft of migration scripts

* refactor: ♻️ settingsManager to accept appId

* feat:  tax-providers and channels transforms

* feat:  add migration classes

* feat: 🚧 add migration to connection getAll

* feat: 🚧 add dummy data script

* feat:  add runtime channel migration

* feat:  add migration and report scripts

* fix: 🐛 name of dummy class method

* feat:  add transform tests

* build: 💚 update lockfile

* fix: creating & updating a provider (#563)

* refactor:  improve the test for update

* docs: 💡 comment crud-settings

* refactor: 🔥 unused file

* fix: 🐛 appId bug

* refactor: 🚚 rename dummy-utils

* fix: 💄 padding in table

* refactor: 💬 change avatax texts

* build: 👷 add changeset
2023-06-15 09:01:50 +02:00

122 lines
3.5 KiB
TypeScript

import { saleorApp } from "../../saleor-app";
import { createClient } from "../../src/lib/graphql";
import { Logger, createLogger } from "../../src/lib/logger";
import { createSettingsManager } from "../../src/modules/app/metadata-manager";
import { TaxProvidersV1 } from "./tax-providers-config-schema-v1";
import { TaxProvidersPrivateMetadataManagerV1 } from "./tax-providers-metadata-manager-v1";
import { ChannelsV1 } from "./channels-config-schema-v1";
import * as dotenv from "dotenv";
import { TaxChannelsPrivateMetadataManagerV1 } from "./tax-channels-metadata-manager-v1";
dotenv.config();
export const dummyChannelsV1Config: ChannelsV1 = {
"default-channel": {
providerInstanceId: "24822834-1a49-4b51-8a59-579affdb772f",
address: {
city: "San Francisco",
country: "US",
state: "CA",
street: "Sesame Street",
zip: "10001",
},
enabled: true,
},
"channel-pln": {
providerInstanceId: "d15d9907-a3cb-42d2-9336-366d2366e91b",
address: {
city: "San Francisco",
country: "US",
state: "CA",
street: "Sesame Street",
zip: "10001",
},
enabled: true,
},
};
export const dummyTaxProvidersV1Config: TaxProvidersV1 = [
{
provider: "avatax",
id: "24822834-1a49-4b51-8a59-579affdb772f",
config: {
isAutocommit: true,
isSandbox: true,
name: "Avatalara1",
password: "password",
username: "username",
companyCode: "companyCode",
shippingTaxCode: "shippingTaxCode",
},
},
{
provider: "taxjar",
id: "d15d9907-a3cb-42d2-9336-366d2366e91b",
config: {
isSandbox: true,
apiKey: "apiKey",
name: "TaxJar1",
},
},
];
// This class is used to generate dummy config for the app to check if the runtime migrations work as expected.
class DummyConfigGenerator {
private logger: Logger;
constructor(private domain: string) {
this.logger = createLogger({
name: "DummyConfigGenerator",
});
}
private getFileApl = () => {
return saleorApp.apl.getAll();
};
private generateDummyTaxProvidersConfig = (): TaxProvidersV1 => dummyTaxProvidersV1Config;
private generateDummyTaxChannelsConfig = (): ChannelsV1 => dummyChannelsV1Config;
generate = async () => {
console.log("Generating dummy config");
const apls = await this.getFileApl();
console.log({ apls }, "Apls retrieved");
const target = apls.find((apl) => apl.domain === this.domain);
if (!target) {
throw new Error(`Domain ${this.domain} not found in apls`);
}
const dummyTaxProvidersConfig = this.generateDummyTaxProvidersConfig();
const dummyTaxChannelsConfig = this.generateDummyTaxChannelsConfig();
console.log({ dummyTaxProvidersConfig, dummyTaxChannelsConfig }, "Dummy configs generated");
const client = createClient(target.saleorApiUrl, async () =>
Promise.resolve({ token: target.token })
);
const metadataManager = createSettingsManager(client, target.appId);
const taxProvidersManager = new TaxProvidersPrivateMetadataManagerV1(
metadataManager,
target.saleorApiUrl
);
const taxChannelsManager = new TaxChannelsPrivateMetadataManagerV1(
metadataManager,
target.saleorApiUrl
);
console.log("Setting dummy configs");
await taxProvidersManager.setConfig(dummyTaxProvidersConfig);
await taxChannelsManager.setConfig(dummyTaxChannelsConfig);
console.log("Dummy config set");
};
}
// const dummyConfigGenerator = new DummyConfigGenerator("");
// dummyConfigGenerator.generate();