source: SMSSender/frontend/business/suffixmanager.h @ 319:1ec456878bcb

separation-frontend-backend
Last change on this file since 319:1ec456878bcb was 319:1ec456878bcb, checked in by Sämy Zehnder <saemy.zehnder@…>, 8 years ago
  • Adjusts header guards to follow common pattern based on the filename.
File size: 1.8 KB
Line 
1/*
2 smssender - A frontend for fast and easy SMS sending over different gateways.
3 Copyright (C) 2007-2014, gorrión. See http://smssender.gorrion.ch
4
5 This program is free software: you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation, either version 3 of the License, or
8 (at your option) any later version.
9
10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13 GNU General Public License for more details.
14
15 You should have received a copy of the GNU General Public License
16 along with this program.  If not, see <http://www.gnu.org/licenses/>.
17 */
18#ifndef FRONTEND_SUFFIXMANAGER_H
19#define FRONTEND_SUFFIXMANAGER_H
20
21#include <QObject>
22#include <QString>
23
24#include "common/business/imanagers.h"
25#include "common/network/snetworkreply.h"
26
27class Settings;
28
29// FIXME: Make this independent of settings manager. Add a suffix property to
30//        ISettingsManager and make it call this class for the online suffix
31//        update. Emit a signal when the suffix is fetched, so that the settings
32//        manager can react.
33class SuffixManager : public QObject {
34    Q_OBJECT
35
36public:
37    const QString URL_SUFFIX;
38
39public:
40    explicit SuffixManager(Settings *settings);
41
42public:
43    QString suffixIfEnabled() const;
44
45    QString suffix() const;
46    QString userSuffix() const;
47    void resetUserSuffix();
48    void setUserSuffix(const QString& suffix);
49
50private:
51    void _setUserSuffix(const QString& suffix);
52
53private slots:
54    void onSuffixFetched();
55
56private:
57    const QString DEFAULT_SUFFIX;
58
59    Settings * const m_settings;
60
61    QString m_onlineSuffix;
62    QString m_userSuffix;
63
64    SNetworkReply m_reply;
65};
66
67#endif /* FRONTEND_SUFFIXMANAGER_H */
Note: See TracBrowser for help on using the repository browser.