forked from cerc-io/snowballtools-base
Nabarun Gogoi
ef0eac8293
* Create web3 modal provider with SIWE * Add auth router to handle SIWE authentication * Use axios instance to make request * Add button for SIWE authentication * Add changes to access session in web-app GQL requests * Add auth check in GQL context and load/create user * Use authenticated user from context * Redirect to sign in page if unauthenticated and logout button * Change sign-in route to login * Get project domain from config file * Set user ethAddress column as unique * Use formatted user name * Get session secret and origin url from config file * Add unique constraint for eth address * Get secure and samesite from origin url * Get wallet connect id and backend url from env file * Format user email in member tab panel * Add backend config isProduction to set trust proxy * Use only one server url config * Add tool tip for displaying email * Add trustProxy and domain in server.session config * Add SERVER_GQL_PATH constant in frontend --------- Co-authored-by: neeraj <neeraj.rtly@gmail.com>
78 lines
2.2 KiB
TypeScript
78 lines
2.2 KiB
TypeScript
import debug from 'debug';
|
|
import { DataSource } from 'typeorm';
|
|
import path from 'path';
|
|
|
|
import { Registry } from '@cerc-io/laconic-sdk';
|
|
|
|
import { Config } from '../src/config';
|
|
import { DEFAULT_CONFIG_FILE_PATH } from '../src/constants';
|
|
import { getConfig } from '../src/utils';
|
|
import { Deployment, DeploymentStatus } from '../src/entity/Deployment';
|
|
|
|
const log = debug('snowball:publish-deploy-records');
|
|
|
|
async function main () {
|
|
const { registryConfig, database, misc } = await getConfig<Config>(DEFAULT_CONFIG_FILE_PATH);
|
|
|
|
const registry = new Registry(registryConfig.gqlEndpoint, registryConfig.restEndpoint, registryConfig.chainId);
|
|
|
|
const dataSource = new DataSource({
|
|
type: 'better-sqlite3',
|
|
database: database.dbPath,
|
|
synchronize: true,
|
|
entities: [path.join(__dirname, '../src/entity/*')]
|
|
});
|
|
|
|
await dataSource.initialize();
|
|
|
|
const deploymentRepository = dataSource.getRepository(Deployment);
|
|
const deployments = await deploymentRepository.find({
|
|
relations: {
|
|
project: true
|
|
},
|
|
where: {
|
|
status: DeploymentStatus.Building
|
|
}
|
|
});
|
|
|
|
for await (const deployment of deployments) {
|
|
const url = `${deployment.project.name}-${deployment.id}.${misc.projectDomain}`;
|
|
|
|
const applicationDeploymentRecord = {
|
|
type: 'ApplicationDeploymentRecord',
|
|
version: '0.0.1',
|
|
name: deployment.applicationRecordData.name,
|
|
application: deployment.applicationRecordId,
|
|
|
|
// TODO: Create DNS record
|
|
dns: 'bafyreihlymqggsgqiqawvehkpr2imt4l3u6q7um7xzjrux5rhsvwnuyewm',
|
|
|
|
// Using dummy values
|
|
meta: JSON.stringify({
|
|
config: 'da39a3ee5e6b4b0d3255bfef95601890afd80709',
|
|
so: '66fcfa49a1664d4cb4ce4f72c1c0e151'
|
|
}),
|
|
|
|
request: deployment.applicationDeploymentRequestId,
|
|
url
|
|
};
|
|
|
|
const result = await registry.setRecord(
|
|
{
|
|
privateKey: registryConfig.privateKey,
|
|
record: applicationDeploymentRecord,
|
|
bondId: registryConfig.bondId
|
|
},
|
|
'',
|
|
registryConfig.fee
|
|
);
|
|
|
|
log('Application deployment record data:', applicationDeploymentRecord);
|
|
log(`Application deployment record published: ${result.data.id}`);
|
|
}
|
|
}
|
|
|
|
main().catch((err) => {
|
|
log(err);
|
|
});
|