File: filesigning.c

package info (click to toggle)
hashrat 1.25%2Bds-1
  • links: PTS, VCS
  • area: main
  • in suites: trixie
  • size: 2,892 kB
  • sloc: ansic: 32,338; sh: 400; makefile: 337
file content (124 lines) | stat: -rw-r--r-- 3,351 bytes parent folder | download | duplicates (2)
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
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
#include "filesigning.h"
#include "files.h"

void HashratSignFile(char *Path, HashratCtx *Ctx)
{
    STREAM *S;
    char *Tempstr=NULL, *HashStr=NULL;
    double pos;
    HASH *Hash;

    S=STREAMOpen(Path, "rw");
    if (! S) return;


    Hash=HashInit(Ctx->HashType);
    HashratFinishHash(&HashStr, Ctx, Hash);
    pos=STREAMSeek(S,0,SEEK_END);

    Tempstr=MCopyStr(Tempstr,"hashrat-placeholder---: ",GetDateStr("%Y/%m/%d %H:%M:%S",NULL)," ",Ctx->HashType,":", HashStr,"\n",NULL);
    STREAMWriteLine(Tempstr,S);
    STREAMFlush(S);

    STREAMSeek(S,0,SEEK_SET);
    Hash=HashInit(Ctx->HashType);
//HashratHashFile(Ctx, Hash, FT_FILE, Path, (off_t) pos);
    HashratFinishHash(&HashStr, Ctx, Hash);


    Tempstr=MCopyStr(Tempstr,"hashrat-integrity-mark: ",GetDateStr("%Y/%m/%d %H:%M:%S",NULL)," ",Ctx->HashType,":", HashStr,"\n",NULL);
    STREAMSeek(S,pos,SEEK_SET);
    STREAMWriteLine(Tempstr,S);
    STREAMFlush(S);


    Destroy(Tempstr);
    Destroy(HashStr);
}



int HashratOutputSigningCheck(HashratCtx *Ctx, const char *ExpectedHash, const char *SigningLine, int LineCount)
{
    char *Token=NULL;
    const char *ptr;
    char *DateStr=NULL, *SignHash=NULL, *HashType=NULL;
    int result=FALSE;

    ptr=GetToken(SigningLine+24," ",&Token,0);
    DateStr=MCopyStr(DateStr,Token, " ", NULL);
    ptr=GetToken(ptr," ",&Token,0);
    DateStr=CatStr(DateStr,Token);


    ptr=GetToken(ptr,":",&HashType,0);
    SignHash=CopyStr(SignHash,ptr);
    StripTrailingWhitespace(SignHash);
    if (strcmp(HashType, Ctx->HashType) !=0)
    {
        if (Flags & FLAG_COLOR) printf("%sIntegrity Mark has wrong HashType: '%s'%s\n",ANSICode(ANSI_YELLOW, 0, 0),Token,ANSI_NORM);
        else printf("Integrity Mark has wrong HashType: '%s'\n",Token);
    }
    else
    {
        if (strcmp(ExpectedHash, SignHash) ==0)
        {
            if (Flags & FLAG_COLOR) printf("%sIntegrity Mark OKAY at Line: %d Date: %s%s\n",ANSICode(ANSI_GREEN,0,0),LineCount,DateStr,ANSI_NORM);
            else printf("Integrity Mark OKAY at Line: %d Date: %s\n",LineCount,DateStr);
            result=TRUE;
        }
        else
        {
            if (Flags & FLAG_COLOR) printf("%sIntegrity Mark FAILED at Line: %d Date: %s%s\n",ANSICode(ANSI_RED, 0, 0), LineCount, DateStr, ANSI_NORM);
            else printf("Integrity Mark FAILED at Line: %d Date: %s\n",LineCount,DateStr);
        }
    }

    Destroy(Token);
    Destroy(DateStr);
    Destroy(SignHash);
    Destroy(HashType);

    return(result);
}



int HashratCheckSignedFile(char *Path, HashratCtx *Ctx)
{
    STREAM *S;
    char *Tempstr=NULL, *HashStr=NULL;
    HASH *Hash, *tmpHash;
    int LineCount=0;

    S=STREAMOpen(Path, "rw");
    if (! S) return(FALSE);

    Hash=HashInit(Ctx->HashType);
    Tempstr=STREAMReadLine(Tempstr, S);
    while (Tempstr)
    {
        LineCount++;

        //hashrat-integrity-mark: 2014/10/29 21:05:19 md5:nTnlHmvVowFowmxXtm0uNw==
        if (strncmp(Tempstr, "hashrat-integrity-mark: ",24)==0)
        {
            tmpHash=Hash->Clone(Hash);
            HashFinish(tmpHash,ENCODE_BASE64,&HashStr);

            HashratOutputSigningCheck(Ctx, HashStr, Tempstr, LineCount);
        }
        Hash->Update(Hash,Tempstr, StrLen(Tempstr));


        Tempstr=STREAMReadLine(Tempstr, S);
    }

    Destroy(Tempstr);
    Destroy(HashStr);

    return(TRUE);
}