Squashed commit of the following:

commit d6f48a8338
Author: Rene Vergara <rene@vergara.network>
Date:   Thu May 19 15:15:09 2022 -0500

    Bump version

commit c40c742b81
Author: Rene Vergara <rene@vergara.network>
Date:   Thu May 19 15:13:41 2022 -0500

    Remove legacy backend and update license

commit b8ea3e79cf
Author: Rene Vergara <rene@vergara.network>
Date:   Wed May 18 16:07:26 2022 -0500

    Integrate the settings component

commit 79e73ec89d
Author: Rene Vergara <rene@vergara.network>
Date:   Wed May 18 15:51:39 2022 -0500

    Integrate with new backend

commit 68d03b6602
Author: Rene Vergara <rene@vergara.network>
Date:   Tue Apr 19 15:36:30 2022 -0500

    Fix #2

commit d4be174b2d
Author: Rene Vergara <rene@vergara.network>
Date:   Mon Apr 11 09:31:08 2022 -0500

    Add MIT license

commit 6dddceff55
Author: Rene Vergara <rene@vergara.network>
Date:   Sun Apr 10 09:41:16 2022 -0500

    Update README

commit 8e98bff2ae
Author: Rene Vergara <rene@vergara.network>
Date:   Fri Apr 8 18:23:13 2022 -0500

    Implement receipt QR code

commit 934e28446c
Author: Rene Vergara <rene@vergara.network>
Date:   Fri Mar 25 18:57:02 2022 -0500

    Begin receipt component

commit 4f0253e6b2
Author: Rene Vergara <rene@vergara.network>
Date:   Mon Mar 7 14:53:10 2022 -0600

    Enable zats on display

commit 42dbd88e28
Author: Rene Vergara <rene@vergara.network>
Date:   Mon Mar 7 13:46:00 2022 -0600

    Enable front end setting for zats

commit 29a90b8614
Author: Rene Vergara <rene@vergara.network>
Date:   Mon Mar 7 13:45:45 2022 -0600

    Fix bug for payment read

commit 8130856d8f
Author: Rene Vergara <rene@vergara.network>
Date:   Mon Mar 7 11:14:29 2022 -0600

    Add zats setting parameter to backend

commit 43c34958f1
Author: Rene Vergara <rene@vergara.network>
Date:   Tue Feb 8 13:38:29 2022 -0600

    Improve biz form arrangement

commit 0ca495a811
Author: Rene Vergara <rene@vergara.network>
Date:   Wed Feb 2 12:30:05 2022 -0600

    Update app version

commit 770852640c
Author: Rene Vergara <rene@vergara.network>
Date:   Wed Feb 2 12:26:58 2022 -0600

    Fix bug of detecting payment

commit a42f04cd4a
Author: Rene Vergara <rene@vergara.network>
Date:   Wed Feb 2 12:26:21 2022 -0600

    Fix bug when deleting the last item

commit a22dc1aac3
Author: Rene Vergara <rene@vergara.network>
Date:   Wed Feb 2 10:36:29 2022 -0600

    Update app version

commit f33a920d29
Author: Rene Vergara <rene@vergara.network>
Date:   Tue Feb 1 12:56:02 2022 -0600

    Refactor the confirm dialog to re-use

commit 372c7eacf5
Author: Rene Vergara <rene@vergara.network>
Date:   Tue Feb 1 12:04:16 2022 -0600

    Enable logout

commit ba631ebf24
Author: Rene Vergara <rene@vergara.network>
Date:   Mon Jan 31 15:32:46 2022 -0600

    Fix bug on order saving

commit d61a1169fd
Author: Rene Vergara <rene@vergara.network>
Date:   Fri Jan 28 15:38:27 2022 -0600

    Update title look of Cancel component

commit 5c36be8fc7
Author: Rene Vergara <rene@vergara.network>
Date:   Fri Jan 28 15:37:41 2022 -0600

    Update look of Terms of Use

commit 5e5089af43
Author: Rene Vergara <rene@vergara.network>
Date:   Fri Jan 28 14:03:35 2022 -0600

    Add business contact name

commit 031c4f8a87
Author: Rene Vergara <rene@vergara.network>
Date:   Fri Jan 28 14:03:05 2022 -0600

    Add Terms of Use

commit 8a165eefb6
Author: Rene Vergara <rene@vergara.network>
Date:   Tue Jan 25 16:41:23 2022 -0600

    Look and feel improvements for wide screens

commit aaed144151
Author: Rene Vergara <rene@vergara.network>
Date:   Tue Jan 25 15:54:31 2022 -0600

    Update font

commit 323ffcc50b
Author: Rene Vergara <rene@vergara.network>
Date:   Tue Jan 25 15:20:01 2022 -0600

    Implement payment checks in API

commit d8380ec33f
Author: Rene Vergara <rene@vergara.network>
Date:   Sat Jan 22 07:50:39 2022 -0600

    Update modules

commit f5a14bf7d7
Author: Rene Vergara <rene@vergara.network>
Date:   Sat Jan 22 07:49:22 2022 -0600

    Implement biz info form

commit 5f80b1d912
Author: Rene Vergara <rene@vergara.network>
Date:   Wed Jan 19 14:50:00 2022 -0600

    Implement Country search

commit 881bb1baf1
Author: Rene Vergara <rene@vergara.network>
Date:   Wed Jan 19 10:26:25 2022 -0600

    Add country field

commit ea8febe368
Author: Rene Vergara <rene@vergara.network>
Date:   Tue Jan 18 16:40:50 2022 -0600

    Create component for business info

commit 0044f25edb
Author: Rene Vergara <rene@vergara.network>
Date:   Tue Jan 18 16:40:36 2022 -0600

    Modify login routing

commit 36242cffb9
Author: Rene Vergara <rene@vergara.network>
Date:   Tue Jan 18 16:40:20 2022 -0600

    Add website field to owner

commit 57d06873f5
Author: Rene Vergara <rene@vergara.network>
Date:   Mon Jan 17 14:49:21 2022 -0600

    Change auth guard to check for payment

commit c40ac0fd44
Author: Rene Vergara <rene@vergara.network>
Date:   Mon Jan 17 14:49:08 2022 -0600

    Add new fields for Owner

commit c9f84f1a28
Author: Rene Vergara <rene@vergara.network>
Date:   Mon Jan 17 13:39:26 2022 -0600

    Update API server to process logins and pays

commit 57781690a0
Author: Rene Vergara <rene@vergara.network>
Date:   Mon Jan 17 12:14:33 2022 -0600

    Add payment schema

commit 18f1667a00
Author: Rene Vergara <rene@vergara.network>
Date:   Sat Jan 15 07:59:25 2022 -0600

    Add new font and update login

commit 1134f1760c
Author: Rene Vergara <rene@vergara.network>
Date:   Sat Jan 15 07:58:56 2022 -0600

    Allow for memo amount in scan component

commit f6a41f3893
Merge: 47f2903 55dc475
Author: Rene Vergara <rene@vergara.network>
Date:   Fri Jan 14 16:17:41 2022 -0600

    Merge branch 'master' into dev

commit 47f2903d98
Author: Rene Vergara <rene@vergara.network>
Date:   Fri Jan 14 16:11:50 2022 -0600

    Change look of login

commit cfd3d0852f
Author: Rene Vergara <rene@vergara.network>
Date:   Fri Jan 14 15:47:31 2022 -0600

    Add copyright and CoinGecko attribution

commit 55dc475a6a
Author: Rene Vergara <rene@vergara.network>
Date:   Tue Nov 23 14:44:46 2021 -0600

    Correct item create form

commit 2596c36289
Author: Rene Vergara <rene@vergara.network>
Date:   Mon Nov 22 14:37:45 2021 -0600

    Implement flexible currency

commit 078916f92d
Author: Rene Vergara <rene@vergara.network>
Date:   Thu Nov 18 16:49:34 2021 -0600

    Change stepper to not editable

commit c1c60a4e20
Author: Rene Vergara <rene@vergara.network>
Date:   Thu Nov 18 16:40:19 2021 -0600

    Improved wording for login

commit 2f610c8f7f
Author: Rene Vergara <rene@vergara.network>
Date:   Thu Nov 18 16:38:25 2021 -0600

    Implement stepper for login

commit e5ff05d814
Author: Rene Vergara <rene@vergara.network>
Date:   Thu Nov 18 09:57:22 2021 -0600

    Enhance UI look and feel

commit 2265ab6512
Merge: b48f10f fb46c62
Author: Rene Vergara <rene@vergara.network>
Date:   Wed Nov 17 16:07:26 2021 -0600

    Merge branch 'master' into dev

commit b48f10fe03
Author: Rene Vergara <rene@vergara.network>
Date:   Wed Nov 17 16:03:46 2021 -0600

    Enhance login screen

commit ed46fd9b23
Author: Rene Vergara <rene@vergara.network>
Date:   Wed Nov 17 14:23:24 2021 -0600

    upgrade Angular

commit 0871a73cc2
Author: Rene Vergara <rene@vergara.network>
Date:   Wed Nov 17 14:14:34 2021 -0600

    Add new logo files

commit fb46c626ec
Author: Rene Vergara <rene@vergara.network>
Date:   Sat Nov 13 07:05:54 2021 -0600

    Correct wallet link

commit 8e3c773d1e
Author: Rene Vergara <rene@vergara.network>
Date:   Sat Nov 13 06:51:20 2021 -0600

    Adjust look of scan component

commit 5c043b1e0e
Author: Rene Vergara <rene@vergara.network>
Date:   Sat Nov 13 06:34:28 2021 -0600

    Reduced required confirmations to 6

commit 01dcdaecd0
Author: Rene Vergara <rene@vergara.network>
Date:   Sat Nov 13 06:33:51 2021 -0600

    Ensure all txs are logged to DB

    Not just the ones with the proper memo

commit 1336cc2009
Author: Rene Vergara <rene@vergara.network>
Date:   Fri Nov 12 11:16:21 2021 -0600

    Add link for wallets on the same device

commit f3e8bf22e3
Author: Rene Vergara <rene@vergara.network>
Date:   Thu Nov 11 13:52:07 2021 -0600

    Fix some issues tracking unconfirmed txs

commit 997276638f
Author: Rene Vergara <rene@vergara.network>
Date:   Thu Nov 11 09:24:43 2021 -0600

    update gitignore

commit 7145a437b4
Author: Rene Vergara <rene@vergara.network>
Date:   Thu Nov 11 09:18:38 2021 -0600

    Adjust visuals for small screens

commit b66650d34d
Author: Rene Vergara <rene@vergara.network>
Date:   Wed Nov 10 09:25:26 2021 -0600

    Implement session length selector

commit 648324ba5f
Author: Rene Vergara <rene@vergara.network>
Date:   Tue Nov 9 15:00:01 2021 -0600

    Implement monitoring of unconfirmed logins

commit d05292b365
Author: Rene Vergara <rene@vergara.network>
Date:   Tue Nov 9 12:39:16 2021 -0600

    Add API authentication

commit dacb8dbafb
Author: Rene Vergara <rene@vergara.network>
Date:   Mon Nov 8 14:37:26 2021 -0600

    Parametrize backend url

commit f33666bd0e
Author: Rene Vergara <rene@vergara.network>
Date:   Mon Nov 8 13:09:16 2021 -0600

    Implement backend https

commit 0a4dda4d73
Author: Rene Vergara <rene@vergara.network>
Date:   Sat Nov 6 07:14:27 2021 -0500

    Adjust session expiration

commit 99bec8f739
Author: Rene Vergara <rene@vergara.network>
Date:   Fri Nov 5 16:32:01 2021 -0500

    Implement list of orders

    Also corrects font in css files

commit b88fe7fc20
Author: Rene Vergara <rene@vergara.network>
Date:   Fri Nov 5 09:53:50 2021 -0500

    Implement link alternative to QR code

commit 172f4da6b1
Author: Rene Vergara <rene@vergara.network>
Date:   Fri Nov 5 09:53:29 2021 -0500

    Update main view to 'shop'

commit 4c5d4c311f
Author: Rene Vergara <rene@vergara.network>
Date:   Fri Nov 5 09:30:35 2021 -0500

    Add totals and price to order storage

commit 7e5210723e
Author: Rene Vergara <rene@vergara.network>
Date:   Fri Nov 5 08:21:19 2021 -0500

    Add ZEC price to order

commit 971fd7ca41
Author: Rene Vergara <rene@vergara.network>
Date:   Thu Nov 4 13:10:56 2021 -0500

    Implement MongoDB authentication

commit fa5221b128
Author: Rene Vergara <rene@vergara.network>
Date:   Thu Nov 4 07:49:09 2021 -0500

    Enhance blockchain scan

commit 01520adbc3
Author: Rene Vergara <rene@vergara.network>
Date:   Tue Nov 2 16:13:24 2021 -0500

    Implement database price feed

commit 0f5a731d08
Author: Rene Vergara <rene@vergara.network>
Date:   Tue Nov 2 10:35:22 2021 -0500

    Implement order closing

commit 33326febaf
Author: Rene Vergara <rene@vergara.network>
Date:   Thu Oct 28 15:34:48 2021 -0500

    Implement settings dialog

commit 251fa5d327
Author: Rene Vergara <rene@vergara.network>
Date:   Thu Oct 28 13:22:54 2021 -0500

    Implement checkout

commit dce8da391e
Author: Rene Vergara <rene@vergara.network>
Date:   Wed Oct 27 15:21:55 2021 -0500

    Implement order creation and cancellation

commit af8ee5dc90
Author: Rene Vergara <rene@vergara.network>
Date:   Wed Oct 27 07:59:43 2021 -0500

    Implement order creation

commit 064044c011
Author: Rene Vergara <rene@vergara.network>
Date:   Tue Oct 26 15:07:51 2021 -0500

    Implement add-to-order dialog

commit 8b3dfb2984
Author: Rene Vergara <rene@vergara.network>
Date:   Tue Oct 26 15:07:10 2021 -0500

    Fix bug in adding item

commit 35fcdaae54
Author: Rene Vergara <rene@vergara.network>
Date:   Tue Oct 26 13:34:52 2021 -0500

    Implement item delete

commit 61d68714d2
Author: Rene Vergara <rene@vergara.network>
Date:   Tue Oct 26 12:58:39 2021 -0500

    Implements custom theme

commit a7062e7b11
Author: Rene Vergara <rene@vergara.network>
Date:   Tue Oct 26 10:09:34 2021 -0500

    Implements item edit

commit 172ebb0171
Author: Rene Vergara <rene@vergara.network>
Date:   Mon Oct 25 15:01:06 2021 -0500

    Implemented basic order service

    Implemented adding the component to the viewer and the search in
    database.

    Fixed bug in search of item list

commit eea8e06d48
Author: Rene Vergara <rene@vergara.network>
Date:   Mon Oct 25 12:49:50 2021 -0500

    Add order mongoose schema

commit cd1a0208df
Author: Rene Vergara <rene@vergara.network>
Date:   Fri Oct 22 17:20:36 2021 -0500

    Implement create item

    Adds Zcash price feed from CoinGecko

commit 22c89b9d4f
Author: Rene Vergara <rene@vergara.network>
Date:   Thu Oct 21 16:23:33 2021 -0500

    Implements item list

commit 85b775ae15
Author: Rene Vergara <rene@vergara.network>
Date:   Thu Oct 21 14:29:19 2021 -0500

    Add item model

commit 62658f7be9
Author: Rene Vergara <rene@vergara.network>
Date:   Thu Oct 21 14:29:04 2021 -0500

    Fix header

commit 7e6cd11962
Author: Rene Vergara <rene@vergara.network>
Date:   Thu Oct 21 11:22:48 2021 -0500

    Fix header

commit 4214dac887
Author: Rene Vergara <rene@vergara.network>
Date:   Thu Oct 21 10:23:58 2021 -0500

    Implement resolver for node address

    Fixes services.

commit 30a83414ad
Author: Rene Vergara <rene@vergara.network>
Date:   Wed Oct 20 15:51:14 2021 -0500

    Update of code base

commit 6059c04b75
Author: Rene Vergara <rene@vergara.network>
Date:   Fri Oct 15 14:14:49 2021 -0500

    Implements Zcash login

commit 9926a1a4fe
Author: Rene Vergara <rene@vergara.network>
Date:   Fri Oct 1 15:10:14 2021 -0500

    initial commit
This commit is contained in:
Rene Vergara 2022-05-19 15:35:03 -05:00
parent ac269d589e
commit 9ed75745ea
No known key found for this signature in database
GPG key ID: 65122AD495A7F5B2
18 changed files with 263 additions and 104 deletions

7
COPYING Normal file
View file

@ -0,0 +1,7 @@
Copyright (c) 2022 Vergara Technologies LLC
This package ("Original Work") is licensed under the terms of the Bootstrap
Open Source License, version 1.0, or at your option, any later version
("BOSL"). See the file ./LICENSE for the terms of the Bootstrap Open Source
Licence, version 1.0.

192
LICENSE
View file

@ -1,20 +1,178 @@
The MIT License (MIT) Copyright (c) 2022 Vergara Technologies
Copyright © 2022 Vergara Technologies LLC
Permission is hereby granted, free of charge, to any person obtaining a copy =======================================================
of this software and associated documentation files (the “Software”), to deal Bootstrap Open Source Licence ("BOSL") v. 1.0
in the Software without restriction, including without limitation the rights =======================================================
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell This Bootstrap Open Source Licence (the "License") applies to any original work
copies of the Software, and to permit persons to whom the Software is of authorship (the "Original Work") whose owner (the "Licensor") has placed the
furnished to do so, subject to the following conditions: following licensing notice adjacent to the copyright notice for the Original
Work:
The above copyright notice and this permission notice shall be included in all *Licensed under the Bootstrap Open Source Licence version 1.0*
copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 1. **Grant of Copyright License.** Licensor grants You a worldwide,
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, royalty-free, non-exclusive, sublicensable license, for the duration of the
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE copyright in the Original Work, to do the following:
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, a. to reproduce the Original Work in copies, either alone or as part of
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE a collective work;
SOFTWARE.
b. to translate, adapt, alter, transform, modify, or arrange the
Original Work, thereby creating derivative works ("Derivative Works")
based upon the Original Work;
c. to distribute or communicate copies of the Original Work and
Derivative Works to the public, provided that prior to any such
distribution or communication You first place a machine-readable copy
of the Source Code of the Original Work and such Derivative Works that
You intend to distribute or communicate in an information repository
reasonably calculated to permit inexpensive and convenient access
thereto by the public (“Information Repository”) for as long as You
continue to distribute or communicate said copies, accompanied by an
irrevocable offer to license said copies to the public free of charge
under this License, said offer valid starting no later than 12 months
after You first distribute or communicate said copies;
d. to perform the Original Work publicly; and
e. to display the Original Work publicly.
2. **Grant of Patent License.** Licensor grants You a worldwide, royalty-free,
non-exclusive, sublicensable license, under patent claims owned or controlled
by the Licensor that are embodied in the Original Work as furnished by the
Licensor, for the duration of the patents, to make, use, sell, offer for sale,
have made, and import the Original Work and Derivative Works.
3. **Grant of Source Code License.** The "Source Code" for a work means the
preferred form of the work for making modifications to it and all available
documentation describing how to modify the work. Licensor agrees to provide a
machine-readable copy of the Source Code of the Original Work along with each
copy of the Original Work that Licensor distributes. Licensor reserves the
right to satisfy this obligation by placing a machine-readable copy of said
Source Code in an Information Repository for as long as Licensor continues to
distribute the Original Work.
4. **Exclusions From License Grant.** Neither the names of Licensor, nor the
names of any contributors to the Original Work, nor any of their trademarks or
service marks, may be used to endorse or promote products derived from this
Original Work without express prior permission of the Licensor. Except as
expressly stated herein, nothing in this License grants any license to
Licensor's trademarks, copyrights, patents, trade secrets or any other
intellectual property. No patent license is granted to make, use, sell, offer
for sale, have made, or import embodiments of any patent claims other than the
licensed claims defined in Section 2. No license is granted to the trademarks
of Licensor even if such marks are included in the Original Work. Nothing in
this License shall be interpreted to prohibit Licensor from licensing under
terms different from this License any Original Work that Licensor otherwise
would have a right to license.
5. **External Deployment.** The term "External Deployment" means the use,
distribution, or communication of the Original Work or Derivative Works in any
way such that the Original Work or Derivative Works may be used by anyone other
than You, whether those works are distributed or communicated to those persons
or made available as an application intended for use over a network. As an
express condition for the grants of license hereunder, You must treat any
External Deployment by You of the Original Work or a Derivative Work as a
distribution under section 1(c).
6. **Attribution Rights.** You must retain, in the Source Code of any
Derivative Works that You create, all copyright, patent, or trademark notices
from the Source Code of the Original Work, as well as any notices of licensing
and any descriptive text identified therein as an "Attribution Notice." You
must cause the Source Code for any Derivative Works that You create to carry a
prominent Attribution Notice reasonably calculated to inform recipients that
You have modified the Original Work.
7. **Warranty of Provenance and Disclaimer of Warranty.** Licensor warrants
that the copyright in and to the Original Work and the patent rights granted
herein by Licensor are owned by the Licensor or are sublicensed to You under
the terms of this License with the permission of the contributor(s) of those
copyrights and patent rights. Except as expressly stated in the immediately
preceding sentence, the Original Work is provided under this License on an "AS
IS" BASIS and WITHOUT WARRANTY, either express or implied, including, without
limitation, the warranties of non-infringement, merchantability or fitness for
a particular purpose. THE ENTIRE RISK AS TO THE QUALITY OF THE ORIGINAL WORK IS
WITH YOU. This DISCLAIMER OF WARRANTY constitutes an essential part of this
License. No license to the Original Work is granted by this License except
under this disclaimer.
8. **Limitation of Liability.** Under no circumstances and under no legal
theory, whether in tort (including negligence), contract, or otherwise, shall
the Licensor be liable to anyone for any indirect, special, incidental, or
consequential damages of any character arising as a result of this License or
the use of the Original Work including, without limitation, damages for loss of
goodwill, work stoppage, computer failure or malfunction, or any and all other
commercial damages or losses. This limitation of liability shall not apply to
the extent applicable law prohibits such limitation.
9. **Acceptance and Termination.** If, at any time, You expressly assented to
this License, that assent indicates your clear and irrevocable acceptance of
this License and all of its terms and conditions. If You distribute or
communicate copies of the Original Work or a Derivative Work, You must make a
reasonable effort under the circumstances to obtain the express assent of
recipients to the terms of this License. This License conditions your rights to
undertake the activities listed in Section 1, including your right to create
Derivative Works based upon the Original Work, and doing so without honoring
these terms and conditions is prohibited by copyright law and international
treaty. Nothing in this License is intended to affect copyright exceptions and
limitations (including 'fair use' or 'fair dealing'). This License shall
terminate immediately and You may no longer exercise any of the rights granted
to You by this License upon your failure to honor the conditions in Section
1(c).
10. **Termination for Patent Action.** This License shall terminate
automatically and You may no longer exercise any of the rights granted to You
by this License as of the date You commence an action, including a cross-claim
or counterclaim, against Licensor or any licensee alleging that the Original
Work infringes a patent. This termination provision shall not apply for an
action alleging patent infringement by combinations of the Original Work with
other software or hardware.
11. **Jurisdiction, Venue and Governing Law.** Any action or suit relating to
this License may be brought only in the courts of a jurisdiction wherein the
Licensor resides or in which Licensor conducts its primary business, and under
the laws of that jurisdiction excluding its conflict-of-law provisions. The
application of the United Nations Convention on Contracts for the International
Sale of Goods is expressly excluded. Any use of the Original Work outside the
scope of this License or after its termination shall be subject to the
requirements and penalties of copyright or patent law in the appropriate
jurisdiction. This section shall survive the termination of this License.
12. **Attorneys' Fees.** In any action to enforce the terms of this License or
seeking damages relating thereto, the prevailing party shall be entitled to
recover its costs and expenses, including, without limitation, reasonable
attorneys' fees and costs incurred in connection with such action, including
any appeal of such action. This section shall survive the termination of this
License.
13. **Miscellaneous.** If any provision of this License is held to be
unenforceable, such provision shall be reformed only to the extent necessary to
make it enforceable.
14. **Definition of "You" in This License.** "You" throughout this License,
whether in upper or lower case, means an individual or a legal entity
exercising rights under, and complying with all of the terms of, this License.
For legal entities, "You" includes any entity that controls, is controlled by,
or is under common control with you. For purposes of this definition, "control"
means (i) the power, direct or indirect, to cause the direction or management
of such entity, whether by contract or otherwise, or (ii) ownership of fifty
percent (50%) or more of the outstanding shares, or (iii) beneficial ownership
of such entity.
15. **Right to Use.** You may use the Original Work in all ways not otherwise
restricted or conditioned by this License or by law, and Licensor promises not
to interfere with or be responsible for such uses by You.
16. **Modification of This License.** This License is Copyright © 2007 Zooko
Wilcox-O'Hearn. Permission is granted to copy, distribute, or communicate this
License without modification. Nothing in this License permits You to modify
this License as applied to the Original Work or to Derivative Works. However,
You may modify the text of this License and copy, distribute or communicate
your modified version (the "Modified License") and apply it to other original
works of authorship subject to the following conditions: (i) You may not
indicate in any way that your Modified License is the "Bootstrap Open Source
Licence" or "BOSL" and you may not use those names in the name of your Modified
License; and (ii) You must replace the notice specified in the first paragraph
above with the notice "Licensed under <insert your license name here>" or with
a notice of your own that is not confusingly similar to the notice in this
License.

View file

@ -1,6 +1,6 @@
{ {
"name": "zgo", "name": "zgo",
"version": "1.0.3", "version": "1.1.0",
"scripts": { "scripts": {
"ng": "ng", "ng": "ng",
"start": "ng serve", "start": "ng serve",

View file

@ -63,7 +63,9 @@ export class BusinessComponent implements OnInit {
country: '', country: '',
email: '', email: '',
website: '', website: '',
zats: false zats: false,
invoices: false,
expiration: new Date(Date.now()).toISOString()
} }
public countriesUpdate: Observable<Country[]>; public countriesUpdate: Observable<Country[]>;
public ownerUpdate: Observable<Owner>; public ownerUpdate: Observable<Owner>;
@ -147,6 +149,7 @@ export class BusinessComponent implements OnInit {
save() { save() {
this.owner = { this.owner = {
_id: '',
address: '', address: '',
currency: 'usd', currency: 'usd',
tax: false, tax: false,
@ -165,7 +168,9 @@ export class BusinessComponent implements OnInit {
country: this.bizForm.get('country')!.value, country: this.bizForm.get('country')!.value,
email: this.bizForm.get('email')!.value, email: this.bizForm.get('email')!.value,
website: this.bizForm.get('website')!.value, website: this.bizForm.get('website')!.value,
zats: false zats: false,
invoices: false,
expiration: new Date(Date.now()).toISOString()
}; };
this.userService.addOwner(this.owner); this.userService.addOwner(this.owner);
this.stepper!.next(); this.stepper!.next();

View file

@ -4,6 +4,7 @@ import {HttpClient, HttpParams, HttpHeaders} from '@angular/common/http';
import {UserService} from './user.service'; import {UserService} from './user.service';
import { Owner } from './owner.model'; import { Owner } from './owner.model';
var Buffer = require('buffer/').Buffer;
//import {User} from './user.model'; //import {User} from './user.model';
@Injectable({providedIn: 'root'}) @Injectable({providedIn: 'root'})
@ -42,11 +43,14 @@ export class FullnodeService{
paid: false, paid: false,
website: '', website: '',
country: '', country: '',
zats: false zats: false,
invoices: false,
expiration: new Date(Date.now()).toISOString()
}; };
constructor(private http: HttpClient, public userService: UserService){ constructor(private http: HttpClient, public userService: UserService){
this.reqHeaders = new HttpHeaders().set('Authorization', this.apiKey); var auth = 'Basic ' + Buffer.from('user:superSecret').toString('base64');
this.reqHeaders = new HttpHeaders().set('Authorization', auth);
this.ownerUpdate = userService.ownerUpdate; this.ownerUpdate = userService.ownerUpdate;
this.getAddr(); this.getAddr();
this.getHeight(); this.getHeight();

View file

@ -37,7 +37,9 @@ export class HeaderComponent implements OnInit, OnDestroy {
paid: false, paid: false,
website: '', website: '',
country: '', country: '',
zats: false zats: false,
invoices: false,
expiration: new Date(Date.now()).toISOString()
}; };
private session: string | null = ''; private session: string | null = '';
public heightUpdate: Observable<number>; public heightUpdate: Observable<number>;

View file

@ -2,6 +2,6 @@ export interface Item {
_id?: any; _id?: any;
name: string; name: string;
description: string; description: string;
user: string; owner: string;
cost: number; cost: number;
} }

View file

@ -23,7 +23,7 @@ export class ItemCreateComponent implements OnInit {
){ ){
if (data._id === '') { if (data._id === '') {
this.form = fb.group({ this.form = fb.group({
id: [null], id: [''],
name: [null, Validators.required], name: [null, Validators.required],
description: [null, Validators.required], description: [null, Validators.required],
cost: new FormControl('', { cost: new FormControl('', {
@ -49,6 +49,7 @@ export class ItemCreateComponent implements OnInit {
} }
save() { save() {
console.log(this.form.value);
this.dialogRef.close(this.form.value); this.dialogRef.close(this.form.value);
} }

View file

@ -40,7 +40,9 @@ export class ItemListComponent implements OnInit{
paid: false, paid: false,
website: '', website: '',
country: '', country: '',
zats: false zats: false,
invoices: false,
expiration: new Date(Date.now()).toISOString()
}; };
public price: number = 1; public price: number = 1;
public ownerUpdate: Observable<Owner>; public ownerUpdate: Observable<Owner>;
@ -87,7 +89,7 @@ export class ItemListComponent implements OnInit{
dialogRef.afterClosed().subscribe((val) => { dialogRef.afterClosed().subscribe((val) => {
if(val != null) { if(val != null) {
var item:Item = {name: val.name, description: val.description, cost: val.cost, user: this.owner.address}; var item:Item = {_id: '', name: val.name, description: val.description, cost: val.cost, owner: this.owner.address};
this.itemService.addItem(item); this.itemService.addItem(item);
} }
this.itemService.getItems(this.owner.address); this.itemService.getItems(this.owner.address);
@ -98,9 +100,9 @@ export class ItemListComponent implements OnInit{
} }
edit(id: string) { edit(id: string) {
//console.log('Edit:', id); console.log('Edit:', id);
const item = this.items.find(element => element._id == id); const item = this.items.find(element => element._id == id);
//console.log(item); console.log(item);
const dialogConfig = new MatDialogConfig(); const dialogConfig = new MatDialogConfig();
dialogConfig.disableClose = true; dialogConfig.disableClose = true;
@ -115,7 +117,7 @@ export class ItemListComponent implements OnInit{
name: val.name, name: val.name,
description: val.description, description: val.description,
cost: val.cost, cost: val.cost,
user: this.owner.address owner: this.owner.address
}; };
//console.log('Edit:', editItem); //console.log('Edit:', editItem);
this.itemService.addItem(editItem).subscribe((response) => { this.itemService.addItem(editItem).subscribe((response) => {

View file

@ -3,5 +3,5 @@ export interface Item {
name: string; name: string;
description: string; description: string;
cost: number; cost: number;
user: string; owner: string;
} }

View file

@ -3,6 +3,8 @@ import { Injectable } from '@angular/core';
import { Subject, BehaviorSubject, Observable } from 'rxjs'; import { Subject, BehaviorSubject, Observable } from 'rxjs';
import { HttpClient, HttpParams, HttpHeaders } from '@angular/common/http'; import { HttpClient, HttpParams, HttpHeaders } from '@angular/common/http';
var Buffer = require('buffer/').Buffer;
@Injectable({providedIn: 'root'}) @Injectable({providedIn: 'root'})
export class ItemService{ export class ItemService{
@ -15,13 +17,14 @@ export class ItemService{
private reqHeaders: HttpHeaders; private reqHeaders: HttpHeaders;
constructor(private http: HttpClient){ constructor(private http: HttpClient){
this.reqHeaders = new HttpHeaders().set('Authorization', this.apiKey); var auth = 'Basic ' + Buffer.from('user:superSecret').toString('base64');
this.reqHeaders = new HttpHeaders().set('Authorization', auth);
} }
getItems(addr: string){ getItems(addr: string){
this.address = addr; this.address = addr;
const params = new HttpParams().append('address', addr); const params = new HttpParams().append('address', addr);
let obs = this.http.get<{message: string, items: any}>(this.beUrl+'api/getitems', { headers:this.reqHeaders, params: params, observe: 'response'}); let obs = this.http.get<{message: string, items: any}>(this.beUrl+'api/items', { headers:this.reqHeaders, params: params, observe: 'response'});
obs.subscribe((ItemDataResponse) => { obs.subscribe((ItemDataResponse) => {
if (ItemDataResponse.status == 200 ) { if (ItemDataResponse.status == 200 ) {
@ -39,7 +42,7 @@ export class ItemService{
addItem(item: Item) { addItem(item: Item) {
//const params = new HttpParams().append('item', JSON.stringify(item)); //const params = new HttpParams().append('item', JSON.stringify(item));
let obs = this.http.post<{message: string}>(this.beUrl+'api/item', { item: item }, { headers: this.reqHeaders }); let obs = this.http.post<{message: string}>(this.beUrl+'api/item', { payload: item }, { headers: this.reqHeaders });
obs.subscribe((ItemResponse) => { obs.subscribe((ItemResponse) => {
console.log('Item added'); console.log('Item added');

View file

@ -35,7 +35,6 @@ export class LoginComponent implements OnInit, AfterViewInit {
address: '', address: '',
session: '', session: '',
blocktime: 0, blocktime: 0,
expired: false,
pin: '', pin: '',
validated: false validated: false
}; };
@ -58,7 +57,9 @@ export class LoginComponent implements OnInit, AfterViewInit {
paid: false, paid: false,
website: '', website: '',
country: '', country: '',
zats: false zats: false,
invoices: false,
expiration: new Date(Date.now()).toISOString()
}; };
private FullnodeSub: Subscription = new Subscription(); private FullnodeSub: Subscription = new Subscription();
private UserSub: Subscription = new Subscription(); private UserSub: Subscription = new Subscription();
@ -152,12 +153,7 @@ export class LoginComponent implements OnInit, AfterViewInit {
} }
loginCheck(){ loginCheck(){
var today = new Date().getTime() / 1000;
this.userService.findUser(); this.userService.findUser();
this.userService.findPending();
this.txsUpdate.subscribe((txs) => {
this.txs = txs;
});
this.userUpdate.subscribe((user) => { this.userUpdate.subscribe((user) => {
if (user.blocktime > 0) { if (user.blocktime > 0) {
if(this.myStepper!.selectedIndex === 1){ if(this.myStepper!.selectedIndex === 1){
@ -173,12 +169,6 @@ export class LoginComponent implements OnInit, AfterViewInit {
} }
} }
}); });
if (this.txs.length > 0) {
this.barMode = 'determinate';
this.barValue = (this.txs[0].confirmations / 2) * 100;
this.confirmedMemo = true;
this.barMessage = 'Login memo found, awaiting confirmations';
}
} }
login(stepper: MatStepper) { login(stepper: MatStepper) {

View file

@ -8,6 +8,8 @@ import { User } from '../user.model';
import { Owner } from '../owner.model'; import { Owner } from '../owner.model';
import { LineItem} from '../items/lineitem.model'; import { LineItem} from '../items/lineitem.model';
var Buffer = require('buffer/').Buffer;
@Injectable({providedIn: 'root'}) @Injectable({providedIn: 'root'})
export class OrderService { export class OrderService {
@ -18,7 +20,6 @@ export class OrderService {
address: '', address: '',
session: '', session: '',
blocktime: 0, blocktime: 0,
expired: false,
pin: '', pin: '',
validated: false validated: false
}, },
@ -42,7 +43,9 @@ export class OrderService {
paid: false, paid: false,
website: '', website: '',
country: '', country: '',
zats: false zats: false,
invoices: false,
expiration: new Date(Date.now()).toISOString()
}, },
order: { order: {
address: '', address: '',
@ -78,7 +81,8 @@ export class OrderService {
public fullnodeService: FullnodeService, public fullnodeService: FullnodeService,
public userService: UserService public userService: UserService
) { ) {
this.reqHeaders = new HttpHeaders().set('Authorization', this.apiKey); var auth = 'Basic ' + Buffer.from('user:superSecret').toString('base64');
this.reqHeaders = new HttpHeaders().set('Authorization', auth);
this.userUpdate = userService.userUpdate; this.userUpdate = userService.userUpdate;
this.ownerUpdate = userService.ownerUpdate; this.ownerUpdate = userService.ownerUpdate;
this.userUpdate.subscribe((user) => { this.userUpdate.subscribe((user) => {
@ -132,7 +136,8 @@ export class OrderService {
addToOrder(lineItem: LineItem) { addToOrder(lineItem: LineItem) {
if(this.dataStore.order._id != null) { if(this.dataStore.order._id != null) {
let obs = this.http.post<{message: string}>(this.beUrl+'api/lineitem', { order_id: this.dataStore.order._id, line: lineItem }, { headers: this.reqHeaders }); this.dataStore.order.lines.push(lineItem);
let obs = this.http.post(this.beUrl+'api/order', { payload: this.dataStore.order }, { headers: this.reqHeaders });
obs.subscribe((orderData) => { obs.subscribe((orderData) => {
this.getOrder(); this.getOrder();
}); });
@ -143,21 +148,21 @@ export class OrderService {
createOrder(lineItem: LineItem) { createOrder(lineItem: LineItem) {
var order:Order = { var order:Order = {
_id: '',
address: this.dataStore.user.address, address: this.dataStore.user.address,
session: this.dataStore.user.session, session: this.dataStore.user.session,
currency: this.dataStore.owner.currency, currency: this.dataStore.owner.currency,
timestamp: new Date(Date.now()).toISOString(),
closed: false, closed: false,
totalZec: 0, totalZec: 0,
price: 0, price: 0,
total: 0, total: 0,
lines: [] lines: [lineItem]
}; };
let obs = this.http.post<{message: string, order: Order}>(this.beUrl+'api/order', {order: order}, { headers: this.reqHeaders }); let obs = this.http.post<{message: string, order: Order}>(this.beUrl+'api/order', {payload: order}, { headers: this.reqHeaders });
obs.subscribe((orderData) => { obs.subscribe((orderData) => {
console.log('Create order', orderData); console.log('Created order');
this.dataStore.order = orderData.order; this.getOrder()
this._orderUpdated.next(Object.assign({}, this.dataStore).order);
this.addToOrder(lineItem);
}); });
return obs; return obs;
@ -197,7 +202,7 @@ export class OrderService {
this.dataStore.order.price = price; this.dataStore.order.price = price;
}); });
this.dataStore.order.closed = true; this.dataStore.order.closed = true;
let obs = this.http.post<{message: string, order: Order}>(this.beUrl+'api/order', {order: this.dataStore.order}, { headers: this.reqHeaders }); let obs = this.http.post(this.beUrl+'api/order', {payload: this.dataStore.order}, { headers: this.reqHeaders });
obs.subscribe((orderData) => { obs.subscribe((orderData) => {
console.log('Closed order', orderData); console.log('Closed order', orderData);
this.dataStore.order = { this.dataStore.order = {

View file

@ -19,4 +19,6 @@ export interface Owner {
website: string; website: string;
country: string; country: string;
zats: boolean; zats: boolean;
invoices: boolean;
expiration: string;
} }

View file

@ -5,6 +5,8 @@ import { Order } from './order/order.model';
import { Owner } from './owner.model'; import { Owner } from './owner.model';
import { UserService } from './user.service'; import { UserService } from './user.service';
var Buffer = require('buffer/').Buffer;
@Injectable({ @Injectable({
providedIn: 'root' providedIn: 'root'
}) })
@ -31,7 +33,9 @@ export class ReceiptService {
paid: false, paid: false,
website: '', website: '',
country: '', country: '',
zats: false zats: false,
invoices: false,
expiration: new Date(Date.now()).toISOString()
}, },
order: { order: {
address: '', address: '',
@ -63,13 +67,14 @@ export class ReceiptService {
private http: HttpClient, private http: HttpClient,
public userService: UserService public userService: UserService
) { ) {
this.reqHeaders = new HttpHeaders().set('Authorization', this.apiKey); var auth = 'Basic ' + Buffer.from('user:superSecret').toString('base64');
this.reqHeaders = new HttpHeaders().set('Authorization', auth);
this.ownerUpdate = userService.ownerUpdate; this.ownerUpdate = userService.ownerUpdate;
} }
getOrderById(id:string) { getOrderById(id:string) {
const params = new HttpParams().append('id', id); //const params = new HttpParams().append('id', id);
let obs = this.http.get<{message: string, order: any}>(this.beUrl+'api/receipt', { headers:this.reqHeaders, params:params, observe: 'response'}); let obs = this.http.get<{message: string, order: any}>(this.beUrl+'api/order/'+id, { headers:this.reqHeaders, observe: 'response'});
obs.subscribe((OrderDataResponse) => { obs.subscribe((OrderDataResponse) => {
if (OrderDataResponse.status == 200) { if (OrderDataResponse.status == 200) {

View file

@ -3,7 +3,6 @@ export interface User {
address: string; address: string;
session: string; session: string;
blocktime: number; blocktime: number;
expired: boolean;
pin: string; pin: string;
validated: boolean; validated: boolean;
} }

View file

@ -6,6 +6,8 @@ import {Owner} from './owner.model';
import { Country } from './country.model'; import { Country } from './country.model';
import {Tx} from './tx.model'; import {Tx} from './tx.model';
var Buffer = require('buffer/').Buffer;
@Injectable({providedIn: 'root'}) @Injectable({providedIn: 'root'})
export class UserService{ export class UserService{
@ -15,7 +17,6 @@ export class UserService{
address: '', address: '',
session: '', session: '',
blocktime: 0, blocktime: 0,
expired: false,
pin: '', pin: '',
validated: false validated: false
}, },
@ -38,7 +39,9 @@ export class UserService{
paid: false, paid: false,
website: '', website: '',
country: '', country: '',
zats: false zats: false,
invoices: false,
expiration: new Date(Date.now()).toISOString()
}, },
txs : [], txs : [],
countries: [] countries: []
@ -64,12 +67,12 @@ export class UserService{
private apiKey = 'YourApiKey'; private apiKey = 'YourApiKey';
constructor(private http: HttpClient){ constructor(private http: HttpClient){
this.reqHeaders = new HttpHeaders().set('Authorization', this.apiKey); var auth = 'Basic ' + Buffer.from('user:superSecret').toString('base64');
this.reqHeaders = new HttpHeaders().set('Authorization', auth);
//console.log('US:', this.reqHeaders); //console.log('US:', this.reqHeaders);
this.session = localStorage.getItem('s4z_token'); this.session = localStorage.getItem('s4z_token');
if (this.session != null) { if (this.session != null) {
this.findUser(); this.findUser();
this.findPending();
} }
} }
@ -88,12 +91,12 @@ export class UserService{
this.session = localStorage.getItem('s4z_token'); this.session = localStorage.getItem('s4z_token');
if (this.session != null) { if (this.session != null) {
const params = new HttpParams().append('session', this.session!); const params = new HttpParams().append('session', this.session!);
let obs = this.http.get<{message: string, user: any}>(this.beUrl+'api/getuser', { headers: this.reqHeaders, params: params, observe: 'response'}); let obs = this.http.get<{message: string, user: any}>(this.beUrl+'api/user', { headers: this.reqHeaders, params: params, observe: 'response'});
obs.subscribe((UserDataResponse) => { obs.subscribe((UserDataResponse) => {
console.log(UserDataResponse.status); console.log(UserDataResponse.status);
if (UserDataResponse.status == 200){ if (UserDataResponse.status == 200){
this.dataStore.user = UserDataResponse.body!.user[0]; this.dataStore.user = UserDataResponse.body!.user;
console.log(`US: Found user, returning it`); console.log(`US: Found user, returning it`);
this._uZaddrUpdated.next(Object.assign({},this.dataStore).user.address); this._uZaddrUpdated.next(Object.assign({},this.dataStore).user.address);
this._userUpdated.next(Object.assign({}, this.dataStore).user); this._userUpdated.next(Object.assign({}, this.dataStore).user);
@ -103,7 +106,6 @@ export class UserService{
address: '', address: '',
session: '', session: '',
blocktime: 0, blocktime: 0,
expired: false,
pin: '', pin: '',
validated: false validated: false
}; };
@ -120,32 +122,6 @@ export class UserService{
} }
} }
findPending() {
this.session = localStorage.getItem('s4z_token');
if (this.session != null) {
const params = new HttpParams().append('session', this.session!);
let obs = this.http.get<{message: string, txs: any}>(this.beUrl+'api/pending', { headers: this.reqHeaders, params: params, observe: 'response'});
obs.subscribe((TxDataResponse) => {
//console.log('US Tx', TxDataResponse);
if (TxDataResponse.status == 200){
this.dataStore.txs = TxDataResponse.body!.txs;
console.log(`US: Pending logins found`);
this._txsUpdated.next(Object.assign({},this.dataStore).txs);
} else {
console.log('US: Did not find pending txs');
this.dataStore.txs = [];
this._txsUpdated.next(Object.assign({},this.dataStore).txs);
}
});
return obs;
} else {
console.log('No session loaded');
return null;
}
}
validateUser(){ validateUser(){
var validatedUser: User = this.dataStore.user; var validatedUser: User = this.dataStore.user;
validatedUser.validated = true; validatedUser.validated = true;
@ -157,10 +133,9 @@ export class UserService{
addOwner(owner: Owner) { addOwner(owner: Owner) {
owner.address = this.dataStore.user.address; owner.address = this.dataStore.user.address;
let obs = this.http.post<{message: string}>(this.beUrl+'api/addowner', {owner: owner}, {headers: this.reqHeaders}); let obs = this.http.post(this.beUrl+'api/owner', {payload: owner}, {headers: this.reqHeaders});
obs.subscribe((responseData) => { obs.subscribe((responseData) => {
console.log(responseData.message);
this.getOwner(this.dataStore.user.address); this.getOwner(this.dataStore.user.address);
}); });
@ -180,12 +155,12 @@ export class UserService{
getOwner(address: string) { getOwner(address: string) {
console.log('getOwner', address); console.log('getOwner', address);
const ownParams = new HttpParams().append('address', address); const ownParams = new HttpParams().append('address', address);
let obs = this.http.get<{message:string, owner: any}>(this.beUrl+'api/getowner', { headers: this.reqHeaders, params: ownParams, observe: 'response'}); let obs = this.http.get<{message:string, owner: any}>(this.beUrl+'api/owner', { headers: this.reqHeaders, params: ownParams, observe: 'response'});
obs.subscribe((OwnerDataResponse) => { obs.subscribe((OwnerDataResponse) => {
console.log('api/getowner', OwnerDataResponse.status); console.log('api/getowner', OwnerDataResponse.status);
if (OwnerDataResponse.status == 200) { if (OwnerDataResponse.status == 200) {
this.dataStore.owner = OwnerDataResponse.body!.owner[0]; this.dataStore.owner = OwnerDataResponse.body!.owner;
//console.log('getOwner object', this.dataStore.owner); //console.log('getOwner object', this.dataStore.owner);
this._ownerUpdated.next(Object.assign({},this.dataStore).owner); this._ownerUpdated.next(Object.assign({},this.dataStore).owner);
this._paidUpdated.next(Object.assign({}, this.dataStore).owner.paid); this._paidUpdated.next(Object.assign({}, this.dataStore).owner.paid);

View file

@ -24,7 +24,6 @@ export class ViewerComponent implements OnInit {
address: '', address: '',
session: '', session: '',
blocktime: 0, blocktime: 0,
expired: false,
pin: '', pin: '',
validated: false validated: false
}; };
@ -48,7 +47,9 @@ export class ViewerComponent implements OnInit {
paid: false, paid: false,
website: '', website: '',
country: '', country: '',
zats: false zats: false,
invoices: false,
expiration: new Date(Date.now()).toISOString()
}; };
public addrUpdate: Observable<string>; public addrUpdate: Observable<string>;
public ownerUpdate: Observable<Owner>; public ownerUpdate: Observable<Owner>;
@ -109,7 +110,7 @@ export class ViewerComponent implements OnInit {
dialogRef.afterClosed().subscribe((val) => { dialogRef.afterClosed().subscribe((val) => {
if (val != null) { if (val != null) {
//console.log('Saving settings', val); //console.log('Saving settings', val);
this.userService.updateOwner(val); this.userService.addOwner(val);
this.fullnodeService.getPrice(val.currency); this.fullnodeService.getPrice(val.currency);
this.loginCheck(); this.loginCheck();
} }
@ -123,7 +124,7 @@ export class ViewerComponent implements OnInit {
this.userUpdate.subscribe((user) => { this.userUpdate.subscribe((user) => {
this.user = user; this.user = user;
//console.log('Viewer loginCheck', this.user); //console.log('Viewer loginCheck', this.user);
if (!this.owner.paid || !this.user.validated || this.user.expired) { if (!this.owner.paid || !this.user.validated) {
console.log('Log in expired!'); console.log('Log in expired!');
this.router.navigate(['/login']); this.router.navigate(['/login']);
} }