This repository has been archived by the owner on Jan 15, 2019. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 110
/
rules.h
82 lines (68 loc) · 1.94 KB
/
rules.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
/*
* This file is part of John the Ripper password cracker,
* Copyright (c) 1996-98 by Solar Designer
*/
/*
* Rules support routines.
*/
#ifndef _JOHN_RULES_H
#define _JOHN_RULES_H
#include "rpp.h"
#define RULES_NAME _PATH_RULES
/*
* Error codes.
*/
#define RULES_ERROR_NONE 0
#define RULES_ERROR_END 1
#define RULES_ERROR_UNKNOWN 2
#define RULES_ERROR_POSITION 3
#define RULES_ERROR_CLASS 4
#define RULES_ERROR_REJECT 5
/*
* Error names.
*/
extern char *rules_errors[];
/*
* Last error code.
*/
extern int rules_errno;
/*
* Configuration file line number, only set after a rules_check() call if
* rules_errno indicates an error.
*/
extern int rules_line;
/*
* Initializes the rules support.
*/
extern void rules_init(int max_length);
/*
* Processes rule reject flags, based on information from the database.
* Returns a pointer to the first command in the rule if it's accepted,
* or NULL if rejected or an error occured. Also sets rules_errno on
* error. If the database is NULL, all rules are accepted (to be used
* for syntax checking).
*/
extern char *rules_reject(char *rule, void *db);
/*
* Applies rule to a word. Returns the updated word, or NULL if rejected or
* an error occured. Also sets rules_errno on error.
*
* split > 0 "single crack" mode, split is the second word's position
* split == 0 "single crack" mode, only one word
* split < 0 other cracking modes, "single crack" mode rules are invalid
*/
extern char *rules_apply(char *word, char *rule, int split);
/*
* Checks if all the rules for context are valid. Returns the number of rules,
* or returns zero and sets rules_errno on error.
*
* split == 0 "single crack" mode rules allowed
* split < 0 "single crack" mode rules are invalid
*/
extern int rules_check(struct rpp_context *start, int split);
/*
* Similar to rules_check(), but displays a message and does not return on
* error.
*/
extern int rules_count(struct rpp_context *start, int split);
#endif