Compare commits

...

8 Commits

Author SHA1 Message Date
Aljaž Starc
78588bb335 use gcr.si in CI 2024-06-13 13:21:36 +00:00
Aljaž Starc
201c6be120 use gcr.si 2024-06-13 13:20:17 +00:00
Aljaž Starc
5b353843ee allow up to 19 characters in iban serverside check 2023-11-26 14:56:17 +00:00
Aljaž Starc
0e8213add7 path iban regex 2023-11-26 14:52:10 +00:00
Aljaž S
aa243a0513 Fix dockerfile 2023-10-28 17:09:08 +02:00
Aljaž Starc
f244b63804 Merge branch 'patch/rework' into 'master'
restructure stuff, add logging, use node 20

See merge request aljaxus/upn-qr!7
2023-10-23 20:57:00 +00:00
Aljaž Starc
548ddc98e7 Fix build-oci 2023-10-23 22:55:33 +02:00
Aljaž Starc
5323504a87 restructure stuff, add logging, use node 20 2023-10-23 22:54:08 +02:00
13 changed files with 24 additions and 25 deletions

View File

@@ -1,9 +1,9 @@
build-oci:
stage: build
image: registry.gitplac.si/cts/build-oci:1.0.3
image: gcr.si/cts/build-oci:1.2.2
script: [ "/build.sh" ]
variables:
CTS_BUILD_DOCKERFILE: Dockerfile
CTS_BUILD_DOCKERFILE: dockerfile
rules:
- if: $CI_COMMIT_REF_NAME == $CI_DEFAULT_BRANCH
variables:

View File

@@ -1,10 +0,0 @@
FROM node:14
WORKDIR /var/src
COPY src/package.json src/yarn.lock /var/src/
RUN yarn install
COPY src /var/src
CMD [ "yarn", "run", "start" ]

View File

@@ -5,16 +5,16 @@ services:
image: node:14
build:
context: ./
dockerfile: Dockerfile
dockerfile: dockerfile
command: ["yarn", "run", "dev"]
environment:
ENV: development
NODE_ENV: development
volumes:
- ./src:/var/src
- /var/src/node_modules
- ./:/app
- /app/node_modules
ports:
- 8080:80
- 80:80
healthcheck:
test: ["CMD", "curl", "-sSG", "http://localhost/healthcheck"]
interval: 30s

12
dockerfile Normal file
View File

@@ -0,0 +1,12 @@
FROM node:20-alpine
WORKDIR /app
COPY package.json yarn.lock /app/
RUN yarn install
COPY public /app/public
COPY views /app/views
COPY index.js /app/
CMD [ "yarn", "run", "start" ]

View File

@@ -19,6 +19,7 @@ app.get('/healthcheck', (req, res) => res.send({ ok: true, pod: process.env.POD_
app.get('/form', (req, res) => res.render('form', { q: req.query }))
app.get('/api/qrcode', async (req, res) => {
console.log(`/api/qrcode "${req.query['client_name']}" "${req.query['client_address']}" "${req.query['client_city']}" "${req.query['amount']}" "${req.query['payment_purpose']}" "${req.query['iban']}" "${req.query['reference']}" "${req.query['issuer_name']}" "${req.query['issuer_address']}" "${req.query['issuer_city']}"`)
const errors = []
function check (name, rgxp) {
@@ -36,7 +37,7 @@ app.get('/api/qrcode', async (req, res) => {
check('client_city', /^[a-zA-Z0-9ČŠŽĐ](?:[A-Z0-9 ČŠŽĐ]{0,31}[A-Z0-9ČŠŽĐ])?$/i)
check('amount', /^(?=.{11}$)[0]{1,11}[0-9]{0,11}$/)
check('payment_purpose', /^.{1,42}$/i)
check('iban', /^[A-Z]{2}\d{17}$/)
check('iban', /^[A-Z]{2}[A-Z0-9]{17,19}$/)
check('reference', /^[A-Z]{2}[0-9\-]{1,24}$/)
check('issuer_name', /^[a-zA-Z0-9ČŠŽĐ.'](?:[A-Z0-9 ČŠŽĐ.'\-]{0,31}[A-Z0-9ČŠŽĐ.'])?$/i)
check('issuer_address', /^[a-zA-Z0-9ČŠŽĐ](?:[A-Z0-9 ČŠŽĐ\-.]{0,31}[A-Z0-9ČŠŽĐ])?$/i)

View File

@@ -19,7 +19,7 @@ spec:
- name: upn-qr-registrypull
containers:
- name: upn-qr-ct
image: registry.gitplac.si/aljaxus/upn-qr
image: gcr.si/aljaxus/upn-qr
imagePullPolicy: Always
env:
- name: POD_NAME

View File

Before

Width:  |  Height:  |  Size: 70 KiB

After

Width:  |  Height:  |  Size: 70 KiB

View File

@@ -49,10 +49,6 @@ section div {
The application does not keep any long-term logs.
</p>
</section>
<section>
<h1>Terms of usage</h1>
<p>Because The Bank Association of Slovenia <a href="https://www.gov.si/zbirke/storitve/vkljucitev-v-izdajanje-upn-s-kodo-qr/" target="_blank">prohibits</a> the printing and use of UPN-QR codes on bills by any unauthorized party, you must be <a href="https://www.upn-qr.si/sl/registracija-izdajatelja">authorized</a> in order to use this application to generate a QR code and print it.</p>
</section>
<section>
<h1 id="maker"><a href="#maker">&#128279;</a> Form maker</h1>
<span>Fill in the fields with reciever's bank information and leave empty the ones that user has to fill out.</span>
@@ -293,11 +289,11 @@ updateQR()
<h5 id="api-qrcode-iban"><a href="#api-qrcode-iban">&#128279;</a> <code>iban</code></h5>
<div>
<span>Regex: <code>^[A-Z]{2}\d{17}$</code></span>
<span>Regex: <code>^[A-Z]{2}[A-Z0-9]{17,19}$</code></span>
<br>
<span>Demo: <a href="https://regex101.com/r/8bXDvh/1">regex101.com/r/8bXDvh/1</a></span>
<span>Demo: <a href="https://regex101.com/r/dN0DsH/1">regex101.com/r/dN0DsH/1</a></span>
<br>
<span>Description: Must contain country code (exp. SI56). No spaces allowed. Max length 34 characters</span>
<span>Description: Must contain country code (exp. SI56). No spaces allowed. Max length 21 characters</span>
<br>
<span>Example: SI56047500000280672</span>
</div>