2018-10-23 20:56:54 -07:00
|
|
|
// @flow
|
|
|
|
|
2018-10-26 13:19:47 -07:00
|
|
|
import {Account} from './account';
|
|
|
|
import {PublicKey} from './publickey';
|
|
|
|
import {Loader} from './loader';
|
|
|
|
import type {Connection} from './connection';
|
2018-10-23 20:56:54 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Factory class for transactions to interact with a program loader
|
|
|
|
*/
|
|
|
|
export class BpfLoader {
|
|
|
|
/**
|
2018-10-25 10:41:18 -07:00
|
|
|
* Public key that identifies the BpfLoader
|
2018-10-23 20:56:54 -07:00
|
|
|
*/
|
|
|
|
static get programId(): PublicKey {
|
2019-05-08 09:33:04 -07:00
|
|
|
return new PublicKey('BPFLoader1111111111111111111111111111111111');
|
2018-10-23 20:56:54 -07:00
|
|
|
}
|
|
|
|
|
2019-10-22 15:16:12 -07:00
|
|
|
/**
|
|
|
|
* Minimum number of signatures required to load a program not including
|
|
|
|
* retries
|
|
|
|
*
|
|
|
|
* Can be used to calculate transaction fees
|
|
|
|
*/
|
|
|
|
static getMinNumSignatures(dataLength: number): number {
|
|
|
|
return Loader.getMinNumSignatures(dataLength);
|
|
|
|
}
|
|
|
|
|
2018-10-23 20:56:54 -07:00
|
|
|
/**
|
2018-10-25 10:41:18 -07:00
|
|
|
* Load a BPF program
|
2018-10-23 20:56:54 -07:00
|
|
|
*
|
|
|
|
* @param connection The connection to use
|
2018-10-25 10:41:18 -07:00
|
|
|
* @param owner User account to load the program into
|
2018-11-06 15:14:59 -08:00
|
|
|
* @param elfBytes The entire ELF containing the BPF program
|
2018-10-23 20:56:54 -07:00
|
|
|
*/
|
2019-05-08 09:33:04 -07:00
|
|
|
static load(
|
2018-10-23 20:56:54 -07:00
|
|
|
connection: Connection,
|
2019-05-08 09:33:04 -07:00
|
|
|
payer: Account,
|
2020-02-11 15:22:12 +08:00
|
|
|
elf: Buffer | Array<number>,
|
2018-10-23 20:56:54 -07:00
|
|
|
): Promise<PublicKey> {
|
2019-05-08 09:33:04 -07:00
|
|
|
const program = new Account();
|
|
|
|
return Loader.load(connection, payer, program, BpfLoader.programId, elf);
|
2018-10-23 20:56:54 -07:00
|
|
|
}
|
|
|
|
}
|