1
0
mirror of https://github.com/anope/anope.git synced 2026-07-02 01:06:39 +02:00

Compare commits

...

843 Commits

Author SHA1 Message Date
Sadie Powell e9424b529c Release 2.1.2. 2024-02-17 18:14:10 +00:00
Sadie Powell a60c796cf6 Update the config changelog. 2024-02-17 18:13:30 +00:00
Sadie Powell fcf16ab20a Merge branch '2.0' into 2.1. 2024-02-11 21:35:31 +00:00
Sadie Powell 8e3be20387 Update the Windows dependencies. 2024-02-11 21:34:00 +00:00
Sadie Powell 689dd44d3b Add a GitHub security policy. 2024-02-11 21:32:23 +00:00
Sadie Powell a25d0aa60e Update the changelog. 2024-02-11 21:14:59 +00:00
Sadie Powell c50d1dc2b5 Remove some outdated development docs. 2024-02-11 21:08:17 +00:00
Sadie Powell 274bb19d03 Switch Thread to use the C++11 equivalent, remove win32/pthread. 2024-02-11 20:35:21 +00:00
Sadie Powell 2c5b84bd1d Replace Condition and Mutex with the C++11 standard equivalents. 2024-02-11 19:53:05 +00:00
Sadie Powell 5c50bcb9c7 Remove the time_t parameter from Tick and TickTimers.
Most uses of Tick do not use the parameter and even when it is used
it is always the same as CurTime.
2024-02-11 18:18:18 +00:00
Sadie Powell cef56abea4 Consistently use time_t for the timer duration. 2024-02-11 18:10:38 +00:00
Sadie Powell 30b9f12711 Remove the now parameter from the Timer class.
This was never actually changed from the default.
2024-02-11 17:56:35 +00:00
Sadie Powell c9e0245f23 Revert "Document ns_no_expire nick default".
This reverts commit 9c9df2ad1f.

Closes #350.
2024-02-11 16:22:01 +00:00
Robby 5337326cc9 Update the dutch language file. 2024-01-31 06:17:01 +01:00
Robby 73d8c85879 Update the dutch language file. 2024-01-31 06:17:00 +01:00
Robby 6237245ab7 Remove an extraneous space in cs_xop, part 2. 2024-01-31 03:20:35 +01:00
Robby 7ae20c2a6d Remove an extraneous space in cs_xop. 2024-01-31 03:08:54 +01:00
Robby ae1829e5a8 Fix a typo in the PASSWORD_TOO_SHORT text string. 2024-01-30 19:15:19 +01:00
Sadie Powell 026661c9a2 Fix irc2sql and webcpanel not being put into the modules folder. 2024-01-30 14:53:08 +00:00
Sadie Powell ec7223ace2 Convert map/multimap/hash_map to an alias template. 2024-01-30 14:29:17 +00:00
Sadie Powell 1f31621bbf Remove various references to old versions. 2024-01-30 14:01:07 +00:00
Sadie Powell dfd41b9b94 Fix Clang and GCC disagreeing about whether a move is needed. 2024-01-24 16:12:29 +00:00
Sadie Powell fdd4aade3b Add a CI workflow for Alpine. 2024-01-24 15:14:21 +00:00
Sadie Powell 0a53f4c26e Merge branch '2.0' into 2.1. 2024-01-24 14:48:53 +00:00
Sadie Powell d6a826a09c Backport CI changes from the 2.1 branch. 2024-01-24 14:45:57 +00:00
Sadie Powell 484160eb4e Shuffle modules around a bit. 2024-01-24 12:34:34 +00:00
Sadie Powell 7ac1fe5847 Rename several modules to remove the m_ prefix. 2024-01-24 12:22:51 +00:00
Sadie Powell 72acef4e15 Mark types that have no inheritors as final. 2024-01-23 16:53:06 +00:00
Sadie Powell a6a0f6c447 Improve the layout of types that inherit from another type. 2024-01-23 15:28:23 +00:00
Sadie Powell 398d674cf4 Fix some CoreExport types that should be DllExport. 2024-01-23 14:06:46 +00:00
Sadie Powell 1467de1c7e Mark all exception types as CoreExport.
From the GCC docs:

>Exception catching of a user defined type in a binary other than
>the one which threw the exception requires a typeinfo lookup.

Closes #335.
2024-01-22 20:06:57 +00:00
Sadie Powell c5023fdfa0 Update the Turkish translation for the changes in 2.1 git.
Co-authored-by: CaPa CuL <capacul@gmail.com>
2024-01-22 19:52:06 +00:00
Sadie Powell 97782248af Merge branch '2.0' into 2.1. 2024-01-22 18:35:12 +00:00
Sadie Powell 016761776b Add a new Turkish translation contributed by CaPa CuL.
Co-authored-by: CaPa CuL <capacul@gmail.com>
2024-01-22 16:29:20 +00:00
Victor Coss c2450eabab Fix typo 2024-01-22 00:38:23 +00:00
Sadie Powell d6ced86021 Fix some module names that were missed in commit 4056af00e3. 2024-01-11 17:13:14 +00:00
Sadie Powell 0d8d1675f7 Fix an oversight in build_subdir. 2024-01-10 17:49:02 +00:00
Sadie Powell 4056af00e3 Parse InspIRCd module names in a way which is 1206 compatible. 2024-01-10 17:47:27 +00:00
Sadie Powell 99b4305573 Add a wrapper for std::string::compare to Anope::string. 2024-01-10 17:07:17 +00:00
Sadie Powell 113301dbba Update the changelogs. 2024-01-09 21:25:44 +00:00
Sadie Powell 349ae043b6 Always build the stats modules.
These have no external dependencies so it makes no sense to not
always build them.
2024-01-09 21:25:44 +00:00
Sadie Powell 710e7dd3a2 Bump the minimum OpenSSL version to 1.1. 2024-01-09 21:25:44 +00:00
Sadie Powell 1e9c6d7931 Always disable SSLv3 support, allow disabling TLSv1.[012]. 2024-01-09 21:25:44 +00:00
Sadie Powell 5772b924cc Drop support for ancient versions of GnuTLS. 2024-01-09 21:25:44 +00:00
Sadie Powell fce5f4cc0f Update the default SSL filenames to use the Certbot names. 2024-01-09 21:25:44 +00:00
Sadie Powell fa7ad6b3df Use native file extensions on macOS and Windows. 2024-01-09 14:35:49 +00:00
Sadie Powell fc2df00cfc Put modules into their own folder on Windows. 2024-01-09 13:57:32 +00:00
Sadie Powell f92c5471c2 Add a string overload of Channel::Kick. 2024-01-08 14:37:50 +00:00
Sadie Powell 0439e3b21b Add a string overload of User::SetModes. 2024-01-08 14:14:57 +00:00
Sadie Powell 5b23fae8bf Add a string overload of Channel::SetModes. 2024-01-08 14:14:37 +00:00
Sadie Powell aac4b0f0a3 Bump the up to date languages for the recent format changes. 2024-01-08 13:47:39 +00:00
Sadie Powell f083795c79 Fix various format string issues. 2024-01-08 13:11:50 +00:00
Sadie Powell 5db79c1e24 Add a non-formatting overload of User::SetModesInternal. 2024-01-08 13:11:50 +00:00
Sadie Powell a4dddfd5f1 Mark format strings with the GNU printf attribute. 2024-01-08 13:11:50 +00:00
Valentin Lorentz 7ddc865cde fr_FR: Generalize gender-neutral grammar
'(e)' and 'le/la' were used in a few places, I generalized them to all
strings referring to people.

I also made role names gender-neutral using contraction (eg. "fondateur"
-> "fondateurice"), and adapted specifiers accordingly.
2024-01-06 23:22:10 +00:00
Sadie Powell 688ecf1c1d Fix an oversight in the mysql module. 2024-01-06 23:19:18 +00:00
Sadie Powell c0453cfec1 Fix a sign conversion issue in the mysql module. 2024-01-06 13:39:03 +00:00
Sadie Powell a9ab0c72a6 Use auto in places where the type is unambiguous. 2024-01-06 13:23:37 +00:00
Robert Scheck de918ef9cf Add missing whitespace in multi-line comment 2024-01-06 12:41:31 +00:00
Sadie Powell 0ee9874112 Update translations for the recent services case fix. 2024-01-05 21:44:08 +00:00
Val Lorentz 388858aee6 Fix inconsistent capitalization of 'services'. 2024-01-05 21:34:26 +00:00
Sadie Powell f22703df59 Fix a translation string and enable translations on CI. 2024-01-05 21:28:54 +00:00
Val Lorentz 4715b76dbe fr_FR: msgmerge + update fuzzy strings. 2024-01-05 21:21:43 +00:00
Sadie Powell 50bd385ccf Add an alias for chanserv/status for the name used by Atheme.
Closes #336.
2024-01-05 21:21:17 +00:00
Sadie Powell e738da9b11 Merge branch '2.0' into 2.1. 2024-01-05 19:52:56 +00:00
Val Lorentz 6e6e053384 fr_FR: Update fuzzy strings 2024-01-05 19:49:56 +00:00
Valentin Lorentz 5edf19d230 fr_FR: Fix trailing spaces 2024-01-05 19:00:19 +00:00
Sadie Powell 4573e1925d Use normal exit codes when exiting the process. 2024-01-05 12:00:28 +00:00
Sadie Powell a40f8e0b9d Update the copyright headers for 2024. 2024-01-04 22:25:48 +00:00
Sadie Powell 9db49ec790 Bump for 2.1.2-git. 2024-01-04 17:55:44 +00:00
Sadie Powell e8cd2909a5 Release 2.1.1. 2024-01-04 17:54:06 +00:00
Sadie Powell e7a57aa754 Update the changelog. 2024-01-04 17:53:05 +00:00
Sadie Powell 1c30f69bd0 Fix a typo in GetCommandLineArgument. 2024-01-04 17:52:30 +00:00
Sadie Powell eb2aaf22ed Fix a copy/paste error in the default channel settings. 2024-01-01 17:32:37 +00:00
k4be 36c43683e5 Remove unused strings from pl_PL 2023-12-27 15:06:30 +00:00
k4be 0b63a4244d Update pl_PL translation for 2.1 2023-12-27 15:06:30 +00:00
Sadie Powell 4a62259695 Move privilege descriptions to the example configs. 2023-12-22 15:58:28 +00:00
Sadie Powell 87e3d5a045 Remove an extraneous space in cs_xop. 2023-12-21 01:27:34 +00:00
Dragone2 2b8384bb39 Updates Italian translations for Anope 2.1 2023-12-21 00:47:47 +00:00
Sadie Powell 6d981960da Merge branch '2.0' into 2.1. 2023-12-20 00:07:51 +00:00
Sadie Powell aca9d30064 Tweak the issue templates slightly. 2023-12-19 21:21:39 +00:00
Sadie Powell b84b1d8166 Misc grammar fixes. 2023-12-17 19:32:45 +00:00
Sadie Powell 6acbd326f3 Add the regex_stdlib regular expression engine.
Unlike other regular expression engines this is available on all
systems.
2023-12-17 15:00:26 +00:00
Sadie Powell cb533b63ac Merge branch '2.0' into 2.1. 2023-12-17 14:33:44 +00:00
Sadie Powell 6538641e87 Remove some unnecessary spaces that break editor indentation. 2023-12-17 13:59:49 +00:00
Sadie Powell eb0e5c89b2 Remove the m_regex_pcre module.
Users should migrate to m_regex_pcre2 instead.
2023-12-17 13:46:34 +00:00
Mingjie Shen 8e2fa4acdb messages: fix incorrect format specifier
Calling a printf-like function with the wrong type of arguments causes
unpredictable behavior.

Signed-off-by: Mingjie Shen <shen497@purdue.edu>
2023-12-08 17:16:53 +00:00
Sadie Powell 84c2f8d3fc Skip checking for chgrp/chmod on Windows. 2023-12-07 15:59:19 +00:00
Dragone2 8d99b3e2d7 Clean-ups old strings 2023-12-05 16:52:02 +00:00
Dragone2 b3ec2a5463 Adds new Italian translations 2023-12-05 16:52:02 +00:00
Sadie Powell 4c67f4393f Update the en_US translation. 2023-12-04 18:49:57 +00:00
Sadie Powell 4e9a2df827 Add the UNBANME privilege to allow users to unban themselves.
This is separate from the existing UNBAN privilege which applies
to all users.

Closes #331.
2023-11-30 14:38:20 +00:00
Sadie Powell 2d2d1972e9 Fix some modules that weren't converted to the new socket ctor.
Closes #330.
2023-11-26 13:26:38 +00:00
PeGaSuS cc9e2c1260 Fix missing end of comment 2023-11-24 21:04:05 +00:00
Sadie Powell 2b21264fb0 Bump for 2.1.1-git. 2023-11-24 13:37:11 +00:00
Sadie Powell 3f61b52db3 Release 2.1.0. 2023-11-24 13:33:10 +00:00
Sadie Powell f5fa4ff0e9 Remove the 1.9 and 2.0 changes from the change log. 2023-11-24 13:29:15 +00:00
Sadie Powell 251551c8c3 Update the change logs. 2023-11-24 13:29:11 +00:00
Sadie Powell e2d546ad46 Add a note about how to send emails on Windows. 2023-11-24 13:24:42 +00:00
Sadie Powell 949176c3e0 Merge branch '2.0' into 2.1. 2023-11-24 13:04:00 +00:00
Sadie Powell 3371941be5 Allow users to opt-out of being added to channel access lists. 2023-11-23 15:10:03 +00:00
Sadie Powell 70d72b62df Avoid needing to cast CurrentUplink by changing it to a size_t. 2023-11-16 21:49:48 +00:00
Sadie Powell c3e95d8e2e Fix chanserv/suspend info not being visible to regular users.
Closes #325.
2023-11-16 19:54:23 +00:00
Sadie Powell 46209895e3 Merge branch '2.0' into 2.1. 2023-11-16 19:34:37 +00:00
Sadie Powell ba163027bd Make the SASL PLAIN implementation more robust.
- Reject auth attempts that try to authenticate using an alternate
  authorization identity.

- Reject auth attempts that contain extraneous null bytes in the
  string as required by the SASL PLAIN RFC.

- General code quality cleanup.
2023-11-16 18:14:15 +00:00
Sadie Powell b28180d680 Implement support for the ANONYMOUS SASL mechanism. 2023-11-14 15:02:04 +00:00
Sadie Powell 0f1f0c5a22 Deduplicate account sending code in the inspircd module. 2023-11-14 13:53:45 +00:00
Sadie Powell 6e16e71fda Remove the two day X-line cap. 2023-11-03 11:01:01 +00:00
Sadie Powell 1eba69d035 Fix a missing override keyword. 2023-10-24 18:10:32 +01:00
Sadie Powell eb409fc6eb When changing the nick of a user on inspircd3 send the expected ts.
This should prevent users being renicked if they changed their nick
between services sending the renick and the IRCd receiving it.
2023-10-24 18:00:34 +01:00
Sadie Powell 97fa6d84bc Fix confirming an unconfirmed operator's account. 2023-10-22 23:31:48 +01:00
Sadie Powell 02940e4ea8 Fix a misleading temporary variable in ns_register. 2023-10-20 18:10:29 +01:00
Sadie Powell 38d5b93e4a Add support for server-initiated logins and logouts on UnrealIRCd. 2023-10-19 23:22:31 +01:00
Sadie Powell 78398a4481 Add support for server-initiated logouts on InspIRCd. 2023-10-19 22:52:05 +01:00
Sadie Powell 69a0f3bec2 Fix removing entries by an alias in chanserv/access and chanserv/xop. 2023-10-12 19:09:44 +01:00
Sadie Powell 0f32d2e553 Use a more human readable datetime format. 2023-10-12 14:41:07 +01:00
Sadie Powell 8e1c7e1e44 Merge branch '2.0' into 2.1. 2023-10-11 15:51:52 +01:00
Sadie Powell a3241065c5 Start migrating to range-based for loops. 2023-10-11 15:51:52 +01:00
Dragone2 6119586920 Small fixes and improvements to Italian translation. 2023-10-04 17:14:39 +01:00
dependabot[bot] 32cf99fdb5 Bump actions/checkout from 3 to 4
Bumps [actions/checkout](https://github.com/actions/checkout) from 3 to 4.
- [Release notes](https://github.com/actions/checkout/releases)
- [Changelog](https://github.com/actions/checkout/blob/main/CHANGELOG.md)
- [Commits](https://github.com/actions/checkout/compare/v3...v4)

---
updated-dependencies:
- dependency-name: actions/checkout
  dependency-type: direct:production
  update-type: version-update:semver-major
...

Signed-off-by: dependabot[bot] <support@github.com>
2023-10-01 17:20:09 +01:00
Sadie Powell dc371aad6d Re-add the GHOST and REGAIN commands for compatibility.
These are hidden so they won't be shown in the help.
2023-09-26 12:39:30 +01:00
Sadie Powell ca2209aaed Show the SQL service name in the db_sql error message.
This should help users diagnose issues easier.
2023-09-05 00:21:31 +01:00
Sadie Powell 0a3ddef315 Replace Twitter with Mastodon in the ns_set_misc example config.
Closes #320.
2023-08-31 07:19:00 +01:00
Sadie Powell adf820c08a Merge branch 2.0 into 2.1. 2023-08-06 13:36:27 +01:00
Sadie Powell 0715db7182 Mark as 2.0.15-git. 2023-08-06 13:00:09 +01:00
Sadie Powell 8bf14ad5ea Release 2.0.14. 2023-08-06 12:58:38 +01:00
Sadie Powell c9f21f4ef6 Update the changelogs. 2023-08-06 12:57:26 +01:00
Sadie Powell 1b2eb9b9c8 Fix the pull request template to be more relevant to Anope. 2023-07-30 12:41:21 +01:00
Sadie Powell 1343be58d7 Add some templates for people filing issues on GitHub. 2023-07-30 12:15:20 +01:00
Sadie Powell 377ba87d52 Remove broken support for MinGW.
This apparently doesn't work and is pointless given we have native
Windows builds now anyway.
2023-07-29 10:01:18 +01:00
Sadie Powell 97f6aadd5b Fix paging the Config header on some util-linux revisions.
We use an environment variable here as passing -e directly may
result in an error on older `more` releases.
2023-07-28 23:56:09 +01:00
Sadie Powell 2dafc85af4 Remove references to the ilm which never got updated from 1.8. 2023-07-16 18:25:21 +01:00
Sadie Powell 7f8a0c9d33 Allow Anope to look up multiple DNS results.
For fixing bug 1756.
2023-07-11 16:11:57 +01:00
Sadie Powell cc23f6dc01 Fix sending log messages from a renamed pseudoclient.
If a command is named e.g. nickserv/wibble it previously tried to
look up the nickserv service and if this service didn't exist then
it would fall back to sending from the first available service. This
caused problems if the NickServ service had been renamed to something
else.

Reported by @AndrioCelos on IRC.
2023-07-11 15:13:17 +01:00
Sadie Powell aa619f1eeb Merge branch '2.0' into 2.1. 2023-07-11 12:28:54 +01:00
Sadie Powell b7458c5da1 Allow access list entries to have a description.
This is useful when adding glob matches to the access list as a
reminder of who they actually match.

Resolves https://bugs.anope.org/view.php?id=1613
2023-07-11 12:19:47 +01:00
PeGaSuS e717ac0a89 Clarify that operserv/sqline can also match channel names. 2023-07-09 23:44:02 +01:00
Sadie Powell 34ab54522e Fix not serialising dontkickops/dontkickvoices properly. 2023-07-09 23:09:11 +01:00
Sadie Powell 47bbc9b3fb Enable CanSQLineChannel in unreal4.
Ref: https://www.unrealircd.org/docs/Server_protocol:SQLINE_command
2023-07-09 22:32:43 +01:00
Sadie Powell 68b51c7481 Fix not getting memo notifications when using SASL. 2023-07-09 22:32:43 +01:00
Sadie Powell 37b60f8d9d Update links to the bugtracker. 2023-07-09 20:06:32 +01:00
Sadie Powell 14204353ac Allow customising the email content type.
This will allow people to send emails using HTML or non UTF-8 text.
2023-07-09 14:39:51 +01:00
Sadie Powell 098f19c005 Fix a crash when a module tries to get another module's config. 2023-07-06 10:53:25 +01:00
PeGaSuS 4e1f5cce80 Tell users that they must identify to their account before using CONFIRM.
This only happens when a nickname is registered via webcpanel and said nickname is online.
2023-07-05 17:09:47 +01:00
Sadie Powell 4a6f4bc92f Pull in the upstream changes from InspIRCd's vendoring tool. 2023-06-20 01:06:35 +01:00
Sadie Powell da2ac3e8a2 Fix detection of the nopartmsg module in the InspIRCd proto modules. 2023-06-20 01:00:37 +01:00
Sadie Powell 7c7158cf24 Terminate lines with CR+LF instead of just LF when sending an email.
From https://www.rfc-editor.org/rfc/rfc5321#section-2.3.1:

> Lines consist of zero or more data characters terminated by the
> sequence ASCII character "CR" (hex value 0D) followed immediately by
> ASCII character "LF" (hex value 0A).
2023-06-06 16:48:47 +01:00
Sadie Powell 1c30205af5 Also build the Windows dependencies in the CI. 2023-06-03 22:02:49 +01:00
Sadie Powell 9d0a6ddc67 Merge branch '2.0' into 2.1. 2023-06-03 21:51:07 +01:00
Adam fbf3b34474 add gettext to conan deps 2023-06-02 23:01:27 -04:00
Adam ce42810265 m_ldap: use Wldap on windows 2023-06-02 21:31:12 -04:00
Adam 07babdbd77 use Conan for extra's dependencies on Windows
conan install src\win32\conanfile.txt --build=missing
cmake -B build .
cmake --build build --config Release --target PACKAGE
2023-06-02 19:08:55 -04:00
Sadie Powell fe3926f572 Mark as 2.0.14-git. 2023-06-01 23:12:08 +01:00
Sadie Powell 03eead042c Release 2.0.13. 2023-06-01 23:12:07 +01:00
Sadie Powell b1fff640dd Update the changelogs. 2023-05-30 16:07:54 +01:00
Dragone2 f251ca6373 Small fixes to the Italian translation. 2023-05-29 21:33:59 +01:00
Adam 24a2c51003 CMakeLists.txt: remove -fno-delete-null-pointer-checks 2023-05-28 21:26:03 -04:00
Adam 66f37139cb regchannels: remove dependency on no-delete-null-pointer-checks 2023-05-28 21:26:03 -04:00
Adam 0646547c9e config: remove dependency on no-delete-null-pointer-checks 2023-05-28 21:25:59 -04:00
Sadie Powell 41206b991e Fix not being able to log into oper accounts when DNS fails. 2023-05-11 13:05:39 +01:00
Sadie Powell b7abfe5eca Avoid returning null when a config tag does not exist.
This invokes undefined behaviour on modern compilers.
2023-05-04 19:21:02 +01:00
Hendrik Jäger 23e7f5bd33 update: german translation 2023-04-21 22:30:18 +01:00
Dragone2 df9dfeae95 Update the Italian translation.
Ref: #309
2023-04-04 16:59:59 +01:00
Sadie Powell 29db25dac7 Fix missing override keywords. 2023-03-13 13:52:56 +00:00
Sadie Powell d210cd2695 Modernize finding system tools and remove checks for unused tools. 2023-03-13 13:52:56 +00:00
Sadie Powell fc8e6ee338 Document the protocol module changes from a while ago. 2023-03-13 01:44:37 +00:00
henk84 e68a41a91e Make language/update.sh safer, faster, cleaner.
Ref: #308

Co-authored-by: Hendrik Jäger <gitcommit@henk.geekmail.org>
2023-03-06 12:01:46 +00:00
henk84 26f846e112 Document how to update a translation.
Ref: #307

Co-authored-by: Hendrik Jäger <gitcommit@henk.geekmail.org>
2023-02-26 23:09:30 +00:00
henk84 f1fbe9e629 Update some german translations.
Ref: #306

Co-authored-by: Hendrik Jäger <gitcommit@henk.geekmail.org>
2023-02-26 23:05:28 +00:00
Sadie Powell ebe3fd7e57 Merge branch '2.0' into 2.1. 2023-02-19 11:21:58 +00:00
Sadie Powell 1c9b34190e Update the en_US translation. 2023-02-19 11:14:37 +00:00
Sadie Powell a5d4aa5821 Remove line numbers from the translation files.
The translations are updated so infrequently that these always
change a bunch and it makes reading the diffs really hard.
2023-02-19 11:12:37 +00:00
Hendrik Jäger 9b583961b0 Update german translation 2023-02-18 21:48:53 +00:00
Bram Matthys fef0cc1c29 unreal4: set vhost/vident during SASL 2023-02-09 16:05:50 +00:00
Sadie Powell f0ad0b4f0a Raise the default session limit from 3 to 5. 2023-02-06 17:12:35 +00:00
Sadie Powell dc1d9c837b Fix crashing when encountering an unterminated commented block. 2023-02-06 17:10:29 +00:00
Sadie Powell 885462d98e Merge branch '2.0' into 2.1. 2022-12-31 22:11:19 +00:00
Sadie Powell 33a337dfc0 Update the copyright headers for 2023. 2022-12-31 22:08:50 +00:00
Sadie Powell b64dc09bd2 Fix marking services pseudoclients as an oper on InspIRCd.
The bot user needs to be marked as introduced in order to send an
oper type.
2022-12-31 21:55:05 +00:00
Sadie Powell 6395107be6 Fix getting the port on non-UNIX socket listeners. 2022-12-27 10:21:40 +00:00
Sadie Powell 24b881c427 Update MODULE_INIT for modern MSVC+ versions. 2022-12-23 15:09:12 +00:00
Sadie Powell 28be881886 Backport anopesmtp removal from the master branch. 2022-12-23 14:21:34 +00:00
Sadie Powell 5bc560a743 Remove some unnecessary dependencies on the Linux CI. 2022-12-23 14:10:33 +00:00
Sadie Powell fee60c8e06 The fantasy:name field is allowed to contain spaces. 2022-12-18 10:36:59 +00:00
Sadie Powell 3f867c1e11 Show the invalid config value in the rejection message. 2022-12-18 10:35:11 +00:00
Sadie Powell b235da2e9c Merge branch '2.0' into 2.1. 2022-12-17 16:18:09 +00:00
Sadie Powell 3f3062a077 Use <filesystem> instead of opendir/readdir/closedir. 2022-12-17 16:03:28 +00:00
dependabot[bot] 2f46739931 Bump actions/checkout from 2 to 3
Bumps [actions/checkout](https://github.com/actions/checkout) from 2 to 3.
- [Release notes](https://github.com/actions/checkout/releases)
- [Changelog](https://github.com/actions/checkout/blob/main/CHANGELOG.md)
- [Commits](https://github.com/actions/checkout/compare/v2...v3)

---
updated-dependencies:
- dependency-name: actions/checkout
  dependency-type: direct:production
  update-type: version-update:semver-major
...

Signed-off-by: dependabot[bot] <support@github.com>
2022-12-17 15:59:28 +00:00
Sadie Powell 6eec018c34 Allow Dependabot to keep our GitHub CI up to date. 2022-12-17 15:57:37 +00:00
Sadie Powell 8a8fb7725b Use the native versions of inet_ntop/inet_pton on Windows. 2022-12-17 12:40:58 +00:00
Sadie Powell f6e5e6a2b4 Add sockaddrs::str to stringify a sockaddrs properly.
Also clean up the socket code slightly.
2022-12-17 12:39:48 +00:00
Sadie Powell dfdcd3021a Add support for linking over UNIX sockets. 2022-12-17 11:50:38 +00:00
Sadie Powell 5fa3d8f929 Use emplace() instead of insert(std::make_pair()). 2022-12-09 16:50:29 +00:00
Sadie Powell e78db21180 Mark as 2.0.13-git. 2022-12-09 08:33:02 +00:00
Sadie Powell d4d2a4b4ce Release 2.0.12. 2022-12-09 08:30:43 +00:00
Sadie Powell e33b8d5f43 Update the changelogs. 2022-12-09 08:28:57 +00:00
PeGaSuS c2b154e1b1 Document cs_no_expire (#301). 2022-12-08 07:16:04 +00:00
Sadie Powell 1a2da82106 Merge branch '2.0' into 2.1. 2022-12-07 15:59:46 +00:00
Sadie Powell 4a2861ba3d Add a module that provides regex/pcre using PCRE2. 2022-12-07 15:43:39 +00:00
Sadie Powell 9d92de1157 Import InspIRCd's vendoring tool and use it to vendor crypt_blowfish. 2022-10-22 20:08:30 +01:00
miwob 211bd80061 Update ircd-hybrid protocol module
* Add METADATA command handler which currently only allows to modify a client's certificate fingerprint
* Minor reformatting and style inconsistency fixes
2022-09-29 13:05:05 +01:00
Austin Ellis 32679a107a Add the ability to confirm accounts via webcpanel after logging in. 2022-09-22 17:38:07 +01:00
Sadie Powell 1664689eb7 Merge branch '2.0' into 2.1. 2022-09-15 18:46:51 +01:00
miwob bc101d10de Update hybrid protocol module to improve compatibility with the latest ircd-hybrid release.
* Remove support for deprecated channel mode `u`
* Add support for channel mode `N`
* Fixed the `UID` message handler requiring the correct amount of arguments
* Fixed the `SID` message handler requiring the correct amount of arguments
* Fixed the `SJOIN` message handler requiring the correct amount of arguments
* Minor documentation updates and style corrections
* Remove pointless return statement in the `JOIN` message handler
* Add support for the owner and admin channel prefix modes
* Add support for `MLOCK`
* Fixed SendChannel() so modes are prefixed with a `+`
* Change SendJoin() to actually use the mode stacker
* Add support for channel mode `Q`
* Add support for channel mode `Z`
* Add support for user mode `B` and `Z`
* Actually user mode `g` is not oper only. For some reason this mode got set to oper only in anope/anope@1e625b6
* Work properly with extended bans, e.g. don't normalize masks starting with a `$`
2022-09-15 14:13:24 +01:00
Sadie Powell 901a456132 Fix allowing spaces in some config fields that shouldn't contain them. 2022-09-12 17:56:45 +01:00
Sadie Powell 0c61915e31 Bahamut now has support for halfops. 2022-09-12 17:56:45 +01:00
Dragone2 d5e85c7f25 Fixe a typo in the Italian translation.
Ref: #298
2022-08-10 19:40:42 +01:00
Michael Stapelberg a5425e3bf3 database: write to temporary file and rename.
This decreases the likelihood of ending up with a zero-byte (or missing)
anope.db.

Co-authored-by: Michael Stapelberg <michael@robustirc.net>
2022-07-27 17:40:49 +01:00
Sadie Powell b96519d85c Build the installer package on Windows CI. 2022-05-01 10:28:18 +01:00
Sadie Powell ac98ed615b Merge branch '2.0' into 2.1. 2022-04-22 10:34:04 +01:00
Sadie Powell 2062eb23f0 Release 2.0.11. 2022-04-22 10:17:19 +01:00
Sadie Powell af4d7d21ba Update the changelogs. 2022-04-21 17:48:54 +01:00
Sadie Powell c2ba553483 Remove unnecessary ProcessModes call in unreal4.
This was made obsolete by the previous commit.
2022-04-11 15:34:37 +01:00
Sadie Powell f2bcf449cd Use windows-2019 for Windows builds. 2022-03-01 05:21:28 +00:00
Sadie Powell 09c587bed0 Remove TR1 compatibility layer.
This isn't necessary now we use C++17.
2022-03-01 05:09:29 +00:00
Sadie Powell a8724b5f03 Use noexcept instead of an empty exception specifier. 2022-03-01 05:06:19 +00:00
PeGaSuS 8dd1fb8ac2 Fix unsetting vhosts on unreal4 (#289). 2022-02-13 14:30:09 +00:00
Sadie Powell b7e85f5161 Default synconset and syncongroup to on. 2022-02-05 23:11:39 +00:00
Sadie Powell 773ed39d5d Merge branch '2.0' into 2.1. 2022-02-05 23:10:42 +00:00
Sadie Powell b5fe380011 Include the required modules in the example InspIRCd config. 2022-01-29 13:33:19 +00:00
Sadie Powell af7bf785f9 Fix a grammar error in nickserv.example.conf. 2022-01-29 13:31:04 +00:00
Sadie Powell 15d51ff033 Document the sysconf header file. 2022-01-13 13:46:29 +00:00
Sadie Powell 83bf5ba255 Remove checks for obsolete Windows SDK versions.
We can't build against these anyway now as they're too old.
2022-01-13 03:22:12 +00:00
Sadie Powell 2881ba112b Clean up the predefined variables on Windows.
- Use _MSC_VER for detecting MSVC instead of a custom define.
- Remove MINGW as you can use __MINGW32__ to detect this.
- Stop defining _WIN32 as this will always be defined on Windows.
2022-01-13 02:35:23 +00:00
Sadie Powell 1ee81580c6 Add support for Windows CI. 2022-01-13 01:59:13 +00:00
Sadie Powell 4f421db5a9 Fix checking whether localisation is enabled. 2022-01-13 01:59:13 +00:00
Sadie Powell 091c0eea28 Rip out check_functions().
This isn't actually used anywhere and just slows down the build.
2022-01-13 01:42:46 +00:00
Sadie Powell eaaabd8de0 Rip out calculate_depends().
This code is incredibly error prone and it just duplicates behaviour
that CMake already implements with depend.make files.
2022-01-13 01:42:38 +00:00
Sadie Powell 40ce51a1a9 Include cstring instead of string.h in services.h 2022-01-13 01:13:46 +00:00
Sadie Powell 23ac008cc1 Remove NO_CLIENT_LONG_LONG from the mysql module.
This is not necessary now we use C++17.
2022-01-13 01:12:05 +00:00
Sadie Powell 6486956401 Fix some methods that should have been marked as CoreExport. 2022-01-13 00:34:51 +00:00
Sadie Powell 33b42ce86e Use the default CMake modules for finding gettext instead of our own. 2022-01-12 23:05:25 +00:00
Sadie Powell a631028660 Merge branch '2.0' into 2.1. 2022-01-12 22:08:35 +00:00
Sadie Powell 04257b9d6a Replace ICQ in the ns_set_misc examples with something not dead. 2022-01-10 16:45:25 +00:00
Sadie Powell acb6c55529 Add all extra modules to the gitignore to avoid adding their symlinks. 2022-01-10 16:20:56 +00:00
Sadie Powell 0e6f8488d3 Avoid duplicate checks in irc2sql. 2022-01-10 16:20:56 +00:00
Filippo Cortigiani 56687c27cb Fix ns_resetpass not returning a response for XMLRPC (#243)
Co-authored-by: filippo nicola cortigiani <simos@H7-25.fritz.box>
2022-01-10 16:12:33 +00:00
k4bek4be 9b0c7929d9 Multiple updates for unreal4 protocol (#285)
* Parse PROTOCTL PREFIX and PROTOCTL USERMODES
* Add several previously unhandled modes
* Fix incorrect SJOIN prefix handling
* Enable message tags sending from ircd
* Add timedban matcher
* Add operclass matcher
* Store all client and channel moddata.
* Call unreal's internal unban on /cs unban
* Check for ~a:0 ban
* Add country ban matcher
* Use +B umode for services bots
2022-01-10 15:50:17 +00:00
k4bek4be d895a3aa01 Use utf-8 encoding for outgoing email (#286) 2022-01-09 19:01:45 +00:00
k4be d4632e5286 Add a "Network Service" (RPL_WHOISOPERATOR) line to WHOIS replies 2022-01-09 18:39:09 +00:00
Michael Wobst c38106211c Adjust IsIdentValid test to comply with upcoming ircd-hybrid release (#272).
hybrid.cpp: adjust IsIdentValid test to comply with upcoming ircd-hybrid where
user names may only consist of [A-Za-z0-9._-] and may not begin with '.', '-',
or '_'.

As a side effect this fixes an issue where currently it is possible to introduce
bots whose user name starts with (non-alnum) characters considered invalid for
ircd-hybrid leading to a services shutdown due to a nick introduction/kill loop.
2022-01-09 15:25:09 +00:00
Sadie Powell b8bcad048e Update the copyright headers for 2022. 2022-01-06 23:15:44 +00:00
Sadie Powell 4e5fc9797c Speed up CI by building with Ninja instead of Make. 2022-01-04 18:48:22 +00:00
Sadie Powell 9befb13ea4 Remove various entries from sysconf which are never actually used. 2022-01-04 15:05:33 +00:00
Sadie Powell 8eb6a4da71 Update more IRCServices references to reflect the current project.
- If referring to the specific piece of software use "Anope".
- If referring to services in general use "services".
2022-01-04 14:11:07 +00:00
Sadie Powell ec7dfb3675 Use C++11 header names instead of their deprecated equivalents. 2022-01-04 12:36:35 +00:00
Sadie Powell 106750db77 Replace all uses of push_back with emplace_back. 2022-01-04 12:28:55 +00:00
Sadie Powell 7d1047490e Consistently use #pragma once across all header files.
This replaces a mixture of no include guards, ANOPE_FOO_H, and FOO_H.
2022-01-04 12:10:32 +00:00
Sadie Powell c9f93eeaed Merge branch '2.0' into 2.1. 2022-01-04 00:39:34 +00:00
Sadie Powell db6b2225b1 Use GNU visibility attributes when on non-Windows.
This reduces binary sizes by several megabytes on my system.
2022-01-04 00:39:05 +00:00
Sadie Powell c6c9d9591c Remove some obsolete header and function checks. 2022-01-04 00:39:05 +00:00
Sadie Powell c1f6a79c72 Export a compilation database for debug builds. 2022-01-04 00:39:05 +00:00
Sadie Powell eb81f22a5b Modernize CXXFLAGS on Unix and enable -Werror on CI.
Also clear up warnings that this exposed.
2022-01-04 00:39:05 +00:00
Sadie Powell a31a7f5a6c Use C++11 default initializers and destructors where possible. 2022-01-04 00:17:19 +00:00
Sadie Powell 7531e90499 Use C++11 style class/struct initialisation. 2022-01-04 00:17:13 +00:00
k4be a93a7c87b6 Update pl_PL translation 2022-01-03 19:53:08 +00:00
Sadie Powell ba2c82e2f5 Fix some minor issues discovered whilst working on 2.1. 2022-01-03 19:37:33 +00:00
Sadie Powell dfcc025a19 Remove MARK_DEPRECATED as there's an attribute for this now. 2022-01-03 19:02:44 +00:00
Sadie Powell a5f7aac295 Replace anope_{final,override} with their C++11 equivalent. 2022-01-03 19:02:44 +00:00
Sadie Powell d76d747196 Require C++17 to build Anope. 2022-01-03 19:02:44 +00:00
Sadie Powell aee1e53cb3 Remove support for precompiled headers.
This might have been useful two decades ago but on recent hardware
this just makes builds take longer than without them.
2022-01-03 16:27:15 +00:00
Sadie Powell fd1ca96e2c Merge branch '2.0' into 2.1. 2022-01-03 15:50:22 +00:00
Sadie Powell 2c18601d8f Fix linking against libraries by their alternate name. 2021-12-28 21:18:22 +00:00
Sadie Powell a1a1b3ad01 Add a build time check that OpenLDAP is reentrant. 2021-12-28 19:20:23 +00:00
Robert Scheck 7a28d81b44 Reflect OpenLDAP 2.5 upstream change from libldap_r to libldap
Starting with OpenLDAP 2.5 upstream decided to merge the non-threaded
libldap_r library into the threaded libldap library. And starting with
OpenLDAP 2.6 common Linux distributions such as Fedora do not ship the
compatibility symbolic link anymore (which leads to a build failure),
thus the linking tests for libldap_r and uses alternatively libldap.

See also:
 - https://lists.openldap.org/hyperkitty/list/openldap-announce@openldap.org/thread/BH3VDPG6IYYF5L5U6LZGHHKMJY5HFA3L/
 - https://bugzilla.redhat.com/show_bug.cgi?id=2032707
2021-12-28 19:20:03 +00:00
Sadie Powell 69dbcba069 Allow specifying multiple dependency libraries like foo|bar. 2021-12-28 18:53:24 +00:00
Hendrik Jäger 66bf55fb7f Fix missing spaces in de_DE 2021-12-23 22:10:27 +00:00
Sadie Powell 002186c016 Document log files having their creation date appended. 2021-12-23 22:08:36 +00:00
Sadie Powell 6a7488edc1 Remove double escaping in CMake regex matching.
This is not needed now we use regex matching directly instead of
via the CMake 2.4 function wrapper.

Fixes building extra modules.
2021-12-14 11:11:22 +00:00
Sadie Powell 4af8dfa549 Update the min version of CMake mentioned in the Config script. 2021-12-14 10:10:03 +00:00
Sadie Powell 4efc2c219b Send mode changes from ChanServ if the channel is not registered.
Avoids calling WhoSends() on a null pointer.
2021-12-03 07:11:37 +00:00
Sadie Powell 84ec0903ee Fix checking if this is null in regchannel.
I can't see any places this might be called on a null pointer.
2021-12-02 10:23:05 +00:00
Sadie Powell 754c82d047 Remove undefined behaviour around checking if this is null. 2021-11-30 11:04:19 +00:00
Sadie Powell 17fa704278 CMake warnings CMP0003 and CMP0007 are not necessary. 2021-11-30 10:11:17 +00:00
Sadie Powell b9ccd4bb0b Fix cmake deprecation warning CMP0026. 2021-11-30 10:03:10 +00:00
Sadie Powell 595bc09ec1 Merge branch '2.0' into 2.1. 2021-11-30 09:50:33 +00:00
Sadie Powell 64f65b035e Fix some message params being sent as <middle> instead of <trailing>. 2021-11-20 19:54:56 +00:00
Sadie Powell b6f1c86f65 Use example.com instead of localhost.net in the example configs. 2021-11-14 20:45:17 +00:00
Sadie Powell a736b54ef1 Use the server name as the enforcer hostname if not otherwise set. 2021-11-14 20:45:01 +00:00
Austin Ellis 8b8bc97194 Fix the grammar of the globaloncycledown message (#279).
The previous default example (which is in use on many Anope networks) refers to Services in 2nd person, then 1st person - in the same sentence.
2021-11-14 00:42:09 +00:00
Sadie Powell 27cff11e31 Increase the default channel expiry to 30 days. 2021-10-17 19:46:29 +01:00
Sadie Powell b7da27ad3a Increase the default nickname expiry to 90 days. 2021-10-17 19:44:05 +01:00
Sadie Powell aa0adcf99b Show the protocol module name when connecting to the uplink. 2021-10-06 20:58:57 +01:00
Sadie Powell 079fb1b66f Mark as 2.0.11-git. 2021-08-29 20:02:49 +01:00
Sadie Powell 1cab1d32c2 Send the oper mode for services pseudoclients on InspIRCd. 2021-08-29 18:37:12 +01:00
Sadie Powell e5075d2dc2 Merge branch '2.0' into 2.1 2021-08-28 19:53:17 +01:00
Matthew Beeching 98fdce2e1d Update Jobe's email address in the readme. 2021-08-25 20:33:11 +01:00
Adam d8d1c1d18c cmake: update NSIS template for NSIS 3
Newer cmake versions require NSIS 3, which already defines a RemoveSection macro causing cpack to fail
2021-08-09 17:17:25 -04:00
Sadie Powell 48ec53242e Release 2.0.10. 2021-08-09 15:54:25 +01:00
Sadie Powell e7e8447fa3 Deduplicate code for checking if a user is securely connected. 2021-08-01 19:23:48 +01:00
Sadie Powell 561b205c4a Merge branch '2.0' into 2.1. 2021-08-01 18:53:24 +01:00
Adam 91321bdf68 webcpanel: fix command source ip to use extforward ip 2021-07-24 12:09:12 -04:00
Sadie Powell 33590aa59b Overwritten has two t's in it. 2021-06-17 18:41:23 +01:00
Josh Soref fd88b756fc Fix various spelling issues (#274).
Signed-off-by: Josh Soref <jsoref@users.noreply.github.com>.
2021-06-17 15:02:30 +01:00
Sadie Powell 8d1bc95faf Use the InspIRCd-sent maxlist size instead of networkinfo:modelistsize. 2021-06-04 02:19:54 +01:00
Sadie Powell e67c2d5632 Add support for per-mode list limits. 2021-06-04 02:12:09 +01:00
Sadie Powell 376053e0ac Allow protocol modules to declare that the IRCd supports tags.
This is not being used currently but will be soon.
2021-06-01 00:21:41 +01:00
Sadie Powell cadc6f48e6 Remove nickserv:strictpasswords as it is now obsolete. 2021-05-31 21:44:10 +01:00
Sadie Powell b6665d5eb9 Add the nickserv:minpasslen option. 2021-05-31 21:16:06 +01:00
Sadie Powell 95955ae069 Rename nickserv:passlen to nickserv:maxpasslen. 2021-05-31 21:00:43 +01:00
Sadie Powell df4313f5bb Merge branch '2.0' into 2.1. 2021-05-31 20:57:48 +01:00
Sadie Powell 3728a0bda1 Fix some misleading indentation in ns_register. 2021-05-31 20:53:29 +01:00
Sadie Powell d2da73cf68 Add the -devel switch to Config.
This makes the script use defaults that make development easier.
2021-05-26 04:13:42 +01:00
Sadie Powell 100b24074d Improve the message for NICK_IDENTIFY_REQUIRED. 2021-05-23 19:51:40 +01:00
Sadie Powell a040f17787 Use InnoDB instead of the deprecated MyISAM engine.
Ref: https://www.percona.com/blog/2016/10/11/mysql-8-0-end-myisam/
2021-04-27 23:21:07 +01:00
Sadie Powell 6274bd0b34 Use utf8mb4 instead of utf8 in chanstats and irc2sql.
The utf8 charset, confusingly, is an alias for utf8mb3 which is not
a real UTF-8 encoding as it can only store three byte characters.

The real UTF-8 charset is utf8mb4.
2021-04-27 23:18:04 +01:00
Sadie Powell 095a25d473 Add the anope_override keyword to methods that lack it. 2021-04-27 21:41:19 +01:00
Sadie Powell 53cd3f47b5 Use elseif in CMake where possible. 2021-04-27 19:20:39 +01:00
Sadie Powell c21f6eb5a3 Rip out compatibility code for now-unsupported CMake versions. 2021-04-27 19:20:36 +01:00
Sadie Powell e2aeab970b Remove the repeated conditions in cmake endif/else statements. 2021-04-27 17:49:21 +01:00
Sadie Powell ef4fd869ae Bump minimum CMake version to 3.8.
This is the minimum version that supports CMAKE_CXX_STANDARD=17.
2021-04-27 17:48:28 +01:00
Sadie Powell dfc8bd4aa2 Switch SendSVSLogin to take a NickAlias. 2021-04-27 17:31:14 +01:00
Sadie Powell fd774bd52a Remove unnecessary space. 2021-04-21 14:09:07 +01:00
Sadie Powell 16fac79b78 The last parameter of Solanum ECHO is a <trailing>. 2021-04-21 14:06:49 +01:00
Sadie Powell 622a8ea7e9 Implement support for the Solanum ECHO server capability.
https://github.com/solanum-ircd/solanum/commit/4cac091255d972b0131ffbf0cd278f984bd892d4
2021-04-21 14:05:35 +01:00
Sadie Powell c00ecc5e02 Process writes to the uplink socket before quitting in all cases.
This allows any error that might have been sent to the IRCd to
actually be sent.
2021-04-16 22:46:11 +01:00
Sadie Powell cdd9b6f11b Default to the inspircd3 protocol module instead of inspircd20. 2021-04-16 22:18:56 +01:00
Sadie Powell faee68e85f Don't enforce casemapping when using the 1202 InspIRCd protocol.
This allows older servers which use a module that provides custom
casemapping (e.g. the ascii module) to link.
2021-04-16 22:17:47 +01:00
Sadie Powell 683f42eeef Use UTC in anopesmtp to fix a C++98 compat warning. 2021-04-08 13:47:13 +01:00
Sadie Powell f83558f10b Log when freopen and chown fail. 2021-04-08 13:47:13 +01:00
Sadie Powell 0a518f4bbd Fix the syntax of Solanum identified messages. 2021-03-30 13:56:20 +01:00
PeGaSuS 9483da3239 Added Account to show the main nick of a grouped nick(s).
#270
2021-02-19 01:42:13 +00:00
Matt Schatz c67911bfcc bots: Fix dtor channel iterator being invalidated.
The call to UnAssign() erases the channel from the set which
invalidates the iterator in this loop. Handle this in the same
manner as the NickCore dtor.
2021-02-19 01:37:08 +00:00
Sadie Powell 3f6e694e50 Send the appropriate messages for Solanum's IDENTIFIED feature. 2021-02-19 01:08:08 +00:00
Sadie Powell c2646d67bb Replace the Charybdis protocol module with Solanum (its successor). 2021-02-19 00:33:27 +00:00
Sadie Powell c68b81eac8 Merge branch '2.0' into 2.1. 2021-02-18 23:59:28 +00:00
Adam 4d271e0210 cs_access: require accounts to be confirmed for level 0 access 2021-01-31 12:05:25 -05:00
Robby c5a4e8337c Update copyright to 2021.
This was done with:
find docs/ include/ language/ modules/ src/ *.* Config -exec sed -i 's/-20.. Anope Team/-2021 Anope Team/i' {} \;
2021-01-07 03:31:08 +01:00
PeGaSuS 7e08e7cb6c Set killprotect as a default option in nickserv.example.conf. 2021-01-07 03:24:17 +01:00
Michael Hazell 4031dc7321 inspircd3: Enable support for channel SQLines (#268) 2021-01-01 19:03:23 +00:00
Robby d1e4943800 Add kill_immed as an available option to nickserv.example.conf. 2020-11-20 17:00:00 +01:00
Sadie Powell 74f18d7b1d Only grant an account an identifier when the identifier is needed. 2020-11-19 14:12:18 +00:00
Sadie Powell 3856538e48 Bump for 2.0.10-git. 2020-10-22 12:10:08 +01:00
Sadie Powell 236affa2a4 Release 2.0.9. 2020-10-22 12:08:50 +01:00
Sadie Powell f8d8104d82 Update the changelog. 2020-10-22 12:07:56 +01:00
Sadie Powell a3c7f716bd Fix the query used by IRC2SQL for updating server information. 2020-10-21 16:26:08 +01:00
Sadie Powell b2b53a1e01 Fix account identifiers conflicting with SQL row identifiers. 2020-10-21 12:20:26 +01:00
Sadie Powell 95f4e29edd Unset the account id before the account name on InspIRCd.
This avoids the id being shown on the logout event.
2020-10-12 17:47:41 +01:00
Sadie Powell cdf147f351 Fix not sending an account id to InspIRCd on SASL.
Also, send the account id first so it shows on the ACCOUNT message.
2020-10-12 17:30:05 +01:00
Sadie Powell 8b2c1548ab Merge tag '2.0.8' into 2.1. 2020-10-07 14:42:33 +01:00
Sadie Powell 2cf507ed66 Bump for 2.0.9-git. 2020-10-07 13:15:31 +01:00
Sadie Powell 46e1395e62 Release 2.0.8. 2020-10-07 13:15:31 +01:00
Sadie Powell 6117299ecd Update the changelog. 2020-10-07 13:15:31 +01:00
Sadie Powell f8777097d1 Fix last case check for le64toh. 2020-10-07 13:15:31 +01:00
TheMythPT a79046e025 Update nickserv.example.conf
This breaks the `killprotect' functionality, because a user is expected to turn into guest after the specified amount of time.
Also new users that register their nicknames will wonder why they can't join a +R channel but they didn't change their nick to Guest*
2020-10-06 15:20:56 +01:00
Sadie Powell d0e8392445 Fix the global/global command showing the wrong origin nick. 2020-10-06 15:13:14 +01:00
Sadie Powell af8056d2dd Simplify the definition of _le64toh in the siphash implementation. 2020-10-06 14:52:55 +01:00
Sadie Powell 4ba871c631 Remove use of the deprecated register keyword.
Fixes a build error on C++17 compilers.
2020-10-02 16:53:13 +01:00
miwob da08dd6d0e Minor spelling fix in operserv.example.conf. it's vs its 2020-10-02 16:52:38 +01:00
miwob 1ac3b38fa8 Update/modernize ircd-hybrid protocol module to stay link compatible with next ircd-hybrid release 2020-10-02 14:53:08 +01:00
Sadie Powell c29b72fcdc Add C++98 and C++14 build matrixes to the Linux CI. 2020-10-02 14:27:04 +01:00
Sadie Powell a3673a5a2d Update the changelogs. 2020-10-01 10:26:20 +01:00
Sadie Powell 5dd5fa4644 Rename unreal4 to unrealircd and inspircd3 to inspircd. 2020-09-28 15:33:16 +01:00
Sadie Powell 9d6dd4af11 Remove the non-tagged version of IRCDMessage::Run. 2020-09-28 15:28:27 +01:00
Sadie Powell f430522b41 Rename things from services to anope. 2020-09-28 15:28:27 +01:00
Sadie Powell 907aa60380 All modern platforms support stdint so remove pstdint. 2020-09-28 15:28:26 +01:00
Sadie Powell c7e26c5f67 Remove nickserv/getpass and Anope::Decrypt.
There is no point having these now plain text passwords are deprecated.
2020-09-28 15:28:26 +01:00
Sadie Powell 8e0e1806a4 Require a secure password hashing algorithm for new accounts.
Insecure algorithms can still be used for existing accounts.
2020-09-28 15:28:26 +01:00
Sadie Powell 7f39fb14f2 Remove operserv/oline and CanSVSO/SendSVSO in IRCDProto.
Now UnrealIRCd 3.2.x support has been removed nothing uses this.
2020-09-28 15:28:26 +01:00
Sadie Powell fb86705d3f Drop support for InspIRCd 1.2, InspIRCd 2.0, and UnrealIRCd 3.2.
None of these are supported by upstream anymore.
2020-09-28 15:28:26 +01:00
Sadie Powell f4fa5b3733 Bump for 2.1.0-git. 2020-09-28 15:28:26 +01:00
Sam James (sam_c) 9701cbcd08 Fix musl build (gettext internals)
__USE_GNU_GETTEXT is exposed by musl because they provide
a GNU gettext-compatible interface. This doesn't mean they
provide all the internals that glibc does.

Check for __GLIBC__ if using internal _nl_msg_cat_cntr.

Signed-off-by: Sam James (sam_c) <sam@cmpct.info>
2020-09-28 13:11:24 +01:00
Sadie Powell 1af02bf2a9 Switch from Travis CI to GitHub Actions.
Closes #153.
2020-09-28 12:47:52 +01:00
Michael bf725aa8dc HostServ: Remove vhost when a nick is dropped 2020-09-28 12:15:48 +01:00
Sadie Powell 52914216f0 Clarify that unreal4 also works for UnrealIRCd 5. 2020-09-14 16:49:25 +01:00
Sadie Powell 8180dd414e Implement support for immutable account identifiers. 2020-09-10 15:15:34 +01:00
miwob ff28985384 Fix -Wclass-memaccess warning:
/anope/src/misc.cpp: In function ‘Anope::string Anope::Resolve(const Anope::string&, int)’:
/anope/src/misc.cpp:742:60: warning: ‘void* memcpy(void*, const void*, size_t)’ copying an object of non-trivial type ‘union sockaddrs’ from an array of ‘struct sockaddr’ [-Wclass-memaccess]
   memcpy(&addr, addrresult->ai_addr, addrresult->ai_addrlen);
                                                            ^
In file included from /anope/include/users.h:21,
                 from /anope/include/bots.h:12,
                 from /anope/include/regchannel.h:18,
                 from /anope/include/config.h:16,
                 from /anope/src/misc.cpp:16:
/anope/include/sockets.h:27:18: note: ‘union sockaddrs’ declared here
 union CoreExport sockaddrs
                  ^~~~~~~~~
2020-09-10 13:22:42 +01:00
miwob 584a209b28 ircd-hybrid protocol module: add support for channel mode 'K' (no knock) 2020-08-01 13:39:35 +01:00
Matt Schatz c327d1aeef Improve wording of the resetpass:confirm log message. 2020-04-06 09:49:46 +01:00
Matt Schatz 0d0763f72f Fix the handling of topic messages with InspIRCd v3. 2020-03-26 08:24:39 +00:00
Robby 4d101569f8 Update the mailmap. 2020-01-24 11:13:26 +01:00
Robby 8866612160 Update my mailmap entries. 2020-01-24 10:05:39 +01:00
Robby d69b14e54c Fix a typo in the mailmap. 2020-01-24 09:50:29 +01:00
Sadie Powell 505eed9eef InspIRCd: send an oper type of "service" instead of "services".
This fixes a grammar issue with RPL_WHOISOPERATOR where users would
see "ChanServ is a services on NetworkName".
2020-01-21 18:27:29 +00:00
Sadie Powell b188a1c0cd Update my name and email address. 2020-01-20 20:48:22 +00:00
Robby 2c1f8260fd ms_info: Fix a typo in the INFO output when a nickname has been given.
Update the dutch language file.
2020-01-07 04:37:19 +01:00
Robby d319fc6eb5 m_chanstats: Make ChanServ's HELP SET CHANSTATS translatable too. (#253)
Also refresh the language files while at it.
2020-01-07 02:45:30 +01:00
Dragone2 83eea99317 Update for Italian translation (#253). 2020-01-06 16:37:16 +01:00
Dragone2 55a23c7253 Update for Italian translation (#250). 2020-01-04 16:54:44 +01:00
Robby c8699c6726 Update copyright to 2020.
This was done with:
find docs/ include/ language/ modules/ src/ *.* Config -exec sed -i 's/-20.. Anope Team/-2020 Anope Team/i' {} \;
2020-01-04 15:51:20 +01:00
Matt Schatz 95c8478ec5 Fix the handling of kick messages with InspIRCd v3. 2020-01-04 12:40:20 +01:00
Peter Powell cba1313a40 Revert "Fix the length limit for InspIRCd v3 S2S messages."
This is causing build errors for some people and i'm unsure why.

This reverts commit a4ab6876c3.
2019-12-15 12:40:31 +00:00
Peter Powell 96ea61d8b8 Add the <limits> include to the inspircd3 module. 2019-12-15 01:50:31 +00:00
Peter Powell 523f89f45f Enable C++11 features on non-GCC C++11 compilers. 2019-12-14 19:16:44 +00:00
Peter Powell 6617d29b52 Fix a bunch of broken indentation. 2019-12-14 18:38:13 +00:00
Peter Powell a4ab6876c3 Fix the length limit for InspIRCd v3 S2S messages. 2019-12-14 18:06:53 +00:00
Peter Powell ff0109d6ba inspircd3: Refer to modules using without a prefix/suffix. 2019-12-14 17:53:42 +00:00
Matt Schatz 059c78aee3 Fix retrieval of TopicLock status in IRCDMessageMetadata. 2019-11-27 18:21:01 +00:00
Matt Schatz f75c5011e2 Update IRCDMessageMetadata for channel metadata.
- InspIRCd 3 now includes the channel TS in any channel metadata.
This pushes the type and value by one.
- Update the messages sent from this function accordingly.
- Fix retrieval of TopicLock status.
2019-11-27 18:21:01 +00:00
Peter Powell 2832c736dd Fix parsing InspIRCd v3 IJOIN messages.
Thanks to @H7-25 and @genius3000 for reporting this.
2019-11-17 10:23:06 +00:00
Matt Schatz f34ba4b1f0 Add the SSL ExtensibleItem for Users.
Copied this directly from inspircd12.cpp, which
inspircd20.cpp inherited from.
2019-11-12 13:06:32 +00:00
Adam 91dde90ad2 Merge pull request #246 from genius3000/2.0+unconfimed_info
Fix NickServ INFO and GLIST showing an incorrect unconfirmed expiry.
2019-11-11 21:20:55 -05:00
Matt Schatz 661b320d23 Look up unconfirmedexpire from the correct module.
- NickServ INFO and GLIST were looking in the wrong module.
2019-11-11 19:15:54 -07:00
Adam ae7706ae55 Bump for 2.0.8-git 2019-11-02 20:59:02 -04:00
Adam 1dee851207 Release 2.0.7 2019-11-02 20:44:48 -04:00
Adam 9c91d386e4 docs: update Changes 2019-11-02 20:43:18 -04:00
Adam 3e4d87051b inspircd3: remove CoreExport from IRCDMessageKick 2019-11-02 20:24:21 -04:00
Robby 26975fc011 Rename a few instances of 'services' to 'stats' in stats.standalone.example.conf and irc2sql.example.conf. 2019-11-03 00:50:37 +01:00
Adam c15dc49994 ns_recover: add privilege for admins to recover other users 2019-10-14 13:13:08 -04:00
Peter Powell 14ee76a0ad Fix various typos. 2019-09-23 14:48:49 +01:00
Peter Powell 4465c67790 Update the supported InspIRCd versions in the README. 2019-09-23 13:23:02 +01:00
Peter Powell 20e0fa33fc Sort message handlers alphabetically. 2019-09-23 13:23:02 +01:00
Peter Powell 7e76daf39f Add the InspIRCd v3 module to the example configs. 2019-09-23 13:23:02 +01:00
Peter Powell 2ee63f0f68 Handle/send 1205-style PING/PONG messages. 2019-09-23 13:23:02 +01:00
Peter Powell c35029fa2f Parse 1205-style mode lists for CAPAB CHANMODES/USERMODES. 2019-09-23 13:23:02 +01:00
Peter Powell bae8987ec1 Add a handler for the IJOIN command. 2019-09-23 13:23:02 +01:00
Peter Powell 470d4d1a97 Update for the 1205 channel METADATA syntax. 2019-09-23 13:23:02 +01:00
Peter Powell 78bac905c2 Update for the 1205 FJOIN syntax. 2019-09-23 13:23:02 +01:00
Peter Powell d88d8e940e Update for the 1205 KICK syntax. 2019-09-23 13:23:02 +01:00
Peter Powell b2c3775b58 Update for the 1205 INVITE syntax. 2019-09-23 13:23:02 +01:00
Peter Powell b311248bed Update for the 1205 SERVER syntax. 2019-09-23 13:23:02 +01:00
Peter Powell f7f45b4e2b Update for the 1205 FTOPIC syntax. 2019-09-23 13:23:02 +01:00
Peter Powell 3cad3514f1 Remove the TOPIC command handler.
This legacy compat command was removed in the 1205 protocol.
2019-09-23 13:23:02 +01:00
Peter Powell 1020ca47bd Remove the JOIN command handler.
This legacy compat command was removed in the 1205 protocol.
2019-09-23 13:23:02 +01:00
Peter Powell 48dbb70ecc Use the SINFO command instead of the old VERSION command. 2019-09-23 13:23:02 +01:00
Peter Powell ae16206f0c Use NUM instead of PUSH for sending numerics to clients. 2019-09-23 13:23:02 +01:00
Peter Powell 7045f206af Require the 1205 (3.0+) server protocol. 2019-09-23 13:23:02 +01:00
Peter Powell 67bd3e44c0 Remove the dependency on the inspircd12 module. 2019-09-23 13:23:02 +01:00
Peter Powell 264981fb1b Mark inspircd3 as being the InspIRCd 3 module. 2019-09-23 13:23:02 +01:00
Peter Powell 47d471c53d Make a copy of the InspIRCd v2 module for v3. 2019-09-23 13:23:02 +01:00
Peter Powell e43bc49ba7 Update the core message parser to allow parsing IRCv3 message tags. 2019-09-23 13:20:07 +01:00
Robby d9de4ddd82 Insert a new line between the subject and message body when sending mail.
Required for RFC 2822 compliancy.

Reported by jrmu via IRC.
2019-08-24 07:37:35 +02:00
Adam 8f7f4b1593 Merge pull request #244 from clem16/2.0
Fixed stupid simple typos.
2019-08-18 20:37:00 -04:00
Clem Morton fc64c0c6dd Fixed stupid simple typos.
Fixed stupid simple type, changed "bot not both" to "but not both"
2019-08-18 16:46:50 -06:00
Robby 03d065e952 Add hide_status as an available option to nickserv.example.conf.
Also improve the hide_* descriptions slightly.
2019-08-04 23:32:52 +02:00
Peter Powell 77a52eec7c Fix the version binary colliding with the C++20 <version> header. 2019-07-05 12:17:37 +01:00
Robby 523a586176 Fix globops logging if there is no predefined sender. 2019-05-10 05:50:18 +02:00
Robby af32a14fc1 Config files: Fix some typos, bring stats.standalone.example.conf up to par with example.conf, etc. 2019-04-05 03:11:39 +02:00
Romain Rivière 5c8548040a Log channel memo deletions 2019-03-30 22:17:00 -04:00
Adam 6a42c1a4f3 Merge pull request #240 from SaberUK/2.0+bot
Mark pseudoclients as bots on InspIRCd if the bot mode exists.
2019-03-30 22:10:44 -04:00
Peter Powell 0defcda8d0 Reset the default modes on CAPAB START. 2019-03-30 20:09:34 +00:00
Peter Powell f6ee88c42a Mark pseudoclients as bots on InspIRCd if the bot mode exists. 2019-03-30 12:11:31 +00:00
Robby 34f65e3266 Update enc_bcrypt with upstream crypt_blowfish 1.3 changes.
Also reverted the URLs in the header to the original ones provided by upstream.
2019-03-14 16:53:52 +01:00
Robby 02ac3a403c Fix the ChanServ SET SUCCESSOR syntax to show that a nickname is optional. 2019-03-06 03:34:25 +01:00
Adam e1e840a87d Merge pull request #239 from SaberUK/2.0+set
Fix missing braces in cs_set.
2019-03-05 08:10:04 -05:00
Peter Powell eb66f9eda0 Fix missing braces in cs_set. 2019-03-05 11:29:45 +00:00
Robby a4c37a373a Update the dutch language file. 2019-02-28 04:44:37 +01:00
Robby bca9b4ce83 Regenerate the language files. 2019-02-28 03:05:07 +01:00
Robby a2446b8d4b Merge pull request #224 from genius3000/2.0+deoper_superadmin
Ensure SuperAdmin isn't left on when de-opering
2019-02-14 04:41:27 +01:00
Robby e567cfda36 Improve the help text for ChanServ SET SUCCESSOR. 2019-02-14 02:41:57 +01:00
Adam 961a9bc506 Merge pull request #221 from SaberUK/2.0+uplink
Make it more clear where the uplink config goes.
2019-02-09 17:37:41 -05:00
Bram Matthys da6e2730c2 Allow post-handshake SASL in UnrealIRCd 4.2.2 and up.
This updates the unreal4 protocol module to work with both pseudo-id's
and real UID's. Something that will also be necessary once UnrealIRCd
gets rid of pseudo-id's altogether.
2019-02-09 17:10:23 -05:00
Robby 2b8072bf80 Remove a few more unnecessary fuzzies in the language files. 2019-01-24 18:04:23 +01:00
Robby 49cea76841 Remove an unnecessary fuzzy in the french language file. 2019-01-24 17:30:17 +01:00
Robby e1c8aa0dbc Update the language files.
- Regenerated the language files.
- Made some corrections to the french language file.
2019-01-24 15:36:50 +01:00
Adam 2546e865e2 Merge pull request #233 from genius3000/2.0+typofix
Fix typo in CS enforce help reply.
2019-01-21 19:14:10 -05:00
Matt Schatz d6af21e0d9 cs_enforce: fix typo in help. 2019-01-20 21:25:07 -07:00
Dragone2 18522f7fc8 Fixed some misspellings in Italian Translation 2019-01-03 21:46:52 -05:00
Adam 4c167bed69 Merge pull request #223 from SimosNap/webcpanel
Fixed NickServ set access from webcpanel
2019-01-03 21:34:00 -05:00
devel 32a21679fb Fixed NickServ set access from webcpanel 2019-01-03 21:33:02 -05:00
Adam a5eaf6fc49 Merge pull request #225 from genius3000/2.0+away_msg
Handle S2S AWAY messages with a timestamp
2019-01-03 21:30:44 -05:00
k4bek4be 9d7245bded Polish translation reworked and completed. 2019-01-03 21:20:34 -05:00
Adam 02fb4b67cf Merge pull request #228 from SaberUK/2.0+casemap
Send the casemap as part of CAPAB CAPABILITIES on InspIRCd.
2019-01-03 21:10:31 -05:00
linuxdaemon cf44418e10 Allow multiple IP addresses in extforward_ip separated by spaces 2019-01-03 21:07:01 -05:00
Robby 6fbb7cffe9 Update copyright to 2019.
This was done with:
find docs/ include/ language/ modules/ src/ *.* Config -exec sed -i 's/-20.. Anope Team/-2019 Anope Team/i' {} \;
2019-01-01 17:43:35 +01:00
Robby b279863acb Update most URLs to use HTTPS if available, and fix some dead ones too. 2018-11-10 15:15:05 +01:00
BoGu5 9e7dadb967 docs/FAQ: Fixed 1.9 to 2.0 in 2.0 branch 2018-11-10 13:07:35 +01:00
Robby 9069bf4e2f Merge branch 'TheMythPT-patch-2' into 2.0
Update chanstats.example.conf

Missing permissions that otherwise allow any registered user to turn on/off chanstats option to any other user
2018-10-28 16:42:17 +01:00
Vitor e85b0a5f68 Update chanstats.example.conf
Missing permissions that otherwise allow any registered user to turn on/off chanstats option to any other user
2018-10-28 16:35:47 +01:00
Peter Powell 195eff9c04 Send the casemap as part of CAPAB CAPABILITIES on InspIRCd.
This is technically part of the 1205 protocol but it is entirely
backwards compatible so older versions will not be negatively
affected by this.
2018-10-27 19:11:38 +01:00
Robby 42aa330db3 ns_set: Log email address change requests when confirmemailchanges = yes 2018-09-11 01:21:19 +02:00
Matt Schatz 1e9d959857 Handle S2S AWAY messages with a timestamp
InspIRCd 2.0 sends a timestamp in its S2S AWAY message since
https://github.com/inspircd/inspircd/commit/b1002b7df55f1aec5bfce48ecd07d6d326174c95
Syntax of `AWAY <timestamp> :<away msg>`
Catch this message and remove the timestamp parameter before
sending it to the core AWAY handler.
2018-07-20 09:39:47 -06:00
Matt Schatz 38721993f1 Ensure SuperAdmin isn't left on when de-opering 2018-07-14 17:38:37 -06:00
Peter Powell 1b782235c4 Make it more clear where the uplink config goes. 2018-06-19 11:15:13 +01:00
Adam 368300d319 Merge pull request #222 from bonnedav/patch-2
Unreal4 does not allow SWHOIS to come from a user source.
2018-06-12 12:36:19 -04:00
Adam 94e10d52fb anopesmtp: fix previous commit 2018-06-12 10:46:55 -04:00
Adam d25c8c169e Merge pull request #203 from MrGadget1024/patch-1
Fix mail sending for reliability.
2018-06-12 10:39:17 -04:00
Vitor 67b7fed9ed example.conf: update example link block for Unreal 4 2018-06-12 10:36:39 -04:00
Dragone2 e32a8dbbe5 Update Italian translation 2018-06-12 10:29:34 -04:00
Dragone2 281edf8475 cs_seen: fix for translations being ignored
These strings: " but %s mysteriously dematerialized.", ". %s is still online." and ", but %s mysteriously dematerialized." weren't translated by the method Anope::printf().
2018-06-12 10:22:20 -04:00
Adam ce7c266651 Merge pull request #214 from genius3000/2.0+fix_insp20_proto
Fix for bug 1712
2018-06-12 10:16:45 -04:00
Adam c1166e3618 Merge pull request #216 from SaberUK/2.0+oline
Disable the os_oline module by default.
2018-06-12 10:08:16 -04:00
Adam 8294c94b95 Merge pull request #217 from genius3000/2.0+ns_set_message
Show NickServ SET MESSAGE in help when 'useprivmsg' is enabled
2018-06-12 10:07:55 -04:00
Adam 6f09b703dd Merge pull request #218 from miwob/modernize
Update ircd-hybrid protocol module to support latest version of ircd-…
2018-06-12 10:01:27 -04:00
miwob 466e5be741 Update ircd-hybrid protocol module to support latest version of ircd-hybrid better 2018-06-12 08:40:57 -04:00
Adam 32076c099c Merge pull request #219 from genius3000/2.0+set_help_hide
Check for 'hide' flag in commands in (bs,cs,ns)_set HELP
2018-06-12 08:39:24 -04:00
Adam 216b96aa57 Merge pull request #220 from genius3000/2.0+ns_ungroup_log
Log NickServ ungroup
2018-06-12 08:16:35 -04:00
bonnedav 6d592e2a0f Unreal4 does not allow SWHOIS to come from a user source. 2018-06-12 00:00:00 -06:00
Matt Schatz feb5a4d935 Log NickServ ungroup 2018-05-08 16:24:02 -06:00
Robby e03ae0cd85 Update copyright to 2018.
This was done with:
find docs/ include/ language/ modules/ src/ *.* Config -exec sed -i 's/-20.. Anope Team/-2018 Anope Team/i' {} \;
2018-04-25 19:22:13 +02:00
Robby 901fc3e40f Document that negating is possible for commands and privs in opertype blocks. 2018-04-25 18:59:09 +02:00
Robby 5683f45925 Clarify available tokens for the email templates. 2018-04-25 16:32:12 +02:00
Robby bafc17472e Add 'n' email token for use in the emailchange template, this token gets replaced with the display nickname. 2018-04-25 16:15:16 +02:00
genius3000 7638c7a884 Check for 'hide' flag in commands in (bs,cs,ns)_set HELP
This code is duplicated from help.cpp to (bs,cs,ns)_set.cpp for listing
the available SET commands. The check for the 'hide' flag was missed
and this incorrectly listed commands that were configured as hidden.
2018-04-02 04:02:23 -06:00
Adam d25722ddd0 m_httpd: make http headers case insensitive 2018-03-26 20:21:06 -04:00
genius3000 750d1009ec Show NickServ SET MESSAGE in help when 'useprivmsg' is enabled 2018-03-10 15:22:02 -07:00
Peter Powell b8e7960ff6 Disable the os_oline module by default.
This only works on UnrealIRCd 3.2 (which has been EOL for over a
year now) and regularly confuses users who think that "your IRCd
does not support OMODE" is an error they need to fix.
2018-03-03 14:26:33 +00:00
genius3000 ff878bbda8 Allow empty values in InspIRCd 2.0 mode strings within CAPABILITIES
Skipping over empty values in the commasepstream can put the mode adding
logic out of order (eg. ignoring the first two tokens when they are the
needed tokens). Most modes are already added by being explicitly checked
for, but the "unknown" or "extra" modes are added here.
2018-02-13 20:35:37 -07:00
Adam 1baf774647 ns_group: send login on successful group too 2018-02-10 08:36:12 -05:00
Adam 772410d974 Merge pull request #211 from Dragone2/patch-5
Update for Italian translation
2018-02-02 22:48:00 -05:00
Adam 7ceb4426c7 m_dns: fix notify socket always being ipv6 2018-02-02 22:39:46 -05:00
Dragone2 10c7a9ff94 Update for Italian translation
Update for the old Italian translation of Anope, with new translated strings, correction of grammatical errors and other minor changes.
2018-02-03 00:19:21 +01:00
Adam b3c4b28a67 Merge pull request #197 from genius3000/2.0+fix_insp_rlines
2.0: Fix sending incorrect RLines to InspIRCd
2018-01-12 12:09:50 -05:00
nekoswag 0da4150283 Update chanserv.example.conf (#206) 2017-12-30 15:32:22 -05:00
Chris Langsenkamp 5920f1b59c Fix mail sending for reliability.
After sending the "\r\n.\r\n" after the mail payload, smtp_send_email was not waiting for the mail server to complete post-processing and respond with "250", but was sending "QUIT\r\n" immediately and dropping the connection.  Mail server may kill the transaction if it can't send the "250" (socket closed).  The changes proposed completes the mail transaction by reading for the 250 and in smtp_disconnect steps through a proper quit sequence by waiting for the 221 server response.

I discovered this by including the --debug option in services.conf sendmailpath, which invoked logging in smtp_send and that slowed it down enough for the mail server to return the 250 and complete the transaction.
2017-12-11 12:41:31 -05:00
Adam 68fcb1af93 Bump for 2.0.7-git 2017-12-11 11:47:06 -05:00
Adam 0574de2d22 Anope 2.0.6 Release 2017-12-11 11:46:10 -05:00
Adam c9c53dbe61 Add README.md, for github 2017-11-19 17:28:05 -05:00
Adam a084245822 README: remove some outdated links 2017-11-19 17:28:05 -05:00
Robby 77e3f062da Update the dutch language file. 2017-11-17 23:56:15 +01:00
genius3000 0e14adcb0f Fix sending incorrect RLines to InspIRCd
Currently a Regex AKILL is sent with a malformed mask to InspIRCd as an RLine.
InspIRCd expects a mask of 'n!u@h\sr', so we need to remove the enclosing
slashes (/.../), change the '#' separator to '\s', and change any literal
spaces to '\s' and then it creates a proper RLine.
2017-10-14 08:36:35 -06:00
Adam 8bb3067e42 Update Changes and Changes.conf 2017-10-12 19:58:02 -04:00
Adam 0c469abe4a Call OnDelChan prior to unsetting extensibles
cs_set uses this to set -P on permanent channels if they are persistent.

Also move similar event in nickcore/nickalias destruction
2017-10-12 19:37:06 -04:00
Adam d63e32a579 No longer try to create persistent channels on the fly
Change initial channel creation to on post init so it will be part of
the burst.
2017-10-12 19:30:48 -04:00
Adam f13c450b93 Add post init event 2017-10-12 19:28:34 -04:00
Adam e95c07291a unreal4: send sjoin with empty users in SendChannel 2017-10-12 19:28:12 -04:00
Adam 2963fc0a1d unreal4: send modes in sjoin 2017-10-12 19:27:51 -04:00
Adam 5d309d46e1 plexus: fix overriding SendSVSLogin 2017-10-10 21:19:23 -04:00
Adam 2e7fcd3098 Merge pull request #199 from syzop/2.0+unrealsaslmechs
Advertise SASL mechanisms to UnrealIRCd servers.
2017-10-09 11:29:55 -04:00
Adam 884759aed4 Merge pull request #200 from syzop/2.0+saslbydefault
Load sasl module by default.
2017-10-09 11:23:09 -04:00
Bram Matthys 2ec65023a6 Load sasl module by default. 2017-10-09 10:31:21 +02:00
Bram Matthys 0093f3fa44 Advertise SASL mechanisms to UnrealIRCd servers. 2017-10-09 10:22:50 +02:00
Adam 2ad76278dd Use full path to file for conf.cpp file could not be opened error message 2017-08-05 18:31:57 -04:00
Tim Gunter 23e59d9f2c Allow calls to XMLRPC to impersonate supplied user, if online 2017-07-28 09:08:40 -04:00
Adam 3cb9e0b97c m_xmlrpc: fix incorrect string find usage 2017-07-24 20:30:34 -04:00
Adam 0b7b6d9d6d ns_group: don't require a user to group 2017-07-24 10:04:07 -04:00
Adam 56e6efbe8f Default require_oper to true. Fixes os_oper unserializer because it doesn't set it. 2017-07-02 18:03:36 -04:00
Adam feed624cdc webcpanel: rate limit login attempts 2017-06-05 18:44:48 -04:00
Adam 1a6f42b994 webcpanel: escape values in template_fileserver
Remove other escapes to prevent double escape.

Not all replaced values were escaped, such as replies from commands.
2017-06-05 10:11:22 -04:00
Adam 04f49225c9 httputils: escape ampersand too 2017-06-05 10:10:58 -04:00
Adam b18d1a69b6 Merge pull request #174 from Techman-/2.0+inspsasl
InspIRCd: Send CHGIDENT/CHGHOST on SVSLOGIN
2017-05-27 12:29:12 -04:00
Adam 0ace685597 Merge pull request #188 from key2peace/2.0
IPv6 support for m_dnsbl and sockaddrs::reverse()
2017-05-27 09:58:34 -04:00
Alexander Maassen bfcfd0b727 Moved m_dns's reverse ip method to sockaddrs::reverse().
Updated m_dnsbl to support ipv6.
2017-05-27 09:56:18 -04:00
Adam 087f1cb359 m_dnsbl: fix exempts, allow cidrs, default exempt 127.0.0.0/8 2017-05-17 08:51:57 -04:00
Adam 010d20198e m_regex_posix: use REG_ICASE 2017-03-30 19:10:31 -04:00
Adam 953e804231 example.conf: disable regexengine directive by default 2017-03-30 17:02:36 -04:00
Adam c656fe0694 regchannel: fix compile warning from previous commit 2017-03-27 22:25:49 -04:00
Adam fb3ec7a897 cs_akick: don't show channel doesn't exist message in enforce from adding akicks 2017-03-27 21:41:35 -04:00
Adam 274658f955 Fix autokick destructor to properly remove channel references from accounts 2017-03-27 21:14:32 -04:00
Adam 7621306f4b example.conf: update to reflect deprecated status of older encryption modules 2017-03-26 18:34:03 -04:00
Adam b804867105 Remove weird warning in nickserv help which for some reason assumes admins' abuse policies 2017-03-23 20:05:09 -04:00
Adam f8f1550c31 Merge pull request #187 from miwob/new-mode
Add channel mode 'u', and 'L' to hybrid protocol module; Remove usele…
2017-03-19 18:56:06 -04:00
Adam 0fcc66711b m_sasl: pass module to logger 2017-03-19 18:55:32 -04:00
Adam 8d9574e306 readme: change minimum supported hybrid version to 8.2 2017-03-19 18:55:19 -04:00
miwob 6cb17c734c Add channel mode 'u', and 'L' to hybrid protocol module; Remove useless CAPABs that are mandatory for some years now. 2017-03-19 12:02:22 +01:00
Adam 3545e8e383 Fix ns_keep_modes default option in nickserv.conf 2017-03-18 15:30:17 -04:00
Adam 3c18e02b0b logger.cpp: fix variable shadow warning 2017-03-16 21:37:34 -04:00
Adam b831cd8a36 Include ip for web clients in command log messages for source 2017-03-16 20:23:57 -04:00
Adam 516ab164f6 redis: check for socket errors when loading database on startup 2017-03-16 20:13:56 -04:00
Adam b2d028533d cs_xop: fix showing alternative access methods in help 2017-03-15 21:44:05 -04:00
Adam a88d9cb1f0 modes.cpp: correct usage of format string passed to SendMode 2017-03-08 19:58:25 -05:00
Adam b57ef5d2c7 db_redis: don't crash if destroying an object with no type 2017-03-08 16:23:30 -05:00
Adam 1a96390826 unreal4: set +xt on chghost as unreal does 2017-03-01 17:44:05 -05:00
Adam 60339edf40 cs_set: don't lower ts from own clients joining 2017-02-21 14:44:33 -05:00
Adam 6990c692d6 Unwrap list modes too in cs_mode, and fix clear on virtual modes to show an error 2017-02-21 12:36:59 -05:00
Adam 98e62b4032 Fix logging in cs_mode set 2017-02-21 12:35:51 -05:00
Adam a1d7d42d6a Unwrap mode changes in RemoveMode before checking if it is set, fixes os_mode not being able to remove extbans etc 2017-02-21 12:35:20 -05:00
Adam 3f7c0829ef os_forbid: match forbids exact on add/del 2017-02-21 09:59:10 -05:00
Adam 46d8af781d Verify configured servername and uplink password are valid 2017-02-21 08:19:03 -05:00
Adam 67b7c8bd7d os_logsearch: fix quick match 2017-02-12 16:46:13 -05:00
Adam 21486e2c81 Merge pull request #185 from fallen/2.0
Update French language file
2017-02-06 14:20:40 -05:00
Adam 29ac40b584 ns_set_misc/cs_set_misc: send syntax help too 2017-02-06 14:06:55 -05:00
Adam dde444ed0e protocol/inspircd12: set +x on /hs off 2017-02-06 13:15:01 -05:00
Adam 9b6c209c80 bs_badwords: allow opers with botserv/administration to list/clear badwords too 2017-02-04 20:21:40 -05:00
Yann Sionneau 3c7d67c8cd Update French language file
- translate "nick" to "pseudo"
- remove "XOP" arg from set secureops
2017-02-04 23:47:05 +01:00
Adam c730291762 logger: some log events rely on empty sources 2017-01-23 08:03:51 -05:00
Adam c593661f40 Anope 2.0.6-git 2017-01-22 17:04:20 -05:00
Adam a9bf251886 Anope 2.0.5 Release 2017-01-22 16:09:36 -05:00
Adam beac29b1d0 m_sasl: don't allow logging into unconfirmed accounts 2017-01-22 16:00:06 -05:00
Adam 35d6437d45 Remove old language strings from lang files 2017-01-20 09:45:25 -05:00
Robby 76ce8ece1a Cleanup some excess whitespaces and tabs, and fix a few typos along the way. 2017-01-17 05:03:25 +01:00
Adam 464093d36e Regenerate language files 2017-01-16 18:59:30 -05:00
Adam 71bb3fefcc Update Changes 2017-01-16 18:58:30 -05:00
Adam 1f6f9f5dbb Revert "Remove efnetrbl from example dnsbl configuration" 2017-01-16 18:45:08 -05:00
Adam 34bf21f7d1 Correct a couple expiry time checks from DoTime() 2017-01-16 18:42:29 -05:00
Adam 847dfd9523 Merge pull request #182 from genius3000/2.0+protocol_match_name
protocol/inspircd: Match servername as well on ENCAP
2017-01-16 18:33:09 -05:00
Adam a96e40e249 Merge pull request #183 from SaberUK/2.0+cmake
Don't give misleading instructions when running CMake fails.
2017-01-16 18:32:34 -05:00
Robby 8656b65e39 Update copyright to 2017.
This was done with:
find docs/ include/ language/ modules/ src/ *.* Config -exec sed -i 's/-20.. Anope Team/-2017 Anope Team/i' {} \;

Added missing copyright headers to files that didn't have it yet.
2017-01-16 03:13:25 +01:00
Robby 39422beaef Update the dutch language file. 2017-01-14 02:57:44 +01:00
Peter Powell 6d29538346 Don't give misleading instructions when running CMake fails. 2017-01-13 22:02:00 +00:00
Adam bdf4650ff8 m_dnsbl: widen allowed reply range to 127.0.0.0/8 2017-01-12 13:26:29 -05:00
Adam 074bde5ccc db_sql: run table creation queries during import synchronously too 2017-01-11 20:44:55 -05:00
Adam a4f7d847ab unreal4: use SENDUMODE instead of GLOBOPS 2017-01-11 20:42:20 -05:00
Adam 5beb338247 Remove efnetrbl from example dnsbl configuration 2017-01-08 15:48:54 -05:00
Adam 7b1154de69 ns_register: notify users of unconfirmed accounts on register when there is no user too 2017-01-08 13:08:04 -05:00
Adam 46aeb8b70b os_list: show number of channels listed, too 2017-01-07 18:09:14 -05:00
Adam fe6271dffb ngircd: move metadata non-exietent user log message to debug 2017-01-07 18:04:07 -05:00
Adam 7cede5bb60 os_list: also allow patterns in nick!user@host#realname form 2017-01-07 18:03:53 -05:00
Adam 2b7f0084b7 Move log messages for status mode change for unknown user to debug 2016-12-22 20:59:04 -05:00
Adam ec7ce09ef4 Make User::Mask behave more like 1.8 2016-12-22 20:52:43 -05:00
Adam 574c8dfbc7 Fix previous commit, deleting sessions removes it from the map which invalidates the reference 2016-12-21 10:35:57 -05:00
Adam 4381031994 m_sasl: log hostname/ip, if provided 2016-12-19 19:03:10 -05:00
Adam b3010c3c6b logger: log source nick if there is no user or account 2016-12-15 08:24:40 -05:00
Adam d092f5e7c8 Fix detecting if chghost/chgident is loaded on inspircd and don't send them unless they are 2016-12-11 09:43:22 -05:00
Adam 358f46b8ae Fix setting kill quick in webcpanel 2016-12-11 09:34:37 -05:00
Adam e5125c2c84 Allow nonconfirmed opers to confirm accounts 2016-12-11 09:24:52 -05:00
Adam 65db59b3ec Remove unnecessary functions from ngircd that duplicate the default behavior, fix a few typos in comments 2016-12-10 23:28:50 -05:00
Adam 95cd7a6aee inspircd12: fix mode handler to handle opers changing other users umodes correctly 2016-12-01 19:10:46 -05:00
Adam 12515fd2c1 cs_access: fix typo 2016-12-01 19:08:39 -05:00
Adam 437a6dbb29 os_logsearch: optimize non wildcard searches, allow regex 2016-11-22 19:44:25 -05:00
Adam d96ca9b824 os_logsearch: add a hard max limit and make the limiter smarter 2016-11-22 19:35:11 -05:00
genius3000 aefde6e44d protocol/inspircd: Match servername as well on ENCAP 2016-11-22 02:26:41 -07:00
Adam 23a0628fba db_old: convert languages to UTF-8 encoded version 2016-11-11 13:30:22 -05:00
Adam ef9c69f99d Don't apply secureops to users with chanserv/administration privilege, not protected 2016-11-05 12:06:26 -04:00
Adam 8be331618c ns_group: allow userless execution 2016-11-05 11:07:02 -04:00
Adam a5fdf7c546 irc2sql: fix changing status modes to update ison modes 2016-11-05 10:36:28 -04:00
Adam dba19d839a cs_access: fix negative access to apply to the -1/0 special casing 2016-11-05 10:35:47 -04:00
Adam 7453c71c00 irc2sql: fix crash on shutdown with no sql 2016-11-05 10:34:25 -04:00
Adam f09ea316dd irc2sql: update max topic len to 512 2016-11-05 10:34:09 -04:00
Adam ac0f3c5ccf m_mysql: null empty columns instead of setting to '' 2016-11-04 22:56:15 -04:00
Adam 76ea111980 irc2sql: fix a couple SQL errors 2016-11-04 22:07:00 -04:00
Adam 9f9183afc4 help: always use command name from config, which may be a different case 2016-11-03 23:23:57 -04:00
Adam ef32505633 dns: set error to REFUSED when there are no answers 2016-11-03 23:15:07 -04:00
Adam 304494322f Don't apply secureops to protected users 2016-11-03 23:08:49 -04:00
Adam 9e510cd0d9 Fix userless /ns set email, #1689 2016-11-03 23:04:22 -04:00
Adam 0f49d1051a Don't try to include files with empty paths 2016-11-03 22:58:50 -04:00
Adam 4b97a9b13f Fix crash loading enc_old prior to the proto mods 2016-11-03 22:54:35 -04:00
Adam 07f72a3122 os_list: fix regex matching 2016-10-25 14:35:36 -04:00
Adam f4543edfe2 plexus: add noop and sasl support 2016-10-16 18:52:40 -04:00
Adam 095751363d db_sql: don't update objects pending creation as it duplicates it 2016-10-16 18:51:58 -04:00
Adam 1b67b97e93 ns_maxemail: equals_ci for comparing emails 2016-10-06 14:59:22 -04:00
Adam d4bf0957d1 inspircd20: specifially add channel modes official-join and operprefix as status modes, sometimes they are sent in CAPAB without a status prefix which causes them to be added as parameter modes 2016-10-04 21:45:45 -04:00
Adam 99acdcf168 cs_mode: check chanserv privilege too for status modes on set 2016-10-04 21:28:43 -04:00
Adam e95950ee26 cs_mode: make override logging of mode set more reliable 2016-10-04 21:13:43 -04:00
Adam fc0171fb40 memoserv: always use display for memo source 2016-09-30 21:03:35 -04:00
Adam 1c82697ccb Revert "Always use display for memo source"
This reverts commit d8a945b1a6.
2016-09-30 20:52:38 -04:00
AlphaTech f3bb46a9f5 MemoServ - Read All 2016-09-25 17:27:30 -04:00
Michael Hazell 3b62c8f3e2 InspIRCd: Send CHGIDENT/CHGHOST on SVSLOGIN 2016-09-25 14:50:03 -04:00
Adam 4d054aa2b2 Merge pull request #173 from genius3000/2.0-remove-expiretimeout-cs_seen
Thanks
2016-09-25 14:38:16 -04:00
Adam 3a8ff5d456 Merge pull request #177 from attilamolnar/2.0+sqliteleak
m_sqlite: Fix possible memory leak when opening a database fails
2016-09-25 14:37:01 -04:00
Adam 0b783b66a4 Merge pull request #178 from Techman-/2.0+resv
Thanks
2016-09-25 14:36:46 -04:00
Adam 0c7050c506 Merge pull request #175 from genius3000/2.0-email-date_header
Added a Date field to the Header
2016-09-25 14:35:43 -04:00
Adam d02b3c1c45 Merge pull request #176 from Alef-Burzmali/2.0+update-fr2
Thanks
2016-09-25 14:33:49 -04:00
Adam d8a945b1a6 Always use display for memo source 2016-09-14 17:24:06 -04:00
Adam b50fbec705 cs_seen: allow unregistered users to use 2016-09-13 12:36:48 -04:00
Adam d488efdcfe ms_cancel: cleanup, consider accounts by equiality instead of sender name to account name 2016-09-06 14:46:19 -04:00
Adam 13c5eec00a m_ssl_openssl: allow certificate chain files to be used 2016-09-05 10:41:52 -04:00
Michael Hazell 39eb9f8cfc ratbox: fix RESVs
Also, enable channel support because it wasn't specified already and point charybdis to these methods instead.
2016-09-04 04:05:11 -04:00
Thomas Fargeix 83c2f8e970 Update French language file. 2016-08-19 21:33:57 +02:00
genius3000 e23cf0c221 Added a Date field to the Header 2016-08-17 10:22:44 -06:00
Attila Molnar de174149f7 m_sqlite: Fix possible memory leak when opening a database fails 2016-08-17 14:09:05 +02:00
genius3000 663e79e4d3 Remove 'expiretimeout' from chanserv.example.conf
As seen within this commit: https://github.com/anope/anope/commit/22658d63bdb1e52a66f4514af45fa55ca5891345
'expiretimeout' is no longer set within cs_seen and I can't see it used elsewhere to be needed in the config.
2016-08-08 23:39:19 -06:00
Adam 2a5e7827bd Merge pull request #172 from bonnedav/patch-1
Thanks
2016-08-08 09:34:14 -04:00
bonnedav 9c0b843665 Remove unused commands from oper config. 2016-08-08 02:41:42 -06:00
Adam 8fdfa6e094 Fix #1684 more, can have non-user sources for encap sasl 2016-07-25 22:27:30 -04:00
Adam dad4be050b cs_xop: remove unused code 2016-07-25 19:35:19 -04:00
Adam 937b0e7185 db_old: fix warnings 2016-07-25 19:34:59 -04:00
Adam db4f38bcf5 Bump for 2.0.5-git 2016-07-23 17:37:05 -04:00
Adam c2e09fdaea Anope 2.0.4 Release 2016-07-23 16:26:14 -04:00
Adam 01768bc73e Update Changes.conf 2016-07-23 16:25:37 -04:00
Adam c18eedec18 ns_set: clear last modes before unserializing them 2016-07-23 16:20:54 -04:00
Adam 0e0615c6fe Note Windows installer fixes in changelog 2016-07-23 16:17:33 -04:00
Adam 5bd3fde79b cs_set: clear last modes before unserializing them 2016-07-23 16:17:21 -04:00
Adam 647f8cd4e6 Add/fix various checks on source user existing in the protocol modules 2016-07-23 15:47:33 -04:00
Adam b2e25db159 Merge pull request #171 from Techman-/2.0+charybdis-resv-fixes
charybdis.cpp: Properly support RESVs
2016-07-23 15:38:26 -04:00
Adam 9f9371531d Fix making directories from the Windows installer 2016-07-23 15:22:54 -04:00
Michael Hazell b578ed2544 charybdis.cpp: Properly support RESVs
Properly support RESV and UNRESV in Charybdis, and improve RESV setting for pseudoclients when bursting.
2016-07-21 23:27:20 -04:00
Adam 0a7f167060 m_dns: accept unpacking the root domain, and don't consider exceptions from nameserver/additional record unpacking as fatal to query parsing 2016-07-19 21:17:58 -04:00
Adam d427772bd3 os_defcon: find module by name, it might not be loaded yet 2016-07-10 20:51:03 -04:00
Robby b2d670298b Update the dutch language file. 2016-07-07 16:07:24 +02:00
Adam 6b646fa1f8 Update Changes 2016-07-03 13:57:11 -04:00
Adam 72269c44e5 Merge pull request #170 from Zoddo/charybdis/join0
Thanks
2016-07-03 13:47:49 -04:00
Adam 3b2366e4ba Merge pull request #169 from SaberUK/2.0+which
Use "cmake --version" instead of "which cmake" to detect CMake.
2016-07-03 13:46:41 -04:00
Adam 257a8a9a24 ns_maxemail: optionally remove gmail aliases 2016-07-03 13:42:18 -04:00
Adam 7a1d2e11dd chankill: don't add duplicate akills 2016-07-03 13:31:12 -04:00
Adam 8dc687b657 #1682: store aftype with masks and include cidrs in GetNUHMask 2016-07-03 13:29:27 -04:00
Adam 18fc113984 #1681 update last realname always on signon 2016-07-03 13:06:06 -04:00
Adam 20c1a5d638 #1680: fix Anope::Duration with one year durations 2016-07-03 12:42:16 -04:00
Adam 8000ae0c0f #1677 apply sqlines even if the ircd doesn't on non opers 2016-07-03 12:36:34 -04:00
Adam 284d95bfe2 #1675: fix saset display to update the account name on the correct clients 2016-07-03 12:27:01 -04:00
Adam c7d5ee4bec Fix /ns confirm to set +r/accounts when appropriate 2016-07-03 12:17:44 -04:00
Adam 4c4cc0ded7 Fix xmlrpc notice call to return something to prevent m_xmlrpc from thinking it is a http 404 2016-07-03 12:08:21 -04:00
Adam 83f89bfece Clarify botserv repeat kicker message and allow setting repeat times to 1 2016-06-25 13:04:32 -04:00
Adam 7cf4245359 Enable -fno-delete-null-pointer-checks on GCC 6 2016-06-22 20:20:28 -04:00
Zoddo 9284441491 Handle /join 0 for ratbox & charybdis 2016-06-02 12:23:26 +02:00
Peter Powell 7592a6981b Use "cmake --version" instead of "which cmake" to detect CMake. 2016-05-21 17:54:33 +01:00
Adam 56b158ea43 Fix handling nick introduction collisions on unreal4 2016-05-20 21:18:34 -04:00
Adam 0143dafe51 Merge pull request #165 from sketchni/patch-1
Add the notice method to XMLRPC.
2016-04-22 10:17:41 -05:00
Adam a2dbcc620e Merge pull request #166 from jmdh/2.0-reproducible
Optionally strip variable build date from compiled program
2016-04-22 10:17:11 -05:00
Adam 9b5fdea8f2 Fix randomnews to work when there are more than newscount random news 2016-04-22 11:15:42 -04:00
Dominic Hargreaves fab07d6b75 Optionally strip variable build date from compiled program
To aid build reproducibility, don't include the build date/time if
-DREPRODUCIBLE_BUILD is defined.

Based on the patch provided by Alexis Bienvenüe in the Debian report.

Bug-Debian: https://bugs.debian.org/820152
Patch-Name: reproducible_datetime.diff
2016-04-21 23:08:12 +01:00
Sketch 1d198da436 Add the notice method to XMLRPC. 2016-04-20 15:41:23 +01:00
Adam 8b6e17fe7e Change access check in cs_updown to not allow actions on users with equal access 2016-04-16 18:14:23 -04:00
Adam 86484b6c2b Merge pull request #164 from SaberUK/2.0+extras
Remove references to cmake-bin which was removed ages ago.
2016-04-16 16:59:21 -05:00
Adam c14ae99d32 Merge pull request #163 from Zoddo/fix_sasl_reauth
Send new account name to the IRCd on SASL reauth
2016-04-16 16:59:00 -05:00
Adam cb0cda2f8d Missed channel deletion in ~ChannelInfo 2016-04-16 18:00:47 -04:00
Peter Powell 2af363755a Remove references to cmake-bin which was removed ages ago. 2016-04-16 13:05:44 +01:00
Zoddo 753b8dc989 Send new account name to the IRCd on SASL reauth 2016-04-15 10:49:30 +02:00
Adam d2ea1e7917 Merge pull request #160 from Zoddo/charybdis/fix_euid
Fix host on charybdis if there is no vhost
2016-04-14 19:18:14 -05:00
Adam a8f66578b1 Merge pull request #161 from Zoddo/charybdis/vhost_svslogin
Send vident/vhost in SVSLOGIN with SASL
2016-04-14 19:17:39 -05:00
Adam ca39aeb554 Merge pull request #162 from SaberUK/2.0+sasl
Remove support for DH-AES and DH-BLOWFISH.
2016-04-14 19:16:56 -05:00
Adam a941f9bde0 Remove memos from memoinfo more reliably 2016-04-14 20:15:53 -04:00
Peter Powell f4f6787c9c Remove support for DH-AES and DH-BLOWFISH.
These SASL mechanisms are considered insecure and should not be
used anymore.
2016-04-13 20:26:50 +01:00
Zoddo 82816cb206 Send vident/vhost in SVSLOGIN with SASL
Only charybdis seems to support that for the moment.
2016-04-10 18:24:25 +02:00
Zoddo 58f0c8c612 Fix host on charybdis if there is no vhost 2016-04-10 17:53:53 +02:00
Adam 21e1913c0f Fix subtle typo in command initializer list 2016-04-05 16:01:16 -04:00
Adam 79e7c3f98a Also defer channel deletion when processing sjoins 2016-03-19 16:21:40 -04:00
Adam 72127e1b00 Merge pull request #159 from Diftraku/2.0
proto/charybdis: Add support for MECHLIST
2016-03-17 17:15:56 -05:00
Toni Kaija ed47588087 proto/charybdis: Add support for MECHLIST 2016-03-17 15:13:11 +02:00
Adam 448967cefc Merge pull request #156 from SaberUK/2.0+sasl-mechlist
Implement support for SASL 3.2 mechanism lists.
2016-03-15 17:41:48 -05:00
Adam 979027138b Merge pull request #155 from SaberUK/2.0+sasl-reauth
Fix logging into accounts with SASL on servers that support reauth.
2016-03-15 17:40:26 -05:00
Robby 176e0e4f37 Update the dutch language file. 2016-03-09 22:42:45 +01:00
Adam b431d4dccf cs_clone: don't clone registered time 2016-03-08 19:49:30 -05:00
Adam 1b12b80b48 language: incrementing _nl_msg_cat_cntr is still required on some systems apparently (freebsd 10?). I don't know why. 2016-03-08 19:47:06 -05:00
Peter Powell 52fdc45597 Implement support for SASL 3.2 mechanism lists. 2016-02-28 16:36:43 +00:00
Peter Powell 91762524e2 Fix logging into accounts with SASL on servers that support reauth. 2016-02-28 13:22:19 +00:00
Adam 413b38b1c1 Fail sasl external auth immediately if cert is empty 2016-02-13 18:25:04 -05:00
Adam ecdccd6ad6 And use account here, user might be null 2016-02-13 18:19:47 -05:00
Adam e0fd118b3e Fix access path changes in ns_alist from earlier 2016-02-13 18:11:03 -05:00
Adam c10d7bdada Update chanserv secure help to reflect more accurately what it does 2016-02-13 14:41:23 -05:00
Adam 4e2ca31cf5 Rewrite access path system to be simplier and use recursion
Show where access is "from" in chanserv/status
2016-02-13 14:16:29 -05:00
Adam addd2a1987 Correct umode +I change in Changelog, is for unreal 2016-02-11 08:36:12 -05:00
Adam 4071487f80 Merge pull request #154 from SaberUK/2.0+inspfix
Fix a low risk privilege escalation exploit on InspIRCd with m_autoop.
2016-02-11 07:03:55 -06:00
Peter Powell 9c17c2d818 Fix a privilege escalation exploit on InspIRCd with m_autoop. 2016-02-10 08:56:23 +00:00
Adam dd9fcca45d Anope 2.0.4-git 2016-01-30 18:50:28 -05:00
Adam d9c0a13caf Anope 2.0.3 Release 2016-01-30 17:27:31 -05:00
Robby 5daa84c7f9 Update the dutch language file. 2016-01-30 23:26:32 +01:00
Adam b12669487f Allow /ms read to get a comma separated list of memo numbers as help describes. Show message if no memos could be displayed. 2016-01-30 16:54:20 -05:00
Robby 0e9a1e87d0 The default xop access for PROTECTME should really be SOP, not AOP. 2016-01-29 19:42:10 +01:00
Robby f118960a25 Update copyright to 2016. This was done with:
find include/ src/ lang/ docs/ modules/ *.* Config -exec sed -i 's/-20.. Anope Team/-2014 Anope Team/i' {} \;

Added missing copyright headers to files that didn't have it yet.
Fixed some whitespace and blank lines along the way.
2016-01-28 20:24:49 +01:00
Adam 5d6a71b6d2 Regenerate language files 2016-01-28 08:15:38 -05:00
Adam 23fab4ad06 Revert "Regenerate language files"
This reverts commit e955db6e85.
2016-01-28 08:15:24 -05:00
Adam 825dc5be46 Revert "Updated and fixed the Greek language."
This reverts commit f451c6cbac.
2016-01-28 08:14:58 -05:00
Robby b6fb6410c0 Update the dutch language file. 2016-01-27 19:14:12 +01:00
Robby 45dfea5ad9 Document m_xmlrpc_main opers 2016-01-27 18:04:55 +01:00
Adam d0a5316c67 Remove default session exception expiry time 2016-01-25 11:51:31 -05:00
Adam 382ab84938 Merge pull request #150 from westor7/patch-1
Updated and fixed the Greek language.
2016-01-25 10:31:47 -06:00
westor f451c6cbac Updated and fixed the Greek language.
Updated and fixed all the non-fuzzy languages items, previously all of them was incorrect.
Added new credits.
2016-01-24 17:20:00 +02:00
Adam 9645f53dc8 Update m_ssl_gnutls Windows library version to libgnutls-30 2016-01-23 22:25:19 -05:00
Adam 41802c28c6 Fix m_sql_oper to compile from the cleanup of the other day 2016-01-23 20:45:10 -05:00
Adam 97a13081e9 Fix typo in changes 2016-01-23 20:44:50 -05:00
Adam 38fcf15d62 Put maxlogins logic a few other important places 2016-01-23 10:53:32 -05:00
Adam 75dd784538 Fix hybrid to compile 2016-01-23 10:53:22 -05:00
Adam e955db6e85 Regenerate language files 2016-01-23 10:37:23 -05:00
Adam a434651e75 Update Changelogs 2016-01-23 10:36:04 -05:00
Adam 7d674726c2 Merge pull request #145 from miwob/style+copyright
Style+copyright
2016-01-23 09:19:08 -06:00
Adam be50211ae6 Merge pull request #149 from miwob/SendSQLine
Update SendSQLine() in hybrid's protocol module to use non-capsulatet…
2016-01-23 09:18:41 -06:00
Adam faa8f57bb2 Merge pull request #148 from SaberUK/2.0+18mod
Error out if any 1.8 modules are in the the module directory.
2016-01-23 09:18:32 -06:00
Adam 8cf21191fb Merge pull request #147 from miwob/temporary_xline
Update SendSGLine() in hybrid's protocol module to add support for te…
2016-01-23 09:18:12 -06:00
Adam ae847bcaf0 Merge pull request #144 from miwob/chankill_example
example.conf: announce operserv/chankill as well
2016-01-23 09:17:56 -06:00
Adam c4bbef0af8 Merge pull request #143 from staticfox/grammar
hs_group: Fix grammar
2016-01-23 09:17:44 -06:00
Adam 7953274a88 Re-lookup access in webcpanel after deleting access as the old group might be invalid 2016-01-23 10:15:01 -05:00
Adam d8eb3d4937 Apply regex sqlines on connect too 2016-01-23 08:58:08 -05:00
Adam f91f375b70 Show akill/xline ids in view 2016-01-22 10:29:44 -05:00
Adam eac25d016a Include memo mail information in ms_info 2016-01-22 10:13:05 -05:00
miwob 2356a1caab Update SendSQLine() in hybrid's protocol module to use non-capsulatet RESV message 2016-01-20 19:18:52 +01:00
Adam 164b349ef9 Fix various inconsistencies/crashes related to having multiple opers configured for the same user through combinations of os_oper/config/m_sql_oper 2016-01-19 16:25:02 -05:00
Peter Powell 2e370f6ed5 Error out if any 1.8 modules are in the the module directory. 2016-01-19 21:07:34 +00:00
miwob 9d30e1d63f Update SendSGLine() in hybrid's protocol module to add support for temporary x-lines 2016-01-19 20:07:45 +01:00
Adam 4771af1cb8 Couple user find by nick fixes 2016-01-19 08:30:35 -05:00
Adam 9c9df2ad1f Document ns_no_expire nick default 2016-01-19 08:30:06 -05:00
miwob 7f418a58da hybrid.cpp: clean up style to match with other code; update copyright header 2016-01-13 16:23:22 +01:00
miwob 510045858f example.conf: announce operserv/chankill as well 2016-01-12 20:00:08 +01:00
Matt Ullman d270910ace hs_group: Fix grammar 2016-01-12 09:31:58 -05:00
Adam 10aeba2da2 Merge pull request #142 from Zoddo/unreal4/uid
[Unreal4] Use UID/SID instead of nick/servername when possible
2016-01-03 11:36:03 -06:00
Zoddo 4e675c50e5 [Unreal4] Use UID/SID instead of nick/servername when possible 2016-01-03 16:31:45 +01:00
Adam 0a37576270 Actually there is no account here 2016-01-02 17:19:08 -05:00
Adam 8f6f2a2c47 Add sasl log category for auth log messages 2016-01-02 17:15:26 -05:00
Adam 36a465473e Add IRCDMESSAGE_SOFT_LIMIT to MD handler 2016-01-02 16:38:25 -05:00
Adam 23a0ecd0c4 unreal4: add md handler, certfp support 2015-12-30 16:11:41 -05:00
Adam 601af1b0eb Unreal 4 changes 2015-12-30 12:42:12 -05:00
Adam fb2aae1b17 Copy unreal -> unreal4 2015-12-30 12:42:03 -05:00
Adam ac984af11a Move CanAdd() check to after mask sanitization as it will remove other entries that are considered "covered by" the new mask 2015-12-29 14:04:45 -05:00
Adam d6cbd64621 Remove run-cc leftover 2015-12-29 14:04:04 -05:00
Adam e6bdc5dddd Merge pull request #141 from miwob/2.0+cmode_T_nonotice
Add support for channel mode +T to the ircd-hybrid protocol module
2015-12-29 12:57:09 -06:00
Adam ba805e30b8 Include gecos in GetNUHMask 2015-12-29 13:53:44 -05:00
Adam 6e48b1d56f Fix saset language reply 2015-12-28 17:45:44 -05:00
Michael Wobst cd6401f628 Add support for channel mode +T to the ircd-hybrid protocol module 2015-12-26 13:29:18 +01:00
Adam a25f94456d Fix race with recovering and svsnicing nicknames. Wait for first svsnick to go through before issuing the second. Fixes users sometimes svsnick colliding when recovering nicknames. 2015-12-19 13:38:47 -05:00
Adam b5228282e1 Merge commit '593ec34' into 2.0 2015-12-13 19:59:29 -05:00
Matt Ullman 593ec34ff7 os_akill: Sanity check AKILLing before modifing the akill list 2015-12-13 19:58:40 -05:00
Adam 7ce0eb219b Fixup ecdd046c80 to compile 2015-12-13 19:52:50 -05:00
miwob 99282e65a6 hybrid.cpp:SendClientIntroduction(): use a valid IP address format. In the future ircd-hybrid will reject UID messages with invalid IP addresses 2015-12-13 19:48:22 -05:00
Adam d07e60b3da Merge pull request #136 from miwob/add+CanSQLineChannel
hybrid.cpp: add missing CanSQLineChannel = true; to the protocol options
2015-12-13 18:46:14 -06:00
Adam 3da2cdb496 Only special case level -1 to everyone and not everything <0 2015-12-13 19:43:21 -05:00
Adam ecdd046c80 Add some replacement tokens for akick reason and welcome notice 2015-12-13 19:37:24 -05:00
Adam 98b35dfab2 Document m_xmlrpc_main notice 2015-12-13 19:28:31 -05:00
Adam 56abaf8498 Add notice method to m_xmlrpc_main 2015-12-13 19:27:15 -05:00
Adam 5394f5433a Fix SendNumericInternal on inspircd sending to the user's uid if dest is a uid 2015-12-13 19:21:53 -05:00
Adam c414433fae Allow wildcard searching emails 2015-12-13 19:19:00 -05:00
Adam 16d08e57df Fall back to account vhost in hs on/off 2015-12-13 19:14:44 -05:00
Adam 252a65af7e Update LOG dir in anoperc 2015-12-08 14:06:08 -05:00
Adam d40edcae69 null xline manager when removing so removexline doesn't get called 2015-11-05 20:50:10 -05:00
Adam 4c1cc0e05d Cleanup after xlines if directly removed 2015-11-04 20:51:02 -05:00
Adam 80c332bc41 Fix logonnews to prioritize the newest entries if it can't show them all 2015-11-04 20:05:01 -05:00
miwob 5a25a3807b hybrid.cpp: add missing CanSQLineChannel = true; to the protocol options 2015-10-24 12:45:19 +02:00
Robby 27a2645ed3 Fix chanserv botmodes. 2015-09-25 02:40:28 +02:00
Adam 830361e97d Check privilege name is valid in SetLevel 2015-09-24 17:22:44 -04:00
Adam 93a92bb73b Clear regex xlines on unload, which happens on shutdown, even though they are perm modules 2015-09-23 14:55:28 -04:00
Robby b9dc44ae9a Update the dutch language file. 2015-09-18 06:04:42 +02:00
Robby f52bbe22af Update my email address. 2015-09-18 05:38:44 +02:00
Robby 96d7797134 Bold code 2 -> 002. 2015-09-18 05:25:20 +02:00
Robby 9810da9829 Fix some sentences to be more correct. 2015-09-18 04:53:49 +02:00
Adam 5692abb316 Don't prevent channel destruction because persist is set. Perm mode/a bot should be assigned anyway which will prevent it. Fixes deleting bots out of perm channels causing desyncs 2015-09-17 20:35:46 -04:00
Adam 2e65bd4012 Channel::DeleteUser delets the container 2015-09-17 12:31:02 -04:00
Adam 1ac4a1d9a5 Defer channel deletion until after i/o. There are some edge cases with events kicking users mid-event that can delete them. 2015-09-17 10:07:30 -04:00
Adam 8d13a355cd Remove associated oper blocks in os_oper when accounts are deleted 2015-09-14 13:43:14 -04:00
Adam 8c4eec2b6e Update topic lock help to reflect how it works 2015-09-14 12:39:59 -04:00
Adam 776207ba67 Don't allow suspended users to login to webcpanel 2015-09-14 12:35:26 -04:00
Adam 2f5e880e57 Don't update channel last used time from ns alist access check 2015-09-14 12:24:13 -04:00
Adam 94f781726e Don't assign bots when persist is set if we aren't synced sinec we might not know of all modes 2015-09-11 14:54:48 -04:00
Adam 054c227df0 Merge pull request #120 from Alef-Burzmali/2.0+nobackupok
Fix db_flatfile to read the "nobackokay" setting
2015-09-06 16:12:22 -04:00
Adam 907e192aab Merge pull request #126 from SaberUK/2.0+typos
Fix a ton of typos.
2015-09-06 16:11:50 -04:00
Adam d6d0c883b0 Merge pull request #128 from SaberUK/2.0+destdir
Fix support for passing relative install paths to CMake.
2015-09-06 16:09:29 -04:00
Adam 7f4327e8ba Merge pull request #129 from AlphaT3ch/placeholder
Placeholder left in French Translation
2015-09-06 16:08:17 -04:00
Adam 132932ffaf Merge pull request #134 from retsofaj/2.0
Have CMake first check for libraries in any additional locations
2015-09-06 16:03:58 -04:00
Adam c007b829f7 Don't unset modes which have no privilege associated with them 2015-09-06 16:01:43 -04:00
Robby 3b647b0740 When toggling NOEXPIRE for a nickname, show the actual nickname in addition to the account name. 2015-09-02 20:36:24 +02:00
Adam 7a21648683 Only remove collide timers if the account matches on id 2015-08-20 15:04:03 -04:00
Jason Foster 389c1dbd92 Have CMake check for libraries first in any additional locations and second in the standard locations.
This allows (e.g.) using the Homebrew-installed OpenSSL instead of the system version.
2015-08-12 20:26:02 -04:00
Adam d95189a4d8 Fix webcpanel/memoserv/memos with a nonexistent channel 2015-07-31 18:26:49 -04:00
Adam e65a22ae9d Fix use after free from unloading modules which are the last one holding onto an IdentifyRequest 2015-07-31 17:07:30 -04:00
Adam 4e8cc4f786 Make secureops help less weird 2015-07-30 19:47:00 -04:00
Adam dfc18db1dd Remove unused variables from m_ldap 2015-07-23 08:25:28 -04:00
Adam 63dbd7fbf0 Set LDAP_OPT_PROTOCOL_VERSION 3 etc on reconnect, too 2015-07-23 08:23:48 -04:00
AlphaTech c1cdefe1a7 Placeholder left in French Translation 2015-07-16 15:21:13 -04:00
Peter Powell cd9a2af65d Fix support for passing relative install paths to CMake. 2015-07-15 00:28:59 +01:00
Adam 7fe0543bc6 Also UnsetExtensibles on botinfo 2015-07-14 18:52:23 -04:00
Peter Powell 2a6ad3d9fc Refuse to configure with old compilers that can't build Anope. 2015-07-13 19:26:02 -04:00
Adam 38cbff4156 Fix cmake for 2.4 once again 2015-07-13 19:25:37 -04:00
Adam a86162f287 Fix incorrect iteration when destructing modelockimpls 2015-07-13 18:02:44 -04:00
Adam ceddb8370c Unset extensibles on larger objects when they destruct
Some complex extensibles require the full object to still be alive in
their destructors to keep proper bookkeeping
2015-07-13 17:59:14 -04:00
Thomas Fargeix 040b06ad56 Fix db_flatfile to read "nobackupokay" 2015-07-11 10:27:27 +02:00
Peter Powell 1666b1a8d8 Fix a ton of typos. 2015-07-08 11:06:02 +01:00
Adam 4362f53cc3 Fix unused variable warning in cs_clone 2015-07-01 20:16:59 -04:00
Dominic Hargreaves cc616a7146 Allow PROGRAM_NAME to be set during configuration 2015-07-01 20:10:15 -04:00
Dominic Hargreaves 0f01c04b02 Allow disabling installation of extra tools (with DISABLE_TOOLS) 2015-07-01 20:09:46 -04:00
Dominic Hargreaves 4cbdf9a73b Support DESTDIR
If DESTDIR is set it should be prepended to CMAKE_INSTALL_PREFIX. See
<http://www.cmake.org/cmake/help/v3.2/variable/CMAKE_INSTALL_PREFIX.html>
2015-07-01 20:08:51 -04:00
Adam fce257dc43 Merge pull request #121 from SaberUK/2.0+cmake-improvements
Various improvements to the build system.
2015-07-01 20:00:59 -04:00
Adam ad7601b0cc Merge pull request #119 from Jyzee/irc2sql-away
irc2sql: handle away messages.
2015-07-01 19:51:29 -04:00
Adam 5be9de5d12 Merge pull request #123 from Alef-Burzmali/2.0+cs-levels
Allow opers with chanserv/access/list to view the levels list
2015-07-01 19:50:26 -04:00
Adam 02ed9a9725 #1649 don't update keepmodes during inhbait 2015-06-29 19:35:57 -04:00
Adam 074f163750 #1643 Umode +I is oper only on Unreal 2015-06-29 13:57:32 -04:00
Adam de023bab0a Don't allow registering service nicks 2015-06-29 13:47:50 -04:00
Adam 510a746f8d Add ns_identify:maxlogins to limit the max number of concurrent logins per account 2015-06-29 09:37:09 -04:00
Adam 8eb46772e6 Don't allow loading hostserv mods if there can be no hostserv 2015-06-29 08:58:31 -04:00
Adam d563aa0da8 Check name validity after unpackname() to check for bad names in questins and ptr/cname rdata 2015-06-29 08:48:08 -04:00
Adam 3e3312db25 Don't allow adding or changing bots to collide with users 2015-06-29 08:42:29 -04:00
Adam bb5c4906cc Also clear vhost on hs_off so the proto mods don't have to 2015-06-21 10:42:49 -04:00
Adam 444976e64f Update host on hs off too
Protocol modules which don't trigger this by causing a mode change
currently desync
2015-06-20 17:33:13 -04:00
Thomas Fargeix 57b614ae59 Allow opers with chanserv/access/list to view the levels list 2015-06-14 19:33:45 +02:00
Peter Powell 2f9eabdb72 Remove support for run-cc.
This tool is not useful anymore. It just slows the build down.
2015-05-17 21:27:09 +01:00
Jyzee a458f7c840 irc2sql: handle away messages. 2015-04-30 19:29:44 +02:00
Adam 65bf84cfb5 When introducing opered clients on inspircd send a fake opertype 2015-04-28 15:23:31 -04:00
Adam 5efaa5b206 Merge pull request #117 from aFreshMelon/fix-xmlrpc-php
Fix xmlrpc php
2015-04-04 09:50:57 -04:00
Sebastian 41f4c7dab6 A variety of small improvements to xmlrpc.php
Pretty simple stuff.

* Better method names
* Better DocBlocks
* Lowercase variables
2015-04-04 09:43:51 +02:00
Peter Powell 0f1936f63d Fix matching the Apple Clang variant on CMake 3.0+ 2015-04-04 03:28:46 +01:00
Peter Powell 5baa6247a9 Don't overwrite CMAKE_INSTALL_PREFIX if it has already been set. 2015-04-02 01:43:05 +01:00
Peter Powell 82f5d1d61d Remove an old Autotools limitation.
This is not needed anymore as support for Autotools was removed.
2015-04-02 01:38:31 +01:00
Sebastian dd8dd3b4a0 Make xmlrpc.php comply with PSR-2 coding standard 2015-04-01 23:28:41 +02:00
Sebastian a718223585 Remove workaround that is no longer needed
This workaround was required previously but breaks the code with the corrections to the XML-RPC response.
2015-04-01 23:27:44 +02:00
Robby- abc4851287 Update the dutch language file. 2015-03-23 02:39:18 +01:00
Adam 3d1255dbe9 Anope 2.0.3-git 2015-03-22 21:22:49 -04:00
437 changed files with 30163 additions and 56237 deletions
+5 -4
View File
@@ -1,5 +1,5 @@
___ ___
/ _ \ http://www.anope.org / _ \ https://www.anope.org/
| /_\ | _ __ _ _ _ _ ___ | /_\ | _ __ _ _ _ _ ___
| _ || '_ \/ _ \/ _ \ / _ \ | _ || '_ \/ _ \/ _ \ / _ \
| | | || | | |_| |_| | __/ | | | || | | |_| |_| | __/
@@ -7,12 +7,13 @@
| | | |
|_| IRC Services |_| IRC Services
CURVER CURVER
This program will help you to compile your Services, and ask you This program will help you to compile your services, and ask you
questions regarding the compile-time settings of it during the questions regarding the compile-time settings of it during the
process. For more options type SOURCE_DIR/Config --help process. For more options type SOURCE_DIR/Config --help
Anope is a set of Services for IRC networks that allows users to Anope is a set of services for IRC networks that allows users to
manage their nicks and channels in a secure and efficient way, manage their nicks and channels in a secure and efficient way,
and administrators to manage their network with powerful tools. and administrators to manage their network with powerful tools.
For all your Anope needs please visit our portal at www.anope.org For all your Anope needs please visit our portal at
https://www.anope.org/
+33
View File
@@ -0,0 +1,33 @@
---
name: Bug report
about: Report a non-security issue with Anope.
---
<!--
Please fill in the template below. It will help us process your bug report a lot faster. If you have multiple bugs to report then please open one issue for each bug.
-->
**Description**
**Steps to reproduce the issue:**
1.
2.
3.
**Describe the results you received:**
**Describe the results you expected:**
**Additional information you deem important (e.g. issue happens only occasionally):**
**Output of `services --version`:**
+15
View File
@@ -0,0 +1,15 @@
---
name: Feature request
about: Request that a new feature is added to Anope.
---
<!--
Please fill in the template below. It will help us process your feature request a lot faster. If you have multiple features to request then please open one issue for each feature.
-->
**Description**
**Why this would be useful**
+1
View File
@@ -0,0 +1 @@
blank_issues_enabled: false
+26
View File
@@ -0,0 +1,26 @@
<!--
Please fill in the template below. It will help us process your pull request a lot faster.
-->
## Summary
<!--
Briefly describe what this pull request changes.
-->
## Rationale
<!--
Describe why you have made this change.
-->
## Testing Environment
<!--
Describe the environment in which you have tested this change:
-->
I have tested this pull request on:
**Operating system name and version:** <!-- e.g. Linux 3.11 -->
**Compiler name and version:** <!-- e.g. GCC 4.2.0 -->
+19
View File
@@ -0,0 +1,19 @@
# Security Policy
## Supported Versions
Currently the 2.0 (stable) branch is actively receiving security fixes.
The 2.1 (development) branch is still early in development and currently only receives security fixes when they are synced from the 2.0 branch.
Version | Supported
------- | ---------
2.1.x | :warning:
2.0.x | :white_check_mark:
1.8.x | :x:
## Reporting a Vulnerability
Please do not report security vulnerabilities on GitHub. Instead, email the details to team@anope.org or get the attention of a developer in our development IRC channel at irc.anope.org #anope-devel and PM them the details.
We will triage your issue as soon as possible and try to release a fixed version within a week of receiving your report.
+6
View File
@@ -0,0 +1,6 @@
version: 2
updates:
- package-ecosystem: github-actions
directory: /
schedule:
interval: monthly
+58
View File
@@ -0,0 +1,58 @@
name: Alpine CI
on:
pull_request:
push:
schedule:
- cron: '0 0 * * 0'
jobs:
build:
if: "!contains(github.event.head_commit.message, '[skip alpine ci]')"
container: alpine:edge
runs-on: ubuntu-latest
env:
CXX: ${{ matrix.compiler }}
CXXFLAGS: -Werror
steps:
- uses: actions/checkout@v4
- name: Install dependencies
run: |
echo "http://dl-cdn.alpinelinux.org/alpine/edge/testing" >> /etc/apk/repositories
apk update
apk add \
clang \
cmake \
g++ \
gettext \
git \
gnutls-dev \
mariadb-dev \
openldap-dev \
openssl-dev \
pcre2-dev \
samurai \
sqlite-dev \
tre-dev
- name: Enable extras
run: |
for MODULE in ldap ldap_authentication ldap_oper mysql regex_pcre2 regex_posix regex_tre sql_authentication sql_log sql_oper sqlite ssl_gnutls ssl_openssl
do
ln -s $PWD/modules/extra/$MODULE.cpp $PWD/modules
done
- name: Run CMake
run: |
mkdir build && cd build
cmake -GNinja -DCMAKE_BUILD_TYPE:STRING=DEBUG -DINSTDIR:STRING=$(readlink -f ../run) ..
- name: Build Anope
run: |
ninja -C build install
strategy:
fail-fast: false
matrix:
compiler:
- clang++
- g++
+53
View File
@@ -0,0 +1,53 @@
name: Ubuntu CI
on:
- pull_request
- push
jobs:
build:
if: "!contains(github.event.head_commit.message, '[skip ubuntu ci]')"
runs-on: ubuntu-20.04
env:
CXX: ${{ matrix.compiler }}
CXXFLAGS: -Werror
steps:
- uses: actions/checkout@v4
- name: Install dependencies
run: |
sudo apt-get update --assume-yes
sudo apt-get install --assume-yes --no-install-recommends \
clang \
g++ \
gettext \
git \
libgnutls28-dev \
libldap2-dev \
libmysqlclient-dev \
libpcre2-dev \
libsqlite3-dev \
libssl-dev \
libtre-dev \
ninja-build
- name: Enable extras
run: |
for MODULE in ldap ldap_authentication ldap_oper mysql regex_pcre2 regex_posix regex_tre sql_authentication sql_log sql_oper sqlite ssl_gnutls ssl_openssl
do
ln -s ${{ github.workspace }}/modules/extra/$MODULE.cpp ${{ github.workspace }}/modules
done
- name: Run CMake
run: |
mkdir build && cd build
cmake -GNinja -DCMAKE_BUILD_TYPE:STRING=DEBUG -DINSTDIR:STRING=${{ github.workspace }}/run ..
- name: Build Anope
run: |
ninja -C ${{ github.workspace }}/build install
strategy:
fail-fast: false
matrix:
compiler:
- clang++
- g++
+35
View File
@@ -0,0 +1,35 @@
name: Windows CI
on:
pull_request:
push:
schedule:
- cron: '0 0 * * 0'
jobs:
build:
if: "!contains(github.event.head_commit.message, '[skip windows ci]')"
runs-on: windows-2019
steps:
- uses: actions/checkout@v3
- name: Setup MSBuild
uses: microsoft/setup-msbuild@v1.3
- name: Setup Conan
uses: turtlebrowser/get-conan@v1.2
with:
version: 1.59.0
- name: Install libraries
run: |
conan install ${{ github.workspace }}\src\win32 --build=missing
- name: Run CMake
run: |
mkdir ${{ github.workspace }}\build
cd ${{ github.workspace }}\build
cmake -A "x64" -G "Visual Studio 16 2019" ..
- name: Build Anope
working-directory: ${{ github.workspace }}\build
run: |
msbuild PACKAGE.vcxproj /M:3 /P:Configuration=Release /P:Platform=x64 /VERBOSITY:MINIMAL
+17 -1
View File
@@ -1,3 +1,19 @@
build/
config.cache config.cache
include/sysconf.h include/sysconf.h
build/ modules/ldap.cpp
modules/ldap_authentication.cpp
modules/ldap_oper.cpp
modules/mysql.cpp
modules/regex_pcre2.cpp
modules/regex_posix.cpp
modules/regex_tre.cpp
modules/sql_authentication.cpp
modules/sql_log.cpp
modules/sql_oper.cpp
modules/sqlite.cpp
modules/ssl_gnutls.cpp
modules/ssl_openssl.cpp
modules/stats
run/
*.mo
+15 -2
View File
@@ -1,3 +1,4 @@
(svnadmin) <svn@localhost> <svn svn@31f1291d-b8d6-0310-a050-a5561fc1590b@5417fbe8-f217-4b02-8779-1006273d7864>
Adam <adam@anope.org> <adam-@5417fbe8-f217-4b02-8779-1006273d7864> Adam <adam@anope.org> <adam-@5417fbe8-f217-4b02-8779-1006273d7864>
Adam <adam@anope.org> <adam@adam-laptop.(none)> Adam <adam@anope.org> <adam@adam-laptop.(none)>
Adam <adam@anope.org> <Adam@anope.org> Adam <adam@anope.org> <Adam@anope.org>
@@ -5,9 +6,11 @@ Adam <adam@anope.org> <Adam@drink-coca-cola.info>
Adam <adam@anope.org> <Adam@sigterm.info> Adam <adam@anope.org> <Adam@sigterm.info>
Adam Kramer <ribosome@anope.org> <ribosome ribosome@31f1291d-b8d6-0310-a050-a5561fc1590b@5417fbe8-f217-4b02-8779-1006273d7864> Adam Kramer <ribosome@anope.org> <ribosome ribosome@31f1291d-b8d6-0310-a050-a5561fc1590b@5417fbe8-f217-4b02-8779-1006273d7864>
Alvaro Toledo <atoledo@keldon.org> <atoledo atoledo@31f1291d-b8d6-0310-a050-a5561fc1590b@5417fbe8-f217-4b02-8779-1006273d7864> Alvaro Toledo <atoledo@keldon.org> <atoledo atoledo@31f1291d-b8d6-0310-a050-a5561fc1590b@5417fbe8-f217-4b02-8779-1006273d7864>
Attila Molnar <attilamolnar@hush.com>
Björn Stiddien <keeper@anope.org> <keeper keeper@31f1291d-b8d6-0310-a050-a5561fc1590b@5417fbe8-f217-4b02-8779-1006273d7864> Björn Stiddien <keeper@anope.org> <keeper keeper@31f1291d-b8d6-0310-a050-a5561fc1590b@5417fbe8-f217-4b02-8779-1006273d7864>
Charles Kingsley <chaz@anope.org> Charles Kingsley <chaz@anope.org>
Charles Kingsley <chaz@anope.org> <sjaz@5417fbe8-f217-4b02-8779-1006273d7864> Charles Kingsley <chaz@anope.org> <sjaz@5417fbe8-f217-4b02-8779-1006273d7864>
Cronus <cronus@nite-serv.com>
Daniel Engel <dane@zero.org> <dane dane@31f1291d-b8d6-0310-a050-a5561fc1590b@5417fbe8-f217-4b02-8779-1006273d7864> Daniel Engel <dane@zero.org> <dane dane@31f1291d-b8d6-0310-a050-a5561fc1590b@5417fbe8-f217-4b02-8779-1006273d7864>
David Robson <rob@anope.org> <robbeh@5417fbe8-f217-4b02-8779-1006273d7864> David Robson <rob@anope.org> <robbeh@5417fbe8-f217-4b02-8779-1006273d7864>
David Robson <rob@anope.org> <rob rob@31f1291d-b8d6-0310-a050-a5561fc1590b@5417fbe8-f217-4b02-8779-1006273d7864> David Robson <rob@anope.org> <rob rob@31f1291d-b8d6-0310-a050-a5561fc1590b@5417fbe8-f217-4b02-8779-1006273d7864>
@@ -15,6 +18,7 @@ Dennis Friis <peavey@inspircd.org> <peavey peavey@inspircd.org@5417fbe8-f217-4b0
Fabio Scotoni <cculex@gmail.com> Fabio Scotoni <cculex@gmail.com>
Florian Schulze <certus@anope.org> <certus certus@31f1291d-b8d6-0310-a050-a5561fc1590b@5417fbe8-f217-4b02-8779-1006273d7864> Florian Schulze <certus@anope.org> <certus certus@31f1291d-b8d6-0310-a050-a5561fc1590b@5417fbe8-f217-4b02-8779-1006273d7864>
Gabriel Acevedo H. <drstein@anope.org> <drstein drstein@31f1291d-b8d6-0310-a050-a5561fc1590b@5417fbe8-f217-4b02-8779-1006273d7864> Gabriel Acevedo H. <drstein@anope.org> <drstein drstein@31f1291d-b8d6-0310-a050-a5561fc1590b@5417fbe8-f217-4b02-8779-1006273d7864>
Harakiri <harakiri@overstack.fr>
Jan Milants <viper@anope.org> Jan Milants <viper@anope.org>
Jan Milants <viper@anope.org> <jantje_85@5417fbe8-f217-4b02-8779-1006273d7864> Jan Milants <viper@anope.org> <jantje_85@5417fbe8-f217-4b02-8779-1006273d7864>
Jan Milants <viper@anope.org> <viper viper@31f1291d-b8d6-0310-a050-a5561fc1590b@5417fbe8-f217-4b02-8779-1006273d7864> Jan Milants <viper@anope.org> <viper viper@31f1291d-b8d6-0310-a050-a5561fc1590b@5417fbe8-f217-4b02-8779-1006273d7864>
@@ -23,15 +27,24 @@ Jens Voss <dukepyrolator@anope.org> <DukePyrolator@5417fbe8-f217-4b02-8779-10062
Jens Voss <dukepyrolator@anope.org> <DukePyrolator@anope.org> Jens Voss <dukepyrolator@anope.org> <DukePyrolator@anope.org>
Jens Voss <dukepyrolator@anope.org> Jens Voß <jens@pyrobook.(none)> Jens Voss <dukepyrolator@anope.org> Jens Voß <jens@pyrobook.(none)>
Lee Holmes <lethality@anope.org> Lee Holmes <lethality@anope.org>
Lee Holmes <lethality@anope.org> <lee@lethality.me.uk>
Mark Summers <mark@goopler.net> <mark mark@31f1291d-b8d6-0310-a050-a5561fc1590b@5417fbe8-f217-4b02-8779-1006273d7864> Mark Summers <mark@goopler.net> <mark mark@31f1291d-b8d6-0310-a050-a5561fc1590b@5417fbe8-f217-4b02-8779-1006273d7864>
Matt Schatz <genius3000@g3k.solutions>
Matt Ullman <matt@airraidsirens.com> <blindsight@gamesurge.net>
Michael Hazell <michaelhazell@hotmail.com> <Techman-@users.noreply.github.com>
Michael Wobst <wobst.michael@web.de>
Michael Wobst <wobst.michael@web.de> <michael@static.163.129.251.148.clients.your-server.de>
Michael Wobst <wobst.michael@web.de> <michael@wobst.at>
Naram Qashat <cyberbotx@anope.org> <cyberbotx@5417fbe8-f217-4b02-8779-1006273d7864> Naram Qashat <cyberbotx@anope.org> <cyberbotx@5417fbe8-f217-4b02-8779-1006273d7864>
Naram Qashat <cyberbotx@anope.org> <cyberbotx@cyberbotx.com> Naram Qashat <cyberbotx@anope.org> <cyberbotx@cyberbotx.com>
Naram Qashat <cyberbotx@anope.org> <Naram Qashat cyberbotx@cyberbotx.com@5417fbe8-f217-4b02-8779-1006273d7864> Naram Qashat <cyberbotx@anope.org> <Naram Qashat cyberbotx@cyberbotx.com@5417fbe8-f217-4b02-8779-1006273d7864>
Pieter Bootsma <geniusdex@anope.org> <geniusdex geniusdex@31f1291d-b8d6-0310-a050-a5561fc1590b@5417fbe8-f217-4b02-8779-1006273d7864> Pieter Bootsma <geniusdex@anope.org> <geniusdex geniusdex@31f1291d-b8d6-0310-a050-a5561fc1590b@5417fbe8-f217-4b02-8779-1006273d7864>
Robby <robby@chat.be> Robby <robby@chatbelgie.be> <robby@anope.org>
Robby <robby@chatbelgie.be> <robby@chat.be>
Robin Burchell <w00t@inspircd.org> <rburchell@5417fbe8-f217-4b02-8779-1006273d7864> Robin Burchell <w00t@inspircd.org> <rburchell@5417fbe8-f217-4b02-8779-1006273d7864>
Robin Burchell <w00t@inspircd.org> <Robin Burchell w00t@inspircd.org@5417fbe8-f217-4b02-8779-1006273d7864> Robin Burchell <w00t@inspircd.org> <Robin Burchell w00t@inspircd.org@5417fbe8-f217-4b02-8779-1006273d7864>
Sadie Powell <sadie@witchery.services> Peter Powell <petpow@saberuk.com>
Sebastian Barfurth <github@afreshmelon.com>
Sebastian V. <hal9000@denorastats.org> Sebastian V. <hal9000@denorastats.org>
Sebastian V. <hal9000@denorastats.org> <pimpmylinux@5417fbe8-f217-4b02-8779-1006273d7864> Sebastian V. <hal9000@denorastats.org> <pimpmylinux@5417fbe8-f217-4b02-8779-1006273d7864>
(svnadmin) <svn@localhost> <svn svn@31f1291d-b8d6-0310-a050-a5561fc1590b@5417fbe8-f217-4b02-8779-1006273d7864>
Trystan S. Lee <trystan@nomadirc.net> <trystan trystan@31f1291d-b8d6-0310-a050-a5561fc1590b@5417fbe8-f217-4b02-8779-1006273d7864> Trystan S. Lee <trystan@nomadirc.net> <trystan trystan@31f1291d-b8d6-0310-a050-a5561fc1590b@5417fbe8-f217-4b02-8779-1006273d7864>
-16
View File
@@ -1,16 +0,0 @@
language: cpp
compiler:
- gcc
before_script:
- mkdir build
- cd build
- cmake -DINSTDIR:STRING=~/services -DDEFUMASK:STRING=077 -DCMAKE_BUILD_TYPE:STRING=DEBUG -DUSE_RUN_CC_PL:BOOLEAN=ON ..
script:
- make
notifications:
irc:
- "irc.anope.org#anope-devel"
+130 -253
View File
@@ -1,78 +1,10 @@
# This usage of CMake requires at least version 2.4 (checks are made to determine what to use when certain versions lack functions) # This usage of CMake requires at least version 3.8
cmake_minimum_required(VERSION 2.4 FATAL_ERROR) cmake_minimum_required(VERSION 3.8 FATAL_ERROR)
if(COMMAND cmake_policy)
cmake_policy(SET CMP0003 NEW)
if(POLICY CMP0026)
cmake_policy(SET CMP0026 OLD)
endif(POLICY CMP0026)
if(POLICY CMP0007)
cmake_policy(SET CMP0007 OLD)
endif(POLICY CMP0007)
endif(COMMAND cmake_policy)
# If the Source dir and the Binary dir are the same, we are building in-source, which we will disallow due to Autotools being there (but only on non-Windows)
if(${CMAKE_CURRENT_SOURCE_DIR} STREQUAL ${CMAKE_CURRENT_BINARY_DIR} AND NOT WIN32)
message(FATAL_ERROR "You can not use CMake to build Anope from the root of it's source tree! Remove the CMakeCache.txt file from this directory, then create a separate directory (either below this directory or elsewhere), and then re-run CMake from there.")
endif(${CMAKE_CURRENT_SOURCE_DIR} STREQUAL ${CMAKE_CURRENT_BINARY_DIR} AND NOT WIN32)
# Set the project as C++ primarily, but have C enabled for the checks required later # Set the project as C++ primarily, but have C enabled for the checks required later
project(Anope CXX) project(Anope CXX)
enable_language(C) enable_language(C)
# Detect the version of CMake for the later conditional checks
execute_process(COMMAND ${CMAKE_COMMAND} --version OUTPUT_VARIABLE VERSION OUTPUT_STRIP_TRAILING_WHITESPACE)
string(REGEX REPLACE "cmake version 2\\.(.*)" "\\1" ONLY_VERSION "${VERSION}")
string(REGEX MATCH "-patch .*$" HAS_PATCH "${ONLY_VERSION}")
if(HAS_PATCH)
string(REGEX REPLACE "(.*)-patch .*" "\\1" MINOR_VERSION "${ONLY_VERSION}")
string(REGEX REPLACE ".*-patch (.*)" "\\1" PATCH_VERSION "${ONLY_VERSION}")
else(HAS_PATCH)
string(REGEX MATCH "\\." HAS_DOT "${ONLY_VERSION}")
if(HAS_DOT)
string(REGEX REPLACE "(.*)\\..*" "\\1" MINOR_VERSION "${ONLY_VERSION}")
string(REGEX REPLACE ".*\\.(.*)" "\\1" PATCH_VERSION "${ONLY_VERSION}")
else(HAS_DOT)
string(REGEX REPLACE "(.*)-beta" "\\1" MINOR_VERSION "${ONLY_VERSION}")
if(MINOR_VERSION STREQUAL "4-1\n")
set(PATCH_VERSION 1)
else(MINOR_VERSION STREQUAL "4-1\n")
set(PATCH_VERSION 0)
endif(MINOR_VERSION STREQUAL "4-1\n")
set(MINOR_VERSION 4)
endif(HAS_DOT)
endif(HAS_PATCH)
# Detect is we are using CMake 2.6 or better, these versions include functions that require less work than CMake 2.4 does
if(MINOR_VERSION GREATER 5)
set(CMAKE26_OR_BETTER TRUE)
set(CMAKE248_OR_BETTER TRUE)
set(CMAKE244_OR_BETTER TRUE)
set(CMAKE242_OR_BETTER TRUE)
else(MINOR_VERSION GREATER 5)
set(CMAKE26_OR_BETTER FALSE)
# Also detect if we are using CMake 2.4.8 or better, the FIND sub-command of list() is non-existant in earlier versions
if(PATCH_VERSION GREATER 7)
set(CMAKE248_OR_BETTER TRUE)
set(CMAKE244_OR_BETTER TRUE)
set(CMAKE242_OR_BETTER TRUE)
else(PATCH_VERSION GREATER 7)
set(CMAKE248_OR_BETTER FALSE)
# Also detect if we are using CMake 2.4.4 or better, the CheckCXXCompilerFlag module and SORT sub-command of list() are non-existant in earlier versions
if(PATCH_VERSION GREATER 3)
set(CMAKE244_OR_BETTER TRUE)
set(CMAKE242_OR_BETTER TRUE)
else(PATCH_VERSION GREATER 3)
set(CMAKE244_OR_BETTER FALSE)
# ALSO detect if we are using CMake 2.4.2 or better, the APPEND sub-command of list() is non-existant in earlier versions
if(PATCH_VERSION GREATER 1)
set(CMAKE242_OR_BETTER TRUE)
else(PATCH_VERSION GREATER 1)
set(CMAKE242_OR_BETTER FALSE)
endif(PATCH_VERSION GREATER 1)
endif(PATCH_VERSION GREATER 3)
endif(PATCH_VERSION GREATER 7)
endif(MINOR_VERSION GREATER 5)
# Override the module include path to include our directory, for our Anope.cmake, as well as we are using our own version of the NSIS template # Override the module include path to include our directory, for our Anope.cmake, as well as we are using our own version of the NSIS template
set(CMAKE_MODULE_PATH ${Anope_SOURCE_DIR}/cmake) set(CMAKE_MODULE_PATH ${Anope_SOURCE_DIR}/cmake)
@@ -85,8 +17,16 @@ set(ENV{LC_ALL} C)
set(DEFAULT_LIBRARY_DIRS) set(DEFAULT_LIBRARY_DIRS)
set(DEFAULT_INCLUDE_DIRS) set(DEFAULT_INCLUDE_DIRS)
# We require C++17 to build
set(CMAKE_CXX_EXTENSIONS OFF)
set(CMAKE_CXX_STANDARD 17)
set(CMAKE_CXX_STANDARD_REQUIRED ON)
# Put modules in their own folder
set_property(GLOBAL PROPERTY USE_FOLDERS ON)
# If we are using a GNU compiler (have to use CXX because it seems to fail on C), we will be able to determine it's default paths for libraries and includes # If we are using a GNU compiler (have to use CXX because it seems to fail on C), we will be able to determine it's default paths for libraries and includes
if(CMAKE_COMPILER_IS_GNUCXX OR ${CMAKE_CXX_COMPILER_ID} STREQUAL "Clang") if(CMAKE_COMPILER_IS_GNUCXX OR "${CMAKE_CXX_COMPILER_ID}" MATCHES "Clang$")
# First look for the compiler's default library directories # First look for the compiler's default library directories
execute_process(COMMAND ${CMAKE_C_COMPILER} -print-search-dirs OUTPUT_VARIABLE LINES OUTPUT_STRIP_TRAILING_WHITESPACE) execute_process(COMMAND ${CMAKE_C_COMPILER} -print-search-dirs OUTPUT_VARIABLE LINES OUTPUT_STRIP_TRAILING_WHITESPACE)
# Find only the part after "libraries: " # Find only the part after "libraries: "
@@ -94,9 +34,9 @@ if(CMAKE_COMPILER_IS_GNUCXX OR ${CMAKE_CXX_COMPILER_ID} STREQUAL "Clang")
# Replace the colons in the list with semicolons (only when not on MinGW, which uses semicolons already), and if on MinGW, just copy the line # Replace the colons in the list with semicolons (only when not on MinGW, which uses semicolons already), and if on MinGW, just copy the line
if(NOT MINGW) if(NOT MINGW)
string(REGEX REPLACE ":" ";" LIBRARIES ${LINE}) string(REGEX REPLACE ":" ";" LIBRARIES ${LINE})
else(NOT MINGW) else()
set(LIBRARIES "${LINE}") set(LIBRARIES "${LINE}")
endif(NOT MINGW) endif()
# Iterate through the libraries # Iterate through the libraries
foreach(LIBRARY ${LIBRARIES}) foreach(LIBRARY ${LIBRARIES})
# Check if the first character is an equal sign, and skip that library directory as it is (I believe) the primary default and shows up later in the list anyways # Check if the first character is an equal sign, and skip that library directory as it is (I believe) the primary default and shows up later in the list anyways
@@ -104,13 +44,13 @@ if(CMAKE_COMPILER_IS_GNUCXX OR ${CMAKE_CXX_COMPILER_ID} STREQUAL "Clang")
if(NOT FIRST_CHAR STREQUAL "=") if(NOT FIRST_CHAR STREQUAL "=")
# If the directory had no = in front of it, make sure it's absolute and add it to the list of default library directories # If the directory had no = in front of it, make sure it's absolute and add it to the list of default library directories
get_filename_component(LIBRARY ${LIBRARY} ABSOLUTE) get_filename_component(LIBRARY ${LIBRARY} ABSOLUTE)
append_to_list(DEFAULT_LIBRARY_DIRS ${LIBRARY}) list(APPEND DEFAULT_LIBRARY_DIRS ${LIBRARY})
endif(NOT FIRST_CHAR STREQUAL "=") endif()
endforeach(LIBRARY) endforeach()
# Remove duplicate entries from the list # Remove duplicate entries from the list
if(DEFAULT_LIBRARY_DIRS) if(DEFAULT_LIBRARY_DIRS)
remove_list_duplicates(DEFAULT_LIBRARY_DIRS) list(REMOVE_DUPLICATES DEFAULT_LIBRARY_DIRS)
endif(DEFAULT_LIBRARY_DIRS) endif()
# Create a temporary file to test for the default include directories # Create a temporary file to test for the default include directories
FILE(WRITE empty.cpp "") FILE(WRITE empty.cpp "")
# Next, we look for the compiler's default include directories # Next, we look for the compiler's default include directories
@@ -127,11 +67,11 @@ if(CMAKE_COMPILER_IS_GNUCXX OR ${CMAKE_CXX_COMPILER_ID} STREQUAL "Clang")
# If the line has the following on it, the next lines will contain directory names # If the line has the following on it, the next lines will contain directory names
if(LINE STREQUAL "#include <...> search starts here:") if(LINE STREQUAL "#include <...> search starts here:")
set(IN_SEARCH TRUE) set(IN_SEARCH TRUE)
else(LINE STREQUAL "#include <...> search starts here:") else()
# If the line has the following on it, we hit the end of the list # If the line has the following on it, we hit the end of the list
if(LINE STREQUAL "End of search list.") if(LINE STREQUAL "End of search list.")
set(IN_SEARCH FALSE) set(IN_SEARCH FALSE)
else(LINE STREQUAL "End of search list.") else()
# If we are within the block between the above two lines... # If we are within the block between the above two lines...
if(IN_SEARCH) if(IN_SEARCH)
# Get everything but the first character of the line # Get everything but the first character of the line
@@ -143,47 +83,16 @@ if(CMAKE_COMPILER_IS_GNUCXX OR ${CMAKE_CXX_COMPILER_ID} STREQUAL "Clang")
# Convert the path to an absolute one, just in case it wasn't # Convert the path to an absolute one, just in case it wasn't
get_filename_component(INCLUDE ${INCLUDE} ABSOLUTE) get_filename_component(INCLUDE ${INCLUDE} ABSOLUTE)
# Add that directory to the list of default include directories # Add that directory to the list of default include directories
append_to_list(DEFAULT_INCLUDE_DIRS ${INCLUDE}) list(APPEND DEFAULT_INCLUDE_DIRS ${INCLUDE})
endif(IN_SEARCH) endif()
endif(LINE STREQUAL "End of search list.") endif()
endif(LINE STREQUAL "#include <...> search starts here:") endif()
endforeach(LINE) endforeach()
# Remove duplicate entries from the list # Remove duplicate entries from the list
if(DEFAULT_INCLUDE_DIRS) if(DEFAULT_INCLUDE_DIRS)
remove_list_duplicates(DEFAULT_INCLUDE_DIRS) list(REMOVE_DUPLICATES DEFAULT_INCLUDE_DIRS)
endif(DEFAULT_INCLUDE_DIRS) endif()
endif(CMAKE_COMPILER_IS_GNUCXX OR ${CMAKE_CXX_COMPILER_ID} STREQUAL "Clang") endif()
# If we are using Visual Studio, locate the path of the Windows Server 2008 SDK or Windows Server 2003 Platform SDK, depending on which is installed
if(MSVC)
# If the path comes up as "/registry" from any of these, the path wasn't found, otherwise, we'll set WSDK_PATH to the corresponding path
# Look for the 2008 SDK under HKLM first
get_filename_component(WSDK2008_PATH "[HKEY_LOCAL_MACHINE\\SOFTWARE\\Microsoft\\Microsoft SDKs\\Windows;CurrentInstallFolder]" ABSOLUTE CACHE)
if(WSDK2008_PATH STREQUAL "/registry")
# If not found, look for the 2003 SDK under HKLM
get_filename_component(WSDK2003_PATH "[HKEY_LOCAL_MACHINE\\SOFTWARE\\Microsoft\\MicrosoftSDK\\InstalledSDKs\\D2FF9F89-8AA2-4373-8A31-C838BF4DBBE1;Install Dir]" ABSOLUTE CACHE)
if(WSDK2003_PATH STREQUAL "/registry")
# If not found, look for the 2008 SDK under HKCU
get_filename_component(WSDK2008_PATH "[HKEY_CURRENT_USER\\SOFTWARE\\Microsoft\\Microsoft SDKs\\Windows;CurrentInstallFolder]" ABSOLUTE CACHE)
if(WSDK2008_PATH STREQUAL "/registry")
# If not found, look for the 2003 SDK under HKCU
get_filename_component(WSDK2003_PATH "[HKEY_CURRENT_USER\\SOFTWARE\\Microsoft\\MicrosoftSDK\\InstalledSDKs\\D2FF9F89-8AA2-4373-8A31-C838BF4DBBE1;Install Dir]" ABSOLUTE CACHE)
if(WSDK2003_PATH STREQUAL "/registry")
# The SDK was never found, set the path to nothing
set(WSDK_PATH "")
else(WSDK2003_PATH STREQUAL "/registry")
set(WSDK_PATH "${WSDK2003_PATH}")
endif(WSDK2003_PATH STREQUAL "/registry")
else(WSDK2008_PATH STREQUAL "/registry")
set(WSDK_PATH "${WSDK2008_PATH}")
endif(WSDK2008_PATH STREQUAL "/registry")
else(WSDK2003_PATH STREQUAL "/registry")
set(WSDK_PATH "${WSDK2003_PATH}")
endif(WSDK2003_PATH STREQUAL "/registry")
else(WSDK2008_PATH STREQUAL "/registry")
set(WSDK_PATH "${WSDK2008_PATH}")
endif(WSDK2008_PATH STREQUAL "/registry")
endif(MSVC)
# If the user specifies -DCMAKE_BUILD_TYPE on the command line, take their definition # If the user specifies -DCMAKE_BUILD_TYPE on the command line, take their definition
# and dump it in the cache along with proper documentation, otherwise set CMAKE_BUILD_TYPE # and dump it in the cache along with proper documentation, otherwise set CMAKE_BUILD_TYPE
@@ -192,57 +101,67 @@ endif(MSVC)
if(NOT MSVC) if(NOT MSVC)
if(CMAKE_BUILD_TYPE) if(CMAKE_BUILD_TYPE)
set(CMAKE_BUILD_TYPE ${CMAKE_BUILD_TYPE} CACHE STRING "Choose the type of build, options are: None(CMAKE_CXX_FLAGS or CMAKE_C_FLAGS used) Debug Release RelWithDebInfo MinSizeRel.") set(CMAKE_BUILD_TYPE ${CMAKE_BUILD_TYPE} CACHE STRING "Choose the type of build, options are: None(CMAKE_CXX_FLAGS or CMAKE_C_FLAGS used) Debug Release RelWithDebInfo MinSizeRel.")
else(CMAKE_BUILD_TYPE) else()
set(CMAKE_BUILD_TYPE DEBUG CACHE STRING "Choose the type of build, options are: None(CMAKE_CXX_FLAGS or CMAKE_C_FLAGS used) Debug Release RelWithDebInfo MinSizeRel.") set(CMAKE_BUILD_TYPE DEBUG CACHE STRING "Choose the type of build, options are: None(CMAKE_CXX_FLAGS or CMAKE_C_FLAGS used) Debug Release RelWithDebInfo MinSizeRel.")
endif(CMAKE_BUILD_TYPE) endif()
endif(NOT MSVC) endif()
# If running under MinGW, we have to force the resource compiler settings (hopefully this will be fixed in a later version of CMake) # If running under MinGW, we have to force the resource compiler settings (hopefully this will be fixed in a later version of CMake)
if(MINGW) if(MINGW)
set(CMAKE_RC_COMPILER_INIT windres) set(CMAKE_RC_COMPILER_INIT windres)
enable_language(RC) enable_language(RC)
set(CMAKE_RC_COMPILE_OBJECT "<CMAKE_RC_COMPILER> <FLAGS> <DEFINES> -o <OBJECT> <SOURCE>") set(CMAKE_RC_COMPILE_OBJECT "<CMAKE_RC_COMPILER> <FLAGS> <DEFINES> -o <OBJECT> <SOURCE>")
endif(MINGW) endif()
# Include the checking functions used later in this CMakeLists.txt # Include the checking functions used later in this CMakeLists.txt
include(CheckFunctionExists) include(CheckFunctionExists)
include(CheckIncludeFile)
include(CheckTypeSize) include(CheckTypeSize)
include(CheckLibraryExists) include(CheckLibraryExists)
if(CMAKE244_OR_BETTER) include(CheckCXXCompilerFlag)
include(CheckCXXCompilerFlag)
else(CMAKE244_OR_BETTER)
include(TestCXXAcceptsFlag)
endif(CMAKE244_OR_BETTER)
# If extra include directories were specified, tell cmake about them. # If extra include directories were specified, tell cmake about them.
if(EXTRA_INCLUDE) if(EXTRA_INCLUDE)
include_directories(${EXTRA_INCLUDE}) include_directories(${EXTRA_INCLUDE})
endif(EXTRA_INCLUDE) endif()
# If extra library directories were specified, tell cmake about them. # If extra library directories were specified, tell cmake about them.
if(EXTRA_LIBS) if(EXTRA_LIBS)
link_directories(${EXTRA_LIBS}) link_directories(${EXTRA_LIBS})
endif(EXTRA_LIBS) endif()
# setup conan
if(EXISTS "${CMAKE_CURRENT_SOURCE_DIR}/conanbuildinfo.cmake")
include("${CMAKE_CURRENT_SOURCE_DIR}/conanbuildinfo.cmake")
conan_basic_setup()
endif()
# Find gettext # Find gettext
find_package(Gettext) find_package(Gettext)
find_package(Intl)
# Add an optional variable for using run-cc.pl for building, Perl will be checked later regardless of this setting if(GETTEXT_FOUND AND Intl_FOUND)
option(USE_RUN_CC_PL "Use run-cc.pl for building" OFF) set(HAVE_LOCALIZATION ON)
option(USE_PCH "Use precompiled headers" OFF) include_directories(${Intl_INCLUDE_DIRS})
else()
message("Unable to find gettext and libintl; disabling localization")
set(HAVE_LOCALIZATION OFF)
endif()
# Use the following directories as includes # Use the following directories as includes
# Note that it is important the binary include directory comes before the include_directories(
# source include directory so the precompiled headers work correctly. ${Anope_BINARY_DIR}/include
include_directories(${Anope_BINARY_DIR}/include ${Anope_SOURCE_DIR}/include ${Anope_BINARY_DIR}/language ${Anope_SOURCE_DIR}/modules/pseudoclients) ${Anope_SOURCE_DIR}/include
${Anope_SOURCE_DIR}/vendor
)
# Pass on REPRODUCIBLE_BUILD
if(REPRODUCIBLE_BUILD)
add_definitions(-DREPRODUCIBLE_BUILD)
endif()
# If using Windows, always add the _WIN32 define
if(WIN32) if(WIN32)
add_definitions(-D_WIN32) # If using Windows, include the windows specific folder for anope_windows.h
# And include the windows specific folder for our anope_windows.h
include_directories(${Anope_SOURCE_DIR}/src/win32) include_directories(${Anope_SOURCE_DIR}/src/win32)
endif(WIN32) endif()
# If using Visual Studio, set the C++ flags accordingly # If using Visual Studio, set the C++ flags accordingly
if(MSVC) if(MSVC)
@@ -252,105 +171,76 @@ if(MSVC)
string(REPLACE "/W3 " "" CMAKE_CXX_FLAGS ${CMAKE_CXX_FLAGS}) string(REPLACE "/W3 " "" CMAKE_CXX_FLAGS ${CMAKE_CXX_FLAGS})
# Set the compile flags to have warnings on the max setting (but disable a few annoying ones), exception handling turned on, the proper defines # Set the compile flags to have warnings on the max setting (but disable a few annoying ones), exception handling turned on, the proper defines
set(CXXFLAGS "${CXXFLAGS} /W4 /wd4100 /wd4127 /wd4250 /wd4251 /wd4355 /wd4706 /wd4800 /wd4996 /EHs") set(CXXFLAGS "${CXXFLAGS} /W4 /wd4100 /wd4127 /wd4250 /wd4251 /wd4355 /wd4706 /wd4800 /wd4996 /EHs")
add_definitions(-DMSVCPP -D_CRT_SECURE_NO_WARNINGS) add_definitions(-D_CRT_SECURE_NO_WARNINGS)
# Otherwise, we're not using Visual Studio # Otherwise, we're not using Visual Studio
else(MSVC) else()
# Set the compile flags to have all warnings on (including shadowed variables) # Set the compile flags to have all warnings on (including shadowed variables)
set(CXXFLAGS "${CXXFLAGS} -Wall -Wshadow") set(CXXFLAGS "${CXXFLAGS} -fvisibility=hidden -fvisibility-inlines-hidden -Wall -Wextra -Wformat=2 -Wmissing-format-attribute -Wpedantic -Wno-format-nonliteral -Wno-format-zero-length -Wno-unused-parameter ${CMAKE_CXX_FLAGS}")
# If on a *nix system, also set the compile flags to remove GNU extensions (favor ISO C++) as well as reject non-ISO C++ code, also remove all leading underscores in exported symbols (only on GNU compiler) endif()
if(UNIX)
set(CXXFLAGS "${CXXFLAGS} -ansi -pedantic ${CMAKE_CXX_FLAGS}")
if (CMAKE_CXX_COMPILER_ID STREQUAL "GNU")
set(CXXFLAGS "${CXXFLAGS} -Wno-long-long -fno-leading-underscore")
endif(CMAKE_CXX_COMPILER_ID STREQUAL "GNU")
# If we aren't on a *nix system, we are using MinGW
else(UNIX)
# Also, if we are building under MinGW, add another define for MinGW
if(MINGW)
add_definitions(-DMINGW)
endif(MINGW)
endif(UNIX)
endif(MSVC)
# If CMake has found that the given system requires a special library for dl* calls, include it with the linker flags # If CMake has found that the given system requires a special library for dl* calls, include it with the linker flags
if(CMAKE_DL_LIBS) if(CMAKE_DL_LIBS)
append_to_list(LINK_LIBS ${CMAKE_DL_LIBS}) list(APPEND LINK_LIBS ${CMAKE_DL_LIBS})
endif(CMAKE_DL_LIBS) endif()
# Under MinGW, the -shared flag isn't properly set in the module-specific linker flags, add it from the C flags for shared libraries # Under MinGW, the -shared flag isn't properly set in the module-specific linker flags, add it from the C flags for shared libraries
if(MINGW) if(MINGW)
set(CMAKE_MODULE_LINKER_FLAGS "${CMAKE_MODULE_LINKER_FLAGS} ${CMAKE_SHARED_LIBRARY_CREATE_C_FLAGS}") set(CMAKE_MODULE_LINKER_FLAGS "${CMAKE_MODULE_LINKER_FLAGS} ${CMAKE_SHARED_LIBRARY_CREATE_C_FLAGS}")
endif(MINGW) endif()
# Under Windows, we set the executable name for Anope to be anope if(NOT PROGRAM_NAME)
if(WIN32)
set(PROGRAM_NAME anope) set(PROGRAM_NAME anope)
# Under *nix, we set the executable name for Anope to be services endif()
else(WIN32)
set(PROGRAM_NAME services)
endif(WIN32)
# If we are not using Visual Studio, we'll run the following checks # If we are not using Visual Studio, we'll run the following checks
if(NOT MSVC) if(NOT MSVC)
# Check if the C++ compiler can accept the -pipe flag, and add it to the compile flags if it works # Check if the C++ compiler can accept the -pipe flag, and add it to the compile flags if it works
if(CMAKE244_OR_BETTER) check_cxx_compiler_flag(-pipe HAVE_PIPE_FLAG)
# If using CMake 2.4.4 or better, we can use check_cxx_compiler_flag
check_cxx_compiler_flag(-pipe HAVE_PIPE_FLAG)
else(CMAKE244_OR_BETTER)
# If using CMake 2.4.3 or older, we will use check_cxx_accepts_flags instead
check_cxx_accepts_flag(-pipe HAVE_PIPE_FLAG)
endif(CMAKE244_OR_BETTER)
# If the flag was accepted, add it to the list of flags # If the flag was accepted, add it to the list of flags
if(HAVE_PIPE_FLAG) if(HAVE_PIPE_FLAG)
set(CXXFLAGS "${CXXFLAGS} -pipe") set(CXXFLAGS "${CXXFLAGS} -pipe")
endif(HAVE_PIPE_FLAG) endif()
# The following are additional library checks, they are not required for Windows # The following are additional library checks, they are not required for Windows
if(NOT WIN32) if(NOT WIN32)
# Check if socket is within the socket library (if the library exists), and add it to the linker flags if needed # Check if socket is within the socket library (if the library exists), and add it to the linker flags if needed
check_library_exists(socket socket "" HAVE_SOCKET_LIB) check_library_exists(socket socket "" HAVE_SOCKET_LIB)
if(HAVE_SOCKET_LIB) if(HAVE_SOCKET_LIB)
append_to_list(LINK_LIBS socket) list(APPEND LINK_LIBS socket)
endif(HAVE_SOCKET_LIB) endif()
# Check if inet_addr is within the nsl library (if the library exists), and add it to the linker flags if needed # Check if inet_addr is within the nsl library (if the library exists), and add it to the linker flags if needed
check_library_exists(nsl inet_addr "" HAVE_NSL_LIB) check_library_exists(nsl inet_addr "" HAVE_NSL_LIB)
if(HAVE_NSL_LIB) if(HAVE_NSL_LIB)
append_to_list(LINK_LIBS nsl) list(APPEND LINK_LIBS nsl)
endif(HAVE_NSL_LIB) endif()
# Check if pthread_create is within the pthread library (if the library exists), and add it to the linker flags if needed # Check if pthread_create is within the pthread library (if the library exists), and add it to the linker flags if needed
check_library_exists(pthread pthread_create "" HAVE_PTHREAD) check_library_exists(pthread pthread_create "" HAVE_PTHREAD)
if(HAVE_PTHREAD) if(HAVE_PTHREAD)
if(NOT APPLE) if(NOT APPLE)
set(LDFLAGS "${LDFLAGS} -pthread") set(LDFLAGS "${LDFLAGS} -pthread")
endif(NOT APPLE) endif()
else(HAVE_PTHREAD) else()
message(FATAL_ERROR "The pthread library is required to build Anope") message(FATAL_ERROR "The pthread library is required to build Anope")
endif(HAVE_PTHREAD) endif()
endif(NOT WIN32) endif()
endif(NOT MSVC) endif()
# If DEFUMASK wasn't passed to CMake, set a default depending on if RUNGROUP was passed in or not # If DEFUMASK wasn't passed to CMake, set a default depending on if RUNGROUP was passed in or not
if(NOT DEFUMASK) if(NOT DEFUMASK)
if(RUNGROUP) if(RUNGROUP)
set(DEFUMASK "007") set(DEFUMASK "007")
else(RUNGROUP) else()
set(DEFUMASK "077") set(DEFUMASK "077")
endif(RUNGROUP) endif()
endif(NOT DEFUMASK) endif()
# Set the DEBUG_BUILD for sysconf.h # Set the DEBUG_BUILD for sysconf.h
if(CMAKE_BUILD_TYPE STREQUAL "DEBUG" OR CMAKE_BUILD_TYPE STREQUAL "RELWITHDEBINFO") if(CMAKE_BUILD_TYPE STREQUAL "DEBUG" OR CMAKE_BUILD_TYPE STREQUAL "RELWITHDEBINFO")
set(CMAKE_EXPORT_COMPILE_COMMANDS ON)
set(DEBUG_BUILD TRUE) set(DEBUG_BUILD TRUE)
endif(CMAKE_BUILD_TYPE STREQUAL "DEBUG" OR CMAKE_BUILD_TYPE STREQUAL "RELWITHDEBINFO") endif()
# Check for the existance of the following include files # Check for the existence of the following functions
check_include_file(cstdint HAVE_CSTDINT)
check_include_file(stdint.h HAVE_STDINT_H)
check_include_file(strings.h HAVE_STRINGS_H)
# Check for the existance of the following functions
check_function_exists(strcasecmp HAVE_STRCASECMP)
check_function_exists(stricmp HAVE_STRICMP)
check_function_exists(umask HAVE_UMASK) check_function_exists(umask HAVE_UMASK)
check_function_exists(epoll_wait HAVE_EPOLL) check_function_exists(epoll_wait HAVE_EPOLL)
check_function_exists(poll HAVE_POLL) check_function_exists(poll HAVE_POLL)
@@ -358,71 +248,62 @@ check_function_exists(kqueue HAVE_KQUEUE)
# Strip the leading and trailing spaces from the compile flags # Strip the leading and trailing spaces from the compile flags
if(CXXFLAGS) if(CXXFLAGS)
strip_string(${CXXFLAGS} CXXFLAGS) string(STRIP ${CXXFLAGS} CXXFLAGS)
endif(CXXFLAGS) endif()
# Strip the leading and trailing spaces from the linker flags # Strip the leading and trailing spaces from the linker flags
if(LDFLAGS) if(LDFLAGS)
strip_string(${LDFLAGS} LDFLAGS) string(STRIP ${LDFLAGS} LDFLAGS)
endif(LDFLAGS) endif()
# Search for the following programs # Search for the following programs
find_program(GREP grep) if(NOT WIN32 AND RUNGROUP)
find_program(SH sh) find_program(CHGRP "chgrp" REQUIRED)
find_program(CHGRP chgrp) find_program(CHMOD "chmod" REQUIRED)
find_program(CHMOD chmod) endif()
find_program(PERL perl)
# If perl is included on the system and the user wants to use run-cc.pl, change the commands for compiling and linking # If a INSTDIR was passed in to CMake, use it as the install prefix, otherwise set the default install prefix to the anope directory under the user's home directory
if(PERL AND USE_RUN_CC_PL)
set(CMAKE_CXX_COMPILE_OBJECT "${PERL} ${Anope_SOURCE_DIR}/run-cc.pl -q ${CMAKE_CXX_COMPILE_OBJECT}")
set(CMAKE_CXX_LINK_EXECUTABLE "${PERL} ${Anope_SOURCE_DIR}/run-cc.pl -q ${CMAKE_CXX_LINK_EXECUTABLE}")
set(CMAKE_CXX_CREATE_SHARED_MODULE "${PERL} ${Anope_SOURCE_DIR}/run-cc.pl -q ${CMAKE_CXX_CREATE_SHARED_MODULE}")
endif(PERL AND USE_RUN_CC_PL)
# If a INSTDIR was passed in to CMake, use it as the install prefix, otherwise set the default install prefix to the services directory under the user's home directory
if(INSTDIR) if(INSTDIR)
set(CMAKE_INSTALL_PREFIX "${INSTDIR}") set(CMAKE_INSTALL_PREFIX "${INSTDIR}")
else(INSTDIR) elseif(NOT CMAKE_INSTALL_PREFIX)
set(CMAKE_INSTALL_PREFIX "$ENV{HOME}/services") set(CMAKE_INSTALL_PREFIX "$ENV{HOME}/anope")
endif(INSTDIR) endif()
# Set default paths for various directories if not already defined # Set default paths for various directories if not already defined
if(NOT BIN_DIR) if(NOT BIN_DIR)
set(BIN_DIR "bin") set(BIN_DIR "bin")
endif(NOT BIN_DIR) endif()
if(NOT DB_DIR) if(NOT DB_DIR)
set(DB_DIR "data") set(DB_DIR "data")
endif(NOT DB_DIR) endif()
if(NOT DOC_DIR) if(NOT DOC_DIR)
set(DOC_DIR "doc") set(DOC_DIR "doc")
endif(NOT DOC_DIR) endif()
if(NOT CONF_DIR) if(NOT CONF_DIR)
set(CONF_DIR "conf") set(CONF_DIR "conf")
endif(NOT CONF_DIR) endif()
if(NOT LIB_DIR) if(NOT LIB_DIR)
set(LIB_DIR "lib") set(LIB_DIR "lib")
endif(NOT LIB_DIR) endif()
if(NOT LOCALE_DIR) if(NOT LOCALE_DIR)
set(LOCALE_DIR "locale") set(LOCALE_DIR "locale")
endif(NOT LOCALE_DIR) endif()
if(NOT LOGS_DIR) if(NOT LOGS_DIR)
set(LOGS_DIR "logs") set(LOGS_DIR "logs")
endif(NOT LOGS_DIR) endif()
# Version number processing # Version number processing
# Find all lines in src/version.sh that start with VERSION_ # Find all lines in src/version.sh that start with VERSION_
read_from_file(${Anope_SOURCE_DIR}/src/version.sh "^VERSION_" VERSIONS) file(STRINGS ${Anope_SOURCE_DIR}/src/version.sh VERSIONS REGEX "^VERSION_")
# Iterate through the strings found # Iterate through the strings found
foreach(VERSION_STR ${VERSIONS}) foreach(VERSION_STR ${VERSIONS})
string(REGEX REPLACE "^VERSION_([A-Z]+)=\"?([^\"]*)\"?$" "\\1;\\2" VERSION_OUT ${VERSION_STR}) string(REGEX REPLACE "^VERSION_([A-Z]+)=\"?([^\"]*)\"?$" "\\1;\\2" VERSION_OUT ${VERSION_STR})
# Depends on CMP0007 OLD
list(LENGTH VERSION_OUT VERSION_LEN) list(LENGTH VERSION_OUT VERSION_LEN)
list(GET VERSION_OUT 0 VERSION_TYPE) list(GET VERSION_OUT 0 VERSION_TYPE)
if(${VERSION_LEN} GREATER 1) if(${VERSION_LEN} GREATER 1)
list(GET VERSION_OUT 1 VERSION_DATA) list(GET VERSION_OUT 1 VERSION_DATA)
set(VERSION_${VERSION_TYPE} ${VERSION_DATA}) set(VERSION_${VERSION_TYPE} ${VERSION_DATA})
endif(${VERSION_LEN} GREATER 1) endif()
endforeach(VERSION_STR ${VERSIONS}) endforeach()
# Default build version to 0 # Default build version to 0
set(VERSION_BUILD 0) set(VERSION_BUILD 0)
@@ -430,7 +311,7 @@ set(VERSION_BUILD 0)
# Only change the build number if version.h exists # Only change the build number if version.h exists
if(EXISTS "${Anope_SOURCE_DIR}/include/version.h") if(EXISTS "${Anope_SOURCE_DIR}/include/version.h")
# Attempt to read the build number from include/version.h # Attempt to read the build number from include/version.h
read_from_file(${Anope_SOURCE_DIR}/include/version.h "^#define VERSION_BUILD" VERSIONS) file(STRINGS ${Anope_SOURCE_DIR}/src/version.sh VERSIONS REGEX "^#define VERSION_BUILD")
foreach(VERSION_STR ${VERSIONS}) foreach(VERSION_STR ${VERSIONS})
# Get the length of the string # Get the length of the string
string(LENGTH ${VERSION_STR} VERSION_LEN) string(LENGTH ${VERSION_STR} VERSION_LEN)
@@ -440,8 +321,8 @@ if(EXISTS "${Anope_SOURCE_DIR}/include/version.h")
string(SUBSTRING ${VERSION_STR} 22 ${VERSION_NUM_LEN} VERSION) string(SUBSTRING ${VERSION_STR} 22 ${VERSION_NUM_LEN} VERSION)
# Set VERSION_BUILD correctly # Set VERSION_BUILD correctly
set(VERSION_BUILD ${VERSION}) set(VERSION_BUILD ${VERSION})
endforeach(VERSION_STR ${VERSIONS}) endforeach()
endif(EXISTS "${Anope_SOURCE_DIR}/include/version.h") endif()
# Set the version variables based on what was found above # Set the version variables based on what was found above
set(VERSION_COMMA "${VERSION_MAJOR},${VERSION_MINOR},${VERSION_PATCH},${VERSION_BUILD}") set(VERSION_COMMA "${VERSION_MAJOR},${VERSION_MINOR},${VERSION_PATCH},${VERSION_BUILD}")
@@ -454,7 +335,7 @@ set(VERSION_FULL_NOBUILD "${VERSION_DOTTED_NOBUILD}${VERSION_EXTRA}")
if(WIN32) if(WIN32)
# Generate the win32.rc file using the above variables # Generate the win32.rc file using the above variables
configure_file(${Anope_SOURCE_DIR}/src/win32/win32.rc.cmake ${Anope_BINARY_DIR}/src/win32/win32.rc) configure_file(${Anope_SOURCE_DIR}/src/win32/win32.rc.cmake ${Anope_BINARY_DIR}/src/win32/win32.rc)
endif(WIN32) endif()
# Add the initial files to ignore which will be ignored regardless of if you are building in-source or out-of-source # Add the initial files to ignore which will be ignored regardless of if you are building in-source or out-of-source
add_to_cpack_ignored_files(".git\;config.cache\;CMakeFiles\;sysconf.h$\;build" TRUE) add_to_cpack_ignored_files(".git\;config.cache\;CMakeFiles\;sysconf.h$\;build" TRUE)
@@ -469,8 +350,8 @@ if(${Anope_SOURCE_DIR} STREQUAL ${Anope_BINARY_DIR})
# If using Visual Studio, add these files as well # If using Visual Studio, add these files as well
if(MSVC) if(MSVC)
add_to_cpack_ignored_files(".vcproj$\;.sln$\;.ncb$\;.suo$\;.dir$\;.ilk$\;.exp$\;.pdb$\;.lib$\;/debug$;/release$;/relwithdebinfo$;/minsizerel$" TRUE) add_to_cpack_ignored_files(".vcproj$\;.sln$\;.ncb$\;.suo$\;.dir$\;.ilk$\;.exp$\;.pdb$\;.lib$\;/debug$;/release$;/relwithdebinfo$;/minsizerel$" TRUE)
endif(MSVC) endif()
endif(${Anope_SOURCE_DIR} STREQUAL ${Anope_BINARY_DIR}) endif()
# Go into the following directories and run their CMakeLists.txt as well # Go into the following directories and run their CMakeLists.txt as well
add_subdirectory(data) add_subdirectory(data)
@@ -481,33 +362,29 @@ add_subdirectory(modules)
add_subdirectory(include) add_subdirectory(include)
# Get the filename of the Anope binary, to use later # Get the filename of the Anope binary, to use later
get_target_property(SERVICES_BINARY ${PROGRAM_NAME} LOCATION) set(SERVICES_BINARY "$<TARGET_FILE:${PROGRAM_NAME}>")
get_filename_component(SERVICES_BINARY ${SERVICES_BINARY} NAME) get_filename_component(SERVICES_BINARY ${SERVICES_BINARY} NAME)
# At install time, create the following additional directories # At install time, create the following additional directories
install(CODE "file(MAKE_DIRECTORY \"\${CMAKE_INSTALL_PREFIX}/${DB_DIR}/backups\")") install(CODE "file(MAKE_DIRECTORY \"\$ENV{DESTDIR}\${CMAKE_INSTALL_PREFIX}/${DB_DIR}/backups\")")
install(CODE "file(MAKE_DIRECTORY \"\${CMAKE_INSTALL_PREFIX}/${LOGS_DIR}\")") install(CODE "file(MAKE_DIRECTORY \"\$ENV{DESTDIR}\${CMAKE_INSTALL_PREFIX}/${LOGS_DIR}\")")
if(WIN32) if(WIN32)
install(CODE "file(MAKE_DIRECTORY \"\${CMAKE_INSTALL_PREFIX}/${DB_DIR}/runtime\")") install(CODE "file(MAKE_DIRECTORY \"\$ENV{DESTDIR}\${CMAKE_INSTALL_PREFIX}/${DB_DIR}/runtime\")")
endif(WIN32) endif()
# On non-Windows platforms, if RUNGROUP is set, change the permissions of the below directories, as well as the group of the data directory # On non-Windows platforms, if RUNGROUP is set, change the permissions of the below directories, as well as the group of the data directory
if(NOT WIN32 AND RUNGROUP) if(NOT WIN32 AND RUNGROUP)
install(CODE "execute_process(COMMAND ${CHMOD} 2775 \"\${CMAKE_INSTALL_PREFIX}/\${DB_DIR}/backups\")") install(CODE "execute_process(COMMAND ${CHMOD} 2775 \"\$ENV{DESTDIR}\${CMAKE_INSTALL_PREFIX}/\${DB_DIR}/backups\")")
install(CODE "execute_process(COMMAND ${CHMOD} 2775 \"\${CMAKE_INSTALL_PREFIX}/\${LOGS_DIR}\")") install(CODE "execute_process(COMMAND ${CHMOD} 2775 \"\$ENV{DESTDIR}\${CMAKE_INSTALL_PREFIX}/\${LOGS_DIR}\")")
install(CODE "execute_process(COMMAND ${CHGRP} -R ${RUNGROUP} \"\${CMAKE_INSTALL_PREFIX}\")") install(CODE "execute_process(COMMAND ${CHGRP} -R ${RUNGROUP} \"\$ENV{DESTDIR}\${CMAKE_INSTALL_PREFIX}\")")
endif(NOT WIN32 AND RUNGROUP) endif()
# On Windows platforms, install extra files # On Windows platforms, install extra files
if(WIN32) if(WIN32)
install(FILES ${Anope_SOURCE_DIR}/src/win32/anope.bat install(FILES ${Anope_SOURCE_DIR}/src/win32/anope.bat
DESTINATION ${BIN_DIR} DESTINATION ${BIN_DIR}
) )
endif()
# Package any DLLs in src/win/ install(CODE "file(REMOVE_RECURSE \"$ENV{DESTDIR}${CMAKE_INSTALL_PREFIX}/${LIB_DIR}/modules\")")
file(GLOB EXTRA_DLLS RELATIVE ${CMAKE_CURRENT_SOURCE_DIR} "${Anope_SOURCE_DIR}/src/win32/*.dll")
install(FILES ${EXTRA_DLLS} DESTINATION ${BIN_DIR})
endif(WIN32)
install(CODE "file(REMOVE_RECURSE \"${CMAKE_INSTALL_PREFIX}/${LIB_DIR}/modules\")")
# Only process the CPack section if we have CPack # Only process the CPack section if we have CPack
if(EXISTS "${CMAKE_ROOT}/Modules/CPack.cmake") if(EXISTS "${CMAKE_ROOT}/Modules/CPack.cmake")
@@ -537,19 +414,19 @@ if(EXISTS "${CMAKE_ROOT}/Modules/CPack.cmake")
"bin\\\\anope.bat\\\" \\\"-debug -nofork" "Anope IRC Services (Debug and Window Logging)" "bin\\\\anope.bat\\\" \\\"-debug -nofork" "Anope IRC Services (Debug and Window Logging)"
"bin\\\\anope.bat\\\" \\\"-nofork" "Anope IRC Services (Window Logging)" "bin\\\\anope.bat\\\" \\\"-nofork" "Anope IRC Services (Window Logging)"
"bin\\\\anope.bat\\\" \\\"-nothird" "Anope IRC Services (No Third Party Modules)" "bin\\\\anope.bat\\\" \\\"-nothird" "Anope IRC Services (No Third Party Modules)"
"http://www.anope.org/" "Anope Web Site" "https://www.anope.org/" "Anope Web Site"
) )
# The following doesn't work, but a bug report has been filed about it # The following doesn't work, but a bug report has been filed about it
#set(CPACK_CREATE_DESKTOP_LINK_${SERVICES_BINARY} TRUE) #set(CPACK_CREATE_DESKTOP_LINK_${SERVICES_BINARY} TRUE)
set(CPACK_NSIS_MUI_ICON "${Anope_SOURCE_DIR}/src\\\\win32\\\\anope-icon.ico") set(CPACK_NSIS_MUI_ICON "${Anope_SOURCE_DIR}/src\\\\win32\\\\anope-icon.ico")
set(CPACK_NSIS_MUI_UNIICON "${Anope_SOURCE_DIR}/src\\\\win32\\\\anope-icon.ico") set(CPACK_NSIS_MUI_UNIICON "${Anope_SOURCE_DIR}/src\\\\win32\\\\anope-icon.ico")
set(CPACK_NSIS_INSTALLED_ICON_NAME "${SERVICES_BINARY}") set(CPACK_NSIS_INSTALLED_ICON_NAME "${SERVICES_BINARY}")
set(CPACK_NSIS_URL_INFO_ABOUT "http://www.anope.org/") set(CPACK_NSIS_URL_INFO_ABOUT "https://www.anope.org/")
set(CPACK_NSIS_COMPRESSOR "/SOLID lzma") set(CPACK_NSIS_COMPRESSOR "/SOLID lzma")
endif(WIN32) endif()
set(CPACK_SOURCE_PACKAGE_FILE_NAME "anope-${VERSION_FULL_NOBUILD}-source") set(CPACK_SOURCE_PACKAGE_FILE_NAME "anope-${VERSION_FULL_NOBUILD}-source")
set(CPACK_SOURCE_GENERATOR "TGZ") set(CPACK_SOURCE_GENERATOR "TGZ")
set(CPACK_SOURCE_IGNORE_FILES "$ENV{CPACK_IGNORED_FILES}") set(CPACK_SOURCE_IGNORE_FILES "$ENV{CPACK_IGNORED_FILES}")
set(CPACK_MONOLITHIC_INSTALL TRUE) set(CPACK_MONOLITHIC_INSTALL TRUE)
include(CPack) include(CPack)
endif(EXISTS "${CMAKE_ROOT}/Modules/CPack.cmake") endif()
+21 -87
View File
@@ -1,8 +1,8 @@
#!/bin/sh #!/bin/sh
# #
# Configuration script for Services. # Configuration script for Anope.
# #
# Anope (c) 2003-2014 Anope Team # Anope (C) 2003-2024 Anope Team
# Contact us at team@anope.org # Contact us at team@anope.org
# #
# This program is free but copyrighted software; see the file COPYING for # This program is free but copyrighted software; see the file COPYING for
@@ -62,18 +62,6 @@ Run_Build_System () {
BUILD_TYPE="-DCMAKE_BUILD_TYPE:STRING=RELEASE" BUILD_TYPE="-DCMAKE_BUILD_TYPE:STRING=RELEASE"
fi fi
if [ "$USE_RUN_CC_PL" = "yes" ] ; then
RUN_CC_PL="-DUSE_RUN_CC_PL:BOOLEAN=ON"
else
RUN_CC_PL="-DUSE_RUN_CC_PL:BOOLEAN=OFF"
fi
if [ "$USE_PCH" = "yes" ] ; then
PCH="-DUSE_PCH:BOOLEAN=ON"
else
PCH="-DUSE_PCH:BOOLEAN=OFF"
fi
if [ "$EXTRA_INCLUDE_DIRS" != "" ] ; then if [ "$EXTRA_INCLUDE_DIRS" != "" ] ; then
EXTRA_INCLUDE="-DEXTRA_INCLUDE:STRING=$EXTRA_INCLUDE_DIRS" EXTRA_INCLUDE="-DEXTRA_INCLUDE:STRING=$EXTRA_INCLUDE_DIRS"
fi fi
@@ -82,12 +70,6 @@ Run_Build_System () {
EXTRA_LIBS="-DEXTRA_LIBS:STRING=$EXTRA_LIB_DIRS" EXTRA_LIBS="-DEXTRA_LIBS:STRING=$EXTRA_LIB_DIRS"
fi fi
case `uname -s` in
MINGW*)
GEN_TYPE="-G\"MSYS Makefiles\""
;;
esac
if [ "$SOURCE_DIR" = "." ] ; then if [ "$SOURCE_DIR" = "." ] ; then
pwdsave=`pwd` pwdsave=`pwd`
test -d build || mkdir build test -d build || mkdir build
@@ -97,9 +79,13 @@ Run_Build_System () {
REAL_SOURCE_DIR="$SOURCE_DIR" REAL_SOURCE_DIR="$SOURCE_DIR"
fi fi
echo "cmake $GEN_TYPE $WITH_INST $WITH_RUN $WITH_PERM $BUILD_TYPE $RUN_CC_PL $PCH $EXTRA_INCLUDE $EXTRA_LIBS $EXTRA_CONFIG_ARGS $REAL_SOURCE_DIR" echo "cmake $GEN_TYPE $WITH_INST $WITH_RUN $WITH_PERM $BUILD_TYPE $EXTRA_INCLUDE $EXTRA_LIBS $EXTRA_CONFIG_ARGS $REAL_SOURCE_DIR"
cmake $GEN_TYPE $WITH_INST $WITH_RUN $WITH_PERM $BUILD_TYPE $RUN_CC_PL $PCH $EXTRA_INCLUDE $EXTRA_LIBS $EXTRA_CONFIG_ARGS $REAL_SOURCE_DIR cmake $GEN_TYPE $WITH_INST $WITH_RUN $WITH_PERM $BUILD_TYPE $EXTRA_INCLUDE $EXTRA_LIBS $EXTRA_CONFIG_ARGS $REAL_SOURCE_DIR
if [ $? -ne 0 ]; then
echo "You should fix these issues and then run ./Config -quick to rerun CMake."
exit 1
fi
echo "" echo ""
if [ "$SOURCE_DIR" = "." ] ; then if [ "$SOURCE_DIR" = "." ] ; then
@@ -127,12 +113,10 @@ export ECHO2 ECHO2SUF
# Init values # Init values
########################################################################### ###########################################################################
INSTDIR=$HOME/services INSTDIR=$HOME/anope
RUNGROUP= RUNGROUP=
UMASK= UMASK=
DEBUG="no" DEBUG="no"
USE_RUN_CC_PL="no"
USE_PCH="no"
EXTRA_INCLUDE_DIRS= EXTRA_INCLUDE_DIRS=
EXTRA_LIB_DIRS= EXTRA_LIB_DIRS=
EXTRA_CONFIG_ARGS= EXTRA_CONFIG_ARGS=
@@ -152,6 +136,9 @@ while [ $# -ge 1 ] ; do
echo "-nointro Skip intro (disclaimer, etc)" echo "-nointro Skip intro (disclaimer, etc)"
echo "-quick Skip questions, go straight to cmake" echo "-quick Skip questions, go straight to cmake"
exit 0 exit 0
elif [ $1 = "-devel" ] ; then
DEBUG="yes"
INSTDIR="$PWD/run"
elif [ $1 = "-nocache" ] ; then elif [ $1 = "-nocache" ] ; then
IGNORE_CACHE="1" IGNORE_CACHE="1"
elif [ $1 = "-nointro" ] ; then elif [ $1 = "-nointro" ] ; then
@@ -173,10 +160,10 @@ done
# Check for CMake and (optionally) install it # Check for CMake and (optionally) install it
########################################################################### ###########################################################################
which cmake > /dev/null cmake --version 2>&1 > /dev/null
if [ $? -ne 0 ] ; then if [ $? -ne 0 ] ; then
clear clear
echo "Anope requires CMake 2.4 or newer, which can be downloaded at http://cmake.org or through your system's package manager." echo "Anope requires CMake 3.8 or newer, which can be downloaded at https://cmake.org/ or through your system's package manager."
echo "If you have installed CMake already, ensure it is in your PATH environment variable." echo "If you have installed CMake already, ensure it is in your PATH environment variable."
exit 0 exit 0
fi fi
@@ -184,23 +171,15 @@ fi
########################################################################### ###########################################################################
if [ ! "$NO_INTRO" ] ; then if [ ! "$NO_INTRO" ] ; then
case `uname -s` in export MORE='-e'
MINGW*)
PAGER=less
;;
*)
PAGER=more
clear
;;
esac
. $SOURCE_DIR/src/version.sh . $SOURCE_DIR/src/version.sh
cat $SOURCE_DIR/.BANNER | sed "s/CURVER/$VERSION_MAJOR.$VERSION_MINOR.$VERSION_PATCH$VERSION_EXTRA/" | sed "s@SOURCE_DIR@$SOURCE_DIR@" | $PAGER cat $SOURCE_DIR/.BANNER | sed "s/CURVER/$VERSION_MAJOR.$VERSION_MINOR.$VERSION_PATCH$VERSION_EXTRA/" | sed "s@SOURCE_DIR@$SOURCE_DIR@" | more
echo "" echo ""
else else
echo "" echo ""
fi fi
echo "Beginning Services configuration." echo "Beginning Anope configuration."
echo "" echo ""
########################################################################### ###########################################################################
@@ -239,7 +218,7 @@ while [ $ok -eq 0 ] ; do
fi fi
fi fi
elif exists "$INPUT/include/services.h" ; then elif exists "$INPUT/include/services.h" ; then
echo "You cannot use the Services source directory as a target directory." echo "You cannot use the Anope source directory as a target directory."
else else
ok=1 ok=1
fi fi
@@ -251,11 +230,11 @@ echo ""
OLD_RUNGROUP="$RUNGROUP" OLD_RUNGROUP="$RUNGROUP"
if [ "$RUNGROUP" ] ; then if [ "$RUNGROUP" ] ; then
echo "Which group should all Services data files be owned by? (If Services" echo "Which group should all Anope data files be owned by? (If Anope"
echo "should not force files to be owned by a particular group, type \"none\"" echo "should not force files to be owned by a particular group, type \"none\""
echo "(without the quotes) and press Return.)" echo "(without the quotes) and press Return.)"
else else
echo "Which group should all Services data files be owned by? (If Services" echo "Which group should all Anope data files be owned by? (If Anope"
echo "should not force files to be owned by a particular group, just press" echo "should not force files to be owned by a particular group, just press"
echo "Return.)" echo "Return.)"
fi fi
@@ -321,49 +300,6 @@ echo ""
#### ####
TEMP_YN="n"
if [ "$USE_RUN_CC_PL" = "yes" ] ; then
TEMP_YN="y"
fi
echo "You can optionally have the build run through run-cc.pl, which will"
echo "cause warnings and errors (if any) to be colored yellow and red,"
echo "respectively. This relies on Perl being installed, so if you say yes"
echo "to this without Perl, the option will be ignored."
echo "NOTE: If you are using MinGW, it is NOT recommended to say yes to"
echo "this, it may fail."
echo "Would you like to utilize run-cc.pl?"
echo2 "[$TEMP_YN] "
read YN
if [ "$YN" ] ; then
if [ "$YN" = "y" ] ; then
USE_RUN_CC_PL="yes"
else
USE_RUN_CC_PL="no"
fi
fi
echo ""
####
TEMP_YN="n"
if [ "$USE_PCH" = "yes" ] ; then
TEMP_YN="y"
fi
echo "Do you want to build using precompiled headers? This can speed up"
echo "the build, but uses more disk space."
echo2 "[$TEMP_YN] "
read YN
if [ "$YN" ] ; then
if [ "$YN" = "y" ] ; then
USE_PCH="yes"
else
USE_PCH="no"
fi
fi
echo ""
####
echo "Are there any extra include directories you wish to use?" echo "Are there any extra include directories you wish to use?"
echo "You may only need to do this if CMake is unable to locate" echo "You may only need to do this if CMake is unable to locate"
echo "missing dependencies without hints." echo "missing dependencies without hints."
@@ -401,7 +337,7 @@ echo ""
#### ####
echo "Are there any extra arguments you wish to pass to CMake?" echo "Are there any extra arguments you wish to pass to CMake?"
echo "If you need no extra arugments to CMake, enter NONE in all caps." echo "If you need no extra arguments to CMake, enter NONE in all caps."
echo2 "[$EXTRA_CONFIG_ARGS] " echo2 "[$EXTRA_CONFIG_ARGS] "
if read INPUT ; then : ; else echo "" ; exit 1 ; fi if read INPUT ; then : ; else echo "" ; exit 1 ; fi
if [ "$INPUT" ] ; then if [ "$INPUT" ] ; then
@@ -426,8 +362,6 @@ INSTDIR="$INSTDIR"
RUNGROUP="$RUNGROUP" RUNGROUP="$RUNGROUP"
UMASK=$UMASK UMASK=$UMASK
DEBUG="$DEBUG" DEBUG="$DEBUG"
USE_RUN_CC_PL="$USE_RUN_CC_PL"
USE_PCH="$USE_PCH"
EXTRA_INCLUDE_DIRS="$EXTRA_INCLUDE_DIRS" EXTRA_INCLUDE_DIRS="$EXTRA_INCLUDE_DIRS"
EXTRA_LIB_DIRS="$EXTRA_LIB_DIRS" EXTRA_LIB_DIRS="$EXTRA_LIB_DIRS"
EXTRA_CONFIG_ARGS="$EXTRA_CONFIG_ARGS" EXTRA_CONFIG_ARGS="$EXTRA_CONFIG_ARGS"
+46
View File
@@ -0,0 +1,46 @@
## About
Anope is an open source set of IRC services. It is highly modular, with a vast number of configurable parameters, and is the most used IRC services package. There are also many modules on the [modsite](https://modules.anope.org) to add additional features. It runs on Linux, BSD, and Windows, and supports many modern IRCds, including InspIRCd, UnrealIRCd, and ircd-hybrid. For more details, credits, command line options, and contact information see [docs/README](https://github.com/anope/anope/blob/2.0/docs/README).
* [Website](https://anope.org)
* [GitHub](https://github.com/anope)
* IRC \#anope on irc.anope.org
## Installation
### Linux/BSD
Download the latest release off of the [releases page](https://github.com/anope/anope/releases).
```
$ ./Config
$ cd build
$ make
$ make install
```
Now change to the directory where you installed Anope to, e.g. `$ cd ~/anope/`
### Windows
Download the latest release off of the [releases page](https://github.com/anope/anope/releases) and run the installer.
## Configuration
Copy conf/anope.example.conf to conf/anope.conf
```
$ cp conf/anope.example.conf conf/anope.conf
```
Edit anope.conf, configuring the uplink, serverinfo, and protocol module configurations. Example link blocks for popular IRCds are included in the anope.example.conf documentation. The [Anope wiki](https://wiki.anope.org) is also a good source of information. Our support channel is located at #anope on [irc.anope.org](irc://irc.anope.org/#anope).
Note that the example configuration file includes other example configuration files. If you want to modify the other example configuration files, copy them (e.g. `modules.example.conf` to `modules.conf`) and modify the `include` directive in `anope.conf` to include the new file.
## Running
Run `$ ./bin/anope` to start Anope. If asked to provide logs for support, use the `--support` flag, e.g.: `$ ./bin/anope --support`
## Installing extra modules
Extra modules, which are usually modules which require extra libraries to use, such as m\_mysql, can be enabled with the `./extras` command from the source directory. Then re-run `Config`, `make` and `make install` again. Third party modules can be installed by placing them into the `modules/third` directory.
+45 -485
View File
@@ -1,421 +1,3 @@
###############################################################################
# strip_string(<input string> <output string>)
#
# A macro to handle stripping the leading and trailing spaces from a string,
# uses string(STRIP) if using CMake 2.6.x or better, otherwise uses
# string(REGEX REPLACE).
###############################################################################
macro(strip_string INPUT_STRING OUTPUT_STRING)
if(CMAKE26_OR_BETTER)
# For CMake 2.6.x or better, we can just use the STRIP sub-command of string()
string(STRIP ${INPUT_STRING} ${OUTPUT_STRING})
else(CMAKE26_OR_BETTER)
# For CMake 2.4.x, we will have to use the REGEX REPLACE sub-command of string() instead
# First check if the input string is empty or not
if (${INPUT_STRING} STREQUAL "")
set(${OUTPUT_STRING} "")
else(${INPUT_STRING} STREQUAL "")
# Determine if the string is entirely empty or not
string(REGEX MATCH "^[ \t]*$" EMPTY_STRING "${INPUT_STRING}")
if(EMPTY_STRING)
set(${OUTPUT_STRING} "")
else(EMPTY_STRING)
# We detect if there is any leading whitespace and remove any if there is
string(SUBSTRING "${INPUT_STRING}" 0 1 FIRST_CHAR)
if(FIRST_CHAR STREQUAL " " OR FIRST_CHAR STREQUAL "\t")
string(REGEX REPLACE "^[ \t]+" "" TEMP_STRING "${INPUT_STRING}")
else(FIRST_CHAR STREQUAL " " OR FIRST_CHAR STREQUAL "\t")
set(TEMP_STRING "${INPUT_STRING}")
endif(FIRST_CHAR STREQUAL " " OR FIRST_CHAR STREQUAL "\t")
# Next we detect if there is any trailing whitespace and remove any if there is
string(LENGTH "${TEMP_STRING}" STRING_LEN)
math(EXPR STRING_LEN "${STRING_LEN} - 1")
string(SUBSTRING "${TEMP_STRING}" ${STRING_LEN} 1 LAST_CHAR)
if(LAST_CHAR STREQUAL " " OR LAST_CHAR STREQUAL "\t")
string(REGEX REPLACE "[ \t]+$" "" ${OUTPUT_STRING} "${TEMP_STRING}")
else(LAST_CHAR STREQUAL " " OR LAST_CHAR STREQUAL "\t")
set(${OUTPUT_STRING} "${TEMP_STRING}")
endif(LAST_CHAR STREQUAL " " OR LAST_CHAR STREQUAL "\t")
endif(EMPTY_STRING)
endif(${INPUT_STRING} STREQUAL "")
endif(CMAKE26_OR_BETTER)
endmacro(strip_string)
###############################################################################
# append_to_list(<list> <args>...)
#
# A macro to handle appending to lists, uses list(APPEND) if using CMake 2.4.2
# or better, otherwise uses set() instead.
###############################################################################
macro(append_to_list LIST)
if(CMAKE242_OR_BETTER)
# For CMake 2.4.2 or better, we can just use the APPEND sub-command of list()
list(APPEND ${LIST} ${ARGN})
else(CMAKE242_OR_BETTER)
# For CMake 2.4.x before 2.4.2, we have to do this manually use set() instead
set(${LIST} ${${LIST}} ${ARGN})
endif(CMAKE242_OR_BETTER)
endmacro(append_to_list)
###############################################################################
# find_in_list(<list> <value> <output variable>)
#
# A macro to handle searching within a list, will store the result in the
# given <output variable>, uses list(FIND) if using CMake 2.6.x or better
# (or CMake 2.4.8 or better), otherwise it iterates through the list to find
# the item.
###############################################################################
macro(find_in_list LIST ITEM_TO_FIND FOUND)
if(CMAKE248_OR_BETTER)
# For CMake 2.4.8 or better, we can use the FIND sub-command of list()
list(FIND ${LIST} ${ITEM_TO_FIND} ITEM_FOUND)
else(CMAKE248_OR_BETTER)
# For CMake 2.4.x before 2.4.8, we have to do this ourselves (NOTE: This is very slow due to a lack of break() as well)
# Firstly we set the position to -1 indicating nothing found, we also use a temporary position
set(ITEM_FOUND -1)
set(POS 0)
# Iterate through the list
foreach(ITEM ${${LIST}})
# If the item we are looking at is the item we are trying to find, set that we've found the item
if(${ITEM} STREQUAL ${ITEM_TO_FIND})
set(ITEM_FOUND ${POS})
endif(${ITEM} STREQUAL ${ITEM_TO_FIND})
# Increase the position value by 1
math(EXPR POS "${POS} + 1")
endforeach(ITEM)
endif(CMAKE248_OR_BETTER)
# Set the given FOUND variable to the result
set(${FOUND} ${ITEM_FOUND})
endmacro(find_in_list)
###############################################################################
# remove_list_duplicates(<list>)
#
# A macro to handle removing duplicates from a list, uses
# list(REMOVE_DUPLICATES) if using CMake 2.6.x or better, otherwise it uses
# a slower method of creating a temporary list and only adding to it when
# a duplicate item hasn't been found.
###############################################################################
macro(remove_list_duplicates LIST)
if(CMAKE26_OR_BETTER)
# For CMake 2.6.x or better, this can be done automatically
list(REMOVE_DUPLICATES ${LIST})
else(CMAKE26_OR_BETTER)
# For CMake 2.4.x, we have to do this ourselves, firstly we'll clear a temporary list
set(NEW_LIST)
# Iterate through the old list
foreach(ITEM ${${LIST}})
# Check if the item is in the new list
find_in_list(NEW_LIST ${ITEM} FOUND_ITEM)
if(FOUND_ITEM EQUAL -1)
# If the item was not found, append it to the list
append_to_list(NEW_LIST ${ITEM})
endif(FOUND_ITEM EQUAL -1)
endforeach(ITEM)
# Replace the old list with the new list
set(${LIST} ${NEW_LIST})
endif(CMAKE26_OR_BETTER)
endmacro(remove_list_duplicates)
###############################################################################
# remove_item_from_list(<list> <value>)
#
# A macro to handle removing a value from a list, uses list(REMOVE_ITEM) in
# both cases, but can remove the value itself using CMake 2.4.2 or better,
# while older versions use a slower method of iterating the list to find the
# index of the value to remove.
###############################################################################
macro(remove_item_from_list LIST VALUE)
if(CMAKE242_OR_BETTER)
# For CMake 2.4.2 or better, this can be done automatically
list(REMOVE_ITEM ${LIST} ${VALUE})
else(CMAKE242_OR_BETTER)
# For CMake 2.4.x before 2.4.2, we have to do this ourselves, firstly we set the index and a variable to indicate if the item was found
set(INDEX 0)
set(FOUND FALSE)
# Iterate through the old list
foreach(ITEM ${${LIST}})
# If the item hasn't been found yet, but the current item is the same, remove it
if(NOT FOUND)
if(ITEM STREQUAL ${VALUE})
set(FOUND TRUE)
list(REMOVE_ITEM ${LIST} ${INDEX})
endif(ITEM STREQUAL ${VALUE})
endif(NOT FOUND)
# Increase the index value by 1
math(EXPR INDEX "${INDEX} + 1")
endforeach(ITEM)
endif(CMAKE242_OR_BETTER)
endmacro(remove_item_from_list)
###############################################################################
# sort_list(<list>)
#
# A macro to handle sorting a list, uses list(SORT) if using CMake 2.4.4 or
# better, otherwise it uses a slower method of creating a temporary list and
# adding elements in alphabetical order.
###############################################################################
macro(sort_list LIST)
if(CMAKE244_OR_BETTER)
# For CMake 2.4.4 or better, this can be done automatically
list(SORT ${LIST})
else(CMAKE244_OR_BETTER)
# For CMake 2.4.x before 2.4.4, we have to do this ourselves, firstly we'll create a teporary list
set(NEW_LIST)
# Iterate through the old list
foreach(ITEM ${${LIST}})
# Temporary index position for the new list, as well as temporary value to store if the item was ever found
set(INDEX 0)
set(FOUND FALSE)
# Iterate through the new list
foreach(NEW_ITEM ${NEW_LIST})
# Compare the items, only if nothing was found before
if(NOT FOUND)
if(NEW_ITEM STRGREATER "${ITEM}")
set(FOUND TRUE)
list(INSERT NEW_LIST ${INDEX} ${ITEM})
endif(NEW_ITEM STRGREATER "${ITEM}")
endif(NOT FOUND)
# Increase the index value by 1
math(EXPR INDEX "${INDEX} + 1")
endforeach(NEW_ITEM)
# If the item was never found, just append it to the end
if(NOT FOUND)
append_to_list(NEW_LIST ${ITEM})
endif(NOT FOUND)
endforeach(ITEM)
# Replace the old list with the new list
set(${LIST} ${NEW_LIST})
endif(CMAKE244_OR_BETTER)
endmacro(sort_list)
###############################################################################
# read_from_file(<filename> <regex> <output variable>)
#
# A macro to handle reading specific lines from a file, uses file(STRINGS) if
# using CMake 2.6.x or better, otherwise we read in the entire file and
# perform a string(REGEX MATCH) on each line of the file instead. This
# macro can also be used to read in all the lines of a file if REGEX is set
# to "".
###############################################################################
macro(read_from_file FILE REGEX STRINGS)
if(CMAKE26_OR_BETTER)
# For CMake 2.6.x or better, we can just use the STRINGS sub-command to get the lines that match the given regular expression (if one is given, otherwise get all lines)
if(REGEX STREQUAL "")
file(STRINGS ${FILE} RESULT)
else(REGEX STREQUAL "")
file(STRINGS ${FILE} RESULT REGEX ${REGEX})
endif(REGEX STREQUAL "")
else(CMAKE26_OR_BETTER)
# For CMake 2.4.x, we need to do this manually, firstly we read the file in
execute_process(COMMAND ${CMAKE_COMMAND} -DFILE:STRING=${FILE} -P ${Anope_SOURCE_DIR}/cmake/ReadFile.cmake ERROR_VARIABLE ALL_STRINGS)
# Next we replace all newlines with semicolons
string(REGEX REPLACE "\n" ";" ALL_STRINGS ${ALL_STRINGS})
if(REGEX STREQUAL "")
# For no regular expression, just set the result to all the lines
set(RESULT ${ALL_STRINGS})
else(REGEX STREQUAL "")
# Clear the result list
set(RESULT)
# Iterate through all the lines of the file
foreach(STRING ${ALL_STRINGS})
# Check for a match against the given regular expression
string(REGEX MATCH ${REGEX} STRING_MATCH ${STRING})
# If we had a match, append the match to the list
if(STRING_MATCH)
append_to_list(RESULT ${STRING})
endif(STRING_MATCH)
endforeach(STRING)
endif(REGEX STREQUAL "")
endif(CMAKE26_OR_BETTER)
# Set the given STRINGS variable to the result
set(${STRINGS} ${RESULT})
endmacro(read_from_file)
###############################################################################
# extract_include_filename(<line> <output variable> [<optional output variable of quote type>])
#
# This macro will take a #include line and extract the filename.
###############################################################################
macro(extract_include_filename INCLUDE FILENAME)
# Strip the leading and trailing spaces from the include line
strip_string(${INCLUDE} INCLUDE_STRIPPED)
# Make sure to only do the following if there is a string
if(INCLUDE_STRIPPED STREQUAL "")
set(FILE "")
else(INCLUDE_STRIPPED STREQUAL "")
# Extract the filename including the quotes or angle brackets
string(REGEX REPLACE "^.*([\"<].*[\">]).*$" "\\1" FILE "${INCLUDE_STRIPPED}")
# If an optional 3rd argument is given, we'll store if the quote style was quoted or angle bracketed
if(${ARGC} GREATER 2)
string(SUBSTRING ${FILE} 0 1 QUOTE)
if(QUOTE STREQUAL "<")
set(${ARGV2} "angle brackets")
else(QUOTE STREQUAL "<")
set(${ARGV2} "quotes")
endif(QUOTE STREQUAL "<")
endif(${ARGC} GREATER 2)
# Now remove the quotes or angle brackets
string(REGEX REPLACE "^[\"<](.*)[\">]$" "\\1" FILE "${FILE}")
endif(INCLUDE_STRIPPED STREQUAL "")
# Set the filename to the the given variable
set(${FILENAME} "${FILE}")
endmacro(extract_include_filename)
###############################################################################
# find_includes(<source filename> <output variable>)
#
# This macro will search through a file for #include lines, regardless of
# whitespace, but only returns the lines that are valid for the current
# platform CMake is running on.
###############################################################################
macro(find_includes SRC INCLUDES)
# Read all lines from the file that start with #, regardless of whitespace before the #
read_from_file(${SRC} "^[ \t]*#.*$" LINES)
# Set that any #include lines found are valid, and create temporary variables for the last found #ifdef/#ifndef
set(VALID_LINE TRUE)
set(LAST_DEF)
set(LAST_CHECK)
# Create an empty include list
set(INCLUDES_LIST)
# Iterate through all the # lines
foreach(LINE ${LINES})
# Search for #ifdef, #ifndef, #else, #endif, and #include
string(REGEX MATCH "^[ \t]*#[ \t]*ifdef[ \t]*.*$" FOUND_IFDEF ${LINE})
string(REGEX MATCH "^[ \t]*#[ \t]*ifndef[ \t]*.*$" FOUND_IFNDEF ${LINE})
string(REGEX MATCH "^[ \t]*#[ \t]*else.*$" FOUND_ELSE ${LINE})
string(REGEX MATCH "^[ \t]*#[ \t]*endif.*$" FOUND_ENDIF ${LINE})
string(REGEX MATCH "^[ \t]*#[ \t]*include[ \t]*[\"<].*[\">][\ t]*.*$" FOUND_INCLUDE ${LINE})
# If we found a #ifdef on the line, extract the data after the #ifdef and set if the lines after it are valid based on the variables in CMake
if(FOUND_IFDEF)
# Extract the define
string(REGEX REPLACE "^[ \t]*#[ \t]*ifdef[ \t]*(.*)$" "\\1" DEFINE ${LINE})
# Replace _WIN32 with WIN32, so we can check if the WIN32 variable of CMake is set instead of _WIN32
if(DEFINE STREQUAL "_WIN32")
set(DEFINE WIN32)
endif(DEFINE STREQUAL "_WIN32")
# Set the last define to this one, and set the last check to true, so when #else is encountered, we can do an opposing check
set(LAST_DEF ${DEFINE})
set(LAST_CHECK TRUE)
# If the define is true (it either exists or is a non-false result), the lines following will be checked, otherwise they will be skipped
if(${DEFINE})
set(VALID_LINE TRUE)
else(${DEFINE})
set(VALID_LINE FALSE)
endif(${DEFINE})
else(FOUND_IFDEF)
# If we found a #ifndef on the line, the same thing as #ifdef is done, except with the checks in the opposite direction
if(FOUND_IFNDEF)
# Extract the define
string(REGEX REPLACE "^[ \t]*#[ \t]*ifndef[ \t]*(.*)$" "\\1" DEFINE ${LINE})
# Replace _WIN32 with WIN32, so we can check if the WIN32 variable of CMake is set instead of _WIN32
if(DEFINE STREQUAL "_WIN32")
set(DEFINE WIN32)
endif(DEFINE STREQUAL "_WIN32")
# Set the last define to this one, and set the last check to false, so when #else is encountered, we can do an opposing check
set(LAST_DEF ${DEFINE})
set(LAST_CHECK FALSE)
# If the define is not true (it either doesn't exists or is a false result), the lines following will be checked, otherwise they will be skipped
if(${DEFINE})
set(VALID_LINE FALSE)
else(${DEFINE})
set(VALUE_LINE TRUE)
endif(${DEFINE})
else(FOUND_IFNDEF)
# If we found a #else on the line, we check the last define in the opposite direction
if(FOUND_ELSE)
# When LAST_CHECK is true, we were inside a #ifdef, now act as if we are entering a #ifndef section by doing an opposing check
if(LAST_CHECK)
if(${LAST_DEF})
set(VALID_LINE FALSE)
else(${LAST_DEF})
set(VALID_LINE TRUE)
endif(${LAST_DEF})
# When LAST_CHECK is false, we were inside a #ifndef, now act as if we are entering a #ifdef section by doing an opposing check
else(LAST_CHECK)
if(${LAST_DEF})
set(VALID_LINE TRUE)
else(${LAST_DEF})
set(VALID_LINE FALSE)
endif(${LAST_DEF})
endif(LAST_CHECK)
else(FOUND_ELSE)
# If we found a #endif on the line, we'll assume everything following the line is valid until we meet another one of the above lines
if(FOUND_ENDIF)
set(VALID_LINE TRUE)
else(FOUND_ENDIF)
# If we found a #include on the line, add the entire line to the list of includes unless the line isn't valid
if(FOUND_INCLUDE)
if(VALID_LINE)
append_to_list(INCLUDES_LIST "${LINE}")
endif(VALID_LINE)
endif(FOUND_INCLUDE)
endif(FOUND_ENDIF)
endif(FOUND_ELSE)
endif(FOUND_IFNDEF)
endif(FOUND_IFDEF)
endforeach(LINE)
set(${INCLUDES} ${INCLUDES_LIST})
endmacro(find_includes)
###############################################################################
# calculate_depends(<source filename> [<optional output variable for includes>])
#
# This macro is used in most of the src (sub)directories to calculate the
# header file dependencies for the given source file.
###############################################################################
macro(calculate_depends SRC)
# Temporarily set that we didn't get a 3rd argument before we actually check if we did get one or not
set(CHECK_ANGLE_INCLUDES FALSE)
# Check for a third argument
if(${ARGC} GREATER 1)
set(CHECK_ANGLE_INCLUDES TRUE)
endif(${ARGC} GREATER 1)
# Find all the lines in the given source file that have any form of #include on them, regardless of whitespace, but only if they are valid for the platform we are on
find_includes(${SRC} INCLUDES)
# Reset the list of headers to empty
set(HEADERS)
# Iterate through the strings containing #include (if any)
foreach(INCLUDE ${INCLUDES})
# Extract the filename from the #include line
extract_include_filename(${INCLUDE} FILENAME QUOTE_TYPE)
if(QUOTE_TYPE STREQUAL "angle brackets")
# The following checks will only be done if there was a request for angle includes to be checked
if(CHECK_ANGLE_INCLUDES)
# Find the path of the include file
if(DEFAULT_INCLUDE_DIRS OR WSDK_PATH OR DEFINED $ENV{VCINSTALLDIR})
find_path(FOUND_${FILENAME}_INCLUDE NAMES ${FILENAME} PATHS ${DEFAULT_INCLUDE_DIRS} ${WSDK_PATH}/include $ENV{VCINSTALLDIR}/include ${EXTRA_INCLUDE})
else(DEFAULT_INCLUDE_DIRS OR WSDK_PATH OR DEFINED $ENV{VCINSTALLDIR})
find_path(FOUND_${FILENAME}_INCLUDE NAMES ${FILENAME} ${EXTRA_INCLUDE})
endif(DEFAULT_INCLUDE_DIRS OR WSDK_PATH OR DEFINED $ENV{VCINSTALLDIR})
# If the include file was found, add it's path to the list of include paths, but only if it doesn't already exist and isn't in the defaults for the compiler
if(FOUND_${FILENAME}_INCLUDE)
# This used to be find_in_list, but it was changed to this loop to do a find on each default include directory, this fixes Mac OS X trying to get it's framework directories in here
set(FOUND_IN_DEFAULTS -1)
foreach(DEFAULT_INCLUDE_DIR ${DEFAULT_INCLUDE_DIRS})
string(REGEX REPLACE "\\+" "\\\\+" DEFAULT_INCLUDE_DIR ${DEFAULT_INCLUDE_DIR})
string(REGEX MATCH ${DEFAULT_INCLUDE_DIR} FOUND_DEFAULT ${FOUND_${FILENAME}_INCLUDE})
if(FOUND_DEFAULT)
set(FOUND_IN_DEFAULTS 0)
endif(FOUND_DEFAULT)
endforeach(DEFAULT_INCLUDE_DIR)
if(FOUND_IN_DEFAULTS EQUAL -1)
find_in_list(${ARGV1} "${FOUND_${FILENAME}_INCLUDE}" FOUND_IN_INCLUDES)
if(FOUND_IN_INCLUDES EQUAL -1)
append_to_list(${ARGV1} "${FOUND_${FILENAME}_INCLUDE}")
endif(FOUND_IN_INCLUDES EQUAL -1)
endif(FOUND_IN_DEFAULTS EQUAL -1)
else(FOUND_${FILENAME}_INCLUDE)
# XXX
if(NOT ${FILENAME} STREQUAL "libintl.h")
message(FATAL_ERROR "${SRC} needs header file ${FILENAME} but we were unable to locate that header file! Check that the header file is within the search path of your OS.")
endif(NOT ${FILENAME} STREQUAL "libintl.h")
endif(FOUND_${FILENAME}_INCLUDE)
endif(CHECK_ANGLE_INCLUDES)
endif(QUOTE_TYPE STREQUAL "angle brackets")
endforeach(INCLUDE)
endmacro(calculate_depends)
############################################################################### ###############################################################################
# calculate_libraries(<source filename> <output variable for linker flags> <output variable for extra depends>) # calculate_libraries(<source filename> <output variable for linker flags> <output variable for extra depends>)
# #
@@ -433,10 +15,10 @@ macro(calculate_libraries SRC SRC_LDFLAGS EXTRA_DEPENDS)
set(LIBRARIES) set(LIBRARIES)
# Check to see if there are any lines matching: /* RequiredLibraries: [something] */ # Check to see if there are any lines matching: /* RequiredLibraries: [something] */
if(WIN32) if(WIN32)
read_from_file(${SRC} "/\\\\*[ \t]*RequiredWindowsLibraries:[ \t]*.*[ \t]*\\\\*/" REQUIRED_LIBRARIES) file(STRINGS ${SRC} REQUIRED_LIBRARIES REGEX "/\\*[ \t]*RequiredWindowsLibraries:[ \t]*.*[ \t]*\\*/")
else(WIN32) else()
read_from_file(${SRC} "/\\\\*[ \t]*RequiredLibraries:[ \t]*.*[ \t]*\\\\*/" REQUIRED_LIBRARIES) file(STRINGS ${SRC} REQUIRED_LIBRARIES REGEX "/\\*[ \t]*RequiredLibraries:[ \t]*.*[ \t]*\\*/")
endif(WIN32) endif()
# Iterate through those lines # Iterate through those lines
foreach(REQUIRED_LIBRARY ${REQUIRED_LIBRARIES}) foreach(REQUIRED_LIBRARY ${REQUIRED_LIBRARIES})
# Strip off the /* RequiredLibraries: and */ from the line # Strip off the /* RequiredLibraries: and */ from the line
@@ -445,82 +27,60 @@ macro(calculate_libraries SRC SRC_LDFLAGS EXTRA_DEPENDS)
string(REGEX REPLACE "," ";" REQUIRED_LIBRARY ${REQUIRED_LIBRARY}) string(REGEX REPLACE "," ";" REQUIRED_LIBRARY ${REQUIRED_LIBRARY})
# Iterate through the libraries given # Iterate through the libraries given
foreach(LIBRARY ${REQUIRED_LIBRARY}) foreach(LIBRARY ${REQUIRED_LIBRARY})
# If the library has multiple names extract the alternate.
unset(LIBRARY_ALT)
if (${LIBRARY} MATCHES "^.+\\|.+$")
string(REGEX REPLACE ".+\\|(.*)" "\\1" LIBRARY_ALT ${LIBRARY})
string(REGEX REPLACE "(.+)\\|.*" "\\1" LIBRARY ${LIBRARY})
endif()
# Locate the library to see if it exists # Locate the library to see if it exists
if(DEFAULT_LIBRARY_DIRS OR WSDK_PATH OR DEFINED $ENV{VCINSTALLDIR}) if(DEFAULT_LIBRARY_DIRS OR DEFINED $ENV{VCINSTALLDIR})
find_library(FOUND_${LIBRARY}_LIBRARY NAMES ${LIBRARY} PATHS ${DEFAULT_LIBRARY_DIRS} ${WSDK_PATH}/lib $ENV{VCINSTALLDIR}/lib ${EXTRA_INCLUDE} ${EXTRA_LIBS}) find_library(FOUND_${LIBRARY}_LIBRARY NAMES ${LIBRARY} ${LIBRARY_ALT} PATHS ${DEFAULT_LIBRARY_DIRS} $ENV{VCINSTALLDIR}/lib ${EXTRA_INCLUDE} ${EXTRA_LIBS})
else(DEFAULT_LIBRARY_DIRS OR WSDK_PATH OR DEFINED $ENV{VCINSTALLDIR}) else()
find_library(FOUND_${LIBRARY}_LIBRARY NAMES ${LIBRARY} ${EXTRA_INCLUDE} ${EXTRA_LIBS}) find_library(FOUND_${LIBRARY}_LIBRARY NAMES ${LIBRARY} ${LIBRARY_ALT} PATHS ${EXTRA_INCLUDE} ${EXTRA_LIBS} NO_DEFAULT_PATH)
endif(DEFAULT_LIBRARY_DIRS OR WSDK_PATH OR DEFINED $ENV{VCINSTALLDIR}) find_library(FOUND_${LIBRARY}_LIBRARY NAMES ${LIBRARY} ${LIBRARY_ALT} PATHS ${EXTRA_INCLUDE} ${EXTRA_LIBS})
endif()
# If the library was found, we will add it to the linker flags # If the library was found, we will add it to the linker flags
if(FOUND_${LIBRARY}_LIBRARY) if(FOUND_${LIBRARY}_LIBRARY)
# Get the path only of the library, to add it to linker flags
get_filename_component(LIBRARY_PATH ${FOUND_${LIBRARY}_LIBRARY} PATH)
if(MSVC) if(MSVC)
# For Visual Studio, instead of editing the linker flags, we'll add the library to a separate list of extra dependencies # For Visual Studio, instead of editing the linker flags, we'll add the library to a separate list of extra dependencies
append_to_list(EXTRA_DEPENDENCIES "${FOUND_${LIBRARY}_LIBRARY}") list(APPEND EXTRA_DEPENDENCIES "${FOUND_${LIBRARY}_LIBRARY}")
else(MSVC) else()
# For all others, add the library paths and libraries # Get the path only of the library, to add it to library paths.
append_to_list(LIBRARY_PATHS "${LIBRARY_PATH}") get_filename_component(LIBRARY_PATH ${FOUND_${LIBRARY}_LIBRARY} PATH)
append_to_list(LIBRARIES "${LIBRARY}") list(APPEND LIBRARY_PATHS "${LIBRARY_PATH}")
endif(MSVC) # Extract the library short name, add it to the library path
else(FOUND_${LIBRARY}_LIBRARY) get_filename_component(LIBRARY_NAME ${FOUND_${LIBRARY}_LIBRARY} NAME_WE)
string(REGEX REPLACE "^lib" "" LIBRARY_NAME ${LIBRARY_NAME})
list(APPEND LIBRARIES ${LIBRARY_NAME})
endif()
else()
# In the case of the library not being found, we fatally error so CMake stops trying to generate # In the case of the library not being found, we fatally error so CMake stops trying to generate
message(FATAL_ERROR "${SRC} needs library ${LIBRARY} but we were unable to locate that library! Check that the library is within the search path of your OS.") message(FATAL_ERROR "${SRC} needs library ${LIBRARY} but we were unable to locate that library! Check that the library is within the search path of your OS.")
endif(FOUND_${LIBRARY}_LIBRARY) endif()
endforeach(LIBRARY) endforeach()
endforeach(REQUIRED_LIBRARY) endforeach()
# Remove duplicates from the library paths # Remove duplicates from the library paths
if(LIBRARY_PATHS) if(LIBRARY_PATHS)
remove_list_duplicates(LIBRARY_PATHS) list(REMOVE_DUPLICATES LIBRARY_PATHS)
endif(LIBRARY_PATHS) endif()
# Remove diplicates from the libraries # Remove diplicates from the libraries
if(LIBRARIES) if(LIBRARIES)
remove_list_duplicates(LIBRARIES) list(REMOVE_DUPLICATES LIBRARIES)
endif(LIBRARIES) endif()
# Iterate through library paths and add them to the linker flags # Iterate through library paths and add them to the linker flags
foreach(LIBRARY_PATH ${LIBRARY_PATHS}) foreach(LIBRARY_PATH ${LIBRARY_PATHS})
find_in_list(DEFAULT_LIBRARY_DIRS "${LIBRARY_PATH}" FOUND_IN_DEFAULTS) if(NOT "${LIBRARY_PATH}" IN_LIST DEFAULT_LIBRARY_DIRS)
if(FOUND_IN_DEFAULTS EQUAL -1)
set(THIS_LDFLAGS "${THIS_LDFLAGS} -L${LIBRARY_PATH}") set(THIS_LDFLAGS "${THIS_LDFLAGS} -L${LIBRARY_PATH}")
endif(FOUND_IN_DEFAULTS EQUAL -1) endif()
endforeach(LIBRARY_PATH) endforeach()
# Iterate through libraries and add them to the linker flags # Iterate through libraries and add them to the linker flags
foreach(LIBRARY ${LIBRARIES}) foreach(LIBRARY ${LIBRARIES})
append_to_list(EXTRA_DEPENDENCIES "${LIBRARY}") list(APPEND EXTRA_DEPENDENCIES "${LIBRARY}")
endforeach(LIBRARY) endforeach()
set(${SRC_LDFLAGS} "${THIS_LDFLAGS}") set(${SRC_LDFLAGS} "${THIS_LDFLAGS}")
set(${EXTRA_DEPENDS} "${EXTRA_DEPENDENCIES}") set(${EXTRA_DEPENDS} "${EXTRA_DEPENDENCIES}")
endmacro(calculate_libraries) endmacro()
###############################################################################
# check_functions(<source filename> <output variable set to TRUE on success>)
#
# This macro is used in most of the module (sub)directories to calculate the
# fcuntion dependencies for the given source file.
###############################################################################
macro(check_functions SRC SUCCESS)
# Default to true
set(${SUCCESS} TRUE)
# Check to see if there are any lines matching: /* RequiredFunctions: [something] */
read_from_file(${SRC} "/\\\\*[ \t]*RequiredFunctions:[ \t]*.*[ \t]*\\\\*/" REQUIRED_FUNCTIONS)
# Iterate through those lines
foreach(REQUIRED_FUNCTION ${REQUIRED_FUNCTIONS})
# Strip off the /* RequiredFunctions: and */ from the line
string(REGEX REPLACE "/\\*[ \t]*RequiredFunctions:[ \t]*([^ \t]*)[ \t]*\\*/" "\\1" REQUIRED_FUNCTION ${REQUIRED_FUNCTION})
# Replace all commas with semicolons
string(REGEX REPLACE "," ";" REQUIRED_FUNCTION ${REQUIRED_FUNCTION})
# Iterate through the functions given
foreach(FUNCTION ${REQUIRED_FUNCTION})
# Check if the function exists
check_function_exists(${REQUIRED_FUNCTION} HAVE_${REQUIRED_FUNCTION})
# If we don't have the function warn the user and set SUCCESS to FALSE
if(NOT HAVE_${REQUIRED_FUNCTION})
message("${SRC} needs function ${REQUIRED_FUNCTION} but we were unable to locate that function!")
set(${SUCCESS} FALSE)
endif(NOT HAVE_${REQUIRED_FUNCTION})
endforeach(FUNCTION)
endforeach(REQUIRED_FUNCTION)
endmacro(check_functions)
############################################################################### ###############################################################################
# add_to_cpack_ignored_files(<item> [TRUE]) # add_to_cpack_ignored_files(<item> [TRUE])
@@ -530,17 +90,17 @@ endmacro(check_functions)
# of TRUE is given, periods will be converted to \\. for CPack. # of TRUE is given, periods will be converted to \\. for CPack.
############################################################################### ###############################################################################
macro(add_to_cpack_ignored_files ITEM) macro(add_to_cpack_ignored_files ITEM)
# Temporary copy of the orignal item # Temporary copy of the original item
set(REAL_ITEM "${ITEM}") set(REAL_ITEM "${ITEM}")
# If we have 2+ arguments, assume that the second one was something like TRUE (doesn't matter really) and convert periods so they will be \\. for CPack # If we have 2+ arguments, assume that the second one was something like TRUE (doesn't matter really) and convert periods so they will be \\. for CPack
if(${ARGC} GREATER 1) if(${ARGC} GREATER 1)
string(REPLACE "." "\\\\." REAL_ITEM ${REAL_ITEM}) string(REPLACE "." "\\\\." REAL_ITEM ${REAL_ITEM})
endif(${ARGC} GREATER 1) endif()
# If the environment variable is already defined, just tack the item to the end # If the environment variable is already defined, just tack the item to the end
if(DEFINED ENV{CPACK_IGNORED_FILES}) if(DEFINED ENV{CPACK_IGNORED_FILES})
set(ENV{CPACK_IGNORED_FILES} "$ENV{CPACK_IGNORED_FILES};${REAL_ITEM}") set(ENV{CPACK_IGNORED_FILES} "$ENV{CPACK_IGNORED_FILES};${REAL_ITEM}")
# Otherwise set the environment variable to the item # Otherwise set the environment variable to the item
else(DEFINED ENV{CPACK_IGNORED_FILES}) else()
set(ENV{CPACK_IGNORED_FILES} "${REAL_ITEM}") set(ENV{CPACK_IGNORED_FILES} "${REAL_ITEM}")
endif(DEFINED ENV{CPACK_IGNORED_FILES}) endif()
endmacro(add_to_cpack_ignored_files) endmacro()
-26
View File
@@ -1,26 +0,0 @@
# Find the header files, libs, and executables for gettext
if(NOT WIN32)
find_path(GETTEXT_INCLUDE libintl.h /usr/include /usr/local/include ${EXTRA_INCLUDE})
find_library(GETTEXT_LIBRARY intl PATHS /usr/lib /usr/lib64 ${EXTRA_LIBS})
find_program(GETTEXT_MSGFMT msgfmt PATHS /usr/bin/ /usr/local/bin ${EXTRA_INCLUDE})
if(GETTEXT_INCLUDE AND GETTEXT_MSGFMT)
set(GETTEXT_FOUND TRUE)
if(GETTEXT_LIBRARY)
set(GETTEXT_LIBRARIES ${GETTEXT_LIBRARY})
endif(GETTEXT_LIBRARY)
endif(GETTEXT_INCLUDE AND GETTEXT_MSGFMT)
else(NOT WIN32)
find_path(GETTEXT_INCLUDE libintl.h ${DEFAULT_INCLUDE_DIRS} ${WSDK_PATH}/include $ENV{VCINSTALLDIR}/include gettext/include ${EXTRA_INCLUDE})
find_library(GETTEXT_LIBRARY libintl PATHS ${DEFAULT_LIBRARY_DIRS} ${WSDK_PATH}/lib $ENV{VCINSTALLDIR}/lib gettext/lib ${EXTRA_LIBS})
find_program(GETTEXT_MSGFMT msgfmt PATHS ${DEFAULT_INCLUDE_DIRS} ${WSDK_PATH}/bin $ENV{VCINSTALLDIR}/bin gettext/bin ${EXTRA_INCLUDE})
if(GETTEXT_INCLUDE AND GETTEXT_LIBRARY AND GETTEXT_MSGFMT)
set(GETTEXT_FOUND TRUE)
set(GETTEXT_LIBRARIES ${GETTEXT_LIBRARY})
endif(GETTEXT_INCLUDE AND GETTEXT_LIBRARY AND GETTEXT_MSGFMT)
endif(NOT WIN32)
# If we found everything we need set variables correctly for lang/CMakeLists.txt to use
if(GETTEXT_FOUND)
include_directories("${GETTEXT_INCLUDE}")
set(GETTEXT_MSGFMT_EXECUTABLE ${GETTEXT_MSGFMT})
endif(GETTEXT_FOUND)
+25 -25
View File
@@ -118,7 +118,7 @@ Var AR_RegFlags
"exit_${SecName}:" "exit_${SecName}:"
!macroend !macroend
!macro RemoveSection SecName !macro RemoveSection_CPack SecName
; This macro is used to call section's Remove_... macro ; This macro is used to call section's Remove_... macro
;from the uninstaller. ;from the uninstaller.
;Input: section index constant name specified in Section command. ;Input: section index constant name specified in Section command.
@@ -348,7 +348,7 @@ Function un.RemoveFromPath
FunctionEnd FunctionEnd
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
; Uninstall sutff ; Uninstall stuff
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
########################################### ###########################################
@@ -452,15 +452,15 @@ Done:
Exch $R1 Exch $R1
FunctionEnd FunctionEnd
Function ConditionalAddToRegisty Function ConditionalAddToRegistry
Pop $0 Pop $0
Pop $1 Pop $1
StrCmp "$0" "" ConditionalAddToRegisty_EmptyString StrCmp "$0" "" ConditionalAddToRegistry_EmptyString
WriteRegStr SHCTX "Software\Microsoft\Windows\CurrentVersion\Uninstall\@CPACK_PACKAGE_NAME@" \ WriteRegStr SHCTX "Software\Microsoft\Windows\CurrentVersion\Uninstall\@CPACK_PACKAGE_NAME@" \
"$1" "$0" "$1" "$0"
;MessageBox MB_OK "Set Registry: '$1' to '$0'" ;MessageBox MB_OK "Set Registry: '$1' to '$0'"
DetailPrint "Set install registry entry: '$1' to '$0'" DetailPrint "Set install registry entry: '$1' to '$0'"
ConditionalAddToRegisty_EmptyString: ConditionalAddToRegistry_EmptyString:
FunctionEnd FunctionEnd
;-------------------------------- ;--------------------------------
@@ -558,44 +558,44 @@ Section "-Core installation"
WriteUninstaller "$INSTDIR\Uninstall.exe" WriteUninstaller "$INSTDIR\Uninstall.exe"
Push "DisplayName" Push "DisplayName"
Push "@CPACK_NSIS_DISPLAY_NAME@" Push "@CPACK_NSIS_DISPLAY_NAME@"
Call ConditionalAddToRegisty Call ConditionalAddToRegistry
Push "DisplayVersion" Push "DisplayVersion"
Push "@CPACK_PACKAGE_VERSION@" Push "@CPACK_PACKAGE_VERSION@"
Call ConditionalAddToRegisty Call ConditionalAddToRegistry
Push "Publisher" Push "Publisher"
Push "@CPACK_PACKAGE_VENDOR@" Push "@CPACK_PACKAGE_VENDOR@"
Call ConditionalAddToRegisty Call ConditionalAddToRegistry
Push "UninstallString" Push "UninstallString"
Push "$INSTDIR\Uninstall.exe" Push "$INSTDIR\Uninstall.exe"
Call ConditionalAddToRegisty Call ConditionalAddToRegistry
Push "NoRepair" Push "NoRepair"
Push "1" Push "1"
Call ConditionalAddToRegisty Call ConditionalAddToRegistry
!ifdef CPACK_NSIS_ADD_REMOVE !ifdef CPACK_NSIS_ADD_REMOVE
;Create add/remove functionality ;Create add/remove functionality
Push "ModifyPath" Push "ModifyPath"
Push "$INSTDIR\AddRemove.exe" Push "$INSTDIR\AddRemove.exe"
Call ConditionalAddToRegisty Call ConditionalAddToRegistry
!else !else
Push "NoModify" Push "NoModify"
Push "1" Push "1"
Call ConditionalAddToRegisty Call ConditionalAddToRegistry
!endif !endif
; Optional registration ; Optional registration
Push "DisplayIcon" Push "DisplayIcon"
Push "$INSTDIR\@CPACK_NSIS_INSTALLED_ICON_NAME@" Push "$INSTDIR\@CPACK_NSIS_INSTALLED_ICON_NAME@"
Call ConditionalAddToRegisty Call ConditionalAddToRegistry
Push "HelpLink" Push "HelpLink"
Push "@CPACK_NSIS_HELP_LINK@" Push "@CPACK_NSIS_HELP_LINK@"
Call ConditionalAddToRegisty Call ConditionalAddToRegistry
Push "URLInfoAbout" Push "URLInfoAbout"
Push "@CPACK_NSIS_URL_INFO_ABOUT@" Push "@CPACK_NSIS_URL_INFO_ABOUT@"
Call ConditionalAddToRegisty Call ConditionalAddToRegistry
Push "Contact" Push "Contact"
Push "@CPACK_NSIS_CONTACT@" Push "@CPACK_NSIS_CONTACT@"
Call ConditionalAddToRegisty Call ConditionalAddToRegistry
!insertmacro MUI_STARTMENU_WRITE_BEGIN Application !insertmacro MUI_STARTMENU_WRITE_BEGIN Application
;Create shortcuts ;Create shortcuts
@@ -607,19 +607,19 @@ Section "-Core installation"
; Write special uninstall registry entries ; Write special uninstall registry entries
Push "StartMenu" Push "StartMenu"
Push "$STARTMENU_FOLDER" Push "$STARTMENU_FOLDER"
Call ConditionalAddToRegisty Call ConditionalAddToRegistry
Push "DoNotAddToPath" Push "DoNotAddToPath"
Push "$DO_NOT_ADD_TO_PATH" Push "$DO_NOT_ADD_TO_PATH"
Call ConditionalAddToRegisty Call ConditionalAddToRegistry
Push "AddToPathAllUsers" Push "AddToPathAllUsers"
Push "$ADD_TO_PATH_ALL_USERS" Push "$ADD_TO_PATH_ALL_USERS"
Call ConditionalAddToRegisty Call ConditionalAddToRegistry
Push "AddToPathCurrentUser" Push "AddToPathCurrentUser"
Push "$ADD_TO_PATH_CURRENT_USER" Push "$ADD_TO_PATH_CURRENT_USER"
Call ConditionalAddToRegisty Call ConditionalAddToRegistry
Push "InstallToDesktop" Push "InstallToDesktop"
Push "$INSTALL_DESKTOP" Push "$INSTALL_DESKTOP"
Call ConditionalAddToRegisty Call ConditionalAddToRegistry
@CPACK_NSIS_EXTRA_INSTALL_COMMANDS@ @CPACK_NSIS_EXTRA_INSTALL_COMMANDS@
@@ -731,7 +731,7 @@ Section "Uninstall"
DeleteRegKey SHCTX "Software\@CPACK_PACKAGE_VENDOR@\@CPACK_PACKAGE_INSTALL_REGISTRY_KEY@" DeleteRegKey SHCTX "Software\@CPACK_PACKAGE_VENDOR@\@CPACK_PACKAGE_INSTALL_REGISTRY_KEY@"
; Removes all optional components ; Removes all optional components
!insertmacro SectionList "RemoveSection" !insertmacro SectionList "RemoveSection_CPack"
!insertmacro MUI_STARTMENU_GETFOLDER Application $MUI_TEMP !insertmacro MUI_STARTMENU_GETFOLDER Application $MUI_TEMP
@@ -739,7 +739,7 @@ Section "Uninstall"
@CPACK_NSIS_DELETE_ICONS@ @CPACK_NSIS_DELETE_ICONS@
@CPACK_NSIS_DELETE_ICONS_EXTRA@ @CPACK_NSIS_DELETE_ICONS_EXTRA@
;Delete empty start menu parent diretories ;Delete empty start menu parent directories
StrCpy $MUI_TEMP "$SMPROGRAMS\$MUI_TEMP" StrCpy $MUI_TEMP "$SMPROGRAMS\$MUI_TEMP"
startMenuDeleteLoop: startMenuDeleteLoop:
@@ -752,13 +752,13 @@ Section "Uninstall"
StrCmp "$MUI_TEMP" "$SMPROGRAMS" startMenuDeleteLoopDone startMenuDeleteLoop StrCmp "$MUI_TEMP" "$SMPROGRAMS" startMenuDeleteLoopDone startMenuDeleteLoop
startMenuDeleteLoopDone: startMenuDeleteLoopDone:
; If the user changed the shortcut, then untinstall may not work. This should ; If the user changed the shortcut, then uninstall may not work. This should
; try to fix it. ; try to fix it.
StrCpy $MUI_TEMP "$START_MENU" StrCpy $MUI_TEMP "$START_MENU"
Delete "$SMPROGRAMS\$MUI_TEMP\Uninstall.lnk" Delete "$SMPROGRAMS\$MUI_TEMP\Uninstall.lnk"
@CPACK_NSIS_DELETE_ICONS_EXTRA@ @CPACK_NSIS_DELETE_ICONS_EXTRA@
;Delete empty start menu parent diretories ;Delete empty start menu parent directories
StrCpy $MUI_TEMP "$SMPROGRAMS\$MUI_TEMP" StrCpy $MUI_TEMP "$SMPROGRAMS\$MUI_TEMP"
secondStartMenuDeleteLoop: secondStartMenuDeleteLoop:
-5
View File
@@ -1,5 +0,0 @@
# This file is external to the read_from_file macro in Anope.cmake in order to
# get around a possible memory leak in older versions of CMake.
file(READ "${FILE}" RESULT)
message("${RESULT}")
+2 -2
View File
@@ -1,6 +1,6 @@
# Only install example.chk and example.conf from this directory # Only install example.chk and anope.example.conf from this directory
# NOTE: I would've had this just find all files in the directory, but that would include files not needed (like this file) # NOTE: I would've had this just find all files in the directory, but that would include files not needed (like this file)
set(DATA example.chk botserv.example.conf example.conf hostserv.example.conf modules.example.conf operserv.example.conf chanserv.example.conf global.example.conf memoserv.example.conf nickserv.example.conf chanstats.example.conf irc2sql.example.conf stats.standalone.example.conf) set(DATA example.chk anope.example.conf botserv.example.conf hostserv.example.conf modules.example.conf operserv.example.conf chanserv.example.conf global.example.conf memoserv.example.conf nickserv.example.conf chanstats.example.conf irc2sql.example.conf stats.standalone.example.conf)
install(FILES ${DATA} install(FILES ${DATA}
DESTINATION ${CONF_DIR} DESTINATION ${CONF_DIR}
) )
+167 -141
View File
@@ -1,8 +1,8 @@
/* /*
* Example configuration file for Services. After making the appropriate * Example configuration file for Anope. After making the appropriate
* changes to this file, place it in the Services conf directory (as * changes to this file, place it in the Anope conf directory (as
* specified in the "configure" script, default /home/username/services/conf) * specified in the "Config" script, default /home/username/anope/conf)
* under the name "services.conf". * under the name "anope.conf".
* *
* The format of this file is fairly simple: three types of comments are supported: * The format of this file is fairly simple: three types of comments are supported:
* - All text after a '#' on a line is ignored, as in shell scripting * - All text after a '#' on a line is ignored, as in shell scripting
@@ -53,7 +53,7 @@
* included to indicate whether an option is required: * included to indicate whether an option is required:
* *
* [REQUIRED] * [REQUIRED]
* Indicates a directive which must be given. Without it, Services will * Indicates a directive which must be given. Without it, Anope will
* not start. * not start.
* *
* [RECOMMENDED] * [RECOMMENDED]
@@ -71,7 +71,7 @@
* *
* [DEPRECATED] * [DEPRECATED]
* Indicates a directive which will disappear in a future version of * Indicates a directive which will disappear in a future version of
* Services, usually because its functionality has been either * Anope, usually because its functionality has been either
* superseded by that of other directives or incorporated into the main * superseded by that of other directives or incorporated into the main
* program. * program.
*/ */
@@ -80,7 +80,7 @@
* [OPTIONAL] Defines * [OPTIONAL] Defines
* *
* You can define values to other values, which can be used to easily change * You can define values to other values, which can be used to easily change
* many values in the configuration. at once. * many values in the configuration at once.
*/ */
/* /*
@@ -90,7 +90,7 @@
define define
{ {
name = "services.host" name = "services.host"
value = "services.localhost.net" value = "services.example.com"
} }
/* /*
@@ -110,7 +110,7 @@ define
#include #include
{ {
type = "executable" type = "executable"
name = "/usr/bin/wget -q -O - http://some.misconfigured.network.com/services.conf" name = "/usr/bin/wget -q -O - https://some.misconfigured.network.com/anope.conf"
} }
/* /*
@@ -120,54 +120,63 @@ define
* This section can be included multiple times, and Anope will attempt to * This section can be included multiple times, and Anope will attempt to
* connect to each server until it finally connects. * connect to each server until it finally connects.
* *
* Each uplink IRCd should have a corresponding configuration to allow Services * Each uplink IRCd should have a corresponding configuration to allow Anope
* to link to it. * to link to it.
* *
* An example configuration for InspIRCd that is compatible with the below uplink * An example configuration for InspIRCd that is compatible with the below uplink
* and serverinfo configuration would look like: * and serverinfo configuration would look like:
* *
* <link name="services.localhost.net" * # This goes in inspircd.conf, *NOT* your Anope config!
* <module name="hidechans">
* <module name="services_account">
* <module name="spanningtree">
* <bind address="127.0.0.1" port="7000" type="servers">
* <link name="services.example.com"
* ipaddr="127.0.0.1" * ipaddr="127.0.0.1"
* port="7000" * port="7000"
* sendpass="mypassword" * sendpass="mypassword"
* recvpass="mypassword"> * recvpass="mypassword">
* <uline server="services.localhost.net" silent="yes"> * <uline server="services.example.com" silent="yes">
* <bind address="127.0.0.1" port="7000" type="servers">
* *
* An example configuration for UnrealIRCd that is compatible with the below uplink * An example configuration for UnrealIRCd that is compatible with the below uplink
* and serverinfo configuration would look like: * and serverinfo configuration would look like:
* *
* link services.localhost.net * // This goes in unrealircd.conf, *NOT* your Anope config!
* { * listen {
* username *; * ip 127.0.0.1;
* hostname *; * port 7000;
* bind-ip "127.0.0.1"; * options {
* port 7000; * serversonly;
* hub *; * };
* password-connect "mypassword";
* password-receive "mypassword";
* class servers;
* }; * };
* ulines { services.localhost.net; }; * link services.example.com {
* listen 127.0.0.1:7000; * incoming {
* mask *@127.0.0.1;
* };
* password "mypassword";
* class servers;
* };
* ulines { services.example.com; };
*/ */
uplink uplink
{ {
/* /*
* The IP or hostname of the IRC server you wish to connect Services to. * The IP address, hostname, or UNIX socket path of the IRC server you wish
* Usually, you will want to connect Services over 127.0.0.1 (aka localhost). * to connect Anope to.
* Usually, you will want to connect over 127.0.0.1 (aka localhost).
* *
* NOTE: On some shell providers, this will not be an option. * NOTE: On some shell providers, this will not be an option.
*/ */
host = "127.0.0.1" host = "127.0.0.1"
/* /*
* Enable if Services should connect using IPv6. * The protocol that Anope should use when connecting to the uplink. Can
* be set to "ipv4" (the default), "ipv6", or "unix".
*/ */
ipv6 = no protocol = "ipv4"
/* /*
* Enable if Services should connect using SSL. * Enable if Anope should connect using SSL.
* You must have an SSL module loaded for this to work. * You must have an SSL module loaded for this to work.
*/ */
ssl = no ssl = no
@@ -193,26 +202,26 @@ uplink
/* /*
* [REQUIRED] Server Information * [REQUIRED] Server Information
* *
* This section contains information about the Services server. * This section contains information about the services server.
*/ */
serverinfo serverinfo
{ {
/* /*
* The hostname that Services will be seen as, it must have no conflicts with any * The hostname that Anope will be seen as, it must have no conflicts with any
* other server names on the rest of your IRC network. Note that it does not have * other server names on the rest of your IRC network. Note that it does not have
* to be an existing hostname, just one that isn't on your network already. * to be an existing hostname, just one that isn't on your network already.
*/ */
name = "services.localhost.net" name = "services.example.com"
/* /*
* The text which should appear as the server's information in /whois and similar * The text which should appear as the server's information in /WHOIS and similar
* queries. * queries.
*/ */
description = "Services for IRC Networks" description = "Anope IRC Services"
/* /*
* The local address that Services will bind to before connecting to the remote * The local address that Anope will bind to before connecting to the remote
* server. This may be useful for multihomed hosts. If omitted, Services will let * server. This may be useful for multihomed hosts. If omitted, Anope will let
* the Operating System choose the local address. This directive is optional. * the Operating System choose the local address. This directive is optional.
* *
* If you don't know what this means or don't need to use it, just leave this * If you don't know what this means or don't need to use it, just leave this
@@ -228,16 +237,16 @@ serverinfo
#id = "00A" #id = "00A"
/* /*
* The filename containing the Services process ID. The path is relative to the * The filename containing the Anope process ID. The path is relative to the
* services root directory. * services root directory.
*/ */
pid = "data/services.pid" pid = "data/anope.pid"
/* /*
* The filename containing the Message of the Day. The path is relative to the * The filename containing the Message of the Day. The path is relative to the
* services root directory. * services root directory.
*/ */
motd = "conf/services.motd" motd = "conf/motd.txt"
} }
/* /*
@@ -248,18 +257,17 @@ serverinfo
* *
* Supported: * Supported:
* - bahamut * - bahamut
* - charybdis
* - hybrid * - hybrid
* - inspircd12 * - inspircd
* - inspircd20
* - ngircd * - ngircd
* - plexus * - plexus
* - ratbox * - ratbox
* - unreal * - solanum
* - unrealircd
*/ */
module module
{ {
name = "inspircd20" name = "inspircd"
/* /*
* Some protocol modules can enforce mode locks server-side. This reduces the spam caused by * Some protocol modules can enforce mode locks server-side. This reduces the spam caused by
@@ -281,32 +289,32 @@ module
/* /*
* [REQUIRED] Network Information * [REQUIRED] Network Information
* *
* This section contains information about the IRC network that Services will be * This section contains information about the IRC network that Anope will be
* connecting to. * connecting to.
*/ */
networkinfo networkinfo
{ {
/* /*
* This is the name of the network that Services will be running on. * This is the name of the network that Anope will be running on.
*/ */
networkname = "LocalNet" networkname = "LocalNet"
/* /*
* Set this to the maximum allowed nick length on your network. * Set this to the maximum allowed nick length on your network.
* Be sure to set this correctly, as setting this wrong can result in * Be sure to set this correctly, as setting this wrong can result in
* Services being disconnected from the network. * Anope being disconnected from the network.
*/ */
nicklen = 31 nicklen = 31
/* Set this to the maximum allowed ident length on your network. /* Set this to the maximum allowed ident length on your network.
* Be sure to set this correctly, as setting this wrong can result in * Be sure to set this correctly, as setting this wrong can result in
* Services being disconnected from the network. * Anope being disconnected from the network.
*/ */
userlen = 10 userlen = 10
/* Set this to the maximum allowed hostname length on your network. /* Set this to the maximum allowed hostname length on your network.
* Be sure to set this correctly, as setting this wrong can result in * Be sure to set this correctly, as setting this wrong can result in
* Services being disconnected from the network. * Anope being disconnected from the network.
*/ */
hostlen = 64 hostlen = 64
@@ -322,7 +330,7 @@ networkinfo
/* /*
* Characters allowed in nicknames. This always includes the characters described * Characters allowed in nicknames. This always includes the characters described
* in RFC1459, and so does not need to be set for normal behavior. Changing this to * in RFC1459, and so does not need to be set for normal behavior. Changing this to
* include characters your IRCd doesn't support will cause your IRCd and/or Services * include characters your IRCd doesn't support will cause your IRCd and/or Anope
* to break. Multibyte characters are not supported, nor are escape sequences. * to break. Multibyte characters are not supported, nor are escape sequences.
* *
* It is recommended you DON'T change this. * It is recommended you DON'T change this.
@@ -334,7 +342,7 @@ networkinfo
* to services, such as BotServ bot hostnames and user vhosts. Changing this is not * to services, such as BotServ bot hostnames and user vhosts. Changing this is not
* recommended unless you know for sure your IRCd supports whatever characters you are * recommended unless you know for sure your IRCd supports whatever characters you are
* wanting to use. Telling services to set a vHost containing characters your IRCd * wanting to use. Telling services to set a vHost containing characters your IRCd
* disallows could potentially break the IRCd and/or Services. * disallows could potentially break the IRCd and/or Anope.
* *
* It is recommended you DON'T change this. * It is recommended you DON'T change this.
*/ */
@@ -359,22 +367,22 @@ networkinfo
} }
/* /*
* [REQUIRED] Services Options * [REQUIRED] Anope Options
* *
* This section contains various options which determine how Services will operate. * This section contains various options which determine how Anope will operate.
*/ */
options options
{ {
/* /*
* On Linux/UNIX systems Anope can setuid and setgid to this user and group * On Linux/UNIX systems Anope can setuid and setgid to this user and group
* after starting up. This is useful if Anope has to bind to privileged ports * after starting up. This is useful if Anope has to bind to privileged ports.
*/ */
#user = "anope" #user = "anope"
#group = "anope" #group = "anope"
/* /*
* The case mapping used by services. This must be set to a valid locale name * The case mapping used by services. This must be set to a valid locale name
* installed on your machine. Services use this case map to compare, with * installed on your machine. Anope uses this case map to compare, with
* case insensitivity, things such as nick names, channel names, etc. * case insensitivity, things such as nick names, channel names, etc.
* *
* We provide two special casemaps shipped with Anope, ascii and rfc1459. * We provide two special casemaps shipped with Anope, ascii and rfc1459.
@@ -400,23 +408,11 @@ options
#seed = 9866235 #seed = 9866235
/* /*
* If set, Services will perform more stringent checks on passwords. If this * Sets the number of invalid password tries before services removes a user
* isn't set, Services will only disallow a password if it is the same as the
* entity (nickname name) with which it is associated. When set, however,
* Services will also check that the password is at least five
* characters long, and in the future will probably check other things
* as well.
*
* This directive is optional, but recommended.
*/
strictpasswords = yes
/*
* Sets the number of invalid password tries before Services removes a user
* from the network. If a user enters a number of invalid passwords equal to * from the network. If a user enters a number of invalid passwords equal to
* the given amount for any Services function or combination of functions * the given amount for any services function or combination of functions
* during a single IRC session (subject to badpasstimeout, below), Services * during a single IRC session (subject to badpasstimeout, below), services
* will issues a /KILL for the user. If not given, Services will ignore * will issues a /KILL for the user. If not given, services will ignore
* failed password attempts (though they will be logged in any case). * failed password attempts (though they will be logged in any case).
* *
* This directive is optional, but recommended. * This directive is optional, but recommended.
@@ -458,7 +454,7 @@ options
/* /*
* Sets the (maximum) frequency at which the timeout list is checked. This, * Sets the (maximum) frequency at which the timeout list is checked. This,
* combined with readtimeout above, determines how accurately timed events, * combined with readtimeout above, determines how accurately timed events,
* such as nick kills, occur; it also determines how much CPU time Services * such as nick kills, occur; it also determines how much CPU time services
* will use doing this. Higher values will cause less accurate timing but * will use doing this. Higher values will cause less accurate timing but
* less CPU usage. * less CPU usage.
* *
@@ -471,7 +467,7 @@ options
timeoutcheck = 3s timeoutcheck = 3s
/* /*
* If set, this will allow users to let Services send PRIVMSGs to them * If set, this will allow users to let services send PRIVMSGs to them
* instead of NOTICEs. Also see the "msg" option of nickserv:defaults, * instead of NOTICEs. Also see the "msg" option of nickserv:defaults,
* which also toggles the default communication (PRIVMSG or NOTICE) to * which also toggles the default communication (PRIVMSG or NOTICE) to
* use for unregistered users. * use for unregistered users.
@@ -484,8 +480,8 @@ options
#useprivmsg = yes #useprivmsg = yes
/* /*
* If set, will force Services to only respond to PRIVMSGs addresses to * If set, will force services to only respond to PRIVMSGs addresses to
* Nick@ServerName - e.g. NickServ@localhost.net. This should be used in * Nick@ServerName - e.g. NickServ@example.com. This should be used in
* conjunction with IRCd aliases. This directive is optional. * conjunction with IRCd aliases. This directive is optional.
* *
* This option will have no effect on some IRCds, such as TS6 IRCds. * This option will have no effect on some IRCds, such as TS6 IRCds.
@@ -493,14 +489,14 @@ options
#usestrictprivmsg = yes #usestrictprivmsg = yes
/* /*
* If set, Services will only show /stats o to IRC Operators. This directive * If set, Anope will only show /stats o to IRC Operators. This directive
* is optional. * is optional.
*/ */
#hidestatso = yes #hidestatso = yes
/* /*
* A space-separated list of ulined servers on your network, it is assumed that * A space-separated list of U-lined servers on your network, it is assumed that
* the servers in this list are allowed to set channel modes and Services will * the servers in this list are allowed to set channel modes and Anope will
* not attempt to reverse their mode changes. * not attempt to reverse their mode changes.
* *
* WARNING: Do NOT put your normal IRC user servers in this directive. * WARNING: Do NOT put your normal IRC user servers in this directive.
@@ -515,13 +511,13 @@ options
retrywait = 60s retrywait = 60s
/* /*
* If set, Services will hide commands that users don't have the privilege to execute * If set, services will hide commands that users don't have the privilege to execute
* from HELP output. * from HELP output.
*/ */
hideprivilegedcommands = yes hideprivilegedcommands = yes
/* /*
* If set, Services will hide commands that users can't execute because they are not * If set, services will hide commands that users can't execute because they are not
* logged in from HELP output. * logged in from HELP output.
*/ */
hideregisteredcommands = yes hideregisteredcommands = yes
@@ -531,14 +527,14 @@ options
* *
* Note for this to work the regex module providing the regex engine must be loaded. * Note for this to work the regex module providing the regex engine must be loaded.
*/ */
regexengine = "regex/pcre" #regexengine = "regex/stdlib"
/* /*
* A list of languages to load on startup that will be available in /nickserv set language. * A list of languages to load on startup that will be available in /NICKSERV SET LANGUAGE.
* Useful if you translate Anope to your language. (Explained further in docs/LANGUAGE). * Useful if you translate Anope to your language. (Explained further in docs/LANGUAGE).
* Note that english should not be listed here because it is the base language. * Note that English should not be listed here because it is the base language.
* *
* Removing .UTF-8 will instead use the default encoding for the language, eg. iso-8859-1 for western European languages. * Removing .UTF-8 will instead use the default encoding for the language, e.g. iso-8859-1 for western European languages.
*/ */
languages = "ca_ES.UTF-8 de_DE.UTF-8 el_GR.UTF-8 es_ES.UTF-8 fr_FR.UTF-8 hu_HU.UTF-8 it_IT.UTF-8 nl_NL.UTF-8 pl_PL.UTF-8 pt_PT.UTF-8 ru_RU.UTF-8 tr_TR.UTF-8" languages = "ca_ES.UTF-8 de_DE.UTF-8 el_GR.UTF-8 es_ES.UTF-8 fr_FR.UTF-8 hu_HU.UTF-8 it_IT.UTF-8 nl_NL.UTF-8 pl_PL.UTF-8 pt_PT.UTF-8 ru_RU.UTF-8 tr_TR.UTF-8"
@@ -654,6 +650,8 @@ log
* - a channel name * - a channel name
* - a filename * - a filename
* - globops * - globops
*
* If you specify a filename the current date in the format ".YYYYMMDD" will be appended to the path.
*/ */
target = "services.log" target = "services.log"
@@ -667,19 +665,19 @@ log
/* /*
* The source(s) to only accept log messages from. Leave commented to allow all sources. * The source(s) to only accept log messages from. Leave commented to allow all sources.
* This can be a users name, a channel name, one of our clients (eg, OperServ), or a server name. * This can be a users name, a channel name, one of our clients (e.g. OperServ), or a server name.
*/ */
#source = "" #source = ""
/* /*
* The bot used to log generic messages which have no predefined sender if there * The bot used to log generic messages which have no predefined sender if the
* is a channel in the target directive. * target directive is set to a channel or globops.
*/ */
bot = "Global" bot = "Global"
/* /*
* The number of days to keep logfiles, only useful if you are logging to a file. * The number of days to keep log files, only useful if you are logging to a file.
* Set to 0 to never delete old logfiles. * Set to 0 to never delete old log files.
* *
* Note that Anope must run 24 hours a day for this feature to work correctly. * Note that Anope must run 24 hours a day for this feature to work correctly.
*/ */
@@ -704,7 +702,7 @@ log
* means "* ~operserv/*" would log everything because * matches everything. * means "* ~operserv/*" would log everything because * matches everything.
* *
* Valid admin, override, and command options are: * Valid admin, override, and command options are:
* pesudo-serv/commandname (eg, operserv/akill, chanserv/set) * pseudo-serv/commandname (e.g. operserv/akill, chanserv/set)
* *
* Valid server options are: * Valid server options are:
* connect, quit, sync, squit * connect, quit, sync, squit
@@ -735,8 +733,9 @@ log
*/ */
log log
{ {
bot = "Global"
target = "globops" target = "globops"
admin = "global/* operserv/mode operserv/kick operserv/akill operserv/s*line operserv/noop operserv/jupe operserv/oline operserv/set operserv/svsnick operserv/svsjoin operserv/svspart nickserv/getpass */drop" admin = "global/* operserv/chankill operserv/mode operserv/kick operserv/akill operserv/s*line operserv/noop operserv/jupe operserv/set operserv/svsnick operserv/svsjoin operserv/svspart nickserv/getpass */drop"
servers = "squit" servers = "squit"
users = "oper" users = "oper"
other = "expire/* bados akill/*" other = "expire/* bados akill/*"
@@ -761,20 +760,21 @@ log
* chanserv/administration - Can modify the settings of any channel (including changing of the owner!) * chanserv/administration - Can modify the settings of any channel (including changing of the owner!)
* chanserv/access/list - Can view channel access and akick lists, but not modify them * chanserv/access/list - Can view channel access and akick lists, but not modify them
* chanserv/access/modify - Can modify channel access and akick lists, and use /chanserv enforce * chanserv/access/modify - Can modify channel access and akick lists, and use /chanserv enforce
* chanserv/auspex - Can see any information with /chanserv info * chanserv/auspex - Can see any information with /CHANSERV INFO
* chanserv/no-register-limit - May register an unlimited number of channels and nicknames * chanserv/no-register-limit - May register an unlimited number of channels and nicknames
* chanserv/kick - Can kick and ban users from channels through ChanServ * chanserv/kick - Can kick and ban users from channels through ChanServ
* memoserv/info - Can see any information with /memoserv info * memoserv/info - Can see any information with /MEMOSERV INFO
* memoserv/set-limit - Can set the limit of max stored memos on any user and channel * memoserv/set-limit - Can set the limit of max stored memos on any user and channel
* memoserv/no-limit - Can send memos through limits and throttles * memoserv/no-limit - Can send memos through limits and throttles
* nickserv/access - Can modify other users access and certificate lists * nickserv/access - Can modify other users access and certificate lists
* nickserv/alist - Can see the channel access list of other users * nickserv/alist - Can see the channel access list of other users
* nickserv/auspex - Can see any information with /nickserv info * nickserv/auspex - Can see any information with /NICKSERV INFO
* nickserv/confirm - Can confirm other users nicknames * nickserv/confirm - Can confirm other users nicknames
* nickserv/drop - Can drop other users nicks * nickserv/drop - Can drop other users nicks
* nickserv/recover - Can recover other users nicks
* operserv/config - Can modify services's configuration * operserv/config - Can modify services's configuration
* operserv/oper/modify - Can add and remove operators with at most the same privileges * operserv/oper/modify - Can add and remove operators with at most the same privileges
* protected - Can not be kicked from channels by Services * protected - Can not be kicked from channels by services
* *
* Available commands: * Available commands:
* botserv/bot/del botserv/bot/add botserv/bot/change botserv/set/private * botserv/bot/del botserv/bot/add botserv/bot/change botserv/set/private
@@ -783,22 +783,16 @@ log
* chanserv/drop chanserv/getkey chanserv/invite * chanserv/drop chanserv/getkey chanserv/invite
* chanserv/list chanserv/suspend chanserv/topic * chanserv/list chanserv/suspend chanserv/topic
* *
* chanserv/saset/bantype chanserv/saset/description chanserv/saset/email chanserv/saset/keepmodes * chanserv/saset/noexpire
* chanserv/saset/founder chanserv/saset/keeptopic chanserv/saset/restricted
* chanserv/saset/peace chanserv/saset/persist chanserv/saset/private
* chanserv/saset/secure chanserv/saset/securefounder chanserv/saset/secureops
* chanserv/saset/signkick chanserv/saset/successor chanserv/saset/topiclock
* chanserv/saset/url chanserv/saset/noexpire chanserv/saset/autoop
* *
* memoserv/sendall memoserv/staff * memoserv/sendall memoserv/staff
* *
* nickserv/getpass nickserv/getemail nickserv/suspend nickserv/ajoin * nickserv/getemail nickserv/suspend nickserv/ajoin nickserv/list
* nickserv/list
* *
* nickserv/saset/autoop nickserv/saset/email nickserv/saset/greet nickserv/saset/password * nickserv/saset/autoop nickserv/saset/email nickserv/saset/greet nickserv/saset/password
* nickserv/saset/display nickserv/saset/kill nickserv/saset/language nickserv/saset/message * nickserv/saset/display nickserv/saset/kill nickserv/saset/language nickserv/saset/message
* nickserv/saset/private nickserv/saset/secure nickserv/saset/url nickserv/saset/noexpire * nickserv/saset/private nickserv/saset/secure nickserv/saset/url nickserv/saset/noexpire
* nickserv/saset/keepmodes * nickserv/saset/keepmodes nickserv/saset/neverop
* *
* hostserv/set hostserv/del hostserv/list * hostserv/set hostserv/del hostserv/list
* *
@@ -810,12 +804,15 @@ log
* operserv/oper operserv/config operserv/umode operserv/logsearch * operserv/oper operserv/config operserv/umode operserv/logsearch
* operserv/modload operserv/jupe operserv/set operserv/noop * operserv/modload operserv/jupe operserv/set operserv/noop
* operserv/quit operserv/update operserv/reload operserv/restart * operserv/quit operserv/update operserv/reload operserv/restart
* operserv/shutdown operserv/svs operserv/oline operserv/kill * operserv/shutdown operserv/svs operserv/kill
* *
* Firstly, we define 'opertypes' which are named whatever we want ('Network Administrator', etc). * Firstly, we define 'opertypes' which are named whatever we want ('Network Administrator', etc).
* These can contain commands for oper-only strings (see above) which grants access to that specific command, * These can contain commands for oper-only strings (see above) which grants access to that specific command,
* and privileges (which grant access to more general permissions for the named area). * and privileges (which grant access to more general permissions for the named area).
* Wildcard entries are permitted for both, e.g. 'commands = "operserv/*"' for all OperServ commands. * Wildcard entries are permitted for both, e.g. 'commands = "operserv/*"' for all OperServ commands.
* You can also negate values with a ~. For example, "~operserv/akill operserv/*" would allow all OperServ
* commands except for operserv/akill. Note that processing stops at the first matching option, which
* means "* ~operserv/*" would allow everything because * matches everything.
* *
* Below are some default example types, but this is by no means exhaustive, * Below are some default example types, but this is by no means exhaustive,
* and it is recommended that you configure them to your needs. * and it is recommended that you configure them to your needs.
@@ -835,7 +832,7 @@ opertype
/* The name of this opertype */ /* The name of this opertype */
name = "Services Operator" name = "Services Operator"
/* What opertype(s) this inherits from. Seperate with a comma. */ /* What opertype(s) this inherits from. Separate with a comma. */
inherits = "Helper, Another Helper" inherits = "Helper, Another Helper"
/* What commands (see above) this opertype may use */ /* What commands (see above) this opertype may use */
@@ -861,7 +858,7 @@ opertype
inherits = "Services Operator" inherits = "Services Operator"
commands = "botserv/* chanserv/access/list chanserv/drop chanserv/getkey chanserv/saset/noexpire memoserv/sendall nickserv/saset/* nickserv/getemail operserv/news operserv/jupe operserv/svs operserv/stats operserv/oline operserv/noop operserv/forbid global/*" commands = "botserv/* chanserv/access/list chanserv/drop chanserv/getkey chanserv/saset/noexpire memoserv/sendall nickserv/saset/* nickserv/getemail operserv/news operserv/jupe operserv/svs operserv/stats operserv/noop operserv/forbid global/*"
privs = "*" privs = "*"
} }
@@ -879,10 +876,10 @@ opertype
* After defining different types of operators in the above opertype section, we now define who is in these groups * After defining different types of operators in the above opertype section, we now define who is in these groups
* through 'oper' blocks, similar to ircd access. * through 'oper' blocks, similar to ircd access.
* *
* The default is to comment these out (so NOBODY will have Services access). * The default is to comment these out (so NOBODY will have access).
* You probably want to add yourself and a few other people at minimum. * You probably want to add yourself and a few other people at minimum.
* *
* As with all permissions, make sure to only give trustworthy people access to Services. * As with all permissions, make sure to only give trustworthy people access.
*/ */
#oper #oper
@@ -893,12 +890,12 @@ opertype
/* The opertype this person will have */ /* The opertype this person will have */
type = "Services Root" type = "Services Root"
/* If set, the user must be an oper on the IRCd to gain their Services /* If set, the user must be an oper on the IRCd to gain their
* oper privileges. * oper privileges.
*/ */
require_oper = yes require_oper = yes
/* An optional password. If defined the user must login using "/msg OperServ LOGIN" first */ /* An optional password. If defined, the user must login using "/OPERSERV LOGIN" first */
#password = "secret" #password = "secret"
/* An optional SSL fingerprint. If defined, it's required to be able to use this opertype. */ /* An optional SSL fingerprint. If defined, it's required to be able to use this opertype. */
@@ -928,7 +925,7 @@ opertype
/* /*
* [OPTIONAL] Mail Config * [OPTIONAL] Mail Config
* *
* This section contains settings related to the use of e-mail from Services. * This section contains settings related to the use of e-mail from services.
* If the usemail directive is set to yes, unless specified otherwise, all other * If the usemail directive is set to yes, unless specified otherwise, all other
* directives are required. * directives are required.
* *
@@ -939,7 +936,7 @@ opertype
mail mail
{ {
/* /*
* If set, this option enables the mail commands in Services. You may choose * If set, this option enables the mail commands in Anope. You may choose
* to disable it if you have no Sendmail-compatible mailer installed. Whilst * to disable it if you have no Sendmail-compatible mailer installed. Whilst
* this directive (and entire block) is optional, it is required if * this directive (and entire block) is optional, it is required if
* nickserv:registration is set to yes. * nickserv:registration is set to yes.
@@ -956,6 +953,9 @@ mail
* it. This one usually needs no parameters on the command-line. Most * it. This one usually needs no parameters on the command-line. Most
* sendmail applications (or replacements of it) require the -t option * sendmail applications (or replacements of it) require the -t option
* to be used. * to be used.
*
* If you are running on Windows you should use a Windows sendmail port
* like https://www.glob.com.au/sendmail/ for sending emails.
*/ */
sendmailpath = "/usr/sbin/sendmail -t" sendmailpath = "/usr/sbin/sendmail -t"
@@ -963,14 +963,14 @@ mail
* This is the e-mail address from which all the e-mails are to be sent from. * This is the e-mail address from which all the e-mails are to be sent from.
* It should really exist. * It should really exist.
*/ */
sendfrom = "services@localhost.net" sendfrom = "services@example.com"
/* /*
* This controls the minimum amount of time a user must wait before sending * This controls the minimum amount of time a user must wait before sending
* another e-mail after they have sent one. It also controls the minimum time * another e-mail after they have sent one. It also controls the minimum time
* a user must wait before they can receive another e-mail. * a user must wait before they can receive another e-mail.
* *
* This feature prevents users from being mail bombed using Services and * This feature prevents users from being mail bombed using services and
* it is highly recommended that it be used. * it is highly recommended that it be used.
* *
* This directive is optional, but highly recommended. * This directive is optional, but highly recommended.
@@ -978,7 +978,7 @@ mail
delay = 5m delay = 5m
/* /*
* If set, Services will not attempt to put quotes around the TO: fields * If set, Anope will not put quotes around the TO: fields
* in e-mails. * in e-mails.
* *
* This directive is optional, and as far as we know, it's only needed * This directive is optional, and as far as we know, it's only needed
@@ -986,8 +986,21 @@ mail
*/ */
#dontquoteaddresses = yes #dontquoteaddresses = yes
/*
* The content type to use when sending emails.
*
* This directive is optional, and is generally only needed if you want to
* use HTML or non UTF-8 text in your services emails.
*/
#content_type = "text/plain; charset=UTF-8"
/* /*
* The subject and message of emails sent to users when they register accounts. * The subject and message of emails sent to users when they register accounts.
*
* Available tokens for this template are:
* %n - Gets replaced with the nickname
* %N - Gets replaced with the network name
* %c - Gets replaced with the confirmation code
*/ */
registration_subject = "Nickname registration for %n" registration_subject = "Nickname registration for %n"
registration_message = "Hi, registration_message = "Hi,
@@ -1001,6 +1014,11 @@ mail
/* /*
* The subject and message of emails sent to users when they request a new password. * The subject and message of emails sent to users when they request a new password.
*
* Available tokens for this template are:
* %n - Gets replaced with the nickname
* %N - Gets replaced with the network name
* %c - Gets replaced with the confirmation code
*/ */
reset_subject = "Reset password request for %n" reset_subject = "Reset password request for %n"
reset_message = "Hi, reset_message = "Hi,
@@ -1014,6 +1032,13 @@ mail
/* /*
* The subject and message of emails sent to users when they request a new email address. * The subject and message of emails sent to users when they request a new email address.
*
* Available tokens for this template are:
* %e - Gets replaced with the old email address
* %E - Gets replaced with the new email address
* %n - Gets replaced with the nickname
* %N - Gets replaced with the network name
* %c - Gets replaced with the confirmation code
*/ */
emailchange_subject = "Email confirmation" emailchange_subject = "Email confirmation"
emailchange_message = "Hi, emailchange_message = "Hi,
@@ -1027,6 +1052,13 @@ mail
/* /*
* The subject and message of emails sent to users when they receive a new memo. * The subject and message of emails sent to users when they receive a new memo.
*
* Available tokens for this template are:
* %n - Gets replaced with the nickname
* %s - Gets replaced with the sender's nickname
* %d - Gets replaced with the memo number
* %t - Gets replaced with the memo text
* %N - Gets replaced with the network name
*/ */
memo_subject = "New memo" memo_subject = "New memo"
memo_message = "Hi %n, memo_message = "Hi %n,
@@ -1083,18 +1115,18 @@ module
/* /*
* Sets the number of days backups of databases are kept. If you don't give it, * Sets the number of days backups of databases are kept. If you don't give it,
* or if you set it to 0, Services won't backup the databases. * or if you set it to 0, Anope won't backup the databases.
* *
* NOTE: Services must run 24 hours a day for this feature to work. * NOTE: Anope must run 24 hours a day for this feature to work.
* *
* This directive is optional, but recommended. * This directive is optional, but recommended.
*/ */
keepbackups = 3 keepbackups = 3
/* /*
* Allows Services to continue file write operations (i.e. database saving) * Allows Anope to continue file write operations (i.e. database saving)
* even if the original file cannot be backed up. Enabling this option may * even if the original file cannot be backed up. Enabling this option may
* allow Services to continue operation under conditions where it might * allow Anope to continue operation under conditions where it might
* otherwise fail, such as a nearly-full disk. * otherwise fail, such as a nearly-full disk.
* *
* NOTE: Enabling this option can cause irrecoverable data loss under some * NOTE: Enabling this option can cause irrecoverable data loss under some
@@ -1166,8 +1198,8 @@ module
/* /*
* db_redis. * db_redis.
* *
* This module allows using Redis (http://redis.io) as a database backend. * This module allows using Redis (https://redis.io/) as a database backend.
* This module requires that m_redis is loaded and configured properly. * This module requires that redis is loaded and configured properly.
* *
* Redis 2.8 supports keyspace notifications which allows Redis to push notifications * Redis 2.8 supports keyspace notifications which allows Redis to push notifications
* to Anope about outside modifications to the database. This module supports this and * to Anope about outside modifications to the database. This module supports this and
@@ -1179,7 +1211,7 @@ module
name = "db_redis" name = "db_redis"
/* /*
* Redis database to use. This must be configured with m_redis. * Redis database to use. This must be configured with redis.
*/ */
engine = "redis/main" engine = "redis/main"
} }
@@ -1193,7 +1225,7 @@ module
* *
* Without any encryption modules loaded users will not be able to authenticate unless * Without any encryption modules loaded users will not be able to authenticate unless
* there is another module loaded that provides authentication checking, such as * there is another module loaded that provides authentication checking, such as
* m_ldap_authentication or m_sql_authentication. * ldap_authentication or sql_authentication.
* *
* With enc_none, passwords will be stored in plain text, allowing for passwords * With enc_none, passwords will be stored in plain text, allowing for passwords
* to be recovered later but it isn't secure and therefore is not recommended. * to be recovered later but it isn't secure and therefore is not recommended.
@@ -1205,29 +1237,23 @@ module
* encrypted by this module. Old passwords stored in another encryption method are * encrypted by this module. Old passwords stored in another encryption method are
* automatically re-encrypted by the primary encryption module on next identify. * automatically re-encrypted by the primary encryption module on next identify.
* *
* NOTE: enc_old is Anope's previous (broken) MD5 implementation which is present in * enc_md5, enc_sha1, and enc_old are deprecated, and are provided for users
* versions prior to Anope 1.7.17. If your databases were made using that module, * to upgrade to a newer encryption module. Do not use them as the primary
* use this and not enc_md5. * encryption module. They will be removed in a future release.
*
* NOTE: enc_sha1 relies on how the OS stores 2+ byte data internally, and is
* potentially broken when moving between 2 different OSes, such as moving from
* Linux to Windows. It is recommended that you use enc_sha256 instead if you want
* to use an SHA-based encryption. If you choose to do so, it is also recommended
* that you first try to get everyone's passwords converted to enc_sha256 before
* switching OSes by placing enc_sha256 at the beginning of the list.
* *
*/ */
#module { name = "enc_bcrypt" } #module { name = "enc_bcrypt" }
module { name = "enc_sha256" } module { name = "enc_sha256" }
#module { name = "enc_md5" }
#module { name = "enc_sha1" }
/* /*
* When using enc_none, passwords will be stored without encryption. This isn't secure * [DEPRECATED] Deprecated encryption modules. You can only use these for compatibility with
* therefore it is not recommended. * old databases and will need to load one of the above modules as your primary encryption
*/ * module.
*/
#module { name = "enc_md5" }
#module { name = "enc_none" } #module { name = "enc_none" }
#module { name = "enc_sha1" }
/* /*
* enc_old is Anope's previous (broken) MD5 implementation used from 1.4.x to 1.7.16. * enc_old is Anope's previous (broken) MD5 implementation used from 1.4.x to 1.7.16.
+4 -3
View File
@@ -242,14 +242,14 @@ command { service = "BotServ"; name = "INFO"; command = "botserv/info"; }
* botserv/kick - Dummy help wrapper for the KICK command. * botserv/kick - Dummy help wrapper for the KICK command.
* botserv/kick/amsg - Configures BotServ's AMSG kicker. * botserv/kick/amsg - Configures BotServ's AMSG kicker.
* botserv/kick/badwords - Configures BotServ's badwords kicker. * botserv/kick/badwords - Configures BotServ's badwords kicker.
* botserv/kick/bolds - Configures BotServ's bold text kiceker. * botserv/kick/bolds - Configures BotServ's bold text kicker.
* botserv/kick/caps - Configures BotServ's capital letters kicker. * botserv/kick/caps - Configures BotServ's capital letters kicker.
* botserv/kick/colors - Configures BotServ's color kicker. * botserv/kick/colors - Configures BotServ's color kicker.
* botserv/kick/flood - Configures BotServ's flood kicker. * botserv/kick/flood - Configures BotServ's flood kicker.
* botserv/kick/italics - Configures BotServ's italics kicker. * botserv/kick/italics - Configures BotServ's italics kicker.
* botserv/kick/repeat - Configures BotServ's repeat kicker. * botserv/kick/repeat - Configures BotServ's repeat kicker.
* botserv/kick/reverses - Configures BotServ's reverse kicker. * botserv/kick/reverses - Configures BotServ's reverse kicker.
* botserv/kick/underlines - Configures BotServ's reverse kicker. * botserv/kick/underlines - Configures BotServ's underline kicker.
* botserv/set/dontkickops - Used for preventing BotServ from kicking channel operators. * botserv/set/dontkickops - Used for preventing BotServ from kicking channel operators.
* botserv/set/dontkickvoices - Used for preventing BotServ from kicking voices. * botserv/set/dontkickvoices - Used for preventing BotServ from kicking voices.
* *
@@ -323,6 +323,7 @@ command { service = "NickServ"; name = "SASET GREET"; command = "nickserv/saset/
privilege privilege
{ {
name = "GREET" name = "GREET"
desc = _("Greet message displayed on join")
rank = 40 rank = 40
level = 5 level = 5
flag = "g" flag = "g"
@@ -333,7 +334,7 @@ privilege
/* /*
* fantasy * fantasy
* *
* Allows 'fantaisist' commands to be used in channels. * Allows 'fantasist' commands to be used in channels.
* *
* Provides the commands: * Provides the commands:
* botserv/set/fantasy - Used for enabling or disabling BotServ's fantasist commands. * botserv/set/fantasy - Used for enabling or disabling BotServ's fantasist commands.
+72 -20
View File
@@ -79,7 +79,7 @@ module
* - cs_secure: Enable channel security, requiring the user to be identified with NickServ in * - cs_secure: Enable channel security, requiring the user to be identified with NickServ in
* order to be considered for being on the access list of the channel * order to be considered for being on the access list of the channel
* - secureops: Only allow operator status to be given if the user is on the access list * - secureops: Only allow operator status to be given if the user is on the access list
* - securefounder: Only allow the real founder of the channel to drop the channel, change it's * - securefounder: Only allow the real founder of the channel to drop the channel, change its
* password, or change the founder or successor * password, or change the founder or successor
* - signkick: Use of ChanServ's KICK command will cause the user's nick to be signed to the kick. * - signkick: Use of ChanServ's KICK command will cause the user's nick to be signed to the kick.
* - signkick_level: Same as above, but the kick will not be signed if the user is at the same access * - signkick_level: Same as above, but the kick will not be signed if the user is at the same access
@@ -89,10 +89,12 @@ module
* - noautoop: Disables autoop on the channel * - noautoop: Disables autoop on the channel
* - cs_keep_modes: Enables keep modes on the channel, which retains modes when the channel is * - cs_keep_modes: Enables keep modes on the channel, which retains modes when the channel is
* not in use. * not in use.
* - cs_no_expire: Enables no expire. Needs founder, successor (if set) or anyone in the access list
* to be a registered nick, otherwise the channel will be dropped.
* - none: No defaults * - none: No defaults
* *
* This directive is optional, if left blank, the options will default to keeptopic, cs_secure, securefounder, * This directive is optional, if left blank, the options will default to keeptopic, peace, cs_secure,
* and signkick. If you really want no defaults, use "none" by itself as the option. * securefounder, and signkick. If you really want no defaults, use "none" by itself as the option.
*/ */
defaults = "keeptopic peace cs_secure securefounder signkick" defaults = "keeptopic peace cs_secure securefounder signkick"
@@ -108,9 +110,9 @@ module
* The length of time before a channel registration expires. * The length of time before a channel registration expires.
* *
* This directive is optional, but recommended. * This directive is optional, but recommended.
* If not set, the default is 14 days. * If not set, the default is 30 days.
*/ */
expire = 14d expire = 30d
/* /*
* The maximum number of entries on a channel's access list. * The maximum number of entries on a channel's access list.
@@ -193,12 +195,12 @@ module
* *
* If you load cs_xop, you may define a XOP command to associate the privilege with. * If you load cs_xop, you may define a XOP command to associate the privilege with.
* *
* The name of privileges are uesd to associate them with channel modes. If you are using an IRCd that allows you to define additional * The name of privileges are used to associate them with channel modes. If you are using an IRCd that allows you to define additional
* channel status modes, such as InspIRCd, you can associate privileges (and thus access levels, flags, xop) with the mode by naming * channel status modes, such as InspIRCd, you can associate privileges (and thus access levels, flags, xop) with the mode by naming
* the privileges appropriately. For example, if you had a channel mode called admin, you could create AUTOADMIN, ADMIN, and ADMINME * the privileges appropriately. For example, if you had a channel mode called admin, you could create AUTOADMIN, ADMIN, and ADMINME
* privileges which would automatically be associated with that channel mode. * privileges which would automatically be associated with that channel mode.
* *
* Defining new privileges here is not useful unless you have a module (eg, a third party one) made to check for * Defining new privileges here is not useful unless you have a module (e.g. a third party one) made to check for
* the specific level you are defining. * the specific level you are defining.
* *
* Sane defaults are provided below that do not need to be edited unless you wish to change the default behavior. * Sane defaults are provided below that do not need to be edited unless you wish to change the default behavior.
@@ -214,6 +216,7 @@ module
privilege privilege
{ {
name = "ACCESS_CHANGE" name = "ACCESS_CHANGE"
desc = _("Allowed to modify the access list")
rank = 0 rank = 0
level = 10 level = 10
flag = "f" flag = "f"
@@ -230,6 +233,7 @@ privilege
privilege privilege
{ {
name = "ACCESS_LIST" name = "ACCESS_LIST"
desc = _("Allowed to view the access list")
rank = 10 rank = 10
level = 3 level = 3
flag = "f" flag = "f"
@@ -246,6 +250,7 @@ privilege
privilege privilege
{ {
name = "AKICK" name = "AKICK"
desc = _("Allowed to use the AKICK command")
rank = 250 rank = 250
level = 10 level = 10
flag = "K" flag = "K"
@@ -262,6 +267,7 @@ privilege
privilege privilege
{ {
name = "ASSIGN" name = "ASSIGN"
desc = _("Allowed to assign/unassign a bot")
rank = 270 rank = 270
level = "founder" level = "founder"
flag = "s" flag = "s"
@@ -278,6 +284,7 @@ privilege
privilege privilege
{ {
name = "AUTOHALFOP" name = "AUTOHALFOP"
desc = _("Automatic halfop upon join")
rank = 100 rank = 100
level = 4 level = 4
flag = "H" flag = "H"
@@ -294,6 +301,7 @@ privilege
privilege privilege
{ {
name = "AUTOOP" name = "AUTOOP"
desc = _("Automatic channel operator status upon join")
rank = 210 rank = 210
level = 5 level = 5
flag = "O" flag = "O"
@@ -310,6 +318,7 @@ privilege
privilege privilege
{ {
name = "AUTOOWNER" name = "AUTOOWNER"
desc = _("Automatic owner upon join")
rank = 330 rank = 330
level = 9999 level = 9999
flag = "Q" flag = "Q"
@@ -326,6 +335,7 @@ privilege
privilege privilege
{ {
name = "AUTOPROTECT" name = "AUTOPROTECT"
desc = _("Automatic protect upon join")
rank = 240 rank = 240
level = 10 level = 10
flag = "A" flag = "A"
@@ -342,6 +352,7 @@ privilege
privilege privilege
{ {
name = "AUTOVOICE" name = "AUTOVOICE"
desc = _("Automatic voice on join")
rank = 50 rank = 50
level = 3 level = 3
flag = "V" flag = "V"
@@ -358,6 +369,7 @@ privilege
privilege privilege
{ {
name = "BADWORDS" name = "BADWORDS"
desc = _("Allowed to modify channel badwords list")
rank = 260 rank = 260
level = 10 level = 10
flag = "K" flag = "K"
@@ -374,6 +386,7 @@ privilege
privilege privilege
{ {
name = "BAN" name = "BAN"
desc = _("Allowed to ban users")
rank = 150 rank = 150
level = 4 level = 4
flag = "b" flag = "b"
@@ -390,6 +403,7 @@ privilege
privilege privilege
{ {
name = "FANTASIA" name = "FANTASIA"
desc = _("Allowed to use fantasy commands")
rank = 30 rank = 30
level = 3 level = 3
flag = "c" flag = "c"
@@ -409,6 +423,7 @@ privilege
privilege privilege
{ {
name = "FOUNDER" name = "FOUNDER"
desc = _("Allowed to issue commands restricted to channel founders")
rank = 360 rank = 360
level = 10000 level = 10000
flag = "F" flag = "F"
@@ -420,12 +435,13 @@ privilege
* *
* Used by chanserv/getkey and nickserv/ajoin. * Used by chanserv/getkey and nickserv/ajoin.
* *
* Users with this permission can get they channel key with GETKEY and * Users with this permission can get their channel key with GETKEY and
* can use nickserv/ajoin to join channels with keys. * can use nickserv/ajoin to join channels with keys.
*/ */
privilege privilege
{ {
name = "GETKEY" name = "GETKEY"
desc = _("Allowed to use GETKEY command")
rank = 180 rank = 180
level = 5 level = 5
flag = "G" flag = "G"
@@ -443,6 +459,7 @@ privilege
privilege privilege
{ {
name = "HALFOP" name = "HALFOP"
desc = _("Allowed to (de)halfop users")
rank = 120 rank = 120
level = 5 level = 5
flag = "h" flag = "h"
@@ -460,6 +477,7 @@ privilege
privilege privilege
{ {
name = "HALFOPME" name = "HALFOPME"
desc = _("Allowed to (de)halfop themself")
rank = 110 rank = 110
level = 4 level = 4
flag = "h" flag = "h"
@@ -477,6 +495,7 @@ privilege
privilege privilege
{ {
name = "INFO" name = "INFO"
desc = _("Allowed to get full INFO output")
rank = 80 rank = 80
level = 9999 level = 9999
flag = "I" flag = "I"
@@ -494,6 +513,7 @@ privilege
privilege privilege
{ {
name = "INVITE" name = "INVITE"
desc = _("Allowed to use the INVITE command")
rank = 190 rank = 190
level = 5 level = 5
flag = "i" flag = "i"
@@ -510,6 +530,7 @@ privilege
privilege privilege
{ {
name = "KICK" name = "KICK"
desc = _("Allowed to use the KICK command")
rank = 130 rank = 130
level = 4 level = 4
flag = "k" flag = "k"
@@ -527,6 +548,7 @@ privilege
privilege privilege
{ {
name = "MEMO" name = "MEMO"
desc = _("Allowed to read channel memos")
rank = 280 rank = 280
level = 10 level = 10
flag = "m" flag = "m"
@@ -544,6 +566,7 @@ privilege
privilege privilege
{ {
name = "MODE" name = "MODE"
desc = _("Allowed to use the MODE command")
rank = 170 rank = 170
level = 9999 level = 9999
flag = "s" flag = "s"
@@ -560,6 +583,7 @@ privilege
privilege privilege
{ {
name = "NOKICK" name = "NOKICK"
desc = _("Prevents users being kicked by services")
rank = 20 rank = 20
level = 1 level = 1
flag = "N" flag = "N"
@@ -577,6 +601,7 @@ privilege
privilege privilege
{ {
name = "OP" name = "OP"
desc = _("Allowed to (de)op users")
rank = 230 rank = 230
level = 5 level = 5
flag = "o" flag = "o"
@@ -594,6 +619,7 @@ privilege
privilege privilege
{ {
name = "OPME" name = "OPME"
desc = _("Allowed to (de)op themself")
rank = 220 rank = 220
level = 5 level = 5
flag = "o" flag = "o"
@@ -611,6 +637,7 @@ privilege
privilege privilege
{ {
name = "OWNER" name = "OWNER"
desc = _("Allowed to (de)owner users")
rank = 350 rank = 350
level = "founder" level = "founder"
flag = "q" flag = "q"
@@ -628,6 +655,7 @@ privilege
privilege privilege
{ {
name = "OWNERME" name = "OWNERME"
desc = _("Allowed to (de)owner themself")
rank = 340 rank = 340
level = 9999 level = 9999
flag = "q" flag = "q"
@@ -645,6 +673,7 @@ privilege
privilege privilege
{ {
name = "PROTECT" name = "PROTECT"
desc = _("Allowed to (de)protect users")
rank = 310 rank = 310
level = 9999 level = 9999
flag = "a" flag = "a"
@@ -662,10 +691,11 @@ privilege
privilege privilege
{ {
name = "PROTECTME" name = "PROTECTME"
desc = _("Allowed to (de)protect themself")
rank = 300 rank = 300
level = 10 level = 10
flag = "a" flag = "a"
xop = "AOP" xop = "SOP"
} }
/* /*
@@ -679,6 +709,7 @@ privilege
privilege privilege
{ {
name = "SAY" name = "SAY"
desc = _("Allowed to use SAY and ACT commands")
rank = 90 rank = 90
level = 5 level = 5
flag = "B" flag = "B"
@@ -692,12 +723,13 @@ privilege
* chanserv/saset/noexpire and chanserv/set. * chanserv/saset/noexpire and chanserv/set.
* *
* Users with this permission can set what BotServ will kick for, change * Users with this permission can set what BotServ will kick for, change
* BotServ and ChanServ settings, clone ChanServ channel setings, and * BotServ and ChanServ settings, clone ChanServ channel settings, and
* set ChanServ logging options. * set ChanServ logging options.
*/ */
privilege privilege
{ {
name = "SET" name = "SET"
desc = _("Allowed to set channel settings")
rank = 320 rank = 320
level = 9999 level = 9999
flag = "s" flag = "s"
@@ -715,6 +747,7 @@ privilege
privilege privilege
{ {
name = "SIGNKICK" name = "SIGNKICK"
desc = _("No signed kick when SIGNKICK LEVEL is used")
rank = 140 rank = 140
level = 9999 level = 9999
flag = "K" flag = "K"
@@ -731,6 +764,7 @@ privilege
privilege privilege
{ {
name = "TOPIC" name = "TOPIC"
desc = _("Allowed to change channel topics")
rank = 160 rank = 160
level = 5 level = 5
flag = "t" flag = "t"
@@ -747,12 +781,30 @@ privilege
privilege privilege
{ {
name = "UNBAN" name = "UNBAN"
desc = _("Allowed to unban users")
rank = 200 rank = 200
level = 4 level = 4
flag = "u" flag = "u"
xop = "HOP" xop = "HOP"
} }
/*
* UNBANME privilege.
*
* Used by chanserv/unban.
*
* Users with this permission can unban themself through ChanServ.
*/
privilege
{
name = "UNBANME"
desc = _("Allowed to unban themself")
rank = 200
level = 4
flag = "U"
xop = "HOP"
}
/* /*
* VOICE privilege. * VOICE privilege.
* *
@@ -764,6 +816,7 @@ privilege
privilege privilege
{ {
name = "VOICE" name = "VOICE"
desc = _("Allowed to (de)voice users")
rank = 70 rank = 70
level = 4 level = 4
flag = "v" flag = "v"
@@ -781,6 +834,7 @@ privilege
privilege privilege
{ {
name = "VOICEME" name = "VOICEME"
desc = _("Allowed to (de)voice themself")
rank = 60 rank = 60
level = 3 level = 3
flag = "v" flag = "v"
@@ -836,8 +890,8 @@ command { service = "ChanServ"; name = "HELP"; command = "generic/help"; }
* Provides commands chanserv/access and chanserv/levels. * Provides commands chanserv/access and chanserv/levels.
* Provides the access system "levels". * Provides the access system "levels".
* *
* Used for giving users access in channels using a levels system. Allows allows redefining which privileges * Used for giving users access in channels using a levels system. Allows redefining which privileges
* are representated by given level on a per channel basis. * are represented by given level on a per channel basis.
* *
* The "LIST" subcommand of chanserv/access will show every access entry on the channel, including access * The "LIST" subcommand of chanserv/access will show every access entry on the channel, including access
* entries not added by cs_access. The "level" of these entries will be the representation of the access * entries not added by cs_access. The "level" of these entries will be the representation of the access
@@ -941,7 +995,7 @@ command { service = "ChanServ"; name = "ENTRYMSG"; command = "chanserv/entrymsg"
* Used for giving users access in channels. * Used for giving users access in channels.
* *
* The "LIST" subcommand of chanserv/flags will show every access entry on the channel, including access * The "LIST" subcommand of chanserv/flags will show every access entry on the channel, including access
* entries not added by cs_flags. The "Flags" of these entries will be the flags representation of the * entries not added by cs_flags. The "flags" of these entries will be the flags representation of the
* privilege set granted by the access entry. * privilege set granted by the access entry.
*/ */
module { name = "cs_flags" } module { name = "cs_flags" }
@@ -1055,7 +1109,7 @@ command { service = "ChanServ"; name = "LOG"; command = "chanserv/log"; group =
* Provides the command chanserv/mode and chanserv/modes. * Provides the command chanserv/mode and chanserv/modes.
* *
* Used for changing mode locks and changing modes. Multiple commands may be mapped to chanserv/modes, the * Used for changing mode locks and changing modes. Multiple commands may be mapped to chanserv/modes, the
* configuration directive 'set' and 'unset' are used to tell chanserv/modes which modes should be set or * configuration directives 'set' and 'unset' are used to tell chanserv/modes which modes should be set or
* unset when the command is executed. * unset when the command is executed.
*/ */
module module
@@ -1121,9 +1175,6 @@ module
/* Sets the time to keep seen entries in the seen database. */ /* Sets the time to keep seen entries in the seen database. */
purgetime = "30d" purgetime = "30d"
/* Sets the delay between checks for expired seen entries. */
expiretimeout = "1d"
} }
command { service = "OperServ"; name = "SEEN"; command = "operserv/seen"; permission = "operserv/seen"; } command { service = "OperServ"; name = "SEEN"; command = "operserv/seen"; permission = "operserv/seen"; }
@@ -1166,7 +1217,7 @@ module
defbantype = 2 defbantype = 2
/* /*
* If set, persisent channels have their creation times lowered to their * If set, persistent channels have their creation times lowered to their
* original registration dates. * original registration dates.
*/ */
persist_lower_ts = true persist_lower_ts = true
@@ -1210,6 +1261,7 @@ command { service = "ChanServ"; name = "SET EMAIL"; command = "chanserv/set/misc
*/ */
module { name = "cs_status" } module { name = "cs_status" }
command { service = "ChanServ"; name = "STATUS"; command = "chanserv/status"; } command { service = "ChanServ"; name = "STATUS"; command = "chanserv/status"; }
command { service = "ChanServ"; name = "WHY"; command = "chanserv/status"; hide = true; }
/* /*
* cs_suspend * cs_suspend
@@ -1290,7 +1342,7 @@ command { service = "ChanServ"; name = "UP"; command = "chanserv/up"; group = "c
* Provides the access system "XOP". * Provides the access system "XOP".
* *
* Used for giving users access in channels. Many commands may be linked to chanserv/xop, but the * Used for giving users access in channels. Many commands may be linked to chanserv/xop, but the
* privileges given by each is determined by the privilege:xop settings above. These commands should * privileges given by each are determined by the privilege:xop settings above. These commands should
* be ordered from highest to lowest, as each command inherits the privileges of the commands below * be ordered from highest to lowest, as each command inherits the privileges of the commands below
* it. * it.
* *
@@ -1312,7 +1364,7 @@ command { service = "ChanServ"; name = "VOP"; command = "chanserv/xop"; group =
/* /*
* cs_statusupdate * cs_statusupdate
* *
* This module automatically updates users status on channels when the * This module automatically updates users' status on channels when the
* channel's access list is modified. * channel's access list is modified.
*/ */
module { name = "cs_statusupdate" } module { name = "cs_statusupdate" }
+2 -2
View File
@@ -5,7 +5,7 @@
module module
{ {
name = "m_chanstats" name = "chanstats"
/* /*
* The name of this engine. * The name of this engine.
@@ -32,7 +32,7 @@ module
} }
command { service = "ChanServ"; name = "SET CHANSTATS"; command = "chanserv/set/chanstats"; } command { service = "ChanServ"; name = "SET CHANSTATS"; command = "chanserv/set/chanstats"; }
command { service = "NickServ"; name = "SET CHANSTATS"; command = "nickserv/set/chanstats"; } command { service = "NickServ"; name = "SET CHANSTATS"; command = "nickserv/set/chanstats"; }
command { service = "NickServ"; name = "SASET CHANSTATS"; command = "nickserv/saset/chanstats"; } command { service = "NickServ"; name = "SASET CHANSTATS"; command = "nickserv/saset/chanstats"; permission = "nickserv/saset/chanstats"; }
module { name = "cs_fantasy_stats" } module { name = "cs_fantasy_stats" }
command { service = "ChanServ"; name = "STATS"; command = "chanserv/stats"; } command { service = "ChanServ"; name = "STATS"; command = "chanserv/stats"; }
+4 -4
View File
@@ -9,16 +9,16 @@
############################################################### ###############################################################
# Anope binary directory # Anope binary directory
ANOPATH=/home/ircd/services/bin ANOPATH=/home/ircd/anope/bin
# Anope data directory # Anope data directory
ANODATA=/home/ircd/services/data ANODATA=/home/ircd/anope/data
# Name of the pid file # Name of the pid file
ANOPIDF=services.pid ANOPIDF=anope.pid
# Name of the executable # Name of the executable
ANOPROG=services ANOPROG=anope
# Parameters to pass to the executable # Parameters to pass to the executable
ANOARGS="" ANOARGS=""
+4 -4
View File
@@ -66,15 +66,15 @@ module
client = "Global" client = "Global"
/* /*
* This is the global message that will be sent when Services are being * This is the global message that will be sent when Anope is being
* shutdown/restarted. * shutdown/restarted.
* *
* This directive is optional. * This directive is optional.
*/ */
#globaloncycledown = "Services are restarting, they will be back shortly - please be good while we're gone" #globaloncycledown = "Services are restarting, they will be back shortly - please be good while they're gone"
/* /*
* This is the global message that will be sent when Services (re)join the * This is the global message that will be sent when Anope (re)joins the
* network. * network.
* *
* This directive is optional. * This directive is optional.
@@ -82,7 +82,7 @@ module
#globaloncycleup = "Services are now back online - have a nice day" #globaloncycleup = "Services are now back online - have a nice day"
/* /*
* If set, Services will hide the IRC Operator's nick in a global * If set, Anope will hide the IRC Operator's nick in a global
* message/notice. * message/notice.
* *
* This directive is optional. * This directive is optional.
+4 -4
View File
@@ -110,12 +110,12 @@ module
/* /*
* Upon nickserv/group, this option syncs the nick's main vHost to the grouped nick. * Upon nickserv/group, this option syncs the nick's main vHost to the grouped nick.
*/ */
syncongroup = false syncongroup = true
/* /*
* This makes vhosts act as if they are per account. * This makes vhosts act as if they are per account.
*/ */
synconset = false synconset = true
} }
command { service = "HostServ"; name = "GROUP"; command = "hostserv/group"; } command { service = "HostServ"; name = "GROUP"; command = "hostserv/group"; }
@@ -161,13 +161,13 @@ module
name = "hs_request" name = "hs_request"
/* /*
* If set, Services will send a memo to the user requesting a vHost when it's been * If set, Anope will send a memo to the user requesting a vHost when it's been
* approved or rejected. * approved or rejected.
*/ */
#memouser = yes #memouser = yes
/* /*
* If set, Services will send a memo to all Services staff when a new vHost is requested. * If set, Anope will send a memo to all services staff when a new vHost is requested.
*/ */
#memooper = yes #memooper = yes
} }
+4 -5
View File
@@ -18,7 +18,7 @@ service
/* /*
* The hostname of the StatServ client. * The hostname of the StatServ client.
*/ */
host = "services.host" host = "stats.host"
/* /*
* The realname of the StatServ client. * The realname of the StatServ client.
@@ -45,7 +45,7 @@ service
* *
* Prefixes may be given to the channels in the form of mode characters or prefix symbols. * Prefixes may be given to the channels in the form of mode characters or prefix symbols.
*/ */
#channels = "@#services,#mychan" #channels = "@#stats,#mychan"
} }
module module
@@ -58,7 +58,7 @@ module
*/ */
client = "StatServ" client = "StatServ"
/* /*
* The name of the SQL engine to use. * The name of the SQL engine to use.
* This must be MySQL and must match the name in the mysql{} block * This must be MySQL and must match the name in the mysql{} block
*/ */
@@ -84,7 +84,7 @@ module
/* /*
* Get the CTCP version from users * Get the CTCP version from users
* The users connecting to the network will receive a CTCP VERSION * The users connecting to the network will receive a CTCP VERSION
* request from the above configured services client * request from the above configured stats client
*/ */
ctcpuser = "yes" ctcpuser = "yes"
@@ -95,4 +95,3 @@ module
*/ */
ctcpeob = "yes" ctcpeob = "yes"
} }
+119 -112
View File
@@ -3,7 +3,7 @@
* *
* The following blocks are used to load all non-core modules, including 3rd-party modules. * The following blocks are used to load all non-core modules, including 3rd-party modules.
* Modules can be prevented from loading by commenting out the line, other modules can be added by * Modules can be prevented from loading by commenting out the line, other modules can be added by
* adding a module block. These modules will be loaded prior to Services connecting to your network. * adding a module block. These modules will be loaded prior to Anope connecting to your network.
* *
* Note that some of these modules are labeled EXTRA, and must be enabled prior to compiling by * Note that some of these modules are labeled EXTRA, and must be enabled prior to compiling by
* running the 'extras' script on Linux and UNIX. * running the 'extras' script on Linux and UNIX.
@@ -19,18 +19,18 @@
module { name = "help" } module { name = "help" }
/* /*
* m_dns * dns
* *
* Adds support for the DNS protocol. By itself this module does nothing useful, * Adds support for the DNS protocol. By itself this module does nothing useful,
* but other modules such as m_dnsbl and os_dns require this. * but other modules such as dnsbl and os_dns require this.
*/ */
#module #module
{ {
name = "m_dns" name = "dns"
/* /*
* The nameserver to use for resolving hostnames, must be an IP or a resolver configuration file. * The nameserver to use for resolving hostnames, must be an IP or a resolver configuration file.
* The below should work fine on all unix like systems. Windows users will have to find their nameservers * The below should work fine on all UNIX-like systems. Windows users will have to find their nameservers
* from ipconfig /all and put the IP here. * from ipconfig /all and put the IP here.
*/ */
nameserver = "/etc/resolv.conf" nameserver = "/etc/resolv.conf"
@@ -80,7 +80,7 @@ module { name = "help" }
} }
/* /*
* m_dnsbl * dnsbl
* *
* Allows configurable DNS blacklists to check connecting users against. If a user * Allows configurable DNS blacklists to check connecting users against. If a user
* is found on the blacklist they will be immediately banned. This is a crucial module * is found on the blacklist they will be immediately banned. This is a crucial module
@@ -88,17 +88,17 @@ module { name = "help" }
*/ */
#module #module
{ {
name = "m_dnsbl" name = "dnsbl"
/* /*
* If set, Services will check clients against the DNSBLs when services connect to its uplink. * If set, Anope will check clients against the DNSBLs when services connect to its uplink.
* This is not recommended, and on large networks will open a very large amount of DNS queries. * This is not recommended, and on large networks will open a very large amount of DNS queries.
* Whilst services are not drastically affected by this, your nameserver/DNSBL might care. * Whilst services are not drastically affected by this, your nameserver/DNSBL might care.
*/ */
check_on_connect = no check_on_connect = no
/* /*
* If set, Services will check clients when coming back from a netsplit. This can cause a large number * If set, Anope will check clients when coming back from a netsplit. This can cause a large number
* of DNS queries open at once. Whilst services are not drastically affected by this, your nameserver/DNSBL * of DNS queries open at once. Whilst services are not drastically affected by this, your nameserver/DNSBL
* might care. * might care.
*/ */
@@ -127,9 +127,9 @@ module { name = "help" }
* %r is the reply reason (configured below). Will be nothing if not configured. * %r is the reply reason (configured below). Will be nothing if not configured.
* %N is the network name set in networkinfo:networkname * %N is the network name set in networkinfo:networkname
*/ */
reason = "You are listed in the efnet RBL, visit http://rbl.efnetrbl.org/?i=%i for info" reason = "You are listed in the EFnet RBL, visit https://rbl.efnetrbl.org/?i=%i for info"
/* Replies to ban and their reason. If no relies are configured, all replies get banned. */ /* Replies to ban and their reason. If no replies are configured, all replies get banned. */
reply reply
{ {
code = 1 code = 1
@@ -171,27 +171,27 @@ module { name = "help" }
{ {
name = "dnsbl.dronebl.org" name = "dnsbl.dronebl.org"
time = 4h time = 4h
reason = "You have a host listed in the DroneBL. For more information, visit http://dronebl.org/lookup_branded?ip=%i&network=%N" reason = "You have a host listed in the DroneBL. For more information, visit https://dronebl.org/lookup_branded?ip=%i&network=%N"
} }
/* Exempt localhost from DNSBL checks */ /* Exempt localhost from DNSBL checks */
exempt { ip = "127.0.0.1" } exempt { ip = "127.0.0.0/8" }
} }
/* /*
* m_helpchan * helpchan
* *
* Gives users who are op in the specified help channel usermode +h (helpop). * Gives users who are op in the specified help channel usermode +h (helpop).
*/ */
#module #module
{ {
name = "m_helpchan" name = "helpchan"
helpchannel = "#help" helpchannel = "#help"
} }
/* /*
* m_httpd * httpd
* *
* Allows services to serve web pages. By itself, this module does nothing useful. * Allows services to serve web pages. By itself, this module does nothing useful.
* *
@@ -200,7 +200,7 @@ module { name = "help" }
*/ */
#module #module
{ {
name = "m_httpd" name = "httpd"
httpd httpd
{ {
@@ -223,8 +223,9 @@ module { name = "help" }
* extforward_headers set below, set this to its IP. * extforward_headers set below, set this to its IP.
* This allows services to obtain the real IP of users by * This allows services to obtain the real IP of users by
* reading the forwarded-for HTTP header. * reading the forwarded-for HTTP header.
* Multiple IP addresses can be specified separated by a space character.
*/ */
#extforward_ip = "192.168.0.255" #extforward_ip = "192.168.0.255 192.168.1.255"
/* The header to look for. These probably work as is. */ /* The header to look for. These probably work as is. */
extforward_header = "X-Forwarded-For Forwarded-For" extforward_header = "X-Forwarded-For Forwarded-For"
@@ -232,18 +233,17 @@ module { name = "help" }
} }
/* /*
* m_ldap [EXTRA] * ldap [EXTRA]
* *
* This module allows other modules to use LDAP. By itself, this module does nothing useful. * This module allows other modules to use LDAP. By itself, this module does nothing useful.
*/ */
#module #module
{ {
name = "m_ldap" name = "ldap"
ldap ldap
{ {
server = "ldap://127.0.0.1" server = "ldap://127.0.0.1"
port = 389
/* /*
* Admin credentials used for performing searches and adding users. * Admin credentials used for performing searches and adding users.
@@ -254,14 +254,14 @@ module { name = "help" }
} }
/* /*
* m_ldap_authentication [EXTRA] * ldap_authentication [EXTRA]
* *
* This module allows many commands such as IDENTIFY, RELEASE, RECOVER, GHOST, etc. use * This module allows many commands such as IDENTIFY, RELEASE, RECOVER, GHOST, etc. use
* LDAP to authenticate users. Requires m_ldap. * LDAP to authenticate users. Requires ldap.
*/ */
#module #module
{ {
name = "m_ldap_authentication" name = "ldap_authentication"
/* /*
* The distinguished name used for searching for users's accounts. * The distinguished name used for searching for users's accounts.
@@ -299,31 +299,31 @@ module { name = "help" }
password_attribute = "userPassword" password_attribute = "userPassword"
/* /*
* If set, the reason to give the users who try to register with nickserv, * If set, the reason to give the users who try to register with NickServ,
* including nick registration from grouping. * including nick registration from grouping.
* *
* If not set, then registration is not blocked. * If not set, then registration is not blocked.
*/ */
#disable_register_reason = "To register on this network visit http://some.misconfigured.site/register" #disable_register_reason = "To register on this network visit https://some.misconfigured.site/register"
/* /*
* If set, the reason to give the users who try to "/msg NickServ SET EMAIL". * If set, the reason to give the users who try to "/msg NickServ SET EMAIL".
* If not set, then email changing is not blocked. * If not set, then email changing is not blocked.
*/ */
#disable_email_reason = "To change your email address visit http://some.misconfigured.site" #disable_email_reason = "To change your email address visit https://some.misconfigured.site"
} }
/* /*
* m_ldap_oper [EXTRA] * ldap_oper [EXTRA]
* *
* This module dynamically ties users to Anope opertypes when they identify * This module dynamically ties users to Anope opertypes when they identify
* via LDAP group membership. Requires m_ldap. * via LDAP group membership. Requires ldap.
* *
* Note that this doesn't give the user privileges on the IRCd, only in Services. * Note that this doesn't give the user privileges on the IRCd, only in Anope.
*/ */
#module #module
{ {
name = "m_ldap_oper" name = "ldap_oper"
/* /*
* An optional binddn to use when searching for groups. * An optional binddn to use when searching for groups.
@@ -355,13 +355,13 @@ module { name = "help" }
} }
/* /*
* m_mysql [EXTRA] * mysql [EXTRA]
* *
* This module allows other modules to use MySQL. * This module allows other modules to use MySQL.
*/ */
#module #module
{ {
name = "m_mysql" name = "mysql"
mysql mysql
{ {
@@ -374,14 +374,15 @@ module { name = "help" }
port = 3306 port = 3306
} }
} }
/* /*
* m_redis * redis
* *
* This module allows other modules to use Redis. * This module allows other modules to use Redis.
*/ */
#module #module
{ {
name = "m_redis" name = "redis"
/* A redis database */ /* A redis database */
redis redis
@@ -400,45 +401,68 @@ module { name = "help" }
} }
/* /*
* m_regex_pcre [EXTRA] * regex_pcre2 [EXTRA]
* *
* Provides the regex engine regex/pcre, which uses the Perl Compatible Regular Expressions library. * Provides the regex engine regex/pcre, which uses version 2 of the Perl Compatible Regular
* Expressions library.
*/ */
#module { name = "m_regex_pcre" } #module { name = "regex_pcre2" }
/* /*
* m_regex_posix [EXTRA] * regex_posix [EXTRA]
* *
* Provides the regex engine regex/posix, which uses the POSIX compliant regular expressions. * Provides the regex engine regex/posix, which uses the POSIX compliant regular expressions.
* This is likely the only regex module you will not need extra libraries for.
*/ */
#module { name = "m_regex_posix" } #module { name = "regex_posix" }
/* /*
* m_regex_tre [EXTRA] * regex_stdlib
*
* Provides the regex engine regex/stdlib, which uses the regular expression library that is part of
* the C++ standard library.
*/
module
{
name = "regex_stdlib"
/*
* The syntax scheme to use. Can be set to awk to use the regular expression grammar used by the
* awk utility in POSIX, basic to use the basic POSIX regular expression grammar, ecmascript to
* use the modified ECMAScript regular expression grammar, egrep to use the regular expression
* grammar used by the grep utility with the -E option in POSIX, extended to use the extended
* POSIX regular expression grammar, or grep to use the regular expression grammar used by the
* grep utility in POSIX.
*
* See https://en.cppreference.com/w/cpp/regex/syntax_option_type for more information.
*/
syntax = "ecmascript"
}
/*
* regex_tre [EXTRA]
* *
* Provides the regex engine regex/tre, which uses the TRE regex library. * Provides the regex engine regex/tre, which uses the TRE regex library.
*/ */
#module { name = "m_regex_tre" } #module { name = "regex_tre" }
/* /*
* m_rewrite * rewrite
* *
* Allows rewriting commands sent to/from clients. * Allows rewriting commands sent to/from clients.
*/ */
#module { name = "m_rewrite" } #module { name = "rewrite" }
#command #command
{ {
service = "ChanServ"; name = "CLEAR"; command = "rewrite" service = "ChanServ"; name = "CLEAR"; command = "rewrite"
/* Enable m_rewrite. */ /* Enable rewrite. */
rewrite = true rewrite = true
/* Source message to match. A $ can be used to match anything. */ /* Source message to match. A $ can be used to match anything. */
rewrite_source = "CLEAR $ USERS" rewrite_source = "CLEAR $ USERS"
/* /*
* Message to rewrite the source message to. A $ followed by a number, eg $0, gets * Message to rewrite the source message to. A $ followed by a number, e.g. $0, gets
* replaced by the number-th word from the source_message, starting from 0. * replaced by the number-th word from the source_message, starting from 0.
*/ */
rewrite_target = "KICK $1 *" rewrite_target = "KICK $1 *"
@@ -452,7 +476,7 @@ module { name = "help" }
} }
/* /*
* m_proxyscan * proxyscan
* *
* This module allows you to scan connecting clients for open proxies. * This module allows you to scan connecting clients for open proxies.
* Note that using this will allow users to get the IP of your services. * Note that using this will allow users to get the IP of your services.
@@ -466,7 +490,7 @@ module { name = "help" }
*/ */
#module #module
{ {
name = "m_proxyscan" name = "proxyscan"
/* /*
* The target IP services tells the proxy to connect back to. This must be a publicly * The target IP services tells the proxy to connect back to. This must be a publicly
@@ -534,56 +558,38 @@ module { name = "help" }
} }
/* /*
* m_sasl * sasl
* *
* Some IRCds allow "SASL" authentication to let users identify to Services * Some IRCds allow "SASL" authentication to let users identify to services
* during the IRCd user registration process. If this module is loaded, Services will allow * during the IRCd user registration process. If this module is loaded, Anope will allow
* authenticating users through this mechanism. Supported mechanisms are: * authenticating users through this mechanism. Supported mechanisms are:
* PLAIN, EXTERNAL. * PLAIN, EXTERNAL.
*/ */
#module { name = "m_sasl" } module { name = "sasl" }
/* /*
* m_sasl_dh-aes [EXTRA] * ssl_gnutls [EXTRA]
*
* Add the DH-AES mechanism to SASL.
* Requires m_sasl to be loaded.
* Requires openssl.
*/
#module { name = "m_sasl_dh-aes" }
/*
* m_sasl_dh-blowfish [EXTRA]
*
* Add the DH-BLOWFISH mechanism to SASL.
* Requires m_sasl to be loaded.
* Requires openssl.
*/
#module { name = "m_sasl_dh-blowfish" }
/*
* m_ssl_gnutls [EXTRA]
* *
* This module provides SSL services to Anope using GnuTLS, for example to * This module provides SSL services to Anope using GnuTLS, for example to
* connect to the uplink server(s) via SSL. * connect to the uplink server(s) via SSL.
* *
* You may only load either m_ssl_gnutls or m_ssl_openssl, bot not both. * You may only load either ssl_gnutls or ssl_openssl, but not both.
*/ */
#module #module
{ {
name = "m_ssl_gnutls" name = "ssl_gnutls"
/* /*
* An optional certificate and key for m_ssl_gnutls to give to the uplink. * An optional certificate and key for ssl_gnutls to give to the uplink.
* *
* You can generate your own certificate and key pair by using: * You can generate your own certificate and key pair by using:
* *
* certtool --generate-privkey --bits 2048 --outfile anope.key * certtool --generate-privkey --bits 2048 --outfile privkey.pem
* certtool --generate-self-signed --load-privkey anope.key --outfile anope.crt * certtool --generate-self-signed --load-privkey privkey.pem --outfile fullchain.pem
* *
*/ */
cert = "data/anope.crt" cert = "data/fullchain.pem"
key = "data/anope.key" key = "data/privkey.pem"
/* /*
* Diffie-Hellman parameters to use when acting as a server. This is only * Diffie-Hellman parameters to use when acting as a server. This is only
@@ -600,49 +606,50 @@ module { name = "help" }
} }
/* /*
* m_ssl_openssl [EXTRA] * ssl_openssl [EXTRA]
* *
* This module provides SSL services to Anope using OpenSSL, for example to * This module provides SSL services to Anope using OpenSSL, for example to
* connect to the uplink server(s) via SSL. * connect to the uplink server(s) via SSL.
* *
* You may only load either m_ssl_openssl or m_ssl_gnutls, bot not both. * You may only load either ssl_openssl or ssl_gnutls, but not both.
* *
*/ */
#module #module
{ {
name = "m_ssl_openssl" name = "ssl_openssl"
/* /*
* An optional certificate and key for m_ssl_openssl to give to the uplink. * An optional certificate and key for ssl_openssl to give to the uplink.
* *
* You can generate your own certificate and key pair by using: * You can generate your own certificate and key pair by using:
* *
* openssl genrsa -out anope.key 2048 * openssl genrsa -out privkey.pem 2048
* openssl req -new -x509 -key anope.key -out anope.crt -days 1095 * openssl req -new -x509 -key privkey.pem -out fullchain.pem -days 1095
*/ */
cert = "data/anope.crt" cert = "data/fullchain.pem"
key = "data/anope.key" key = "data/privkey.pem"
/* /*
* As of 2014 SSL 3.0 is considered insecure, but it might be enabled * If you wish to increase security you can disable support for older
* on some systems by default for compatibility reasons. * versions of TLS with no known vulnerabilities but that provide less
* You can use the following option to enable or disable it explicitly. * security. For your security SSLv2 and SSLv3 are always disabled.
* Leaving this option not set defaults to the default system behavior.
*/ */
#sslv3 = no #tlsv10 = no
#tlsv11 = no
#tlsv12 = yes
} }
/* /*
* m_sql_authentication [EXTRA] * sql_authentication [EXTRA]
* *
* This module allows authenticating users against an external SQL database using a custom * This module allows authenticating users against an external SQL database using a custom
* query. * query.
*/ */
#module #module
{ {
name = "m_sql_authentication" name = "sql_authentication"
/* SQL engine to use. Should be configured elsewhere with m_mysql, m_sqlite, etc. */ /* SQL engine to use. Should be configured elsewhere with mysql, sqlite, etc. */
engine = "mysql/main" engine = "mysql/main"
/* Query to execute to authenticate. A non empty result from this query is considered a success, /* Query to execute to authenticate. A non empty result from this query is considered a success,
@@ -674,17 +681,17 @@ module { name = "help" }
* If set, the reason to give the users who try to "/msg NickServ REGISTER". * If set, the reason to give the users who try to "/msg NickServ REGISTER".
* If not set, then registration is not blocked. * If not set, then registration is not blocked.
*/ */
#disable_reason = "To register on this network visit http://some.misconfigured.site/register" #disable_reason = "To register on this network visit https://some.misconfigured.site/register"
/* /*
* If set, the reason to give the users who try to "/msg NickServ SET EMAIL". * If set, the reason to give the users who try to "/msg NickServ SET EMAIL".
* If not set, then email changing is not blocked. * If not set, then email changing is not blocked.
*/ */
#disable_email_reason = "To change your email address visit http://some.misconfigured.site" #disable_email_reason = "To change your email address visit https://some.misconfigured.site"
} }
/* /*
* m_sql_log [EXTRA] * sql_log [EXTRA]
* *
* This module adds an additional target option to log{} blocks * This module adds an additional target option to log{} blocks
* that allows logging Service's logs to SQL. To log to SQL, add * that allows logging Service's logs to SQL. To log to SQL, add
@@ -701,24 +708,24 @@ module { name = "help" }
* it if it doesn't exist. This module does not create any indexes (keys) * it if it doesn't exist. This module does not create any indexes (keys)
* on the table and it is recommended you add them yourself as necessary. * on the table and it is recommended you add them yourself as necessary.
*/ */
#module { name = "m_sql_log" } #module { name = "sql_log" }
/* /*
* m_sql_oper [EXTRA] * sql_oper [EXTRA]
* *
* This module allows granting users services operator privileges and possibly IRC Operator * This module allows granting users services operator privileges and possibly IRC Operator
* privileges based on an external SQL database using a custom query. * privileges based on an external SQL database using a custom query.
*/ */
#module #module
{ {
name = "m_sql_oper" name = "sql_oper"
/* SQL engine to use. Should be configured elsewhere with m_mysql, m_sqlite, etc. */ /* SQL engine to use. Should be configured elsewhere with mysql, sqlite, etc. */
engine = "mysql/main" engine = "mysql/main"
/* Query to execute to determine if a user should have operator privileges. /* Query to execute to determine if a user should have operator privileges.
* A field named opertype must be returned in order to link the user to their oper type. * A field named opertype must be returned in order to link the user to their oper type.
* The oper types must be configured earlier in services.conf. * The oper types must be configured earlier in anope.conf.
* *
* If a field named modes is returned from this query then those modes are set on the user. * If a field named modes is returned from this query then those modes are set on the user.
* Without this, only a simple +o is sent. * Without this, only a simple +o is sent.
@@ -730,13 +737,13 @@ module { name = "help" }
} }
/* /*
* m_sqlite [EXTRA] * sqlite [EXTRA]
* *
* This module allows other modules to use SQLite. * This module allows other modules to use SQLite.
*/ */
#module #module
{ {
name = "m_sqlite" name = "sqlite"
/* A SQLite database */ /* A SQLite database */
sqlite sqlite
@@ -756,7 +763,7 @@ module { name = "help" }
* as they could over IRC. If you are using the default configuration you should be able to access * as they could over IRC. If you are using the default configuration you should be able to access
* this panel by visiting http://127.0.0.1:8080 in your web browser from the machine Anope is running on. * this panel by visiting http://127.0.0.1:8080 in your web browser from the machine Anope is running on.
* *
* This module requires m_httpd. * This module requires httpd.
*/ */
#module #module
{ {
@@ -773,23 +780,23 @@ module { name = "help" }
} }
/* /*
* m_xmlrpc * xmlrpc
* *
* Allows remote applications (websites) to execute queries in real time to retrieve data from Anope. * Allows remote applications (websites) to execute queries in real time to retrieve data from Anope.
* By itself this module does nothing, but allows other modules (m_xmlrpc_main) to receive and send XMLRPC queries. * By itself this module does nothing, but allows other modules (m_xmlrpc_main) to receive and send XMLRPC queries.
*/ */
#module #module
{ {
name = "m_xmlrpc" name = "xmlrpc"
/* Web service to use. Requires m_httpd. */ /* Web service to use. Requires httpd. */
server = "httpd/main" server = "httpd/main"
} }
/* /*
* m_xmlrpc_main * xmlrpc_main
* *
* Adds the main XMLRPC core functions. * Adds the main XMLRPC core functions.
* Requires m_xmlrpc. * Requires xmlrpc.
*/ */
#module { name = "m_xmlrpc_main" } #module { name = "xmlrpc_main" }
+60 -47
View File
@@ -79,7 +79,7 @@ module
confirmemailchanges = no confirmemailchanges = no
/* /*
* A message sent to users on connect if they use an unregistered nick. * A message sent to users on connect if they use an unregistered nick. %n will be replaced with the user's nickname.
* *
* This directive is optional. * This directive is optional.
*/ */
@@ -92,26 +92,30 @@ module
* *
* The options are: * The options are:
* - killprotect: Kill nick if not identified within 60 seconds * - killprotect: Kill nick if not identified within 60 seconds
* - kill_quick: Kill nick if not identified within 20 seconds, this one overrides the above * - kill_quick: Kill nick if not identified within 20 seconds, this one overrides the killprotect
* option and the above must be specified with this one * option and the killprotect option must be specified with this one
* - kill_immed: Kill nick immediately if not identified, this one overrides both the killprotect
* and kill_quick options and the killprotect option must be specified with this one
* - ns_secure: Enable nickname security, requiring the nick's password before any operations * - ns_secure: Enable nickname security, requiring the nick's password before any operations
* can be done on it * can be done on it
* - ns_private: Hide the nick from NickServ's LIST command * - ns_private: Hide the nick from NickServ's LIST command
* - hide_email: Hide's the nick's e-mail address from NickServ's INFO command * - hide_email: Hide the nick's e-mail address from NickServ's INFO command
* - hide_mask: Hide's the nick's last or current user@host from NickServ's INFO command * - hide_mask: Hide the nick's last or current user@host from NickServ's INFO command
* - hide_quit: Hide's the nick's last quit message * - hide_status: Hide the nick's services operator access status from NickServ's INFO command
* - hide_quit: Hide the nick's last quit message from NickServ's INFO command
* - memo_signon: Notify user if they have a new memo when they sign into the nick * - memo_signon: Notify user if they have a new memo when they sign into the nick
* - memo_receive: Notify user if they have a new memo as soon as it's received * - memo_receive: Notify user if they have a new memo as soon as it's received
* - memo_mail: Notify user if they have a new memo by mail * - memo_mail: Notify user if they have a new memo by mail
* - autoop: User will be automatically opped in channels they enter and have access to * - autoop: User will be automatically opped in channels they enter and have access to
* - msg: Services messages will be sent as PRIVMSGs instead of NOTICEs, requires * - neverop: User can not be added to access lists
* options:useprivmsg to be enabled as well * - msg: Messages will be sent as PRIVMSGs instead of NOTICEs, requires options:useprivmsg
* - ns_keepmodes: Enables keepmodes, which retains user modes across sessions * to be enabled as well
* - ns_keep_modes: Enables keepmodes, which retains user modes across sessions
* *
* This directive is optional, if left blank, the options will default to ns_secure, memo_signon, and * This directive is optional, if left blank, the options will default to ns_secure, memo_signon, and
* memo_receive. If you really want no defaults, use "none" by itself as the option. * memo_receive. If you really want no defaults, use "none" by itself as the option.
*/ */
defaults = "ns_secure ns_private hide_email hide_mask memo_signon memo_receive autoop" defaults = "killprotect ns_secure ns_private hide_email hide_mask memo_signon memo_receive autoop"
/* /*
* The minimum length of time between consecutive uses of NickServ's REGISTER command. This * The minimum length of time between consecutive uses of NickServ's REGISTER command. This
@@ -122,20 +126,20 @@ module
/* /*
* The length of time before a nick's registration expires. * The length of time before a nick's registration expires.
* *
* This directive is optional, but recommended. If not set, the default is 21 days. * This directive is optional, but recommended. If not set, the default is 90 days.
*/ */
expire = 21d expire = 90d
/* /*
* Prevents the use of the ACCESS and CERT (excluding their LIST subcommand), DROP, FORBID, SUSPEND, * Prevents the use of the ACCESS and CERT (excluding their LIST subcommand), DROP, FORBID, SUSPEND
* GETPASS and SET PASSWORD commands by services operators on other services operators. * and SET PASSWORD commands by services operators on other services operators.
* *
* This directive is optional, but recommended. * This directive is optional, but recommended.
*/ */
secureadmins = yes secureadmins = yes
/* /*
* If set, Services will set the channel modes a user has access to upon identifying, assuming * If set, Anope will set the channel modes a user has access to upon identifying, assuming
* they are not already set. * they are not already set.
* *
* This directive is optional. * This directive is optional.
@@ -143,14 +147,14 @@ module
modeonid = yes modeonid = yes
/* /*
* If set, Services will set these user modes on any user who identifies. * If set, Anope will set these user modes on any user who identifies.
* *
* This directive is optional. * This directive is optional.
*/ */
#modesonid = "+R" #modesonid = "+R"
/* /*
* If set, Services will not show netsplits in the last quit message field * If set, Anope will not show netsplits in the last quit message field
* of NickServ's INFO command. * of NickServ's INFO command.
*/ */
hidenetsplitquit = no hidenetsplitquit = no
@@ -164,7 +168,7 @@ module
/* /*
* If set, forbids the registration of nicks that contain an existing * If set, forbids the registration of nicks that contain an existing
* nick with Services access. For example, if Tester is a Services Oper, * nick with services access. For example, if Tester is a Services Oper,
* you can't register NewTester or Tester123 unless you are an IRC * you can't register NewTester or Tester123 unless you are an IRC
* Operator. * Operator.
* *
@@ -177,14 +181,14 @@ module
#restrictopernicks = yes #restrictopernicks = yes
/* /*
* The username, and possibly hostname, used for fake users created when Services needs to * The username, and possibly hostname, used for fake users created when Anope needs to
* hold a nickname. * hold a nickname.
*/ */
enforceruser = "enforcer" enforceruser = "enforcer"
enforcerhost = "services.host" enforcerhost = "services.host"
/* /*
* The length of time Services hold nicknames. * The length of time Anope should hold nicknames for.
* *
* This directive is optional, but recommended. If not set it defaults to 1 minute. * This directive is optional, but recommended. If not set it defaults to 1 minute.
*/ */
@@ -200,16 +204,23 @@ module
guestnickprefix = "Guest" guestnickprefix = "Guest"
/* /*
* If set, Services do not allow ownership of nick names, only ownership of accounts. * If set, Anope does not allow ownership of nick names, only ownership of accounts.
*/ */
nonicknameownership = no nonicknameownership = no
/*
* The minimum length of passwords
*
* This directive is optional. If not set it defaults to 8.
*/
minpasslen = 8
/* /*
* The maximum length of passwords * The maximum length of passwords
* *
* This directive is optional. If not set it defaults to 32. * This directive is optional. If not set it defaults to 32.
*/ */
passlen = 32 maxpasslen = 32
} }
/* /*
@@ -255,12 +266,12 @@ module
accessmax = 32 accessmax = 32
/* /*
* If set, Services will add the usermask of registering users to the access list of their * If set, Anope will add the usermask of registering users to the access list of their
* newly created account. If not set, users will always have to identify to NickServ before * newly created account. If not set, users will always have to identify to NickServ before
* being recognized, unless they manually add an address to the access list of their account. * being recognized, unless they manually add an address to the access list of their account.
* This directive is optional. * This directive is optional.
*/ */
addaccessonreg = yes addaccessonreg = no
} }
command { service = "NickServ"; name = "ACCESS"; command = "nickserv/access"; } command { service = "NickServ"; name = "ACCESS"; command = "nickserv/access"; }
@@ -331,18 +342,6 @@ command { service = "NickServ"; name = "DROP"; command = "nickserv/drop"; }
module { name = "ns_getemail" } module { name = "ns_getemail" }
command { service = "NickServ"; name = "GETEMAIL"; command = "nickserv/getemail"; permission = "nickserv/getemail"; group = "nickserv/admin"; } command { service = "NickServ"; name = "GETEMAIL"; command = "nickserv/getemail"; permission = "nickserv/getemail"; group = "nickserv/admin"; }
/*
* ns_getpass
*
* Provides the command nickserv/getpass.
*
* Used for getting users passwords.
*
* Requires no encryption is being used.
*/
#module { name = "ns_getpass" }
#command { service = "NickServ"; name = "GETPASS"; command = "nickserv/getpass"; permission = "nickserv/getpass"; }
/* /*
* ns_group * ns_group
* *
@@ -381,7 +380,15 @@ command { service = "NickServ"; name = "UNGROUP"; command = "nickserv/ungroup";
* *
* Used for identifying to accounts. * Used for identifying to accounts.
*/ */
module { name = "ns_identify" } module
{
name = "ns_identify"
/*
* If set, limits the number of concurrent users that can be logged in as a given account at once.
*/
maxlogins = 10
}
command { service = "NickServ"; name = "ID"; command = "nickserv/identify"; hide = true; } command { service = "NickServ"; name = "ID"; command = "nickserv/identify"; hide = true; }
command { service = "NickServ"; name = "IDENTIFY"; command = "nickserv/identify"; } command { service = "NickServ"; name = "IDENTIFY"; command = "nickserv/identify"; }
@@ -390,7 +397,7 @@ command { service = "NickServ"; name = "IDENTIFY"; command = "nickserv/identify"
* *
* Provides the commands: * Provides the commands:
* nickserv/info. - Used for gathering information about an account. * nickserv/info. - Used for gathering information about an account.
* nickserv/set/hide, nickserv/saset/hide - Used for configuring which options are publically shown in nickserv/info. * nickserv/set/hide, nickserv/saset/hide - Used for configuring which options are publicly shown in nickserv/info.
* *
*/ */
module { name = "ns_info" } module { name = "ns_info" }
@@ -445,17 +452,18 @@ module
name = "ns_recover" name = "ns_recover"
/* /*
* If set, Services will svsnick and svsjoin users who use the recover * If set, Anope will svsnick and svsjoin users who use the recover
* command on an identified user to the nick and channels of the recovered user. * command on an identified user to the nick and channels of the recovered user.
* *
* This directive is opional. * This directive is optional.
*/ */
restoreonrecover = yes restoreonrecover = yes
} }
command { service = "NickServ"; name = "RECOVER"; command = "nickserv/recover"; } command { service = "NickServ"; name = "RECOVER"; command = "nickserv/recover"; }
# Uncomment below to emulate 1.8's behavior of ghost and release.
#command { service = "NickServ"; name = "GHOST"; command = "nickserv/recover"; } # For compatibility with Anope 1.8 and Atheme.
#command { service = "NickServ"; name = "RELEASE"; command = "nickserv/recover"; } command { service = "NickServ"; name = "GHOST"; command = "nickserv/recover"; hide = true; }
command { service = "NickServ"; name = "RELEASE"; command = "nickserv/recover"; hide = true; }
/* /*
* ns_register * ns_register
@@ -524,6 +532,7 @@ command { service = "NickServ"; name = "RESETPASS"; command = "nickserv/resetpas
* nickserv/set/message, nickserv/saset/message - Used to configure how services send messages to you. * nickserv/set/message, nickserv/saset/message - Used to configure how services send messages to you.
* nickserv/set/password, nickserv/saset/password - Used for changing a users password. * nickserv/set/password, nickserv/saset/password - Used for changing a users password.
* nickserv/set/secure, nickserv/saset/secure - Used for configuring whether a user can identify by simply being recognized by nickserv/access. * nickserv/set/secure, nickserv/saset/secure - Used for configuring whether a user can identify by simply being recognized by nickserv/access.
* nickserv/set/neverop, nickserv/saset/neverop - Used to configure whether a user can be added to access lists
* nickserv/saset/noexpire - Used for configuring noexpire, which prevents nicks from expiring. * nickserv/saset/noexpire - Used for configuring noexpire, which prevents nicks from expiring.
*/ */
module module
@@ -568,6 +577,9 @@ command { service = "NickServ"; name = "SASET PASSWORD"; command = "nickserv/sas
command { service = "NickServ"; name = "SET SECURE"; command = "nickserv/set/secure"; } command { service = "NickServ"; name = "SET SECURE"; command = "nickserv/set/secure"; }
command { service = "NickServ"; name = "SASET SECURE"; command = "nickserv/saset/secure"; permission = "nickserv/saset/secure"; } command { service = "NickServ"; name = "SASET SECURE"; command = "nickserv/saset/secure"; permission = "nickserv/saset/secure"; }
command { service = "NickServ"; name = "SET NEVEROP"; command = "nickserv/set/neverop"; }
command { service = "NickServ"; name = "SASET NEVEROP"; command = "nickserv/saset/neverop"; permission = "nickserv/saset/neverop"; }
command { service = "NickServ"; name = "SASET NOEXPIRE"; command = "nickserv/saset/noexpire"; permission = "nickserv/saset/noexpire"; } command { service = "NickServ"; name = "SASET NOEXPIRE"; command = "nickserv/saset/noexpire"; permission = "nickserv/saset/noexpire"; }
@@ -582,12 +594,13 @@ command { service = "NickServ"; name = "SASET NOEXPIRE"; command = "nickserv/sas
module { name = "ns_set_misc" } module { name = "ns_set_misc" }
command { service = "NickServ"; name = "SET URL"; command = "nickserv/set/misc"; misc_description = _("Associate a URL with your account"); } command { service = "NickServ"; name = "SET URL"; command = "nickserv/set/misc"; misc_description = _("Associate a URL with your account"); }
command { service = "NickServ"; name = "SASET URL"; command = "nickserv/saset/misc"; misc_description = _("Associate a URL with this account"); permission = "nickserv/saset/url"; group = "nickserv/admin"; } command { service = "NickServ"; name = "SASET URL"; command = "nickserv/saset/misc"; misc_description = _("Associate a URL with this account"); permission = "nickserv/saset/url"; group = "nickserv/admin"; }
#command { service = "NickServ"; name = "SET ICQ"; command = "nickserv/set/misc"; misc_description = _("Associate an ICQ account with your account"); } #command { service = "NickServ"; name = "SET DISCORD"; command = "nickserv/set/misc"; misc_description = _("Associate a Discord account with your account"); }
#command { service = "NickServ"; name = "SASET ICQ"; command = "nickserv/saset/misc"; misc_description = _("Associate an ICQ account with this account"); permission = "nickserv/saset/icq"; group = "nickserv/admin"; } #command { service = "NickServ"; name = "SASET DISCORD"; command = "nickserv/saset/misc"; misc_description = _("Associate a Discord account with this account"); permission = "nickserv/saset/discord"; group = "nickserv/admin"; }
#command { service = "NickServ"; name = "SET TWITTER"; command = "nickserv/set/misc"; misc_description = _("Associate a Twitter account with your account"); }
#command { service = "NickServ"; name = "SASET TWITTER"; command = "nickserv/saset/misc"; misc_description = _("Associate a Twitter account with this account"); permission = "nickserv/saset/twitter"; group = "nickserv/admin"; }
#command { service = "NickServ"; name = "SET FACEBOOK"; command = "nickserv/set/misc"; misc_description = _("Associate a Facebook URL with your account"); } #command { service = "NickServ"; name = "SET FACEBOOK"; command = "nickserv/set/misc"; misc_description = _("Associate a Facebook URL with your account"); }
#command { service = "NickServ"; name = "SASET FACEBOOK"; command = "nickserv/saset/misc"; misc_description = _("Associate a Facebook URL with this account"); permission = "nickserv/saset/facebook"; group = "nickserv/admin"; } #command { service = "NickServ"; name = "SASET FACEBOOK"; command = "nickserv/saset/misc"; misc_description = _("Associate a Facebook URL with this account"); permission = "nickserv/saset/facebook"; group = "nickserv/admin"; }
#command { service = "NickServ"; name = "SET MASTODON"; command = "nickserv/set/misc"; misc_description = _("Associate a Mastodon account with your account"); }
#command { service = "NickServ"; name = "SASET MASTODON"; command = "nickserv/saset/misc"; misc_description = _("Associate a Mastodon account with this account"); permission = "nickserv/saset/mastodon"; group = "nickserv/admin"; }
/* /*
* ns_status * ns_status
+18 -31
View File
@@ -75,7 +75,7 @@ module
sqlineexpiry = 30d sqlineexpiry = 30d
/* /*
* If set, this option will make Services send an AKILL command immediately after it has been * If set, this option will make Anope send an AKILL command immediately after it has been
* added with AKILL ADD. This eliminates the need for killing the user after the AKILL has * added with AKILL ADD. This eliminates the need for killing the user after the AKILL has
* been added. * been added.
* *
@@ -84,7 +84,7 @@ module
akillonadd = yes akillonadd = yes
/* /*
* If set, this option will make Services send an (SVS)KILL command immediately after SNLINE ADD. * If set, this option will make Anope send an (SVS)KILL command immediately after SNLINE ADD.
* This eliminates the need for killing the user after the SNLINE has been added. * This eliminates the need for killing the user after the SNLINE has been added.
* *
* This directive is optional. * This directive is optional.
@@ -92,7 +92,7 @@ module
killonsnline = yes killonsnline = yes
/* /*
* If set, this option will make Services send an (SVS)KILL command immediately after SQLINE ADD. * If set, this option will make Anope send an (SVS)KILL command immediately after SQLINE ADD.
* This eliminates the need for killing the user after the SQLINE has been added. * This eliminates the need for killing the user after the SQLINE has been added.
* *
* This directive is optional. * This directive is optional.
@@ -159,7 +159,7 @@ command { service = "OperServ"; name = "CHANKILL"; command = "operserv/chankill"
* *
* Provides the command operserv/defcon. * Provides the command operserv/defcon.
* *
* Allows you to set services in defcon mode, which can be used to restrict services access * Allows you to set services in DefCon mode, which can be used to restrict services access
* during bot attacks. * during bot attacks.
*/ */
#module #module
@@ -167,7 +167,7 @@ command { service = "OperServ"; name = "CHANKILL"; command = "operserv/chankill"
name = "os_defcon" name = "os_defcon"
/* /*
* Default DefCon level (1-5) to use when starting Services up. Level 5 constitutes normal operation * Default DefCon level (1-5) to use when starting Anope up. Level 5 constitutes normal operation
* while level 1 constitutes the most restrictive operation. If this setting is left out or set to * while level 1 constitutes the most restrictive operation. If this setting is left out or set to
* 0, DefCon will be disabled and the rest of this block will be ignored. * 0, DefCon will be disabled and the rest of this block will be ignored.
*/ */
@@ -184,8 +184,8 @@ command { service = "OperServ"; name = "CHANKILL"; command = "operserv/chankill"
* - forcechanmodes: Forces all channels to have the modes given in the later chanmodes directive * - forcechanmodes: Forces all channels to have the modes given in the later chanmodes directive
* - reducedsessions: Reduces the session limit to the value given in the later sessionlimit directive * - reducedsessions: Reduces the session limit to the value given in the later sessionlimit directive
* - nonewclients: KILL any new clients trying to connect * - nonewclients: KILL any new clients trying to connect
* - operonly: Services will ignore all non-IRCops * - operonly: Ignore all non-IRCops
* - silentoperonly: Services will silently ignore all non-IRCops * - silentoperonly: Silently ignore all non-IRCops
* - akillnewclients: AKILL any new clients trying to connect * - akillnewclients: AKILL any new clients trying to connect
* - nonewmemos: No new memos will be sent to block MemoServ attacks * - nonewmemos: No new memos will be sent to block MemoServ attacks
*/ */
@@ -209,7 +209,7 @@ command { service = "OperServ"; name = "CHANKILL"; command = "operserv/chankill"
* The channel modes to set on all channels when the DefCon channel mode system is in use. * The channel modes to set on all channels when the DefCon channel mode system is in use.
* *
* Note 1: Choose these modes carefully, because when DefCon switches to a level which does NOT have * Note 1: Choose these modes carefully, because when DefCon switches to a level which does NOT have
* the mode setting selected, Services will set the reverse on all channels, e.g. if this setting * the mode setting selected, Anope will set the reverse on all channels, e.g. if this setting
* is +RN when DefCon is used, all channels will be set to +RN, when DefCon is removed, all * is +RN when DefCon is used, all channels will be set to +RN, when DefCon is removed, all
* channels will be set to -RN. You don't want to set this to +k for example, because when DefCon * channels will be set to -RN. You don't want to set this to +k for example, because when DefCon
* is removed, all channels are set -k, removing the key from previously keyed channels. * is removed, all channels are set -k, removing the key from previously keyed channels.
@@ -227,14 +227,14 @@ command { service = "OperServ"; name = "CHANKILL"; command = "operserv/chankill"
#timeout = 15m #timeout = 15m
/* /*
* If set, Services will send a global message on DefCon level changes. * If set, Anope will send a global message on DefCon level changes.
* *
* This directive is optional. * This directive is optional.
*/ */
#globalondefcon = yes #globalondefcon = yes
/* /*
* If set, Services will send the global message defined in the message directive on DefCon level * If set, Anope will send the global message defined in the message directive on DefCon level
* changes. * changes.
* *
* This directive is optional. * This directive is optional.
@@ -267,7 +267,7 @@ command { service = "OperServ"; name = "CHANKILL"; command = "operserv/chankill"
* *
* Provides the command operserv/dns. * Provides the command operserv/dns.
* *
* This module requires that m_dns is loaded. * This module requires that dns is loaded.
* *
* This module allows controlling a DNS zone. This is useful for * This module allows controlling a DNS zone. This is useful for
* controlling what servers users are placed on for load balancing, * controlling what servers users are placed on for load balancing,
@@ -348,7 +348,7 @@ command { service = "OperServ"; name = "FORBID"; command = "operserv/forbid"; pe
* *
* Provides the command operserv/ignore. * Provides the command operserv/ignore.
* *
* Used to make Services ignore users. * Used to make Anope ignore users.
*/ */
module { name = "os_ignore" } module { name = "os_ignore" }
command { service = "OperServ"; name = "IGNORE"; command = "operserv/ignore"; permission = "operserv/ignore"; } command { service = "OperServ"; name = "IGNORE"; command = "operserv/ignore"; permission = "operserv/ignore"; }
@@ -506,17 +506,6 @@ command { service = "OperServ"; name = "RANDOMNEWS"; command = "operserv/randomn
module { name = "os_noop" } module { name = "os_noop" }
command { service = "OperServ"; name = "NOOP"; command = "operserv/noop"; permission = "operserv/noop"; } command { service = "OperServ"; name = "NOOP"; command = "operserv/noop"; permission = "operserv/noop"; }
/*
* os_oline
*
* Provides the command operserv/oline.
*
* Used to set oper flags on users, and is specific to UnrealIRCd.
* See /helpop ?svso on your IRCd for more information.
*/
module { name = "os_oline" }
command { service = "OperServ"; name = "OLINE"; command = "operserv/oline"; permission = "operserv/oline"; }
/* /*
* os_oper * os_oper
* *
@@ -532,7 +521,7 @@ command { service = "OperServ"; name = "OPER"; command = "operserv/oper"; permis
* *
* Provides the command operserv/reload. * Provides the command operserv/reload.
* *
* Used to reload the services.conf configuration file. * Used to reload the anope.conf configuration file.
*/ */
module { name = "os_reload" } module { name = "os_reload" }
command { service = "OperServ"; name = "RELOAD"; command = "operserv/reload"; permission = "operserv/reload"; } command { service = "OperServ"; name = "RELOAD"; command = "operserv/reload"; permission = "operserv/reload"; }
@@ -544,7 +533,7 @@ command { service = "OperServ"; name = "RELOAD"; command = "operserv/reload"; pe
* *
* This module enables session limiting. Session limiting prevents users from connecting more than a certain * This module enables session limiting. Session limiting prevents users from connecting more than a certain
* number of times from the same IP at the same time - thus preventing most types of cloning. * number of times from the same IP at the same time - thus preventing most types of cloning.
* Once a host reaches it's session limit, all clients attempting to connect from that host will * Once a host reaches its session limit, all clients attempting to connect from that host will
* be killed. Exceptions to the default session limit can be defined via the exception list. * be killed. Exceptions to the default session limit can be defined via the exception list.
* *
* Used to manage the session limit exception list, and view currently active sessions. * Used to manage the session limit exception list, and view currently active sessions.
@@ -559,7 +548,7 @@ module
* *
* This directive is required if os_session is loaded. * This directive is required if os_session is loaded.
*/ */
defaultsessionlimit = 3 defaultsessionlimit = 5
/* /*
* The maximum session limit that may be set for a host in an exception. * The maximum session limit that may be set for a host in an exception.
@@ -570,10 +559,8 @@ module
/* /*
* Sets the default expiry time for session exceptions. * Sets the default expiry time for session exceptions.
*
* This directive is required if os_session is loaded.
*/ */
exceptionexpiry = 1d #exceptionexpiry = 1d
/* /*
* The message that will be NOTICE'd to a user just before they are removed from the network because * The message that will be NOTICE'd to a user just before they are removed from the network because
@@ -594,10 +581,10 @@ module
* *
* This directive is optional, if not set, nothing will be sent. * This directive is optional, if not set, nothing will be sent.
*/ */
#sessionlimitdetailsloc = "Please visit http://your.website.url/ for more information about session limits." #sessionlimitdetailsloc = "Please visit https://your.website.url/ for more information about session limits."
/* /*
* If set and is not 0, this directive tells Services to add an AKILL if the number of subsequent kills * If set and is not 0, this directive tells Anope to add an AKILL if the number of subsequent kills
* for the same host exceeds this value, preventing the network from experiencing KILL floods. * for the same host exceeds this value, preventing the network from experiencing KILL floods.
* *
* This directive is optional. * This directive is optional.
+73 -69
View File
@@ -1,8 +1,8 @@
/* /*
* Example configuration file for Services. After making the appropriate * Example configuration file for Anope. After making the appropriate
* changes to this file, place it in the Services conf directory (as * changes to this file, place it in the Anope conf directory (as
* specified in the "configure" script, default /home/username/services/conf) * specified in the "Config" script, default /home/username/anope/conf)
* under the name "services.conf". * under the name "anope.conf".
* *
* The format of this file is fairly simple: three types of comments are supported: * The format of this file is fairly simple: three types of comments are supported:
* - All text after a '#' on a line is ignored, as in shell scripting * - All text after a '#' on a line is ignored, as in shell scripting
@@ -53,7 +53,7 @@
* included to indicate whether an option is required: * included to indicate whether an option is required:
* *
* [REQUIRED] * [REQUIRED]
* Indicates a directive which must be given. Without it, Services will * Indicates a directive which must be given. Without it, Anope will
* not start. * not start.
* *
* [RECOMMENDED] * [RECOMMENDED]
@@ -71,7 +71,7 @@
* *
* [DEPRECATED] * [DEPRECATED]
* Indicates a directive which will disappear in a future version of * Indicates a directive which will disappear in a future version of
* Services, usually because its functionality has been either * Anope, usually because its functionality has been either
* superseded by that of other directives or incorporated into the main * superseded by that of other directives or incorporated into the main
* program. * program.
*/ */
@@ -80,17 +80,17 @@
* [OPTIONAL] Defines * [OPTIONAL] Defines
* *
* You can define values to other values, which can be used to easily change * You can define values to other values, which can be used to easily change
* many values in the configuration. at once. * many values in the configuration at once.
*/ */
/* /*
* The services.host define is used in multiple different locations throughout the * The stats.host define is used in multiple different locations throughout the
* configuration for services clients hostnames. * configuration for the stats client hostname.
*/ */
define define
{ {
name = "services.host" name = "stats.host"
value = "services.localhost.net" value = "stats.example.com"
} }
/* /*
@@ -110,7 +110,7 @@ define
#include #include
{ {
type = "executable" type = "executable"
name = "/usr/bin/wget -q -O - http://some.misconfigured.network.com/services.conf" name = "/usr/bin/wget -q -O - https://some.misconfigured.network.com/stats.conf"
} }
/* /*
@@ -120,54 +120,60 @@ define
* This section can be included multiple times, and Anope will attempt to * This section can be included multiple times, and Anope will attempt to
* connect to each server until it finally connects. * connect to each server until it finally connects.
* *
* Each uplink IRCd should have a corresponding configuration to allow Services * Each uplink IRCd should have a corresponding configuration to allow Anope
* to link to it. * to link to it.
* *
* An example configuration for InspIRCd that is compatible with the below uplink * An example configuration for InspIRCd that is compatible with the below uplink
* and serverinfo configuration would look like: * and serverinfo configuration would look like:
* *
* <link name="services.localhost.net" * # This goes in inspircd.conf, *NOT* your Anope config!
* <link name="stats.example.com"
* ipaddr="127.0.0.1" * ipaddr="127.0.0.1"
* port="7000" * port="7000"
* sendpass="mypassword" * sendpass="mypassword"
* recvpass="mypassword"> * recvpass="mypassword">
* <uline server="services.localhost.net" silent="yes"> * <uline server="stats.example.com" silent="yes">
* <bind address="127.0.0.1" port="7000" type="servers"> * <bind address="127.0.0.1" port="7000" type="servers">
* *
* An example configuration for UnrealIRCd that is compatible with the below uplink * An example configuration for UnrealIRCd that is compatible with the below uplink
* and serverinfo configuration would look like: * and serverinfo configuration would look like:
* *
* link services.localhost.net * // This goes in unrealircd.conf, *NOT* your Anope config!
* { * listen {
* username *; * ip 127.0.0.1;
* hostname *; * port 7000;
* bind-ip "127.0.0.1"; * options {
* port 7000; * serversonly;
* hub *; * };
* password-connect "mypassword";
* password-receive "mypassword";
* class servers;
* }; * };
* ulines { services.localhost.net; }; * link stats.example.com {
* listen 127.0.0.1:7000; * incoming {
* mask *@127.0.0.1;
* };
* password "mypassword";
* class servers;
* };
* ulines { stats.example.com; };
*/ */
uplink uplink
{ {
/* /*
* The IP or hostname of the IRC server you wish to connect Services to. * The IP address, hostname, or UNIX socket path of the IRC server you wish
* Usually, you will want to connect Services over 127.0.0.1 (aka localhost). * to connect Anope to.
* Usually, you will want to connect over 127.0.0.1 (aka localhost).
* *
* NOTE: On some shell providers, this will not be an option. * NOTE: On some shell providers, this will not be an option.
*/ */
host = "127.0.0.1" host = "127.0.0.1"
/* /*
* Enable if Services should connect using IPv6. * The protocol that Anope should use when connecting to the uplink. Can
* be set to "ipv4" (the default), "ipv6", or "unix".
*/ */
ipv6 = no protocol = "ipv4"
/* /*
* Enable if Services should connect using SSL. * Enable if Anope should connect using SSL.
* You must have an SSL module loaded for this to work. * You must have an SSL module loaded for this to work.
*/ */
ssl = no ssl = no
@@ -193,26 +199,26 @@ uplink
/* /*
* [REQUIRED] Server Information * [REQUIRED] Server Information
* *
* This section contains information about the Services server. * This section contains information about the services server.
*/ */
serverinfo serverinfo
{ {
/* /*
* The hostname that Services will be seen as, it must have no conflicts with any * The hostname that Anope will be seen as, it must have no conflicts with any
* other server names on the rest of your IRC network. Note that it does not have * other server names on the rest of your IRC network. Note that it does not have
* to be an existing hostname, just one that isn't on your network already. * to be an existing hostname, just one that isn't on your network already.
*/ */
name = "stats.localhost.net" name = "stats.example.com"
/* /*
* The text which should appear as the server's information in /whois and similar * The text which should appear as the server's information in /WHOIS and similar
* queries. * queries.
*/ */
description = "Stats for IRC Networks" description = "Anope IRC Statistics"
/* /*
* The local address that Services will bind to before connecting to the remote * The local address that Anope will bind to before connecting to the remote
* server. This may be useful for multihomed hosts. If omitted, Services will let * server. This may be useful for multihomed hosts. If omitted, Anope will let
* the Operating System choose the local address. This directive is optional. * the Operating System choose the local address. This directive is optional.
* *
* If you don't know what this means or don't need to use it, just leave this * If you don't know what this means or don't need to use it, just leave this
@@ -228,16 +234,16 @@ serverinfo
#id = "00A" #id = "00A"
/* /*
* The filename containing the Services process ID. The path is relative to the * The filename containing the Anope process ID. The path is relative to the
* services root directory. * services root directory.
*/ */
pid = "data/services.pid" pid = "data/anope.pid"
/* /*
* The filename containing the Message of the Day. The path is relative to the * The filename containing the Message of the Day. The path is relative to the
* services root directory. * services root directory.
*/ */
motd = "conf/services.motd" motd = "conf/motd.txt"
} }
/* /*
@@ -248,49 +254,48 @@ serverinfo
* *
* Supported: * Supported:
* - bahamut * - bahamut
* - charybdis
* - hybrid * - hybrid
* - inspircd12 * - inspircd
* - inspircd20
* - ngircd * - ngircd
* - plexus * - plexus
* - ratbox * - ratbox
* - unreal * - solanum
* - unrealircd
*/ */
module module
{ {
name = "inspircd20" name = "inspircd"
} }
/* /*
* [REQUIRED] Network Information * [REQUIRED] Network Information
* *
* This section contains information about the IRC network that Services will be * This section contains information about the IRC network that Anope will be
* connecting to. * connecting to.
*/ */
networkinfo networkinfo
{ {
/* /*
* This is the name of the network that Services will be running on. * This is the name of the network that Anope will be running on.
*/ */
networkname = "LocalNet" networkname = "LocalNet"
/* /*
* Set this to the maximum allowed nick length on your network. * Set this to the maximum allowed nick length on your network.
* Be sure to set this correctly, as setting this wrong can result in * Be sure to set this correctly, as setting this wrong can result in
* Services being disconnected from the network. * Anope being disconnected from the network.
*/ */
nicklen = 31 nicklen = 31
/* Set this to the maximum allowed ident length on your network. /* Set this to the maximum allowed ident length on your network.
* Be sure to set this correctly, as setting this wrong can result in * Be sure to set this correctly, as setting this wrong can result in
* Services being disconnected from the network. * Anope being disconnected from the network.
*/ */
userlen = 10 userlen = 10
/* Set this to the maximum allowed hostname length on your network. /* Set this to the maximum allowed hostname length on your network.
* Be sure to set this correctly, as setting this wrong can result in * Be sure to set this correctly, as setting this wrong can result in
* Services being disconnected from the network. * Anope being disconnected from the network.
*/ */
hostlen = 64 hostlen = 64
@@ -308,7 +313,7 @@ networkinfo
* to services, such as BotServ bot hostnames and user vhosts. Changing this is not * to services, such as BotServ bot hostnames and user vhosts. Changing this is not
* recommended unless you know for sure your IRCd supports whatever characters you are * recommended unless you know for sure your IRCd supports whatever characters you are
* wanting to use. Telling services to set a vHost containing characters your IRCd * wanting to use. Telling services to set a vHost containing characters your IRCd
* disallows could potentially break the IRCd and/or Services. * disallows could potentially break the IRCd and/or Anope.
* *
* It is recommended you DON'T change this. * It is recommended you DON'T change this.
*/ */
@@ -333,22 +338,22 @@ networkinfo
} }
/* /*
* [REQUIRED] Services Options * [REQUIRED] Anope Options
* *
* This section contains various options which determine how Services will operate. * This section contains various options which determine how Anope will operate.
*/ */
options options
{ {
/* /*
* On Linux/UNIX systems Anope can setuid and setgid to this user and group * On Linux/UNIX systems Anope can setuid and setgid to this user and group
* after starting up. This is useful if Anope has to bind to privileged ports * after starting up. This is useful if Anope has to bind to privileged ports.
*/ */
#user = "anope" #user = "anope"
#group = "anope" #group = "anope"
/* /*
* The case mapping used by services. This must be set to a valid locale name * The case mapping used by services. This must be set to a valid locale name
* installed on your machine. Services use this case map to compare, with * installed on your machine. Anope uses this case map to compare, with
* case insensitivity, things such as nick names, channel names, etc. * case insensitivity, things such as nick names, channel names, etc.
* *
* We provide two special casemaps shipped with Anope, ascii and rfc1459. * We provide two special casemaps shipped with Anope, ascii and rfc1459.
@@ -372,14 +377,14 @@ options
warningtimeout = 4h warningtimeout = 4h
/* /*
* If set, Services will only show /stats o to IRC Operators. This directive * If set, Anope will only show /stats o to IRC Operators. This directive
* is optional. * is optional.
*/ */
#hidestatso = yes #hidestatso = yes
/* /*
* A space-separated list of ulined servers on your network, it is assumed that * A space-separated list of U-lined servers on your network, it is assumed that
* the servers in this list are allowed to set channel modes and Services will * the servers in this list are allowed to set channel modes and Anope will
* not attempt to reverse their mode changes. * not attempt to reverse their mode changes.
* *
* WARNING: Do NOT put your normal IRC user servers in this directive. * WARNING: Do NOT put your normal IRC user servers in this directive.
@@ -411,17 +416,17 @@ log
*/ */
target = "stats.log" target = "stats.log"
/* Log to both services.log and the channel #services /* Log to both stats.log and the channel #stats
* *
* Note that some older IRCds, such as Ratbox, require services to be in the * Note that some older IRCds, such as Ratbox, require services to be in the
* log channel to be able to message it. To do this, configure service:channels to * log channel to be able to message it. To do this, configure service:channels to
* join your logging channel. * join your logging channel.
*/ */
#target = "stats.log #services" #target = "stats.log #stats"
/* /*
* The source(s) to only accept log messages from. Leave commented to allow all sources. * The source(s) to only accept log messages from. Leave commented to allow all sources.
* This can be a users name, a channel name, one of our clients (eg, OperServ), or a server name. * This can be a users name, a channel name, one of our clients (e.g. OperServ), or a server name.
*/ */
#source = "" #source = ""
@@ -432,8 +437,8 @@ log
bot = "Global" bot = "Global"
/* /*
* The number of days to keep logfiles, only useful if you are logging to a file. * The number of days to keep log files, only useful if you are logging to a file.
* Set to 0 to never delete old logfiles. * Set to 0 to never delete old log files.
* *
* Note that Anope must run 24 hours a day for this feature to work correctly. * Note that Anope must run 24 hours a day for this feature to work correctly.
*/ */
@@ -461,7 +466,7 @@ log
* create, destroy, join, part, kick, leave, mode * create, destroy, join, part, kick, leave, mode
* *
* Valid user options are: * Valid user options are:
* connect, disconnect, quit, nick, ident, host, mode, maxusers, oper * connect, disconnect, quit, nick, ident, host, mode, maxusers, oper, away
* *
* Rawio and debug are simple yes/no answers, there are no types for them. * Rawio and debug are simple yes/no answers, there are no types for them.
* *
@@ -478,13 +483,13 @@ log
/* /*
* [REQUIRED] MySQL Database configuration. * [REQUIRED] MySQL Database configuration.
* *
* m_mysql * mysql
* *
* This module allows other modules to use MySQL. * This module allows other modules to use MySQL.
*/ */
module module
{ {
name = "m_mysql" name = "mysql"
mysql mysql
{ {
@@ -510,4 +515,3 @@ include
type = "file" type = "file"
name = "irc2sql.example.conf" name = "irc2sql.example.conf"
} }
-1
View File
@@ -1 +0,0 @@
astyle --style=java --indent=tab --brackets=break-closing --indent-switches --indent-cases --brackets=break
-1
View File
@@ -1 +0,0 @@
For all bug reports / updates please see http://bugs.anope.org
-111
View File
@@ -1,111 +0,0 @@
C++-style Casting
=================
In C, you can cast in one of two ways:
(type)var
type(var)
The problem with C-style casting is that it allows a programmer to get away
with too much, and is also not designed to handle C++ classes.
C++ has 4 types of casting in addition to allowing C-style casting. They are:
static_cast
const_cast
dynamic_cast
reinterpret_cast
The syntax is usually *_cast<type>(var).
static_cast
-----------
From my expierence, this cast is closest to C-style casting for non-pointer
types as well as between some (but not all) pointer types. This type of cast,
like C-style casting, is performed at compile-time. static_cast can also do
a downcast of a derived class to a base class, but only if the base class is
not a virtual base class. Sometimes the result of this cast can become
undefined. static_cast is a bit more strict that C-style casting, though. It
disallows certain class conversions that would've been allowed with a C-style
cast. static_cast also doesn't allow you to cast to an incomplete type. In
these cases, I would try either dynamic_cast or reinterpret_cast.
const_cast
----------
This cast is mainly to add or remove const-ness or volatile-ness from a
variable. This is safer than using a C-style cast to change the const-ness
of a variable. In most cases if you try to use one of the other casts and it
complains about const-ness, you will want to either use this cast instead or
wrap the other cast around this cast. An example:
const int *a;
static_cast<void *>(a); <-- This will fail.
To remedy the above, you would might try this:
const int *a;
const_cast<void *>(a); <-- But this will still fail.
The real solution is this:
const int *a;
static_cast<void *>(const_cast<int *>(a));
It is not recommended to use const_cast on the this variable within a member
function of a class that is declared const. Instead you should use the mutable
keyword on the variable in the class's definition.
dynamic_cast
------------
This cast can only be used on pointers or references to classes. It can cast a
derived class to a base class, a derived class to another derived class
(provided that both are children of the same base class), or a base class to a
derived class. You can also use this to cast a class to void *. This cast is
done at run-time as opposed to the other casts, and relies on C++'s RTTI to be
enabled. It is meant to be used on polymorphic classes, so use static_cast on
non-polymorphic classes.
derived-to-base conversions are actually done statically, so you use either
dynamic_cast or static_cast on them, regardless of if the classes are
polymorphic or not.
derived-to-derived or base-to-derived conversions, however, rely on run-time
type information, and this cast is used on those classes that are polymorphic.
This is safer than C-style casting in that an invalid pointer conversion will
return a NULL pointer, and an invalid reference conversion will throw a
Bad_cast exception.
Note that in Anope we prefer if Anope::debug_cast is used.
This uses dynamic_cast (and checks for a NULL pointer return) on debug builds
and static_cast on release builds, to speed up the program beacuse of dynamic_cast's
reliance on RTTI.
reinterpret_cast
----------------
This cast I would use only as a last resort if static_cast isn't allowed on a
conversion. It allows for conversions between two unrelated types, such as
going from char * to int *. It can also be used to convert a pointer to an
integral type and vica versa. The sites I've read mention how the result is
non-portable, which I assume means the resulting object code is non-portable,
so since the code is compiled on many systems anyways, I don't see this as
being a huge issue. It is recommended to only use this if necessary, though.
Links
=====
The following links are web sites I've used to get this information, and might
describe some of the above a bit better than I have. :P
http://www.acm.org/crossroads/xrds3-1/ovp3-1.html
http://www.cplusplus.com/doc/tutorial/typecasting.html
http://www.codeguru.com/forum/showthread.php?t=312456
http://www.cs.umd.edu/class/sum2003/cmsc311/Notes/BitOp/cast.html
http://msdn.microsoft.com/en-us/library/5f6c9f8h(VS.80).aspx
http://en.wikibooks.org/wiki/C%2B%2B_Programming/Type_Casting
http://www.informit.com/guides/content.aspx?g=cplusplus&seqNum=134
-- CyberBotX, Nov 23, 2008
+3 -3
View File
@@ -6,10 +6,10 @@ if(WIN32)
if(IN_SOURCE) if(IN_SOURCE)
# Add README.txt to list of files for CPack to ignore # Add README.txt to list of files for CPack to ignore
add_to_cpack_ignored_files("README.txt$" TRUE) add_to_cpack_ignored_files("README.txt$" TRUE)
endif(IN_SOURCE) endif()
set(DOCS Changes Changes.conf DEFCON FAQ INSTALL LANGUAGE MODULES NEWS ${CMAKE_CURRENT_BINARY_DIR}/README.txt WIN32.txt) set(DOCS Changes Changes.conf DEFCON FAQ INSTALL LANGUAGE MODULES ${CMAKE_CURRENT_BINARY_DIR}/README.txt WIN32.txt)
install(FILES ${DOCS} install(FILES ${DOCS}
DESTINATION ${DOC_DIR} DESTINATION ${DOC_DIR}
) )
set_directory_properties(PROPERTIES ADDITIONAL_MAKE_CLEAN_FILES "${CMAKE_CURRENT_BINARY_DIR}/README.txt") set_directory_properties(PROPERTIES ADDITIONAL_MAKE_CLEAN_FILES "${CMAKE_CURRENT_BINARY_DIR}/README.txt")
endif(WIN32) endif()
-239
View File
@@ -1,239 +0,0 @@
Orginally pulled from: http://www.inspircd.org/wiki/Coding_Guidelines
---
InspIRCd Coding Guidelines
The following are a set of guidelines for writing patches to InspIRCd, or for
creating modules for distribution with the official package. These guidelines
were written a time after InspIRCd development started, and so not all code
yet follows these. This will be rectified with time.
1. Comments
* Multi Line
Multiple line comments should follow the C-style comment, for example:
/*
* This is a multiple line comment, huzzah..
*/
* Single Line
Single line comments should also be in the C style, for example:
/* This is a boring one-line comment */
* Doxygen commenting
If you wish your comment to show in doxygen, the comment should be directly
above the item you are documenting (a class, function, enum, etc) and the
first line should be "/**". For example:
/** This is a doxygen multiline comment.
* Description of thingymebob here.
*/
The first line after the "**" is used as the short description of the item
(up to the full stop) and everything afterwards as the detailed description.
2. Indentation
Tabs. Tabs. ONLY TABS. Use a single tab for each level of indentation,
for example:
int main()
{
<tab>if (condition)
<tab>{
<tab><tab>code
<tab>}
}
3. Separation
Always put a space in between a keyword like if/while and the condition,
for example:
if (foo == bar)
NOT
if(foo == bar)
4. Braces
Always put braces opening and closing blocks on separate lines, see the
identation example. For example, place braces like this:
if (apples == "green")
{
cout << "Apples are green" << endl;
}
and not:
if (apples == "green") {
cout << "Apples are green" << endl;
}
The one exception to this is if you are declaring a class method which is
only one line long, in that case the following is acceptable in most cases:
class foo : public bar
{
foo() { }
getrandomfoo() { return rand(); }
};
5. Templates
Where possible, use templates rather than #defines. Avoid use of RTTI.
6. Structs
Structs should be declared in the following fashion:
struct BodyPartBasket
{
int arms;
int legs;
int scrotalsacs;
};
and not like this:
typedef struct
{
int arms;
int legs;
int scrotalsacs;
} BodyPartBasket;
The second way is not required in C++ to be able to do this:
BodyPartBasket mybasket;
Plus, placing the name at the bottom of the declaration makes readability
more difficult (as you have to scroll down to the bottom of the struct to
find its name). (where possible, call them classes rather than structs.)
7. Variable naming
Class and struct names should be in camel case with a leading capital letter,
for example "MyBagOfBones" and not "my_bag_of_bones" or "mybagofbones".
Variable names can be in either camel case with a leading capital letter or
alternatively all lower case, so long as the same naming convention is
adhered to throughout the class. No classes or variables should be named in
capitals unless this makes sense for the name (for example "class DNS").
Constants and enum values should always be completely in CAPITALS and
underscores may be used, for example:
enum DecayState
{
DECAYED_MOULDY = 0,
DECAYED_SMELLY = 1,
DECAYED_MAGGOTS = 2
};
All value names in an enum should be started with the same text which should
be related in some way to the enum's use. For example "DNS_CNAME, DNS_A,
DNS_AAAA".
8. Use of references
Wherever possible, when dealing with any complex class, pass a const reference
rather than a copy of the class. For example:
MyThingy::MyThingy(const std::string &thingyvalue)
{
}
Of course, if you intended to change the string you can just omit the 'const'.
9. Use of char pointers
Whenever you use char pointers (char*, char**) try to use const equivalents.
This is much safer and avoids ugly and dangerous casts. For example:
MyThingy::Thingify(const char* const* wotsits)
{
}
If it is possible without performance loss, consider avoiding char pointers
altogether and using std::string instead.
10. Use of STL
For more information on use of STL in InspIRCd, please see the separate
STL FAQ.
11. Making copies of data
Never ever make a copy of a piece of data unless it is absolutely necessary.
For example, don't use strlcpy() to make a copy of the const char* string
returned by std::string::c_str(), if the change can be done to the std::string
itself. The same goes for unnecessary variable assignments, especially those
which assign large classes.
12. namespace std
Avoid the following:
using namespace std;
It might take a bit more typing, but things work better if you don't set
(then later assume) the namespace -- specify it explicitly when you want to
use it.
13. Linefeeds
Unix linefeeds only please. We do not like to see our screens covered in ^M.
14. Portability
Always make sure your code is portable to all supported operating systems,
remember of course that as of 1.1.8 this includes windows. Don't write code
that only works on windows, or only works on Linux. Test your code on all
platforms or ask for help from other developers who have the platforms you
want to test on.
* new() and delete(), malloc() and free()
Apart from the fact that using malloc() and free() is bad practice in C++
code, you must never use malloc() or free() in InspIRCd, within its modules
or within the core. This is because if you use malloc() or free() in windows,
the memory is claimed from the program's local heap.
In windows, each shared object (module, dll) has its own heap, which is
protected from other dlls and executables. To get around this issue and
allow more posix-like memory access from other dlls in the program (other
modules), InspIRCd overrides the operators new and delete to ensure that
memory allocated by them comes from the windows global heap. If you use
malloc() and free() for this, the ircd will segfault when another module
tries to access the memory you have allocated!
* strdup()
As with malloc(), above, strdup() should be avoided. Where strdup() is
absolutely necessary, use strnewdup() which is our strdup() implementation
that calls operator new instead of using malloc().
char arrays allocated by strnewdup() should be deleted with operator delete[].
* CoreExport and DllImport
Prefix all types you want to import or export to other modules with CoreExport
and DllImport macros. These do nothing in POSIX operating systems, however
in windows these are expanded to the instructions __declspec(dllimport) and
__declspec(dllexport) respectively depending on where they are used and how.
15. External Dependencies
If a module is compiled as standard, or the code is part of the core, you must
not use any dependencies that are not available as standard on all supported
operating systems beyond libstdc++, libc, and whatever else is currently
required to build the core. Modules which use nonstandard dependencies belong
in the modules/extra directory.
16. Profiling and Performance
It is one thing to assume that code performs bad, it is another thing to prove
that it actually is. A lot of experienced programmers talk about 'premature
optimisation', and here is what it means: if you have a piece of code called
once on startup that takes 10 seconds instead of one second to run, and a
piece of code that takes 0.05 seconds to run when it should take 0.01, and
it is called once per second, the second piece of code is the priority.
In other words, make sure that what you think is slow, and a performance
problem in Insp actually is.
To do this, use the callgrind tool from Valgrind (valgrind --tool=cachegrind
bin/inspircd -nofork -debug), and kcachegrind (or similar) to view the output
files.
+29 -255
View File
@@ -1,260 +1,34 @@
Anope Version 2.0.2 Anope Version 2.1.2
------------------- -------------------
Fix keepmodes preventing the first user of a channel from being deopped Bumped the minimum OpenSSL version to 1.1.0.
Fix SQlines that don't begin with # from matching channels Bumped the minumum GnuTLS version to 3.0.0.
Made cs_clone behave like the help describes, copying many settings and lists by default Disabled SSLv3 support in the m_ssl_openssl module.
Allow cs_clone to clone levels, too Modernized mutex and thread code to use Modern C++.
Update Hybrid protocol module for 8.2 Normalised the program exit codes.
Fix not unescaping all characters sent over XMLRPC Updated the Dutch translation.
Fix crash when os_mode is used to destroy channels, like when unsetting permanent channel mode from an empty channel Updated the French translation.
Allow users with topic change privilege to change the topic instead of requiring them to use ChanServ's topic command
Fix negatively locking param modes in default mlock
Change entrymsg to check for the SET privilege, not real founder
Allow configuring characters allowed in nicknames
Fix crash when non users register channels externally (like XMLRPC)
Remove operserv/exception MOVE, it did not function correctly. Instead reorder the list by deleting/adding entries.
Allow flood ttb to be 0.
Enforce mlock when disabling defcon modes
Fix cs_mode not being able to apply mlock on register
Add log message when users send memos
Fix old collide timers from staying around after successful identify. Fixes being able to identify and logout and still being hit by the old timers.
Fix undefined behavior in cs_mode which usually crashes when clearing large list modes
Show all opertypes in operserv/info, even if no opers use them
Anope Version 2.0.1 Anope Version 2.1.1
------------------- -------------------
Fix access entries on accounts sometimes not updating when a user's display name changes Added the UNBANME privilege to allow users to unban themselves.
Fix ns_group to properly validate the account of the user against the target Fixed building on Windows systems without chgrp/chmod.
Fix os_stats not saving max user count and time when using SQL Fixed creating sockets in the m_dns, m_httpd, m_proxyscan, and m_redis modules.
Fix nickalias's 'nc' field sometimes not being updated when using SQL Fixed reading the values of command line arguments.
Fix several crashes on Windows related to being unable to load modules Moved core privilege descriptions to the example configs.
Fix bs_bot change not properly reintroducing bots after changing their ident, host, or realname Updated the Italian translation.
Updated the Polish translation.
Add English language file to allow users to easily modify language strings Anope Version 2.1.0
Add configuring which mode cs_ban sets, and added a MUTE command to BotServ's fantasy
Allow SVSPART to take an optional reason
Allow cs_list to search channel topics and descriptions
Anope Version 2.0.0
------------------- -------------------
Added irc2sql stats module Added support for access list entry descriptions.
Added support for linking over a UNIX socket.
Anope Version 1.9.9 Added support for server-initiated logins and logouts on UnrealIRCd.
-------------------- Added support for server-initiated logouts on InspIRCd.
A Added a better webpanel template, removed the old one Added support for the ANONYMOUS SASL mechanism.
A Added SQL logging support Allowed users to opt-out of being added to channel access lists.
A Added Redis database support Cleaned up the codebase to use Modern C++17.
A Added ability to configure what privileges XOP commands give Modernized the build system to use a modern version of CMake.
U Updated Dutch language file, from Robby <robby@chat.be> Removed support for using insecure encryption methods as the primary method.
U Updated Spanish langauge file, from Isaac Fontal <i_fontal@hotmail.com> Removed the Windows-only anopesmtp tool.
F Fix build on Solaris and OSX Removed the two day X-line cap.
F Fixed setting BotServ's default settings in the config Updated all references to IRCServices to refer to Anope instead.
F Fixed some names of config items, including NickServ's kill protect
Anope Version 1.9.8
--------------------
A Ability to configure fantasy commands in the config
A Add SVSJOIN and SVSPART commands
F Fix "leave" channel log level from not logging
F Fix users able to "resend" their registration mail with registration set to admin only
F Fix build on OpenBSD
F Fix not logging debug logs to the logfile when debug mode is enabled
F Fix defcon timeout timer
F Fix crash in os_forbid with expiring entries
F Fix several issues with db_sql_live
Anope Version 1.9.7
--------------------
A Added ability for using regex as patterns for various commands
A Extended ability of operserv/akill to also match against nick and realname
A Added chanserv:require configuration option
A Added nickserv:unregistered_notice and nickserv:registration configuration option
A Added options:casemap configuration option
A Added a web panel
A db_sql_live now allows all tables to be "live", not just a select few
Anope Version 1.9.6
--------------------
A Added ability to configure emails sent by services
A Added chanserv/up and chanserv/down
A Added m_proxyscan
A Added more configurability for what vhosts are valid
A Added chanserv/log
A Added ability to configure ChanServ privileges
A Added a new database format
A Added SQLite support
A Added more verbose messages on startup
A Added ability for chanserv/suspend and nickserv/suspend to take an expiry time
A Added no nickname ownership config option
A Added m_rewrite
A Added akill IDs
F Fixed crash in clearusers
F Fixed crash in /os oper info
F Fixed eventfd Config check to work properly on OpenVZ
Anope Version 1.9.5
--------------------
A Extended LDAP support
A Added os_oper, os_kill, os_forbid, m_statusupdate, cs_sync, and bs_autoassign
A Added a new configuration file format
A Added a new commands system
A Added a new access system, and cs_flags
F Fixed not logging debug logs to file
F Fixed the mail delay time
F Fixed sending account data for unconfirmed nicks
F Fixed poll() engine build on FreeBSD
F Fixed really large HELP replies being truncated
F Fixed sometimes appending !*@* to valid hosts on access lists
F Fixed m_ssl sometimes failing connecting for no reason
F Fixed crash in cs_entrymsg
F Fixed setting -P on channels with only a botserv bot in it
F Fixed modemanager complaining about prefixless modes on InspIRCd
Anope Version 1.9.4
--------------------
A Automatically set channel founder to the user with the highest access if there is no successor
A /chanserv clone command to copy settings from one channel to another.
A /chanserv mode command
A Ability for users to delete their own access in channels
A Added support for Plexus 3
A Readded in support for /cs op/deop/etc to op/deop you in all channels
A Added LDAP support
A Added live SQL support
A Added support for learning tracking/storing/locking all modes at runtime
A Added m_alias
A Added support for XMLRPC queries
A Added /botserv set msg
A Added /operserv config
A Added /ns cert
A Added /operserv login
F Changed the GHOST command to not allow ghosting unidentified users if the RECOVER command exists
F Some failed logic in /operserv exception that prevents proper exceptions from being added
F Fixed the anope_os_sxlines MySQL table and code to work after restarting
Anope Version 1.9.3
--------------------
A Added italics BotServ kicks support
A Tell users when their nicks expire in /ns glist and /ns info
A Added SSL support
A Prevent negaitve mode changes, kicks, bans, and autokicks from affecting people with the 'god' user mode (On UnrealIRCd, usermode +q)
A Added nickserv/auxpex permission
A Added nickserv ungroup command
A Renamed the SGLINE to be SNLINE
A Added /chanserv saset command
A Added threads for mail sending
A Added m_dnsbl and an asynchronous DNS system
A Added a new language system that uses gettext
A Added m_mysql which uses threads to execute queries
A Added many subcommand modules for some commands, eg ns_set_autoop, ns_set_email, etc
A Added a new logging system that is a bit more flexible
A Added cs_set_misc and ns_set_misc to add miscellaneous set commands
A Added os_modreload, which allows reloading some modules not normally unloable, like the protocol module
A Added FOUNDER access level
A Made OperServ, Global, MemoServ, and ChanServ optional
F Shutting down if a config reload fails
F Autoid to live through restarts on Unreal
F Storing vhosts in MySQL
F Not flushing the anope_extra table before rewriting databaes
F Anoperc start/stop to send the globaloncycle global, and fixed anoperc rehash to really rehash
F Fixed a potential crash if HostServ or BotServ was disbled
Anope Version 1.9.2
--------------------
A K alias to chanserv kick command
A KB alias to chanserv ban command
A The ability to register empty nonregistered channels
A Flatfile plaintext databases and removed old binary ones
A Added in live updating SQL and the ability to execute commands through SQL (see docs/MYSQL)
A Added support for many more modes into Anope and the ability to have generic support for modes unknown to Anope
A Added a mode stacker to combine many mode changes into fewer
A Added in the CS SET PERSIST command which can be used to keep service bots in channels even when the channel is empty
A Added AUTOOWNER OWNER and OWNERME into CS LEVELS
A Added ns_resetpass module to the core
A CS ACCESS VIEW which shows who added the access and last time used
A Last used time to CS AKICK VIEW
A Added a sha_256 encryption module
A Added the ability to load multiple encryption modules, and the ability to seamlessly convert your database between diferent encryptions
A Added configuration options to allow Anope to reconnect if it disconnects from the uplink instead of dieing
A Added support for linking with IPv6
F Unban command to accept an optional nick arg
F Some typos in services.conf
F Crash when users change their host that are identified to a group, but not a nick
F Host length checking in HS SET(ALL) and HS REQUEST
F Only show if a user is online in NS INFO if they are really identiifed for the group of the nick they are on
F Crash when using BSSmartJoin
F Converting access entries to access from xop when a users access is below voice
F A bad pointer passed to the OnDelEvent which could cause some 3rd party modules to crash
F CS FORBID allows to you forbid unregistered channels
F The -nothird command line option to work
F ms_rsend to really work
F SQUITing juped servers on InspIRCd1.2+
Anope Version 1.9.1
--------------------
F Don't enforce akick/forbidden/etc.-restrictions on clients on ulined servers.
F Remove modules_unload_all fini + hack that goes with it.
F Signal handling cleanup.
A Seamless fantasy support on all ChanServ commands, instead of requiring bs_fantasy_*.
F Allow fantasy to be disabled on some commands (e.g. FORBID).
F Some commands (e.g. !help) need to strip the pre-provided channelname from them.
D HelpServ removed
F Command parser cleanup: mod_current_buffer removed and replaced with proper parser. Commands now indicate how they want the buffer split.
F Make NS ENFORCE/RELEASE stuff more sane, redo timers.
A Opertypes (similar to InspIRCd's opertypes)
Provided by Ankit <ankit@nevitus.com> - 2009
F Segfault on shutdown
Provided by Adam <adam@anope.org> - 2009
F NickServ registration is sometimes denied.
F Applied patch from Adam to fix some potential screwups
F More fixes to bs_bot from Adam, plus an extra fix within DoAdd not covered in Adam's patch.
F Fix bs_bot to use the correct parameters, patch from Adam.
F Fix for bug #1004, based from second half of patch from Adam.
F Partial patch by Adam, commenting fix for #1006 for future reference.
F Forward-port r1946: Patch by Adam fixing #1006 (originally caused by #922): modes set by ChanServ are reversed. Thanks!
Provided by DukePyrolator <dukepyrolator@gmx.de> - 2009
F Patch converting all match calls to new method, thanks!
F Add 'w' and 'y' support to dotime(), also prevent an overflow.
F Allow NS STATUS from unregistered users, thanks DP!
F Wild pointers do not a happy Anope make. Thanks DP :)
F Allow NS REGISTER to unregistered nicks, silly oversight. Thanks DP! :)
F Fix call order, thanks to DP
F Pass the right array to do_umode(), fixes mode tracking on Unreal. Thanks to DukePyrolator (yet again :P)
F Fix bs_set help, thanks to DukePyrolator! :)
F Fix two segfaults, noted by DukePyrolator. Thanks!
F Fix part one of #1010, reported by DukePyrolator. (Language settings are not respected in message sending.) Thanks!
F Memory leak on +beI modes.
Provided by Liber <Liber@jasonirc.net> - 2009
F Support operoverride and such things (stop reversing changes from nonopped people where unnecessary)
Anope Version 1.9.0
--------------------
F Modified compile to use g++
F Improve protocol modules support (classes, virtual methods, etc)
F Move core services to use BotInfo
F Move BotInfo and related methods into a class
F Move modules into a class
F Fixed ns resending of passcode issue
F Modules now delete themselves
F additional field where users' masked host can be stored so both masked IP and vhost are available instead of just one.
F No struct Uid, ugly, and, unnecessary that we store UID in BotInfo.
F Prevent deletion of core services via /bs bot
F Module subsystem cleanup ('modules' branch)
F Move modules to use classes somewhat (AnopeInit, AnopeFini)
F Change MODULE_INIT to return a pointer
F Remove duplicate module creation.. have loadModule return a pointer rather than creating one
F Remove buffered loading/unloading, this makes os_modunload perm, but who cares
F Remove 'delayed' loading, this is necessary because of before/after connected to ircd (ircd is before, rest after), I'm sure this can be done better.
A Remove old config, replace with insp-inspired (albeit bind format) config (CBX)
F Clean up protocol modules a bit
A InspIRCd 1.2 support
F Remove old (prior to 1.8.0) db compat
F Establish a proper base for services pseudoclients
F Add ss_main StatServ Hal9000 to play with :)
F Burn automake with fire (CBX)
Provided by mooncup <mooncup@anonnet.org> - 2009
F Automatically reapply vhost on hs off for unreal.
+21 -167
View File
@@ -1,172 +1,26 @@
Anope Version 2.0.2 Anope Version 2.1.2
------------------- -------------------
Add an operserv/oper/modify privilege, required to use oper add and oper del Added module:tlsv10 to m_ssl_openssl for configuring whether TLSv1.0 is usable (defaults to no).
Add a chanserv/access/list privilege, which allow readonly access to ChanServ access and akick lists Added module:tlsv11 to m_ssl_openssl for configuring whether TLSv1.0 is usable (defaults to yes).
Changed m_dnsbl's result configuration to be more extensible Added module:tlsv12 to m_ssl_openssl for configuring whether TLSv1.0 is usable (defaults to yes)
Add 'max' setting to cs_mode Removed module:sslv3 from m_ssl_openssl.
Add 'nickchars' setting to networkinfo Removed the m_ prefix from the names of the chanstats, dns, dnsbl, helpchan, httpd, ldap, ldap_oper, mysql, proxyscan, redis, regex_pcre2, regex_posix, regex_stdlib, regex_tre, rewrite, sasl, sql_log, sql_oper, sqlite, ssl_gnutls, ssl_openssl, xmlrpc, and xmlrpc_main modules.
Add 'botserv/fantasy', 'chanserv/access/list', and 'operserv/oper/modify' oper privileges
Fix 'emailchange_message' to include the proper email address
Set a default permission on operserv/defcon
Anope Version 2.0.1 Anope Version 2.1.1
------------------- -------------------
Add MUTE command to BotServ fantasy configuration Added the m_regex_stdlib module.
Document memo_mail option in nickserv.conf Removed the m_regex_pcre module (use m_regex_pcre2 instead).
Add 'show' setting to ns_info and cs_info to control which fields are shown to non opers
Anope Version 2.0.0 Anope Version 2.1.0
------------------- -------------------
options:passlen, enforceruser, enforcerhost, releasetimeout, and guestnickprefix moved to nickserv's module configuration Added nickserv:minpasslen for configuring the minimum password length (defaults to 8).
options:hideregisteredcommands added Removed nickserv:strictpasswords as it is obsolete now nickserv:minpasslen exists.
m_ssl renamed to m_ssl_openssl Removed the inspircd12 and inspircd20 modules (use inspircd instead).
mail:restrict removed Removed the ns_getpass module (no supported encryption modules).
Removed the os_oline module (no supported IRCds).
Anope Version 1.9.9 Removed the unreal module (use unrealircd instead).
------------------- Renamed nickserv:passlen to nickserv:maxpasslen.
There is not many config changes betewen 1.9.8 and 1.9.9, however many of the Renamed the charybdis module to solanum.
options have been moved around to make more sense, too many to list here, Renamed the inspircd3 module to inspircd.
so get a new config. Renamed the unreal4 module to unrealircd.
Replaced uplink:ipv6 with uplink:protocol.
Anope Version 1.9.8
-------------------
networkinfo:chanlen added
options:user and options:group added
nickserv:modesonid added to set modes on everyone who identifies
nickserv:kill and nickserv:killquick added to configure NickServ's kill timeout
nickserv:restoreonrecover added to try to restore a user's session after a ghost
command:group added
fantasy block added
dns block has been moved to modules.conf as a part of m_dns
Anope Version 1.9.7
-------------------
operserv:notifications removed in favor of log{} blocks
options:regexengine added
options:casemap added
chanserv:require added
nickserv:registration added, emailregistration removed.
nickserv:unregistered_notice added
Anope Version 1.9.6
-------------------
service:channels added to join services to channels
mail block modified to allow configuring of email messages
oper:host and oper:vhost added
oper:require_oper added
options:nonicknameownership added
operserv:akillids added
nickserv/access oper privilege added
Anope Version 1.9.5
-------------------
Don't even try it, get a new config and start over.
Anope Version 1.9.4
-------------------
** ADDED CONFIGURATION DIRECTIVES **
memoserv:modules added ms_ignore
chanserv:modules added cs_clone and cs_mode
nickserv:suspendexpire and nickserv:forbidexpire added
chanserv:suspendexpire and chanserv:forbidexpire added
module added cs_entrymsg
nickserv:modules added ns_ajoin, ns_cert
options:nomlock added
log:target added globops
nickserv:confirmemailchanges added
operserv:modules added os_config, os_login
** MODIFIED CONFIGURATION DIRECTIVES **
operserv:notifications removed osglobal, osmode, oskick, osakill, ossnline, ossqline, osszline, osnoop, osjupe, getpass, setpass, forbid, drop
renamed nickserv:preregexpire to nickserv:unconfirmedexpire
** DELETED CONFIGURATION DIRECTIVES **
opertype:commands removed operserv/umode
operserv:modules removed os_umode
Anope Version 1.9.3
------------------
** ADDED CONFIGURATION DIRECTIVES **
nickserv/auspex privilege added
SSL module added for SSL support
opertype:inherits added to allow opertypes to inherit commands and privs from other opertypes
Various nickserv/saset/* and chanserv/saset/* opertype command privileges added
nickserv:modules added many new ns_set_command modules
chanserv:modules added many new cs_set_command modules
opertype:commands added nickserv/saset/* and chanserv/saset/*
options:socketengine added to choose what socket engine to use
module:cs_set_misc and module:ns_set_misc added to replace the old set url/icq/email modules
options:hideprivilegedcommands added to hide privileged commands from normal users
log block added to customize logging
dns block added to configure dns settings
m_dnsbl added
mysql configuration block added
** MODIFIED CONFIGURATION DIRECTIVES **
opertype:commands changed operserv/sgline to opserv/snline
operserv:modules changed os_sgline to os_snline
operserv:modules added os_modreload
operserv:sglineexpiry changed to operserv:snlineexpiry
operserv:killonsgline changed to operserv:killonsnline
operserv:notifications ossgline changed ossnline
memoserv was made optional
moved operserv:global configuration into its own global block
chanserv was made optional
** DELETED CONFIGURATION DIRECTIVES **
serverinfo:helpchannel removed because it has been readded in m_helpchan
networkinfo:logchannel, logbot, logusers, logmaxusers, logchannel, and options:keeplogs removed because of the log block
dumpcore because it really didn't do anything
Anope Version 1.9.2
--------------------
** ADDED CONFIGURATION DIRECTIVES **
options:enablelogchannel added to auto turn on the logchannel on startup
options:mlock added to configure the default mlock modes on new channels
options:database added for the database modules
options:botmodes added to configure modes BotServ bots should use
options:userlen added to configure maxiumum ident length
options:hostlen added to configure maximum hostname length
options:database added to configure what database modules to use
options:passlen added to specify the maximum length of passwords
uplink:ipv6 added to enable IPv6 connectivity
options:maxretries added to specify the number of reconnect attempts allowed
options:retrywait added to specify how long to wait between reconnect attempts
opertype command chanserv/aop/list removed as it was unnecessary, use chanserv/access/list instead
** MODIFIED CONFIGURATION DIRECTIVES **
options:encryption added enc_sha256
chanserv:modules added cs_unban
nickserv:modules added ns_resetpass
** DELETED CONFIGURATION DIRECTIVES **
nickserv:database deleted because of new database system
nickserv:prenickdatabase deleted because of new database system
chanserv:database deleted because of the new database system
botserv:database deleted because of the new database system
hostserv:database deleted because of the new database system
operserv:database deleted because of the new database system
operserv:newsdatabase deleted because of the new database system
operserv:exceptiondatabase deleted because of the new database system
hs_request:database deleted because of the new database system
os_ignore:database deleted because of the new database system
serverinfo:localport deleted
Anope Version 1.9.1
-------------------
** ADDED CONFIGURATION DIRECTIVES **
Opertypes have been added, through the opertype blocks.
Services Operators are now specified in the oper blocks.
** MODIFIED CONFIGURATION DIRECTIVES **
botserv:modules no longer contains bs_fantasy* modules, fantasy is now seamless.
operserv:modules has replaced os_logonnews, os_opernews, and os_randomnews with os_news.
operserv:modules no longer contains os_admin and os_oper modules, removed in favor of oper blocks.
operserv:notifications no longer contains osraw due to removal of OS RAW.
** DELETED CONFIGURATION DIRECTIVES **
Nick tracking has been removed as an option.
Restricting of NS GETPASS and CS GETPASS removed in favor of opertypes.
Host Setters were removed in favor of opertypes.
HelpServ has been removed entirely.
operserv:disableraw removed due to removal of OS RAW.
+19 -20
View File
@@ -1,4 +1,4 @@
Anope DefCon Anope DefCon
------------ ------------
1) Introduction 1) Introduction
@@ -10,8 +10,8 @@ Anope DefCon
1) Introduction 1) Introduction
Anope 1.6 onwards supports a unique protection mechanism based on the Anope supports a unique protection mechanism based on the
military "Defense Readiness Condition" (DefCon) system. It is based on military "Defense Readiness Condition" (DefCon) system. It is based on
5 levels of defense readiness defined as: 5 levels of defense readiness defined as:
DEFCON5 Normal peacetime readiness DEFCON5 Normal peacetime readiness
@@ -23,9 +23,9 @@ Anope DefCon
These are configurable levels that mandates what actions Anope should These are configurable levels that mandates what actions Anope should
take in case of emergency and change in readiness status. take in case of emergency and change in readiness status.
It is used to prevent abuse to both Services, and the ircd on which they It is used to prevent abuse to both Anope, and the IRCd on which they
are running. Also to protect the users, primarily in the event of Clones are running. Also to protect the users, primarily in the event of Clones
and/or FloodBOT attacks. and/or FloodBOT attacks.
2) Installation 2) Installation
@@ -44,26 +44,26 @@ Anope DefCon
Pre-defined DefCon actions: Pre-defined DefCon actions:
No new channel registrations No new channel registrations
No New Nick Registrations No New Nick Registrations
No Mode Lock changes No Mode Lock changes
Force Chan Mode Force Chan Mode
Use Reduced Session Limit Use Reduced Session Limit
KILL any new clients trying to connect KILL any new clients trying to connect
Services will ignore everyone but opers Ignore everyone but opers
Services will silently ignore everyone but opers Silently ignore everyone but opers
AKILL all new clients trying to connect AKILL all new clients trying to connect
No new memos sent to block MemoServ attacks No new memos sent to block MemoServ attacks
Information regarding how to enable this for specific defcon levels can Information regarding how to enable this for specific defcon levels can
be found in operserv.conf be found in operserv.conf
4) Usage 4) Usage
Anope starts up in DEFCON5 (normal readiness). To change the Defcon level Anope starts up in DEFCON5 (normal readiness). To change the Defcon level
in action use: in action use:
/msg OperServ DEFCON 1|2|3|4|5 /msg OperServ DEFCON 1|2|3|4|5
5) Usage Example 5) Usage Example
@@ -89,6 +89,5 @@ Anope DefCon
6) Support 6) Support
You might get DefCon support by posting on our online forum, or maybe on You might get DefCon support by posting on our online forum, or maybe on
our #anope channel at /server irc.anope.org. our #anope channel at /server irc.anope.org.
-35
View File
@@ -1,35 +0,0 @@
Anope Internal Events
---------------------
1) Intro
2) Using Events
1) Introduction to Internal Events
Internal Events are setup to give module developers more information
about what the core is doing at different times. This information can
be as complex as data we are feeding to the uplink, to simple triggered
events such as the databases being saved.
Additionally there is a module included with the core
which can provide some clue as to how to use the code in your modules.
The rest of this document assumes that you are used to writing modules.
2) Using Events
Each Event in Anope calls a function.
You must override these functions in your main modules class.
The full list of functions and parameters are in modules.h. In this
case, you would be overriding OnJoinChannel() and OnPartChannel() like so:
void OnJoinChannel(User *u, Channel *c) anope_override { }
void OnPartChannel(User *u, Channel *c) anope_override { }
Some of these event overrides can be used to prevent or allow things to
happen that would normally not be allowed or denied. You can also use
ModuleManager (not explained here) to set control which order the modules
are queried (when multiple modules hook to the same event).
The "anope_override" identifier is for compatibility with C++11.
Its usage is highly recommended.
+5 -5
View File
@@ -1,10 +1,10 @@
Frequently Asked Questions (FAQ) concerning Anope Frequently Asked Questions (FAQ) concerning Anope
------------------------------------------------ -------------------------------------------------
The information in the 1.9 FAQ is subject to change at any The information in the 2.0 FAQ is subject to change at any
moment due to new developments. Please visit our website moment due to new developments. Please visit our website
for the most up to date information. for the most up to date information.
An updated version of the FAQ can be found here: An updated version of the FAQ can be found here:
http://wiki.anope.org/index.php/FAQ https://wiki.anope.org/index.php/2.0/FAQ
+18 -22
View File
@@ -19,7 +19,7 @@ Note: You should also read the README and FAQ files!
The very first thing you need to do is to get the Anope package (if not The very first thing you need to do is to get the Anope package (if not
already done). You can find it at: already done). You can find it at:
http://www.anope.org/ https://www.anope.org/
Anope requires cmake to build. You can check if CMake is already Anope requires cmake to build. You can check if CMake is already
installed on your system using the command: installed on your system using the command:
@@ -32,12 +32,12 @@ Note: You should also read the README and FAQ files!
CMake unless you install it yourself into your home directory. CMake CMake unless you install it yourself into your home directory. CMake
can be downloaded from: can be downloaded from:
http://www.cmake.org/cmake/resources/software.html https://cmake.org/download/
Next, unpack the package in your home directory, and go into the created Next, unpack the package in your home directory, and go into the created
directory. directory.
If there are any extra modules you want to enable, such as m_mysql, run If there are any extra modules you want to enable, such as mysql, run
the 'extras' script to enable them. If you do not know you can come back the 'extras' script to enable them. If you do not know you can come back
later and enable them. later and enable them.
@@ -52,15 +52,15 @@ Note: You should also read the README and FAQ files!
cause trouble on your network if passwords are not encrypted, or read cause trouble on your network if passwords are not encrypted, or read
the memos of any user. the memos of any user.
Now go into the conf directory (by default, ~/services/conf). Copy the example Now go into the conf directory (by default, ~/anope/conf). Copy the example
configuration file (example.conf) to services.conf, and open the latter configuration file (anope.example.conf) to anope.conf, and open the latter
with your favorite text editor. It contains all the configuration with your favorite text editor. It contains all the configuration
directives Anope will use at startup. Read the instructions contained in directives Anope will use at startup. Read the instructions contained in
the file carefully. Using the default values is NOT a good idea, and will the file carefully. Using the default values is NOT a good idea, and will
most likely not work! most likely not work!
If you need help, you should visit http://forum.anope.org/ or #anope on If you need help, you should visit https://forum.anope.org/ or #anope on
irc.anope.org. Provide *complete* error output, along with other relevant irc.anope.org. Provide *complete* error output, along with other relevant
information eg. OS, compiler and C++ library versions. information eg. OS, compiler and C++ library versions.
See the README file for more information. See the README file for more information.
@@ -71,40 +71,36 @@ Note: You should also read the README and FAQ files!
* IMPORTANT: Back up your old databases! * IMPORTANT: Back up your old databases!
* If you are upgrading to a new major release, ALWAYS restart a * If you are upgrading to a new major release, ALWAYS restart a
fresh configuration file from example.conf. fresh configuration file from anope.example.conf.
3) Setting up the IRCd 3) Setting up the IRCd
Services acts as an IRC server with pseudo-clients on it. To link them to Anope acts as an IRC server with pseudo-clients on it. To link them to
your network, you'll need to configure your IRCd to allow services to link. your network, you'll need to configure your IRCd to allow services to link.
The configuration varies depending on the IRCd, but you will probably need The configuration varies depending on the IRCd, but you will probably need
a link block (also called connect block, or C line), a U line (also called a link block (also called connect block, or C line), a U line (also called
a shared block), and be sure that the IRCd is listneing on the given port a shared block), and be sure that the IRCd is listening on the given port
in the link block. in the link block.
Example link configurations can be found in example.conf for some of the Example link configurations can be found in anope.example.conf for some of the
popular IRCds. popular IRCds.
Don't forget to /rehash your IRCd to apply changes. Don't forget to /rehash your IRCd to apply changes.
You may also try our interactive link maker, which is located at:
http://anope.org/ilm.php
4) Starting Anope 4) Starting Anope
Go into the directory where binaries were installed (by default, this is Go into the directory where binaries were installed (by default, this is
~/services/bin). Type ./services to launch Anope. ~/anope/bin). Type ./anope to launch Anope.
If there are syntax errors in the configuration file they will be If there are syntax errors in the configuration file they will be
displayed on the screen. Correct them until there are no errors anymore. displayed on the screen. Correct them until there are no errors anymore.
A successful startup won't generate any message. A successful startup won't generate any message.
Give Services at least one minute to link to your network, as certain Give Anope at least one minute to link to your network, as certain
IRCds on some OSes may be really slow for the link process. If nothing IRCds on some OSes may be really slow for the link process. If nothing
happens after about a minute, it is probably a configuration problem. Try happens after about a minute, it is probably a configuration problem. Try
to launch Anope with ./services -debug -nofork to see any errors that it to launch Anope with ./anope -debug -nofork to see any errors that it
encounters, and try to correct them. encounters, and try to correct them.
If you need help to solve errors, feel free to subscribe to the Anope If you need help to solve errors, feel free to subscribe to the Anope
@@ -116,16 +112,16 @@ Note: You should also read the README and FAQ files!
still running, and restart it if not. still running, and restart it if not.
First rename the example.chk script that is in Anope path (by default, First rename the example.chk script that is in Anope path (by default,
this is ~/services/conf) to services.chk and edit it. You'll need to this is ~/anope/conf) to anope.chk and edit it. You'll need to
modify the CONFIGURATION part of the file. Then ensure that the file is modify the CONFIGURATION part of the file. Then ensure that the file is
marked as executable by typing chmod +x services.chk, and try to launch the marked as executable by typing chmod +x anope.chk, and try to launch the
script to see if it works (Anope must not be running when you do this ;)) script to see if it works (Anope must not be running when you do this ;))
When this is done, you'll have to add the crontab entry. Type crontab -e. When this is done, you'll have to add the crontab entry. Type crontab -e.
This will open the default text editor with the crontab file. Enter the This will open the default text editor with the crontab file. Enter the
following (with correct path): following (with correct path):
*/5 * * * * /home/ircd/services/conf/services.chk >/dev/null 2>&1 */5 * * * * /home/ircd/anope/conf/anope.chk >/dev/null 2>&1
The */5 at the beginning means "check every 5 minutes". You may replace The */5 at the beginning means "check every 5 minutes". You may replace
the 5 with other another number if you want (but less than 60). Consult the 5 with other another number if you want (but less than 60). Consult
+21 -26
View File
@@ -12,14 +12,14 @@ Note : Vous devrez également lire les fichiers README et FAQ !
1) Installation d'Anope 1) Installation d'Anope
NOTE IMPORTANTE : il est déconseillé d'utiliser (et même d'installer) NOTE IMPORTANTE : il est déconseillé d'utiliser (et même d'installer)
Anope en tant que root. Utilisez un utilisateur non Anope en tant que root. Utilisez un utilisateur non
privilégié. Celui que vous utilisez pour l'IRCd ou privilégié. Celui que vous utilisez pour l'IRCd ou
un utilisateur dédié suffira. un utilisateur dédié suffira.
La première chose que vous devez faire est d'obtenir le package Anope La première chose que vous devez faire est d'obtenir le package Anope
(si ce n'est déjà fait). Vous pouvez le trouver ici : (si ce n'est déjà fait). Vous pouvez le trouver ici :
http://www.anope.org/ https://www.anope.org/
Anope nécessite cmake pour être compilé. Vous pouvez vérifier si CMake Anope nécessite cmake pour être compilé. Vous pouvez vérifier si CMake
est déjà installé sur votre système avec la commande : est déjà installé sur votre système avec la commande :
@@ -27,17 +27,17 @@ Note : Vous devrez également lire les fichiers README et FAQ !
cmake --version cmake --version
Si CMake est installé, vous aurez une ligne qui dit quelque chose comme Si CMake est installé, vous aurez une ligne qui dit quelque chose comme
"cmake version 2.8.12.2". Si la version est inférieure à 2.4 ou si vous "cmake version 2.8.12.2". Si la version est inférieure à 2.4 ou si vous
obtenez une erreur disant que la commande n'a pas été trouvée, vous ne obtenez une erreur disant que la commande n'a pas été trouvée, vous ne
pourrez pas utiliser CMake à moins de l'installer vous-même dans votre pourrez pas utiliser CMake à moins de l'installer vous-même dans votre
répertoire home. CMake peut être téléchargé ici : répertoire home. CMake peut être téléchargé ici :
http://www.cmake.org/cmake/resources/software.html https://cmake.org/download/
Ensuite, décompressez le package dans votre répertoire home, et allez Ensuite, décompressez le package dans votre répertoire home, et allez
dans le répértoire qui vient d'être créé. dans le répértoire qui vient d'être créé.
Si il y a des modules facultatifs que vous voulez activer comme m_mysql, Si il y a des modules facultatifs que vous voulez activer comme mysql,
exécuter le script 'extras' pour les activer. Si vous ne savez pas, vous exécuter le script 'extras' pour les activer. Si vous ne savez pas, vous
pouvez les activer plus tard. pouvez les activer plus tard.
@@ -49,22 +49,22 @@ Note : Vous devrez également lire les fichiers README et FAQ !
Allez dans le dossier build (cd build) et tapez make et make install. Allez dans le dossier build (cd build) et tapez make et make install.
Ceci va installer tous les fichiers nécessaires dans les dossiers que Ceci va installer tous les fichiers nécessaires dans les dossiers que
vous avez indiqués avec le script Config et régler les permissions des vous avez indiqués avec le script Config et régler les permissions des
fichiers. Vous devez vous assurer que le répertoire data n'est pas fichiers. Vous devez vous assurer que le répertoire data n'est pas
accessible par les autres utilisateurs, car des utilisateurs accessible par les autres utilisateurs, car des utilisateurs
malveillants pourraient causer des problèmes sur votre réseau, si les malveillants pourraient causer des problèmes sur votre réseau, si les
mots de passe ne sont pas chiffrés, ou lire les mémos de tous les mots de passe ne sont pas chiffrés, ou lire les mémos de tous les
utilisateurs. utilisateurs.
Allez maintenant dans le répertoire conf (par défaut, ~/services/conf). Allez maintenant dans le répertoire conf (par défaut, ~/anope/conf).
Copiez l'exemple de fichier de configuration (example.conf) en Copiez l'exemple de fichier de configuration (anope.example.conf) en
services.conf et ouvrez ce dernier avec votre éditeur de texte favori. anope.conf et ouvrez ce dernier avec votre éditeur de texte favori.
Il contient toutes les directives de configuration qu'Anope va utiliser Il contient toutes les directives de configuration qu'Anope va utiliser
en démarrant. Lisez attentivement les instructions contenues dans le en démarrant. Lisez attentivement les instructions contenues dans le
fichier. L'utilisation des valeurs par défaut n'est pas toujours fichier. L'utilisation des valeurs par défaut n'est pas toujours
recommandée, et Anope ne fonctionnera probablement pas ! recommandée, et Anope ne fonctionnera probablement pas !
Si vous avez besoin d'aide, vous pouvez aller sur le site Si vous avez besoin d'aide, vous pouvez aller sur le site
http://forum.anope.org/ ou le canal #anope sur irc.anope.org. https://forum.anope.org/ ou le canal #anope sur irc.anope.org.
Fournissez *l'essemble* des erreurs qui apparaîssent, en plus de Fournissez *l'essemble* des erreurs qui apparaîssent, en plus de
toutes informations utiles, comme les versions de votre OS, du toutes informations utiles, comme les versions de votre OS, du
compilateur utilisé et de la librairie C++. Lisez le fichier README compilateur utilisé et de la librairie C++. Lisez le fichier README
@@ -78,11 +78,11 @@ Note : Vous devrez également lire les fichiers README et FAQ !
* IMPORTANT : Sauvegardez vos anciennes bases de données ! * IMPORTANT : Sauvegardez vos anciennes bases de données !
* Si vous mettez à jour vers une nouvelle version majeure, * Si vous mettez à jour vers une nouvelle version majeure,
recommencez *toujours* toute votre configuration à partir du recommencez *toujours* toute votre configuration à partir du
fichier example.conf. fichier anope.example.conf.
3) Configuration de l'IRCd 3) Configuration de l'IRCd
Les Services agissent comme un serveur IRC avec des pseudo-clients. Anope agit comme un serveur IRC avec des pseudo-clients.
Pour les relier à votre réseau, vous aurez besoin de configurer votre Pour les relier à votre réseau, vous aurez besoin de configurer votre
IRCd pour permettre aux services de se connecter. IRCd pour permettre aux services de se connecter.
@@ -92,21 +92,16 @@ Note : Vous devrez également lire les fichiers README et FAQ !
sur le port donné dans le bloc link. sur le port donné dans le bloc link.
Des exemples de configurations de bloc link peuvent être trouvés dans Des exemples de configurations de bloc link peuvent être trouvés dans
le fichier example.conf pour certains des IRCd les plus populaires. le fichier anope.example.conf pour certains des IRCd les plus populaires.
Souvenez-vous de /rehash votre IRCd pour appliquer les changements. Souvenez-vous de /rehash votre IRCd pour appliquer les changements.
Vous pouvez également essayer notre créateur de bloc link interactif
situé ici :
http://anope.org/ilm.php
4) Mettre en route Anope 4) Mettre en route Anope
Allez dans le répertoire où les fichiers binaires ont été installés Allez dans le répertoire où les fichiers binaires ont été installés
(par défaut, ~/services/bin). Tapez ./services pour lancer Anope. (par défaut, ~/anope/bin). Tapez ./anope pour lancer Anope.
S'il y a des erreurs de syntaxe dans le fichier de configuration, elles S'il y a des erreurs de syntaxe dans le fichier de configuration, elles
seront affichées à l'écran. Corrigez-les jusqu'à ce qu'il n'y en ait seront affichées à l'écran. Corrigez-les jusqu'à ce qu'il n'y en ait
plus. Un démarrage réussi ne générera pas de message. plus. Un démarrage réussi ne générera pas de message.
@@ -114,7 +109,7 @@ Note : Vous devrez également lire les fichiers README et FAQ !
réseau, car certains IRCds sur certains systèmes peuvent être très réseau, car certains IRCds sur certains systèmes peuvent être très
lents pour le processus de liaison. Si rien ne se passe après environ lents pour le processus de liaison. Si rien ne se passe après environ
une minute, il y a probablement un problème de configuration. Essayez une minute, il y a probablement un problème de configuration. Essayez
de lancer Anope en mode debug avec ./services -debug -nofork pour voir de lancer Anope en mode debug avec ./anope -debug -nofork pour voir
toutes les erreurs rencontrées et essayez de les corriger. toutes les erreurs rencontrées et essayez de les corriger.
Si vous avez besoin d'aide pour résoudre des erreurs, n'hésitez pas à Si vous avez besoin d'aide pour résoudre des erreurs, n'hésitez pas à
@@ -127,10 +122,10 @@ Note : Vous devrez également lire les fichiers README et FAQ !
est toujours en cours d'exécution et de le redémarrer s'il n'est pas. est toujours en cours d'exécution et de le redémarrer s'il n'est pas.
D'abord renommez le script example.chk qui est dans les dossiers D'abord renommez le script example.chk qui est dans les dossiers
d'Anope (par défaut, ~/services/conf) en services.chk et modifiez-le. d'Anope (par défaut, ~/anope/conf) en anope.chk et modifiez-le.
Vous aurez besoin de modifier la partie CONFIGURATION du fichier. Vous aurez besoin de modifier la partie CONFIGURATION du fichier.
Assurez-vous ensuite que le fichier est marqué comme exécutable en Assurez-vous ensuite que le fichier est marqué comme exécutable en
tapant chmod +x services.chk et essayez de lancer le script pour voir tapant chmod +x anope.chk et essayez de lancer le script pour voir
si cela fonctionne (Anope ne doit pas être en marche lorsque vous si cela fonctionne (Anope ne doit pas être en marche lorsque vous
testez cela ;)) testez cela ;))
@@ -138,7 +133,7 @@ Note : Vous devrez également lire les fichiers README et FAQ !
crontab -e. Cela va ouvrir l'éditeur de texte par défaut avec le crontab -e. Cela va ouvrir l'éditeur de texte par défaut avec le
fichier crontab. Entrez la ligne suivante (avec le chemin correct) : fichier crontab. Entrez la ligne suivante (avec le chemin correct) :
*/5 * * * * /home/ircd/services/conf/services.chk > /dev/null 2>&1 */5 * * * * /home/ircd/anope/conf/anope.chk > /dev/null 2>&1
Le */5 au début signifie "vérifier toutes les 5 minutes". Vous pouvez Le */5 au début signifie "vérifier toutes les 5 minutes". Vous pouvez
remplacer le 5 par un autre numéro si vous voulez (mais moins de 60). remplacer le 5 par un autre numéro si vous voulez (mais moins de 60).
+17 -5
View File
@@ -1,9 +1,10 @@
Anope Mutli Language Support Anope Multi Language Support
---------------------------- ----------------------------
1) Building Anope with gettext support 1) Building Anope with gettext support
2) Adding a new language 2) Adding a new language
3) Using languages with modules 3) Using languages with modules
4) Updating a language file
1) Building Anope with gettext support 1) Building Anope with gettext support
@@ -22,13 +23,13 @@ Anope Mutli Language Support
2) Adding a new language 2) Adding a new language
Anope uses gettext (http://www.gnu.org/software/gettext/) to translate messages for users. To add a new language Anope uses gettext (https://www.gnu.org/software/gettext/) to translate messages for users. To add a new language
install gettext and run `msginit -l language -o anope.language.po -i anope.pot`. For example if I was translating to install gettext and run `msginit -l language -o anope.language.po -i anope.pot`. For example if I was translating to
Spanish I could run `msginit -l es_ES -o anope.es_ES.po -i anope.pot`. Open the newly generating .po file and start Spanish I could run `msginit -l es_ES -o anope.es_ES.po -i anope.pot`. Open the newly generating .po file and start
translating. Once you are done simply rerun ./Config; make && make install and add the language to your services.conf. translating. Once you are done simply rerun ./Config; make && make install and add the language to your anope.conf.
Note that on Windows it is not quite this simple, windows.cpp must be edited and Anope recompiled and restarted. Note that on Windows it is not quite this simple, windows.cpp must be edited and Anope recompiled and restarted.
Poedit (http://www.poedit.net/) is a popular po file editor, and we recommend using it or another editor designed to edit Poedit (https://poedit.net/) is a popular po file editor, and we recommend using it or another editor designed to edit
po files (especially on Windows). po files (especially on Windows).
If you have finished a language file translation and you want others to use it, please send it to team@anope.org If you have finished a language file translation and you want others to use it, please send it to team@anope.org
@@ -36,7 +37,7 @@ Anope Mutli Language Support
NOTE: There is no guarantee we will use your work so please do not be offended if we say no thanks. NOTE: There is no guarantee we will use your work so please do not be offended if we say no thanks.
3) Using langages with modules 3) Using languages with modules
Module authors can easily add the ability to have their modules translated by adding _() around the strings they Module authors can easily add the ability to have their modules translated by adding _() around the strings they
want translated (messages to the user, etc). want translated (messages to the user, etc).
@@ -51,3 +52,14 @@ Anope Mutli Language Support
All .po and .pot files should be placed in modules/third/language. Additionally an update script is provided there All .po and .pot files should be placed in modules/third/language. Additionally an update script is provided there
that will create .pot files and merge any changes to it with existing .po files. that will create .pot files and merge any changes to it with existing .po files.
4) Updating a language file
Poedit (https://poedit.net/) is a popular po file editor, and we recommend using it or another editor designed to edit
po files (especially on Windows).
Before editing the relevant file in languages/, run `update.sh` in the languages/ folder, i.e. `cd` to it and run
./update.sh
This will update the language file to contain all strings that need a translation.
Then commit only the changed .po files in git.
+7 -7
View File
@@ -12,7 +12,7 @@ Anope Modules
1) Introduction 1) Introduction
Anope 1.6 onwards supports external modules. External modules are pieces Anope supports external modules. External modules are pieces
of code that can be attached to a running Anope process dynamically. These of code that can be attached to a running Anope process dynamically. These
modules can serve several purposes, and perform all kind of operations to modules can serve several purposes, and perform all kind of operations to
enhance your network. enhance your network.
@@ -22,7 +22,7 @@ Anope Modules
1. If modules are supported by your system, they will be configured 1. If modules are supported by your system, they will be configured
automatically when you run ./Config. The modules will be installed automatically when you run ./Config. The modules will be installed
to the modules directory in your data path (by default this will to the modules directory in your data path (by default this will
be ~/services/data/modules). be ~/anope/data/modules).
2. Compile Anope as usual using ./Config. The "make" process will now 2. Compile Anope as usual using ./Config. The "make" process will now
compile module support into Anope, and compile the default sample compile module support into Anope, and compile the default sample
@@ -87,7 +87,7 @@ Anope Modules
5) More Modules 5) More Modules
You can download more useful modules from http://modules.anope.org/. Just You can download more useful modules from https://modules.anope.org/. Just
grab the module file (usually with a .cpp extension). Place the module grab the module file (usually with a .cpp extension). Place the module
file in your modules (anope-1.9.x/modules/third) folder; although any of file in your modules (anope-1.9.x/modules/third) folder; although any of
the other folders within the modules directory will work. the other folders within the modules directory will work.
@@ -98,7 +98,7 @@ Anope Modules
1. Make sure you're in the main source directory. (usually anope-1.X.XX/) 1. Make sure you're in the main source directory. (usually anope-1.X.XX/)
2. Run ./Config to find and configure modules, then `cd build`. 2. Run ./Config to find and configure modules, then `cd build`.
3. Run `make` to compile Anope, and any modules. 3. Run `make` to compile Anope, and any modules.
4. Run `make install` to copy the compiled binaries to the ~/services/ 4. Run `make install` to copy the compiled binaries to the ~/anope/
directory. directory.
You can now use /msg OperServ MODLOAD to load the new modules. You can now use /msg OperServ MODLOAD to load the new modules.
@@ -117,12 +117,12 @@ Anope Modules
There are a number of useful documents on the Anope Wiki. The Anope Wiki There are a number of useful documents on the Anope Wiki. The Anope Wiki
can be reached at: can be reached at:
* http://wiki.anope.org/ * https://wiki.anope.org/
8) Modules Repository 8) Modules Repository
You can find modules at http://modules.anope.org You can find modules at https://modules.anope.org/
These modules are 3rd party and as such are not supported by the Anope Team. These modules are 3rd party and as such are not supported by the Anope Team.
Contact the Module Author directly with problems, not the Anope Team. Contact the Module Author directly with problems, not the Anope Team.
-7
View File
@@ -1,7 +0,0 @@
Highlighted News in Anope 1.9
=============================
* Added in live updating SQL and the ability to execute commands through SQL
* Re-designed configuration file
* Code refresh / rewrite into C++
+17 -19
View File
@@ -1,16 +1,14 @@
Anope -- a set of IRC services for IRC networks Anope -- a set of IRC services for IRC networks
----------------------------------------------- -----------------------------------------------
Anope is 2003-2014 Anope Team <team@anope.org>. Anope is 2003-2024 Anope Team <team@anope.org>.
Based on Epona 2000-2002 PegSoft <epona@pegsoft.net>. Based on Epona 2000-2002 PegSoft <epona@pegsoft.net>.
Based on Services 1996-1999 Andrew Church <achurch@achurch.org>. Based on Services 1996-1999 Andrew Church <achurch@achurch.org>.
This program is free but copyrighted software; see the file COPYING for This program is free but copyrighted software; see the file COPYING for
details. details.
Information about Anope may be found at http://www.anope.org/ Information about Anope may be found at https://www.anope.org/
Information about Epona may be found at http://www.epona.org/
Information about Services may be found at http://www.ircservices.esper.net/
Table of Contents Table of Contents
----------------- -----------------
@@ -19,7 +17,7 @@ Table of Contents
3) Installation 3) Installation
4) Command Line Options 4) Command Line Options
5) Messages Translation 5) Messages Translation
6) Contact and Mailing List 6) Contact
1) Credits 1) Credits
@@ -94,7 +92,7 @@ Table of Contents
* Lee Holmes <lethality@anope.org> * Lee Holmes <lethality@anope.org>
* Lucas Nussbaum <lucas@lucas-nussbaum.net> * Lucas Nussbaum <lucas@lucas-nussbaum.net>
* Mark Summers <mark@goopler.net> * Mark Summers <mark@goopler.net>
* Matthew Beeching <jobe@invictachat.net> * Matthew Beeching <jobe@mdbnet.co.uk>
* Naram Qashat <cyberbotx@anope.org> * Naram Qashat <cyberbotx@anope.org>
* Phil Lavin <phil@anope.org> * Phil Lavin <phil@anope.org>
* Pieter Bootsma <geniusdex@anope.org> * Pieter Bootsma <geniusdex@anope.org>
@@ -107,11 +105,11 @@ Table of Contents
Anope Translations: Anope Translations:
* Robby <robby@chat.be> (nl_NL) * Robby <robby@chatbelgie.be> (nl_NL)
* Kein <kein-of@yandex.ru> (ru_RU) * Kein <kein-of@yandex.ru> (ru_RU)
* Maik Funke <Han@mefalcon.org> (de_DE) * Maik Funke <Han@mefalcon.org> (de_DE)
* Isaac Fontal <i_fontal@hotmail.com> (es_ES) * Isaac Fontal <i_fontal@hotmail.com> (es_ES)
* Janos Kapitany <sarkanyka@cjbchat.hu> (hu_HU) * Janos Kapitany <sarkanyka@cjbchat.hu> (hu_HU)
* Szymon S'wierkosz <szymek@adres.pl> (pl_PL) * Szymon S'wierkosz <szymek@adres.pl> (pl_PL)
* Christopher N. <saka@epiknet.org> (fr_FR) * Christopher N. <saka@epiknet.org> (fr_FR)
* Yusuf Kurekci <ysfm.20@gmail.com> (tr_TR) * Yusuf Kurekci <ysfm.20@gmail.com> (tr_TR)
@@ -122,7 +120,7 @@ Table of Contents
2) Presentation 2) Presentation
Anope is a set of Services for IRC networks that allows users to manage Anope is a set of services for IRC networks that allows users to manage
their nicks and channels in a secure and efficient way, and administrators their nicks and channels in a secure and efficient way, and administrators
to manage their network with powerful tools. to manage their network with powerful tools.
@@ -169,13 +167,13 @@ Table of Contents
Anope currently works with: Anope currently works with:
* Bahamut 1.4.27 or later (including 1.8) * Bahamut 1.4.27 or later (including 1.8)
* Charybdis 3.4 or later * ircd-hybrid 8.2.23 or later
* Hybrid 8.1 or later * InspIRCd 3 or later
* InspIRCd 1.2 or 2.0
* ngIRCd 19.2 or later * ngIRCd 19.2 or later
* Plexus 3 or later * Plexus 3 or later
* Ratbox 2.0.6 or later * Ratbox 2.0.6 or later
* UnrealIRCd 3.2 or later * Solanum (all versions)
* UnrealIRCd 4 or later
Anope could also work with some of the daemons derived by the ones listed Anope could also work with some of the daemons derived by the ones listed
above, but there's no support for them if they work or don't work. above, but there's no support for them if they work or don't work.
@@ -227,7 +225,7 @@ Table of Contents
the log file; if you send a bug report, PLEASE include an excerpt from the log file; if you send a bug report, PLEASE include an excerpt from
the log file WITH DEBUGGING ACTIVE; we cannot emphasize enough how the log file WITH DEBUGGING ACTIVE; we cannot emphasize enough how
important this is to tracking down problems. (You can also enable important this is to tracking down problems. (You can also enable
debugging while Services is running using OperServ's SET DEBUG command.) debugging while Anope is running using OperServ's SET DEBUG command.)
If you repeat use --debug=<level>, the debugging level will be increased, If you repeat use --debug=<level>, the debugging level will be increased,
which provides more detailed information but may also slow Anope down which provides more detailed information but may also slow Anope down
considerably and make the log file grow dramatically faster. In general, considerably and make the log file grow dramatically faster. In general,
@@ -242,19 +240,19 @@ Table of Contents
6) Contact 6) Contact
For announcements and discussions about Anope, please visit our For announcements and discussions about Anope, please visit our
Portal and Forums at http://www.anope.org/ -- make sure you register Portal and Forums at https://www.anope.org/ -- make sure you register
yourself to get full benefits. yourself to get full benefits.
If you read the documentation carefully, and didn't find the answer to If you read the documentation carefully, and didn't find the answer to
your question, feel free to post on the website forums or join our irc your question, feel free to post on the website forums or join our irc
channel (irc.anope.org #anope). Once you join our Support channel be as channel (irc.anope.org #anope). Once you join our Support channel be as
precise as possible when asking a question, because we have no extraordinary precise as possible when asking a question, because we have no extraordinary
powers and can't guess things if they aren't provided. powers and can't guess things if they aren't provided.
The more precise you are the sooner you'll be likely to get an answer. The more precise you are the sooner you'll be likely to get an answer.
If you think you found a bug, add it to the bug tracking system If you think you found a bug, add it to the bug tracking system
(http://bugs.anope.org) and - again - be as precise as possible. Also say (https://github.com/anope/anope/issues) and - again - be as precise as possible.
whether the bug happens always or under what circumstances, and anything Also say whether the bug happens always or under what circumstances, and anything
that could be useful to track your bug down. If you wrote a patch, send that could be useful to track your bug down. If you wrote a patch, send
it over. :) it over. :)
+10 -10
View File
@@ -1,8 +1,8 @@
Starting in Anope 1.9.9, Anope has Redis database support (http://redis.io/). Anope has Redis database support (https://redis.io/).
This document explains the data structure used by Anope, and explains how This document explains the data structure used by Anope, and explains how
keyspace notification works. keyspace notification works.
This is not a tutorial on how to use Redis, see http://redis.io/documentation This is not a tutorial on how to use Redis, see https://redis.io/documentation
for that. for that.
Table of Contents Table of Contents
@@ -14,7 +14,7 @@ Table of Contents
1) Data structure 1) Data structure
There are 4 key namespaces in Anope, they are: There are 4 key namespaces in Anope, they are:
id - The keys in id are used to atomically create object ids for new id - The keys in id are used to atomically create object ids for new
objects. For example, if I were to create a new BotInfo I would first: objects. For example, if I were to create a new BotInfo I would first:
@@ -32,7 +32,7 @@ Table of Contents
hash - The keys in hash are the actual objects, stored as hashes. For hash - The keys in hash are the actual objects, stored as hashes. For
example, if I had just looked up all BotInfo ids and wanted to iterate example, if I had just looked up all BotInfo ids and wanted to iterate
over all of them, I woulld start by: over all of them, I would start by:
redis 127.0.0.1:6379> HGETALL hash:BotInfo:1 redis 127.0.0.1:6379> HGETALL hash:BotInfo:1
@@ -70,10 +70,10 @@ Table of Contents
2) Keyspace notifications 2) Keyspace notifications
Redis 2.7 (unstable) and 2.8 (stable) and newer support keyspace notifications Redis 2.7 (unstable) and 2.8 (stable) and newer support keyspace notifications
(http://redis.io/topics/notifications). This allows Redis to notify Anope of (https://redis.io/topics/notifications). This allows Redis to notify Anope of
any external changes to objects in the database. Once notified, Anope will any external changes to objects in the database. Once notified, Anope will
immediately update the object. Otherwise, Anope keeps all objects in memory immediately update the object. Otherwise, Anope keeps all objects in memory
and will not regularly read from the databaes once started. and will not regularly read from the database once started.
You can use this to modify objects in Redis and have them immediately reflected You can use this to modify objects in Redis and have them immediately reflected
back into Anope. Additionally you can use this feature to run multiple Anope back into Anope. Additionally you can use this feature to run multiple Anope
@@ -93,7 +93,7 @@ Table of Contents
The key space ids and value are managed entirely by Anope, you do The key space ids and value are managed entirely by Anope, you do
not (and should not) modify them. Once you modify the object (hash), Anope will not (and should not) modify them. Once you modify the object (hash), Anope will
update them for you to correctly refelect any changes made to the object. update them for you to correctly reflect any changes made to the object.
Finally, always use atomic operations. If you are inserting a new object with Finally, always use atomic operations. If you are inserting a new object with
multiple commands, or inserting multiple objects at once, specifically if the multiple commands, or inserting multiple objects at once, specifically if the
@@ -149,12 +149,12 @@ Table of Contents
Which returns a new object ID for me, in this example it will be "8". Which returns a new object ID for me, in this example it will be "8".
Now I can create the object: Now I can create the object:
HMSET hash:BotInfo:8 nick redis user redis host services.anope.org realname "Services for IRC Networks" HMSET hash:BotInfo:8 nick redis user redis host services.anope.org realname "Anope IRC Services"
Note if you are using HSET instead of HMSET you will need to use a transaction, as shown in the above example. Note if you are using HSET instead of HMSET you will need to use a transaction, as shown in the above example.
If you are watching your services logs you will immediatly see: If you are watching your services logs you will immediately see:
USERS: redis!redis@services.anope.org (Services for IRC Networks) connected to the network (services.anope.org) USERS: redis!redis@services.anope.org (Anope IRC Services) connected to the network (services.anope.org)
And the bot redis will be in BotServ's bot list. And the bot redis will be in BotServ's bot list.
Notice how ids:BotInfo and the value keys are updated automatically. Notice how ids:BotInfo and the value keys are updated automatically.
-26
View File
@@ -1,26 +0,0 @@
Anope Bundled Tools
-------------------
1) Anope SMTP Client
Provided with Anope is a simple SMTP client which can be used instead of
programs like SendMail in some cases.
The SMTP client can be used instead of sendmail for use with Anope's mail
options. To use the SMTP client instead of sendmail, find the line in your
services configuration file (services.conf) that defines sendmailpath. On
that line, change the path to your services installation directory, then
followed by "bin/anopesmtp" and the IP address of a valid SMTP server. It
should look like this:
sendmailpath = "/home/anope/services/bin/anopesmtp 127.0.0.1"
If the SMTP client doesn't send mail, or if there's an other problem with
it, you can enable debug mode by passing the --debug flag after the server
address. This should generate a log file of what happened when it tried
to connect to the SMTP server.
Credits:
Originally written by Dominick Meglio <codemastr@unrealircd.com>
Ported to *nix by Trystan Scott Lee <trystan@nomadirc.net>
+5 -6
View File
@@ -18,10 +18,10 @@ Anope for Windows
1) Download the required files: 1) Download the required files:
* Current Anope source: * Current Anope source:
http://sourceforge.net/project/showfiles.php?group_id=94081 https://github.com/anope/anope/releases
* CMake: * CMake:
http://www.cmake.org/cmake/resources/software.html https://cmake.org/download/
(NOTE: When installing, tell CMake to add itself to the PATH.) (NOTE: When installing, tell CMake to add itself to the PATH.)
@@ -70,7 +70,7 @@ Anope for Windows
If you cannot find whats causing the error, please visit our forums or If you cannot find whats causing the error, please visit our forums or
our IRC Support channel for assistance. our IRC Support channel for assistance.
Some Anope modules require third party libraries, such as m_mysql and Some Anope modules require third party libraries, such as mysql and
the SSL modules. If these libraries are installed in nonstandard the SSL modules. If these libraries are installed in nonstandard
locations, cmake will probably not find them and should be told where locations, cmake will probably not find them and should be told where
they are by passing their location to Config. they are by passing their location to Config.
@@ -103,7 +103,7 @@ Anope for Windows
INSTALL within the Solution Explorer. Right-click on INSTALL and choose Build. INSTALL within the Solution Explorer. Right-click on INSTALL and choose Build.
When you have done this, all the files will be installed to where they belong. When you have done this, all the files will be installed to where they belong.
The only thing you need to do is rename "data/example.conf" to be "data/services.conf", The only thing you need to do is rename "data/anope.example.conf" to be "data/anope.conf",
and then follow the steps to set up Anope. and then follow the steps to set up Anope.
You have now completed the building phase of Anope for Windows. You can You have now completed the building phase of Anope for Windows. You can
@@ -120,7 +120,7 @@ Anope for Windows
Notepad will cause strange characters to appear, and you may not be able to Notepad will cause strange characters to appear, and you may not be able to
edit the file correctly. edit the file correctly.
Open services.conf, and read through it carefully and adjust the settings Open anope.conf, and read through it carefully and adjust the settings
you think you need to adjust. you think you need to adjust.
If you are unsure of the settings, you can go to the dos command prompt If you are unsure of the settings, you can go to the dos command prompt
@@ -159,4 +159,3 @@ Anope for Windows
Anope's Windows Installer was made using: Anope's Windows Installer was made using:
* NSIS 2.20 <http://nsis.sourceforge.net> * NSIS 2.20 <http://nsis.sourceforge.net>
+8 -5
View File
@@ -1,13 +1,13 @@
Starting with Anope 1.9.4 XMLRPC using PHP's xmlrpc_encode_request and xmlrpc_decode functions is supported. XMLRPC using PHP's xmlrpc_encode_request and xmlrpc_decode functions is supported.
This allows external applications, such as websites, to execute remote procedure calls to Anope in real time. This allows external applications, such as websites, to execute remote procedure calls to Anope in real time.
Currently there are 5 supported XMLRPC calls, provided by m_xmlrpc_main: Currently there are 5 supported XMLRPC calls, provided by xmlrpc_main:
checkAuthentication - Takes two parameters, an account name and a password. Checks if the account name is valid and the password checkAuthentication - Takes two parameters, an account name and a password. Checks if the account name is valid and the password
is correct for the account name, useful for making login pages on websites. is correct for the account name, useful for making login pages on websites.
command - Takes three parameters, a service name (BotServ, ChanServ, NickServ), a user name (whether online or not), and the command command - Takes three parameters, a service name (BotServ, ChanServ, NickServ), a user name (whether online or not), and the command
to execute. This will execute a the given command to Anope using the given service name. If the user given is online, the to execute. This will execute the given command to Anope using the given service name. If the user given is online, the
command reply will go to them, if not it is returned by XMLRPC. command reply will go to them, if not it is returned by XMLRPC.
stats - Takes no parameters, returns miscellaneous stats that can be found in the /operserv stats command. stats - Takes no parameters, returns miscellaneous stats that can be found in the /operserv stats command.
@@ -17,10 +17,13 @@ channel - Takes one parameter, a channel name, and returns real time information
user - Takes one parameter, a user name, and returns real time information regarding that user. user - Takes one parameter, a user name, and returns real time information regarding that user.
opers - Takes no parameters, returns opertypes, their privileges and commands.
notice - Takes three parameters, source user, target user, and message. Sends a message to the user.
XMLRPC was designed to be used with db_sql, and will not return any information that can be pulled from the SQL XMLRPC was designed to be used with db_sql, and will not return any information that can be pulled from the SQL
database, such as accounts and registered channel information. It is instead used for pulling realtime data such database, such as accounts and registered channel information. It is instead used for pulling realtime data such
as users and channels currently online. For examples on how to use these calls in PHP, see xmlrpc.php in docs/XMLRPC. as users and channels currently online. For examples on how to use these calls in PHP, see xmlrpc.php in docs/XMLRPC.
Also note that the parameter named "id" is reserved for query ID. If you pass a query to Anope containing a value for id. it will Also note that the parameter named "id" is reserved for query ID. If you pass a query to Anope containing a value for id. it will
be stored by Anope and the same id will be passed back in the result. be stored by Anope and the same id will be passed back in the result.
+126 -71
View File
@@ -1,90 +1,145 @@
<?php <?php
/* XMLRPC Functions
/**
* XMLRPC Functions
* *
* (C) 2003-2014 Anope Team * (C) 2003-2024 Anope Team
* Contact us at team@anope.org * Contact us at team@anope.org
*
*/ */
class AnopeXMLRPC class AnopeXMLRPC
{ {
private $Host; /**
* The XMLRPC host
*
* @var string
*/
private $host;
function __construct($Host) /**
{ * Initiate a new AnopeXMLRPC instance
$this->Host = $Host; *
} * @param $host
*/
public function __construct($host)
{
$this->host = $host;
}
/** Run an XMLRPC command. Name should be a query name and params an array of parameters, eg: /**
* $this->RunXMLRPC("checkAuthentication", array("adam", "qwerty")); * Run an XMLRPC command. Name should be a query name and params an array of parameters, eg:
* If successful returns back an array of useful information. * $this->raw("checkAuthentication", ["adam", "qwerty"]);
* * If successful returns back an array of useful information.
* Note that $params["id"] is reserved for query ID, you may set it to something if you wish. *
* If you do, the same ID will be passed back with the reply from Anope. * Note that $params["id"] is reserved for query ID, you may set it to something if you wish.
*/ * If you do, the same ID will be passed back with the reply from Anope.
function RunXMLRPC($name, $params) *
{ * @param $name
$xmlquery = xmlrpc_encode_request($name, $params); * @param $params
$context = stream_context_create(array("http" => array( * @return array|null
"method" => "POST", */
"header" => "Content-Type: text/xml", public function run($name, $params)
"content" => $xmlquery))); {
$xmlquery = xmlrpc_encode_request($name, $params);
$context = stream_context_create(["http" => [
"method" => "POST",
"header" => "Content-Type: text/xml",
"content" => $xmlquery]]);
$inbuf = file_get_contents($this->Host, false, $context); $inbuf = file_get_contents($this->host, false, $context);
$response = xmlrpc_decode($inbuf); $response = xmlrpc_decode($inbuf);
if (isset($response[0])) if ($response) {
return $response[0]; return $response;
return NULL; }
}
/** Do Command on Service as User, eg: return null;
* $anope->DoCommand("ChanServ", "Adam", "REGISTER #adam"); }
* Returns an array of information regarding the command execution, if
* If 'online' is set to yes, then the reply to the command was sent to the user on IRC.
* If 'online' is set to no, then the reply to the command is in the array member 'return'
*/
function DoCommand($Service, $User, $Command)
{
return $this->RunXMLRPC("command", array($Service, $User, $Command));
}
/** Check an account/nick name and password to see if they are valid /**
* Returns the account display name if valid * Do Command on Service as User, eg:
*/ * $anope->command("ChanServ", "Adam", "REGISTER #adam");
function CheckAuthentication($Account, $Pass) * Returns an array of information regarding the command execution, if
{ * If 'online' is set to yes, then the reply to the command was sent to the user on IRC.
$ret = $this->RunXMLRPC("checkAuthentication", array($Account, $Pass)); * If 'online' is set to no, then the reply to the command is in the array member 'return'
*
* @param $service
* @param $user
* @param $command
* @return array|null
*/
public function command($service, $user, $command)
{
return $this->run("command", [$service, $user, $command]);
}
if ($ret && $ret["result"] == "Success") /**
return $ret["account"]; * Check an account/nick name and password to see if they are valid
return NULL; * Returns the account display name if valid
} *
* @param $account
* @param $pass
* @return string|null
*/
public function auth($account, $pass)
{
$ret = $this->run("checkAuthentication", [$account, $pass]);
/* Returns an array of misc stats regarding Anope if ($ret && $ret["result"] == "Success") {
*/ return $ret["account"];
function DoStats() }
{
return $this->RunXMLRPC("stats", NULL);
}
/* Look up data for a channel return null;
* Returns an array containing channel information, or an array of size one }
* (just containing the name) if the channel does not exist
*/
function DoChannel($Channel)
{
return $this->RunXMLRPC("channel", array($Channel));
}
/* Like DoChannel(), but different. /**
*/ * Returns an array of misc stats regarding Anope
function DoUser($User) *
{ * @return array|null
return $this->RunXMLRPC("user", array($User)); */
} public function stats()
{
return $this->run("stats", null);
}
/**
* Look up data for a channel
* Returns an array containing channel information, or an array of size one
* (just containing the name) if the channel does not exist
*
* @param $channel
* @return array|null
*/
public function channel($channel)
{
return $this->run("channel", [$channel]);
}
/**
* Sent a notice to a user.
* Returns an array containing channel information, or an array of size one
* (just containing the name) if the channel does not exist
*
* @param $source
* @param $target
* @param $message
* @return array|null
*/
public function notice($source, $target, $message)
{
return $this->run("notice", [$source, $target, $message]);
}
/**
* Like channel(), but different.
*
* @param $user
* @return array|null
*/
public function user($user)
{
return $this->run("user", [$user]);
}
} }
$anopexmlrpc = new AnopeXMLRPC("http://127.0.0.1:8080/xmlrpc"); $anope = new AnopeXMLRPC("http://127.0.0.1:8080/xmlrpc");
?>
+3 -8
View File
@@ -1,7 +1,7 @@
#!/usr/bin/env perl #!/usr/bin/env perl
# #
# Script taken from InspIRCd, www.inspircd.org # Script taken from InspIRCd, https://www.inspircd.org/
# #
# This program is distributed in the hope that it will be useful, but WITHOUT # This program is distributed in the hope that it will be useful, but WITHOUT
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS # ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
@@ -9,7 +9,7 @@
# details. # details.
# #
# You should have received a copy of the GNU General Public License # You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>. # along with this program. If not, see <https://www.gnu.org/licenses/>.
# #
@@ -148,12 +148,7 @@ while (1)
if ($input eq "q") { if ($input eq "q") {
if (-e "build/CMakeFiles") { if (-e "build/CMakeFiles") {
if (-e "cmake-bin") { system("cmake", "build/.");
my $cmake_path = `find cmake-bin -name cmake -print0`;
system($cmake_path, "build/.");
} else {
system("cmake", "build/.");
}
print "\nNow cd build, then run make to build Anope.\n\n"; print "\nNow cd build, then run make to build Anope.\n\n";
} else { } else {
print "\nBuild directory not found. You should run ./Config now.\n\n" print "\nBuild directory not found. You should run ./Config now.\n\n"
+10 -52
View File
@@ -1,64 +1,22 @@
# Set version.cpp to use C++ as well as set its compile flags # Set version.cpp to use C++ as well as set its compile flags
set_source_files_properties(version.cpp PROPERTIES LANGUAGE CXX COMPILE_FLAGS "${CXXFLAGS}") set_source_files_properties(version.cpp PROPERTIES LANGUAGE CXX COMPILE_FLAGS "${CXXFLAGS}")
# Generate version executable to modify version.h, setting it's linker flags as well # Generate version-bin executable to modify version.h, setting it's linker flags as well
add_executable(version version.cpp) add_executable(version-bin version.cpp)
set_target_properties(version PROPERTIES LINKER_LANGUAGE CXX LINK_FLAGS "${LDFLAGS}") set_target_properties(version-bin PROPERTIES LINKER_LANGUAGE CXX LINK_FLAGS "${LDFLAGS}")
get_target_property(version_BINARY version LOCATION) set(version_BINARY "$<TARGET_FILE:version-bin>")
# Modify version.h from the above executable, with dependencies to version.cpp # Modify version.h from the above executable, with dependencies to version.cpp
# and all of the source files in the main build # and all of the source files in the main build
add_custom_command(OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/version_build add_custom_command(OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/version.h ${CMAKE_CURRENT_BINARY_DIR}/build.h
COMMAND ${version_BINARY} ${Anope_SOURCE_DIR} ${CMAKE_CURRENT_BINARY_DIR}/version.h ${CMAKE_CURRENT_BINARY_DIR}/build.h COMMAND version-bin ${Anope_SOURCE_DIR} ${CMAKE_CURRENT_BINARY_DIR}/version.h ${CMAKE_CURRENT_BINARY_DIR}/build.h
DEPENDS version ${SRC_SRCS} DEPENDS version-bin ${SRC_SRCS}
) )
# Add version to list of files for CPack to ignore # Add version-bin to list of files for CPack to ignore
get_filename_component(version_BINARY ${version_BINARY} NAME) get_filename_component(version_BINARY ${version_BINARY} NAME)
add_to_cpack_ignored_files("${version_BINARY}$" TRUE) add_to_cpack_ignored_files("${version_BINARY}$" TRUE)
if(NOT WIN32) if(NOT WIN32)
add_to_cpack_ignored_files("version.h$" TRUE) add_to_cpack_ignored_files("version.h$" TRUE)
add_to_cpack_ignored_files("build.h$" TRUE) add_to_cpack_ignored_files("build.h$" TRUE)
endif(NOT WIN32) endif()
set(PCH_SOURCES_GCH "")
if(USE_PCH AND CMAKE_COMPILER_IS_GNUCXX)
string(REPLACE " " ";" PCH_CXXFLAGS "${CXXFLAGS} ${CMAKE_CXX_FLAGS}")
file(GLOB PCH_SOURCES RELATIVE ${CMAKE_CURRENT_SOURCE_DIR} "*.h")
sort_list(PCH_SOURCES)
foreach(PCH_SOURCE ${PCH_SOURCES})
find_includes(${PCH_SOURCE} INCLUDES)
set(INCLUDES_LIST)
append_to_list(INCLUDES_LIST ${PCH_SOURCE})
foreach(INCLUDE ${INCLUDES})
# Extract the filename from the #include line
extract_include_filename(${INCLUDE} FILENAME QUOTE_TYPE)
if(QUOTE_TYPE STREQUAL "quotes")
find_in_list(PCH_SOURCES "${FILENAME}" FOUND)
if(NOT FOUND EQUAL -1)
append_to_list(INCLUDES_LIST ${FILENAME})
endif(NOT FOUND EQUAL -1)
endif(QUOTE_TYPE STREQUAL "quotes")
endforeach(INCLUDE)
set(PCH_EXTRAFLAGS "")
if(DEBUG_BUILD)
set(PCH_EXTRAFLAGS "-g")
endif(DEBUG_BUILD)
if(PCH_SOURCE STREQUAL "module.h")
set(PCH_EXTRAFLAGS ${PCH_EXTRAFLAGS} -fPIC)
endif(PCH_SOURCE STREQUAL "module.h")
if(GETTEXT_INCLUDE)
set(PCH_GETTEXT_INCLUDE "-I${GETTEXT_INCLUDE}")
endif(GETTEXT_INCLUDE)
set(PCH_SOURCES_GCH "${PCH_SOURCES_GCH};${CMAKE_CURRENT_BINARY_DIR}/${PCH_SOURCE}.gch")
add_custom_command(OUTPUT ${CMAKE_CURRENT_BINARY_DIR}/${PCH_SOURCE}.gch
COMMAND ${CMAKE_CXX_COMPILER} ARGS ${PCH_CXXFLAGS} ${PCH_EXTRAFLAGS}
${PCH_GETTEXT_INCLUDE} -I${CMAKE_CURRENT_BINARY_DIR} -I${Anope_SOURCE_DIR}/modules/pseudoclients ${CMAKE_CURRENT_SOURCE_DIR}/${PCH_SOURCE} -o ${CMAKE_CURRENT_BINARY_DIR}/${PCH_SOURCE}.gch
DEPENDS ${INCLUDES_LIST} VERBATIM
)
endforeach(PCH_SOURCE ${PCH_SOURCES})
endif(USE_PCH AND CMAKE_COMPILER_IS_GNUCXX)
# Add a custom target to the above file # Add a custom target to the above file
add_custom_target(headers DEPENDS version ${CMAKE_CURRENT_BINARY_DIR}/version_build ${PCH_SOURCES_GCH}) add_custom_target(headers DEPENDS ${CMAKE_CURRENT_BINARY_DIR}/version.h ${CMAKE_CURRENT_BINARY_DIR}/build.h)
+28 -31
View File
@@ -1,17 +1,15 @@
/* /*
* *
* (C) 2003-2014 Anope Team * (C) 2003-2024 Anope Team
* Contact us at team@anope.org * Contact us at team@anope.org
* *
* Please read COPYING and README for further details. * Please read COPYING and README for further details.
* *
* Based on the original code of Epona by Lara. * Based on the original code of Epona by Lara.
* Based on the original code of Services by Andy Church. * Based on the original code of Services by Andy Church.
*
*/ */
#ifndef ACCESS_H #pragma once
#define ACCESS_H
#include "services.h" #include "services.h"
#include "anope.h" #include "anope.h"
@@ -29,7 +27,7 @@ enum
* backing each ChanAccess determines whether that ChanAccess has a given * backing each ChanAccess determines whether that ChanAccess has a given
* privilege. * privilege.
*/ */
struct CoreExport Privilege struct CoreExport Privilege final
{ {
Anope::string name; Anope::string name;
Anope::string desc; Anope::string desc;
@@ -40,10 +38,10 @@ struct CoreExport Privilege
bool operator==(const Privilege &other) const; bool operator==(const Privilege &other) const;
}; };
class CoreExport PrivilegeManager class CoreExport PrivilegeManager final
{ {
static std::vector<Privilege> Privileges; static std::vector<Privilege> Privileges;
public: public:
static void AddPrivilege(Privilege p); static void AddPrivilege(Privilege p);
static void RemovePrivilege(Privilege &p); static void RemovePrivilege(Privilege &p);
static Privilege *FindPrivilege(const Anope::string &name); static Privilege *FindPrivilege(const Anope::string &name);
@@ -54,9 +52,10 @@ class CoreExport PrivilegeManager
/* A provider of access. Only used for creating ChanAccesses, as /* A provider of access. Only used for creating ChanAccesses, as
* they contain pure virtual functions. * they contain pure virtual functions.
*/ */
class CoreExport AccessProvider : public Service class CoreExport AccessProvider
: public Service
{ {
public: public:
AccessProvider(Module *owner, const Anope::string &name); AccessProvider(Module *owner, const Anope::string &name);
virtual ~AccessProvider(); virtual ~AccessProvider();
@@ -65,32 +64,29 @@ class CoreExport AccessProvider : public Service
*/ */
virtual ChanAccess *Create() = 0; virtual ChanAccess *Create() = 0;
private: private:
static std::list<AccessProvider *> Providers; static std::list<AccessProvider *> Providers;
public: public:
static const std::list<AccessProvider *>& GetProviders(); static const std::list<AccessProvider *>& GetProviders();
}; };
/* Represents one entry of an access list on a channel. */ /* Represents one entry of an access list on a channel. */
class CoreExport ChanAccess : public Serializable class CoreExport ChanAccess
: public Serializable
{ {
Anope::string mask; Anope::string mask;
/* account this access entry is for, if any */ /* account this access entry is for, if any */
Serialize::Reference<NickCore> nc; Serialize::Reference<NickCore> nc;
public: public:
typedef std::multimap<const ChanAccess *, const ChanAccess *> Set; typedef std::vector<ChanAccess *> Path;
/* shows the 'path' taken to determine if an access entry matches a user
* .first are access entries checked
* .second are access entries which match
*/
typedef std::pair<Set, Set> Path;
/* The provider that created this access entry */ /* The provider that created this access entry */
AccessProvider *provider; AccessProvider *provider;
/* Channel this access entry is on */ /* Channel this access entry is on */
Serialize::Reference<ChannelInfo> ci; Serialize::Reference<ChannelInfo> ci;
Anope::string creator; Anope::string creator;
Anope::string description;
time_t last_seen; time_t last_seen;
time_t created; time_t created;
@@ -101,15 +97,17 @@ class CoreExport ChanAccess : public Serializable
const Anope::string &Mask() const; const Anope::string &Mask() const;
NickCore *GetAccount() const; NickCore *GetAccount() const;
void Serialize(Serialize::Data &data) const anope_override; void Serialize(Serialize::Data &data) const override;
static Serializable* Unserialize(Serializable *obj, Serialize::Data &); static Serializable* Unserialize(Serializable *obj, Serialize::Data &);
static const unsigned int MAX_DEPTH = 4;
/** Check if this access entry matches the given user or account /** Check if this access entry matches the given user or account
* @param u The user * @param u The user
* @param nc The account * @param nc The account
* @param p The path to the access object which matches will be put here * @param next Next channel to check if any
*/ */
virtual bool Matches(const User *u, const NickCore *nc, Path &p) const; virtual bool Matches(const User *u, const NickCore *nc, ChannelInfo* &next) const;
/** Check if this access entry has the given privilege. /** Check if this access entry has the given privilege.
* @param name The privilege name * @param name The privilege name
@@ -137,13 +135,13 @@ class CoreExport ChanAccess : public Serializable
/* A group of access entries. This is used commonly, for example with ChannelInfo::AccessFor, /* A group of access entries. This is used commonly, for example with ChannelInfo::AccessFor,
* to show what access a user has on a channel because users can match multiple access entries. * to show what access a user has on a channel because users can match multiple access entries.
*/ */
class CoreExport AccessGroup : public std::vector<ChanAccess *> class CoreExport AccessGroup final
{ {
public: public:
/* access entries + paths */
std::vector<ChanAccess::Path> paths;
/* Channel these access entries are on */ /* Channel these access entries are on */
const ChannelInfo *ci; const ChannelInfo *ci;
/* Path from these entries to other entries that they depend on */
ChanAccess::Path path;
/* Account these entries affect, if any */ /* Account these entries affect, if any */
const NickCore *nc; const NickCore *nc;
/* super_admin always gets all privs. founder is a special case where ci->founder == nc */ /* super_admin always gets all privs. founder is a special case where ci->founder == nc */
@@ -171,7 +169,6 @@ class CoreExport AccessGroup : public std::vector<ChanAccess *>
bool operator<(const AccessGroup &other) const; bool operator<(const AccessGroup &other) const;
bool operator>=(const AccessGroup &other) const; bool operator>=(const AccessGroup &other) const;
bool operator<=(const AccessGroup &other) const; bool operator<=(const AccessGroup &other) const;
inline bool empty() const { return paths.empty(); }
}; };
#endif
+39 -30
View File
@@ -1,17 +1,15 @@
/* /*
* *
* (C) 2003-2014 Anope Team * (C) 2003-2024 Anope Team
* Contact us at team@anope.org * Contact us at team@anope.org
* *
* Please read COPYING and README for further details. * Please read COPYING and README for further details.
* *
* Based on the original code of Epona by Lara. * Based on the original code of Epona by Lara.
* Based on the original code of Services by Andy Church. * Based on the original code of Services by Andy Church.
*
*/ */
#ifndef ACCOUNT_H #pragma once
#define ACCOUNT_H
#include "extensible.h" #include "extensible.h"
#include "serialize.h" #include "serialize.h"
@@ -21,19 +19,23 @@
typedef Anope::hash_map<NickAlias *> nickalias_map; typedef Anope::hash_map<NickAlias *> nickalias_map;
typedef Anope::hash_map<NickCore *> nickcore_map; typedef Anope::hash_map<NickCore *> nickcore_map;
typedef std::unordered_map<uint64_t, NickCore *> nickcoreid_map;
extern CoreExport Serialize::Checker<nickalias_map> NickAliasList; extern CoreExport Serialize::Checker<nickalias_map> NickAliasList;
extern CoreExport Serialize::Checker<nickcore_map> NickCoreList; extern CoreExport Serialize::Checker<nickcore_map> NickCoreList;
extern CoreExport nickcoreid_map NickCoreIdList;
/* A registered nickname. /* A registered nickname.
* It matters that Base is here before Extensible (it is inherited by Serializable) * It matters that Base is here before Extensible (it is inherited by Serializable)
*/ */
class CoreExport NickAlias : public Serializable, public Extensible class CoreExport NickAlias final
: public Serializable
, public Extensible
{ {
Anope::string vhost_ident, vhost_host, vhost_creator; Anope::string vhost_ident, vhost_host, vhost_creator;
time_t vhost_created; time_t vhost_created;
public: public:
Anope::string nick; Anope::string nick;
Anope::string last_quit; Anope::string last_quit;
Anope::string last_realname; Anope::string last_realname;
@@ -46,21 +48,21 @@ class CoreExport NickAlias : public Serializable, public Extensible
/* Account this nick is tied to. Multiple nicks can be tied to a single account. */ /* Account this nick is tied to. Multiple nicks can be tied to a single account. */
Serialize::Reference<NickCore> nc; Serialize::Reference<NickCore> nc;
/** Constructor /** Constructor
* @param nickname The nick * @param nickname The nick
* @param nickcore The nickcore for this nick * @param nickcore The nickcore for this nick
*/ */
NickAlias(const Anope::string &nickname, NickCore *nickcore); NickAlias(const Anope::string &nickname, NickCore *nickcore);
~NickAlias(); ~NickAlias();
void Serialize(Serialize::Data &data) const anope_override; void Serialize(Serialize::Data &data) const override;
static Serializable* Unserialize(Serializable *obj, Serialize::Data &); static Serializable* Unserialize(Serializable *obj, Serialize::Data &);
/** Set a vhost for the user /** Set a vhost for the user
* @param ident The ident * @param ident The ident
* @param host The host * @param host The host
* @param creator Who created the vhost * @param creator Who created the vhost
* @param time When the vhost was craated * @param time When the vhost was created
*/ */
void SetVhost(const Anope::string &ident, const Anope::string &host, const Anope::string &creator, time_t created = Anope::CurTime); void SetVhost(const Anope::string &ident, const Anope::string &host, const Anope::string &creator, time_t created = Anope::CurTime);
@@ -104,12 +106,16 @@ class CoreExport NickAlias : public Serializable, public Extensible
* account's display. * account's display.
* It matters that Base is here before Extensible (it is inherited by Serializable) * It matters that Base is here before Extensible (it is inherited by Serializable)
*/ */
class CoreExport NickCore : public Serializable, public Extensible class CoreExport NickCore final
: public Serializable
, public Extensible
{ {
/* Channels which reference this core in some way (this is on their access list, akick list, is founder, successor, etc) */ /* Channels which reference this core in some way (this is on their access list, akick list, is founder, successor, etc) */
Serialize::Checker<std::map<ChannelInfo *, int> > chanaccess; Serialize::Checker<std::map<ChannelInfo *, int> > chanaccess;
public: /* Unique identifier for the account. */
/* Name of the account. Find(display)->nc == this. */ uint64_t id;
public:
/* Name of the account. Find(display)->nc == this. */
Anope::string display; Anope::string display;
/* User password in form of hashm:data */ /* User password in form of hashm:data */
Anope::string pass; Anope::string pass;
@@ -127,7 +133,7 @@ class CoreExport NickCore : public Serializable, public Extensible
*/ */
Serialize::Checker<std::vector<NickAlias *> > aliases; Serialize::Checker<std::vector<NickAlias *> > aliases;
/* Set if this user is a services operattor. o->ot must exist. */ /* Set if this user is a services operator. o->ot must exist. */
Oper *o; Oper *o;
/* Unsaved data */ /* Unsaved data */
@@ -141,11 +147,12 @@ class CoreExport NickCore : public Serializable, public Extensible
/** Constructor /** Constructor
* @param display The display nick * @param display The display nick
* @param id The account id
*/ */
NickCore(const Anope::string &nickdisplay); NickCore(const Anope::string &nickdisplay, uint64_t nickid = 0);
~NickCore(); ~NickCore();
void Serialize(Serialize::Data &data) const anope_override; void Serialize(Serialize::Data &data) const override;
static Serializable* Unserialize(Serializable *obj, Serialize::Data &); static Serializable* Unserialize(Serializable *obj, Serialize::Data &);
/** Changes the display for this account /** Changes the display for this account
@@ -179,6 +186,9 @@ class CoreExport NickCore : public Serializable, public Extensible
*/ */
unsigned GetAccessCount() const; unsigned GetAccessCount() const;
/** Retrieves the account id for this user */
uint64_t GetId();
/** Find an entry in the nick's access list /** Find an entry in the nick's access list
* *
* @param entry The nick!ident@host entry to search for * @param entry The nick!ident@host entry to search for
@@ -215,7 +225,7 @@ class CoreExport NickCore : public Serializable, public Extensible
* @return The account, if it exists * @return The account, if it exists
*/ */
static NickCore* Find(const Anope::string &nick); static NickCore* Find(const Anope::string &nick);
void AddChannelReference(ChannelInfo *ci); void AddChannelReference(ChannelInfo *ci);
void RemoveChannelReference(ChannelInfo *ci); void RemoveChannelReference(ChannelInfo *ci);
void GetChannelReferences(std::deque<ChannelInfo *> &queue); void GetChannelReferences(std::deque<ChannelInfo *> &queue);
@@ -227,26 +237,27 @@ class CoreExport NickCore : public Serializable, public Extensible
class CoreExport IdentifyRequest class CoreExport IdentifyRequest
{ {
/* Owner of this request, used to cleanup requests if a module is unloaded /* Owner of this request, used to cleanup requests if a module is unloaded
* while a reqyest us pending */ * while a request us pending */
Module *owner; Module *owner;
Anope::string account; Anope::string account;
Anope::string password; Anope::string password;
std::set<Module *> holds; std::set<Module *> holds;
bool dispatched; bool dispatched = false;
bool success; bool success = false;
static std::set<IdentifyRequest *> Requests; static std::set<IdentifyRequest *> Requests;
protected: protected:
IdentifyRequest(Module *o, const Anope::string &acc, const Anope::string &pass); IdentifyRequest(Module *o, const Anope::string &acc, const Anope::string &pass);
virtual ~IdentifyRequest(); virtual ~IdentifyRequest();
public: public:
/* One of these is called when the request goes through */ /* One of these is called when the request goes through */
virtual void OnSuccess() = 0; virtual void OnSuccess() = 0;
virtual void OnFail() = 0; virtual void OnFail() = 0;
Module *GetOwner() const { return owner; }
const Anope::string &GetAccount() const { return account; } const Anope::string &GetAccount() const { return account; }
const Anope::string &GetPassword() const { return password; } const Anope::string &GetPassword() const { return password; }
@@ -254,17 +265,17 @@ class CoreExport IdentifyRequest
* for the request to complete. Multiple modules may hold a request at any time, * for the request to complete. Multiple modules may hold a request at any time,
* but the request is not complete until every module has released it. If you do not * but the request is not complete until every module has released it. If you do not
* require holding this (eg, your password check is done in this thread and immediately) * require holding this (eg, your password check is done in this thread and immediately)
* then you don't need to hold the request before Successing it. * then you don't need to hold the request before calling `Success()`.
* @param m The module holding this request * @param m The module holding this request
*/ */
void Hold(Module *m); void Hold(Module *m);
/** Releases a held request /** Releases a held request
* @param m The module releaseing the hold * @param m The module releasing the hold
*/ */
void Release(Module *m); void Release(Module *m);
/** Called by modules when this IdentifyRequest has successeded successfully. /** Called by modules when this IdentifyRequest has succeeded.
* If this request is behind held it must still be Released after calling this. * If this request is behind held it must still be Released after calling this.
* @param m The module confirming authentication * @param m The module confirming authentication
*/ */
@@ -278,5 +289,3 @@ class CoreExport IdentifyRequest
static void ModuleUnload(Module *m); static void ModuleUnload(Module *m);
}; };
#endif // ACCOUNT_H
+85 -66
View File
@@ -1,17 +1,15 @@
/* /*
* *
* (C) 2003-2014 Anope Team * (C) 2003-2024 Anope Team
* Contact us at team@anope.org * Contact us at team@anope.org
* *
* Please read COPYING and README for further details. * Please read COPYING and README for further details.
* *
* Based on the original code of Epona by Lara. * Based on the original code of Epona by Lara.
* Based on the original code of Services by Andy Church. * Based on the original code of Services by Andy Church.
*
*/ */
#ifndef ANOPE_H #pragma once
#define ANOPE_H
#include <signal.h> #include <signal.h>
@@ -24,15 +22,15 @@ namespace Anope
* allow us to only require one type of string everywhere that can be converted * allow us to only require one type of string everywhere that can be converted
* at any time to a specific type of string. * at any time to a specific type of string.
*/ */
class CoreExport string class CoreExport string final
{ {
private: private:
/** /**
* The actual string is stored in an std::string as it can be converted to * The actual string is stored in an std::string as it can be converted to
* ci::string, or a C-style string at any time. * ci::string, or a C-style string at any time.
*/ */
std::string _string; std::string _string;
public: public:
/** /**
* Extras. * Extras.
*/ */
@@ -55,6 +53,7 @@ namespace Anope
string(const ci::string &_str) : _string(_str.c_str()) { } string(const ci::string &_str) : _string(_str.c_str()) { }
string(const string &_str, size_type pos, size_type n = npos) : _string(_str._string, pos, n) { } string(const string &_str, size_type pos, size_type n = npos) : _string(_str._string, pos, n) { }
template <class InputIterator> string(InputIterator first, InputIterator last) : _string(first, last) { } template <class InputIterator> string(InputIterator first, InputIterator last) : _string(first, last) { }
string(const string &) = default;
/** /**
* Assignment operators, so any type of string can be assigned to this class. * Assignment operators, so any type of string can be assigned to this class.
@@ -211,6 +210,10 @@ namespace Anope
inline size_type find_last_not_of(const string &_str, size_type pos = npos) const { return this->_string.find_last_not_of(_str._string, pos); } inline size_type find_last_not_of(const string &_str, size_type pos = npos) const { return this->_string.find_last_not_of(_str._string, pos); }
inline size_type find_last_not_of_ci(const string &_str, size_type pos = npos) const { return ci::string(this->_string.c_str()).find_last_not_of(ci::string(_str._string.c_str()), pos); } inline size_type find_last_not_of_ci(const string &_str, size_type pos = npos) const { return ci::string(this->_string.c_str()).find_last_not_of(ci::string(_str._string.c_str()), pos); }
inline int compare(size_t pos, size_t len, const string& str) const { return ci::string(this->_string.c_str()).compare(pos, len, ci::string(str.c_str())); }
inline int compare(size_t pos, size_t len, const string& str, size_t subpos, size_type sublen = npos) const { return ci::string(this->_string.c_str()).compare(pos, len, ci::string(str.c_str()), subpos, sublen); }
inline int compare(size_t pos, size_t len, const char* s, size_type n = npos) const { return ci::string(this->_string.c_str()).compare(pos, len, s, n); }
/** /**
* Determine if string consists of only numbers. * Determine if string consists of only numbers.
*/ */
@@ -255,8 +258,8 @@ namespace Anope
inline string lower() const inline string lower() const
{ {
Anope::string new_string = *this; Anope::string new_string = *this;
for (size_type i = 0; i < new_string.length(); ++i) for (auto &chr : new_string)
new_string[i] = Anope::tolower(new_string[i]); chr = Anope::tolower(chr);
return new_string; return new_string;
} }
@@ -266,8 +269,8 @@ namespace Anope
inline string upper() const inline string upper() const
{ {
Anope::string new_string = *this; Anope::string new_string = *this;
for (size_type i = 0; i < new_string.length(); ++i) for (auto &chr : new_string)
new_string[i] = Anope::toupper(new_string[i]); chr = Anope::toupper(chr);
return new_string; return new_string;
} }
@@ -309,23 +312,23 @@ namespace Anope
inline const string operator+(const char *_str, const string &str) { string tmp(_str); tmp += str; return tmp; } inline const string operator+(const char *_str, const string &str) { string tmp(_str); tmp += str; return tmp; }
inline const string operator+(const std::string &_str, const string &str) { string tmp(_str); tmp += str; return tmp; } inline const string operator+(const std::string &_str, const string &str) { string tmp(_str); tmp += str; return tmp; }
struct hash_ci struct hash_ci final
{ {
inline size_t operator()(const string &s) const inline size_t operator()(const string &s) const
{ {
return TR1NS::hash<std::string>()(s.lower().str()); return std::hash<std::string>()(s.lower().str());
} }
}; };
struct hash_cs struct hash_cs final
{ {
inline size_t operator()(const string &s) const inline size_t operator()(const string &s) const
{ {
return TR1NS::hash<std::string>()(s.str()); return std::hash<std::string>()(s.str());
} }
}; };
struct compare struct compare final
{ {
inline bool operator()(const string &s1, const string &s2) const inline bool operator()(const string &s1, const string &s2) const
{ {
@@ -333,11 +336,18 @@ namespace Anope
} }
}; };
template<typename T> class map : public std::map<string, T, ci::less> { }; template<typename T>
template<typename T> class multimap : public std::multimap<string, T, ci::less> { }; using map = std::map<string, T, ci::less>;
template<typename T> class hash_map : public TR1NS::unordered_map<string, T, hash_ci, compare> { };
template<typename T>
using multimap = std::multimap<string, T, ci::less>;
template<typename T>
using hash_map = std::unordered_map<string, T, hash_ci, compare>;
#ifndef REPRODUCIBLE_BUILD
static const char *const compiled = __TIME__ " " __DATE__; static const char *const compiled = __TIME__ " " __DATE__;
#endif
/** The time Anope started. /** The time Anope started.
*/ */
@@ -361,15 +371,15 @@ namespace Anope
*/ */
extern CoreExport int Debug; extern CoreExport int Debug;
/** Other comand line options. /** Other command line options.
*/ */
extern CoreExport bool ReadOnly, NoFork, NoThird, NoExpire, ProtocolDebug; extern CoreExport bool ReadOnly, NoFork, NoThird, NoExpire, ProtocolDebug;
/** The root of the services installation. Usually ~/services /** The root of the Anope installation. Usually ~/anope
*/ */
extern CoreExport Anope::string ServicesDir; extern CoreExport Anope::string ServicesDir;
/** Services binary name (eg services) /** Anope binary name (eg anope)
*/ */
extern CoreExport Anope::string ServicesBin; extern CoreExport Anope::string ServicesBin;
@@ -383,7 +393,7 @@ namespace Anope
/** The uplink we are currently connected to /** The uplink we are currently connected to
*/ */
extern CoreExport int CurrentUplink; extern CoreExport size_t CurrentUplink;
/** Various methods to determine the Anope version running /** Various methods to determine the Anope version running
*/ */
@@ -402,7 +412,7 @@ namespace Anope
/** Used to "fork" the process and go into the background during initial startup /** Used to "fork" the process and go into the background during initial startup
* while we are AtTerm(). The actual fork is not done here, but earlier, and this * while we are AtTerm(). The actual fork is not done here, but earlier, and this
* simply notifys the parent via kill() to exit(). * simply notifies the parent via kill() to exit().
*/ */
extern void Fork(); extern void Fork();
@@ -412,10 +422,10 @@ namespace Anope
/** One of the first functions called, does general initialization such as reading /** One of the first functions called, does general initialization such as reading
* command line args, loading the configuration, doing the initial fork() if necessary, * command line args, loading the configuration, doing the initial fork() if necessary,
* initializating language support, loading modules, and loading databases. * initializing language support, loading modules, and loading databases.
* @throws CoreException if something bad went wrong * @throws CoreException if something bad went wrong
*/ */
extern void Init(int ac, char **av); extern bool Init(int ac, char **av);
/** Calls the save database event /** Calls the save database event
*/ */
@@ -442,13 +452,13 @@ namespace Anope
*/ */
extern CoreExport void Unhex(const string &src, string &dest); extern CoreExport void Unhex(const string &src, string &dest);
extern CoreExport void Unhex(const string &src, char *dest, size_t sz); extern CoreExport void Unhex(const string &src, char *dest, size_t sz);
/** Base 64 encode a string /** Base 64 encode a string
* @param src The string to encode * @param src The string to encode
* @param target Where the encoded string is placed * @param target Where the encoded string is placed
*/ */
extern CoreExport void B64Encode(const string &src, string &target); extern CoreExport void B64Encode(const string &src, string &target);
/** Base 64 decode a string /** Base 64 decode a string
* @param src The base64 encoded string * @param src The base64 encoded string
* @param target The plain text result * @param target The plain text result
@@ -461,13 +471,12 @@ namespace Anope
*/ */
extern CoreExport void Encrypt(const Anope::string &src, Anope::string &dest); extern CoreExport void Encrypt(const Anope::string &src, Anope::string &dest);
/** Decrypts what is in 'src' to 'dest'. /** Hashes a buffer with SipHash-2-4
* @param src The source string to decrypt * @param src The start of the buffer to hash
* @param dest The destination where the decrypted string is placed * @param src_sz The total number of bytes in the buffer
* @return true if decryption was successful. This is usually not the case * @param key A 16 byte key to hash the buffer with.
* as most encryption methods we use are one way.
*/ */
extern CoreExport bool Decrypt(const Anope::string &src, Anope::string &dest); extern CoreExport uint64_t SipHash24(const void *src, unsigned long src_sz, const char key[16]);
/** Returns a sequence of data formatted as the format argument specifies. /** Returns a sequence of data formatted as the format argument specifies.
** After the format parameter, the function expects at least as many ** After the format parameter, the function expects at least as many
@@ -476,7 +485,7 @@ namespace Anope
* @param ... any number of parameters * @param ... any number of parameters
* @return a Anope::string * @return a Anope::string
*/ */
extern CoreExport string printf(const char *fmt, ...); extern CoreExport string printf(const char *fmt, ...) ATTR_FORMAT(1, 2);
/** Return the last error code /** Return the last error code
* @return The error code * @return The error code
@@ -537,36 +546,43 @@ namespace Anope
*/ */
extern Anope::string Resolve(const Anope::string &host, int type); extern Anope::string Resolve(const Anope::string &host, int type);
/** Does a blocking dns query and returns all IPs.
* @param host host to look up
* @param type inet addr type
* @return A list of all IPs that the host resolves to
*/
extern std::vector<Anope::string> ResolveMultiple(const Anope::string &host, int type);
/** Generate a string of random letters and numbers /** Generate a string of random letters and numbers
* @param len The length of the string returned * @param len The length of the string returned
*/ */
extern CoreExport Anope::string Random(size_t len); extern CoreExport Anope::string Random(size_t len);
} }
/** sepstream allows for splitting token seperated lists. /** sepstream allows for splitting token separated lists.
* Each successive call to sepstream::GetToken() returns * Each successive call to sepstream::GetToken() returns
* the next token, until none remain, at which point the method returns * the next token, until none remain, at which point the method returns
* an empty string. * an empty string.
*/ */
class CoreExport sepstream class CoreExport sepstream
{ {
private: private:
/** Original string. /** Original string.
*/ */
Anope::string tokens; Anope::string tokens;
/** Seperator value /** Separator value
*/ */
char sep; char sep;
/** Current string position /** Current string position
*/ */
size_t pos; size_t pos = 0;
/** If set then GetToken() can return an empty string /** If set then GetToken() can return an empty string
*/ */
bool allow_empty; bool allow_empty;
public: public:
/** Create a sepstream and fill it with the provided data /** Create a sepstream and fill it with the provided data
*/ */
sepstream(const Anope::string &source, char seperator, bool allowempty = false); sepstream(const Anope::string &source, char separator, bool allowempty = false);
/** Fetch the next token from the stream /** Fetch the next token from the stream
* @param token The next token from the stream is placed here * @param token The next token from the stream is placed here
@@ -576,7 +592,7 @@ class CoreExport sepstream
/** Gets token number 'num' from the stream /** Gets token number 'num' from the stream
* @param token The token is placed here * @param token The token is placed here
* @param num The token number to featch * @param num The token number to fetch
* @return True if the token was able to be fetched * @return True if the token was able to be fetched
*/ */
bool GetToken(Anope::string &token, int num); bool GetToken(Anope::string &token, int num);
@@ -594,7 +610,7 @@ class CoreExport sepstream
/** Gets token number 'num' from the stream and all remaining tokens. /** Gets token number 'num' from the stream and all remaining tokens.
* @param token The token is placed here * @param token The token is placed here
* @param num The token number to featch * @param num The token number to fetch
* @return True if the token was able to be fetched * @return True if the token was able to be fetched
*/ */
bool GetTokenRemainder(Anope::string &token, int num); bool GetTokenRemainder(Anope::string &token, int num);
@@ -615,22 +631,24 @@ class CoreExport sepstream
bool StreamEnd(); bool StreamEnd();
}; };
/** A derived form of sepstream, which seperates on commas /** A derived form of sepstream, which separates on commas
*/ */
class commasepstream : public sepstream class commasepstream final
: public sepstream
{ {
public: public:
/** Initialize with comma seperator /** Initialize with comma separator
*/ */
commasepstream(const Anope::string &source, bool allowempty = false) : sepstream(source, ',', allowempty) { } commasepstream(const Anope::string &source, bool allowempty = false) : sepstream(source, ',', allowempty) { }
}; };
/** A derived form of sepstream, which seperates on spaces /** A derived form of sepstream, which separates on spaces
*/ */
class spacesepstream : public sepstream class spacesepstream final
: public sepstream
{ {
public: public:
/** Initialize with space seperator /** Initialize with space separator
*/ */
spacesepstream(const Anope::string &source) : sepstream(source, ' ') { } spacesepstream(const Anope::string &source) : sepstream(source, ' ') { }
}; };
@@ -641,17 +659,18 @@ class spacesepstream : public sepstream
* be loaded. If this happens, the error message returned by ModuleException::GetReason will be displayed to the user * be loaded. If this happens, the error message returned by ModuleException::GetReason will be displayed to the user
* attempting to load the module, or dumped to the console if the ircd is currently loading for the first time. * attempting to load the module, or dumped to the console if the ircd is currently loading for the first time.
*/ */
class CoreException : public std::exception class CoreExport CoreException
: public std::exception
{ {
protected: protected:
/** Holds the error message to be displayed /** Holds the error message to be displayed
*/ */
Anope::string err; Anope::string err;
/** Source of the exception /** Source of the exception
*/ */
Anope::string source; Anope::string source;
public: public:
/** Default constructor, just uses the error mesage 'Core threw an exception'. /** Default constructor, just uses the error message 'Core threw an exception'.
*/ */
CoreException() : err("Core threw an exception"), source("The core") { } CoreException() : err("Core threw an exception"), source("The core") { }
/** This constructor can be used to specify an error message before throwing. /** This constructor can be used to specify an error message before throwing.
@@ -665,7 +684,7 @@ class CoreException : public std::exception
* Actually no, it does nothing. Never mind. * Actually no, it does nothing. Never mind.
* @throws Nothing! * @throws Nothing!
*/ */
virtual ~CoreException() throw() { } virtual ~CoreException() noexcept = default;
/** Returns the reason for the exception. /** Returns the reason for the exception.
* The module should probably put something informative here as the user will see this upon failure. * The module should probably put something informative here as the user will see this upon failure.
*/ */
@@ -680,10 +699,11 @@ class CoreException : public std::exception
} }
}; };
class ModuleException : public CoreException class CoreExport ModuleException
: public CoreException
{ {
public: public:
/** Default constructor, just uses the error mesage 'Module threw an exception'. /** Default constructor, just uses the error message 'Module threw an exception'.
*/ */
ModuleException() : CoreException("Module threw an exception", "A Module") { } ModuleException() : CoreException("Module threw an exception", "A Module") { }
@@ -694,15 +714,16 @@ class ModuleException : public CoreException
* Actually no, it does nothing. Never mind. * Actually no, it does nothing. Never mind.
* @throws Nothing! * @throws Nothing!
*/ */
virtual ~ModuleException() throw() { } virtual ~ModuleException() noexcept = default;
}; };
class ConvertException : public CoreException class CoreExport ConvertException final
: public CoreException
{ {
public: public:
ConvertException(const Anope::string &reason = "") : CoreException(reason) { } ConvertException(const Anope::string &reason = "") : CoreException(reason) { }
virtual ~ConvertException() throw() { } virtual ~ConvertException() noexcept = default;
}; };
/** Convert something to a string /** Convert something to a string
@@ -758,7 +779,7 @@ template<typename T> inline T convertTo(const Anope::string &s, bool failIfLefto
} }
/** Casts to be used instead of dynamic_cast, this uses dynamic_cast /** Casts to be used instead of dynamic_cast, this uses dynamic_cast
* for debug builds and static_cast on releass builds * for debug builds and static_cast on release builds
* to speed up the program because dynamic_cast relies on RTTI. * to speed up the program because dynamic_cast relies on RTTI.
*/ */
#ifdef DEBUG_BUILD #ifdef DEBUG_BUILD
@@ -776,5 +797,3 @@ template<typename T, typename O> inline T anope_dynamic_static_cast(O ptr)
return static_cast<T>(ptr); return static_cast<T>(ptr);
} }
#endif #endif
#endif // ANOPE_H
+16 -23
View File
@@ -1,14 +1,12 @@
/* /*
* *
* Copyright (C) 2008-2011 Adam <Adam@anope.org> * (C) 2008-2011 Adam <Adam@anope.org>
* Copyright (C) 2008-2014 Anope Team <team@anope.org> * (C) 2008-2024 Anope Team <team@anope.org>
* *
* Please read COPYING and README for further details. * Please read COPYING and README for further details.
*
*/ */
#ifndef BASE_H #pragma once
#define BASE_H
#include "services.h" #include "services.h"
@@ -17,9 +15,8 @@
class CoreExport Base class CoreExport Base
{ {
/* References to this base class */ /* References to this base class */
std::set<ReferenceBase *> *references; std::set<ReferenceBase *> *references = nullptr;
public: public:
Base();
virtual ~Base(); virtual ~Base();
/** Adds a reference to this object. Eg, when a Reference /** Adds a reference to this object. Eg, when a Reference
@@ -33,12 +30,12 @@ class CoreExport Base
class ReferenceBase class ReferenceBase
{ {
protected: protected:
bool invalid; bool invalid = false;
public: public:
ReferenceBase() : invalid(false) { } ReferenceBase() = default;
ReferenceBase(const ReferenceBase &other) : invalid(other.invalid) { } ReferenceBase(const ReferenceBase &other) : invalid(other.invalid) { }
virtual ~ReferenceBase() { } virtual ~ReferenceBase() = default;
inline void Invalidate() { this->invalid = true; } inline void Invalidate() { this->invalid = true; }
}; };
@@ -46,14 +43,13 @@ class ReferenceBase
* no longer be valid once the object it refers is destructed. * no longer be valid once the object it refers is destructed.
*/ */
template<typename T> template<typename T>
class Reference : public ReferenceBase class Reference
: public ReferenceBase
{ {
protected: protected:
T *ref; T *ref = nullptr;
public: public:
Reference() : ref(NULL) Reference() = default;
{
}
Reference(T *obj) : ref(obj) Reference(T *obj) : ref(obj)
{ {
@@ -140,6 +136,3 @@ class Reference : public ReferenceBase
return false; return false;
} }
}; };
#endif // BASE_H
+7 -9
View File
@@ -1,14 +1,12 @@
/* /*
* *
* Copyright (C) 2008-2011 Robin Burchell <w00t@inspircd.org> * (C) 2008-2011 Robin Burchell <w00t@inspircd.org>
* Copyright (C) 2008-2014 Anope Team <team@anope.org> * (C) 2008-2024 Anope Team <team@anope.org>
* *
* Please read COPYING and README for further details. * Please read COPYING and README for further details.
*
*/ */
#ifndef BOTS_H #pragma once
#define BOTS_H
#include "users.h" #include "users.h"
#include "anope.h" #include "anope.h"
@@ -21,11 +19,13 @@ typedef Anope::map<BotInfo *> botinfo_map;
extern CoreExport Serialize::Checker<botinfo_map> BotListByNick, BotListByUID; extern CoreExport Serialize::Checker<botinfo_map> BotListByNick, BotListByUID;
/* A service bot (NickServ, ChanServ, a BotServ bot, etc). */ /* A service bot (NickServ, ChanServ, a BotServ bot, etc). */
class CoreExport BotInfo : public User, public Serializable class CoreExport BotInfo final
: public User
, public Serializable
{ {
/* Channels this bot is assigned to */ /* Channels this bot is assigned to */
Serialize::Checker<std::set<ChannelInfo *> > channels; Serialize::Checker<std::set<ChannelInfo *> > channels;
public: public:
time_t created; time_t created;
/* Last time this bot said something (via privmsg) */ /* Last time this bot said something (via privmsg) */
time_t lastmsg; time_t lastmsg;
@@ -132,5 +132,3 @@ class CoreExport BotInfo : public User, public Serializable
*/ */
static BotInfo* Find(const Anope::string &nick, bool nick_only = false); static BotInfo* Find(const Anope::string &nick, bool nick_only = false);
}; };
#endif // BOTS_H
+32 -20
View File
@@ -1,14 +1,12 @@
/* Channel support /* Channel support
* *
* (C) 2008-2014 Anope Team * (C) 2008-2024 Anope Team
* Contact us at team@anope.org * Contact us at team@anope.org
* *
* Please read COPYING and README for further details. * Please read COPYING and README for further details.
*
*/ */
#ifndef CHANNELS_H #pragma once
#define CHANNELS_H
#include "anope.h" #include "anope.h"
#include "extensible.h" #include "extensible.h"
@@ -20,7 +18,8 @@ typedef Anope::hash_map<Channel *> channel_map;
extern CoreExport channel_map ChannelList; extern CoreExport channel_map ChannelList;
/* A user container, there is one of these per user per channel. */ /* A user container, there is one of these per user per channel. */
struct ChanUserContainer : public Extensible struct ChanUserContainer final
: public Extensible
{ {
User *user; User *user;
Channel *chan; Channel *chan;
@@ -30,17 +29,21 @@ struct ChanUserContainer : public Extensible
ChanUserContainer(User *u, Channel *c) : user(u), chan(c) { } ChanUserContainer(User *u, Channel *c) : user(u), chan(c) { }
}; };
class CoreExport Channel : public Base, public Extensible class CoreExport Channel final
: public Base
, public Extensible
{ {
public: static std::vector<Channel *> deleting;
public:
typedef std::multimap<Anope::string, Anope::string> ModeList; typedef std::multimap<Anope::string, Anope::string> ModeList;
private: private:
/** A map of channel modes with their parameters set on this channel /** A map of channel modes with their parameters set on this channel
*/ */
ModeList modes; ModeList modes;
public: public:
/* Channel name */ /* Channel name */
Anope::string name; Anope::string name;
/* Set if this channel is registered. ci->c == this. Contains information relevant to the registered channel */ /* Set if this channel is registered. ci->c == this. Contains information relevant to the registered channel */
Serialize::Reference<ChannelInfo> ci; Serialize::Reference<ChannelInfo> ci;
@@ -59,7 +62,7 @@ class CoreExport Channel : public Base, public Extensible
Anope::string topic; Anope::string topic;
/* Who set the topic */ /* Who set the topic */
Anope::string topic_setter; Anope::string topic_setter;
/* The timestamp associated with the topic. Not necessarually anywhere close to Anope::CurTime. /* The timestamp associated with the topic. Not necessarily anywhere close to Anope::CurTime.
* This is the time the topic was *originally set*. When we restore the topic we want to change the TS back * This is the time the topic was *originally set*. When we restore the topic we want to change the TS back
* to this, but we can only do this on certain IRCds. * to this, but we can only do this on certain IRCds.
*/ */
@@ -73,14 +76,14 @@ class CoreExport Channel : public Base, public Extensible
int16_t chanserv_modecount; /* Number of check_mode()'s this sec */ int16_t chanserv_modecount; /* Number of check_mode()'s this sec */
int16_t bouncy_modes; /* Did we fail to set modes here? */ int16_t bouncy_modes; /* Did we fail to set modes here? */
private: private:
/** Constructor /** Constructor
* @param name The channel name * @param name The channel name
* @param ts The time the channel was created * @param ts The time the channel was created
*/ */
Channel(const Anope::string &nname, time_t ts = Anope::CurTime); Channel(const Anope::string &nname, time_t ts = Anope::CurTime);
public: public:
/** Destructor /** Destructor
*/ */
~Channel(); ~Channel();
@@ -138,7 +141,7 @@ class CoreExport Channel : public Base, public Extensible
/** See if a channel has a mode /** See if a channel has a mode
* @param name The mode name * @param name The mode name
* @return The number of modes set * @return The number of modes set
* @param param The optional mode param * @param param The optional mode param
*/ */
size_t HasMode(const Anope::string &name, const Anope::string &param = ""); size_t HasMode(const Anope::string &name, const Anope::string &param = "");
@@ -204,7 +207,8 @@ class CoreExport Channel : public Base, public Extensible
* @param enforce_mlock Should mlock be enforced on this mode change * @param enforce_mlock Should mlock be enforced on this mode change
* @param cmodes The modes to set * @param cmodes The modes to set
*/ */
void SetModes(BotInfo *bi, bool enforce_mlock, const char *cmodes, ...); void SetModes(BotInfo *bi, bool enforce_mlock, const char *cmodes, ...) ATTR_FORMAT(4, 5);
void SetModes(BotInfo *bi, bool enforce_mlock, const Anope::string &cmodes);
/** Set a string of modes internally on a channel /** Set a string of modes internally on a channel
* @param source The setter * @param source The setter
@@ -231,9 +235,10 @@ class CoreExport Channel : public Base, public Extensible
* @param bi The sender, can be NULL for the service bot for this channel * @param bi The sender, can be NULL for the service bot for this channel
* @param u The user being kicked * @param u The user being kicked
* @param reason The reason for the kick * @param reason The reason for the kick
* @return true if the kick was scucessful, false if a module blocked the kick * @return true if the kick was successful, false if a module blocked the kick
*/ */
bool Kick(BotInfo *bi, User *u, const char *reason = NULL, ...); bool Kick(BotInfo *bi, User *u, const char *reason = NULL, ...) ATTR_FORMAT(4, 5);
bool Kick(BotInfo *bi, User *u, const Anope::string &reason);
/** Get all modes set on this channel, excluding status modes. /** Get all modes set on this channel, excluding status modes.
* @return a map of modes and their optional parameters. * @return a map of modes and their optional parameters.
@@ -248,7 +253,7 @@ class CoreExport Channel : public Base, public Extensible
/** Get a string of the modes set on this channel /** Get a string of the modes set on this channel
* @param complete Include mode parameters * @param complete Include mode parameters
* @param plus If set to false (with complete), mode parameters will not be given for modes requring no parameters to be unset * @param plus If set to false (with complete), mode parameters will not be given for modes requiring no parameters to be unset
* @return A mode string * @return A mode string
*/ */
Anope::string GetModes(bool complete, bool plus); Anope::string GetModes(bool complete, bool plus);
@@ -288,6 +293,11 @@ class CoreExport Channel : public Base, public Extensible
*/ */
bool CheckKick(User *user); bool CheckKick(User *user);
/** Find which bot should send mode/topic/etc changes for this channel
* @return The bot
*/
BotInfo *WhoSends() const;
/** Finds a channel /** Finds a channel
* @param name The channel to find * @param name The channel to find
* @return The channel, if found * @return The channel, if found
@@ -300,6 +310,8 @@ class CoreExport Channel : public Base, public Extensible
* @param ts The time the channel was created * @param ts The time the channel was created
*/ */
static Channel *FindOrCreate(const Anope::string &name, bool &created, time_t ts = Anope::CurTime); static Channel *FindOrCreate(const Anope::string &name, bool &created, time_t ts = Anope::CurTime);
};
#endif // CHANNELS_H void QueueForDeletion();
static void DeleteChannels();
};
+26 -28
View File
@@ -1,6 +1,6 @@
/* Declarations for command data. /* Declarations for command data.
* *
* (C) 2003-2014 Anope Team * (C) 2003-2024 Anope Team
* Contact us at team@anope.org * Contact us at team@anope.org
* *
* Please read COPYING and README for further details. * Please read COPYING and README for further details.
@@ -9,25 +9,22 @@
* Based on the original code of Services by Andy Church. * Based on the original code of Services by Andy Church.
*/ */
#ifndef COMMAND_H #pragma once
#define COMMAND_H
#include "service.h" #include "service.h"
#include "anope.h" #include "anope.h"
#include "channels.h" #include "channels.h"
struct CommandGroup struct CommandGroup final
{ {
Anope::string name, description; Anope::string name, description;
}; };
/* Used in BotInfo::commands */ /* Used in BotInfo::commands */
struct CommandInfo struct CommandInfo final
{ {
typedef Anope::map<CommandInfo> map; typedef Anope::map<CommandInfo> map;
CommandInfo() : hide(false), prepend_channel(false) { }
/* Service name of the command */ /* Service name of the command */
Anope::string name; Anope::string name;
/* Permission required to execute the command */ /* Permission required to execute the command */
@@ -35,30 +32,32 @@ struct CommandInfo
/* Group this command is in */ /* Group this command is in */
Anope::string group; Anope::string group;
/* whether or not to hide this command in help output */ /* whether or not to hide this command in help output */
bool hide; bool hide = false;
/* Only used with fantasy */ /* Only used with fantasy */
bool prepend_channel; bool prepend_channel = false;
}; };
/* Where the replies from commands go to. User inheits from this and is the normal /* Where the replies from commands go to. User inherits from this and is the normal
* source of a CommandReply * source of a CommandReply
*/ */
struct CoreExport CommandReply struct CoreExport CommandReply
{ {
virtual ~CommandReply() { } virtual ~CommandReply() = default;
virtual void SendMessage(BotInfo *source, const Anope::string &msg) = 0; virtual void SendMessage(BotInfo *source, const Anope::string &msg) = 0;
}; };
/* The source for a command */ /* The source for a command */
class CoreExport CommandSource class CoreExport CommandSource final
{ {
/* The nick executing the command */ /* The nick executing the command */
Anope::string nick; Anope::string nick;
/* User executing the command, may be NULL */ /* User executing the command, may be NULL */
Reference<User> u; Reference<User> u;
public: public:
/* The account executing the command */ /* The account executing the command */
Reference<NickCore> nc; Reference<NickCore> nc;
/* for web clients */
Anope::string ip;
/* Where the reply should go */ /* Where the reply should go */
CommandReply *reply; CommandReply *reply;
/* Channel the command was executed on (fantasy) */ /* Channel the command was executed on (fantasy) */
@@ -78,7 +77,7 @@ class CoreExport CommandSource
AccessGroup AccessFor(ChannelInfo *ci); AccessGroup AccessFor(ChannelInfo *ci);
bool IsFounder(ChannelInfo *ci); bool IsFounder(ChannelInfo *ci);
void Reply(const char *message, ...); void Reply(const char *message, ...) ATTR_FORMAT(2, 3);
void Reply(const Anope::string &message); void Reply(const Anope::string &message);
bool HasCommand(const Anope::string &cmd); bool HasCommand(const Anope::string &cmd);
@@ -89,7 +88,8 @@ class CoreExport CommandSource
/** Every services command is a class, inheriting from Command. /** Every services command is a class, inheriting from Command.
*/ */
class CoreExport Command : public Service class CoreExport Command
: public Service
{ {
Anope::string desc; Anope::string desc;
std::vector<Anope::string> syntax; std::vector<Anope::string> syntax;
@@ -98,8 +98,8 @@ class CoreExport Command : public Service
/* Command requires that a user is executing it */ /* Command requires that a user is executing it */
bool require_user; bool require_user;
public: public:
/* Maximum paramaters accepted by this command */ /* Maximum parameters accepted by this command */
size_t max_params; size_t max_params;
/* Minimum parameters required to use this command */ /* Minimum parameters required to use this command */
size_t min_params; size_t min_params;
@@ -107,7 +107,7 @@ class CoreExport Command : public Service
/* Module which owns us */ /* Module which owns us */
Module *module; Module *module;
protected: protected:
/** Create a new command. /** Create a new command.
* @param owner The owner of the command * @param owner The owner of the command
* @param sname The command name * @param sname The command name
@@ -117,10 +117,10 @@ class CoreExport Command : public Service
*/ */
Command(Module *owner, const Anope::string &sname, size_t min_params, size_t max_params = 0); Command(Module *owner, const Anope::string &sname, size_t min_params, size_t max_params = 0);
public: public:
virtual ~Command(); virtual ~Command() = default;
protected: protected:
void SetDesc(const Anope::string &d); void SetDesc(const Anope::string &d);
void ClearSyntax(); void ClearSyntax();
@@ -130,15 +130,15 @@ class CoreExport Command : public Service
void AllowUnregistered(bool b); void AllowUnregistered(bool b);
void RequireUser(bool b); void RequireUser(bool b);
public: public:
bool AllowUnregistered() const; bool AllowUnregistered() const;
bool RequireUser() const; bool RequireUser() const;
/** Get the command description /** Get the command description
* @param source The source wanting the command description * @param source The source wanting the command description
* @return The commands description * @return The commands description
*/ */
virtual const Anope::string GetDesc(CommandSource &source) const; virtual const Anope::string GetDesc(CommandSource &source) const;
/** Execute this command. /** Execute this command.
* @param source The source * @param source The source
@@ -146,7 +146,7 @@ class CoreExport Command : public Service
*/ */
virtual void Execute(CommandSource &source, const std::vector<Anope::string> &params) = 0; virtual void Execute(CommandSource &source, const std::vector<Anope::string> &params) = 0;
/** Called when HELP is requsted for the client this command is on. /** Called when HELP is requested for the client this command is on.
* @param source The source * @param source The source
*/ */
virtual void OnServHelp(CommandSource &source); virtual void OnServHelp(CommandSource &source);
@@ -176,10 +176,8 @@ class CoreExport Command : public Service
* Note that if the same command exists multiple places this will return the first one encountered * Note that if the same command exists multiple places this will return the first one encountered
* @param command_service The command service to lookup, eg, nickserv/register * @param command_service The command service to lookup, eg, nickserv/register
* @param bot If found, is set to the bot the command is on, eg NickServ * @param bot If found, is set to the bot the command is on, eg NickServ
* @param name If found, is set to the comand name, eg REGISTER * @param name If found, is set to the command name, eg REGISTER
* @return true if the given command service exists * @return true if the given command service exists
*/ */
static bool FindCommandFromService(const Anope::string &command_service, BotInfo* &bi, Anope::string &name); static bool FindCommandFromService(const Anope::string &command_service, BotInfo* &bi, Anope::string &name);
}; };
#endif // COMMANDS_H
+38 -29
View File
@@ -1,17 +1,15 @@
/* /*
* *
* (C) 2003-2014 Anope Team * (C) 2003-2024 Anope Team
* Contact us at team@anope.org * Contact us at team@anope.org
* *
* Please read COPYING and README for further details. * Please read COPYING and README for further details.
* *
* Based on the original code of Epona by Lara. * Based on the original code of Epona by Lara.
* Based on the original code of Services by Andy Church. * Based on the original code of Services by Andy Church.
*
*/ */
#ifndef CONFIG_H #pragma once
#define CONFIG_H
#include "account.h" #include "account.h"
#include "regchannel.h" #include "regchannel.h"
@@ -21,27 +19,33 @@
namespace Configuration namespace Configuration
{ {
namespace Internal
{
class CoreExport Block class CoreExport Block
{ {
friend struct Conf; friend struct Configuration::Conf;
public: public:
typedef Anope::map<Anope::string> item_map; typedef Anope::map<Anope::string> item_map;
typedef Anope::multimap<Block> block_map; typedef Anope::multimap<Block> block_map;
private: private:
Anope::string name; Anope::string name;
item_map items; item_map items;
block_map blocks; block_map blocks;
int linenum; int linenum;
public: /* Represents a missing tag. */
Block(const Anope::string &); static Block EmptyBlock;
const Anope::string &GetName() const;
int CountBlock(const Anope::string &name);
Block* GetBlock(const Anope::string &name, int num = 0);
template<typename T> inline T Get(const Anope::string &tag) public:
Block(const Anope::string &);
const Anope::string &GetName() const;
int CountBlock(const Anope::string &name) const;
const Block* GetBlock(const Anope::string &name, int num = 0) const;
Block* GetMutableBlock(const Anope::string &name, int num = 0);
template<typename T> inline T Get(const Anope::string &tag) const
{ {
return this->Get<T>(tag, ""); return this->Get<T>(tag, "");
} }
@@ -61,24 +65,29 @@ namespace Configuration
} }
bool Set(const Anope::string &tag, const Anope::string &value); bool Set(const Anope::string &tag, const Anope::string &value);
const item_map* GetItems() const; const item_map &GetItems() const;
}; };
template<> CoreExport const Anope::string Block::Get(const Anope::string &tag, const Anope::string& def) const; template<> CoreExport const Anope::string Block::Get(const Anope::string &tag, const Anope::string& def) const;
template<> CoreExport time_t Block::Get(const Anope::string &tag, const Anope::string &def) const; template<> CoreExport time_t Block::Get(const Anope::string &tag, const Anope::string &def) const;
template<> CoreExport bool Block::Get(const Anope::string &tag, const Anope::string &def) const; template<> CoreExport bool Block::Get(const Anope::string &tag, const Anope::string &def) const;
} // namespace Internal
typedef const Internal::Block Block;
typedef Internal::Block MutableBlock;
/** Represents a configuration file /** Represents a configuration file
*/ */
class File class File final
{ {
Anope::string name; Anope::string name;
bool executable; bool executable;
FILE *fp; FILE *fp = nullptr;
public: public:
File(const Anope::string &, bool); File(const Anope::string &, bool);
~File(); ~File();
const Anope::string &GetName() const; const Anope::string &GetName() const;
Anope::string GetPath() const;
bool IsOpen() const; bool IsOpen() const;
bool Open(); bool Open();
@@ -89,7 +98,8 @@ namespace Configuration
struct Uplink; struct Uplink;
struct CoreExport Conf : Block struct CoreExport Conf final
: Block
{ {
/* options:readtimeout */ /* options:readtimeout */
time_t ReadTimeout; time_t ReadTimeout;
@@ -140,18 +150,18 @@ namespace Configuration
BotInfo *GetClient(const Anope::string &name); BotInfo *GetClient(const Anope::string &name);
Block *GetCommand(CommandSource &); const Block *GetCommand(CommandSource &);
}; };
struct Uplink struct Uplink final
{ {
Anope::string host; Anope::string host;
unsigned port; unsigned port;
Anope::string password; Anope::string password;
bool ipv6; int protocol;
Uplink(const Anope::string &_host, int _port, const Anope::string &_password, bool _ipv6) : host(_host), port(_port), password(_password), ipv6(_ipv6) { } Uplink(const Anope::string &_host, int _port, const Anope::string &_password, int _protocol) : host(_host), port(_port), password(_password), protocol(_protocol) { }
inline bool operator==(const Uplink &other) const { return host == other.host && port == other.port && password == other.password && ipv6 == other.ipv6; } inline bool operator==(const Uplink &other) const { return host == other.host && port == other.port && password == other.password && protocol == other.protocol; }
inline bool operator!=(const Uplink &other) const { return !(*this == other); } inline bool operator!=(const Uplink &other) const { return !(*this == other); }
}; };
} }
@@ -162,10 +172,11 @@ namespace Configuration
* be loaded. If this happens, the error message returned by ModuleException::GetReason will be displayed to the user * be loaded. If this happens, the error message returned by ModuleException::GetReason will be displayed to the user
* attempting to load the module, or dumped to the console if the ircd is currently loading for the first time. * attempting to load the module, or dumped to the console if the ircd is currently loading for the first time.
*/ */
class ConfigException : public CoreException class CoreExport ConfigException final
: public CoreException
{ {
public: public:
/** Default constructor, just uses the error mesage 'Config threw an exception'. /** Default constructor, just uses the error message 'Config threw an exception'.
*/ */
ConfigException() : CoreException("Config threw an exception", "Config Parser") { } ConfigException() : CoreException("Config threw an exception", "Config Parser") { }
/** This constructor can be used to specify an error message before throwing. /** This constructor can be used to specify an error message before throwing.
@@ -175,10 +186,8 @@ class ConfigException : public CoreException
* Actually no, it does nothing. Never mind. * Actually no, it does nothing. Never mind.
* @throws Nothing! * @throws Nothing!
*/ */
virtual ~ConfigException() throw() { } virtual ~ConfigException() noexcept = default;
}; };
extern Configuration::File ServicesConf; extern Configuration::File ServicesConf;
extern CoreExport Configuration::Conf *Config; extern CoreExport Configuration::Conf *Config;
#endif // CONFIG_H
+2 -3
View File
@@ -1,15 +1,15 @@
/* /*
* *
* (C) 2003-2014 Anope Team * (C) 2003-2024 Anope Team
* Contact us at team@anope.org * Contact us at team@anope.org
* *
* Please read COPYING and README for further details. * Please read COPYING and README for further details.
* *
* Based on the original code of Epona by Lara. * Based on the original code of Epona by Lara.
* Based on the original code of Services by Andy Church. * Based on the original code of Services by Andy Church.
*
*/ */
#pragma once
class AccessGroup; class AccessGroup;
class AutoKick; class AutoKick;
@@ -53,4 +53,3 @@ struct MemoInfo;
struct ModeLock; struct ModeLock;
struct Oper; struct Oper;
namespace SASL { struct Message; } namespace SASL { struct Message; }
+39 -35
View File
@@ -1,14 +1,12 @@
/* /*
* *
* (C) 2003-2014 Anope Team * (C) 2003-2024 Anope Team
* Contact us at team@anope.org * Contact us at team@anope.org
* *
* Please read COPYING and README for further details. * Please read COPYING and README for further details.
*
*/ */
#ifndef EXTENSIBLE_H #pragma once
#define EXTENSIBLE_H
#include "anope.h" #include "anope.h"
#include "serialize.h" #include "serialize.h"
@@ -17,15 +15,16 @@
class Extensible; class Extensible;
class CoreExport ExtensibleBase : public Service class CoreExport ExtensibleBase
: public Service
{ {
protected: protected:
std::map<Extensible *, void *> items; std::map<Extensible *, void *> items;
ExtensibleBase(Module *m, const Anope::string &n); ExtensibleBase(Module *m, const Anope::string &n);
~ExtensibleBase(); ~ExtensibleBase();
public: public:
virtual void Unset(Extensible *obj) = 0; virtual void Unset(Extensible *obj) = 0;
/* called when an object we are keep track of is serializing */ /* called when an object we are keep track of is serializing */
@@ -35,11 +34,13 @@ class CoreExport ExtensibleBase : public Service
class CoreExport Extensible class CoreExport Extensible
{ {
public: public:
std::set<ExtensibleBase *> extension_items; std::set<ExtensibleBase *> extension_items;
virtual ~Extensible(); virtual ~Extensible();
void UnsetExtensibles();
template<typename T> T* GetExt(const Anope::string &name) const; template<typename T> T* GetExt(const Anope::string &name) const;
bool HasExt(const Anope::string &name) const; bool HasExt(const Anope::string &name) const;
@@ -53,12 +54,13 @@ class CoreExport Extensible
}; };
template<typename T> template<typename T>
class BaseExtensibleItem : public ExtensibleBase class BaseExtensibleItem
: public ExtensibleBase
{ {
protected: protected:
virtual T *Create(Extensible *) = 0; virtual T *Create(Extensible *) = 0;
public: public:
BaseExtensibleItem(Module *m, const Anope::string &n) : ExtensibleBase(m, n) { } BaseExtensibleItem(Module *m, const Anope::string &n) : ExtensibleBase(m, n) { }
~BaseExtensibleItem() ~BaseExtensibleItem()
@@ -92,7 +94,7 @@ class BaseExtensibleItem : public ExtensibleBase
return t; return t;
} }
void Unset(Extensible *obj) anope_override void Unset(Extensible *obj) override
{ {
T *value = Get(obj); T *value = Get(obj);
items.erase(obj); items.erase(obj);
@@ -124,54 +126,57 @@ class BaseExtensibleItem : public ExtensibleBase
}; };
template<typename T> template<typename T>
class ExtensibleItem : public BaseExtensibleItem<T> class ExtensibleItem
: public BaseExtensibleItem<T>
{ {
protected: protected:
T* Create(Extensible *obj) anope_override T* Create(Extensible *obj) override
{ {
return new T(obj); return new T(obj);
} }
public: public:
ExtensibleItem(Module *m, const Anope::string &n) : BaseExtensibleItem<T>(m, n) { } ExtensibleItem(Module *m, const Anope::string &n) : BaseExtensibleItem<T>(m, n) { }
}; };
template<typename T> template<typename T>
class PrimitiveExtensibleItem : public BaseExtensibleItem<T> class PrimitiveExtensibleItem
: public BaseExtensibleItem<T>
{ {
protected: protected:
T* Create(Extensible *obj) anope_override T* Create(Extensible *obj) override
{ {
return new T(); return new T();
} }
public: public:
PrimitiveExtensibleItem(Module *m, const Anope::string &n) : BaseExtensibleItem<T>(m, n) { } PrimitiveExtensibleItem(Module *m, const Anope::string &n) : BaseExtensibleItem<T>(m, n) { }
}; };
template<> template<>
class PrimitiveExtensibleItem<bool> : public BaseExtensibleItem<bool> class PrimitiveExtensibleItem<bool> : public BaseExtensibleItem<bool>
{ {
protected: protected:
bool* Create(Extensible *) anope_override bool* Create(Extensible *) override
{ {
return NULL; return NULL;
} }
public: public:
PrimitiveExtensibleItem(Module *m, const Anope::string &n) : BaseExtensibleItem<bool>(m, n) { } PrimitiveExtensibleItem(Module *m, const Anope::string &n) : BaseExtensibleItem<bool>(m, n) { }
}; };
template<typename T> template<typename T>
class SerializableExtensibleItem : public PrimitiveExtensibleItem<T> class SerializableExtensibleItem
: public PrimitiveExtensibleItem<T>
{ {
public: public:
SerializableExtensibleItem(Module *m, const Anope::string &n) : PrimitiveExtensibleItem<T>(m, n) { } SerializableExtensibleItem(Module *m, const Anope::string &n) : PrimitiveExtensibleItem<T>(m, n) { }
void ExtensibleSerialize(const Extensible *e, const Serializable *s, Serialize::Data &data) const anope_override void ExtensibleSerialize(const Extensible *e, const Serializable *s, Serialize::Data &data) const override
{ {
T* t = this->Get(e); T* t = this->Get(e);
data[this->name] << *t; data[this->name] << *t;
} }
void ExtensibleUnserialize(Extensible *e, Serializable *s, Serialize::Data &data) anope_override void ExtensibleUnserialize(Extensible *e, Serializable *s, Serialize::Data &data) override
{ {
T t; T t;
if (data[this->name] >> t) if (data[this->name] >> t)
@@ -184,15 +189,15 @@ class SerializableExtensibleItem : public PrimitiveExtensibleItem<T>
template<> template<>
class SerializableExtensibleItem<bool> : public PrimitiveExtensibleItem<bool> class SerializableExtensibleItem<bool> : public PrimitiveExtensibleItem<bool>
{ {
public: public:
SerializableExtensibleItem(Module *m, const Anope::string &n) : PrimitiveExtensibleItem<bool>(m, n) { } SerializableExtensibleItem(Module *m, const Anope::string &n) : PrimitiveExtensibleItem<bool>(m, n) { }
void ExtensibleSerialize(const Extensible *e, const Serializable *s, Serialize::Data &data) const anope_override void ExtensibleSerialize(const Extensible *e, const Serializable *s, Serialize::Data &data) const override
{ {
data[this->name] << true; data[this->name] << true;
} }
void ExtensibleUnserialize(Extensible *e, Serializable *s, Serialize::Data &data) anope_override void ExtensibleUnserialize(Extensible *e, Serializable *s, Serialize::Data &data) override
{ {
bool b = false; bool b = false;
data[this->name] >> b; data[this->name] >> b;
@@ -204,7 +209,8 @@ class SerializableExtensibleItem<bool> : public PrimitiveExtensibleItem<bool>
}; };
template<typename T> template<typename T>
struct ExtensibleRef : ServiceReference<BaseExtensibleItem<T> > struct ExtensibleRef final
: ServiceReference<BaseExtensibleItem<T> >
{ {
ExtensibleRef(const Anope::string &n) : ServiceReference<BaseExtensibleItem<T> >("Extensible", n) { } ExtensibleRef(const Anope::string &n) : ServiceReference<BaseExtensibleItem<T> >("Extensible", n) { }
}; };
@@ -258,5 +264,3 @@ void Extensible::Shrink(const Anope::string &name)
else else
Log(LOG_DEBUG) << "Shrink for nonexistent type " << name << " on " << static_cast<void *>(this); Log(LOG_DEBUG) << "Shrink for nonexistent type " << name << " on " << static_cast<void *>(this);
} }
#endif // EXTENSIBLE_H
+21 -29
View File
@@ -1,25 +1,16 @@
/* /*
* *
* Copyright (C) 2002-2011 InspIRCd Development Team * (C) 2002-2011 InspIRCd Development Team
* Copyright (C) 2009-2014 Anope Team <team@anope.org> * (C) 2009-2024 Anope Team <team@anope.org>
* *
* Please read COPYING and README for further details. * Please read COPYING and README for further details.
*
*/ */
#ifndef HASHCOMP_H #pragma once
#define HASHCOMP_H
#include <string> #include <string>
#include <locale> #include <locale>
#if defined _LIBCPP_VERSION || defined _WIN32
#include <unordered_map> #include <unordered_map>
#define TR1NS std
#else
#include <tr1/unordered_map>
#define TR1NS std::tr1
#endif
#include "services.h" #include "services.h"
@@ -27,19 +18,20 @@ namespace Anope
{ {
class string; class string;
/* Casemap in use by Anope. ci::string's comparation functions use this (and thus Anope::string) */ /* Casemap in use by Anope. ci::string's comparison functions use this (and thus Anope::string) */
extern std::locale casemap; extern std::locale casemap;
extern void CaseMapRebuild(); extern CoreExport void CaseMapRebuild();
extern unsigned char tolower(unsigned char); extern CoreExport unsigned char tolower(unsigned char);
extern unsigned char toupper(unsigned char); extern CoreExport unsigned char toupper(unsigned char);
/* ASCII case insensitive ctype. */ /* ASCII case insensitive ctype. */
template<typename char_type> template<typename char_type>
class ascii_ctype : public std::ctype<char_type> class ascii_ctype
: public std::ctype<char_type>
{ {
public: public:
char_type do_toupper(char_type c) const anope_override char_type do_toupper(char_type c) const override
{ {
if (c >= 'a' && c <= 'z') if (c >= 'a' && c <= 'z')
return c - 32; return c - 32;
@@ -47,7 +39,7 @@ namespace Anope
return c; return c;
} }
char_type do_tolower(char_type c) const anope_override char_type do_tolower(char_type c) const override
{ {
if (c >= 'A' && c <= 'Z') if (c >= 'A' && c <= 'Z')
return c + 32; return c + 32;
@@ -58,10 +50,11 @@ namespace Anope
/* rfc1459 case insensitive ctype, { = [, } = ], and | = \ */ /* rfc1459 case insensitive ctype, { = [, } = ], and | = \ */
template<typename char_type> template<typename char_type>
class rfc1459_ctype : public ascii_ctype<char_type> class rfc1459_ctype final
: public ascii_ctype<char_type>
{ {
public: public:
char_type do_toupper(char_type c) const anope_override char_type do_toupper(char_type c) const override
{ {
if (c == '{' || c == '}' || c == '|') if (c == '{' || c == '}' || c == '|')
return c - 32; return c - 32;
@@ -69,7 +62,7 @@ namespace Anope
return ascii_ctype<char_type>::do_toupper(c); return ascii_ctype<char_type>::do_toupper(c);
} }
char_type do_tolower(char_type c) const anope_override char_type do_tolower(char_type c) const override
{ {
if (c == '[' || c == ']' || c == '\\') if (c == '[' || c == ']' || c == '\\')
return c + 32; return c + 32;
@@ -87,7 +80,8 @@ namespace ci
* This class is used to implement ci::string, a case-insensitive, ASCII- * This class is used to implement ci::string, a case-insensitive, ASCII-
* comparing string class. * comparing string class.
*/ */
struct CoreExport ci_char_traits : std::char_traits<char> struct CoreExport ci_char_traits final
: std::char_traits<char>
{ {
/** Check if two chars match. /** Check if two chars match.
* @param c1st First character * @param c1st First character
@@ -123,7 +117,7 @@ namespace ci
* @param s1 String to find in * @param s1 String to find in
* @param n Position to search up to * @param n Position to search up to
* @param c Character to search for * @param c Character to search for
* @return Pointer to the first occurance of c in s1 * @return Pointer to the first occurrence of c in s1
*/ */
static const char *find(const char *s1, int n, char c); static const char *find(const char *s1, int n, char c);
}; };
@@ -132,7 +126,7 @@ namespace ci
*/ */
typedef std::basic_string<char, ci_char_traits, std::allocator<char> > string; typedef std::basic_string<char, ci_char_traits, std::allocator<char> > string;
struct CoreExport less struct CoreExport less final
{ {
/** Compare two Anope::strings as ci::strings and find which one is less /** Compare two Anope::strings as ci::strings and find which one is less
* @param s1 The first string * @param s1 The first string
@@ -196,5 +190,3 @@ inline bool operator!=(const std::string &leftval, const ci::string &rightval)
{ {
return !(leftval.c_str() == rightval); return !(leftval.c_str() == rightval);
} }
#endif // HASHCOMP_H
+14 -13
View File
@@ -1,18 +1,19 @@
/* /*
* *
* (C) 2008-2014 Anope Team * (C) 2008-2024 Anope Team
* Contact us at team@anope.org * Contact us at team@anope.org
* *
* Please read COPYING and README for further details. * Please read COPYING and README for further details.
*
*/ */
#pragma once
#include "anope.h" #include "anope.h"
namespace Language namespace Language
{ {
/* Languages we support as configured in services.conf. They are /* Languages we support as configured in anope.conf. They are
* added to this list if we detect a language exists in the correct * added to this list if we detect a language exists in the correct
* location for each language. * location for each language.
*/ */
@@ -24,7 +25,7 @@ namespace Language
* and we detect a language file exists for at least one of the supported * and we detect a language file exists for at least one of the supported
* languages for the module, then we add the module's domain (its name) * languages for the module, then we add the module's domain (its name)
* here. * here.
* *
* When strings are translated they are checked against all domains. * When strings are translated they are checked against all domains.
*/ */
extern std::vector<Anope::string> Domains; extern std::vector<Anope::string> Domains;
@@ -41,7 +42,7 @@ namespace Language
extern CoreExport const char *Translate(const char *string); extern CoreExport const char *Translate(const char *string);
/** Translates a string to the language of the given user. /** Translates a string to the language of the given user.
* @param u The user to transate the string for * @param u The user to translate the string for
* @param string A string to translate * @param string A string to translate
* @return The translated string if found, else the original string. * @return The translated string if found, else the original string.
*/ */
@@ -71,10 +72,11 @@ namespace Language
#define READ_ONLY_MODE _("Services are in read-only mode!") #define READ_ONLY_MODE _("Services are in read-only mode!")
#define PASSWORD_INCORRECT _("Password incorrect.") #define PASSWORD_INCORRECT _("Password incorrect.")
#define ACCESS_DENIED _("Access denied.") #define ACCESS_DENIED _("Access denied.")
#define MORE_OBSCURE_PASSWORD _("Please try again with a more obscure password. Passwords should be at least\n" \ #define MORE_OBSCURE_PASSWORD _("Please try again with a more obscure password. Passwords should not be\n" \
"five characters long, should not be something easily guessed\n" \ "something that could be easily guessed (e.g. your real name or your nick) and\n" \
"(e.g. your real name or your nick), and cannot contain the space or tab characters.") "cannot contain the space or tab characters.\n")
#define PASSWORD_TOO_LONG _("Your password is too long. It must not exceed %u characters.") #define PASSWORD_TOO_SHORT _("Your password is too short. It must be longer than %u characters.")
#define PASSWORD_TOO_LONG _("Your password is too long. It must be shorter than %u characters.")
#define NICK_NOT_REGISTERED _("Your nick isn't registered.") #define NICK_NOT_REGISTERED _("Your nick isn't registered.")
#define NICK_X_NOT_REGISTERED _("Nick \002%s\002 isn't registered.") #define NICK_X_NOT_REGISTERED _("Nick \002%s\002 isn't registered.")
#define NICK_X_NOT_IN_USE _("Nick \002%s\002 isn't currently in use.") #define NICK_X_NOT_IN_USE _("Nick \002%s\002 isn't currently in use.")
@@ -83,7 +85,7 @@ namespace Language
#define CHAN_X_SUSPENDED _("Channel %s is currently suspended.") #define CHAN_X_SUSPENDED _("Channel %s is currently suspended.")
#define CHAN_X_NOT_REGISTERED _("Channel \002%s\002 isn't registered.") #define CHAN_X_NOT_REGISTERED _("Channel \002%s\002 isn't registered.")
#define CHAN_X_NOT_IN_USE _("Channel \002%s\002 doesn't exist.") #define CHAN_X_NOT_IN_USE _("Channel \002%s\002 doesn't exist.")
#define NICK_IDENTIFY_REQUIRED _("Password authentication required for that command.") #define NICK_IDENTIFY_REQUIRED _("You must be logged into an account to use that command.")
#define MAIL_X_INVALID _("\002%s\002 is not a valid e-mail address.") #define MAIL_X_INVALID _("\002%s\002 is not a valid e-mail address.")
#define UNKNOWN _("<unknown>") #define UNKNOWN _("<unknown>")
#define NO_EXPIRE _("does not expire") #define NO_EXPIRE _("does not expire")
@@ -109,9 +111,9 @@ namespace Language
#define CHAN_INFO_HEADER _("Information for channel \002%s\002:") #define CHAN_INFO_HEADER _("Information for channel \002%s\002:")
#define CHAN_EXCEPTED _("\002%s\002 matches an except on %s and cannot be banned until the except has been removed.") #define CHAN_EXCEPTED _("\002%s\002 matches an except on %s and cannot be banned until the except has been removed.")
#define MEMO_NEW_X_MEMO_ARRIVED _("There is a new memo on channel %s.\n" \ #define MEMO_NEW_X_MEMO_ARRIVED _("There is a new memo on channel %s.\n" \
"Type \002%s%s READ %s %d\002 to read it.") "Type \002%s%s READ %s %zu\002 to read it.")
#define MEMO_NEW_MEMO_ARRIVED _("You have a new memo from %s.\n" \ #define MEMO_NEW_MEMO_ARRIVED _("You have a new memo from %s.\n" \
"Type \002%s%s READ %d\002 to read it.") "Type \002%s%s READ %zu\002 to read it.")
#define MEMO_HAVE_NO_MEMOS _("You have no memos.") #define MEMO_HAVE_NO_MEMOS _("You have no memos.")
#define MEMO_X_HAS_NO_MEMOS _("%s has no memos.") #define MEMO_X_HAS_NO_MEMOS _("%s has no memos.")
#define MEMO_SEND_DISABLED _("Sorry, memo sending is temporarily disabled.") #define MEMO_SEND_DISABLED _("Sorry, memo sending is temporarily disabled.")
@@ -126,4 +128,3 @@ namespace Language
#define HOST_SET_IDENTTOOLONG _("Error! The vHost ident is too long, please use an ident shorter than %d characters.") #define HOST_SET_IDENTTOOLONG _("Error! The vHost ident is too long, please use an ident shorter than %d characters.")
#define HOST_NOT_ASSIGNED _("Please contact an Operator to get a vHost assigned to this nick.") #define HOST_NOT_ASSIGNED _("Please contact an Operator to get a vHost assigned to this nick.")
#define HOST_NO_VIDENT _("Your IRCd does not support vIdent's, if this is incorrect, please report this as a possible bug") #define HOST_NO_VIDENT _("Your IRCd does not support vIdent's, if this is incorrect, please report this as a possible bug")
+15 -20
View File
@@ -1,17 +1,15 @@
/* /*
* *
* (C) 2003-2014 Anope Team * (C) 2003-2024 Anope Team
* Contact us at team@anope.org * Contact us at team@anope.org
* *
* Please read COPYING and README for further details. * Please read COPYING and README for further details.
* *
* Based on the original code of Epona by Lara. * Based on the original code of Epona by Lara.
* Based on the original code of Services by Andy Church. * Based on the original code of Services by Andy Church.
*
*/ */
#ifndef LISTS_H #pragma once
#define LISTS_H
#include "services.h" #include "services.h"
#include "anope.h" #include "anope.h"
@@ -25,13 +23,13 @@
*/ */
class CoreExport NumberList class CoreExport NumberList
{ {
private: private:
bool is_valid; bool is_valid = true;
std::set<unsigned> numbers; std::set<unsigned> numbers;
bool desc; bool desc;
public: public:
/** Processes a numbered list /** Processes a numbered list
* @param list The list * @param list The list
* @param descending True to make HandleNumber get called with numbers in descending order * @param descending True to make HandleNumber get called with numbers in descending order
@@ -40,7 +38,7 @@ class CoreExport NumberList
/** Destructor, does nothing /** Destructor, does nothing
*/ */
virtual ~NumberList(); virtual ~NumberList() = default;
/** Should be called after the constructors are done running. This calls the callbacks. /** Should be called after the constructors are done running. This calls the callbacks.
*/ */
@@ -52,7 +50,7 @@ class CoreExport NumberList
virtual void HandleNumber(unsigned number); virtual void HandleNumber(unsigned number);
/** Called when there is an error with the numbered list /** Called when there is an error with the numbered list
* Return false to immediatly stop processing the list and return * Return false to immediately stop processing the list and return
* This is all done before we start calling HandleNumber, so no numbers will have been processed yet * This is all done before we start calling HandleNumber, so no numbers will have been processed yet
* @param list The list * @param list The list
* @return false to stop processing * @return false to stop processing
@@ -62,15 +60,15 @@ class CoreExport NumberList
/** This class handles formatting LIST/VIEW replies. /** This class handles formatting LIST/VIEW replies.
*/ */
class CoreExport ListFormatter class CoreExport ListFormatter final
{ {
public: public:
typedef std::map<Anope::string, Anope::string> ListEntry; typedef std::map<Anope::string, Anope::string> ListEntry;
private: private:
NickCore *nc; NickCore *nc;
std::vector<Anope::string> columns; std::vector<Anope::string> columns;
std::vector<ListEntry> entries; std::vector<ListEntry> entries;
public: public:
ListFormatter(NickCore *nc); ListFormatter(NickCore *nc);
ListFormatter &AddColumn(const Anope::string &name); ListFormatter &AddColumn(const Anope::string &name);
void AddEntry(const ListEntry &entry); void AddEntry(const ListEntry &entry);
@@ -80,17 +78,14 @@ class CoreExport ListFormatter
/** This class handles formatting INFO replies /** This class handles formatting INFO replies
*/ */
class CoreExport InfoFormatter class CoreExport InfoFormatter final
{ {
NickCore *nc; NickCore *nc;
std::vector<std::pair<Anope::string, Anope::string> > replies; std::vector<std::pair<Anope::string, Anope::string> > replies;
unsigned longest; unsigned longest = 0;
public: public:
InfoFormatter(NickCore *nc); InfoFormatter(NickCore *nc);
void Process(std::vector<Anope::string> &); void Process(std::vector<Anope::string> &);
Anope::string &operator[](const Anope::string &key); Anope::string &operator[](const Anope::string &key);
void AddOption(const Anope::string &opt); void AddOption(const Anope::string &opt);
}; };
#endif // LISTS_H
+23 -28
View File
@@ -1,26 +1,24 @@
/* /*
* *
* (C) 2003-2014 Anope Team * (C) 2003-2024 Anope Team
* Contact us at team@anope.org * Contact us at team@anope.org
* *
* Please read COPYING and README for further details. * Please read COPYING and README for further details.
* *
* Based on the original code of Epona by Lara. * Based on the original code of Epona by Lara.
* Based on the original code of Services by Andy Church. * Based on the original code of Services by Andy Church.
*
*/ */
#ifndef LOGGER_H #pragma once
#define LOGGER_H
#include "anope.h" #include "anope.h"
#include "defs.h" #include "defs.h"
enum LogType enum LogType
{ {
/* Used whenever an administrator uses an administrative comand */ /* Used whenever an administrator uses an administrative command */
LOG_ADMIN, LOG_ADMIN,
/* Used whenever an administrator overides something, such as adding /* Used whenever an administrator overrides something, such as adding
* access to a channel where they don't have permission to. * access to a channel where they don't have permission to.
*/ */
LOG_OVERRIDE, LOG_OVERRIDE,
@@ -39,7 +37,7 @@ enum LogType
LOG_DEBUG_4 LOG_DEBUG_4
}; };
struct LogFile struct LogFile final
{ {
Anope::string filename; Anope::string filename;
std::ofstream stream; std::ofstream stream;
@@ -50,27 +48,27 @@ struct LogFile
}; };
/* Represents a single log message */ /* Represents a single log message */
class CoreExport Log class CoreExport Log final
{ {
public: public:
/* Bot that should log this message */ /* Bot that should log this message */
BotInfo *bi; BotInfo *bi = nullptr;
/* For commands, the user executing the command, but might not always exist */ /* For commands, the user executing the command, but might not always exist */
User *u; User *u = nullptr;
/* For commands, the account executing the command, but will not always exist */ /* For commands, the account executing the command, but will not always exist */
NickCore *nc; NickCore *nc = nullptr;
/* For commands, the command being executed */ /* For commands, the command being executed */
Command *c; Command *c = nullptr;
/* For commands, the command source */ /* For commands, the command source */
CommandSource *source; CommandSource *source = nullptr;
/* Used for LOG_CHANNEL */ /* Used for LOG_CHANNEL */
Channel *chan; Channel *chan = nullptr;
/* For commands, the channel the command was executed on, will not always exist */ /* For commands, the channel the command was executed on, will not always exist */
const ChannelInfo *ci; const ChannelInfo *ci = nullptr;
/* For LOG_SERVER */ /* For LOG_SERVER */
Server *s; Server *s = nullptr;
/* For LOG_MODULE */ /* For LOG_MODULE */
Module *m; Module *m = nullptr;
LogType type; LogType type;
Anope::string category; Anope::string category;
@@ -96,11 +94,11 @@ class CoreExport Log
~Log(); ~Log();
private: private:
Anope::string FormatSource() const; Anope::string FormatSource() const;
Anope::string FormatCommand() const; Anope::string FormatCommand() const;
public: public:
Anope::string BuildPrefix() const; Anope::string BuildPrefix() const;
template<typename T> Log &operator<<(T val) template<typename T> Log &operator<<(T val)
@@ -111,13 +109,13 @@ class CoreExport Log
}; };
/* Configured in the configuration file, actually does the message logging */ /* Configured in the configuration file, actually does the message logging */
class CoreExport LogInfo class CoreExport LogInfo final
{ {
public: public:
BotInfo *bot; BotInfo *bot = nullptr;
std::vector<Anope::string> targets; std::vector<Anope::string> targets;
std::vector<LogFile *> logfiles; std::vector<LogFile *> logfiles;
int last_day; int last_day = 0;
std::vector<Anope::string> sources; std::vector<Anope::string> sources;
int log_age; int log_age;
std::vector<Anope::string> admin; std::vector<Anope::string> admin;
@@ -141,6 +139,3 @@ class CoreExport LogInfo
/* Logs the message l if configured to */ /* Logs the message l if configured to */
void ProcessMessage(const Log *l); void ProcessMessage(const Log *l);
}; };
#endif // LOGGER_H
+11 -14
View File
@@ -1,18 +1,15 @@
/* /*
* *
* (C) 2003-2014 Anope Team * (C) 2003-2024 Anope Team
* Contact us at team@anope.org * Contact us at team@anope.org
* *
* Please read COPYING and README for further details. * Please read COPYING and README for further details.
* *
* Based on the original code of Epona by Lara. * Based on the original code of Epona by Lara.
* Based on the original code of Services by Andy Church. * Based on the original code of Services by Andy Church.
*
*
*/ */
#ifndef MAIL_H #pragma once
#define MAIL_H
#include "anope.h" #include "anope.h"
#include "threadengine.h" #include "threadengine.h"
@@ -25,20 +22,22 @@ namespace Mail
extern CoreExport bool Validate(const Anope::string &email); extern CoreExport bool Validate(const Anope::string &email);
/* A email message being sent */ /* A email message being sent */
class Message : public Thread class Message final
: public Thread
{ {
private: private:
Anope::string sendmail_path; Anope::string sendmail_path;
Anope::string send_from; Anope::string send_from;
Anope::string mail_to; Anope::string mail_to;
Anope::string addr; Anope::string addr;
Anope::string subject; Anope::string subject;
Anope::string message; Anope::string message;
Anope::string content_type;
bool dont_quote_addresses; bool dont_quote_addresses;
bool success; bool success = false;
public: public:
/** Construct this message. Once constructed call Thread::Start to launch the mail sending. /** Construct this message. Once constructed call Thread::Start to launch the mail sending.
* @param sf Config->SendFrom * @param sf Config->SendFrom
* @param mailto Name of person being mailed (u->nick, nc->display, etc) * @param mailto Name of person being mailed (u->nick, nc->display, etc)
* @param addr Destination address to mail * @param addr Destination address to mail
@@ -50,9 +49,7 @@ namespace Mail
~Message(); ~Message();
/* Called from within the thread to actually send the mail */ /* Called from within the thread to actually send the mail */
void Run() anope_override; void Run() override;
}; };
} // namespace Mail } // namespace Mail
#endif // MAIL_H
+11 -13
View File
@@ -1,30 +1,30 @@
/* /*
* *
* (C) 2003-2014 Anope Team * (C) 2003-2024 Anope Team
* Contact us at team@anope.org * Contact us at team@anope.org
* *
* Please read COPYING and README for further details. * Please read COPYING and README for further details.
* *
* Based on the original code of Epona by Lara. * Based on the original code of Epona by Lara.
* Based on the original code of Services by Andy Church. * Based on the original code of Services by Andy Church.
*
*/ */
#ifndef MEMO_H #pragma once
#define MEMO_H
#include "anope.h" #include "anope.h"
#include "serialize.h" #include "serialize.h"
class CoreExport Memo : public Serializable class CoreExport Memo final
: public Serializable
{ {
public: public:
bool unread; MemoInfo *mi;
bool unread;
bool receipt; bool receipt;
Memo(); Memo();
~Memo(); ~Memo();
void Serialize(Serialize::Data &data) const anope_override; void Serialize(Serialize::Data &data) const override;
static Serializable* Unserialize(Serializable *obj, Serialize::Data &); static Serializable* Unserialize(Serializable *obj, Serialize::Data &);
Anope::string owner; Anope::string owner;
@@ -37,9 +37,9 @@ class CoreExport Memo : public Serializable
/* Memo info structures. Since both nicknames and channels can have memos, /* Memo info structures. Since both nicknames and channels can have memos,
* we encapsulate memo data in a MemoInfo to make it easier to handle. * we encapsulate memo data in a MemoInfo to make it easier to handle.
*/ */
struct CoreExport MemoInfo struct CoreExport MemoInfo final
{ {
int16_t memomax; int16_t memomax = 0;
Serialize::Checker<std::vector<Memo *> > memos; Serialize::Checker<std::vector<Memo *> > memos;
std::vector<Anope::string> ignores; std::vector<Anope::string> ignores;
@@ -51,5 +51,3 @@ struct CoreExport MemoInfo
static MemoInfo *GetMemoInfo(const Anope::string &targ, bool &is_chan); static MemoInfo *GetMemoInfo(const Anope::string &targ, bool &is_chan);
}; };
#endif // MEMO_H
+104 -84
View File
@@ -1,15 +1,16 @@
/* /*
* *
* (C) 2003-2014 Anope Team * (C) 2003-2024 Anope Team
* Contact us at team@anope.org * Contact us at team@anope.org
* *
* Please read COPYING and README for further details. * Please read COPYING and README for further details.
* *
* Based on the original code of Epona by Lara. * Based on the original code of Epona by Lara.
* Based on the original code of Services by Andy Church. * Based on the original code of Services by Andy Church.
*
*/ */
#pragma once
#include "protocol.h" #include "protocol.h"
/* Common IRCD messages. /* Common IRCD messages.
@@ -20,42 +21,47 @@
namespace Message namespace Message
{ {
struct CoreExport Away : IRCDMessage struct CoreExport Away
: IRCDMessage
{ {
Away(Module *creator, const Anope::string &mname = "AWAY") : IRCDMessage(creator, mname, 0) { SetFlag(IRCDMESSAGE_REQUIRE_USER); SetFlag(IRCDMESSAGE_SOFT_LIMIT); } Away(Module *creator, const Anope::string &mname = "AWAY") : IRCDMessage(creator, mname, 0) { SetFlag(IRCDMESSAGE_REQUIRE_USER); SetFlag(IRCDMESSAGE_SOFT_LIMIT); }
void Run(MessageSource &source, const std::vector<Anope::string> &params) anope_override; void Run(MessageSource &source, const std::vector<Anope::string> &params, const Anope::map<Anope::string> &tags) override;
}; };
struct CoreExport Capab : IRCDMessage struct CoreExport Capab
: IRCDMessage
{ {
Capab(Module *creator, const Anope::string &mname = "CAPAB") : IRCDMessage(creator, mname, 1) { SetFlag(IRCDMESSAGE_SOFT_LIMIT); } Capab(Module *creator, const Anope::string &mname = "CAPAB") : IRCDMessage(creator, mname, 1) { SetFlag(IRCDMESSAGE_SOFT_LIMIT); }
void Run(MessageSource &source, const std::vector<Anope::string> &params) anope_override; void Run(MessageSource &source, const std::vector<Anope::string> &params, const Anope::map<Anope::string> &tags) override;
};
struct CoreExport Error : IRCDMessage
{
Error(Module *creator, const Anope::string &mname = "ERROR") : IRCDMessage(creator, mname, 1) { }
void Run(MessageSource &source, const std::vector<Anope::string> &params) anope_override;
}; };
struct CoreExport Invite : IRCDMessage struct CoreExport Error
: IRCDMessage
{
Error(Module *creator, const Anope::string &mname = "ERROR") : IRCDMessage(creator, mname, 1) { }
void Run(MessageSource &source, const std::vector<Anope::string> &params, const Anope::map<Anope::string> &tags) override;
};
struct CoreExport Invite
: IRCDMessage
{ {
Invite(Module *creator, const Anope::string &mname = "INVITE") : IRCDMessage(creator, mname, 2) { SetFlag(IRCDMESSAGE_REQUIRE_USER); SetFlag(IRCDMESSAGE_SOFT_LIMIT); } Invite(Module *creator, const Anope::string &mname = "INVITE") : IRCDMessage(creator, mname, 2) { SetFlag(IRCDMESSAGE_REQUIRE_USER); SetFlag(IRCDMESSAGE_SOFT_LIMIT); }
void Run(MessageSource &source, const std::vector<Anope::string> &params) anope_override; void Run(MessageSource &source, const std::vector<Anope::string> &params, const Anope::map<Anope::string> &tags) override;
}; };
struct CoreExport Join : IRCDMessage struct CoreExport Join
: IRCDMessage
{ {
Join(Module *creator, const Anope::string &mname = "JOIN") : IRCDMessage(creator, mname, 1) { SetFlag(IRCDMESSAGE_REQUIRE_USER); SetFlag(IRCDMESSAGE_SOFT_LIMIT); } Join(Module *creator, const Anope::string &mname = "JOIN") : IRCDMessage(creator, mname, 1) { SetFlag(IRCDMESSAGE_REQUIRE_USER); SetFlag(IRCDMESSAGE_SOFT_LIMIT); }
void Run(MessageSource &source, const std::vector<Anope::string> &params) anope_override; void Run(MessageSource &source, const std::vector<Anope::string> &params, const Anope::map<Anope::string> &tags) override;
typedef std::pair<ChannelStatus, User *> SJoinUser; typedef std::pair<ChannelStatus, User *> SJoinUser;
/** Handle a SJOIN. /** Handle a SJOIN.
* @param source The source of the SJOIN * @param source The source of the SJOIN
* @param chan The channel the users are joining to * @param chan The channel the users are joining to
@@ -65,111 +71,125 @@ namespace Message
*/ */
static void SJoin(MessageSource &source, const Anope::string &chan, time_t ts, const Anope::string &modes, const std::list<SJoinUser> &users); static void SJoin(MessageSource &source, const Anope::string &chan, time_t ts, const Anope::string &modes, const std::list<SJoinUser> &users);
}; };
struct CoreExport Kick : IRCDMessage struct CoreExport Kick
: IRCDMessage
{ {
Kick(Module *creator, const Anope::string &mname = "KICK") : IRCDMessage(creator, mname, 2) { SetFlag(IRCDMESSAGE_SOFT_LIMIT); } Kick(Module *creator, const Anope::string &mname = "KICK") : IRCDMessage(creator, mname, 2) { SetFlag(IRCDMESSAGE_SOFT_LIMIT); }
void Run(MessageSource &source, const std::vector<Anope::string> &params) anope_override; void Run(MessageSource &source, const std::vector<Anope::string> &params, const Anope::map<Anope::string> &tags) override;
};
struct CoreExport Kill : IRCDMessage
{
Kill(Module *creator, const Anope::string &mname = "KILL") : IRCDMessage(creator, mname, 2) { }
void Run(MessageSource &source, const std::vector<Anope::string> &params) anope_override;
}; };
struct CoreExport Mode : IRCDMessage struct CoreExport Kill
: IRCDMessage
{
Kill(Module *creator, const Anope::string &mname = "KILL") : IRCDMessage(creator, mname, 2) { }
void Run(MessageSource &source, const std::vector<Anope::string> &params, const Anope::map<Anope::string> &tags) override;
};
struct CoreExport Mode
: IRCDMessage
{ {
Mode(Module *creator, const Anope::string &mname = "MODE") : IRCDMessage(creator, mname, 2) { SetFlag(IRCDMESSAGE_SOFT_LIMIT); } Mode(Module *creator, const Anope::string &mname = "MODE") : IRCDMessage(creator, mname, 2) { SetFlag(IRCDMESSAGE_SOFT_LIMIT); }
void Run(MessageSource &source, const std::vector<Anope::string> &params) anope_override; void Run(MessageSource &source, const std::vector<Anope::string> &params, const Anope::map<Anope::string> &tags) override;
}; };
struct CoreExport MOTD : IRCDMessage struct CoreExport MOTD
: IRCDMessage
{ {
MOTD(Module *creator, const Anope::string &mname = "MOTD") : IRCDMessage(creator, mname, 1) { } MOTD(Module *creator, const Anope::string &mname = "MOTD") : IRCDMessage(creator, mname, 1) { }
void Run(MessageSource &source, const std::vector<Anope::string> &params) anope_override; void Run(MessageSource &source, const std::vector<Anope::string> &params, const Anope::map<Anope::string> &tags) override;
}; };
struct CoreExport Notice : IRCDMessage struct CoreExport Notice
: IRCDMessage
{ {
Notice(Module *creator, const Anope::string &mname = "NOTICE") : IRCDMessage(creator, mname, 2) { SetFlag(IRCDMESSAGE_REQUIRE_USER); } Notice(Module *creator, const Anope::string &mname = "NOTICE") : IRCDMessage(creator, mname, 2) { SetFlag(IRCDMESSAGE_REQUIRE_USER); }
void Run(MessageSource &source, const std::vector<Anope::string> &params) anope_override; void Run(MessageSource &source, const std::vector<Anope::string> &params, const Anope::map<Anope::string> &tags) override;
}; };
struct CoreExport Part : IRCDMessage struct CoreExport Part
: IRCDMessage
{ {
Part(Module *creator, const Anope::string &mname = "PART") : IRCDMessage(creator, mname, 1) { SetFlag(IRCDMESSAGE_REQUIRE_USER); SetFlag(IRCDMESSAGE_SOFT_LIMIT); } Part(Module *creator, const Anope::string &mname = "PART") : IRCDMessage(creator, mname, 1) { SetFlag(IRCDMESSAGE_REQUIRE_USER); SetFlag(IRCDMESSAGE_SOFT_LIMIT); }
void Run(MessageSource &source, const std::vector<Anope::string> &params) anope_override; void Run(MessageSource &source, const std::vector<Anope::string> &params, const Anope::map<Anope::string> &tags) override;
}; };
struct CoreExport Ping : IRCDMessage struct CoreExport Ping
: IRCDMessage
{ {
Ping(Module *creator, const Anope::string &mname = "PING") : IRCDMessage(creator, mname, 1) { SetFlag(IRCDMESSAGE_SOFT_LIMIT); } Ping(Module *creator, const Anope::string &mname = "PING") : IRCDMessage(creator, mname, 1) { SetFlag(IRCDMESSAGE_SOFT_LIMIT); }
void Run(MessageSource &source, const std::vector<Anope::string> &params) anope_override; void Run(MessageSource &source, const std::vector<Anope::string> &params, const Anope::map<Anope::string> &tags) override;
}; };
struct CoreExport Privmsg : IRCDMessage struct CoreExport Privmsg
: IRCDMessage
{ {
Privmsg(Module *creator, const Anope::string &mname = "PRIVMSG") : IRCDMessage(creator, mname, 2) { SetFlag(IRCDMESSAGE_REQUIRE_USER); } Privmsg(Module *creator, const Anope::string &mname = "PRIVMSG") : IRCDMessage(creator, mname, 2) { SetFlag(IRCDMESSAGE_REQUIRE_USER); }
void Run(MessageSource &source, const std::vector<Anope::string> &params) anope_override; void Run(MessageSource &source, const std::vector<Anope::string> &params, const Anope::map<Anope::string> &tags) override;
}; };
struct CoreExport Quit : IRCDMessage struct CoreExport Quit
: IRCDMessage
{ {
Quit(Module *creator, const Anope::string &mname = "QUIT") : IRCDMessage(creator, mname, 1) { SetFlag(IRCDMESSAGE_REQUIRE_USER); } Quit(Module *creator, const Anope::string &mname = "QUIT") : IRCDMessage(creator, mname, 1) { SetFlag(IRCDMESSAGE_REQUIRE_USER); }
void Run(MessageSource &source, const std::vector<Anope::string> &params) anope_override; void Run(MessageSource &source, const std::vector<Anope::string> &params, const Anope::map<Anope::string> &tags) override;
}; };
struct CoreExport SQuit : IRCDMessage struct CoreExport SQuit
: IRCDMessage
{ {
SQuit(Module *creator, const Anope::string &mname = "SQUIT") : IRCDMessage(creator, mname, 2) { } SQuit(Module *creator, const Anope::string &mname = "SQUIT") : IRCDMessage(creator, mname, 2) { }
void Run(MessageSource &source, const std::vector<Anope::string> &params) anope_override; void Run(MessageSource &source, const std::vector<Anope::string> &params, const Anope::map<Anope::string> &tags) override;
}; };
struct CoreExport Stats : IRCDMessage struct CoreExport Stats
: IRCDMessage
{ {
Stats(Module *creator, const Anope::string &mname = "STATS") : IRCDMessage(creator, mname, 1) { SetFlag(IRCDMESSAGE_REQUIRE_USER); SetFlag(IRCDMESSAGE_SOFT_LIMIT); } Stats(Module *creator, const Anope::string &mname = "STATS") : IRCDMessage(creator, mname, 1) { SetFlag(IRCDMESSAGE_REQUIRE_USER); SetFlag(IRCDMESSAGE_SOFT_LIMIT); }
void Run(MessageSource &source, const std::vector<Anope::string> &params) anope_override; void Run(MessageSource &source, const std::vector<Anope::string> &params, const Anope::map<Anope::string> &tags) override;
}; };
struct CoreExport Time : IRCDMessage struct CoreExport Time
: IRCDMessage
{ {
Time(Module *creator, const Anope::string &mname = "TIME") : IRCDMessage(creator, mname, 0) { SetFlag(IRCDMESSAGE_SOFT_LIMIT); } Time(Module *creator, const Anope::string &mname = "TIME") : IRCDMessage(creator, mname, 0) { SetFlag(IRCDMESSAGE_SOFT_LIMIT); }
void Run(MessageSource &source, const std::vector<Anope::string> &params) anope_override; void Run(MessageSource &source, const std::vector<Anope::string> &params, const Anope::map<Anope::string> &tags) override;
}; };
struct CoreExport Topic : IRCDMessage struct CoreExport Topic
: IRCDMessage
{ {
Topic(Module *creator, const Anope::string &mname = "TOPIC") : IRCDMessage(creator, mname, 2) { SetFlag(IRCDMESSAGE_REQUIRE_USER); } Topic(Module *creator, const Anope::string &mname = "TOPIC") : IRCDMessage(creator, mname, 2) { SetFlag(IRCDMESSAGE_REQUIRE_USER); }
void Run(MessageSource &source, const std::vector<Anope::string> &params) anope_override; void Run(MessageSource &source, const std::vector<Anope::string> &params, const Anope::map<Anope::string> &tags) override;
}; };
struct CoreExport Version : IRCDMessage struct CoreExport Version
: IRCDMessage
{ {
Version(Module *creator, const Anope::string &mname = "VERSION") : IRCDMessage(creator, mname, 0) { SetFlag(IRCDMESSAGE_SOFT_LIMIT); } Version(Module *creator, const Anope::string &mname = "VERSION") : IRCDMessage(creator, mname, 0) { SetFlag(IRCDMESSAGE_SOFT_LIMIT); }
void Run(MessageSource &source, const std::vector<Anope::string> &params) anope_override; void Run(MessageSource &source, const std::vector<Anope::string> &params, const Anope::map<Anope::string> &tags) override;
}; };
struct CoreExport Whois : IRCDMessage struct CoreExport Whois
: IRCDMessage
{ {
Whois(Module *creator, const Anope::string &mname = "WHOIS") : IRCDMessage(creator, mname, 1) { SetFlag(IRCDMESSAGE_SOFT_LIMIT); } Whois(Module *creator, const Anope::string &mname = "WHOIS") : IRCDMessage(creator, mname, 1) { SetFlag(IRCDMESSAGE_SOFT_LIMIT); }
void Run(MessageSource &source, const std::vector<Anope::string> &params) anope_override; void Run(MessageSource &source, const std::vector<Anope::string> &params, const Anope::map<Anope::string> &tags) override;
}; };
} // namespace Message } // namespace Message
+73 -62
View File
@@ -1,13 +1,12 @@
/* Mode support /* Mode support
* *
* Copyright (C) 2008-2011 Adam <Adam@anope.org> * (C) 2008-2011 Adam <Adam@anope.org>
* Copyright (C) 2008-2014 Anope Team <team@anope.org> * (C) 2008-2024 Anope Team <team@anope.org>
* *
* Please read COPYING and README for further details. * Please read COPYING and README for further details.
*/ */
#ifndef MODES_H #pragma once
#define MODES_H
#include "anope.h" #include "anope.h"
#include "base.h" #include "base.h"
@@ -36,11 +35,12 @@ enum ModeClass
/** This class is the basis of all modes in Anope /** This class is the basis of all modes in Anope
*/ */
class CoreExport Mode : public Base class CoreExport Mode
: public Base
{ {
public: public:
/* Mode name */ /* Mode name */
Anope::string name; Anope::string name;
/* Class of mode this is (user/channel) */ /* Class of mode this is (user/channel) */
ModeClass mclass; ModeClass mclass;
/* Mode char for this, eg 'b' */ /* Mode char for this, eg 'b' */
@@ -55,7 +55,7 @@ class CoreExport Mode : public Base
* @param type The mode type * @param type The mode type
*/ */
Mode(const Anope::string &mname, ModeClass mclass, char mc, ModeType type); Mode(const Anope::string &mname, ModeClass mclass, char mc, ModeType type);
virtual ~Mode(); virtual ~Mode() = default;
/** Can a user set this mode, used for mlock /** Can a user set this mode, used for mlock
* @param u The user * @param u The user
@@ -65,9 +65,10 @@ class CoreExport Mode : public Base
/** This class is a user mode, all user modes use this/inherit from this /** This class is a user mode, all user modes use this/inherit from this
*/ */
class CoreExport UserMode : public Mode class CoreExport UserMode
: public Mode
{ {
public: public:
/** constructor /** constructor
* @param name The mode name * @param name The mode name
* @param mc The mode char * @param mc The mode char
@@ -75,10 +76,11 @@ class CoreExport UserMode : public Mode
UserMode(const Anope::string &name, char mc); UserMode(const Anope::string &name, char mc);
}; };
class CoreExport UserModeParam : public UserMode class CoreExport UserModeParam
: public UserMode
{ {
public: public:
/** constructor /** constructor
* @param name The mode name * @param name The mode name
* @param mc The mode char * @param mc The mode char
*/ */
@@ -93,10 +95,11 @@ class CoreExport UserModeParam : public UserMode
/** This class is a channel mode, all channel modes use this/inherit from this /** This class is a channel mode, all channel modes use this/inherit from this
*/ */
class CoreExport ChannelMode : public Mode class CoreExport ChannelMode
: public Mode
{ {
public: public:
/* channel modes that can posssibly unwrap this mode */ /* channel modes that can possibly unwrap this mode */
std::vector<ChannelMode *> listeners; std::vector<ChannelMode *> listeners;
/** constructor /** constructor
@@ -105,7 +108,7 @@ class CoreExport ChannelMode : public Mode
*/ */
ChannelMode(const Anope::string &name, char mc); ChannelMode(const Anope::string &name, char mc);
bool CanSet(User *u) const anope_override; bool CanSet(User *u) const override;
virtual void Check() { } virtual void Check() { }
@@ -124,9 +127,10 @@ class CoreExport ChannelMode : public Mode
/** This is a mode for lists, eg b/e/I. These modes should inherit from this /** This is a mode for lists, eg b/e/I. These modes should inherit from this
*/ */
class CoreExport ChannelModeList : public ChannelMode class CoreExport ChannelModeList
: public ChannelMode
{ {
public: public:
/** constructor /** constructor
* @param name The mode name * @param name The mode name
* @param mc The mode char * @param mc The mode char
@@ -160,11 +164,12 @@ class CoreExport ChannelModeList : public ChannelMode
virtual void OnDel(Channel *chan, const Anope::string &mask) { } virtual void OnDel(Channel *chan, const Anope::string &mask) { }
}; };
/** This is a mode with a paramater, eg +k/l. These modes should use/inherit from this /** This is a mode with a parameter, eg +k/l. These modes should use/inherit from this
*/ */
class CoreExport ChannelModeParam : public ChannelMode class CoreExport ChannelModeParam
: public ChannelMode
{ {
public: public:
/** constructor /** constructor
* @param name The mode name * @param name The mode name
* @param mc The mode char * @param mc The mode char
@@ -184,54 +189,56 @@ class CoreExport ChannelModeParam : public ChannelMode
/** This is a mode that is a channel status, eg +v/h/o/a/q. /** This is a mode that is a channel status, eg +v/h/o/a/q.
*/ */
class CoreExport ChannelModeStatus : public ChannelMode class CoreExport ChannelModeStatus
: public ChannelMode
{ {
public: public:
/* The symbol, eg @ % + */ /* The symbol, eg @ % + */
char symbol; char symbol;
/* The "level" of the mode, used to compare with other modes. /* The "level" of the mode, used to compare with other modes.
* Used so we know op > halfop > voice etc. * Used so we know op > halfop > voice etc.
*/ */
short level; unsigned level;
/** constructor /** constructor
* @param name The mode name * @param name The mode name
* @param mc The mode char * @param mc The mode char
* @param msymbol The symbol for the mode, eg @ % * @param msymbol The symbol for the mode, eg @ %
* @param mlevel A level for the mode, which is usually determined by the PREFIX capab * @param mlevel A level for the mode, which is usually determined by the PREFIX capab
*/ */
ChannelModeStatus(const Anope::string &name, char mc, char msymbol, short mlevel); ChannelModeStatus(const Anope::string &name, char mc, char msymbol, unsigned mlevel);
}; };
/** A virtual mode. This mode doesn't natively exist on the IRCd (like extbans), /** A virtual mode. This mode doesn't natively exist on the IRCd (like extbans),
* but we still have a representation for it. * but we still have a representation for it.
*/ */
template<typename T> template<typename T>
class CoreExport ChannelModeVirtual : public T class CoreExport ChannelModeVirtual
: public T
{ {
Anope::string base; Anope::string base;
ChannelMode *basech; ChannelMode *basech;
public: public:
ChannelModeVirtual(const Anope::string &mname, const Anope::string &basename); ChannelModeVirtual(const Anope::string &mname, const Anope::string &basename);
~ChannelModeVirtual(); ~ChannelModeVirtual();
void Check() anope_override; void Check() override;
ChannelMode *Wrap(Anope::string &param) anope_override; ChannelMode *Wrap(Anope::string &param) override;
ChannelMode *Unwrap(ChannelMode *cm, Anope::string &param) = 0; ChannelMode *Unwrap(ChannelMode *cm, Anope::string &param) override = 0;
}; };
/* The status a user has on a channel (+v, +h, +o) etc */ /* The status a user has on a channel (+v, +h, +o) etc */
class CoreExport ChannelStatus class CoreExport ChannelStatus final
{ {
Anope::string modes; Anope::string modes;
public: public:
ChannelStatus(); ChannelStatus() = default;
ChannelStatus(const Anope::string &modes); ChannelStatus(const Anope::string &modes);
void AddMode(char c); void AddMode(char c);
void DelMode(char c); void DelMode(char c);
bool HasMode(char c) const; bool HasMode(char c) const;
bool Empty() const; bool Empty() const;
@@ -240,51 +247,56 @@ class CoreExport ChannelStatus
Anope::string BuildModePrefixList() const; Anope::string BuildModePrefixList() const;
}; };
class CoreExport UserModeOperOnly : public UserMode class CoreExport UserModeOperOnly
: public UserMode
{ {
public: public:
UserModeOperOnly(const Anope::string &mname, char um) : UserMode(mname, um) { } UserModeOperOnly(const Anope::string &mname, char um) : UserMode(mname, um) { }
bool CanSet(User *u) const anope_override; bool CanSet(User *u) const override;
}; };
class CoreExport UserModeNoone : public UserMode class CoreExport UserModeNoone
: public UserMode
{ {
public: public:
UserModeNoone(const Anope::string &mname, char um) : UserMode(mname, um) { } UserModeNoone(const Anope::string &mname, char um) : UserMode(mname, um) { }
bool CanSet(User *u) const anope_override; bool CanSet(User *u) const override;
}; };
/** Channel mode +k (key) /** Channel mode +k (key)
*/ */
class CoreExport ChannelModeKey : public ChannelModeParam class CoreExport ChannelModeKey
: public ChannelModeParam
{ {
public: public:
ChannelModeKey(char mc) : ChannelModeParam("KEY", mc) { } ChannelModeKey(char mc) : ChannelModeParam("KEY", mc) { }
bool IsValid(Anope::string &value) const anope_override; bool IsValid(Anope::string &value) const override;
}; };
/** This class is used for oper only channel modes /** This class is used for oper only channel modes
*/ */
class CoreExport ChannelModeOperOnly : public ChannelMode class CoreExport ChannelModeOperOnly
: public ChannelMode
{ {
public: public:
ChannelModeOperOnly(const Anope::string &mname, char mc) : ChannelMode(mname, mc) { } ChannelModeOperOnly(const Anope::string &mname, char mc) : ChannelMode(mname, mc) { }
/* Opers only */ /* Opers only */
bool CanSet(User *u) const anope_override; bool CanSet(User *u) const override;
}; };
/** This class is used for channel modes only servers may set /** This class is used for channel modes only servers may set
*/ */
class CoreExport ChannelModeNoone : public ChannelMode class CoreExport ChannelModeNoone
: public ChannelMode
{ {
public: public:
ChannelModeNoone(const Anope::string &mname, char mc) : ChannelMode(mname, mc) { } ChannelModeNoone(const Anope::string &mname, char mc) : ChannelMode(mname, mc) { }
bool CanSet(User *u) const anope_override; bool CanSet(User *u) const override;
}; };
/** This is the mode manager /** This is the mode manager
@@ -293,9 +305,9 @@ class CoreExport ChannelModeNoone : public ChannelMode
* This also contains a mode stacker that will combine multiple modes and set * This also contains a mode stacker that will combine multiple modes and set
* them on a channel or user at once * them on a channel or user at once
*/ */
class CoreExport ModeManager class CoreExport ModeManager final
{ {
public: public:
/* Number of generic channel and user modes we are tracking */ /* Number of generic channel and user modes we are tracking */
static unsigned GenericChannelModes; static unsigned GenericChannelModes;
@@ -389,17 +401,18 @@ class CoreExport ModeManager
/** Represents a mask set on a channel (b/e/I) /** Represents a mask set on a channel (b/e/I)
*/ */
class CoreExport Entry class CoreExport Entry final
{ {
Anope::string name; Anope::string name;
Anope::string mask; Anope::string mask;
public: public:
unsigned short cidr_len; unsigned short cidr_len = 0;
int family = 0;
Anope::string nick, user, host, real; Anope::string nick, user, host, real;
/** Constructor /** Constructor
* @param mode What mode this host is for, can be empty for unknown/no mode * @param mode What mode this host is for, can be empty for unknown/no mode
* @param host A full or poartial nick!ident@host/cidr#real name mask * @param host A full or partial nick!ident@host/cidr#real name mask
*/ */
Entry(const Anope::string &mode, const Anope::string &host); Entry(const Anope::string &mode, const Anope::string &host);
@@ -417,5 +430,3 @@ class CoreExport Entry
*/ */
bool Matches(User *u, bool full = false) const; bool Matches(User *u, bool full = false) const;
}; };
#endif // MODES_H
+2 -5
View File
@@ -1,6 +1,6 @@
/* /*
* *
* (C) 2003-2014 Anope Team * (C) 2003-2024 Anope Team
* Contact us at team@anope.org * Contact us at team@anope.org
* *
* Please read COPYING and README for further details. * Please read COPYING and README for further details.
@@ -9,8 +9,7 @@
* Based on the original code of Services by Andy Church. * Based on the original code of Services by Andy Church.
*/ */
#ifndef MODULE_H #pragma once
#define MODULE_H
#include "access.h" #include "access.h"
#include "account.h" #include "account.h"
@@ -50,5 +49,3 @@
#include "modules/pseudoclients/global.h" #include "modules/pseudoclients/global.h"
#include "modules/pseudoclients/memoserv.h" #include "modules/pseudoclients/memoserv.h"
#include "modules/pseudoclients/nickserv.h" #include "modules/pseudoclients/nickserv.h"
#endif // MODULE_H
+48 -63
View File
@@ -1,20 +1,18 @@
/* Modular support /* Modular support
* *
* (C) 2003-2014 Anope Team * (C) 2003-2024 Anope Team
* Contact us at team@anope.org * Contact us at team@anope.org
* *
* Please read COPYING and README for further details. * Please read COPYING and README for further details.
* *
* Based on the original code of Epona by Lara. * Based on the original code of Epona by Lara.
* Based on the original code of Services by Andy Church. * Based on the original code of Services by Andy Church.
*
*/ */
#pragma once
#include "serialize.h" #include "serialize.h"
#ifndef MODULES_H
#define MODULES_H
#include "base.h" #include "base.h"
#include "modes.h" #include "modes.h"
#include "timers.h" #include "timers.h"
@@ -26,32 +24,7 @@
* and functions needed to make a module loadable by the OS. * and functions needed to make a module loadable by the OS.
* It defines the class factory and external AnopeInit and AnopeFini functions. * It defines the class factory and external AnopeInit and AnopeFini functions.
*/ */
#ifdef _WIN32 #define MODULE_INIT(x) \
# define MODULE_INIT(x) \
extern "C" DllExport Module *AnopeInit(const Anope::string &, const Anope::string &); \
extern "C" Module *AnopeInit(const Anope::string &modname, const Anope::string &creator) \
{ \
return new x(modname, creator); \
} \
BOOLEAN WINAPI DllMain(HINSTANCE, DWORD, LPVOID) \
{ \
return TRUE; \
} \
extern "C" DllExport void AnopeFini(x *); \
extern "C" void AnopeFini(x *m) \
{ \
delete m; \
} \
extern "C" DllExport ModuleVersionC AnopeVersion() \
{ \
ModuleVersionC ver; \
ver.version_major = VERSION_MAJOR; \
ver.version_minor = VERSION_MINOR; \
ver.version_patch = VERSION_PATCH; \
return ver; \
}
#else
# define MODULE_INIT(x) \
extern "C" DllExport Module *AnopeInit(const Anope::string &modname, const Anope::string &creator) \ extern "C" DllExport Module *AnopeInit(const Anope::string &modname, const Anope::string &creator) \
{ \ { \
return new x(modname, creator); \ return new x(modname, creator); \
@@ -68,12 +41,11 @@
ver.version_patch = VERSION_PATCH; \ ver.version_patch = VERSION_PATCH; \
return ver; \ return ver; \
} }
#endif
/** /**
* This #define allows us to call a method in all * This #define allows us to call a method in all
* loaded modules in a readable simple way, e.g.: * loaded modules in a readable simple way, e.g.:
* *
* FOREACH_MOD(OnUserConnect, (user, exempt)); * FOREACH_MOD(OnUserConnect, (user, exempt));
*/ */
#define FOREACH_MOD(ename, args) \ #define FOREACH_MOD(ename, args) \
@@ -105,7 +77,7 @@ else \
* This define is similar to the one above but returns a result. * This define is similar to the one above but returns a result.
* The first module to return a result other than EVENT_CONTINUE is the value to be accepted, * The first module to return a result other than EVENT_CONTINUE is the value to be accepted,
* and any modules after are ignored. This is used like: * and any modules after are ignored. This is used like:
* *
* EventReturn MOD_RESULT; * EventReturn MOD_RESULT;
* FOREACH_RESULT(OnUserConnect, MOD_RESULT, (user, exempt)); * FOREACH_RESULT(OnUserConnect, MOD_RESULT, (user, exempt));
*/ */
@@ -190,7 +162,7 @@ enum
}; };
typedef unsigned short ModType; typedef unsigned short ModType;
struct ModuleVersionC struct ModuleVersionC final
{ {
int version_major, version_minor, version_patch; int version_major, version_minor, version_patch;
}; };
@@ -198,14 +170,14 @@ struct ModuleVersionC
/** Returned by Module::GetVersion, used to see what version of Anope /** Returned by Module::GetVersion, used to see what version of Anope
* a module is compiled against. * a module is compiled against.
*/ */
class ModuleVersion class ModuleVersion final
{ {
private: private:
int version_major; int version_major;
int version_minor; int version_minor;
int version_patch; int version_patch;
public: public:
ModuleVersion(const ModuleVersionC &); ModuleVersion(const ModuleVersionC &);
/** Get the major version of Anope this was built against /** Get the major version of Anope this was built against
@@ -224,15 +196,19 @@ class ModuleVersion
int GetPatch() const; int GetPatch() const;
}; };
class NotImplementedException : public CoreException { }; class CoreExport NotImplementedException final
: public CoreException
{
};
/** Every module in Anope is actually a class. /** Every module in Anope is actually a class.
*/ */
class CoreExport Module : public Extensible class CoreExport Module
: public Extensible
{ {
private: private:
bool permanent; bool permanent;
public: public:
/** The module name (e.g. os_modload) /** The module name (e.g. os_modload)
*/ */
Anope::string name; Anope::string name;
@@ -302,6 +278,11 @@ class CoreExport Module : public Extensible
* before they will be called. * before they will be called.
*/ */
/** Called on startup after database load, but before
* connecting to the uplink.
*/
virtual void OnPostInit() { throw NotImplementedException(); }
/** Called before a user has been kicked from a channel. /** Called before a user has been kicked from a channel.
* @param source The kicker * @param source The kicker
* @param cu The user, channel, and status of the user being kicked * @param cu The user, channel, and status of the user being kicked
@@ -318,7 +299,7 @@ class CoreExport Module : public Extensible
*/ */
virtual void OnUserKicked(const MessageSource &source, User *target, const Anope::string &channel, ChannelStatus &status, const Anope::string &kickmsg) { throw NotImplementedException(); } virtual void OnUserKicked(const MessageSource &source, User *target, const Anope::string &channel, ChannelStatus &status, const Anope::string &kickmsg) { throw NotImplementedException(); }
/** Called when Services' configuration is being (re)loaded. /** Called when the configuration is being (re)loaded.
* @param conf The config that is being built now and will replace the global Config object * @param conf The config that is being built now and will replace the global Config object
* @throws A ConfigException to abort the config (re)loading process. * @throws A ConfigException to abort the config (re)loading process.
*/ */
@@ -398,10 +379,8 @@ class CoreExport Module : public Extensible
virtual EventReturn OnLoadDatabase() { throw NotImplementedException(); } virtual EventReturn OnLoadDatabase() { throw NotImplementedException(); }
/** Called when anope needs to check passwords against encryption /** Called when anope needs to check passwords against encryption
* see src/encrypt.c for detailed informations
*/ */
virtual EventReturn OnEncrypt(const Anope::string &src, Anope::string &dest) { throw NotImplementedException(); } virtual EventReturn OnEncrypt(const Anope::string &src, Anope::string &dest) { throw NotImplementedException(); }
virtual EventReturn OnDecrypt(const Anope::string &hashm, const Anope::string &src, Anope::string &dest) { throw NotImplementedException(); }
/** Called on fantasy command /** Called on fantasy command
* @param source The source of the command * @param source The source of the command
@@ -503,7 +482,7 @@ class CoreExport Module : public Extensible
*/ */
virtual void OnChanExpire(ChannelInfo *ci) { throw NotImplementedException(); } virtual void OnChanExpire(ChannelInfo *ci) { throw NotImplementedException(); }
/** Called before Anope connecs to its uplink /** Called before Anope connects to its uplink
*/ */
virtual void OnPreServerConnect() { throw NotImplementedException(); } virtual void OnPreServerConnect() { throw NotImplementedException(); }
@@ -551,7 +530,7 @@ class CoreExport Module : public Extensible
/** Called before an exception is deleted /** Called before an exception is deleted
* @param source The source deleting it * @param source The source deleting it
* @param ex The exceotion * @param ex The exception
*/ */
virtual void OnExceptionDel(CommandSource &source, Exception *ex) { throw NotImplementedException(); } virtual void OnExceptionDel(CommandSource &source, Exception *ex) { throw NotImplementedException(); }
@@ -772,7 +751,7 @@ class CoreExport Module : public Extensible
*/ */
virtual void OnNickSuspend(NickAlias *na) { throw NotImplementedException(); } virtual void OnNickSuspend(NickAlias *na) { throw NotImplementedException(); }
/** Called when a nick is unsuspneded /** Called when a nick is unsuspended
* @param na The nick alias * @param na The nick alias
*/ */
virtual void OnNickUnsuspended(NickAlias *na) { throw NotImplementedException(); } virtual void OnNickUnsuspended(NickAlias *na) { throw NotImplementedException(); }
@@ -935,12 +914,12 @@ class CoreExport Module : public Extensible
*/ */
virtual void OnUserModeUnset(const MessageSource &setter, User *u, const Anope::string &mname) { throw NotImplementedException(); } virtual void OnUserModeUnset(const MessageSource &setter, User *u, const Anope::string &mname) { throw NotImplementedException(); }
/** Called when a channel mode is introducted into Anope /** Called when a channel mode is introduced into Anope
* @param cm The mode * @param cm The mode
*/ */
virtual void OnChannelModeAdd(ChannelMode *cm) { throw NotImplementedException(); } virtual void OnChannelModeAdd(ChannelMode *cm) { throw NotImplementedException(); }
/** Called when a user mode is introducted into Anope /** Called when a user mode is introduced into Anope
* @param um The mode * @param um The mode
*/ */
virtual void OnUserModeAdd(UserMode *um) { throw NotImplementedException(); } virtual void OnUserModeAdd(UserMode *um) { throw NotImplementedException(); }
@@ -1016,7 +995,7 @@ class CoreExport Module : public Extensible
*/ */
virtual void OnLogMessage(LogInfo *li, const Log *l, const Anope::string &msg) { throw NotImplementedException(); } virtual void OnLogMessage(LogInfo *li, const Log *l, const Anope::string &msg) { throw NotImplementedException(); }
/** Called when a DNS request (question) is recieved. /** Called when a DNS request (question) is received.
* @param req The dns request * @param req The dns request
* @param reply The reply that will be sent * @param reply The reply that will be sent
*/ */
@@ -1062,7 +1041,7 @@ class CoreExport Module : public Extensible
/** Called when a nickserv/set command is used. /** Called when a nickserv/set command is used.
* @param source The source of the command * @param source The source of the command
* @param cmd The command * @param cmd The command
* @param nc The nickcore being modifed * @param nc The nickcore being modified
* @param setting The setting passed to the command. Probably ON/OFF. * @param setting The setting passed to the command. Probably ON/OFF.
* @return EVENT_STOP to halt immediately * @return EVENT_STOP to halt immediately
*/ */
@@ -1076,7 +1055,7 @@ class CoreExport Module : public Extensible
*/ */
virtual EventReturn OnMessage(MessageSource &source, Anope::string &command, std::vector<Anope::string> &param) { throw NotImplementedException(); } virtual EventReturn OnMessage(MessageSource &source, Anope::string &command, std::vector<Anope::string> &param) { throw NotImplementedException(); }
/** Called to determine if a chnanel mode can be set by a user /** Called to determine if a channel mode can be set by a user
* @param u The user * @param u The user
* @param cm The mode * @param cm The mode
*/ */
@@ -1089,17 +1068,25 @@ class CoreExport Module : public Extensible
*/ */
virtual void OnExpireTick() { throw NotImplementedException(); } virtual void OnExpireTick() { throw NotImplementedException(); }
/** Called when a nick is validated. That is, to determine if a user is permissted /** Called when a nick is validated. That is, to determine if a user is permitted
* to be on the given nick. * to be on the given nick.
* @param u The user * @param u The user
* @param na The nick they are on * @param na The nick they are on
* @return EVENT_STOP to force the user off of the nick * @return EVENT_STOP to force the user off of the nick
*/ */
virtual EventReturn OnNickValidate(User *u, NickAlias *na) { throw NotImplementedException(); } virtual EventReturn OnNickValidate(User *u, NickAlias *na) { throw NotImplementedException(); }
/** Called when a certain user has to be unbanned on a certain channel.
* May be used to send protocol-specific messages.
* @param u The user to be unbanned
* @param c The channel that user has to be unbanned on
*/
virtual void OnChannelUnban(User *u, ChannelInfo *ci) { throw NotImplementedException(); }
}; };
enum Implementation enum Implementation
{ {
I_OnPostInit,
I_OnPreUserKicked, I_OnUserKicked, I_OnReload, I_OnPreBotAssign, I_OnBotAssign, I_OnBotUnAssign, I_OnUserConnect, I_OnPreUserKicked, I_OnUserKicked, I_OnReload, I_OnPreBotAssign, I_OnBotAssign, I_OnBotUnAssign, I_OnUserConnect,
I_OnNewServer, I_OnUserNickChange, I_OnPreHelp, I_OnPostHelp, I_OnPreCommand, I_OnPostCommand, I_OnSaveDatabase, I_OnNewServer, I_OnUserNickChange, I_OnPreHelp, I_OnPostHelp, I_OnPreCommand, I_OnPostCommand, I_OnSaveDatabase,
I_OnLoadDatabase, I_OnEncrypt, I_OnDecrypt, I_OnBotFantasy, I_OnBotNoFantasyAccess, I_OnBotBan, I_OnBadWordAdd, I_OnLoadDatabase, I_OnEncrypt, I_OnDecrypt, I_OnBotFantasy, I_OnBotNoFantasyAccess, I_OnBotBan, I_OnBadWordAdd,
@@ -1120,20 +1107,20 @@ enum Implementation
I_OnPrivmsg, I_OnLog, I_OnLogMessage, I_OnDnsRequest, I_OnCheckModes, I_OnChannelSync, I_OnSetCorrectModes, I_OnPrivmsg, I_OnLog, I_OnLogMessage, I_OnDnsRequest, I_OnCheckModes, I_OnChannelSync, I_OnSetCorrectModes,
I_OnSerializeCheck, I_OnSerializableConstruct, I_OnSerializableDestruct, I_OnSerializableUpdate, I_OnSerializeCheck, I_OnSerializableConstruct, I_OnSerializableDestruct, I_OnSerializableUpdate,
I_OnSerializeTypeCreate, I_OnSetChannelOption, I_OnSetNickOption, I_OnMessage, I_OnCanSet, I_OnCheckDelete, I_OnSerializeTypeCreate, I_OnSetChannelOption, I_OnSetNickOption, I_OnMessage, I_OnCanSet, I_OnCheckDelete,
I_OnExpireTick, I_OnNickValidate, I_OnExpireTick, I_OnNickValidate, I_OnChannelUnban,
I_SIZE I_SIZE
}; };
/** Used to manage modules. /** Used to manage modules.
*/ */
class CoreExport ModuleManager class CoreExport ModuleManager final
{ {
public: public:
/** Event handler hooks. /** Event handler hooks.
*/ */
static std::vector<Module *> EventHandlers[I_SIZE]; static std::vector<Module *> EventHandlers[I_SIZE];
/** List of all modules loaded in Anope /** List of all modules loaded in Anope
*/ */
static std::list<Module *> Modules; static std::list<Module *> Modules;
@@ -1172,7 +1159,7 @@ class CoreExport ModuleManager
/** Checks whether this version of Anope is at least major.minor.patch.build /** Checks whether this version of Anope is at least major.minor.patch.build
* Throws a ModuleException if not * Throws a ModuleException if not
* @param major The major version * @param major The major version
* @param minor The minor vesion * @param minor The minor version
* @param patch The patch version * @param patch The patch version
*/ */
static void RequireVersion(int major, int minor, int patch); static void RequireVersion(int major, int minor, int patch);
@@ -1211,7 +1198,7 @@ class CoreExport ModuleManager
*/ */
static void UnloadAll(); static void UnloadAll();
private: private:
/** Call the module_delete function to safely delete the module /** Call the module_delete function to safely delete the module
* @param m the module to delete * @param m the module to delete
* @return MOD_ERR_OK on success, anything else on fail * @return MOD_ERR_OK on success, anything else on fail
@@ -1223,5 +1210,3 @@ class CoreExport ModuleManager
*/ */
static ModuleVersion GetVersion(void *handle); static ModuleVersion GetVersion(void *handle);
}; };
#endif // MODULES_H
+7 -8
View File
@@ -1,16 +1,16 @@
/* BotServ core functions /* BotServ core functions
* *
* (C) 2003-2014 Anope Team * (C) 2003-2024 Anope Team
* Contact us at team@anope.org * Contact us at team@anope.org
* *
* Please read COPYING and README for further details. * Please read COPYING and README for further details.
* *
* Based on the original code of Epona by Lara. * Based on the original code of Epona by Lara.
* Based on the original code of Services by Andy Church. * Based on the original code of Services by Andy Church.
*
*
*/ */
#pragma once
/** Flags for badwords /** Flags for badwords
*/ */
enum BadWordType enum BadWordType
@@ -32,14 +32,14 @@ struct BadWord
Anope::string word; Anope::string word;
BadWordType type; BadWordType type;
virtual ~BadWord() { } virtual ~BadWord() = default;
protected: protected:
BadWord() { } BadWord() = default;
}; };
struct BadWords struct BadWords
{ {
virtual ~BadWords() { } virtual ~BadWords() = default;
/** Add a badword to the badword list /** Add a badword to the badword list
* @param word The badword * @param word The badword
@@ -70,4 +70,3 @@ struct BadWords
virtual void Check() = 0; virtual void Check() = 0;
}; };
+7 -7
View File
@@ -1,16 +1,16 @@
/* BotServ core functions /* BotServ core functions
* *
* (C) 2003-2014 Anope Team * (C) 2003-2024 Anope Team
* Contact us at team@anope.org * Contact us at team@anope.org
* *
* Please read COPYING and README for further details. * Please read COPYING and README for further details.
* *
* Based on the original code of Epona by Lara. * Based on the original code of Epona by Lara.
* Based on the original code of Services by Andy Church. * Based on the original code of Services by Andy Church.
*
*
*/ */
#pragma once
/* Indices for TTB (Times To Ban) */ /* Indices for TTB (Times To Ban) */
enum enum
{ {
@@ -37,10 +37,10 @@ struct KickerData
bool dontkickops, dontkickvoices; bool dontkickops, dontkickvoices;
protected: protected:
KickerData() { } KickerData() = default;
public: public:
virtual ~KickerData() { } virtual ~KickerData() = default;
virtual void Check(ChannelInfo *ci) = 0; virtual void Check(ChannelInfo *ci) = 0;
}; };
+11 -9
View File
@@ -1,11 +1,13 @@
/* /*
* (C) 2003-2014 Anope Team *
* (C) 2003-2024 Anope Team
* Contact us at team@anope.org * Contact us at team@anope.org
* *
* Please read COPYING and README for further details. * Please read COPYING and README for further details.
*
*/ */
#pragma once
struct EntryMsg struct EntryMsg
{ {
Anope::string chan; Anope::string chan;
@@ -13,17 +15,18 @@ struct EntryMsg
Anope::string message; Anope::string message;
time_t when; time_t when;
virtual ~EntryMsg() { } virtual ~EntryMsg() = default;
protected: protected:
EntryMsg() { } EntryMsg() = default;
}; };
struct EntryMessageList : Serialize::Checker<std::vector<EntryMsg *> > struct EntryMessageList
: Serialize::Checker<std::vector<EntryMsg *> >
{ {
protected: protected:
EntryMessageList() : Serialize::Checker<std::vector<EntryMsg *> >("EntryMsg") { } EntryMessageList() : Serialize::Checker<std::vector<EntryMsg *> >("EntryMsg") { }
public: public:
virtual ~EntryMessageList() virtual ~EntryMessageList()
{ {
for (unsigned i = (*this)->size(); i > 0; --i) for (unsigned i = (*this)->size(); i > 0; --i)
@@ -32,4 +35,3 @@ struct EntryMessageList : Serialize::Checker<std::vector<EntryMsg *> >
virtual EntryMsg* Create() = 0; virtual EntryMsg* Create() = 0;
}; };
+11 -9
View File
@@ -1,6 +1,6 @@
/* ChanServ core functions /* ChanServ core functions
* *
* (C) 2003-2014 Anope Team * (C) 2003-2024 Anope Team
* Contact us at team@anope.org * Contact us at team@anope.org
* *
* Please read COPYING and README for further details. * Please read COPYING and README for further details.
@@ -9,6 +9,8 @@
* Based on the original code of Services by Andy Church. * Based on the original code of Services by Andy Church.
*/ */
#pragma once
struct LogSetting struct LogSetting
{ {
Anope::string chan; Anope::string chan;
@@ -22,22 +24,22 @@ struct LogSetting
Anope::string creator; Anope::string creator;
time_t created; time_t created;
virtual ~LogSetting() { } virtual ~LogSetting() = default;
protected: protected:
LogSetting() { } LogSetting() = default;
}; };
struct LogSettings : Serialize::Checker<std::vector<LogSetting *> > struct LogSettings
: Serialize::Checker<std::vector<LogSetting *> >
{ {
typedef std::vector<LogSetting *>::iterator iterator; typedef std::vector<LogSetting *>::iterator iterator;
protected: protected:
LogSettings() : Serialize::Checker<std::vector<LogSetting *> >("LogSetting") LogSettings() : Serialize::Checker<std::vector<LogSetting *> >("LogSetting")
{ {
} }
public: public:
virtual ~LogSettings() { } virtual ~LogSettings() = default;
virtual LogSetting *Create() = 0; virtual LogSetting *Create() = 0;
}; };
+9 -8
View File
@@ -1,6 +1,6 @@
/* ChanServ core functions /* ChanServ core functions
* *
* (C) 2003-2014 Anope Team * (C) 2003-2024 Anope Team
* Contact us at team@anope.org * Contact us at team@anope.org
* *
* Please read COPYING and README for further details. * Please read COPYING and README for further details.
@@ -9,6 +9,8 @@
* Based on the original code of Services by Andy Church. * Based on the original code of Services by Andy Church.
*/ */
#pragma once
struct ModeLock struct ModeLock
{ {
Anope::string ci; Anope::string ci;
@@ -18,16 +20,16 @@ struct ModeLock
Anope::string setter; Anope::string setter;
time_t created; time_t created;
virtual ~ModeLock() { } virtual ~ModeLock() = default;
protected: protected:
ModeLock() { } ModeLock() = default;
}; };
struct ModeLocks struct ModeLocks
{ {
typedef std::vector<ModeLock *> ModeList; typedef std::vector<ModeLock *> ModeList;
virtual ~ModeLocks() { } virtual ~ModeLocks() = default;
/** Check if a mode is mlocked /** Check if a mode is mlocked
* @param mode The mode * @param mode The mode
@@ -74,17 +76,16 @@ struct ModeLocks
/** Get details for a specific mlock /** Get details for a specific mlock
* @param mname The mode name * @param mname The mode name
* @param An optional param to match with * @param An optional param to match with
* @return The MLock, if any * @return The MLock, if any
*/ */
virtual const ModeLock *GetMLock(const Anope::string &mname, const Anope::string &param = "") = 0; virtual const ModeLock *GetMLock(const Anope::string &mname, const Anope::string &param = "") = 0;
/** Get the current mode locks as a string /** Get the current mode locks as a string
* @param complete True to show mlock parameters aswell * @param complete True to show mlock parameters as well
* @return A string of mode locks, eg: +nrt * @return A string of mode locks, eg: +nrt
*/ */
virtual Anope::string GetMLockAsString(bool complete) const = 0; virtual Anope::string GetMLockAsString(bool complete) const = 0;
virtual void Check() = 0; virtual void Check() = 0;
}; };
+49 -45
View File
@@ -1,17 +1,15 @@
/* /*
* *
* (C) 2003-2014 Anope Team * (C) 2003-2024 Anope Team
* Contact us at team@anope.org * Contact us at team@anope.org
* *
* Please read COPYING and README for further details. * Please read COPYING and README for further details.
* *
* Based on the original code of Epona by Lara. * Based on the original code of Epona by Lara.
* Based on the original code of Services by Andy Church. * Based on the original code of Services by Andy Church.
*
*/ */
#ifndef DNS_H #pragma once
#define DNS_H
namespace DNS namespace DNS
{ {
@@ -53,7 +51,7 @@ namespace DNS
QUERYFLAGS_Z = 0x70, QUERYFLAGS_Z = 0x70,
QUERYFLAGS_RCODE = 0xF QUERYFLAGS_RCODE = 0xF
}; };
enum Error enum Error
{ {
ERROR_NONE, ERROR_NONE,
@@ -70,42 +68,43 @@ namespace DNS
ERROR_NO_RECORDS, ERROR_NO_RECORDS,
ERROR_INVALIDTYPE ERROR_INVALIDTYPE
}; };
struct Question struct Question
{ {
Anope::string name; Anope::string name;
QueryType type; QueryType type = QUERY_NONE;
unsigned short qclass; unsigned short qclass = 0;
Question() : type(QUERY_NONE), qclass(0) { }
Question(const Anope::string &n, QueryType t, unsigned short c = 1) : name(n), type(t), qclass(c) { }
inline bool operator==(const Question & other) const { return name == other.name && type == other.type && qclass == other.qclass; }
struct hash Question() = default;
Question(const Anope::string &n, QueryType t, unsigned short c = 1) : name(n), type(t), qclass(c) { }
inline bool operator==(const Question & other) const { return name == other.name && type == other.type && qclass == other.qclass; }
struct hash final
{ {
size_t operator()(const Question &q) const size_t operator()(const Question &q) const
{ {
return Anope::hash_ci()(q.name); return Anope::hash_ci()(q.name);
} }
}; };
}; };
struct ResourceRecord : Question struct ResourceRecord final
: Question
{ {
unsigned int ttl; unsigned int ttl = 0;
Anope::string rdata; Anope::string rdata;
time_t created; time_t created;
ResourceRecord(const Anope::string &n, QueryType t, unsigned short c = 1) : Question(n, t, c), ttl(0), created(Anope::CurTime) { } ResourceRecord(const Anope::string &n, QueryType t, unsigned short c = 1) : Question(n, t, c), created(Anope::CurTime) { }
ResourceRecord(const Question &q) : Question(q), ttl(0), created(Anope::CurTime) { } ResourceRecord(const Question &q) : Question(q), created(Anope::CurTime) { }
}; };
struct Query struct Query
{ {
std::vector<Question> questions; std::vector<Question> questions;
std::vector<ResourceRecord> answers, authorities, additional; std::vector<ResourceRecord> answers, authorities, additional;
Error error; Error error;
Query() : error(ERROR_NONE) { } Query() : error(ERROR_NONE) { }
Query(const Question &q) : error(ERROR_NONE) { questions.push_back(q); } Query(const Question &q) : error(ERROR_NONE) { questions.push_back(q); }
}; };
@@ -115,57 +114,66 @@ namespace DNS
/** DNS manager /** DNS manager
*/ */
class Manager : public Service class Manager
: public Service
{ {
public: public:
Manager(Module *creator) : Service(creator, "DNS::Manager", "dns/manager") { } Manager(Module *creator) : Service(creator, "DNS::Manager", "dns/manager") { }
virtual ~Manager() { } virtual ~Manager() = default;
virtual void Process(Request *req) = 0; virtual void Process(Request *req) = 0;
virtual void RemoveRequest(Request *req) = 0; virtual void RemoveRequest(Request *req) = 0;
virtual bool HandlePacket(ReplySocket *s, const unsigned char *const data, int len, sockaddrs *from) = 0; virtual bool HandlePacket(ReplySocket *s, const unsigned char *const data, int len, sockaddrs *from) = 0;
virtual void UpdateSerial() = 0; virtual void UpdateSerial() = 0;
virtual void Notify(const Anope::string &zone) = 0; virtual void Notify(const Anope::string &zone) = 0;
virtual uint32_t GetSerial() const = 0; virtual uint32_t GetSerial() const = 0;
}; };
/** A DNS query. /** A DNS query.
*/ */
class Request : public Timer, public Question class Request
: public Timer
, public Question
{ {
Manager *manager; Manager *manager;
public: public:
/* Use result cache if available */ /* Use result cache if available */
bool use_cache; bool use_cache;
/* Request id */ /* Request id */
unsigned short id; unsigned short id = 0;
/* Creator of this request */ /* Creator of this request */
Module *creator; Module *creator;
Request(Manager *mgr, Module *c, const Anope::string &addr, QueryType qt, bool cache = false) : Timer(0), Question(addr, qt), manager(mgr), Request(Manager *mgr, Module *c, const Anope::string &addr, QueryType qt, bool cache = false)
use_cache(cache), id(0), creator(c) { } : Timer(0)
, Question(addr, qt)
, manager(mgr)
, use_cache(cache)
, creator(c)
{
}
virtual ~Request() virtual ~Request()
{ {
manager->RemoveRequest(this); manager->RemoveRequest(this);
} }
/** Called when this request succeeds /** Called when this request succeeds
* @param r The query sent back from the nameserver * @param r The query sent back from the nameserver
*/ */
virtual void OnLookupComplete(const Query *r) = 0; virtual void OnLookupComplete(const Query *r) = 0;
/** Called when this request fails or times out. /** Called when this request fails or times out.
* @param r The query sent back from the nameserver, check the error code. * @param r The query sent back from the nameserver, check the error code.
*/ */
virtual void OnError(const Query *r) { } virtual void OnError(const Query *r) { }
/** Used to time out the query, xalls OnError and lets the TimerManager /** Used to time out the query, xalls OnError and lets the TimerManager
* delete this request. * delete this request.
*/ */
void Tick(time_t) anope_override void Tick() override
{ {
Log(LOG_DEBUG_2) << "Resolver: timeout for query " << this->name; Log(LOG_DEBUG_2) << "Resolver: timeout for query " << this->name;
Query rr(*this); Query rr(*this);
@@ -173,9 +181,5 @@ namespace DNS
this->OnError(&rr); this->OnError(&rr);
} }
}; };
} // namespace DNS } // namespace DNS
#endif // DNS_H
+9 -8
View File
@@ -1,15 +1,16 @@
/* /*
* *
* (C) 2003-2014 Anope Team * (C) 2003-2024 Anope Team
* Contact us at team@anope.org * Contact us at team@anope.org
* *
* Please read COPYING and README for further details. * Please read COPYING and README for further details.
* *
* Based on the original code of Epona by Lara. * Based on the original code of Epona by Lara.
* Based on the original code of Services by Andy Church. * Based on the original code of Services by Andy Church.
*
*/ */
#pragma once
namespace Encryption namespace Encryption
{ {
typedef std::pair<const unsigned char *, size_t> Hash; typedef std::pair<const unsigned char *, size_t> Hash;
@@ -17,21 +18,21 @@ namespace Encryption
class Context class Context
{ {
public: public:
virtual ~Context() { } virtual ~Context() = default;
virtual void Update(const unsigned char *data, size_t len) = 0; virtual void Update(const unsigned char *data, size_t len) = 0;
virtual void Finalize() = 0; virtual void Finalize() = 0;
virtual Hash GetFinalizedHash() = 0; virtual Hash GetFinalizedHash() = 0;
}; };
class Provider : public Service class Provider
: public Service
{ {
public: public:
Provider(Module *creator, const Anope::string &sname) : Service(creator, "Encryption::Provider", sname) { } Provider(Module *creator, const Anope::string &sname) : Service(creator, "Encryption::Provider", sname) { }
virtual ~Provider() { } virtual ~Provider() = default;
virtual Context *CreateContext(IV * = NULL) = 0; virtual Context *CreateContext(IV * = NULL) = 0;
virtual IV GetDefaultIV() = 0; virtual IV GetDefaultIV() = 0;
}; };
} }
+45 -32
View File
@@ -1,5 +1,12 @@
#ifndef ANOPE_HTTPD_H /*
#define ANOPE_HTTPD_H *
* (C) 2012-2024 Anope Team
* Contact us at team@anope.org
*
* Please read COPYING and README for further details.
*/
#pragma once
enum HTTPError enum HTTPError
{ {
@@ -11,15 +18,16 @@ enum HTTPError
}; };
/* A message to someone */ /* A message to someone */
struct HTTPReply struct HTTPReply final
{ {
HTTPError error; HTTPError error = HTTP_ERROR_OK;
Anope::string content_type; Anope::string content_type;
std::map<Anope::string, Anope::string> headers; std::map<Anope::string, Anope::string, ci::less> headers;
typedef std::list<std::pair<Anope::string, Anope::string> > cookie; typedef std::list<std::pair<Anope::string, Anope::string> > cookie;
std::vector<cookie> cookies; std::vector<cookie> cookies;
HTTPReply() : error(HTTP_ERROR_OK), length(0) { } HTTPReply() = default;
HTTPReply& operator=(const HTTPReply &) = default;
HTTPReply(const HTTPReply& other) : error(other.error), length(other.length) HTTPReply(const HTTPReply& other) : error(other.error), length(other.length)
{ {
@@ -27,18 +35,18 @@ struct HTTPReply
headers = other.headers; headers = other.headers;
cookies = other.cookies; cookies = other.cookies;
for (unsigned i = 0; i < other.out.size(); ++i) for (const auto &datum : other.out)
out.push_back(new Data(other.out[i]->buf, other.out[i]->len)); out.push_back(new Data(datum->buf, datum->len));
} }
~HTTPReply() ~HTTPReply()
{ {
for (unsigned i = 0; i < out.size(); ++i) for (const auto *datum : out)
delete out[i]; delete datum;
out.clear(); out.clear();
} }
struct Data struct Data final
{ {
char *buf; char *buf;
size_t len; size_t len;
@@ -57,7 +65,7 @@ struct HTTPReply
}; };
std::deque<Data *> out; std::deque<Data *> out;
size_t length; size_t length = 0;
void Write(const Anope::string &message) void Write(const Anope::string &message)
{ {
@@ -72,8 +80,8 @@ struct HTTPReply
} }
}; };
/* A message from soneone */ /* A message from someone */
struct HTTPMessage struct HTTPMessage final
{ {
std::map<Anope::string, Anope::string> headers; std::map<Anope::string, Anope::string> headers;
std::map<Anope::string, Anope::string> cookies; std::map<Anope::string, Anope::string> cookies;
@@ -85,13 +93,14 @@ struct HTTPMessage
class HTTPClient; class HTTPClient;
class HTTPProvider; class HTTPProvider;
class HTTPPage : public Base class HTTPPage
: public virtual Base
{ {
Anope::string url; Anope::string url;
Anope::string content_type; Anope::string content_type;
public: public:
HTTPPage(const Anope::string &u, const Anope::string &ct = "text/html") : url(u), content_type(ct) { } HTTPPage(const Anope::string &u, const Anope::string &ct = "text/html") : url(u), content_type(ct) { }
const Anope::string &GetURL() const { return this->url; } const Anope::string &GetURL() const { return this->url; }
@@ -107,15 +116,18 @@ class HTTPPage : public Base
virtual bool OnRequest(HTTPProvider *, const Anope::string &, HTTPClient *, HTTPMessage &, HTTPReply &) = 0; virtual bool OnRequest(HTTPProvider *, const Anope::string &, HTTPClient *, HTTPMessage &, HTTPReply &) = 0;
}; };
class HTTPClient : public ClientSocket, public BinarySocket, public Base class HTTPClient
: public ClientSocket
, public BinarySocket
, public Base
{ {
protected: protected:
void WriteClient(const Anope::string &message) void WriteClient(const Anope::string &message)
{ {
BinarySocket::Write(message + "\r\n"); BinarySocket::Write(message + "\r\n");
} }
public: public:
HTTPClient(ListenSocket *l, int f, const sockaddrs &a) : ClientSocket(l, a), BinarySocket() { } HTTPClient(ListenSocket *l, int f, const sockaddrs &a) : ClientSocket(l, a), BinarySocket() { }
virtual const Anope::string GetIP() virtual const Anope::string GetIP()
@@ -127,13 +139,15 @@ class HTTPClient : public ClientSocket, public BinarySocket, public Base
virtual void SendReply(HTTPReply *) = 0; virtual void SendReply(HTTPReply *) = 0;
}; };
class HTTPProvider : public ListenSocket, public Service class HTTPProvider
: public ListenSocket
, public Service
{ {
Anope::string ip; Anope::string ip;
unsigned short port; unsigned short port;
bool ssl; bool ssl;
public: public:
Anope::string ext_ip; std::vector<Anope::string> ext_ips;
std::vector<Anope::string> ext_headers; std::vector<Anope::string> ext_headers;
HTTPProvider(Module *c, const Anope::string &n, const Anope::string &i, const unsigned short p, bool s) : ListenSocket(i, p, i.find(':') != Anope::string::npos), Service(c, "HTTPProvider", n), ip(i), port(p), ssl(s) { } HTTPProvider(Module *c, const Anope::string &n, const Anope::string &i, const unsigned short p, bool s) : ListenSocket(i, p, i.find(':') != Anope::string::npos), Service(c, "HTTPProvider", n), ip(i), port(p), ssl(s) { }
@@ -188,10 +202,8 @@ namespace HTTPUtils
{ {
Anope::string encoded; Anope::string encoded;
for (unsigned i = 0; i < url.length(); ++i) for (const auto c : url)
{ {
const char& c = url[i];
if (isalnum(c) || c == '.' || c == '-' || c == '*' || c == '_') if (isalnum(c) || c == '.' || c == '-' || c == '*' || c == '_')
encoded += c; encoded += c;
else if (c == ' ') else if (c == ' ')
@@ -207,9 +219,9 @@ namespace HTTPUtils
{ {
Anope::string dst; Anope::string dst;
for (unsigned i = 0; i < src.length(); ++i) for (const auto c : src)
{ {
switch (src[i]) switch (c)
{ {
case '<': case '<':
dst += "&lt;"; dst += "&lt;";
@@ -220,13 +232,14 @@ namespace HTTPUtils
case '"': case '"':
dst += "&quot;"; dst += "&quot;";
break; break;
case '&':
dst += "&amp;";
break;
default: default:
dst += src[i]; dst += c;
} }
} }
return dst; return dst;
} }
} }
#endif // ANOPE_HTTPD_H
+23 -16
View File
@@ -1,15 +1,22 @@
#ifndef ANOPE_LDAP_H /*
#define ANOPE_LDAP_H *
* (C) 2011-2024 Anope Team
* Contact us at team@anope.org
*
* Please read COPYING and README for further details.
*/
class LDAPException : public ModuleException #pragma once
class DllExport LDAPException : public ModuleException
{ {
public: public:
LDAPException(const Anope::string &reason) : ModuleException(reason) { } LDAPException(const Anope::string &reason) : ModuleException(reason) { }
virtual ~LDAPException() throw() { } virtual ~LDAPException() noexcept = default;
}; };
struct LDAPModification struct LDAPModification final
{ {
enum LDAPOperation enum LDAPOperation
{ {
@@ -24,7 +31,8 @@ struct LDAPModification
}; };
typedef std::vector<LDAPModification> LDAPMods; typedef std::vector<LDAPModification> LDAPMods;
struct LDAPAttributes : public std::map<Anope::string, std::vector<Anope::string> > struct LDAPAttributes final
: public std::map<Anope::string, std::vector<Anope::string>>
{ {
size_t size(const Anope::string &attr) const size_t size(const Anope::string &attr) const
{ {
@@ -35,8 +43,8 @@ struct LDAPAttributes : public std::map<Anope::string, std::vector<Anope::string
const std::vector<Anope::string> keys() const const std::vector<Anope::string> keys() const
{ {
std::vector<Anope::string> k; std::vector<Anope::string> k;
for (const_iterator it = this->begin(), it_end = this->end(); it != it_end; ++it) for (const auto &[key, _] : *this)
k.push_back(it->first); k.push_back(key);
return k; return k;
} }
@@ -67,7 +75,7 @@ enum QueryType
QUERY_MODIFY QUERY_MODIFY
}; };
struct LDAPResult struct LDAPResult final
{ {
std::vector<LDAPAttributes> messages; std::vector<LDAPAttributes> messages;
Anope::string error; Anope::string error;
@@ -104,20 +112,21 @@ struct LDAPResult
class LDAPInterface class LDAPInterface
{ {
public: public:
Module *owner; Module *owner;
LDAPInterface(Module *m) : owner(m) { } LDAPInterface(Module *m) : owner(m) { }
virtual ~LDAPInterface() { } virtual ~LDAPInterface() = default;
virtual void OnResult(const LDAPResult &r) = 0; virtual void OnResult(const LDAPResult &r) = 0;
virtual void OnError(const LDAPResult &err) = 0; virtual void OnError(const LDAPResult &err) = 0;
virtual void OnDelete() { } virtual void OnDelete() { }
}; };
class LDAPProvider : public Service class LDAPProvider
: public Service
{ {
public: public:
LDAPProvider(Module *c, const Anope::string &n) : Service(c, "LDAPProvider", n) { } LDAPProvider(Module *c, const Anope::string &n) : Service(c, "LDAPProvider", n) { }
/** Attempt to bind to the LDAP server as an admin /** Attempt to bind to the LDAP server as an admin
@@ -159,5 +168,3 @@ class LDAPProvider : public Service
*/ */
virtual void Modify(LDAPInterface *i, const Anope::string &base, LDAPMods &attributes) = 0; virtual void Modify(LDAPInterface *i, const Anope::string &base, LDAPMods &attributes) = 0;
}; };
#endif // ANOPE_LDAP_H
+11 -9
View File
@@ -1,6 +1,6 @@
/* NickServ core functions /* NickServ core functions
* *
* (C) 2003-2014 Anope Team * (C) 2003-2024 Anope Team
* Contact us at team@anope.org * Contact us at team@anope.org
* *
* Please read COPYING and README for further details. * Please read COPYING and README for further details.
@@ -9,12 +9,14 @@
* Based on the original code of Services by Andy Church. * Based on the original code of Services by Andy Church.
*/ */
#pragma once
struct NSCertList struct NSCertList
{ {
protected: protected:
NSCertList() { } NSCertList() = default;
public: public:
virtual ~NSCertList() { } virtual ~NSCertList() = default;
/** Add an entry to the nick's certificate list /** Add an entry to the nick's certificate list
* *
@@ -26,7 +28,7 @@ struct NSCertList
/** Get an entry from the nick's cert list by index /** Get an entry from the nick's cert list by index
* *
* @param entry Index in the certificaate list vector to retrieve * @param entry Index in the certificate list vector to retrieve
* @return The fingerprint entry of the given index if within bounds, an empty string if the vector is empty or the index is out of bounds * @return The fingerprint entry of the given index if within bounds, an empty string if the vector is empty or the index is out of bounds
* *
* Retrieves an entry from the certificate list corresponding to the given index. * Retrieves an entry from the certificate list corresponding to the given index.
@@ -61,11 +63,11 @@ struct NSCertList
virtual void Check() = 0; virtual void Check() = 0;
}; };
class CertService : public Service class CertService
: public Service
{ {
public: public:
CertService(Module *c) : Service(c, "CertService", "certs") { } CertService(Module *c) : Service(c, "CertService", "certs") { }
virtual NickCore* FindAccountFromCert(const Anope::string &cert) = 0; virtual NickCore* FindAccountFromCert(const Anope::string &cert) = 0;
}; };
+19 -12
View File
@@ -1,5 +1,12 @@
#ifndef OS_FORBID_H /*
#define OS_FORBID_H *
* (C) 2011-2024 Anope Team
* Contact us at team@anope.org
*
* Please read COPYING and README for further details.
*/
#pragma once
enum ForbidType enum ForbidType
{ {
@@ -15,18 +22,19 @@ struct ForbidData
Anope::string mask; Anope::string mask;
Anope::string creator; Anope::string creator;
Anope::string reason; Anope::string reason;
time_t created; time_t created = 0;
time_t expires; time_t expires = 0;
ForbidType type; ForbidType type;
virtual ~ForbidData() { } virtual ~ForbidData() = default;
protected: protected:
ForbidData() : created(0), expires(0) { } ForbidData() = default;
}; };
class ForbidService : public Service class ForbidService
: public Service
{ {
public: public:
ForbidService(Module *m) : Service(m, "ForbidService", "forbid") { } ForbidService(Module *m) : Service(m, "ForbidService", "forbid") { }
virtual void AddForbid(ForbidData *d) = 0; virtual void AddForbid(ForbidData *d) = 0;
@@ -37,10 +45,9 @@ class ForbidService : public Service
virtual ForbidData *FindForbid(const Anope::string &mask, ForbidType type) = 0; virtual ForbidData *FindForbid(const Anope::string &mask, ForbidType type) = 0;
virtual ForbidData *FindForbidExact(const Anope::string &mask, ForbidType type) = 0;
virtual std::vector<ForbidData *> GetForbids() = 0; virtual std::vector<ForbidData *> GetForbids() = 0;
}; };
static ServiceReference<ForbidService> forbid_service("ForbidService", "forbid"); static ServiceReference<ForbidService> forbid_service("ForbidService", "forbid");
#endif
+11 -10
View File
@@ -1,6 +1,6 @@
/* OperServ ignore interface /* OperServ ignore interface
* *
* (C) 2003-2014 Anope Team * (C) 2003-2024 Anope Team
* Contact us at team@anope.org * Contact us at team@anope.org
* *
* Please read COPYING and README for further details. * Please read COPYING and README for further details.
@@ -9,25 +9,27 @@
* Based on the original code of Services by Andy Church. * Based on the original code of Services by Andy Church.
*/ */
#pragma once
struct IgnoreData struct IgnoreData
{ {
Anope::string mask; Anope::string mask;
Anope::string creator; Anope::string creator;
Anope::string reason; Anope::string reason;
time_t time; /* When do we stop ignoring them? */ time_t time = 0; /* When do we stop ignoring them? */
virtual ~IgnoreData() { } virtual ~IgnoreData() = default;
protected: protected:
IgnoreData() : time(0) { } IgnoreData() = default;
}; };
class IgnoreService : public Service class IgnoreService
: public Service
{ {
protected: protected:
IgnoreService(Module *c) : Service(c, "IgnoreService", "ignore") { } IgnoreService(Module *c) : Service(c, "IgnoreService", "ignore") { }
public: public:
virtual void AddIgnore(IgnoreData *) = 0; virtual void AddIgnore(IgnoreData *) = 0;
virtual void DelIgnore(IgnoreData *) = 0; virtual void DelIgnore(IgnoreData *) = 0;
@@ -42,4 +44,3 @@ class IgnoreService : public Service
}; };
static ServiceReference<IgnoreService> ignore_service("IgnoreService", "ignore"); static ServiceReference<IgnoreService> ignore_service("IgnoreService", "ignore");
+18 -12
View File
@@ -1,5 +1,12 @@
#ifndef OS_NEWS /*
#define OS_NEWS *
* (C) 2011-2024 Anope Team
* Contact us at team@anope.org
*
* Please read COPYING and README for further details.
*/
#pragma once
enum NewsType enum NewsType
{ {
@@ -8,14 +15,15 @@ enum NewsType
NEWS_OPER NEWS_OPER
}; };
struct NewsMessages struct NewsMessages final
{ {
NewsType type; NewsType type;
Anope::string name; Anope::string name;
const char *msgs[10]; const char *msgs[10];
}; };
struct NewsItem : Serializable struct NewsItem
: Serializable
{ {
NewsType type; NewsType type;
Anope::string text; Anope::string text;
@@ -25,21 +33,19 @@ struct NewsItem : Serializable
NewsItem() : Serializable("NewsItem") { } NewsItem() : Serializable("NewsItem") { }
}; };
class NewsService : public Service class NewsService
: public Service
{ {
public: public:
NewsService(Module *m) : Service(m, "NewsService", "news") { } NewsService(Module *m) : Service(m, "NewsService", "news") { }
virtual NewsItem *CreateNewsItem() = 0; virtual NewsItem *CreateNewsItem() = 0;
virtual void AddNewsItem(NewsItem *n) = 0; virtual void AddNewsItem(NewsItem *n) = 0;
virtual void DelNewsItem(NewsItem *n) = 0; virtual void DelNewsItem(NewsItem *n) = 0;
virtual std::vector<NewsItem *> &GetNewsList(NewsType t) = 0; virtual std::vector<NewsItem *> &GetNewsList(NewsType t) = 0;
}; };
static ServiceReference<NewsService> news_service("NewsService", "news"); static ServiceReference<NewsService> news_service("NewsService", "news");
#endif // OS_NEWS
+21 -15
View File
@@ -1,16 +1,24 @@
#ifndef OS_SESSION_H /*
#define OS_SESSION_H *
* (C) 2011-2024 Anope Team
* Contact us at team@anope.org
*
* Please read COPYING and README for further details.
*/
struct Session #pragma once
struct Session final
{ {
cidr addr; /* A cidr (sockaddrs + len) representing this session */ cidr addr; /* A cidr (sockaddrs + len) representing this session */
unsigned count; /* Number of clients with this host */ unsigned count = 1; /* Number of clients with this host */
unsigned hits; /* Number of subsequent kills for a host */ unsigned hits = 0; /* Number of subsequent kills for a host */
Session(const sockaddrs &ip, int len) : addr(ip, len), count(1), hits(0) { } Session(const sockaddrs &ip, int len) : addr(ip, len) { }
}; };
struct Exception : Serializable struct Exception final
: Serializable
{ {
Anope::string mask; /* Hosts to which this exception applies */ Anope::string mask; /* Hosts to which this exception applies */
unsigned limit; /* Session limit for exception */ unsigned limit; /* Session limit for exception */
@@ -20,14 +28,15 @@ struct Exception : Serializable
time_t expires; /* Time when it expires. 0 == no expiry */ time_t expires; /* Time when it expires. 0 == no expiry */
Exception() : Serializable("Exception") { } Exception() : Serializable("Exception") { }
void Serialize(Serialize::Data &data) const anope_override; void Serialize(Serialize::Data &data) const override;
static Serializable* Unserialize(Serializable *obj, Serialize::Data &data); static Serializable* Unserialize(Serializable *obj, Serialize::Data &data);
}; };
class SessionService : public Service class SessionService
: public Service
{ {
public: public:
typedef TR1NS::unordered_map<cidr, Session *, cidr::hash> SessionMap; typedef std::unordered_map<cidr, Session *, cidr::hash> SessionMap;
typedef std::vector<Exception *> ExceptionVector; typedef std::vector<Exception *> ExceptionVector;
SessionService(Module *m) : Service(m, "SessionService", "session") { } SessionService(Module *m) : Service(m, "SessionService", "session") { }
@@ -40,7 +49,7 @@ class SessionService : public Service
virtual Exception *FindException(User *u) = 0; virtual Exception *FindException(User *u) = 0;
virtual Exception *FindException(const Anope::string &host) = 0; virtual Exception *FindException(const Anope::string &host) = 0;
virtual ExceptionVector &GetExceptions() = 0; virtual ExceptionVector &GetExceptions() = 0;
@@ -82,6 +91,3 @@ Serializable* Exception::Unserialize(Serializable *obj, Serialize::Data &data)
session_service->AddException(ex); session_service->AddException(ex);
return ex; return ex;
} }
#endif
+12 -7
View File
@@ -1,9 +1,17 @@
#ifndef CHANSERV_H /*
#define CHANSERV_H *
* (C) 2011-2024 Anope Team
* Contact us at team@anope.org
*
* Please read COPYING and README for further details.
*/
class ChanServService : public Service #pragma once
class ChanServService
: public Service
{ {
public: public:
ChanServService(Module *m) : Service(m, "ChanServService", "ChanServ") ChanServService(Module *m) : Service(m, "ChanServService", "ChanServ")
{ {
} }
@@ -13,6 +21,3 @@ class ChanServService : public Service
*/ */
virtual void Hold(Channel *c) = 0; virtual void Hold(Channel *c) = 0;
}; };
#endif // CHANSERV_H
+15 -7
View File
@@ -1,13 +1,24 @@
#ifndef GLOBAL_H /*
#define GLOBAL_H *
* (C) 2011-2024 Anope Team
* Contact us at team@anope.org
*
* Please read COPYING and README for further details.
*/
class GlobalService : public Service #pragma once
class GlobalService
: public Service
{ {
public: public:
GlobalService(Module *m) : Service(m, "GlobalService", "Global") GlobalService(Module *m) : Service(m, "GlobalService", "Global")
{ {
} }
/** Retrieves the bot which sends global messages unless otherwise specified. */
virtual Reference<BotInfo> GetDefaultSender() = 0;
/** Send out a global message to all users /** Send out a global message to all users
* @param sender Our client which should send the global * @param sender Our client which should send the global
* @param source The sender of the global * @param source The sender of the global
@@ -15,6 +26,3 @@ class GlobalService : public Service
*/ */
virtual void SendGlobal(BotInfo *sender, const Anope::string &source, const Anope::string &message) = 0; virtual void SendGlobal(BotInfo *sender, const Anope::string &source, const Anope::string &message) = 0;
}; };
#endif // GLOBAL_H
+13 -8
View File
@@ -1,9 +1,17 @@
#ifndef MEMOSERV_H /*
#define MEMOSERV_H *
* (C) 2011-2024 Anope Team
* Contact us at team@anope.org
*
* Please read COPYING and README for further details.
*/
class MemoServService : public Service #pragma once
class MemoServService
: public Service
{ {
public: public:
enum MemoResult enum MemoResult
{ {
MEMO_SUCCESS, MEMO_SUCCESS,
@@ -17,7 +25,7 @@ class MemoServService : public Service
} }
/** Sends a memo. /** Sends a memo.
* @param source The source of the memo, can be anythin. * @param source The source of the memo, can be anything.
* @param target The target of the memo, nick or channel. * @param target The target of the memo, nick or channel.
* @param message Memo text * @param message Memo text
* @param force true to force the memo, restrictions/delays etc are not checked * @param force true to force the memo, restrictions/delays etc are not checked
@@ -29,6 +37,3 @@ class MemoServService : public Service
*/ */
virtual void Check(User *u) = 0; virtual void Check(User *u) = 0;
}; };
#endif // MEMOSERV_H
+12 -7
View File
@@ -1,9 +1,17 @@
#ifndef NICKSERV_H /*
#define NICKSERV_H *
* (C) 2011-2024 Anope Team
* Contact us at team@anope.org
*
* Please read COPYING and README for further details.
*/
class NickServService : public Service #pragma once
class NickServService
: public Service
{ {
public: public:
NickServService(Module *m) : Service(m, "NickServService", "NickServ") NickServService(Module *m) : Service(m, "NickServService", "NickServ")
{ {
} }
@@ -12,6 +20,3 @@ class NickServService : public Service
virtual void Collide(User *u, NickAlias *na) = 0; virtual void Collide(User *u, NickAlias *na) = 0;
virtual void Release(NickAlias *na) = 0; virtual void Release(NickAlias *na) = 0;
}; };
#endif // NICKSERV_H
+14 -11
View File
@@ -1,15 +1,16 @@
/* /*
* *
* (C) 2003-2014 Anope Team * (C) 2003-2024 Anope Team
* Contact us at team@anope.org * Contact us at team@anope.org
* *
* Please read COPYING and README for further details. * Please read COPYING and README for further details.
*
*/ */
#pragma once
namespace Redis namespace Redis
{ {
struct Reply struct Reply final
{ {
enum Type enum Type
{ {
@@ -24,15 +25,15 @@ namespace Redis
Reply() { Clear(); } Reply() { Clear(); }
~Reply() { Clear(); } ~Reply() { Clear(); }
void Clear() void Clear()
{ {
type = NOT_PARSED; type = NOT_PARSED;
i = 0; i = 0;
bulk.clear(); bulk.clear();
multi_bulk_size = 0; multi_bulk_size = 0;
for (unsigned j = 0; j < multi_bulk.size(); ++j) for (const auto *reply : multi_bulk)
delete multi_bulk[j]; delete reply;
multi_bulk.clear(); multi_bulk.clear();
} }
@@ -44,21 +45,24 @@ namespace Redis
class Interface class Interface
{ {
public: public:
Module *owner; Module *owner;
Interface(Module *m) : owner(m) { } Interface(Module *m) : owner(m) { }
virtual ~Interface() { } virtual ~Interface() = default;
virtual void OnResult(const Reply &r) = 0; virtual void OnResult(const Reply &r) = 0;
virtual void OnError(const Anope::string &error) { Log(owner) << error; } virtual void OnError(const Anope::string &error) { Log(owner) << error; }
}; };
class Provider : public Service class Provider
: public Service
{ {
public: public:
Provider(Module *c, const Anope::string &n) : Service(c, "Redis::Provider", n) { } Provider(Module *c, const Anope::string &n) : Service(c, "Redis::Provider", n) { }
virtual bool IsSocketDead() = 0;
virtual void SendCommand(Interface *i, const std::vector<Anope::string> &cmds) = 0; virtual void SendCommand(Interface *i, const std::vector<Anope::string> &cmds) = 0;
virtual void SendCommand(Interface *i, const Anope::string &str) = 0; virtual void SendCommand(Interface *i, const Anope::string &str) = 0;
@@ -71,4 +75,3 @@ namespace Redis
virtual void CommitTransaction() = 0; virtual void CommitTransaction() = 0;
}; };
} }
+35 -14
View File
@@ -1,14 +1,16 @@
/* /*
* *
* (C) 2014 Anope Team * (C) 2014-2024 Anope Team
* Contact us at team@anope.org * Contact us at team@anope.org
* *
* Please read COPYING and README for further details. * Please read COPYING and README for further details.
*/ */
#pragma once
namespace SASL namespace SASL
{ {
struct Message struct Message final
{ {
Anope::string source; Anope::string source;
Anope::string target; Anope::string target;
@@ -20,9 +22,10 @@ namespace SASL
class Mechanism; class Mechanism;
struct Session; struct Session;
class Service : public ::Service class Service
: public ::Service
{ {
public: public:
Service(Module *o) : ::Service(o, "SASL::Service", "sasl") { } Service(Module *o) : ::Service(o, "SASL::Service", "sasl") { }
virtual void ProcessMessage(const Message &) = 0; virtual void ProcessMessage(const Message &) = 0;
@@ -46,6 +49,7 @@ namespace SASL
{ {
time_t created; time_t created;
Anope::string uid; Anope::string uid;
Anope::string hostname, ip;
Reference<Mechanism> mech; Reference<Mechanism> mech;
Session(Mechanism *m, const Anope::string &u) : created(Anope::CurTime), uid(u), mech(m) { } Session(Mechanism *m, const Anope::string &u) : created(Anope::CurTime), uid(u), mech(m) { }
@@ -57,9 +61,10 @@ namespace SASL
}; };
/* PLAIN, EXTERNAL, etc */ /* PLAIN, EXTERNAL, etc */
class Mechanism : public ::Service class Mechanism
: public ::Service
{ {
public: public:
Mechanism(Module *o, const Anope::string &sname) : Service(o, "SASL::Mechanism", sname) { } Mechanism(Module *o, const Anope::string &sname) : Service(o, "SASL::Mechanism", sname) { }
virtual Session* CreateSession(const Anope::string &uid) { return new Session(this, uid); } virtual Session* CreateSession(const Anope::string &uid) { return new Session(this, uid); }
@@ -73,32 +78,42 @@ namespace SASL
} }
}; };
class IdentifyRequest : public ::IdentifyRequest class IdentifyRequest
: public ::IdentifyRequest
{ {
Anope::string uid; Anope::string uid;
Anope::string hostname, ip;
public: public:
IdentifyRequest(Module *m, const Anope::string &id, const Anope::string &acc, const Anope::string &pass) : ::IdentifyRequest(m, acc, pass), uid(id) { } IdentifyRequest(Module *m, const Anope::string &id, const Anope::string &acc, const Anope::string &pass, const Anope::string &h, const Anope::string &i) : ::IdentifyRequest(m, acc, pass), uid(id), hostname(h), ip(i) { }
void OnSuccess() anope_override void OnSuccess() override
{ {
if (!sasl) if (!sasl)
return; return;
NickAlias *na = NickAlias::Find(GetAccount()); NickAlias *na = NickAlias::Find(GetAccount());
if (!na || na->nc->HasExt("NS_SUSPENDED")) if (!na || na->nc->HasExt("NS_SUSPENDED") || na->nc->HasExt("UNCONFIRMED"))
return OnFail();
unsigned int maxlogins = Config->GetModule("ns_identify")->Get<unsigned int>("maxlogins");
if (maxlogins && na->nc->users.size() >= maxlogins)
return OnFail(); return OnFail();
Session *s = sasl->GetSession(uid); Session *s = sasl->GetSession(uid);
if (s) if (s)
{ {
Log(Config->GetClient("NickServ")) << "A user identified to account " << this->GetAccount() << " using SASL"; Anope::string user = "A user";
if (!hostname.empty() && !ip.empty())
user = hostname + " (" + ip + ")";
Log(this->GetOwner(), "sasl", Config->GetClient("NickServ")) << user << " identified to account " << this->GetAccount() << " using SASL";
sasl->Succeed(s, na->nc); sasl->Succeed(s, na->nc);
delete s; delete s;
} }
} }
void OnFail() anope_override void OnFail() override
{ {
if (!sasl) if (!sasl)
return; return;
@@ -116,8 +131,14 @@ namespace SASL
accountstatus = "nonexistent "; accountstatus = "nonexistent ";
else if (na->nc->HasExt("NS_SUSPENDED")) else if (na->nc->HasExt("NS_SUSPENDED"))
accountstatus = "suspended "; accountstatus = "suspended ";
else if (na->nc->HasExt("UNCONFIRMED"))
accountstatus = "unconfirmed ";
Log(Config->GetClient("NickServ")) << "A user failed to identify for " << accountstatus << "account " << this->GetAccount() << " using SASL"; Anope::string user = "A user";
if (!hostname.empty() && !ip.empty())
user = hostname + " (" + ip + ")";
Log(this->GetOwner(), "sasl", Config->GetClient("NickServ")) << user << " failed to identify for " << accountstatus << "account " << this->GetAccount() << " using SASL";
} }
}; };
} }
+7 -4
View File
@@ -1,17 +1,20 @@
/* /*
* (C) 2003-2014 Anope Team *
* (C) 2003-2024 Anope Team
* Contact us at team@anope.org * Contact us at team@anope.org
* *
* Please read COPYING and README for further details. * Please read COPYING and README for further details.
*/ */
#pragma once
struct MiscData struct MiscData
{ {
Anope::string object; Anope::string object;
Anope::string name; Anope::string name;
Anope::string data; Anope::string data;
MiscData() { } virtual ~MiscData() = default;
virtual ~MiscData() { } protected:
MiscData() = default;
}; };
+40 -34
View File
@@ -1,17 +1,21 @@
/* /*
* (C) 2003-2014 Anope Team *
* (C) 2003-2024 Anope Team
* Contact us at team@anope.org * Contact us at team@anope.org
* *
* Please read COPYING and README for further details. * Please read COPYING and README for further details.
*/ */
#pragma once
namespace SQL namespace SQL
{ {
class Data : public Serialize::Data class Data final
: public Serialize::Data
{ {
public: public:
typedef std::map<Anope::string, std::stringstream *> Map; typedef std::map<Anope::string, std::stringstream *> Map;
Map data; Map data;
std::map<Anope::string, Type> types; std::map<Anope::string, Type> types;
@@ -20,7 +24,7 @@ namespace SQL
Clear(); Clear();
} }
std::iostream& operator[](const Anope::string &key) anope_override std::iostream& operator[](const Anope::string &key) override
{ {
std::stringstream *&ss = data[key]; std::stringstream *&ss = data[key];
if (!ss) if (!ss)
@@ -28,44 +32,46 @@ namespace SQL
return *ss; return *ss;
} }
std::set<Anope::string> KeySet() const anope_override std::set<Anope::string> KeySet() const override
{ {
std::set<Anope::string> keys; std::set<Anope::string> keys;
for (Map::const_iterator it = this->data.begin(), it_end = this->data.end(); it != it_end; ++it) for (const auto &[key, _] : this->data)
keys.insert(it->first); keys.insert(key);
return keys; return keys;
} }
size_t Hash() const anope_override size_t Hash() const override
{ {
size_t hash = 0; size_t hash = 0;
for (Map::const_iterator it = this->data.begin(), it_end = this->data.end(); it != it_end; ++it) for (const auto &[_, value] : this->data)
if (!it->second->str().empty()) {
hash ^= Anope::hash_cs()(it->second->str()); if (!value->str().empty())
hash ^= Anope::hash_cs()(value->str());
}
return hash; return hash;
} }
std::map<Anope::string, std::iostream *> GetData() const std::map<Anope::string, std::iostream *> GetData() const
{ {
std::map<Anope::string, std::iostream *> d; std::map<Anope::string, std::iostream *> d;
for (Map::const_iterator it = this->data.begin(), it_end = this->data.end(); it != it_end; ++it) for (const auto &[key, value] : this->data)
d[it->first] = it->second; d[key] = value;
return d; return d;
} }
void Clear() void Clear()
{ {
for (Map::const_iterator it = this->data.begin(), it_end = this->data.end(); it != it_end; ++it) for (const auto &[_, value] : this->data)
delete it->second; delete value;
this->data.clear(); this->data.clear();
} }
void SetType(const Anope::string &key, Type t) anope_override void SetType(const Anope::string &key, Type t) override
{ {
this->types[key] = t; this->types[key] = t;
} }
Type GetType(const Anope::string &key) const anope_override Type GetType(const Anope::string &key) const override
{ {
std::map<Anope::string, Type>::const_iterator it = this->types.find(key); std::map<Anope::string, Type>::const_iterator it = this->types.find(key);
if (it != this->types.end()) if (it != this->types.end())
@@ -76,24 +82,24 @@ namespace SQL
/** A SQL exception, can be thrown at various points /** A SQL exception, can be thrown at various points
*/ */
class Exception : public ModuleException class DllExport Exception : public ModuleException
{ {
public: public:
Exception(const Anope::string &reason) : ModuleException(reason) { } Exception(const Anope::string &reason) : ModuleException(reason) { }
virtual ~Exception() throw() { } virtual ~Exception() noexcept = default;
}; };
/** A SQL query /** A SQL query
*/ */
struct QueryData struct QueryData final
{ {
Anope::string data; Anope::string data;
bool escape; bool escape;
}; };
struct Query struct Query final
{ {
Anope::string query; Anope::string query;
std::map<Anope::string, QueryData> parameters; std::map<Anope::string, QueryData> parameters;
@@ -134,21 +140,21 @@ namespace SQL
*/ */
class Result class Result
{ {
protected: protected:
/* Rows, column, item */ /* Rows, column, item */
std::vector<std::map<Anope::string, Anope::string> > entries; std::vector<std::map<Anope::string, Anope::string> > entries;
Query query; Query query;
Anope::string error; Anope::string error;
public: public:
unsigned int id; unsigned int id = 0;
Anope::string finished_query; Anope::string finished_query;
Result() : id(0) { } Result() = default;
Result(unsigned int i, const Query &q, const Anope::string &fq, const Anope::string &err = "") : query(q), error(err), id(i), finished_query(fq) { } Result(unsigned int i, const Query &q, const Anope::string &fq, const Anope::string &err = "") : query(q), error(err), id(i), finished_query(fq) { }
inline operator bool() const { return this->error.empty(); } inline operator bool() const { return this->error.empty(); }
inline const unsigned int GetID() const { return this->id; } inline unsigned int GetID() const { return this->id; }
inline const Query &GetQuery() const { return this->query; } inline const Query &GetQuery() const { return this->query; }
inline const Anope::string &GetError() const { return this->error; } inline const Anope::string &GetError() const { return this->error; }
@@ -182,11 +188,11 @@ namespace SQL
*/ */
class Interface class Interface
{ {
public: public:
Module *owner; Module *owner;
Interface(Module *m) : owner(m) { } Interface(Module *m) : owner(m) { }
virtual ~Interface() { } virtual ~Interface() = default;
virtual void OnResult(const Result &r) = 0; virtual void OnResult(const Result &r) = 0;
virtual void OnError(const Result &r) = 0; virtual void OnError(const Result &r) = 0;
@@ -194,9 +200,10 @@ namespace SQL
/** Class providing the SQL service, modules call this to execute queries /** Class providing the SQL service, modules call this to execute queries
*/ */
class Provider : public Service class Provider
: public Service
{ {
public: public:
Provider(Module *c, const Anope::string &n) : Service(c, "SQL::Provider", n) { } Provider(Module *c, const Anope::string &n) : Service(c, "SQL::Provider", n) { }
virtual void Run(Interface *i, const Query &query) = 0; virtual void Run(Interface *i, const Query &query) = 0;
@@ -213,4 +220,3 @@ namespace SQL
}; };
} }
+13 -4
View File
@@ -1,9 +1,18 @@
/*
*
* (C) 2010-2024 Anope Team
* Contact us at team@anope.org
*
* Please read COPYING and README for further details.
*/
class SSLService : public Service #pragma once
class SSLService
: public Service
{ {
public: public:
SSLService(Module *o, const Anope::string &n) : Service(o, "SSLService", n) { } SSLService(Module *o, const Anope::string &n) : Service(o, "SSLService", n) { }
virtual void Init(Socket *s) = 0; virtual void Init(Socket *s) = 0;
}; };
+6 -3
View File
@@ -1,5 +1,6 @@
/* /*
* (C) 2003-2014 Anope Team *
* (C) 2003-2024 Anope Team
* Contact us at team@anope.org * Contact us at team@anope.org
* *
* Please read COPYING and README for further details. * Please read COPYING and README for further details.
@@ -8,11 +9,13 @@
* Based on the original code of Services by Andy Church. * Based on the original code of Services by Andy Church.
*/ */
#pragma once
struct SuspendInfo struct SuspendInfo
{ {
Anope::string what, by, reason; Anope::string what, by, reason;
time_t when, expires; time_t when, expires;
SuspendInfo() { } SuspendInfo() = default;
virtual ~SuspendInfo() { } virtual ~SuspendInfo() = default;
}; };

Some files were not shown because too many files have changed in this diff Show More