"""
this script is for blended attack

@article{Blended,
	title        = {Targeted Backdoor Attacks on Deep Learning Systems Using Data Poisoning},
	author       = {Xinyun Chen and Chang Liu and Bo Li and Kimberly Lu and Dawn Song},
	journal      = {arXiv preprint arXiv:1712.05526},
	year         = {2017}
}
"""
import argparse
import os
import sys

os.chdir(sys.path[0])
sys.path.append("../")
os.getcwd()

from attack.badnet import BadNet, add_common_attack_args


class Trojan(BadNet):
    def set_bd_args(cls, parser: argparse.ArgumentParser) -> argparse.ArgumentParser:
        parser = add_common_attack_args(parser)
        parser.add_argument(
            "--attack_trigger_img_path",
            type=int,
        )
        parser.add_argument(
            "--attack_train_blended_alpha",
            type=float,
        )
        parser.add_argument(
            "--attack_test_blended_alpha",
            type=float,
        )
        parser.add_argument(
            "--bd_yaml_path",
            type=str,
            default="../config/attack/trojanwm/default.yaml",
            help="path for yaml file provide additional default attributes",
        )
        return parser


if __name__ == "__main__":
    attack = Trojan()
    parser = argparse.ArgumentParser(description=sys.argv[0])
    parser = attack.set_args(parser)
    parser = attack.set_bd_args(parser)
    args = parser.parse_args()
    attack.add_bd_yaml_to_args(args)
    attack.add_yaml_to_args(args)
    args = attack.process_args(args)
    attack.prepare(args)
    attack.stage1_non_training_data_prepare()
    attack.stage2_training()
