File size: 4,020 Bytes
ccb6b75
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
import logger from '../utils/logger.js';

class CodeReviewEngine {
  constructor(aiProvider, memory, developer) {
    this.ai = aiProvider;
    this.memory = memory;
    this.developer = developer;
  }

  async reviewPullRequest(pr, files) {
    const reviews = [];

    for (const file of files.slice(0, 5)) {
      const content = file.patch || file.content || '';

      if (!content || content.length < 50) continue;

      try {
        const review = await this._reviewFile(file, content);
        if (review) {
          reviews.push(review);
        }
      } catch (error) {
        logger.error(`Failed to review file ${file.filename}: ${error.message}`);
      }
    }

    return reviews;
  }

  async _reviewFile(file, content) {
    const roleContext = this.developer.getRoleContext();

    const prompt = `أنت تراجع كود في Pull Request.

الملف: ${file.filename}
نوع التغيير: ${file.status}
الدور: ${roleContext.role}

الكود:
\`\`\`
${content.slice(0, 2000)}
\`\`\`

قم بمراجعة الكود واذكر:
1. هل هناك مشاكل أمنية؟
2. هل هناك مشاكل أداء؟
3. هل الكود نظيف ومقروء؟
4. هل هناك أخطاء محتملة؟
5. اقتراحات للتحسين

اكتب مراجعة مختصرة (3-5 نقاط) بالعربية أو الإنجليزية.`;

    const review = await this.ai.generate(prompt, {
      maxTokens: 500,
      temperature: 0.7,
    });

    return {
      file: file.filename,
      review: review.trim(),
      type: this._determineReviewType(review),
    };
  }

  _determineReviewType(review) {
    const lower = review.toLowerCase();

    if (lower.includes('security') || lower.includes('vulnerability') || lower.includes('xss') || lower.includes('sql injection')) {
      return 'security';
    }

    if (lower.includes('performance') || lower.includes('slow') || lower.includes('n+1') || lower.includes('optimize')) {
      return 'performance';
    }

    if (lower.includes('bug') || lower.includes('error') || lower.includes('crash') || lower.includes('null')) {
      return 'bug';
    }

    if (lower.includes('good') || lower.includes('clean') || lower.includes('nice') || lower.includes('excellent')) {
      return 'positive';
    }

    return 'suggestion';
  }

  async generateLineComment(line, context, file) {
    try {
      const prompt = `تعليق على سطر كود في ملف ${file}.

السطر: ${line}
السياق: ${context?.slice(0, 200) || ''}

اكتب تعليق قصير (جملة واحدة) على هذا السطر.`;

      const comment = await this.ai.generate(prompt, {
        maxTokens: 100,
        temperature: 0.8,
      });

      return comment.trim();
    } catch (error) {
      logger.error(`Failed to generate line comment: ${error.message}`);
      return 'Consider reviewing this line.';
    }
  }

  async suggestImprovements(code, language) {
    try {
      const prompt = `اقترح تحسينات على هذا الكود (${language}):

\`\`\`
${code.slice(0, 1500)}
\`\`\`

اذكر 2-3 تحسينات محددة.`;

      const suggestions = await this.ai.generate(prompt, {
        maxTokens: 300,
        temperature: 0.7,
      });

      return suggestions.trim();
    } catch (error) {
      logger.error(`Failed to suggest improvements: ${error.message}`);
      return 'Consider adding error handling and tests.';
    }
  }

  async checkForBugs(code, language) {
    try {
      const prompt = `هل ترى أي أخطاء في هذا الكود (${language}

\`\`\`
${code.slice(0, 1500)}
\`\`\`

اكتب أي أخطاء محتملة أو "No bugs found" إذا لم تجد شيء.`;

      const result = await this.ai.generate(prompt, {
        maxTokens: 200,
        temperature: 0.6,
      });

      return result.trim();
    } catch (error) {
      logger.error(`Failed to check for bugs: ${error.message}`);
      return 'Unable to check for bugs.';
    }
  }
}

export default CodeReviewEngine;