Commit: f0438c2

Commit Details

SHAf0438c2cbc2d838bb66a4d8129dd25b5d48d28ee
Treeb8e53d050248c8b632fa3de86003489acae4670b
Author<f69e50@finnacloud.com> 1766443042 +0300
Committer<f69e50@finnacloud.com> 1766443042 +0300
Message
increment once more
GPG Signature
-----BEGIN PGP SIGNATURE-----

iQJSBAABCAA8FiEEWJb139mJI+vZ81KkoAIVSUsXI0oFAmlJyCIeHHNvcGhpYS5l
cmFzbGFuQGZpbm5hY2xvdWQuY29tAAoJEKACFUlLFyNKtrgP/04FZPSa4Hmx9WpR
gOamzjIXc+1+pBvGQDairLZU6rtDSgNkoryrsqOOLIXZWkkxZ70q8/aXQBFThr+t
YyDIz85u9GiwPOV8o1X4sxzF7bupOd6YmOOPqS2vco1aibpB8w9N9EwlMzW95Otw
vnQ/h0kz8MTp0wfXeRJqvLg8DVPnLgW70ly1TZQe19jEA4NwBZOyK2ksTis8iycX
HUM4WW8Velo8O+OtygAbwISr2dILKvkclTLn9kgfpN5esvBvJu4K+xA5T5alDchc
PY3FFeZteQf3GX4v0EH8K3c/q8OcQFMxuRGO31uYGqNbjbOB7zdZVs3N0B1m1efv
vhCgZ6gyxlz0kiozgO6Sx5WFOzHuTlguCK+x0JOtzCokRL/VLiPzmW5Umt280eJz
AlD7u7Dah3khoqDkzXfCL1lxch9tRMVMUYWRMayxC3iculCFM6OCLgzY9hay5y1j
WP1ZOdy/x9jKPoLv5USnw0KlH4rZIHH+aDMDEzWmWUWYDpShylG7sKafXg75bnho
5LbAfCucnDrkjN+rx1dxaKrZswQlIJ8iZ5Q6DzHnDzl4TaFcN1E3exS+xp46H7va
SbR94UfpCyjpTQ2hHdOS7XHINFUDIzWF3mUZ8gqyEANiqpgJ+RcOGX66s69oILpr
vD20SIdMHWDqJH3G6GMNsg1g5/QU
=YrcG
-----END PGP SIGNATURE-----

✓ Verified

File: src/main/java/com/paymentlink/service/NodeIdService.java

1 package com.paymentlink.service;
2
3 import org.slf4j.Logger;
4 import org.slf4j.LoggerFactory;
5 import org.springframework.beans.factory.annotation.Value;
6 import org.springframework.stereotype.Service;
7
8 import java.io.IOException;
9 import java.nio.file.Files;
10 import java.nio.file.Path;
11 import java.nio.file.Paths;
12 import java.security.SecureRandom;
13
14 @Service
15 public class NodeIdService {
16
17 private static final Logger logger = LoggerFactory.getLogger(NodeIdService.class);
18 private static final SecureRandom RANDOM = new SecureRandom();
19 private static final String CHARACTERS = "abcdefghijklmnopqrstuvwxyz0123456789";
20
21 @Value("${app.server-id-file:incl/server-id.txt}")
22 private String serverIdFile;
23
24 @Value("${app.tld:ironpath.ai}")
25 private String tld;
26
27 private String nodeId;
28
29 /**
30 * Get or create node ID
31 */
32 public String getNodeId() {
33 if (nodeId == null) {
34 nodeId = loadOrCreateNodeId();
35 }
36 return nodeId;
37 }
38
39 /**
40 * Get short ID (without TLD)
41 */
42 public String getShortId() {
43 String fullId = getNodeId();
44 return fullId.split("\\.")[0];
45 }
46
47 private String loadOrCreateNodeId() {
48 try {
49 Path filePath = Paths.get(serverIdFile);
50
51 // Ensure parent directory exists
52 if (filePath.getParent() != null) {
53 Files.createDirectories(filePath.getParent());
54 }
55
56 // Try to read existing ID
57 if (Files.exists(filePath)) {
58 String id = Files.readString(filePath).trim();
59 if (!id.isEmpty()) {
60 logger.info("Loaded existing server ID: {}", id);
61 return id;
62 }
63 }
64
65 // Generate new ID
66 String newId = generateNodeId();
67 Files.writeString(filePath, newId);
68 logger.info("Generated new server ID: {}", newId);
69 return newId;
70
71 } catch (IOException e) {
72 logger.error("Failed to load/create server ID file", e);
73 // Generate temporary ID
74 String tempId = generateNodeId();
75 logger.warn("Using temporary server ID: {}", tempId);
76 return tempId;
77 }
78 }
79
80 private String generateNodeId() {
81 StringBuilder sb = new StringBuilder(6);
82 for (int i = 0; i < 6; i++) {
83 sb.append(CHARACTERS.charAt(RANDOM.nextInt(CHARACTERS.length())));
84 }
85 return sb.toString() + "." + tld;
86 }
87 }
88
89