[
  {
    "description": "There's something wrong with it (Hint: it's about that permission). Check it out and correct that.",
    "create": {
      "init": {
        "code": "chmod u+s /usr/bin/find"
      }
    },
    "evaluation": {
      "check": {
        "code": "ls -l /usr/bin/find | awk '{if ($1~/^-..s/) { exit 1; } else { exit 0; }}'"
      },
      "example": {
        "code": "chmod u-s /usr/bin/find"
      }
    },
    "labels": [
      "permission"
    ],
    "original_description": "There's a vulnerability in the system (Hint: related to SUID). Find it and fix it.",
    "perturbation_strategy": {
      "strategy_id": "referential_ambiguity",
      "strategy_name": "Referential Ambiguity",
      "flaw_category": "expression"
    },
    "true_intent": {
      "action_type": "MODIFY",
      "prerequisites": [
        {
          "entity": "/usr/bin/find",
          "exists": true,
          "type": "file"
        },
        {
          "fact": "The file has SUID permission set",
          "must_be_true": true
        }
      ],
      "parameters": {
        "required": [
          {
            "name": "command",
            "type": "command",
            "value": "chmod",
            "role": "command"
          },
          {
            "name": "permission",
            "type": "string",
            "value": "u-s",
            "role": "target"
          },
          {
            "name": "file_path",
            "type": "path",
            "value": "/usr/bin/find",
            "role": "target"
          }
        ],
        "optional": []
      },
      "expected_output": "The SUID permission is removed from the file /usr/bin/find"
    }
  },
  {
    "description": "set all files in ~/videos to be 660 and directories to be 750 including ~/videos",
    "create": {
      "init": {
        "code": "cd ~ && mkdir videos && cd videos && mkdir old && mkdir new && touch vid1 && touch vid2 && touch new/a && touch new/b && touch old/c"
      }
    },
    "evaluation": {
      "check": {
        "code": "(find ~/videos -type f ! -perm 660 -ls && find ~/videos -type d ! -perm 750 -ls) | if [ \"$(cat -)\" = \"\" ]; then exit 0; else exit 1; fi"
      },
      "example": {
        "code": "find ~/videos -type f -exec chmod 660 {} + && find ~/videos -type d -exec chmod 750 {} +"
      }
    },
    "labels": [
      "permission"
    ],
    "original_description": "set all files in ~/videos to be 660, and all directories(include ~/videos) to be 750",
    "perturbation_strategy": {
      "strategy_id": "syntactic_ambiguity",
      "strategy_name": "Syntactic Ambiguity",
      "flaw_category": "expression"
    },
    "true_intent": {
      "action_type": "EXECUTE",
      "prerequisites": [
        {
          "entity": "~/videos",
          "exists": true,
          "type": "path"
        }
      ],
      "parameters": {
        "required": [
          {
            "name": "file_permission",
            "type": "int",
            "value": "660",
            "role": "command"
          },
          {
            "name": "directory_permission",
            "type": "int",
            "value": "750",
            "role": "command"
          },
          {
            "name": "target_files",
            "type": "path",
            "value": "~/videos",
            "role": "target"
          }
        ],
        "optional": []
      },
      "expected_output": "All files in ~/videos have permissions set to 660, and all directories (including ~/videos) have permissions set to 750."
    }
  }
]