Compare commits
15 Commits
0.0.15
...
3.8.3+hotf
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
b96401de8a | ||
|
|
7b65537e14 | ||
|
|
4b4b580d71 | ||
|
|
b46fb1a1d9 | ||
|
|
5ee8870d96 | ||
|
|
375bd6fcde | ||
|
|
1ca0ee7aaf | ||
|
|
622576295e | ||
|
|
5c13d83cc1 | ||
|
|
8beb75eb75 | ||
|
|
ab67f7fa10 | ||
|
|
c2bf30e268 | ||
|
|
a9567886b4 | ||
|
|
78979b424b | ||
|
|
95ececeba0 |
@@ -1,3 +1,11 @@
|
|||||||
|
## 3.8.3+hotfix.7
|
||||||
|
|
||||||
|
- [Bug fixes and performance enhancements.](https://github.com/openimsdk/openim-sdk-core/releases/tag/v3.8.3-patch.7)
|
||||||
|
|
||||||
|
## 3.8.3+3
|
||||||
|
|
||||||
|
- [Bug fixes and performance enhancements.](https://github.com/openimsdk/openim-sdk-core/releases/tag/v3.8.3-patch.3)
|
||||||
|
|
||||||
## 3.8.2
|
## 3.8.2
|
||||||
|
|
||||||
- [Bug fixes and performance enhancements.](https://github.com/openimsdk/openim-sdk-core/releases/tag/v3.8.2)
|
- [Bug fixes and performance enhancements.](https://github.com/openimsdk/openim-sdk-core/releases/tag/v3.8.2)
|
||||||
|
|||||||
674
LICENSE
674
LICENSE
@@ -1,21 +1,661 @@
|
|||||||
MIT License
|
GNU AFFERO GENERAL PUBLIC LICENSE
|
||||||
|
Version 3, 19 November 2007
|
||||||
|
|
||||||
Copyright (c) 2018 OpenIM Corporation
|
Copyright (C) 2007 Free Software Foundation, Inc. <https://fsf.org/>
|
||||||
|
Everyone is permitted to copy and distribute verbatim copies
|
||||||
|
of this license document, but changing it is not allowed.
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
Preamble
|
||||||
of this software and associated documentation files (the "Software"), to deal
|
|
||||||
in the Software without restriction, including without limitation the rights
|
|
||||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
||||||
copies of the Software, and to permit persons to whom the Software is
|
|
||||||
furnished to do so, subject to the following conditions:
|
|
||||||
|
|
||||||
The above copyright notice and this permission notice shall be included in all
|
The GNU Affero General Public License is a free, copyleft license for
|
||||||
copies or substantial portions of the Software.
|
software and other kinds of works, specifically designed to ensure
|
||||||
|
cooperation with the community in the case of network server software.
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
The licenses for most software and other practical works are designed
|
||||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
to take away your freedom to share and change the works. By contrast,
|
||||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
our General Public Licenses are intended to guarantee your freedom to
|
||||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
share and change all versions of a program--to make sure it remains free
|
||||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
software for all its users.
|
||||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
||||||
SOFTWARE.
|
When we speak of free software, we are referring to freedom, not
|
||||||
|
price. Our General Public Licenses are designed to make sure that you
|
||||||
|
have the freedom to distribute copies of free software (and charge for
|
||||||
|
them if you wish), that you receive source code or can get it if you
|
||||||
|
want it, that you can change the software or use pieces of it in new
|
||||||
|
free programs, and that you know you can do these things.
|
||||||
|
|
||||||
|
Developers that use our General Public Licenses protect your rights
|
||||||
|
with two steps: (1) assert copyright on the software, and (2) offer
|
||||||
|
you this License which gives you legal permission to copy, distribute
|
||||||
|
and/or modify the software.
|
||||||
|
|
||||||
|
A secondary benefit of defending all users' freedom is that
|
||||||
|
improvements made in alternate versions of the program, if they
|
||||||
|
receive widespread use, become available for other developers to
|
||||||
|
incorporate. Many developers of free software are heartened and
|
||||||
|
encouraged by the resulting cooperation. However, in the case of
|
||||||
|
software used on network servers, this result may fail to come about.
|
||||||
|
The GNU General Public License permits making a modified version and
|
||||||
|
letting the public access it on a server without ever releasing its
|
||||||
|
source code to the public.
|
||||||
|
|
||||||
|
The GNU Affero General Public License is designed specifically to
|
||||||
|
ensure that, in such cases, the modified source code becomes available
|
||||||
|
to the community. It requires the operator of a network server to
|
||||||
|
provide the source code of the modified version running there to the
|
||||||
|
users of that server. Therefore, public use of a modified version, on
|
||||||
|
a publicly accessible server, gives the public access to the source
|
||||||
|
code of the modified version.
|
||||||
|
|
||||||
|
An older license, called the Affero General Public License and
|
||||||
|
published by Affero, was designed to accomplish similar goals. This is
|
||||||
|
a different license, not a version of the Affero GPL, but Affero has
|
||||||
|
released a new version of the Affero GPL which permits relicensing under
|
||||||
|
this license.
|
||||||
|
|
||||||
|
The precise terms and conditions for copying, distribution and
|
||||||
|
modification follow.
|
||||||
|
|
||||||
|
TERMS AND CONDITIONS
|
||||||
|
|
||||||
|
0. Definitions.
|
||||||
|
|
||||||
|
"This License" refers to version 3 of the GNU Affero General Public License.
|
||||||
|
|
||||||
|
"Copyright" also means copyright-like laws that apply to other kinds of
|
||||||
|
works, such as semiconductor masks.
|
||||||
|
|
||||||
|
"The Program" refers to any copyrightable work licensed under this
|
||||||
|
License. Each licensee is addressed as "you". "Licensees" and
|
||||||
|
"recipients" may be individuals or organizations.
|
||||||
|
|
||||||
|
To "modify" a work means to copy from or adapt all or part of the work
|
||||||
|
in a fashion requiring copyright permission, other than the making of an
|
||||||
|
exact copy. The resulting work is called a "modified version" of the
|
||||||
|
earlier work or a work "based on" the earlier work.
|
||||||
|
|
||||||
|
A "covered work" means either the unmodified Program or a work based
|
||||||
|
on the Program.
|
||||||
|
|
||||||
|
To "propagate" a work means to do anything with it that, without
|
||||||
|
permission, would make you directly or secondarily liable for
|
||||||
|
infringement under applicable copyright law, except executing it on a
|
||||||
|
computer or modifying a private copy. Propagation includes copying,
|
||||||
|
distribution (with or without modification), making available to the
|
||||||
|
public, and in some countries other activities as well.
|
||||||
|
|
||||||
|
To "convey" a work means any kind of propagation that enables other
|
||||||
|
parties to make or receive copies. Mere interaction with a user through
|
||||||
|
a computer network, with no transfer of a copy, is not conveying.
|
||||||
|
|
||||||
|
An interactive user interface displays "Appropriate Legal Notices"
|
||||||
|
to the extent that it includes a convenient and prominently visible
|
||||||
|
feature that (1) displays an appropriate copyright notice, and (2)
|
||||||
|
tells the user that there is no warranty for the work (except to the
|
||||||
|
extent that warranties are provided), that licensees may convey the
|
||||||
|
work under this License, and how to view a copy of this License. If
|
||||||
|
the interface presents a list of user commands or options, such as a
|
||||||
|
menu, a prominent item in the list meets this criterion.
|
||||||
|
|
||||||
|
1. Source Code.
|
||||||
|
|
||||||
|
The "source code" for a work means the preferred form of the work
|
||||||
|
for making modifications to it. "Object code" means any non-source
|
||||||
|
form of a work.
|
||||||
|
|
||||||
|
A "Standard Interface" means an interface that either is an official
|
||||||
|
standard defined by a recognized standards body, or, in the case of
|
||||||
|
interfaces specified for a particular programming language, one that
|
||||||
|
is widely used among developers working in that language.
|
||||||
|
|
||||||
|
The "System Libraries" of an executable work include anything, other
|
||||||
|
than the work as a whole, that (a) is included in the normal form of
|
||||||
|
packaging a Major Component, but which is not part of that Major
|
||||||
|
Component, and (b) serves only to enable use of the work with that
|
||||||
|
Major Component, or to implement a Standard Interface for which an
|
||||||
|
implementation is available to the public in source code form. A
|
||||||
|
"Major Component", in this context, means a major essential component
|
||||||
|
(kernel, window system, and so on) of the specific operating system
|
||||||
|
(if any) on which the executable work runs, or a compiler used to
|
||||||
|
produce the work, or an object code interpreter used to run it.
|
||||||
|
|
||||||
|
The "Corresponding Source" for a work in object code form means all
|
||||||
|
the source code needed to generate, install, and (for an executable
|
||||||
|
work) run the object code and to modify the work, including scripts to
|
||||||
|
control those activities. However, it does not include the work's
|
||||||
|
System Libraries, or general-purpose tools or generally available free
|
||||||
|
programs which are used unmodified in performing those activities but
|
||||||
|
which are not part of the work. For example, Corresponding Source
|
||||||
|
includes interface definition files associated with source files for
|
||||||
|
the work, and the source code for shared libraries and dynamically
|
||||||
|
linked subprograms that the work is specifically designed to require,
|
||||||
|
such as by intimate data communication or control flow between those
|
||||||
|
subprograms and other parts of the work.
|
||||||
|
|
||||||
|
The Corresponding Source need not include anything that users
|
||||||
|
can regenerate automatically from other parts of the Corresponding
|
||||||
|
Source.
|
||||||
|
|
||||||
|
The Corresponding Source for a work in source code form is that
|
||||||
|
same work.
|
||||||
|
|
||||||
|
2. Basic Permissions.
|
||||||
|
|
||||||
|
All rights granted under this License are granted for the term of
|
||||||
|
copyright on the Program, and are irrevocable provided the stated
|
||||||
|
conditions are met. This License explicitly affirms your unlimited
|
||||||
|
permission to run the unmodified Program. The output from running a
|
||||||
|
covered work is covered by this License only if the output, given its
|
||||||
|
content, constitutes a covered work. This License acknowledges your
|
||||||
|
rights of fair use or other equivalent, as provided by copyright law.
|
||||||
|
|
||||||
|
You may make, run and propagate covered works that you do not
|
||||||
|
convey, without conditions so long as your license otherwise remains
|
||||||
|
in force. You may convey covered works to others for the sole purpose
|
||||||
|
of having them make modifications exclusively for you, or provide you
|
||||||
|
with facilities for running those works, provided that you comply with
|
||||||
|
the terms of this License in conveying all material for which you do
|
||||||
|
not control copyright. Those thus making or running the covered works
|
||||||
|
for you must do so exclusively on your behalf, under your direction
|
||||||
|
and control, on terms that prohibit them from making any copies of
|
||||||
|
your copyrighted material outside their relationship with you.
|
||||||
|
|
||||||
|
Conveying under any other circumstances is permitted solely under
|
||||||
|
the conditions stated below. Sublicensing is not allowed; section 10
|
||||||
|
makes it unnecessary.
|
||||||
|
|
||||||
|
3. Protecting Users' Legal Rights From Anti-Circumvention Law.
|
||||||
|
|
||||||
|
No covered work shall be deemed part of an effective technological
|
||||||
|
measure under any applicable law fulfilling obligations under article
|
||||||
|
11 of the WIPO copyright treaty adopted on 20 December 1996, or
|
||||||
|
similar laws prohibiting or restricting circumvention of such
|
||||||
|
measures.
|
||||||
|
|
||||||
|
When you convey a covered work, you waive any legal power to forbid
|
||||||
|
circumvention of technological measures to the extent such circumvention
|
||||||
|
is effected by exercising rights under this License with respect to
|
||||||
|
the covered work, and you disclaim any intention to limit operation or
|
||||||
|
modification of the work as a means of enforcing, against the work's
|
||||||
|
users, your or third parties' legal rights to forbid circumvention of
|
||||||
|
technological measures.
|
||||||
|
|
||||||
|
4. Conveying Verbatim Copies.
|
||||||
|
|
||||||
|
You may convey verbatim copies of the Program's source code as you
|
||||||
|
receive it, in any medium, provided that you conspicuously and
|
||||||
|
appropriately publish on each copy an appropriate copyright notice;
|
||||||
|
keep intact all notices stating that this License and any
|
||||||
|
non-permissive terms added in accord with section 7 apply to the code;
|
||||||
|
keep intact all notices of the absence of any warranty; and give all
|
||||||
|
recipients a copy of this License along with the Program.
|
||||||
|
|
||||||
|
You may charge any price or no price for each copy that you convey,
|
||||||
|
and you may offer support or warranty protection for a fee.
|
||||||
|
|
||||||
|
5. Conveying Modified Source Versions.
|
||||||
|
|
||||||
|
You may convey a work based on the Program, or the modifications to
|
||||||
|
produce it from the Program, in the form of source code under the
|
||||||
|
terms of section 4, provided that you also meet all of these conditions:
|
||||||
|
|
||||||
|
a) The work must carry prominent notices stating that you modified
|
||||||
|
it, and giving a relevant date.
|
||||||
|
|
||||||
|
b) The work must carry prominent notices stating that it is
|
||||||
|
released under this License and any conditions added under section
|
||||||
|
7. This requirement modifies the requirement in section 4 to
|
||||||
|
"keep intact all notices".
|
||||||
|
|
||||||
|
c) You must license the entire work, as a whole, under this
|
||||||
|
License to anyone who comes into possession of a copy. This
|
||||||
|
License will therefore apply, along with any applicable section 7
|
||||||
|
additional terms, to the whole of the work, and all its parts,
|
||||||
|
regardless of how they are packaged. This License gives no
|
||||||
|
permission to license the work in any other way, but it does not
|
||||||
|
invalidate such permission if you have separately received it.
|
||||||
|
|
||||||
|
d) If the work has interactive user interfaces, each must display
|
||||||
|
Appropriate Legal Notices; however, if the Program has interactive
|
||||||
|
interfaces that do not display Appropriate Legal Notices, your
|
||||||
|
work need not make them do so.
|
||||||
|
|
||||||
|
A compilation of a covered work with other separate and independent
|
||||||
|
works, which are not by their nature extensions of the covered work,
|
||||||
|
and which are not combined with it such as to form a larger program,
|
||||||
|
in or on a volume of a storage or distribution medium, is called an
|
||||||
|
"aggregate" if the compilation and its resulting copyright are not
|
||||||
|
used to limit the access or legal rights of the compilation's users
|
||||||
|
beyond what the individual works permit. Inclusion of a covered work
|
||||||
|
in an aggregate does not cause this License to apply to the other
|
||||||
|
parts of the aggregate.
|
||||||
|
|
||||||
|
6. Conveying Non-Source Forms.
|
||||||
|
|
||||||
|
You may convey a covered work in object code form under the terms
|
||||||
|
of sections 4 and 5, provided that you also convey the
|
||||||
|
machine-readable Corresponding Source under the terms of this License,
|
||||||
|
in one of these ways:
|
||||||
|
|
||||||
|
a) Convey the object code in, or embodied in, a physical product
|
||||||
|
(including a physical distribution medium), accompanied by the
|
||||||
|
Corresponding Source fixed on a durable physical medium
|
||||||
|
customarily used for software interchange.
|
||||||
|
|
||||||
|
b) Convey the object code in, or embodied in, a physical product
|
||||||
|
(including a physical distribution medium), accompanied by a
|
||||||
|
written offer, valid for at least three years and valid for as
|
||||||
|
long as you offer spare parts or customer support for that product
|
||||||
|
model, to give anyone who possesses the object code either (1) a
|
||||||
|
copy of the Corresponding Source for all the software in the
|
||||||
|
product that is covered by this License, on a durable physical
|
||||||
|
medium customarily used for software interchange, for a price no
|
||||||
|
more than your reasonable cost of physically performing this
|
||||||
|
conveying of source, or (2) access to copy the
|
||||||
|
Corresponding Source from a network server at no charge.
|
||||||
|
|
||||||
|
c) Convey individual copies of the object code with a copy of the
|
||||||
|
written offer to provide the Corresponding Source. This
|
||||||
|
alternative is allowed only occasionally and noncommercially, and
|
||||||
|
only if you received the object code with such an offer, in accord
|
||||||
|
with subsection 6b.
|
||||||
|
|
||||||
|
d) Convey the object code by offering access from a designated
|
||||||
|
place (gratis or for a charge), and offer equivalent access to the
|
||||||
|
Corresponding Source in the same way through the same place at no
|
||||||
|
further charge. You need not require recipients to copy the
|
||||||
|
Corresponding Source along with the object code. If the place to
|
||||||
|
copy the object code is a network server, the Corresponding Source
|
||||||
|
may be on a different server (operated by you or a third party)
|
||||||
|
that supports equivalent copying facilities, provided you maintain
|
||||||
|
clear directions next to the object code saying where to find the
|
||||||
|
Corresponding Source. Regardless of what server hosts the
|
||||||
|
Corresponding Source, you remain obligated to ensure that it is
|
||||||
|
available for as long as needed to satisfy these requirements.
|
||||||
|
|
||||||
|
e) Convey the object code using peer-to-peer transmission, provided
|
||||||
|
you inform other peers where the object code and Corresponding
|
||||||
|
Source of the work are being offered to the general public at no
|
||||||
|
charge under subsection 6d.
|
||||||
|
|
||||||
|
A separable portion of the object code, whose source code is excluded
|
||||||
|
from the Corresponding Source as a System Library, need not be
|
||||||
|
included in conveying the object code work.
|
||||||
|
|
||||||
|
A "User Product" is either (1) a "consumer product", which means any
|
||||||
|
tangible personal property which is normally used for personal, family,
|
||||||
|
or household purposes, or (2) anything designed or sold for incorporation
|
||||||
|
into a dwelling. In determining whether a product is a consumer product,
|
||||||
|
doubtful cases shall be resolved in favor of coverage. For a particular
|
||||||
|
product received by a particular user, "normally used" refers to a
|
||||||
|
typical or common use of that class of product, regardless of the status
|
||||||
|
of the particular user or of the way in which the particular user
|
||||||
|
actually uses, or expects or is expected to use, the product. A product
|
||||||
|
is a consumer product regardless of whether the product has substantial
|
||||||
|
commercial, industrial or non-consumer uses, unless such uses represent
|
||||||
|
the only significant mode of use of the product.
|
||||||
|
|
||||||
|
"Installation Information" for a User Product means any methods,
|
||||||
|
procedures, authorization keys, or other information required to install
|
||||||
|
and execute modified versions of a covered work in that User Product from
|
||||||
|
a modified version of its Corresponding Source. The information must
|
||||||
|
suffice to ensure that the continued functioning of the modified object
|
||||||
|
code is in no case prevented or interfered with solely because
|
||||||
|
modification has been made.
|
||||||
|
|
||||||
|
If you convey an object code work under this section in, or with, or
|
||||||
|
specifically for use in, a User Product, and the conveying occurs as
|
||||||
|
part of a transaction in which the right of possession and use of the
|
||||||
|
User Product is transferred to the recipient in perpetuity or for a
|
||||||
|
fixed term (regardless of how the transaction is characterized), the
|
||||||
|
Corresponding Source conveyed under this section must be accompanied
|
||||||
|
by the Installation Information. But this requirement does not apply
|
||||||
|
if neither you nor any third party retains the ability to install
|
||||||
|
modified object code on the User Product (for example, the work has
|
||||||
|
been installed in ROM).
|
||||||
|
|
||||||
|
The requirement to provide Installation Information does not include a
|
||||||
|
requirement to continue to provide support service, warranty, or updates
|
||||||
|
for a work that has been modified or installed by the recipient, or for
|
||||||
|
the User Product in which it has been modified or installed. Access to a
|
||||||
|
network may be denied when the modification itself materially and
|
||||||
|
adversely affects the operation of the network or violates the rules and
|
||||||
|
protocols for communication across the network.
|
||||||
|
|
||||||
|
Corresponding Source conveyed, and Installation Information provided,
|
||||||
|
in accord with this section must be in a format that is publicly
|
||||||
|
documented (and with an implementation available to the public in
|
||||||
|
source code form), and must require no special password or key for
|
||||||
|
unpacking, reading or copying.
|
||||||
|
|
||||||
|
7. Additional Terms.
|
||||||
|
|
||||||
|
"Additional permissions" are terms that supplement the terms of this
|
||||||
|
License by making exceptions from one or more of its conditions.
|
||||||
|
Additional permissions that are applicable to the entire Program shall
|
||||||
|
be treated as though they were included in this License, to the extent
|
||||||
|
that they are valid under applicable law. If additional permissions
|
||||||
|
apply only to part of the Program, that part may be used separately
|
||||||
|
under those permissions, but the entire Program remains governed by
|
||||||
|
this License without regard to the additional permissions.
|
||||||
|
|
||||||
|
When you convey a copy of a covered work, you may at your option
|
||||||
|
remove any additional permissions from that copy, or from any part of
|
||||||
|
it. (Additional permissions may be written to require their own
|
||||||
|
removal in certain cases when you modify the work.) You may place
|
||||||
|
additional permissions on material, added by you to a covered work,
|
||||||
|
for which you have or can give appropriate copyright permission.
|
||||||
|
|
||||||
|
Notwithstanding any other provision of this License, for material you
|
||||||
|
add to a covered work, you may (if authorized by the copyright holders of
|
||||||
|
that material) supplement the terms of this License with terms:
|
||||||
|
|
||||||
|
a) Disclaiming warranty or limiting liability differently from the
|
||||||
|
terms of sections 15 and 16 of this License; or
|
||||||
|
|
||||||
|
b) Requiring preservation of specified reasonable legal notices or
|
||||||
|
author attributions in that material or in the Appropriate Legal
|
||||||
|
Notices displayed by works containing it; or
|
||||||
|
|
||||||
|
c) Prohibiting misrepresentation of the origin of that material, or
|
||||||
|
requiring that modified versions of such material be marked in
|
||||||
|
reasonable ways as different from the original version; or
|
||||||
|
|
||||||
|
d) Limiting the use for publicity purposes of names of licensors or
|
||||||
|
authors of the material; or
|
||||||
|
|
||||||
|
e) Declining to grant rights under trademark law for use of some
|
||||||
|
trade names, trademarks, or service marks; or
|
||||||
|
|
||||||
|
f) Requiring indemnification of licensors and authors of that
|
||||||
|
material by anyone who conveys the material (or modified versions of
|
||||||
|
it) with contractual assumptions of liability to the recipient, for
|
||||||
|
any liability that these contractual assumptions directly impose on
|
||||||
|
those licensors and authors.
|
||||||
|
|
||||||
|
All other non-permissive additional terms are considered "further
|
||||||
|
restrictions" within the meaning of section 10. If the Program as you
|
||||||
|
received it, or any part of it, contains a notice stating that it is
|
||||||
|
governed by this License along with a term that is a further
|
||||||
|
restriction, you may remove that term. If a license document contains
|
||||||
|
a further restriction but permits relicensing or conveying under this
|
||||||
|
License, you may add to a covered work material governed by the terms
|
||||||
|
of that license document, provided that the further restriction does
|
||||||
|
not survive such relicensing or conveying.
|
||||||
|
|
||||||
|
If you add terms to a covered work in accord with this section, you
|
||||||
|
must place, in the relevant source files, a statement of the
|
||||||
|
additional terms that apply to those files, or a notice indicating
|
||||||
|
where to find the applicable terms.
|
||||||
|
|
||||||
|
Additional terms, permissive or non-permissive, may be stated in the
|
||||||
|
form of a separately written license, or stated as exceptions;
|
||||||
|
the above requirements apply either way.
|
||||||
|
|
||||||
|
8. Termination.
|
||||||
|
|
||||||
|
You may not propagate or modify a covered work except as expressly
|
||||||
|
provided under this License. Any attempt otherwise to propagate or
|
||||||
|
modify it is void, and will automatically terminate your rights under
|
||||||
|
this License (including any patent licenses granted under the third
|
||||||
|
paragraph of section 11).
|
||||||
|
|
||||||
|
However, if you cease all violation of this License, then your
|
||||||
|
license from a particular copyright holder is reinstated (a)
|
||||||
|
provisionally, unless and until the copyright holder explicitly and
|
||||||
|
finally terminates your license, and (b) permanently, if the copyright
|
||||||
|
holder fails to notify you of the violation by some reasonable means
|
||||||
|
prior to 60 days after the cessation.
|
||||||
|
|
||||||
|
Moreover, your license from a particular copyright holder is
|
||||||
|
reinstated permanently if the copyright holder notifies you of the
|
||||||
|
violation by some reasonable means, this is the first time you have
|
||||||
|
received notice of violation of this License (for any work) from that
|
||||||
|
copyright holder, and you cure the violation prior to 30 days after
|
||||||
|
your receipt of the notice.
|
||||||
|
|
||||||
|
Termination of your rights under this section does not terminate the
|
||||||
|
licenses of parties who have received copies or rights from you under
|
||||||
|
this License. If your rights have been terminated and not permanently
|
||||||
|
reinstated, you do not qualify to receive new licenses for the same
|
||||||
|
material under section 10.
|
||||||
|
|
||||||
|
9. Acceptance Not Required for Having Copies.
|
||||||
|
|
||||||
|
You are not required to accept this License in order to receive or
|
||||||
|
run a copy of the Program. Ancillary propagation of a covered work
|
||||||
|
occurring solely as a consequence of using peer-to-peer transmission
|
||||||
|
to receive a copy likewise does not require acceptance. However,
|
||||||
|
nothing other than this License grants you permission to propagate or
|
||||||
|
modify any covered work. These actions infringe copyright if you do
|
||||||
|
not accept this License. Therefore, by modifying or propagating a
|
||||||
|
covered work, you indicate your acceptance of this License to do so.
|
||||||
|
|
||||||
|
10. Automatic Licensing of Downstream Recipients.
|
||||||
|
|
||||||
|
Each time you convey a covered work, the recipient automatically
|
||||||
|
receives a license from the original licensors, to run, modify and
|
||||||
|
propagate that work, subject to this License. You are not responsible
|
||||||
|
for enforcing compliance by third parties with this License.
|
||||||
|
|
||||||
|
An "entity transaction" is a transaction transferring control of an
|
||||||
|
organization, or substantially all assets of one, or subdividing an
|
||||||
|
organization, or merging organizations. If propagation of a covered
|
||||||
|
work results from an entity transaction, each party to that
|
||||||
|
transaction who receives a copy of the work also receives whatever
|
||||||
|
licenses to the work the party's predecessor in interest had or could
|
||||||
|
give under the previous paragraph, plus a right to possession of the
|
||||||
|
Corresponding Source of the work from the predecessor in interest, if
|
||||||
|
the predecessor has it or can get it with reasonable efforts.
|
||||||
|
|
||||||
|
You may not impose any further restrictions on the exercise of the
|
||||||
|
rights granted or affirmed under this License. For example, you may
|
||||||
|
not impose a license fee, royalty, or other charge for exercise of
|
||||||
|
rights granted under this License, and you may not initiate litigation
|
||||||
|
(including a cross-claim or counterclaim in a lawsuit) alleging that
|
||||||
|
any patent claim is infringed by making, using, selling, offering for
|
||||||
|
sale, or importing the Program or any portion of it.
|
||||||
|
|
||||||
|
11. Patents.
|
||||||
|
|
||||||
|
A "contributor" is a copyright holder who authorizes use under this
|
||||||
|
License of the Program or a work on which the Program is based. The
|
||||||
|
work thus licensed is called the contributor's "contributor version".
|
||||||
|
|
||||||
|
A contributor's "essential patent claims" are all patent claims
|
||||||
|
owned or controlled by the contributor, whether already acquired or
|
||||||
|
hereafter acquired, that would be infringed by some manner, permitted
|
||||||
|
by this License, of making, using, or selling its contributor version,
|
||||||
|
but do not include claims that would be infringed only as a
|
||||||
|
consequence of further modification of the contributor version. For
|
||||||
|
purposes of this definition, "control" includes the right to grant
|
||||||
|
patent sublicenses in a manner consistent with the requirements of
|
||||||
|
this License.
|
||||||
|
|
||||||
|
Each contributor grants you a non-exclusive, worldwide, royalty-free
|
||||||
|
patent license under the contributor's essential patent claims, to
|
||||||
|
make, use, sell, offer for sale, import and otherwise run, modify and
|
||||||
|
propagate the contents of its contributor version.
|
||||||
|
|
||||||
|
In the following three paragraphs, a "patent license" is any express
|
||||||
|
agreement or commitment, however denominated, not to enforce a patent
|
||||||
|
(such as an express permission to practice a patent or covenant not to
|
||||||
|
sue for patent infringement). To "grant" such a patent license to a
|
||||||
|
party means to make such an agreement or commitment not to enforce a
|
||||||
|
patent against the party.
|
||||||
|
|
||||||
|
If you convey a covered work, knowingly relying on a patent license,
|
||||||
|
and the Corresponding Source of the work is not available for anyone
|
||||||
|
to copy, free of charge and under the terms of this License, through a
|
||||||
|
publicly available network server or other readily accessible means,
|
||||||
|
then you must either (1) cause the Corresponding Source to be so
|
||||||
|
available, or (2) arrange to deprive yourself of the benefit of the
|
||||||
|
patent license for this particular work, or (3) arrange, in a manner
|
||||||
|
consistent with the requirements of this License, to extend the patent
|
||||||
|
license to downstream recipients. "Knowingly relying" means you have
|
||||||
|
actual knowledge that, but for the patent license, your conveying the
|
||||||
|
covered work in a country, or your recipient's use of the covered work
|
||||||
|
in a country, would infringe one or more identifiable patents in that
|
||||||
|
country that you have reason to believe are valid.
|
||||||
|
|
||||||
|
If, pursuant to or in connection with a single transaction or
|
||||||
|
arrangement, you convey, or propagate by procuring conveyance of, a
|
||||||
|
covered work, and grant a patent license to some of the parties
|
||||||
|
receiving the covered work authorizing them to use, propagate, modify
|
||||||
|
or convey a specific copy of the covered work, then the patent license
|
||||||
|
you grant is automatically extended to all recipients of the covered
|
||||||
|
work and works based on it.
|
||||||
|
|
||||||
|
A patent license is "discriminatory" if it does not include within
|
||||||
|
the scope of its coverage, prohibits the exercise of, or is
|
||||||
|
conditioned on the non-exercise of one or more of the rights that are
|
||||||
|
specifically granted under this License. You may not convey a covered
|
||||||
|
work if you are a party to an arrangement with a third party that is
|
||||||
|
in the business of distributing software, under which you make payment
|
||||||
|
to the third party based on the extent of your activity of conveying
|
||||||
|
the work, and under which the third party grants, to any of the
|
||||||
|
parties who would receive the covered work from you, a discriminatory
|
||||||
|
patent license (a) in connection with copies of the covered work
|
||||||
|
conveyed by you (or copies made from those copies), or (b) primarily
|
||||||
|
for and in connection with specific products or compilations that
|
||||||
|
contain the covered work, unless you entered into that arrangement,
|
||||||
|
or that patent license was granted, prior to 28 March 2007.
|
||||||
|
|
||||||
|
Nothing in this License shall be construed as excluding or limiting
|
||||||
|
any implied license or other defenses to infringement that may
|
||||||
|
otherwise be available to you under applicable patent law.
|
||||||
|
|
||||||
|
12. No Surrender of Others' Freedom.
|
||||||
|
|
||||||
|
If conditions are imposed on you (whether by court order, agreement or
|
||||||
|
otherwise) that contradict the conditions of this License, they do not
|
||||||
|
excuse you from the conditions of this License. If you cannot convey a
|
||||||
|
covered work so as to satisfy simultaneously your obligations under this
|
||||||
|
License and any other pertinent obligations, then as a consequence you may
|
||||||
|
not convey it at all. For example, if you agree to terms that obligate you
|
||||||
|
to collect a royalty for further conveying from those to whom you convey
|
||||||
|
the Program, the only way you could satisfy both those terms and this
|
||||||
|
License would be to refrain entirely from conveying the Program.
|
||||||
|
|
||||||
|
13. Remote Network Interaction; Use with the GNU General Public License.
|
||||||
|
|
||||||
|
Notwithstanding any other provision of this License, if you modify the
|
||||||
|
Program, your modified version must prominently offer all users
|
||||||
|
interacting with it remotely through a computer network (if your version
|
||||||
|
supports such interaction) an opportunity to receive the Corresponding
|
||||||
|
Source of your version by providing access to the Corresponding Source
|
||||||
|
from a network server at no charge, through some standard or customary
|
||||||
|
means of facilitating copying of software. This Corresponding Source
|
||||||
|
shall include the Corresponding Source for any work covered by version 3
|
||||||
|
of the GNU General Public License that is incorporated pursuant to the
|
||||||
|
following paragraph.
|
||||||
|
|
||||||
|
Notwithstanding any other provision of this License, you have
|
||||||
|
permission to link or combine any covered work with a work licensed
|
||||||
|
under version 3 of the GNU General Public License into a single
|
||||||
|
combined work, and to convey the resulting work. The terms of this
|
||||||
|
License will continue to apply to the part which is the covered work,
|
||||||
|
but the work with which it is combined will remain governed by version
|
||||||
|
3 of the GNU General Public License.
|
||||||
|
|
||||||
|
14. Revised Versions of this License.
|
||||||
|
|
||||||
|
The Free Software Foundation may publish revised and/or new versions of
|
||||||
|
the GNU Affero General Public License from time to time. Such new versions
|
||||||
|
will be similar in spirit to the present version, but may differ in detail to
|
||||||
|
address new problems or concerns.
|
||||||
|
|
||||||
|
Each version is given a distinguishing version number. If the
|
||||||
|
Program specifies that a certain numbered version of the GNU Affero General
|
||||||
|
Public License "or any later version" applies to it, you have the
|
||||||
|
option of following the terms and conditions either of that numbered
|
||||||
|
version or of any later version published by the Free Software
|
||||||
|
Foundation. If the Program does not specify a version number of the
|
||||||
|
GNU Affero General Public License, you may choose any version ever published
|
||||||
|
by the Free Software Foundation.
|
||||||
|
|
||||||
|
If the Program specifies that a proxy can decide which future
|
||||||
|
versions of the GNU Affero General Public License can be used, that proxy's
|
||||||
|
public statement of acceptance of a version permanently authorizes you
|
||||||
|
to choose that version for the Program.
|
||||||
|
|
||||||
|
Later license versions may give you additional or different
|
||||||
|
permissions. However, no additional obligations are imposed on any
|
||||||
|
author or copyright holder as a result of your choosing to follow a
|
||||||
|
later version.
|
||||||
|
|
||||||
|
15. Disclaimer of Warranty.
|
||||||
|
|
||||||
|
THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY
|
||||||
|
APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT
|
||||||
|
HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY
|
||||||
|
OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO,
|
||||||
|
THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
||||||
|
PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM
|
||||||
|
IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF
|
||||||
|
ALL NECESSARY SERVICING, REPAIR OR CORRECTION.
|
||||||
|
|
||||||
|
16. Limitation of Liability.
|
||||||
|
|
||||||
|
IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
|
||||||
|
WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS
|
||||||
|
THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY
|
||||||
|
GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE
|
||||||
|
USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF
|
||||||
|
DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD
|
||||||
|
PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS),
|
||||||
|
EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF
|
||||||
|
SUCH DAMAGES.
|
||||||
|
|
||||||
|
17. Interpretation of Sections 15 and 16.
|
||||||
|
|
||||||
|
If the disclaimer of warranty and limitation of liability provided
|
||||||
|
above cannot be given local legal effect according to their terms,
|
||||||
|
reviewing courts shall apply local law that most closely approximates
|
||||||
|
an absolute waiver of all civil liability in connection with the
|
||||||
|
Program, unless a warranty or assumption of liability accompanies a
|
||||||
|
copy of the Program in return for a fee.
|
||||||
|
|
||||||
|
END OF TERMS AND CONDITIONS
|
||||||
|
|
||||||
|
How to Apply These Terms to Your New Programs
|
||||||
|
|
||||||
|
If you develop a new program, and you want it to be of the greatest
|
||||||
|
possible use to the public, the best way to achieve this is to make it
|
||||||
|
free software which everyone can redistribute and change under these terms.
|
||||||
|
|
||||||
|
To do so, attach the following notices to the program. It is safest
|
||||||
|
to attach them to the start of each source file to most effectively
|
||||||
|
state the exclusion of warranty; and each file should have at least
|
||||||
|
the "copyright" line and a pointer to where the full notice is found.
|
||||||
|
|
||||||
|
<one line to give the program's name and a brief idea of what it does.>
|
||||||
|
Copyright (C) <year> <name of author>
|
||||||
|
|
||||||
|
This program is free software: you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU Affero General Public License as published
|
||||||
|
by the Free Software Foundation, either version 3 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
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 FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU Affero General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Affero General Public License
|
||||||
|
along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
Also add information on how to contact you by electronic and paper mail.
|
||||||
|
|
||||||
|
If your software can interact with users remotely through a computer
|
||||||
|
network, you should also make sure that it provides a way for users to
|
||||||
|
get its source. For example, if your program is a web application, its
|
||||||
|
interface could display a "Source" link that leads users to an archive
|
||||||
|
of the code. There are many ways you could offer source, and different
|
||||||
|
solutions will be better for different programs; see section 13 for the
|
||||||
|
specific requirements.
|
||||||
|
|
||||||
|
You should also get your employer (if you work as a programmer) or school,
|
||||||
|
if any, to sign a "copyright disclaimer" for the program, if necessary.
|
||||||
|
For more information on this, and how to apply and follow the GNU AGPL, see
|
||||||
|
<https://www.gnu.org/licenses/>.
|
||||||
|
|||||||
12
README.md
12
README.md
@@ -155,4 +155,14 @@ Check out our [user case studies](https://github.com/OpenIMSDK/community/blob/ma
|
|||||||
|
|
||||||
## License :page_facing_up:
|
## License :page_facing_up:
|
||||||
|
|
||||||
OpenIM is licensed under the Apache 2.0 license. See [LICENSE](https://github.com/openimsdk/open-im-server/tree/main/LICENSE) for the full license text.
|
This software is licensed under a dual-license model:
|
||||||
|
|
||||||
|
- The GNU Affero General Public License (AGPL), Version 3 or later; **OR**
|
||||||
|
- Commercial license terms from OpenIMSDK.
|
||||||
|
|
||||||
|
If you wish to use this software under commercial terms, please contact us at: contact@openim.io
|
||||||
|
|
||||||
|
For more information, see: https://www.openim.io/en/licensing
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -30,10 +30,6 @@ buildscript {
|
|||||||
|
|
||||||
rootProject.allprojects {
|
rootProject.allprojects {
|
||||||
repositories {
|
repositories {
|
||||||
maven {
|
|
||||||
url 'http://192.168.77.132:8081/repository/mvn2-group'
|
|
||||||
allowInsecureProtocol true
|
|
||||||
}
|
|
||||||
google()
|
google()
|
||||||
mavenCentral()
|
mavenCentral()
|
||||||
}
|
}
|
||||||
@@ -46,9 +42,6 @@ android {
|
|||||||
|
|
||||||
defaultConfig {
|
defaultConfig {
|
||||||
minSdkVersion 21
|
minSdkVersion 21
|
||||||
ndk {
|
|
||||||
abiFilters "arm64-v8a","x86" // 根据需要添加其他 ABI
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
compileOptions {
|
compileOptions {
|
||||||
sourceCompatibility JavaVersion.VERSION_1_8
|
sourceCompatibility JavaVersion.VERSION_1_8
|
||||||
@@ -57,5 +50,5 @@ android {
|
|||||||
}
|
}
|
||||||
|
|
||||||
dependencies {
|
dependencies {
|
||||||
implementation 'com.openim:sdkcore:1.0.8'
|
implementation 'io.openim:core-sdk:3.8.3-patch7@aar'
|
||||||
}
|
}
|
||||||
@@ -1,6 +1,5 @@
|
|||||||
#Tue Nov 12 14:22:37 CST 2024
|
|
||||||
distributionBase=GRADLE_USER_HOME
|
distributionBase=GRADLE_USER_HOME
|
||||||
distributionPath=wrapper/dists
|
distributionPath=wrapper/dists
|
||||||
distributionUrl=https\://mirrors.cloud.tencent.com/gradle/gradle-7.4-bin.zip
|
|
||||||
zipStoreBase=GRADLE_USER_HOME
|
zipStoreBase=GRADLE_USER_HOME
|
||||||
zipStorePath=wrapper/dists
|
zipStorePath=wrapper/dists
|
||||||
|
distributionUrl=https\://services.gradle.org/distributions/gradle-6.7-all.zip
|
||||||
|
|||||||
@@ -24,7 +24,7 @@ import io.openim.flutter_openim_sdk.manager.GroupManager;
|
|||||||
import io.openim.flutter_openim_sdk.manager.IMManager;
|
import io.openim.flutter_openim_sdk.manager.IMManager;
|
||||||
import io.openim.flutter_openim_sdk.manager.MessageManager;
|
import io.openim.flutter_openim_sdk.manager.MessageManager;
|
||||||
import io.openim.flutter_openim_sdk.manager.UserManager;
|
import io.openim.flutter_openim_sdk.manager.UserManager;
|
||||||
import io.openim.flutter_openim_sdk.manager.ChannelManager;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* FlutterOpenimSdkPlugin
|
* FlutterOpenimSdkPlugin
|
||||||
@@ -42,7 +42,6 @@ public class FlutterOpenimSdkPlugin implements FlutterPlugin, MethodCallHandler,
|
|||||||
private static MessageManager messageManager;
|
private static MessageManager messageManager;
|
||||||
private static ConversationManager conversationManager;
|
private static ConversationManager conversationManager;
|
||||||
private static GroupManager groupManager;
|
private static GroupManager groupManager;
|
||||||
private static ChannelManager channelManager;
|
|
||||||
private static Activity activity;
|
private static Activity activity;
|
||||||
private static Context context;
|
private static Context context;
|
||||||
private ConnectivityListener connectivityListener;
|
private ConnectivityListener connectivityListener;
|
||||||
@@ -56,8 +55,6 @@ public class FlutterOpenimSdkPlugin implements FlutterPlugin, MethodCallHandler,
|
|||||||
FlutterOpenimSdkPlugin.messageManager = new MessageManager();
|
FlutterOpenimSdkPlugin.messageManager = new MessageManager();
|
||||||
FlutterOpenimSdkPlugin.conversationManager = new ConversationManager();
|
FlutterOpenimSdkPlugin.conversationManager = new ConversationManager();
|
||||||
FlutterOpenimSdkPlugin.groupManager = new GroupManager();
|
FlutterOpenimSdkPlugin.groupManager = new GroupManager();
|
||||||
FlutterOpenimSdkPlugin.channelManager = new ChannelManager();
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -29,14 +29,6 @@ public class OnAdvancedMsgListener implements open_im_sdk_callback.OnAdvancedMsg
|
|||||||
CommonUtil.emitEvent("advancedMsgListener", "onNewRecvMessageRevoked", values);
|
CommonUtil.emitEvent("advancedMsgListener", "onNewRecvMessageRevoked", values);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onNewRecvMessageEdited(String s) {
|
|
||||||
final Map<String, String> values = new ArrayMap<>();
|
|
||||||
values.put("id", id);
|
|
||||||
values.put("messageEdited", s);
|
|
||||||
CommonUtil.emitEvent("advancedMsgListener", "onNewRecvMessageEdited", values);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onRecvC2CReadReceipt(String s) {
|
public void onRecvC2CReadReceipt(String s) {
|
||||||
final Map<String, String> values = new ArrayMap<>();
|
final Map<String, String> values = new ArrayMap<>();
|
||||||
|
|||||||
@@ -1,32 +0,0 @@
|
|||||||
package io.openim.flutter_openim_sdk.listener;
|
|
||||||
|
|
||||||
import io.openim.flutter_openim_sdk.util.CommonUtil;
|
|
||||||
|
|
||||||
public class OnChannelListener implements open_im_sdk_callback.OnChannelListener {
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onChannelDismissed(String s) {
|
|
||||||
CommonUtil.emitEvent("channelListener", "onChannelDismissed", s);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onChannelInfoChanged(String s) {
|
|
||||||
CommonUtil.emitEvent("channelListener", "onChannelInfoChanged", s);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onChannelMemberAdded(String s) {
|
|
||||||
CommonUtil.emitEvent("channelListener", "onChannelMemberAdded", s);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onChannelMemberDeleted(String s) {
|
|
||||||
CommonUtil.emitEvent("channelListener", "onChannelMemberDeleted", s);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onChannelMemberInfoChanged(String s) {
|
|
||||||
CommonUtil.emitEvent("channelListener", "onChannelMemberInfoChanged", s);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
@@ -1,103 +0,0 @@
|
|||||||
package io.openim.flutter_openim_sdk.manager;
|
|
||||||
|
|
||||||
import io.flutter.plugin.common.MethodCall;
|
|
||||||
import io.flutter.plugin.common.MethodChannel;
|
|
||||||
import io.openim.flutter_openim_sdk.listener.OnBaseListener;
|
|
||||||
import io.openim.flutter_openim_sdk.listener.OnChannelListener;
|
|
||||||
import open_im_sdk.Open_im_sdk;
|
|
||||||
|
|
||||||
public class ChannelManager extends BaseManager {
|
|
||||||
|
|
||||||
public void setChannelListener(MethodCall methodCall, MethodChannel.Result result) {
|
|
||||||
Open_im_sdk.setChannelListener(new OnChannelListener());
|
|
||||||
|
|
||||||
result.success(null);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
public void getChannelMembersInfo(MethodCall methodCall, MethodChannel.Result result) {
|
|
||||||
Open_im_sdk.getSpecifiedChannelMembersInfo(
|
|
||||||
new OnBaseListener(result, methodCall),
|
|
||||||
value(methodCall, "operationID"),
|
|
||||||
value(methodCall, "channelID"),
|
|
||||||
jsonValue(methodCall, "userIDList")
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void getChannelMemberList(MethodCall methodCall, MethodChannel.Result result) {
|
|
||||||
Open_im_sdk.getChannelMemberList(
|
|
||||||
new OnBaseListener(result, methodCall),
|
|
||||||
value(methodCall, "operationID"),
|
|
||||||
value(methodCall, "channelID"),
|
|
||||||
value(methodCall, "filter"),
|
|
||||||
value(methodCall, "offset"),
|
|
||||||
value(methodCall, "count")
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
public void getChannelsInfo(MethodCall methodCall, MethodChannel.Result result) {
|
|
||||||
Open_im_sdk.getSpecifiedChannelsInfo(
|
|
||||||
new OnBaseListener(result, methodCall),
|
|
||||||
value(methodCall, "operationID"),
|
|
||||||
jsonValue(methodCall, "channelIDList")
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void joinChannel(MethodCall methodCall, MethodChannel.Result result) {
|
|
||||||
Open_im_sdk.joinChannel(
|
|
||||||
new OnBaseListener(result, methodCall),
|
|
||||||
value(methodCall, "operationID"),
|
|
||||||
value(methodCall, "channelID"),
|
|
||||||
value(methodCall, "reason"),
|
|
||||||
value(methodCall, "joinSource"),
|
|
||||||
value(methodCall, "ex")
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void quitChannel(MethodCall methodCall, MethodChannel.Result result) {
|
|
||||||
Open_im_sdk.quitChannel(
|
|
||||||
new OnBaseListener(result, methodCall),
|
|
||||||
value(methodCall, "operationID"),
|
|
||||||
value(methodCall, "channelID")
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
public void changeChannelMute(MethodCall methodCall, MethodChannel.Result result) {
|
|
||||||
Open_im_sdk.changeChannelMute(
|
|
||||||
new OnBaseListener(result, methodCall),
|
|
||||||
value(methodCall, "operationID"),
|
|
||||||
value(methodCall, "channelID"),
|
|
||||||
value(methodCall, "mute")
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void changeChannelMemberMute(MethodCall methodCall, MethodChannel.Result result) {
|
|
||||||
Open_im_sdk.changeChannelMemberMute(
|
|
||||||
new OnBaseListener(result, methodCall),
|
|
||||||
value(methodCall, "operationID"),
|
|
||||||
value(methodCall, "channelID"),
|
|
||||||
value(methodCall, "userID"),
|
|
||||||
int2long(methodCall, "seconds")
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
public void isJoinChannel(MethodCall methodCall, MethodChannel.Result result) {
|
|
||||||
Open_im_sdk.isJoinChannel(new OnBaseListener(result, methodCall),
|
|
||||||
value(methodCall, "operationID"),
|
|
||||||
value(methodCall, "channelID")
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void getUsersInChannel(MethodCall methodCall, MethodChannel.Result result) {
|
|
||||||
Open_im_sdk.getUsersInChannel(new OnBaseListener(result, methodCall),
|
|
||||||
value(methodCall, "operationID"),
|
|
||||||
value(methodCall, "channelID"),
|
|
||||||
jsonValue(methodCall, "userIDs")
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -35,14 +35,16 @@ public class FriendshipManager extends BaseManager {
|
|||||||
public void getFriendApplicationListAsRecipient(MethodCall methodCall, MethodChannel.Result result) {
|
public void getFriendApplicationListAsRecipient(MethodCall methodCall, MethodChannel.Result result) {
|
||||||
Open_im_sdk.getFriendApplicationListAsRecipient(
|
Open_im_sdk.getFriendApplicationListAsRecipient(
|
||||||
new OnBaseListener(result, methodCall),
|
new OnBaseListener(result, methodCall),
|
||||||
value(methodCall, "operationID")
|
value(methodCall, "operationID"),
|
||||||
|
jsonValue(methodCall, "req")
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void getFriendApplicationListAsApplicant(MethodCall methodCall, MethodChannel.Result result) {
|
public void getFriendApplicationListAsApplicant(MethodCall methodCall, MethodChannel.Result result) {
|
||||||
Open_im_sdk.getFriendApplicationListAsApplicant(
|
Open_im_sdk.getFriendApplicationListAsApplicant(
|
||||||
new OnBaseListener(result, methodCall),
|
new OnBaseListener(result, methodCall),
|
||||||
value(methodCall, "operationID")
|
value(methodCall, "operationID"),
|
||||||
|
jsonValue(methodCall, "req")
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -135,4 +137,12 @@ public class FriendshipManager extends BaseManager {
|
|||||||
jsonValue(methodCall, "req")
|
jsonValue(methodCall, "req")
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void getFriendApplicationUnhandledCount(MethodCall methodCall, MethodChannel.Result result) {
|
||||||
|
Open_im_sdk.getFriendApplicationUnhandledCount(
|
||||||
|
new OnBaseListener(result, methodCall),
|
||||||
|
value(methodCall, "operationID"),
|
||||||
|
jsonValue(methodCall, "req")
|
||||||
|
);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -126,14 +126,16 @@ public class GroupManager extends BaseManager {
|
|||||||
public void getGroupApplicationListAsRecipient(MethodCall methodCall, MethodChannel.Result result) {
|
public void getGroupApplicationListAsRecipient(MethodCall methodCall, MethodChannel.Result result) {
|
||||||
Open_im_sdk.getGroupApplicationListAsRecipient(
|
Open_im_sdk.getGroupApplicationListAsRecipient(
|
||||||
new OnBaseListener(result, methodCall),
|
new OnBaseListener(result, methodCall),
|
||||||
value(methodCall, "operationID")
|
value(methodCall, "operationID"),
|
||||||
|
jsonValue(methodCall, "req")
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void getGroupApplicationListAsApplicant(MethodCall methodCall, MethodChannel.Result result) {
|
public void getGroupApplicationListAsApplicant(MethodCall methodCall, MethodChannel.Result result) {
|
||||||
Open_im_sdk.getGroupApplicationListAsApplicant(
|
Open_im_sdk.getGroupApplicationListAsApplicant(
|
||||||
new OnBaseListener(result, methodCall),
|
new OnBaseListener(result, methodCall),
|
||||||
value(methodCall, "operationID")
|
value(methodCall, "operationID"),
|
||||||
|
jsonValue(methodCall, "req")
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -240,4 +242,11 @@ public class GroupManager extends BaseManager {
|
|||||||
jsonValue(methodCall, "userIDs")
|
jsonValue(methodCall, "userIDs")
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void getGroupApplicationUnhandledCount(MethodCall methodCall, MethodChannel.Result result) {
|
||||||
|
Open_im_sdk.getGroupApplicationUnhandledCount(new OnBaseListener(result, methodCall),
|
||||||
|
value(methodCall, "operationID"),
|
||||||
|
jsonValue(methodCall, "req")
|
||||||
|
);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
@@ -27,7 +27,6 @@ public class MessageManager extends BaseManager {
|
|||||||
jsonValue(methodCall, "message"),
|
jsonValue(methodCall, "message"),
|
||||||
value(methodCall, "userID"),
|
value(methodCall, "userID"),
|
||||||
value(methodCall, "groupID"),
|
value(methodCall, "groupID"),
|
||||||
value(methodCall, "channelID"),
|
|
||||||
jsonValue(methodCall, "offlinePushInfo"),
|
jsonValue(methodCall, "offlinePushInfo"),
|
||||||
value(methodCall, "isOnlineOnly")
|
value(methodCall, "isOnlineOnly")
|
||||||
);
|
);
|
||||||
@@ -42,16 +41,6 @@ public class MessageManager extends BaseManager {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void editMessage(MethodCall methodCall, MethodChannel.Result result) {
|
|
||||||
Open_im_sdk.editMessage(
|
|
||||||
new OnBaseListener(result, methodCall),
|
|
||||||
value(methodCall, "operationID"),
|
|
||||||
value(methodCall, "conversationID"),
|
|
||||||
value(methodCall, "clientMsgID"),
|
|
||||||
jsonValue(methodCall, "message")
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void deleteMessageFromLocalStorage(MethodCall methodCall, MethodChannel.Result result) {
|
public void deleteMessageFromLocalStorage(MethodCall methodCall, MethodChannel.Result result) {
|
||||||
Open_im_sdk.deleteMessageFromLocalStorage(
|
Open_im_sdk.deleteMessageFromLocalStorage(
|
||||||
new OnBaseListener(result, methodCall),
|
new OnBaseListener(result, methodCall),
|
||||||
@@ -100,7 +89,6 @@ public class MessageManager extends BaseManager {
|
|||||||
value(methodCall, "operationID"),
|
value(methodCall, "operationID"),
|
||||||
jsonValue(methodCall, "message"),
|
jsonValue(methodCall, "message"),
|
||||||
value(methodCall, "groupID"),
|
value(methodCall, "groupID"),
|
||||||
value(methodCall, "channelID"),
|
|
||||||
value(methodCall, "senderID")
|
value(methodCall, "senderID")
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
@@ -351,7 +339,6 @@ public class MessageManager extends BaseManager {
|
|||||||
jsonValue(methodCall, "message"),
|
jsonValue(methodCall, "message"),
|
||||||
value(methodCall, "userID"),
|
value(methodCall, "userID"),
|
||||||
value(methodCall, "groupID"),
|
value(methodCall, "groupID"),
|
||||||
value(methodCall, "channelId"),
|
|
||||||
jsonValue(methodCall, "offlinePushInfo"),
|
jsonValue(methodCall, "offlinePushInfo"),
|
||||||
value(methodCall, "isOnlineOnly")
|
value(methodCall, "isOnlineOnly")
|
||||||
);
|
);
|
||||||
|
|||||||
@@ -49,25 +49,7 @@ public class CommonUtil {
|
|||||||
res.put("errMsg", errMsg);
|
res.put("errMsg", errMsg);
|
||||||
}
|
}
|
||||||
Log.i("F-OpenIMSDK(native call flutter)", "thread: " + threadName + " { method:" + method + ", type:" + type + " }");
|
Log.i("F-OpenIMSDK(native call flutter)", "thread: " + threadName + " { method:" + method + ", type:" + type + " }");
|
||||||
FlutterOpenimSdkPlugin.channel.invokeMethod(method, res, new MethodChannel.Result() {
|
FlutterOpenimSdkPlugin.channel.invokeMethod(method, res);
|
||||||
@Override
|
|
||||||
public void success(Object result) {
|
|
||||||
// 处理成功返回值
|
|
||||||
Log.i("F-OpenIMSDK(native call flutter)", "Method " + method + " returned: ");
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void error(String errorCode, String errorMessage, Object errorDetails) {
|
|
||||||
// 处理错误
|
|
||||||
Log.e("F-OpenIMSDK(native call flutter)", "Method " + method + " error: " + errorCode + ", " + errorMessage);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void notImplemented() {
|
|
||||||
// 处理未实现的方法
|
|
||||||
Log.w("F-OpenIMSDK(native call flutter)", "Method " + method + " not implemented");
|
|
||||||
}
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
29
example/ios/Podfile.lock
Normal file
29
example/ios/Podfile.lock
Normal file
@@ -0,0 +1,29 @@
|
|||||||
|
PODS:
|
||||||
|
- Flutter (1.0.0)
|
||||||
|
- flutter_openim_sdk (0.0.1):
|
||||||
|
- Flutter
|
||||||
|
- OpenIMSDKCore (= 3.8.2)
|
||||||
|
- OpenIMSDKCore (3.8.2)
|
||||||
|
|
||||||
|
DEPENDENCIES:
|
||||||
|
- Flutter (from `Flutter`)
|
||||||
|
- flutter_openim_sdk (from `.symlinks/plugins/flutter_openim_sdk/ios`)
|
||||||
|
|
||||||
|
SPEC REPOS:
|
||||||
|
trunk:
|
||||||
|
- OpenIMSDKCore
|
||||||
|
|
||||||
|
EXTERNAL SOURCES:
|
||||||
|
Flutter:
|
||||||
|
:path: Flutter
|
||||||
|
flutter_openim_sdk:
|
||||||
|
:path: ".symlinks/plugins/flutter_openim_sdk/ios"
|
||||||
|
|
||||||
|
SPEC CHECKSUMS:
|
||||||
|
Flutter: e0871f40cf51350855a761d2e70bf5af5b9b5de7
|
||||||
|
flutter_openim_sdk: 77bdd08fb8dda1644a0c150b8ba7324f11b32404
|
||||||
|
OpenIMSDKCore: aaffd63079a874d9272b8b962598723cb8128d32
|
||||||
|
|
||||||
|
PODFILE CHECKSUM: 819463e6a0290f5a72f145ba7cde16e8b6ef0796
|
||||||
|
|
||||||
|
COCOAPODS: 1.15.2
|
||||||
@@ -10,10 +10,12 @@
|
|||||||
1498D2341E8E89220040F4C2 /* GeneratedPluginRegistrant.m in Sources */ = {isa = PBXBuildFile; fileRef = 1498D2331E8E89220040F4C2 /* GeneratedPluginRegistrant.m */; };
|
1498D2341E8E89220040F4C2 /* GeneratedPluginRegistrant.m in Sources */ = {isa = PBXBuildFile; fileRef = 1498D2331E8E89220040F4C2 /* GeneratedPluginRegistrant.m */; };
|
||||||
331C808B294A63AB00263BE5 /* RunnerTests.swift in Sources */ = {isa = PBXBuildFile; fileRef = 331C807B294A618700263BE5 /* RunnerTests.swift */; };
|
331C808B294A63AB00263BE5 /* RunnerTests.swift in Sources */ = {isa = PBXBuildFile; fileRef = 331C807B294A618700263BE5 /* RunnerTests.swift */; };
|
||||||
3B3967161E833CAA004F5970 /* AppFrameworkInfo.plist in Resources */ = {isa = PBXBuildFile; fileRef = 3B3967151E833CAA004F5970 /* AppFrameworkInfo.plist */; };
|
3B3967161E833CAA004F5970 /* AppFrameworkInfo.plist in Resources */ = {isa = PBXBuildFile; fileRef = 3B3967151E833CAA004F5970 /* AppFrameworkInfo.plist */; };
|
||||||
|
3E0FE62DE2A4D4E61AC3FD02 /* Pods_Runner.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 8BB3D975831D21A8FACEF96B /* Pods_Runner.framework */; };
|
||||||
74858FAF1ED2DC5600515810 /* AppDelegate.swift in Sources */ = {isa = PBXBuildFile; fileRef = 74858FAE1ED2DC5600515810 /* AppDelegate.swift */; };
|
74858FAF1ED2DC5600515810 /* AppDelegate.swift in Sources */ = {isa = PBXBuildFile; fileRef = 74858FAE1ED2DC5600515810 /* AppDelegate.swift */; };
|
||||||
97C146FC1CF9000F007C117D /* Main.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 97C146FA1CF9000F007C117D /* Main.storyboard */; };
|
97C146FC1CF9000F007C117D /* Main.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 97C146FA1CF9000F007C117D /* Main.storyboard */; };
|
||||||
97C146FE1CF9000F007C117D /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 97C146FD1CF9000F007C117D /* Assets.xcassets */; };
|
97C146FE1CF9000F007C117D /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 97C146FD1CF9000F007C117D /* Assets.xcassets */; };
|
||||||
97C147011CF9000F007C117D /* LaunchScreen.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 97C146FF1CF9000F007C117D /* LaunchScreen.storyboard */; };
|
97C147011CF9000F007C117D /* LaunchScreen.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 97C146FF1CF9000F007C117D /* LaunchScreen.storyboard */; };
|
||||||
|
F32475A5B591900F07118022 /* Pods_RunnerTests.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 119B0071FAB85FAD36937602 /* Pods_RunnerTests.framework */; };
|
||||||
/* End PBXBuildFile section */
|
/* End PBXBuildFile section */
|
||||||
|
|
||||||
/* Begin PBXContainerItemProxy section */
|
/* Begin PBXContainerItemProxy section */
|
||||||
@@ -40,14 +42,19 @@
|
|||||||
/* End PBXCopyFilesBuildPhase section */
|
/* End PBXCopyFilesBuildPhase section */
|
||||||
|
|
||||||
/* Begin PBXFileReference section */
|
/* Begin PBXFileReference section */
|
||||||
|
119B0071FAB85FAD36937602 /* Pods_RunnerTests.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Pods_RunnerTests.framework; sourceTree = BUILT_PRODUCTS_DIR; };
|
||||||
1498D2321E8E86230040F4C2 /* GeneratedPluginRegistrant.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = GeneratedPluginRegistrant.h; sourceTree = "<group>"; };
|
1498D2321E8E86230040F4C2 /* GeneratedPluginRegistrant.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = GeneratedPluginRegistrant.h; sourceTree = "<group>"; };
|
||||||
1498D2331E8E89220040F4C2 /* GeneratedPluginRegistrant.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = GeneratedPluginRegistrant.m; sourceTree = "<group>"; };
|
1498D2331E8E89220040F4C2 /* GeneratedPluginRegistrant.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = GeneratedPluginRegistrant.m; sourceTree = "<group>"; };
|
||||||
331C807B294A618700263BE5 /* RunnerTests.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = RunnerTests.swift; sourceTree = "<group>"; };
|
331C807B294A618700263BE5 /* RunnerTests.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = RunnerTests.swift; sourceTree = "<group>"; };
|
||||||
331C8081294A63A400263BE5 /* RunnerTests.xctest */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = RunnerTests.xctest; sourceTree = BUILT_PRODUCTS_DIR; };
|
331C8081294A63A400263BE5 /* RunnerTests.xctest */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = RunnerTests.xctest; sourceTree = BUILT_PRODUCTS_DIR; };
|
||||||
3B3967151E833CAA004F5970 /* AppFrameworkInfo.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; name = AppFrameworkInfo.plist; path = Flutter/AppFrameworkInfo.plist; sourceTree = "<group>"; };
|
3B3967151E833CAA004F5970 /* AppFrameworkInfo.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; name = AppFrameworkInfo.plist; path = Flutter/AppFrameworkInfo.plist; sourceTree = "<group>"; };
|
||||||
|
4D6806EF7C87F4A8E899A73E /* Pods-Runner.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Runner.release.xcconfig"; path = "Target Support Files/Pods-Runner/Pods-Runner.release.xcconfig"; sourceTree = "<group>"; };
|
||||||
|
5C84146D7BEE11433AA4DE9E /* Pods-RunnerTests.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-RunnerTests.release.xcconfig"; path = "Target Support Files/Pods-RunnerTests/Pods-RunnerTests.release.xcconfig"; sourceTree = "<group>"; };
|
||||||
74858FAD1ED2DC5600515810 /* Runner-Bridging-Header.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = "Runner-Bridging-Header.h"; sourceTree = "<group>"; };
|
74858FAD1ED2DC5600515810 /* Runner-Bridging-Header.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = "Runner-Bridging-Header.h"; sourceTree = "<group>"; };
|
||||||
74858FAE1ED2DC5600515810 /* AppDelegate.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = AppDelegate.swift; sourceTree = "<group>"; };
|
74858FAE1ED2DC5600515810 /* AppDelegate.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = AppDelegate.swift; sourceTree = "<group>"; };
|
||||||
7AFA3C8E1D35360C0083082E /* Release.xcconfig */ = {isa = PBXFileReference; lastKnownFileType = text.xcconfig; name = Release.xcconfig; path = Flutter/Release.xcconfig; sourceTree = "<group>"; };
|
7AFA3C8E1D35360C0083082E /* Release.xcconfig */ = {isa = PBXFileReference; lastKnownFileType = text.xcconfig; name = Release.xcconfig; path = Flutter/Release.xcconfig; sourceTree = "<group>"; };
|
||||||
|
7D277EA428A8FDCA196F3196 /* Pods-Runner.profile.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Runner.profile.xcconfig"; path = "Target Support Files/Pods-Runner/Pods-Runner.profile.xcconfig"; sourceTree = "<group>"; };
|
||||||
|
8BB3D975831D21A8FACEF96B /* Pods_Runner.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Pods_Runner.framework; sourceTree = BUILT_PRODUCTS_DIR; };
|
||||||
9740EEB21CF90195004384FC /* Debug.xcconfig */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.xcconfig; name = Debug.xcconfig; path = Flutter/Debug.xcconfig; sourceTree = "<group>"; };
|
9740EEB21CF90195004384FC /* Debug.xcconfig */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.xcconfig; name = Debug.xcconfig; path = Flutter/Debug.xcconfig; sourceTree = "<group>"; };
|
||||||
9740EEB31CF90195004384FC /* Generated.xcconfig */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.xcconfig; name = Generated.xcconfig; path = Flutter/Generated.xcconfig; sourceTree = "<group>"; };
|
9740EEB31CF90195004384FC /* Generated.xcconfig */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.xcconfig; name = Generated.xcconfig; path = Flutter/Generated.xcconfig; sourceTree = "<group>"; };
|
||||||
97C146EE1CF9000F007C117D /* Runner.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = Runner.app; sourceTree = BUILT_PRODUCTS_DIR; };
|
97C146EE1CF9000F007C117D /* Runner.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = Runner.app; sourceTree = BUILT_PRODUCTS_DIR; };
|
||||||
@@ -55,13 +62,25 @@
|
|||||||
97C146FD1CF9000F007C117D /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Assets.xcassets; sourceTree = "<group>"; };
|
97C146FD1CF9000F007C117D /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Assets.xcassets; sourceTree = "<group>"; };
|
||||||
97C147001CF9000F007C117D /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/LaunchScreen.storyboard; sourceTree = "<group>"; };
|
97C147001CF9000F007C117D /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/LaunchScreen.storyboard; sourceTree = "<group>"; };
|
||||||
97C147021CF9000F007C117D /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = "<group>"; };
|
97C147021CF9000F007C117D /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = "<group>"; };
|
||||||
|
BD60456F5D1660BF5A90F9A1 /* Pods-RunnerTests.profile.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-RunnerTests.profile.xcconfig"; path = "Target Support Files/Pods-RunnerTests/Pods-RunnerTests.profile.xcconfig"; sourceTree = "<group>"; };
|
||||||
|
F0FFA291A8BB24B66A6DCC8C /* Pods-RunnerTests.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-RunnerTests.debug.xcconfig"; path = "Target Support Files/Pods-RunnerTests/Pods-RunnerTests.debug.xcconfig"; sourceTree = "<group>"; };
|
||||||
|
FA507785CCEA4423C40C3CCD /* Pods-Runner.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Runner.debug.xcconfig"; path = "Target Support Files/Pods-Runner/Pods-Runner.debug.xcconfig"; sourceTree = "<group>"; };
|
||||||
/* End PBXFileReference section */
|
/* End PBXFileReference section */
|
||||||
|
|
||||||
/* Begin PBXFrameworksBuildPhase section */
|
/* Begin PBXFrameworksBuildPhase section */
|
||||||
|
1B803A0F046E9658A8FCEED0 /* Frameworks */ = {
|
||||||
|
isa = PBXFrameworksBuildPhase;
|
||||||
|
buildActionMask = 2147483647;
|
||||||
|
files = (
|
||||||
|
F32475A5B591900F07118022 /* Pods_RunnerTests.framework in Frameworks */,
|
||||||
|
);
|
||||||
|
runOnlyForDeploymentPostprocessing = 0;
|
||||||
|
};
|
||||||
97C146EB1CF9000F007C117D /* Frameworks */ = {
|
97C146EB1CF9000F007C117D /* Frameworks */ = {
|
||||||
isa = PBXFrameworksBuildPhase;
|
isa = PBXFrameworksBuildPhase;
|
||||||
buildActionMask = 2147483647;
|
buildActionMask = 2147483647;
|
||||||
files = (
|
files = (
|
||||||
|
3E0FE62DE2A4D4E61AC3FD02 /* Pods_Runner.framework in Frameworks */,
|
||||||
);
|
);
|
||||||
runOnlyForDeploymentPostprocessing = 0;
|
runOnlyForDeploymentPostprocessing = 0;
|
||||||
};
|
};
|
||||||
@@ -76,6 +95,20 @@
|
|||||||
path = RunnerTests;
|
path = RunnerTests;
|
||||||
sourceTree = "<group>";
|
sourceTree = "<group>";
|
||||||
};
|
};
|
||||||
|
8575235C80CAB4F7FB7F5B46 /* Pods */ = {
|
||||||
|
isa = PBXGroup;
|
||||||
|
children = (
|
||||||
|
FA507785CCEA4423C40C3CCD /* Pods-Runner.debug.xcconfig */,
|
||||||
|
4D6806EF7C87F4A8E899A73E /* Pods-Runner.release.xcconfig */,
|
||||||
|
7D277EA428A8FDCA196F3196 /* Pods-Runner.profile.xcconfig */,
|
||||||
|
F0FFA291A8BB24B66A6DCC8C /* Pods-RunnerTests.debug.xcconfig */,
|
||||||
|
5C84146D7BEE11433AA4DE9E /* Pods-RunnerTests.release.xcconfig */,
|
||||||
|
BD60456F5D1660BF5A90F9A1 /* Pods-RunnerTests.profile.xcconfig */,
|
||||||
|
);
|
||||||
|
name = Pods;
|
||||||
|
path = Pods;
|
||||||
|
sourceTree = "<group>";
|
||||||
|
};
|
||||||
9740EEB11CF90186004384FC /* Flutter */ = {
|
9740EEB11CF90186004384FC /* Flutter */ = {
|
||||||
isa = PBXGroup;
|
isa = PBXGroup;
|
||||||
children = (
|
children = (
|
||||||
@@ -94,6 +127,8 @@
|
|||||||
97C146F01CF9000F007C117D /* Runner */,
|
97C146F01CF9000F007C117D /* Runner */,
|
||||||
97C146EF1CF9000F007C117D /* Products */,
|
97C146EF1CF9000F007C117D /* Products */,
|
||||||
331C8082294A63A400263BE5 /* RunnerTests */,
|
331C8082294A63A400263BE5 /* RunnerTests */,
|
||||||
|
8575235C80CAB4F7FB7F5B46 /* Pods */,
|
||||||
|
B94289CF044A7671B3BECB8E /* Frameworks */,
|
||||||
);
|
);
|
||||||
sourceTree = "<group>";
|
sourceTree = "<group>";
|
||||||
};
|
};
|
||||||
@@ -121,6 +156,15 @@
|
|||||||
path = Runner;
|
path = Runner;
|
||||||
sourceTree = "<group>";
|
sourceTree = "<group>";
|
||||||
};
|
};
|
||||||
|
B94289CF044A7671B3BECB8E /* Frameworks */ = {
|
||||||
|
isa = PBXGroup;
|
||||||
|
children = (
|
||||||
|
8BB3D975831D21A8FACEF96B /* Pods_Runner.framework */,
|
||||||
|
119B0071FAB85FAD36937602 /* Pods_RunnerTests.framework */,
|
||||||
|
);
|
||||||
|
name = Frameworks;
|
||||||
|
sourceTree = "<group>";
|
||||||
|
};
|
||||||
/* End PBXGroup section */
|
/* End PBXGroup section */
|
||||||
|
|
||||||
/* Begin PBXNativeTarget section */
|
/* Begin PBXNativeTarget section */
|
||||||
@@ -128,8 +172,10 @@
|
|||||||
isa = PBXNativeTarget;
|
isa = PBXNativeTarget;
|
||||||
buildConfigurationList = 331C8087294A63A400263BE5 /* Build configuration list for PBXNativeTarget "RunnerTests" */;
|
buildConfigurationList = 331C8087294A63A400263BE5 /* Build configuration list for PBXNativeTarget "RunnerTests" */;
|
||||||
buildPhases = (
|
buildPhases = (
|
||||||
|
70DBF52745AF25A4FC72D8C3 /* [CP] Check Pods Manifest.lock */,
|
||||||
331C807D294A63A400263BE5 /* Sources */,
|
331C807D294A63A400263BE5 /* Sources */,
|
||||||
331C807F294A63A400263BE5 /* Resources */,
|
331C807F294A63A400263BE5 /* Resources */,
|
||||||
|
1B803A0F046E9658A8FCEED0 /* Frameworks */,
|
||||||
);
|
);
|
||||||
buildRules = (
|
buildRules = (
|
||||||
);
|
);
|
||||||
@@ -145,6 +191,7 @@
|
|||||||
isa = PBXNativeTarget;
|
isa = PBXNativeTarget;
|
||||||
buildConfigurationList = 97C147051CF9000F007C117D /* Build configuration list for PBXNativeTarget "Runner" */;
|
buildConfigurationList = 97C147051CF9000F007C117D /* Build configuration list for PBXNativeTarget "Runner" */;
|
||||||
buildPhases = (
|
buildPhases = (
|
||||||
|
3DCEC8459668E43AE9B4C8D5 /* [CP] Check Pods Manifest.lock */,
|
||||||
9740EEB61CF901F6004384FC /* Run Script */,
|
9740EEB61CF901F6004384FC /* Run Script */,
|
||||||
97C146EA1CF9000F007C117D /* Sources */,
|
97C146EA1CF9000F007C117D /* Sources */,
|
||||||
97C146EB1CF9000F007C117D /* Frameworks */,
|
97C146EB1CF9000F007C117D /* Frameworks */,
|
||||||
@@ -238,6 +285,50 @@
|
|||||||
shellPath = /bin/sh;
|
shellPath = /bin/sh;
|
||||||
shellScript = "/bin/sh \"$FLUTTER_ROOT/packages/flutter_tools/bin/xcode_backend.sh\" embed_and_thin";
|
shellScript = "/bin/sh \"$FLUTTER_ROOT/packages/flutter_tools/bin/xcode_backend.sh\" embed_and_thin";
|
||||||
};
|
};
|
||||||
|
3DCEC8459668E43AE9B4C8D5 /* [CP] Check Pods Manifest.lock */ = {
|
||||||
|
isa = PBXShellScriptBuildPhase;
|
||||||
|
buildActionMask = 2147483647;
|
||||||
|
files = (
|
||||||
|
);
|
||||||
|
inputFileListPaths = (
|
||||||
|
);
|
||||||
|
inputPaths = (
|
||||||
|
"${PODS_PODFILE_DIR_PATH}/Podfile.lock",
|
||||||
|
"${PODS_ROOT}/Manifest.lock",
|
||||||
|
);
|
||||||
|
name = "[CP] Check Pods Manifest.lock";
|
||||||
|
outputFileListPaths = (
|
||||||
|
);
|
||||||
|
outputPaths = (
|
||||||
|
"$(DERIVED_FILE_DIR)/Pods-Runner-checkManifestLockResult.txt",
|
||||||
|
);
|
||||||
|
runOnlyForDeploymentPostprocessing = 0;
|
||||||
|
shellPath = /bin/sh;
|
||||||
|
shellScript = "diff \"${PODS_PODFILE_DIR_PATH}/Podfile.lock\" \"${PODS_ROOT}/Manifest.lock\" > /dev/null\nif [ $? != 0 ] ; then\n # print error to STDERR\n echo \"error: The sandbox is not in sync with the Podfile.lock. Run 'pod install' or update your CocoaPods installation.\" >&2\n exit 1\nfi\n# This output is used by Xcode 'outputs' to avoid re-running this script phase.\necho \"SUCCESS\" > \"${SCRIPT_OUTPUT_FILE_0}\"\n";
|
||||||
|
showEnvVarsInLog = 0;
|
||||||
|
};
|
||||||
|
70DBF52745AF25A4FC72D8C3 /* [CP] Check Pods Manifest.lock */ = {
|
||||||
|
isa = PBXShellScriptBuildPhase;
|
||||||
|
buildActionMask = 2147483647;
|
||||||
|
files = (
|
||||||
|
);
|
||||||
|
inputFileListPaths = (
|
||||||
|
);
|
||||||
|
inputPaths = (
|
||||||
|
"${PODS_PODFILE_DIR_PATH}/Podfile.lock",
|
||||||
|
"${PODS_ROOT}/Manifest.lock",
|
||||||
|
);
|
||||||
|
name = "[CP] Check Pods Manifest.lock";
|
||||||
|
outputFileListPaths = (
|
||||||
|
);
|
||||||
|
outputPaths = (
|
||||||
|
"$(DERIVED_FILE_DIR)/Pods-RunnerTests-checkManifestLockResult.txt",
|
||||||
|
);
|
||||||
|
runOnlyForDeploymentPostprocessing = 0;
|
||||||
|
shellPath = /bin/sh;
|
||||||
|
shellScript = "diff \"${PODS_PODFILE_DIR_PATH}/Podfile.lock\" \"${PODS_ROOT}/Manifest.lock\" > /dev/null\nif [ $? != 0 ] ; then\n # print error to STDERR\n echo \"error: The sandbox is not in sync with the Podfile.lock. Run 'pod install' or update your CocoaPods installation.\" >&2\n exit 1\nfi\n# This output is used by Xcode 'outputs' to avoid re-running this script phase.\necho \"SUCCESS\" > \"${SCRIPT_OUTPUT_FILE_0}\"\n";
|
||||||
|
showEnvVarsInLog = 0;
|
||||||
|
};
|
||||||
9740EEB61CF901F6004384FC /* Run Script */ = {
|
9740EEB61CF901F6004384FC /* Run Script */ = {
|
||||||
isa = PBXShellScriptBuildPhase;
|
isa = PBXShellScriptBuildPhase;
|
||||||
alwaysOutOfDate = 1;
|
alwaysOutOfDate = 1;
|
||||||
@@ -379,6 +470,7 @@
|
|||||||
};
|
};
|
||||||
331C8088294A63A400263BE5 /* Debug */ = {
|
331C8088294A63A400263BE5 /* Debug */ = {
|
||||||
isa = XCBuildConfiguration;
|
isa = XCBuildConfiguration;
|
||||||
|
baseConfigurationReference = F0FFA291A8BB24B66A6DCC8C /* Pods-RunnerTests.debug.xcconfig */;
|
||||||
buildSettings = {
|
buildSettings = {
|
||||||
BUNDLE_LOADER = "$(TEST_HOST)";
|
BUNDLE_LOADER = "$(TEST_HOST)";
|
||||||
CODE_SIGN_STYLE = Automatic;
|
CODE_SIGN_STYLE = Automatic;
|
||||||
@@ -396,6 +488,7 @@
|
|||||||
};
|
};
|
||||||
331C8089294A63A400263BE5 /* Release */ = {
|
331C8089294A63A400263BE5 /* Release */ = {
|
||||||
isa = XCBuildConfiguration;
|
isa = XCBuildConfiguration;
|
||||||
|
baseConfigurationReference = 5C84146D7BEE11433AA4DE9E /* Pods-RunnerTests.release.xcconfig */;
|
||||||
buildSettings = {
|
buildSettings = {
|
||||||
BUNDLE_LOADER = "$(TEST_HOST)";
|
BUNDLE_LOADER = "$(TEST_HOST)";
|
||||||
CODE_SIGN_STYLE = Automatic;
|
CODE_SIGN_STYLE = Automatic;
|
||||||
@@ -411,6 +504,7 @@
|
|||||||
};
|
};
|
||||||
331C808A294A63A400263BE5 /* Profile */ = {
|
331C808A294A63A400263BE5 /* Profile */ = {
|
||||||
isa = XCBuildConfiguration;
|
isa = XCBuildConfiguration;
|
||||||
|
baseConfigurationReference = BD60456F5D1660BF5A90F9A1 /* Pods-RunnerTests.profile.xcconfig */;
|
||||||
buildSettings = {
|
buildSettings = {
|
||||||
BUNDLE_LOADER = "$(TEST_HOST)";
|
BUNDLE_LOADER = "$(TEST_HOST)";
|
||||||
CODE_SIGN_STYLE = Automatic;
|
CODE_SIGN_STYLE = Automatic;
|
||||||
|
|||||||
@@ -4,4 +4,7 @@
|
|||||||
<FileRef
|
<FileRef
|
||||||
location = "group:Runner.xcodeproj">
|
location = "group:Runner.xcodeproj">
|
||||||
</FileRef>
|
</FileRef>
|
||||||
|
<FileRef
|
||||||
|
location = "group:Pods/Pods.xcodeproj">
|
||||||
|
</FileRef>
|
||||||
</Workspace>
|
</Workspace>
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
import Flutter
|
import Flutter
|
||||||
import UIKit
|
import UIKit
|
||||||
|
|
||||||
@UIApplicationMain
|
@main
|
||||||
@objc class AppDelegate: FlutterAppDelegate {
|
@objc class AppDelegate: FlutterAppDelegate {
|
||||||
override func application(
|
override func application(
|
||||||
_ application: UIApplication,
|
_ application: UIApplication,
|
||||||
|
|||||||
@@ -76,7 +76,7 @@ packages:
|
|||||||
path: ".."
|
path: ".."
|
||||||
relative: true
|
relative: true
|
||||||
source: path
|
source: path
|
||||||
version: "3.8.1+1"
|
version: "3.8.3+hotfix.3"
|
||||||
flutter_test:
|
flutter_test:
|
||||||
dependency: "direct dev"
|
dependency: "direct dev"
|
||||||
description: flutter
|
description: flutter
|
||||||
@@ -86,18 +86,18 @@ packages:
|
|||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
name: leak_tracker
|
name: leak_tracker
|
||||||
sha256: "7f0df31977cb2c0b88585095d168e689669a2cc9b97c309665e3386f3e9d341a"
|
sha256: "3f87a60e8c63aecc975dda1ceedbc8f24de75f09e4856ea27daf8958f2f0ce05"
|
||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "10.0.4"
|
version: "10.0.5"
|
||||||
leak_tracker_flutter_testing:
|
leak_tracker_flutter_testing:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
name: leak_tracker_flutter_testing
|
name: leak_tracker_flutter_testing
|
||||||
sha256: "06e98f569d004c1315b991ded39924b21af84cf14cc94791b8aea337d25b57f8"
|
sha256: "932549fb305594d82d7183ecd9fa93463e9914e1b67cacc34bc40906594a1806"
|
||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "3.0.3"
|
version: "3.0.5"
|
||||||
leak_tracker_testing:
|
leak_tracker_testing:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
@@ -126,18 +126,18 @@ packages:
|
|||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
name: material_color_utilities
|
name: material_color_utilities
|
||||||
sha256: "0e0a020085b65b6083975e499759762399b4475f766c21668c4ecca34ea74e5a"
|
sha256: f7142bb1154231d7ea5f96bc7bde4bda2a0945d2806bb11670e30b850d56bdec
|
||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "0.8.0"
|
version: "0.11.1"
|
||||||
meta:
|
meta:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
name: meta
|
name: meta
|
||||||
sha256: "7687075e408b093f36e6bbf6c91878cc0d4cd10f409506f7bc996f68220b9136"
|
sha256: bdb68674043280c3428e9ec998512fb681678676b3c54e773629ffe74419f8c7
|
||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "1.12.0"
|
version: "1.15.0"
|
||||||
path:
|
path:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
@@ -195,10 +195,10 @@ packages:
|
|||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
name: test_api
|
name: test_api
|
||||||
sha256: "9955ae474176f7ac8ee4e989dadfb411a58c30415bcfb648fa04b2b8a03afa7f"
|
sha256: "5b8a98dafc4d5c4c9c72d8b31ab2b23fc13422348d2997120294d3bac86b4ddb"
|
||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "0.7.0"
|
version: "0.7.2"
|
||||||
vector_math:
|
vector_math:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
@@ -211,10 +211,10 @@ packages:
|
|||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
name: vm_service
|
name: vm_service
|
||||||
sha256: "3923c89304b715fb1eb6423f017651664a03bf5f4b29983627c4da791f74a4ec"
|
sha256: "5c5f338a667b4c644744b661f309fb8080bb94b18a7e91ef1dbd343bed00ed6d"
|
||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "14.2.1"
|
version: "14.2.5"
|
||||||
sdks:
|
sdks:
|
||||||
dart: ">=3.4.4 <4.0.0"
|
dart: ">=3.4.4 <4.0.0"
|
||||||
flutter: ">=3.18.0-18.0.pre.54"
|
flutter: ">=3.18.0-18.0.pre.54"
|
||||||
|
|||||||
@@ -1,101 +0,0 @@
|
|||||||
import Foundation
|
|
||||||
import OpenIMCore
|
|
||||||
|
|
||||||
public class ChannelManager: BaseServiceManager {
|
|
||||||
|
|
||||||
public override func registerHandlers() {
|
|
||||||
super.registerHandlers()
|
|
||||||
|
|
||||||
// self["changeChannelMemberMute"] = changeChannelMemberMute
|
|
||||||
// self["changeChannelMute"] = changeChannelMute
|
|
||||||
|
|
||||||
// self["getChannelMemberList"] = getChannelMemberList
|
|
||||||
|
|
||||||
|
|
||||||
self["getChannelMembersInfo"] = getChannelMembersInfo
|
|
||||||
self["getChannelsInfo"] = getChannelsInfo
|
|
||||||
|
|
||||||
|
|
||||||
self["getUsersInChannel"] = getUsersInChannel
|
|
||||||
self["isJoinChannel"] = isJoinChannel
|
|
||||||
self["joinChannel"] = joinChannel
|
|
||||||
self["quitChannel"] = quitChannel
|
|
||||||
self["setChannelListener"] = setChannelListener
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
// func changeChannelMemberMute(methodCall: FlutterMethodCall, result: @escaping FlutterResult) {
|
|
||||||
// Open_im_sdkChangeChannelMemberMute(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[string: "channelID"], methodCall[string:"userID"], methodCall[int:"seconds"])
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// func changeChannelMute(methodCall: FlutterMethodCall, result: @escaping FlutterResult) {
|
|
||||||
// Open_im_sdkChangeChannelMute(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[string: "channelID"], methodCall[bool: "mute"])
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// func getChannelMemberList(methodCall: FlutterMethodCall, result: @escaping FlutterResult) {
|
|
||||||
// Open_im_sdkGetChannelMemberList(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[string: "channelID"], methodCall[int32: "filter"],
|
|
||||||
// methodCall[int32: "offset"], methodCall[int32: "count"])
|
|
||||||
// }
|
|
||||||
|
|
||||||
func getChannelMembersInfo(methodCall: FlutterMethodCall, result: @escaping FlutterResult) {
|
|
||||||
Open_im_sdkGetSpecifiedChannelMembersInfo(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[string: "channelID"], methodCall[jsonString: "userIDList"])
|
|
||||||
}
|
|
||||||
|
|
||||||
func getChannelsInfo(methodCall: FlutterMethodCall, result: @escaping FlutterResult) {
|
|
||||||
Open_im_sdkGetSpecifiedChannelsInfo(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[jsonString: "channelIDList"])
|
|
||||||
}
|
|
||||||
|
|
||||||
func getUsersInChannel(methodCall: FlutterMethodCall, result: @escaping FlutterResult) {
|
|
||||||
Open_im_sdkGetUsersInChannel(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[string: "channelID"],
|
|
||||||
methodCall[jsonString: "userIDs"])
|
|
||||||
}
|
|
||||||
|
|
||||||
func isJoinChannel(methodCall: FlutterMethodCall, result: @escaping FlutterResult) {
|
|
||||||
Open_im_sdkIsJoinChannel(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[string: "channelID"])
|
|
||||||
}
|
|
||||||
|
|
||||||
func joinChannel(methodCall: FlutterMethodCall, result: @escaping FlutterResult) {
|
|
||||||
Open_im_sdkJoinChannel(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[string: "channelID"], methodCall[string:
|
|
||||||
"reason"], methodCall[int32: "joinSource"], methodCall[jsonString: "ex"])
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
func quitChannel(methodCall: FlutterMethodCall, result: @escaping FlutterResult) {
|
|
||||||
Open_im_sdkQuitChannel(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[string: "channelID"])
|
|
||||||
}
|
|
||||||
|
|
||||||
func setChannelListener(methodCall: FlutterMethodCall, result: @escaping FlutterResult) {
|
|
||||||
Open_im_sdkSetChannelListener(ChannelListener(channel: channel))
|
|
||||||
callBack(result)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public class ChannelListener: NSObject, Open_im_sdk_callbackOnChannelListenerProtocol {
|
|
||||||
|
|
||||||
private let channel: FlutterMethodChannel
|
|
||||||
|
|
||||||
init(channel: FlutterMethodChannel) {
|
|
||||||
self.channel = channel
|
|
||||||
}
|
|
||||||
|
|
||||||
public func onChannelDismissed(_ s: String?) {
|
|
||||||
CommonUtil.emitEvent(channel: channel, method: "channelListener", type: "onChannelDismissed", errCode: nil, errMsg: nil, data: s)
|
|
||||||
}
|
|
||||||
|
|
||||||
public func onChannelInfoChanged(_ s: String?) {
|
|
||||||
CommonUtil.emitEvent(channel: channel, method: "channelListener", type: "onChannelInfoChanged", errCode: nil, errMsg: nil, data: s)
|
|
||||||
}
|
|
||||||
|
|
||||||
public func onChannelMemberAdded(_ s: String?) {
|
|
||||||
CommonUtil.emitEvent(channel: channel, method: "channelListener", type: "onChannelMemberAdded", errCode: nil, errMsg: nil, data: s)
|
|
||||||
}
|
|
||||||
|
|
||||||
public func onChannelMemberDeleted(_ s: String?) {
|
|
||||||
CommonUtil.emitEvent(channel: channel, method: "channelListener", type: "onChannelMemberDeleted", errCode: nil, errMsg: nil, data: s)
|
|
||||||
}
|
|
||||||
|
|
||||||
public func onChannelMemberInfoChanged(_ s: String?) {
|
|
||||||
CommonUtil.emitEvent(channel: channel, method: "channelListener", type: "onChannelMemberInfoChanged", errCode: nil, errMsg: nil, data: s)
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
@@ -21,6 +21,7 @@ public class FriendshipManager: BaseServiceManager {
|
|||||||
self["searchFriends"] = searchFriends
|
self["searchFriends"] = searchFriends
|
||||||
self["setFriendListener"] = setFriendListener
|
self["setFriendListener"] = setFriendListener
|
||||||
self["updateFriends"] = updateFriends
|
self["updateFriends"] = updateFriends
|
||||||
|
self["getFriendApplicationUnhandledCount"] = getFriendApplicationUnhandledCount
|
||||||
}
|
}
|
||||||
|
|
||||||
func acceptFriendApplication(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
func acceptFriendApplication(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
||||||
@@ -48,11 +49,11 @@ public class FriendshipManager: BaseServiceManager {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func getFriendApplicationListAsApplicant(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
func getFriendApplicationListAsApplicant(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
||||||
Open_im_sdkGetFriendApplicationListAsApplicant(BaseCallback(result: result), methodCall[string: "operationID"])
|
Open_im_sdkGetFriendApplicationListAsApplicant(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[jsonString: "req"])
|
||||||
}
|
}
|
||||||
|
|
||||||
func getFriendApplicationListAsRecipient(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
func getFriendApplicationListAsRecipient(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
||||||
Open_im_sdkGetFriendApplicationListAsRecipient(BaseCallback(result: result), methodCall[string: "operationID"])
|
Open_im_sdkGetFriendApplicationListAsRecipient(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[jsonString: "req"])
|
||||||
}
|
}
|
||||||
|
|
||||||
func getFriendList(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
func getFriendList(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
||||||
@@ -87,6 +88,10 @@ public class FriendshipManager: BaseServiceManager {
|
|||||||
func updateFriends(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
func updateFriends(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
||||||
Open_im_sdkUpdateFriends(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[jsonString: "req"])
|
Open_im_sdkUpdateFriends(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[jsonString: "req"])
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func getFriendApplicationUnhandledCount(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
||||||
|
Open_im_sdkGetFriendApplicationUnhandledCount(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[jsonString: "req"])
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public class FriendshipListener: NSObject, Open_im_sdk_callbackOnFriendshipListenerProtocol {
|
public class FriendshipListener: NSObject, Open_im_sdk_callbackOnFriendshipListenerProtocol {
|
||||||
|
|||||||
@@ -32,6 +32,7 @@ public class GroupManager: BaseServiceManager {
|
|||||||
self["setGroupListener"] = setGroupListener
|
self["setGroupListener"] = setGroupListener
|
||||||
self["setGroupMemberInfo"] = setGroupMemberInfo
|
self["setGroupMemberInfo"] = setGroupMemberInfo
|
||||||
self["transferGroupOwner"] = transferGroupOwner
|
self["transferGroupOwner"] = transferGroupOwner
|
||||||
|
self["getGroupApplicationUnhandledCount"] = getGroupApplicationUnhandledCount
|
||||||
}
|
}
|
||||||
|
|
||||||
func acceptGroupApplication(methodCall: FlutterMethodCall, result: @escaping FlutterResult) {
|
func acceptGroupApplication(methodCall: FlutterMethodCall, result: @escaping FlutterResult) {
|
||||||
@@ -55,11 +56,11 @@ public class GroupManager: BaseServiceManager {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func getGroupApplicationListAsApplicant(methodCall: FlutterMethodCall, result: @escaping FlutterResult) {
|
func getGroupApplicationListAsApplicant(methodCall: FlutterMethodCall, result: @escaping FlutterResult) {
|
||||||
Open_im_sdkGetGroupApplicationListAsApplicant(BaseCallback(result: result), methodCall[string: "operationID"])
|
Open_im_sdkGetGroupApplicationListAsApplicant(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[jsonString: "req"])
|
||||||
}
|
}
|
||||||
|
|
||||||
func getGroupApplicationListAsRecipient(methodCall: FlutterMethodCall, result: @escaping FlutterResult) {
|
func getGroupApplicationListAsRecipient(methodCall: FlutterMethodCall, result: @escaping FlutterResult) {
|
||||||
Open_im_sdkGetGroupApplicationListAsRecipient(BaseCallback(result: result), methodCall[string: "operationID"])
|
Open_im_sdkGetGroupApplicationListAsRecipient(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[jsonString: "req"])
|
||||||
}
|
}
|
||||||
|
|
||||||
func getGroupMemberList(methodCall: FlutterMethodCall, result: @escaping FlutterResult) {
|
func getGroupMemberList(methodCall: FlutterMethodCall, result: @escaping FlutterResult) {
|
||||||
@@ -147,6 +148,10 @@ public class GroupManager: BaseServiceManager {
|
|||||||
func transferGroupOwner(methodCall: FlutterMethodCall, result: @escaping FlutterResult) {
|
func transferGroupOwner(methodCall: FlutterMethodCall, result: @escaping FlutterResult) {
|
||||||
Open_im_sdkTransferGroupOwner(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[string: "groupID"], methodCall[string: "userID"])
|
Open_im_sdkTransferGroupOwner(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[string: "groupID"], methodCall[string: "userID"])
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func getGroupApplicationUnhandledCount(methodCall: FlutterMethodCall, result: @escaping FlutterResult) {
|
||||||
|
Open_im_sdkGetGroupApplicationUnhandledCount(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[jsonString: "req"])
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public class GroupListener: NSObject, Open_im_sdk_callbackOnGroupListenerProtocol {
|
public class GroupListener: NSObject, Open_im_sdk_callbackOnGroupListenerProtocol {
|
||||||
|
|||||||
@@ -65,7 +65,7 @@ public class MessageManager: BaseServiceManager {
|
|||||||
func sendMessage(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
func sendMessage(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
||||||
let sendMsgProgressListener: SendMsgProgressListener = SendMsgProgressListener(channel: channel,result: result,methodCall: methodCall)
|
let sendMsgProgressListener: SendMsgProgressListener = SendMsgProgressListener(channel: channel,result: result,methodCall: methodCall)
|
||||||
Open_im_sdkSendMessage(sendMsgProgressListener, methodCall[string: "operationID"], methodCall[jsonString: "message"], methodCall[string: "userID"],
|
Open_im_sdkSendMessage(sendMsgProgressListener, methodCall[string: "operationID"], methodCall[jsonString: "message"], methodCall[string: "userID"],
|
||||||
methodCall[string: "groupID"], methodCall[string: "channelID"],methodCall[jsonString: "offlinePushInfo"], methodCall[bool: "isOnlineOnly"])
|
methodCall[string: "groupID"], methodCall[jsonString: "offlinePushInfo"], methodCall[bool: "isOnlineOnly"])
|
||||||
}
|
}
|
||||||
|
|
||||||
func revokeMessage(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
func revokeMessage(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
||||||
@@ -95,7 +95,7 @@ public class MessageManager: BaseServiceManager {
|
|||||||
|
|
||||||
func insertGroupMessageToLocalStorage(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
func insertGroupMessageToLocalStorage(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
||||||
Open_im_sdkInsertGroupMessageToLocalStorage(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[jsonString: "message"],
|
Open_im_sdkInsertGroupMessageToLocalStorage(BaseCallback(result: result), methodCall[string: "operationID"], methodCall[jsonString: "message"],
|
||||||
methodCall[string: "groupID"], methodCall[string: "channelID"],methodCall[string: "senderID"])
|
methodCall[string: "groupID"], methodCall[string: "senderID"])
|
||||||
}
|
}
|
||||||
|
|
||||||
func markMessagesAsReadByMsgID(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
func markMessagesAsReadByMsgID(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
||||||
@@ -227,7 +227,7 @@ public class MessageManager: BaseServiceManager {
|
|||||||
|
|
||||||
func sendMessageNotOss(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
func sendMessageNotOss(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
||||||
let sendMsgProgressListener: SendMsgProgressListener = SendMsgProgressListener(channel: channel,result: result,methodCall: methodCall)
|
let sendMsgProgressListener: SendMsgProgressListener = SendMsgProgressListener(channel: channel,result: result,methodCall: methodCall)
|
||||||
Open_im_sdkSendMessageNotOss(sendMsgProgressListener, methodCall[string: "operationID"], methodCall[jsonString: "message"], methodCall[string: "userID"], methodCall[string: "groupID"], methodCall[string: "channelID"],methodCall[jsonString: "offlinePushInfo"], methodCall[bool: "isOnlineOnly"])
|
Open_im_sdkSendMessageNotOss(sendMsgProgressListener, methodCall[string: "operationID"], methodCall[jsonString: "message"], methodCall[string: "userID"], methodCall[string: "groupID"], methodCall[jsonString: "offlinePushInfo"], methodCall[bool: "isOnlineOnly"])
|
||||||
}
|
}
|
||||||
|
|
||||||
func createImageMessageByURL(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
func createImageMessageByURL(methodCall: FlutterMethodCall, result: @escaping FlutterResult){
|
||||||
|
|||||||
@@ -8,15 +8,13 @@ public class SwiftFlutterOpenimSdkPlugin: NSObject, FlutterPlugin {
|
|||||||
let messageManager: MessageManager
|
let messageManager: MessageManager
|
||||||
let groupManager: GroupManager
|
let groupManager: GroupManager
|
||||||
let userManger: UserManager
|
let userManger: UserManager
|
||||||
let channelManager: ChannelManager
|
|
||||||
|
|
||||||
init(channel: FlutterMethodChannel) {
|
init(channel: FlutterMethodChannel) {
|
||||||
self.imManager = IMMananger(channel: channel)
|
self.imManager = IMMananger(channel: channel)
|
||||||
self.conversationManager = ConversationManager(channel: channel)
|
self.conversationManager = ConversationManager(channel: channel)
|
||||||
self.friendshipManager = FriendshipManager(channel: channel)
|
self.friendshipManager = FriendshipManager(channel: channel)
|
||||||
self.messageManager = MessageManager(channel: channel)
|
self.messageManager = MessageManager(channel: channel)
|
||||||
self.groupManager = GroupManager(channel: channel)
|
self.groupManager = GroupManager(channel: channel)
|
||||||
self.channelManager = ChannelManager(channel: channel)
|
|
||||||
self.userManger = UserManager(channel: channel)
|
self.userManger = UserManager(channel: channel)
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -39,8 +37,6 @@ public class SwiftFlutterOpenimSdkPlugin: NSObject, FlutterPlugin {
|
|||||||
friendshipManager.handleMethod(call: call, result: result)
|
friendshipManager.handleMethod(call: call, result: result)
|
||||||
case "groupManager":
|
case "groupManager":
|
||||||
groupManager.handleMethod(call: call, result: result)
|
groupManager.handleMethod(call: call, result: result)
|
||||||
case "channelManager":
|
|
||||||
channelManager.handleMethod(call: call, result: result)
|
|
||||||
case "userManager":
|
case "userManager":
|
||||||
userManger.handleMethod(call: call, result: result)
|
userManger.handleMethod(call: call, result: result)
|
||||||
default:
|
default:
|
||||||
|
|||||||
@@ -4,7 +4,7 @@
|
|||||||
#
|
#
|
||||||
Pod::Spec.new do |s|
|
Pod::Spec.new do |s|
|
||||||
s.name = 'flutter_openim_sdk'
|
s.name = 'flutter_openim_sdk'
|
||||||
s.version = '0.0.5'
|
s.version = '0.0.1'
|
||||||
s.summary = 'A new Flutter project.'
|
s.summary = 'A new Flutter project.'
|
||||||
s.description = <<-DESC
|
s.description = <<-DESC
|
||||||
A new Flutter project.
|
A new Flutter project.
|
||||||
@@ -15,17 +15,12 @@ A new Flutter project.
|
|||||||
s.source = { :path => '.' }
|
s.source = { :path => '.' }
|
||||||
s.source_files = 'Classes/**/*'
|
s.source_files = 'Classes/**/*'
|
||||||
s.dependency 'Flutter'
|
s.dependency 'Flutter'
|
||||||
s.platform = :ios, '13.0'
|
s.platform = :ios, '11.0'
|
||||||
|
|
||||||
#s.ios.vendored_frameworks = 'frameworks/*.xcframework'
|
s.dependency 'OpenIMSDKCore','3.8.3-hotfix.7'
|
||||||
#s.vendored_frameworks = 'frameworks/*.xcframework'
|
|
||||||
s.dependency 'openim_sdk_core_ios','0.5.0'
|
|
||||||
s.static_framework = true
|
s.static_framework = true
|
||||||
s.library = 'resolv'
|
s.library = 'resolv'
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# s.vendored_frameworks = 'Framework/*.xcframework'
|
# s.vendored_frameworks = 'Framework/*.xcframework'
|
||||||
# Flutter.framework does not contain a i386 slice.
|
# Flutter.framework does not contain a i386 slice.
|
||||||
s.pod_target_xcconfig = { 'DEFINES_MODULE' => 'YES', 'EXCLUDED_ARCHS[sdk=iphonesimulator*]' => 'i386 arm64' }
|
s.pod_target_xcconfig = { 'DEFINES_MODULE' => 'YES', 'EXCLUDED_ARCHS[sdk=iphonesimulator*]' => 'i386 arm64' }
|
||||||
|
|||||||
@@ -17,7 +17,6 @@ export 'src/listener/conversation_listener.dart';
|
|||||||
export 'src/listener/custom_business_listener.dart';
|
export 'src/listener/custom_business_listener.dart';
|
||||||
export 'src/listener/friendship_listener.dart';
|
export 'src/listener/friendship_listener.dart';
|
||||||
export 'src/listener/group_listener.dart';
|
export 'src/listener/group_listener.dart';
|
||||||
export 'src/listener/channel_listener.dart';
|
|
||||||
export 'src/listener/listener_for_service.dart';
|
export 'src/listener/listener_for_service.dart';
|
||||||
export 'src/listener/msg_send_progress_listener.dart';
|
export 'src/listener/msg_send_progress_listener.dart';
|
||||||
export 'src/listener/upload_file_listener.dart';
|
export 'src/listener/upload_file_listener.dart';
|
||||||
@@ -25,13 +24,11 @@ export 'src/listener/user_listener.dart';
|
|||||||
export 'src/manager/im_conversation_manager.dart';
|
export 'src/manager/im_conversation_manager.dart';
|
||||||
export 'src/manager/im_friendship_manager.dart';
|
export 'src/manager/im_friendship_manager.dart';
|
||||||
export 'src/manager/im_group_manager.dart';
|
export 'src/manager/im_group_manager.dart';
|
||||||
export 'src/manager/im_channel_manager.dart';
|
|
||||||
export 'src/manager/im_manager.dart';
|
export 'src/manager/im_manager.dart';
|
||||||
export 'src/manager/im_message_manager.dart';
|
export 'src/manager/im_message_manager.dart';
|
||||||
export 'src/manager/im_user_manager.dart';
|
export 'src/manager/im_user_manager.dart';
|
||||||
export 'src/models/conversation_info.dart';
|
export 'src/models/conversation_info.dart';
|
||||||
export 'src/models/group_info.dart';
|
export 'src/models/group_info.dart';
|
||||||
export 'src/models/channel_info.dart';
|
|
||||||
export 'src/models/init_config.dart';
|
export 'src/models/init_config.dart';
|
||||||
export 'src/models/message.dart';
|
export 'src/models/message.dart';
|
||||||
export 'src/models/notification_info.dart';
|
export 'src/models/notification_info.dart';
|
||||||
|
|||||||
@@ -12,8 +12,4 @@ class ConversationType {
|
|||||||
|
|
||||||
/// Notification
|
/// Notification
|
||||||
static const notification = 4;
|
static const notification = 4;
|
||||||
|
|
||||||
/// Super channel chat
|
|
||||||
static const superChannel = 11;
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -4,7 +4,6 @@ class ListenerType {
|
|||||||
static const connectListener = 'connectListener';
|
static const connectListener = 'connectListener';
|
||||||
static const userListener = 'userListener';
|
static const userListener = 'userListener';
|
||||||
static const groupListener = 'groupListener';
|
static const groupListener = 'groupListener';
|
||||||
static const channelListener = 'channelListener';
|
|
||||||
static const advancedMsgListener = 'advancedMsgListener';
|
static const advancedMsgListener = 'advancedMsgListener';
|
||||||
static const conversationListener = 'conversationListener';
|
static const conversationListener = 'conversationListener';
|
||||||
static const friendListener = 'friendListener';
|
static const friendListener = 'friendListener';
|
||||||
|
|||||||
@@ -12,3 +12,12 @@ class MessageStatus {
|
|||||||
/// Already deleted
|
/// Already deleted
|
||||||
static const deleted = 4;
|
static const deleted = 4;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
enum GetHistoryViewType {
|
||||||
|
history(0),
|
||||||
|
search(1);
|
||||||
|
|
||||||
|
final int rawValue;
|
||||||
|
|
||||||
|
const GetHistoryViewType(this.rawValue);
|
||||||
|
}
|
||||||
|
|||||||
@@ -168,9 +168,6 @@ class MessageType {
|
|||||||
/// Recall Message
|
/// Recall Message
|
||||||
static const revokeMessageNotification = 2101;
|
static const revokeMessageNotification = 2101;
|
||||||
|
|
||||||
/// Edit Message
|
|
||||||
static const editMessageNotification = 2108;
|
|
||||||
|
|
||||||
/// Single Chat Has Read Receipt
|
/// Single Chat Has Read Receipt
|
||||||
static const signalHasReadReceiptNotification = 2150;
|
static const signalHasReadReceiptNotification = 2150;
|
||||||
|
|
||||||
|
|||||||
@@ -4,7 +4,6 @@ import 'package:flutter_openim_sdk/flutter_openim_sdk.dart';
|
|||||||
class OnAdvancedMsgListener {
|
class OnAdvancedMsgListener {
|
||||||
Function(Message msg)? onMsgDeleted;
|
Function(Message msg)? onMsgDeleted;
|
||||||
Function(RevokedInfo info)? onNewRecvMessageRevoked;
|
Function(RevokedInfo info)? onNewRecvMessageRevoked;
|
||||||
Function(EditedInfo info)? onNewRecvMessageEdited;
|
|
||||||
Function(List<ReadReceiptInfo> list)? onRecvC2CReadReceipt;
|
Function(List<ReadReceiptInfo> list)? onRecvC2CReadReceipt;
|
||||||
Function(Message msg)? onRecvNewMessage;
|
Function(Message msg)? onRecvNewMessage;
|
||||||
Function(Message msg)? onRecvOfflineNewMessage;
|
Function(Message msg)? onRecvOfflineNewMessage;
|
||||||
@@ -16,7 +15,6 @@ class OnAdvancedMsgListener {
|
|||||||
OnAdvancedMsgListener({
|
OnAdvancedMsgListener({
|
||||||
this.onMsgDeleted,
|
this.onMsgDeleted,
|
||||||
this.onNewRecvMessageRevoked,
|
this.onNewRecvMessageRevoked,
|
||||||
this.onNewRecvMessageEdited,
|
|
||||||
this.onRecvC2CReadReceipt,
|
this.onRecvC2CReadReceipt,
|
||||||
this.onRecvNewMessage,
|
this.onRecvNewMessage,
|
||||||
this.onRecvOfflineNewMessage,
|
this.onRecvOfflineNewMessage,
|
||||||
@@ -32,12 +30,6 @@ class OnAdvancedMsgListener {
|
|||||||
onNewRecvMessageRevoked?.call(info);
|
onNewRecvMessageRevoked?.call(info);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Message has been edited
|
|
||||||
void newRecvMessageEdited(EditedInfo info) {
|
|
||||||
onNewRecvMessageEdited?.call(info);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/// C2C Message Read Receipt
|
/// C2C Message Read Receipt
|
||||||
void recvC2CReadReceipt(List<ReadReceiptInfo> list) {
|
void recvC2CReadReceipt(List<ReadReceiptInfo> list) {
|
||||||
onRecvC2CReadReceipt?.call(list);
|
onRecvC2CReadReceipt?.call(list);
|
||||||
|
|||||||
@@ -1,60 +0,0 @@
|
|||||||
import 'package:flutter_openim_sdk/flutter_openim_sdk.dart';
|
|
||||||
|
|
||||||
import '../models/channel_info.dart';
|
|
||||||
|
|
||||||
/// Channel Listener
|
|
||||||
class OnChannelListener {
|
|
||||||
|
|
||||||
Function(ChannelInfo info)? onChannelDismissed;
|
|
||||||
Function(ChannelInfo info)? onChannelInfoChanged;
|
|
||||||
Function(ChannelMembersInfo info)? onChannelMemberAdded;
|
|
||||||
Function(ChannelMembersInfo info)? onChannelMemberDeleted;
|
|
||||||
Function(ChannelMembersInfo info)? onChannelMemberInfoChanged;
|
|
||||||
Function(ChannelInfo info)? onJoinedChannelAdded;
|
|
||||||
Function(ChannelInfo info)? onJoinedChannelDeleted;
|
|
||||||
|
|
||||||
OnChannelListener({
|
|
||||||
this.onChannelDismissed,
|
|
||||||
this.onChannelInfoChanged,
|
|
||||||
this.onChannelMemberAdded,
|
|
||||||
this.onChannelMemberDeleted,
|
|
||||||
this.onChannelMemberInfoChanged,
|
|
||||||
this.onJoinedChannelAdded,
|
|
||||||
this.onJoinedChannelDeleted,
|
|
||||||
});
|
|
||||||
|
|
||||||
|
|
||||||
void channelDismissed(ChannelInfo info) {
|
|
||||||
onChannelDismissed?.call(info);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Channel information changed
|
|
||||||
void channelInfoChanged(ChannelInfo info) {
|
|
||||||
onChannelInfoChanged?.call(info);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Channel member added
|
|
||||||
void channelMemberAdded(ChannelMembersInfo info) {
|
|
||||||
onChannelMemberAdded?.call(info);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Channel member deleted
|
|
||||||
void channelMemberDeleted(ChannelMembersInfo info) {
|
|
||||||
onChannelMemberDeleted?.call(info);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Channel member information changed
|
|
||||||
void channelMemberInfoChanged(ChannelMembersInfo info) {
|
|
||||||
onChannelMemberInfoChanged?.call(info);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Joined channel added
|
|
||||||
void joinedChannelAdded(ChannelInfo info) {
|
|
||||||
onJoinedChannelAdded?.call(info);
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Joined channel deleted
|
|
||||||
void joinedChannelDeleted(ChannelInfo info) {
|
|
||||||
onJoinedChannelDeleted?.call(info);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,323 +0,0 @@
|
|||||||
import 'dart:developer';
|
|
||||||
|
|
||||||
import 'package:flutter/services.dart';
|
|
||||||
import 'package:flutter_openim_sdk/flutter_openim_sdk.dart';
|
|
||||||
import 'package:flutter_openim_sdk/src/models/set_channel_member_info.dart';
|
|
||||||
|
|
||||||
import '../listener/channel_listener.dart';
|
|
||||||
import '../models/channel_info.dart';
|
|
||||||
|
|
||||||
class ChannelManager {
|
|
||||||
MethodChannel _channel;
|
|
||||||
late OnChannelListener listener;
|
|
||||||
|
|
||||||
ChannelManager(this._channel);
|
|
||||||
|
|
||||||
/// Channel relationship listener
|
|
||||||
Future setChannelListener(OnChannelListener listener) {
|
|
||||||
this.listener = listener;
|
|
||||||
return _channel.invokeMethod('setChannelListener', _buildParam({}));
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Query channel member information
|
|
||||||
/// [channelID] Channel ID
|
|
||||||
/// [userIDList] List of user IDs
|
|
||||||
Future<List<ChannelMembersInfo>> getChannelMembersInfo({
|
|
||||||
required String channelID,
|
|
||||||
required List<String> userIDList,
|
|
||||||
String? operationID,
|
|
||||||
}) =>
|
|
||||||
_channel
|
|
||||||
.invokeMethod(
|
|
||||||
'getChannelMembersInfo',
|
|
||||||
_buildParam({
|
|
||||||
'channelID': channelID,
|
|
||||||
'userIDList': userIDList,
|
|
||||||
"operationID": Utils.checkOperationID(operationID),
|
|
||||||
}))
|
|
||||||
.then((value) =>
|
|
||||||
Utils.toList(value, (map) => ChannelMembersInfo.fromJson(map)));
|
|
||||||
|
|
||||||
/// Paginate and retrieve the channel member list
|
|
||||||
/// [channelID] Channel ID
|
|
||||||
/// [filter] Member filter (0: All, 1: Channel owner, 2: Administrator, 3: Regular member, 4: Admin + Regular member, 5: Channel owner + Admin)
|
|
||||||
/// [offset] Starting index
|
|
||||||
/// [count] Total count
|
|
||||||
Future<List<ChannelMembersInfo>> getChannelMemberList({
|
|
||||||
required String channelID,
|
|
||||||
int filter = 0,
|
|
||||||
int offset = 0,
|
|
||||||
int count = 0,
|
|
||||||
String? operationID,
|
|
||||||
}) =>
|
|
||||||
_channel
|
|
||||||
.invokeMethod(
|
|
||||||
'getChannelMemberList',
|
|
||||||
_buildParam({
|
|
||||||
'channelID': channelID,
|
|
||||||
'filter': filter,
|
|
||||||
'offset': offset,
|
|
||||||
'count': count,
|
|
||||||
'operationID': Utils.checkOperationID(operationID),
|
|
||||||
}))
|
|
||||||
.then((value) =>
|
|
||||||
Utils.toList(value, (map) => ChannelMembersInfo.fromJson(map)));
|
|
||||||
|
|
||||||
// /// Paginate and retrieve the channel member list as a map
|
|
||||||
// /// [channelID] Channel ID
|
|
||||||
// /// [filter] Member filter (0: All, 1: Channel owner, 2: Administrator, 3: Regular member, 4: Admin + Regular member, 5: Channel owner + Admin)
|
|
||||||
// /// [offset] Starting index
|
|
||||||
// /// [count] Total count
|
|
||||||
// Future<List<dynamic>> getChannelMemberListMap({
|
|
||||||
// required String channelID,
|
|
||||||
// int filter = 0,
|
|
||||||
// int offset = 0,
|
|
||||||
// int count = 0,
|
|
||||||
// String? operationID,
|
|
||||||
// }) =>
|
|
||||||
// _channel
|
|
||||||
// .invokeMethod(
|
|
||||||
// 'getChannelMemberList',
|
|
||||||
// _buildParam({
|
|
||||||
// 'channelID': channelID,
|
|
||||||
// 'filter': filter,
|
|
||||||
// 'offset': offset,
|
|
||||||
// 'count': count,
|
|
||||||
// 'operationID': Utils.checkOperationID(operationID),
|
|
||||||
// }))
|
|
||||||
// .then((value) => Utils.toListMap(value));
|
|
||||||
|
|
||||||
// /// Query the list of joined channels
|
|
||||||
// Future<List<ChannelInfo>> getJoinedChannelList({String? operationID}) => _channel
|
|
||||||
// .invokeMethod(
|
|
||||||
// 'getJoinedChannelList',
|
|
||||||
// _buildParam({
|
|
||||||
// 'operationID': Utils.checkOperationID(operationID),
|
|
||||||
// }))
|
|
||||||
// .then((value) => Utils.toList(value, (map) => ChannelInfo.fromJson(map)));
|
|
||||||
//
|
|
||||||
// Future<List<ChannelInfo>> getJoinedChannelListPage({String? operationID, int offset = 0, int count = 40}) => _channel
|
|
||||||
// .invokeMethod(
|
|
||||||
// 'getJoinedChannelListPage',
|
|
||||||
// _buildParam({
|
|
||||||
// 'offset': offset,
|
|
||||||
// 'count': count,
|
|
||||||
// 'operationID': Utils.checkOperationID(operationID),
|
|
||||||
// }))
|
|
||||||
// .then((value) => Utils.toList(value, (map) => ChannelInfo.fromJson(map)));
|
|
||||||
|
|
||||||
// /// Query the list of joined channels
|
|
||||||
// Future<List<dynamic>> getJoinedChannelListMap({String? operationID}) =>
|
|
||||||
// _channel
|
|
||||||
// .invokeMethod(
|
|
||||||
// 'getJoinedChannelList',
|
|
||||||
// _buildParam({
|
|
||||||
// 'operationID': Utils.checkOperationID(operationID),
|
|
||||||
// }))
|
|
||||||
// .then((value) => Utils.toListMap(value));
|
|
||||||
|
|
||||||
/// Check if the user has joined a channel
|
|
||||||
/// [channelID] Channel ID
|
|
||||||
Future<bool> isJoinedChannel({
|
|
||||||
required String channelID,
|
|
||||||
String? operationID,
|
|
||||||
}) =>
|
|
||||||
_channel
|
|
||||||
.invokeMethod(
|
|
||||||
'isJoinChannel',
|
|
||||||
_buildParam({
|
|
||||||
'channelID': channelID,
|
|
||||||
'operationID': Utils.checkOperationID(operationID),
|
|
||||||
}))
|
|
||||||
.then((value) => value == 'true' ? true : false);
|
|
||||||
|
|
||||||
/// Query channel information
|
|
||||||
Future<List<ChannelInfo>> getChannelsInfo({
|
|
||||||
required List<String> channelIDList,
|
|
||||||
String? operationID,
|
|
||||||
}) =>
|
|
||||||
_channel
|
|
||||||
.invokeMethod(
|
|
||||||
'getChannelsInfo',
|
|
||||||
_buildParam({
|
|
||||||
'channelIDList': channelIDList,
|
|
||||||
'operationID': Utils.checkOperationID(operationID),
|
|
||||||
}))
|
|
||||||
.then((value) =>
|
|
||||||
Utils.toList(value, (map) => ChannelInfo.fromJson(map)));
|
|
||||||
|
|
||||||
/// Apply to join a channel, requiring approval from an administrator or the channel.
|
|
||||||
/// [joinSource] 2: Invited, 3: Searched, 4: Using a QR code
|
|
||||||
Future<dynamic> joinChannel(
|
|
||||||
{required String channelID,
|
|
||||||
String? reason,
|
|
||||||
String? operationID,
|
|
||||||
int joinSource = 3,
|
|
||||||
String? ex}) =>
|
|
||||||
_channel.invokeMethod(
|
|
||||||
'joinChannel',
|
|
||||||
_buildParam({
|
|
||||||
'channelID': channelID,
|
|
||||||
'reason': reason,
|
|
||||||
'joinSource': joinSource,
|
|
||||||
'ex': ex,
|
|
||||||
'operationID': Utils.checkOperationID(operationID),
|
|
||||||
}));
|
|
||||||
|
|
||||||
/// Exit a channel
|
|
||||||
Future<dynamic> quitChannel({
|
|
||||||
required String channelID,
|
|
||||||
String? operationID,
|
|
||||||
}) =>
|
|
||||||
_channel.invokeMethod(
|
|
||||||
'quitChannel',
|
|
||||||
_buildParam({
|
|
||||||
'channelID': channelID,
|
|
||||||
'operationID': Utils.checkOperationID(operationID),
|
|
||||||
}));
|
|
||||||
|
|
||||||
//
|
|
||||||
// /// Query a channel
|
|
||||||
// /// [keywordList] Search keywords; currently, only one keyword is supported, and it cannot be empty.
|
|
||||||
// /// [isSearchChannelID] Whether to search by channel ID (Note: cannot set both to false at the same time); defaults to false if not set.
|
|
||||||
// /// [isSearchChannelName] Whether to search by channel name; defaults to false if not set.
|
|
||||||
// Future<List<ChannelInfo>> searchChannels({
|
|
||||||
// List<String> keywordList = const [],
|
|
||||||
// bool isSearchChannelID = false,
|
|
||||||
// bool isSearchChannelName = false,
|
|
||||||
// String? operationID,
|
|
||||||
// }) =>
|
|
||||||
// _channel
|
|
||||||
// .invokeMethod(
|
|
||||||
// 'searchChannels',
|
|
||||||
// _buildParam({
|
|
||||||
// 'searchParam': {
|
|
||||||
// 'keywordList': keywordList,
|
|
||||||
// 'isSearchChannelID': isSearchChannelID,
|
|
||||||
// 'isSearchChannelName': isSearchChannelName,
|
|
||||||
// },
|
|
||||||
// 'operationID': Utils.checkOperationID(operationID),
|
|
||||||
// }))
|
|
||||||
// .then((value) => Utils.toList(value, (map) => ChannelInfo.fromJson(map)));
|
|
||||||
|
|
||||||
// /// Get a channel member list based on join time
|
|
||||||
// Future<List<ChannelMembersInfo>> getChannelMemberListByJoinTime({
|
|
||||||
// required String channelID,
|
|
||||||
// int offset = 0,
|
|
||||||
// int count = 0,
|
|
||||||
// int joinTimeBegin = 0,
|
|
||||||
// int joinTimeEnd = 0,
|
|
||||||
// List<String> filterUserIDList = const [],
|
|
||||||
// String? operationID,
|
|
||||||
// }) =>
|
|
||||||
// _channel
|
|
||||||
// .invokeMethod(
|
|
||||||
// 'getChannelMemberListByJoinTimeFilter',
|
|
||||||
// _buildParam({
|
|
||||||
// 'channelID': channelID,
|
|
||||||
// 'offset': offset,
|
|
||||||
// 'count': count,
|
|
||||||
// 'joinTimeBegin': joinTimeBegin,
|
|
||||||
// 'joinTimeEnd': joinTimeEnd,
|
|
||||||
// 'excludeUserIDList': filterUserIDList,
|
|
||||||
// 'operationID': Utils.checkOperationID(operationID),
|
|
||||||
// }))
|
|
||||||
// .then((value) => Utils.toList(value, (map) => ChannelMembersInfo.fromJson(map)));
|
|
||||||
|
|
||||||
// /// Search for channel members
|
|
||||||
// /// [channelID] Channel ID
|
|
||||||
// /// [keywordList] Search keywords; currently, only one keyword is supported, and it cannot be empty.
|
|
||||||
// /// [isSearchUserID] Whether to search by member ID
|
|
||||||
// /// [isSearchMemberNickname] Whether to search by member nickname
|
|
||||||
// /// [offset] Start index
|
|
||||||
// /// [count] Total count to retrieve
|
|
||||||
// Future<List<ChannelMembersInfo>> searchChannelMembers({
|
|
||||||
// required String channelID,
|
|
||||||
// List<String> keywordList = const [],
|
|
||||||
// bool isSearchUserID = false,
|
|
||||||
// bool isSearchMemberNickname = false,
|
|
||||||
// int offset = 0,
|
|
||||||
// int count = 40,
|
|
||||||
// String? operationID,
|
|
||||||
// }) =>
|
|
||||||
// _channel
|
|
||||||
// .invokeMethod(
|
|
||||||
// 'searchChannelMembers',
|
|
||||||
// _buildParam({
|
|
||||||
// 'searchParam': {
|
|
||||||
// 'channelID': channelID,
|
|
||||||
// 'keywordList': keywordList,
|
|
||||||
// 'isSearchUserID': isSearchUserID,
|
|
||||||
// 'isSearchMemberNickname': isSearchMemberNickname,
|
|
||||||
// 'offset': offset,
|
|
||||||
// 'count': count,
|
|
||||||
// },
|
|
||||||
// 'operationID': Utils.checkOperationID(operationID),
|
|
||||||
// }))
|
|
||||||
// .then((value) => Utils.toList(value, (map) => ChannelMembersInfo.fromJson(map)));
|
|
||||||
|
|
||||||
// /// Query a channel
|
|
||||||
// /// [channelID] Channel ID
|
|
||||||
// /// [keywordList] Search keyword, currently only supports searching with one keyword, and it cannot be empty
|
|
||||||
// /// [isSearchUserID] Whether to search member IDs with the keyword
|
|
||||||
// /// [isSearchMemberNickname] Whether to search member nicknames with the keyword
|
|
||||||
// /// [offset] Starting index
|
|
||||||
// /// [count] Total number to retrieve each time
|
|
||||||
// Future<List<dynamic>> searchChannelMembersListMap({
|
|
||||||
// required String channelID,
|
|
||||||
// List<String> keywordList = const [],
|
|
||||||
// bool isSearchUserID = false,
|
|
||||||
// bool isSearchMemberNickname = false,
|
|
||||||
// int offset = 0,
|
|
||||||
// int count = 40,
|
|
||||||
// String? operationID,
|
|
||||||
// }) =>
|
|
||||||
// _channel
|
|
||||||
// .invokeMethod(
|
|
||||||
// 'searchChannelMembers',
|
|
||||||
// _buildParam({
|
|
||||||
// 'searchParam': {
|
|
||||||
// 'channelID': channelID,
|
|
||||||
// 'keywordList': keywordList,
|
|
||||||
// 'isSearchUserID': isSearchUserID,
|
|
||||||
// 'isSearchMemberNickname': isSearchMemberNickname,
|
|
||||||
// 'offset': offset,
|
|
||||||
// 'count': count,
|
|
||||||
// },
|
|
||||||
// 'operationID': Utils.checkOperationID(operationID),
|
|
||||||
// }))
|
|
||||||
// .then((value) => Utils.toListMap(value));
|
|
||||||
//
|
|
||||||
// /// Modify the ChannelMemberInfo ex field
|
|
||||||
// Future<dynamic> setChannelMemberInfo({
|
|
||||||
// required SetChannelMemberInfo channelMembersInfo,
|
|
||||||
// String? operationID,
|
|
||||||
// }) =>
|
|
||||||
// _channel.invokeMethod(
|
|
||||||
// 'setChannelMemberInfo',
|
|
||||||
// _buildParam({
|
|
||||||
// 'info': channelMembersInfo.toJson(),
|
|
||||||
// 'operationID': Utils.checkOperationID(operationID),
|
|
||||||
// }));
|
|
||||||
|
|
||||||
Future<dynamic> getUsersInChannel(
|
|
||||||
String channelID,
|
|
||||||
List<String> userIDs, {
|
|
||||||
String? operationID,
|
|
||||||
}) =>
|
|
||||||
_channel.invokeMethod(
|
|
||||||
'getUsersInChannel',
|
|
||||||
_buildParam({
|
|
||||||
'channelID': channelID,
|
|
||||||
'userIDs': userIDs,
|
|
||||||
'operationID': Utils.checkOperationID(operationID),
|
|
||||||
}));
|
|
||||||
|
|
||||||
static Map _buildParam(Map<String, dynamic> param) {
|
|
||||||
param["ManagerName"] = "channelManager";
|
|
||||||
param = Utils.cleanMap(param);
|
|
||||||
log('param: $param');
|
|
||||||
|
|
||||||
return param;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -4,8 +4,6 @@ import 'dart:developer';
|
|||||||
import 'package:flutter/services.dart';
|
import 'package:flutter/services.dart';
|
||||||
import 'package:flutter_openim_sdk/flutter_openim_sdk.dart';
|
import 'package:flutter_openim_sdk/flutter_openim_sdk.dart';
|
||||||
|
|
||||||
import '../models/update_req.dart';
|
|
||||||
|
|
||||||
class ConversationManager {
|
class ConversationManager {
|
||||||
MethodChannel _channel;
|
MethodChannel _channel;
|
||||||
late OnConversationListener listener;
|
late OnConversationListener listener;
|
||||||
|
|||||||
@@ -3,8 +3,6 @@ import 'dart:async';
|
|||||||
import 'package:flutter/services.dart';
|
import 'package:flutter/services.dart';
|
||||||
import 'package:flutter_openim_sdk/flutter_openim_sdk.dart';
|
import 'package:flutter_openim_sdk/flutter_openim_sdk.dart';
|
||||||
|
|
||||||
import '../models/update_req.dart';
|
|
||||||
|
|
||||||
class FriendshipManager {
|
class FriendshipManager {
|
||||||
MethodChannel _channel;
|
MethodChannel _channel;
|
||||||
late OnFriendshipListener listener;
|
late OnFriendshipListener listener;
|
||||||
@@ -51,22 +49,36 @@ class FriendshipManager {
|
|||||||
}));
|
}));
|
||||||
|
|
||||||
/// Get Friend Requests Sent to Me
|
/// Get Friend Requests Sent to Me
|
||||||
Future<List<FriendApplicationInfo>> getFriendApplicationListAsRecipient({String? operationID}) => _channel
|
Future<List<FriendApplicationInfo>> getFriendApplicationListAsRecipient(
|
||||||
.invokeMethod(
|
{GetFriendApplicationListAsRecipientReq? req, String? operationID}) {
|
||||||
'getFriendApplicationListAsRecipient',
|
if (req != null && req.offset > 0) {
|
||||||
_buildParam({
|
assert(req.count > 0, 'count must be greater than 0');
|
||||||
"operationID": Utils.checkOperationID(operationID),
|
}
|
||||||
}))
|
return _channel
|
||||||
.then((value) => Utils.toList(value, (v) => FriendApplicationInfo.fromJson(v)));
|
.invokeMethod(
|
||||||
|
'getFriendApplicationListAsRecipient',
|
||||||
|
_buildParam({
|
||||||
|
'req': req?.toJson() ?? {},
|
||||||
|
"operationID": Utils.checkOperationID(operationID),
|
||||||
|
}))
|
||||||
|
.then((value) => Utils.toList(value, (v) => FriendApplicationInfo.fromJson(v)));
|
||||||
|
}
|
||||||
|
|
||||||
/// Get Friend Requests Sent by Me
|
/// Get Friend Requests Sent by Me
|
||||||
Future<List<FriendApplicationInfo>> getFriendApplicationListAsApplicant({String? operationID}) => _channel
|
Future<List<FriendApplicationInfo>> getFriendApplicationListAsApplicant(
|
||||||
.invokeMethod(
|
{GetFriendApplicationListAsApplicantReq? req, String? operationID}) {
|
||||||
'getFriendApplicationListAsApplicant',
|
if (req != null && req.offset > 0) {
|
||||||
_buildParam({
|
assert(req.count > 0, 'count must be greater than 0');
|
||||||
"operationID": Utils.checkOperationID(operationID),
|
}
|
||||||
}))
|
return _channel
|
||||||
.then((value) => Utils.toList(value, (v) => FriendApplicationInfo.fromJson(v)));
|
.invokeMethod(
|
||||||
|
'getFriendApplicationListAsApplicant',
|
||||||
|
_buildParam({
|
||||||
|
'req': req?.toJson() ?? {},
|
||||||
|
"operationID": Utils.checkOperationID(operationID),
|
||||||
|
}))
|
||||||
|
.then((value) => Utils.toList(value, (v) => FriendApplicationInfo.fromJson(v)));
|
||||||
|
}
|
||||||
|
|
||||||
/// Get Friend List, including friends who have been put into the blacklist
|
/// Get Friend List, including friends who have been put into the blacklist
|
||||||
Future<List<FriendInfo>> getFriendList({
|
Future<List<FriendInfo>> getFriendList({
|
||||||
|
|||||||
@@ -2,7 +2,6 @@ import 'dart:developer';
|
|||||||
|
|
||||||
import 'package:flutter/services.dart';
|
import 'package:flutter/services.dart';
|
||||||
import 'package:flutter_openim_sdk/flutter_openim_sdk.dart';
|
import 'package:flutter_openim_sdk/flutter_openim_sdk.dart';
|
||||||
import 'package:flutter_openim_sdk/src/models/set_group_member_info.dart';
|
|
||||||
|
|
||||||
class GroupManager {
|
class GroupManager {
|
||||||
MethodChannel _channel;
|
MethodChannel _channel;
|
||||||
@@ -40,22 +39,20 @@ class GroupManager {
|
|||||||
/// [groupID] Group ID
|
/// [groupID] Group ID
|
||||||
/// [userIDList] List of user IDs
|
/// [userIDList] List of user IDs
|
||||||
/// [reason] Reason for removal
|
/// [reason] Reason for removal
|
||||||
Future<List<GroupInviteResult>> kickGroupMember({
|
Future kickGroupMember({
|
||||||
required String groupID,
|
required String groupID,
|
||||||
required List<String> userIDList,
|
required List<String> userIDList,
|
||||||
String? reason,
|
String? reason,
|
||||||
String? operationID,
|
String? operationID,
|
||||||
}) =>
|
}) =>
|
||||||
_channel
|
_channel.invokeMethod(
|
||||||
.invokeMethod(
|
'kickGroupMember',
|
||||||
'kickGroupMember',
|
_buildParam({
|
||||||
_buildParam({
|
'groupID': groupID,
|
||||||
'groupID': groupID,
|
'userIDList': userIDList,
|
||||||
'userIDList': userIDList,
|
'reason': reason,
|
||||||
'reason': reason,
|
"operationID": Utils.checkOperationID(operationID),
|
||||||
"operationID": Utils.checkOperationID(operationID),
|
}));
|
||||||
}))
|
|
||||||
.then((value) => Utils.toList(value, (map) => GroupInviteResult.fromJson(map)));
|
|
||||||
|
|
||||||
/// Query group member information
|
/// Query group member information
|
||||||
/// [groupID] Group ID
|
/// [groupID] Group ID
|
||||||
@@ -259,22 +256,41 @@ class GroupManager {
|
|||||||
}));
|
}));
|
||||||
|
|
||||||
/// Handle group membership applications received as a group owner or administrator
|
/// Handle group membership applications received as a group owner or administrator
|
||||||
Future<List<GroupApplicationInfo>> getGroupApplicationListAsRecipient({String? operationID}) => _channel
|
Future<List<GroupApplicationInfo>> getGroupApplicationListAsRecipient({
|
||||||
.invokeMethod(
|
GetGroupApplicationListAsRecipientReq? req,
|
||||||
'getGroupApplicationListAsRecipient',
|
String? operationID,
|
||||||
_buildParam({
|
}) {
|
||||||
'operationID': Utils.checkOperationID(operationID),
|
if (req != null && req.offset > 0) {
|
||||||
}))
|
assert(req.count > 0, 'count must be greater than 0');
|
||||||
.then((value) => Utils.toList(value, (map) => GroupApplicationInfo.fromJson(map)));
|
}
|
||||||
|
return _channel
|
||||||
|
.invokeMethod(
|
||||||
|
'getGroupApplicationListAsRecipient',
|
||||||
|
_buildParam({
|
||||||
|
'req': req?.toJson() ?? {},
|
||||||
|
"operationID": Utils.checkOperationID(operationID),
|
||||||
|
}))
|
||||||
|
.then((value) => Utils.toList(value, (map) => GroupApplicationInfo.fromJson(map)));
|
||||||
|
}
|
||||||
|
|
||||||
/// Get the list of group membership applications sent by the user
|
/// Get the list of group membership applications sent by the user
|
||||||
Future<List<GroupApplicationInfo>> getGroupApplicationListAsApplicant({String? operationID}) => _channel
|
Future<List<GroupApplicationInfo>> getGroupApplicationListAsApplicant({
|
||||||
.invokeMethod(
|
GetGroupApplicationListAsApplicantReq? req,
|
||||||
'getGroupApplicationListAsApplicant',
|
String? operationID,
|
||||||
_buildParam({
|
}) {
|
||||||
'operationID': Utils.checkOperationID(operationID),
|
if (req != null && req.offset > 0) {
|
||||||
}))
|
assert(req.count > 0, 'count must be greater than 0');
|
||||||
.then((value) => Utils.toList(value, (map) => GroupApplicationInfo.fromJson(map)));
|
}
|
||||||
|
|
||||||
|
return _channel
|
||||||
|
.invokeMethod(
|
||||||
|
'getGroupApplicationListAsApplicant',
|
||||||
|
_buildParam({
|
||||||
|
'req': req?.toJson() ?? {},
|
||||||
|
"operationID": Utils.checkOperationID(operationID),
|
||||||
|
}))
|
||||||
|
.then((value) => Utils.toList(value, (map) => GroupApplicationInfo.fromJson(map)));
|
||||||
|
}
|
||||||
|
|
||||||
/// Accept a group membership application as an administrator or group owner
|
/// Accept a group membership application as an administrator or group owner
|
||||||
/// Note: Membership applications require approval from administrators or the group.
|
/// Note: Membership applications require approval from administrators or the group.
|
||||||
@@ -589,9 +605,7 @@ class GroupManager {
|
|||||||
param["ManagerName"] = "groupManager";
|
param["ManagerName"] = "groupManager";
|
||||||
param = Utils.cleanMap(param);
|
param = Utils.cleanMap(param);
|
||||||
log('param: $param');
|
log('param: $param');
|
||||||
|
|
||||||
return param;
|
return param;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -6,9 +6,6 @@ import 'package:flutter/services.dart';
|
|||||||
import 'package:flutter_openim_sdk/flutter_openim_sdk.dart';
|
import 'package:flutter_openim_sdk/flutter_openim_sdk.dart';
|
||||||
import 'package:flutter_openim_sdk/src/logger.dart';
|
import 'package:flutter_openim_sdk/src/logger.dart';
|
||||||
|
|
||||||
import '../models/channel_info.dart';
|
|
||||||
import 'im_channel_manager.dart';
|
|
||||||
|
|
||||||
class IMManager {
|
class IMManager {
|
||||||
MethodChannel _channel;
|
MethodChannel _channel;
|
||||||
late ConversationManager conversationManager;
|
late ConversationManager conversationManager;
|
||||||
@@ -16,7 +13,6 @@ class IMManager {
|
|||||||
late MessageManager messageManager;
|
late MessageManager messageManager;
|
||||||
late GroupManager groupManager;
|
late GroupManager groupManager;
|
||||||
late UserManager userManager;
|
late UserManager userManager;
|
||||||
late ChannelManager channelManager;
|
|
||||||
|
|
||||||
late OnConnectListener _connectListener;
|
late OnConnectListener _connectListener;
|
||||||
OnListenerForService? _listenerForService;
|
OnListenerForService? _listenerForService;
|
||||||
@@ -33,7 +29,6 @@ class IMManager {
|
|||||||
friendshipManager = FriendshipManager(_channel);
|
friendshipManager = FriendshipManager(_channel);
|
||||||
messageManager = MessageManager(_channel);
|
messageManager = MessageManager(_channel);
|
||||||
groupManager = GroupManager(_channel);
|
groupManager = GroupManager(_channel);
|
||||||
channelManager = ChannelManager(_channel);
|
|
||||||
userManager = UserManager(_channel);
|
userManager = UserManager(_channel);
|
||||||
_addNativeCallback(_channel);
|
_addNativeCallback(_channel);
|
||||||
}
|
}
|
||||||
@@ -62,7 +57,7 @@ class IMManager {
|
|||||||
case 'onUserTokenExpired':
|
case 'onUserTokenExpired':
|
||||||
_connectListener.userTokenExpired();
|
_connectListener.userTokenExpired();
|
||||||
break;
|
break;
|
||||||
case 'onUserTokenInvalid':
|
case 'onUserTokenInvalid':
|
||||||
_connectListener.userTokenInvalid();
|
_connectListener.userTokenInvalid();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@@ -128,44 +123,7 @@ class IMManager {
|
|||||||
groupManager.listener.joinedGroupDeleted(i);
|
groupManager.listener.joinedGroupDeleted(i);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
} else if (call.method == ListenerType.channelListener) {
|
} else if (call.method == ListenerType.advancedMsgListener) {
|
||||||
String type = call.arguments['type'];
|
|
||||||
dynamic data = call.arguments['data'];
|
|
||||||
switch (type) {
|
|
||||||
|
|
||||||
case 'onChannelDismissed':
|
|
||||||
final i = Utils.toObj(data, (map) => ChannelInfo.fromJson(map));
|
|
||||||
channelManager.listener.channelDismissed(i);
|
|
||||||
break;
|
|
||||||
case 'onChannelInfoChanged':
|
|
||||||
final i = Utils.toObj(data, (map) => ChannelInfo.fromJson(map));
|
|
||||||
channelManager.listener.channelInfoChanged(i);
|
|
||||||
break;
|
|
||||||
case 'onChannelMemberAdded':
|
|
||||||
final i = Utils.toObj(
|
|
||||||
data, (map) => ChannelMembersInfo.fromJson(map));
|
|
||||||
channelManager.listener.channelMemberAdded(i);
|
|
||||||
break;
|
|
||||||
case 'onChannelMemberDeleted':
|
|
||||||
final i = Utils.toObj(
|
|
||||||
data, (map) => ChannelMembersInfo.fromJson(map));
|
|
||||||
channelManager.listener.channelMemberDeleted(i);
|
|
||||||
break;
|
|
||||||
case 'onChannelMemberInfoChanged':
|
|
||||||
final i = Utils.toObj(
|
|
||||||
data, (map) => ChannelMembersInfo.fromJson(map));
|
|
||||||
channelManager.listener.channelMemberInfoChanged(i);
|
|
||||||
break;
|
|
||||||
case 'onJoinedChannelAdded':
|
|
||||||
final i = Utils.toObj(data, (map) => ChannelInfo.fromJson(map));
|
|
||||||
channelManager.listener.joinedChannelAdded(i);
|
|
||||||
break;
|
|
||||||
case 'onJoinedChannelDeleted':
|
|
||||||
final i = Utils.toObj(data, (map) => ChannelInfo.fromJson(map));
|
|
||||||
channelManager.listener.joinedChannelDeleted(i);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}else if (call.method == ListenerType.advancedMsgListener) {
|
|
||||||
var type = call.arguments['type'];
|
var type = call.arguments['type'];
|
||||||
// var id = call.arguments['data']['id'];
|
// var id = call.arguments['data']['id'];
|
||||||
switch (type) {
|
switch (type) {
|
||||||
@@ -179,11 +137,6 @@ class IMManager {
|
|||||||
var info = Utils.toObj(value, (map) => RevokedInfo.fromJson(map));
|
var info = Utils.toObj(value, (map) => RevokedInfo.fromJson(map));
|
||||||
messageManager.msgListener.newRecvMessageRevoked(info);
|
messageManager.msgListener.newRecvMessageRevoked(info);
|
||||||
break;
|
break;
|
||||||
case 'onNewRecvMessageEdited':
|
|
||||||
var value = call.arguments['data']['messageEdited'];
|
|
||||||
var info = Utils.toObj(value, (map) => EditedInfo.fromJson(map));
|
|
||||||
messageManager.msgListener.newRecvMessageEdited(info);
|
|
||||||
break;
|
|
||||||
case 'onRecvC2CReadReceipt':
|
case 'onRecvC2CReadReceipt':
|
||||||
var value = call.arguments['data']['msgReceiptList'];
|
var value = call.arguments['data']['msgReceiptList'];
|
||||||
var list = Utils.toList(value, (map) => ReadReceiptInfo.fromJson(map));
|
var list = Utils.toList(value, (map) => ReadReceiptInfo.fromJson(map));
|
||||||
@@ -459,8 +412,8 @@ class IMManager {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// Deinitialize the SDK
|
/// Deinitialize the SDK
|
||||||
Future<dynamic> unInitSDK() {
|
void unInitSDK() {
|
||||||
return _channel.invokeMethod('unInitSDK', _buildParam({}));
|
_channel.invokeMethod('unInitSDK', _buildParam({}));
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Login
|
/// Login
|
||||||
|
|||||||
@@ -36,7 +36,6 @@ class MessageManager {
|
|||||||
required OfflinePushInfo offlinePushInfo,
|
required OfflinePushInfo offlinePushInfo,
|
||||||
String? userID,
|
String? userID,
|
||||||
String? groupID,
|
String? groupID,
|
||||||
String? channelID,
|
|
||||||
bool isOnlineOnly = false,
|
bool isOnlineOnly = false,
|
||||||
String? operationID,
|
String? operationID,
|
||||||
}) =>
|
}) =>
|
||||||
@@ -48,7 +47,6 @@ class MessageManager {
|
|||||||
'offlinePushInfo': offlinePushInfo.toJson(),
|
'offlinePushInfo': offlinePushInfo.toJson(),
|
||||||
'userID': userID ?? '',
|
'userID': userID ?? '',
|
||||||
'groupID': groupID ?? '',
|
'groupID': groupID ?? '',
|
||||||
'channelID': channelID ?? '',
|
|
||||||
'isOnlineOnly': isOnlineOnly,
|
'isOnlineOnly': isOnlineOnly,
|
||||||
'operationID': Utils.checkOperationID(operationID),
|
'operationID': Utils.checkOperationID(operationID),
|
||||||
}))
|
}))
|
||||||
@@ -132,7 +130,6 @@ class MessageManager {
|
|||||||
/// [message] Message content
|
/// [message] Message content
|
||||||
Future<Message> insertGroupMessageToLocalStorage({
|
Future<Message> insertGroupMessageToLocalStorage({
|
||||||
String? groupID,
|
String? groupID,
|
||||||
String? channelID,
|
|
||||||
String? senderID,
|
String? senderID,
|
||||||
Message? message,
|
Message? message,
|
||||||
String? operationID,
|
String? operationID,
|
||||||
@@ -143,7 +140,6 @@ class MessageManager {
|
|||||||
_buildParam({
|
_buildParam({
|
||||||
"message": message?.toJson(),
|
"message": message?.toJson(),
|
||||||
"groupID": groupID,
|
"groupID": groupID,
|
||||||
"channelID": channelID,
|
|
||||||
"senderID": senderID,
|
"senderID": senderID,
|
||||||
"operationID": Utils.checkOperationID(operationID),
|
"operationID": Utils.checkOperationID(operationID),
|
||||||
}))
|
}))
|
||||||
@@ -151,8 +147,7 @@ class MessageManager {
|
|||||||
|
|
||||||
/// Typing status update
|
/// Typing status update
|
||||||
/// [msgTip] Custom content
|
/// [msgTip] Custom content
|
||||||
@Deprecated(
|
@Deprecated('Use [OpenIM.iMManager.conversationManager.changeInputStates(conversationID:focus:)] instead')
|
||||||
'Use [OpenIM.iMManager.conversationManager.changeInputStates(conversationID:focus:)] instead')
|
|
||||||
Future typingStatusUpdate({
|
Future typingStatusUpdate({
|
||||||
required String userID,
|
required String userID,
|
||||||
String? msgTip,
|
String? msgTip,
|
||||||
@@ -532,8 +527,7 @@ class MessageManager {
|
|||||||
},
|
},
|
||||||
'operationID': Utils.checkOperationID(operationID),
|
'operationID': Utils.checkOperationID(operationID),
|
||||||
}))
|
}))
|
||||||
.then((value) =>
|
.then((value) => Utils.toObj(value, (map) => SearchResult.fromJson(map)));
|
||||||
Utils.toObj(value, (map) => SearchResult.fromJson(map)));
|
|
||||||
|
|
||||||
/// Revoke a message
|
/// Revoke a message
|
||||||
/// [message] The message to be revoked
|
/// [message] The message to be revoked
|
||||||
@@ -550,23 +544,6 @@ class MessageManager {
|
|||||||
"operationID": Utils.checkOperationID(operationID),
|
"operationID": Utils.checkOperationID(operationID),
|
||||||
}));
|
}));
|
||||||
|
|
||||||
/// Edit a message
|
|
||||||
/// [message] The message to be edited
|
|
||||||
Future editMessage({
|
|
||||||
required String conversationID,
|
|
||||||
required String clientMsgID,
|
|
||||||
String? operationID,
|
|
||||||
required Message message,
|
|
||||||
}) =>
|
|
||||||
_channel.invokeMethod(
|
|
||||||
'editMessage',
|
|
||||||
_buildParam({
|
|
||||||
'conversationID': conversationID,
|
|
||||||
'clientMsgID': clientMsgID,
|
|
||||||
"operationID": Utils.checkOperationID(operationID),
|
|
||||||
'message': message.toJson(),
|
|
||||||
}));
|
|
||||||
|
|
||||||
/// Mark messages as read
|
/// Mark messages as read
|
||||||
/// [conversationID] Conversation ID
|
/// [conversationID] Conversation ID
|
||||||
/// [messageIDList] List of clientMsgIDs of messages to be marked as read
|
/// [messageIDList] List of clientMsgIDs of messages to be marked as read
|
||||||
@@ -592,7 +569,7 @@ class MessageManager {
|
|||||||
Future<AdvancedMessage> getAdvancedHistoryMessageList({
|
Future<AdvancedMessage> getAdvancedHistoryMessageList({
|
||||||
String? conversationID,
|
String? conversationID,
|
||||||
Message? startMsg,
|
Message? startMsg,
|
||||||
int? lastMinSeq,
|
GetHistoryViewType viewType = GetHistoryViewType.history,
|
||||||
int? count,
|
int? count,
|
||||||
String? operationID,
|
String? operationID,
|
||||||
}) =>
|
}) =>
|
||||||
@@ -603,11 +580,10 @@ class MessageManager {
|
|||||||
'conversationID': conversationID ?? '',
|
'conversationID': conversationID ?? '',
|
||||||
'startClientMsgID': startMsg?.clientMsgID ?? '',
|
'startClientMsgID': startMsg?.clientMsgID ?? '',
|
||||||
'count': count ?? 40,
|
'count': count ?? 40,
|
||||||
'lastMinSeq': lastMinSeq ?? 0,
|
'viewType': viewType.rawValue,
|
||||||
'operationID': Utils.checkOperationID(operationID),
|
'operationID': Utils.checkOperationID(operationID),
|
||||||
}))
|
}))
|
||||||
.then((value) =>
|
.then((value) => Utils.toObj(value, (map) => AdvancedMessage.fromJson(map)));
|
||||||
Utils.toObj(value, (map) => AdvancedMessage.fromJson(map)));
|
|
||||||
|
|
||||||
/// Get chat history (newly received chat history after startMsg). Used for locating a specific message in global search and then fetching messages received after that message.
|
/// Get chat history (newly received chat history after startMsg). Used for locating a specific message in global search and then fetching messages received after that message.
|
||||||
/// [conversationID] Conversation ID, can be used for querying notifications
|
/// [conversationID] Conversation ID, can be used for querying notifications
|
||||||
@@ -616,7 +592,7 @@ class MessageManager {
|
|||||||
Future<AdvancedMessage> getAdvancedHistoryMessageListReverse({
|
Future<AdvancedMessage> getAdvancedHistoryMessageListReverse({
|
||||||
String? conversationID,
|
String? conversationID,
|
||||||
Message? startMsg,
|
Message? startMsg,
|
||||||
int? lastMinSeq,
|
GetHistoryViewType viewType = GetHistoryViewType.history,
|
||||||
int? count,
|
int? count,
|
||||||
String? operationID,
|
String? operationID,
|
||||||
}) =>
|
}) =>
|
||||||
@@ -627,11 +603,10 @@ class MessageManager {
|
|||||||
'conversationID': conversationID ?? '',
|
'conversationID': conversationID ?? '',
|
||||||
'startClientMsgID': startMsg?.clientMsgID ?? '',
|
'startClientMsgID': startMsg?.clientMsgID ?? '',
|
||||||
'count': count ?? 40,
|
'count': count ?? 40,
|
||||||
'lastMinSeq': lastMinSeq ?? 0,
|
'viewType': viewType.rawValue,
|
||||||
'operationID': Utils.checkOperationID(operationID),
|
'operationID': Utils.checkOperationID(operationID),
|
||||||
}))
|
}))
|
||||||
.then((value) =>
|
.then((value) => Utils.toObj(value, (map) => AdvancedMessage.fromJson(map)));
|
||||||
Utils.toObj(value, (map) => AdvancedMessage.fromJson(map)));
|
|
||||||
|
|
||||||
/// Find message details
|
/// Find message details
|
||||||
/// [conversationID] Conversation ID
|
/// [conversationID] Conversation ID
|
||||||
@@ -647,8 +622,7 @@ class MessageManager {
|
|||||||
'searchParams': searchParams.map((e) => e.toJson()).toList(),
|
'searchParams': searchParams.map((e) => e.toJson()).toList(),
|
||||||
'operationID': Utils.checkOperationID(operationID),
|
'operationID': Utils.checkOperationID(operationID),
|
||||||
}))
|
}))
|
||||||
.then((value) =>
|
.then((value) => Utils.toObj(value, (map) => SearchResult.fromJson(map)));
|
||||||
Utils.toObj(value, (map) => SearchResult.fromJson(map)));
|
|
||||||
|
|
||||||
/// Rich text message
|
/// Rich text message
|
||||||
/// [text] Input content
|
/// [text] Input content
|
||||||
@@ -700,7 +674,6 @@ class MessageManager {
|
|||||||
required OfflinePushInfo offlinePushInfo,
|
required OfflinePushInfo offlinePushInfo,
|
||||||
String? userID,
|
String? userID,
|
||||||
String? groupID,
|
String? groupID,
|
||||||
String? channelID,
|
|
||||||
bool isOnlineOnly = false,
|
bool isOnlineOnly = false,
|
||||||
String? operationID,
|
String? operationID,
|
||||||
}) =>
|
}) =>
|
||||||
@@ -712,7 +685,6 @@ class MessageManager {
|
|||||||
'offlinePushInfo': offlinePushInfo.toJson(),
|
'offlinePushInfo': offlinePushInfo.toJson(),
|
||||||
'userID': userID ?? '',
|
'userID': userID ?? '',
|
||||||
'groupID': groupID ?? '',
|
'groupID': groupID ?? '',
|
||||||
'channelID': channelID ?? '',
|
|
||||||
'isOnlineOnly': isOnlineOnly,
|
'isOnlineOnly': isOnlineOnly,
|
||||||
'operationID': Utils.checkOperationID(operationID),
|
'operationID': Utils.checkOperationID(operationID),
|
||||||
}))
|
}))
|
||||||
|
|||||||
@@ -1,165 +0,0 @@
|
|||||||
import 'package:flutter_openim_sdk/flutter_openim_sdk.dart';
|
|
||||||
|
|
||||||
/// Channel Information
|
|
||||||
class ChannelInfo {
|
|
||||||
/// Channel ID
|
|
||||||
String channelID;
|
|
||||||
|
|
||||||
/// Channel Name
|
|
||||||
String? channelName;
|
|
||||||
|
|
||||||
/// Channel Announcement
|
|
||||||
String? notification;
|
|
||||||
|
|
||||||
/// Channel Introduction
|
|
||||||
String? introduction;
|
|
||||||
|
|
||||||
/// Channel Avatar
|
|
||||||
String? faceURL;
|
|
||||||
|
|
||||||
/// Creation Time
|
|
||||||
int? createTime;
|
|
||||||
|
|
||||||
/// Number of Channel Members
|
|
||||||
int? memberCount;
|
|
||||||
|
|
||||||
/// Channel Status: 0 - Normal, 1 - Blocked, 2 - Dissolved, 3 - Muted
|
|
||||||
int? status;
|
|
||||||
|
|
||||||
/// Creator's ID
|
|
||||||
String? creatorUserID;
|
|
||||||
|
|
||||||
/// Channel Type [ChannelType]
|
|
||||||
int? channelType;
|
|
||||||
|
|
||||||
/// Extra Information
|
|
||||||
String? ex;
|
|
||||||
|
|
||||||
|
|
||||||
ChannelInfo({
|
|
||||||
required this.channelID,
|
|
||||||
this.channelName,
|
|
||||||
this.notification,
|
|
||||||
this.introduction,
|
|
||||||
this.faceURL,
|
|
||||||
this.createTime,
|
|
||||||
this.memberCount,
|
|
||||||
this.status,
|
|
||||||
this.creatorUserID,
|
|
||||||
this.channelType,
|
|
||||||
this.ex,
|
|
||||||
});
|
|
||||||
|
|
||||||
ChannelInfo.fromJson(Map<String, dynamic> json) : channelID = json['channelID'] {
|
|
||||||
channelName = json['channelName'];
|
|
||||||
notification = json['notification'];
|
|
||||||
introduction = json['introduction'];
|
|
||||||
faceURL = json['faceURL'];
|
|
||||||
createTime = json['createTime'];
|
|
||||||
memberCount = json['memberCount'];
|
|
||||||
status = json['status'];
|
|
||||||
creatorUserID = json['creatorUserID'];
|
|
||||||
channelType = json['channelType'];
|
|
||||||
ex = json['ex'];
|
|
||||||
}
|
|
||||||
|
|
||||||
Map<String, dynamic> toJson() {
|
|
||||||
final data = Map<String, dynamic>();
|
|
||||||
data['channelID'] = this.channelID;
|
|
||||||
data['channelName'] = this.channelName;
|
|
||||||
data['notification'] = this.notification;
|
|
||||||
data['introduction'] = this.introduction;
|
|
||||||
data['faceURL'] = this.faceURL;
|
|
||||||
data['createTime'] = this.createTime;
|
|
||||||
data['memberCount'] = this.memberCount;
|
|
||||||
data['status'] = this.status;
|
|
||||||
data['creatorUserID'] = this.creatorUserID;
|
|
||||||
data['channelType'] = this.channelType;
|
|
||||||
data['ex'] = this.ex;
|
|
||||||
return data;
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Corresponding Conversation Type for Channel Type
|
|
||||||
int get sessionType => ConversationType.superChannel;
|
|
||||||
|
|
||||||
@override
|
|
||||||
bool operator ==(Object other) =>
|
|
||||||
identical(this, other) || other is ChannelInfo && runtimeType == other.runtimeType && channelID == other.channelID;
|
|
||||||
|
|
||||||
@override
|
|
||||||
int get hashCode => channelID.hashCode;
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Channel Member Information
|
|
||||||
class ChannelMembersInfo {
|
|
||||||
/// Channel ID
|
|
||||||
String? channelID;
|
|
||||||
|
|
||||||
/// User ID
|
|
||||||
String? userID;
|
|
||||||
|
|
||||||
/// Nickname
|
|
||||||
String? nickname;
|
|
||||||
|
|
||||||
/// Avatar
|
|
||||||
String? faceURL;
|
|
||||||
|
|
||||||
/// Role [ChannelRoleLevel]
|
|
||||||
int? roleLevel;
|
|
||||||
|
|
||||||
/// Join Time
|
|
||||||
int? joinTime;
|
|
||||||
|
|
||||||
/// Extra Information
|
|
||||||
String? ex;
|
|
||||||
|
|
||||||
/// Mute End Time (seconds)
|
|
||||||
int? muteEndTime;
|
|
||||||
|
|
||||||
ChannelMembersInfo({
|
|
||||||
this.channelID,
|
|
||||||
this.userID,
|
|
||||||
this.roleLevel,
|
|
||||||
this.joinTime,
|
|
||||||
this.nickname,
|
|
||||||
this.faceURL,
|
|
||||||
this.ex,
|
|
||||||
this.muteEndTime,
|
|
||||||
});
|
|
||||||
|
|
||||||
ChannelMembersInfo.fromJson(Map<String, dynamic> json) {
|
|
||||||
channelID = json['channelID'];
|
|
||||||
userID = json['userID'];
|
|
||||||
roleLevel = json['roleLevel'];
|
|
||||||
joinTime = json['joinTime'];
|
|
||||||
nickname = json['nickname'];
|
|
||||||
faceURL = json['faceURL'];
|
|
||||||
ex = json['ex'];
|
|
||||||
muteEndTime = json['muteEndTime'];
|
|
||||||
}
|
|
||||||
|
|
||||||
Map<String, dynamic> toJson() {
|
|
||||||
final data = Map<String, dynamic>();
|
|
||||||
data['channelID'] = this.channelID;
|
|
||||||
data['userID'] = this.userID;
|
|
||||||
data['roleLevel'] = this.roleLevel;
|
|
||||||
data['joinTime'] = this.joinTime;
|
|
||||||
data['nickname'] = this.nickname;
|
|
||||||
data['faceURL'] = this.faceURL;
|
|
||||||
data['ex'] = this.ex;
|
|
||||||
data['muteEndTime'] = this.muteEndTime;
|
|
||||||
|
|
||||||
return data;
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
bool operator ==(Object other) =>
|
|
||||||
identical(this, other) ||
|
|
||||||
other is ChannelMembersInfo &&
|
|
||||||
runtimeType == other.runtimeType &&
|
|
||||||
channelID == other.channelID &&
|
|
||||||
userID == other.userID;
|
|
||||||
|
|
||||||
@override
|
|
||||||
int get hashCode => channelID.hashCode ^ userID.hashCode;
|
|
||||||
}
|
|
||||||
@@ -15,9 +15,6 @@ class ConversationInfo {
|
|||||||
// Group ID in case of a group chat
|
// Group ID in case of a group chat
|
||||||
String? groupID;
|
String? groupID;
|
||||||
|
|
||||||
// Channel ID in case of a channel chat
|
|
||||||
String? channelID;
|
|
||||||
|
|
||||||
// Display name or nickname
|
// Display name or nickname
|
||||||
String? showName;
|
String? showName;
|
||||||
|
|
||||||
@@ -72,7 +69,6 @@ class ConversationInfo {
|
|||||||
this.conversationType,
|
this.conversationType,
|
||||||
this.userID,
|
this.userID,
|
||||||
this.groupID,
|
this.groupID,
|
||||||
this.channelID,
|
|
||||||
this.showName,
|
this.showName,
|
||||||
this.faceURL,
|
this.faceURL,
|
||||||
this.recvMsgOpt,
|
this.recvMsgOpt,
|
||||||
@@ -95,7 +91,6 @@ class ConversationInfo {
|
|||||||
conversationType = json['conversationType'];
|
conversationType = json['conversationType'];
|
||||||
userID = json['userID'];
|
userID = json['userID'];
|
||||||
groupID = json['groupID'];
|
groupID = json['groupID'];
|
||||||
channelID = json['channelID'];
|
|
||||||
showName = json['showName'];
|
showName = json['showName'];
|
||||||
faceURL = json['faceURL'];
|
faceURL = json['faceURL'];
|
||||||
recvMsgOpt = json['recvMsgOpt'];
|
recvMsgOpt = json['recvMsgOpt'];
|
||||||
@@ -127,7 +122,6 @@ class ConversationInfo {
|
|||||||
data['conversationType'] = this.conversationType;
|
data['conversationType'] = this.conversationType;
|
||||||
data['userID'] = this.userID;
|
data['userID'] = this.userID;
|
||||||
data['groupID'] = this.groupID;
|
data['groupID'] = this.groupID;
|
||||||
data['channelID'] = this.channelID;
|
|
||||||
data['showName'] = this.showName;
|
data['showName'] = this.showName;
|
||||||
data['faceURL'] = this.faceURL;
|
data['faceURL'] = this.faceURL;
|
||||||
data['recvMsgOpt'] = this.recvMsgOpt;
|
data['recvMsgOpt'] = this.recvMsgOpt;
|
||||||
@@ -153,10 +147,6 @@ class ConversationInfo {
|
|||||||
// Check if it's a group chat
|
// Check if it's a group chat
|
||||||
bool get isGroupChat => conversationType == ConversationType.group || conversationType == ConversationType.superGroup;
|
bool get isGroupChat => conversationType == ConversationType.group || conversationType == ConversationType.superGroup;
|
||||||
|
|
||||||
// Check if it's a channel chat
|
|
||||||
bool get isChannelChat => conversationType == ConversationType.superChannel;
|
|
||||||
|
|
||||||
|
|
||||||
// Check if it's a valid conversation (not in a group if isNotInGroup is true)
|
// Check if it's a valid conversation (not in a group if isNotInGroup is true)
|
||||||
bool get isValid => isSingleChat || (isGroupChat && !isNotInGroup!);
|
bool get isValid => isSingleChat || (isGroupChat && !isNotInGroup!);
|
||||||
|
|
||||||
|
|||||||
@@ -422,3 +422,90 @@ class GroupInviteResult {
|
|||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
class GetGroupApplicationListAsRecipientReq {
|
||||||
|
final List<String> groupIDs;
|
||||||
|
final List<int> handleResults;
|
||||||
|
final int offset;
|
||||||
|
final int count;
|
||||||
|
|
||||||
|
GetGroupApplicationListAsRecipientReq({
|
||||||
|
this.groupIDs = const [],
|
||||||
|
this.handleResults = const [],
|
||||||
|
required this.offset,
|
||||||
|
required this.count,
|
||||||
|
});
|
||||||
|
|
||||||
|
GetGroupApplicationListAsRecipientReq.fromJson(Map<String, dynamic> json)
|
||||||
|
: groupIDs = json['groupIDs'] == null ? [] : List<String>.from(json['groupIDs'].map((x) => x)),
|
||||||
|
handleResults = json['handleResults'] == null ? [] : List<int>.from(json['handleResults'].map((x) => x)),
|
||||||
|
offset = json['offset'],
|
||||||
|
count = json['count'];
|
||||||
|
|
||||||
|
Map<String, dynamic> toJson() {
|
||||||
|
final data = <String, dynamic>{};
|
||||||
|
data['groupIDs'] = groupIDs;
|
||||||
|
data['handleResults'] = handleResults;
|
||||||
|
data['offset'] = offset;
|
||||||
|
data['count'] = count;
|
||||||
|
return data;
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
String toString() {
|
||||||
|
return 'GetGroupApplicationListAsRecipientReq{groupIDs: $groupIDs, handleResults: $handleResults, offset: $offset, count: $count}';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class GetGroupApplicationListAsApplicantReq {
|
||||||
|
final List<String> groupIDs;
|
||||||
|
final List<int> handleResults;
|
||||||
|
final int offset;
|
||||||
|
final int count;
|
||||||
|
|
||||||
|
GetGroupApplicationListAsApplicantReq({
|
||||||
|
this.groupIDs = const [],
|
||||||
|
this.handleResults = const [],
|
||||||
|
required this.offset,
|
||||||
|
required this.count,
|
||||||
|
});
|
||||||
|
|
||||||
|
GetGroupApplicationListAsApplicantReq.fromJson(Map<String, dynamic> json)
|
||||||
|
: groupIDs = json['groupIDs'] == null ? [] : List<String>.from(json['groupIDs'].map((x) => x)),
|
||||||
|
handleResults = json['handleResults'] == null ? [] : List<int>.from(json['handleResults'].map((x) => x)),
|
||||||
|
offset = json['offset'],
|
||||||
|
count = json['count'];
|
||||||
|
|
||||||
|
Map<String, dynamic> toJson() {
|
||||||
|
final data = <String, dynamic>{};
|
||||||
|
data['groupIDs'] = groupIDs;
|
||||||
|
data['handleResults'] = handleResults;
|
||||||
|
data['offset'] = offset;
|
||||||
|
data['count'] = count;
|
||||||
|
return data;
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
String toString() {
|
||||||
|
return 'GetGroupApplicationListAsApplicantReq{groupIDs: $groupIDs, handleResults: $handleResults, offset: $offset, count: $count}';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class GetGroupApplicationUnhandledCountReq {
|
||||||
|
final int time;
|
||||||
|
|
||||||
|
GetGroupApplicationUnhandledCountReq({this.time = 0});
|
||||||
|
|
||||||
|
GetGroupApplicationUnhandledCountReq.fromJson(Map<String, dynamic> json) : time = json['time'];
|
||||||
|
|
||||||
|
Map<String, dynamic> toJson() {
|
||||||
|
final data = <String, dynamic>{};
|
||||||
|
data['time'] = time;
|
||||||
|
return data;
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
String toString() {
|
||||||
|
return 'GetGroupApplicationUnhandledCountReq{time: $time}';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|||||||
@@ -42,9 +42,6 @@ class Message {
|
|||||||
/// Group ID.
|
/// Group ID.
|
||||||
String? groupID;
|
String? groupID;
|
||||||
|
|
||||||
/// Channel ID.
|
|
||||||
String? channelID;
|
|
||||||
|
|
||||||
/// Message localEx.
|
/// Message localEx.
|
||||||
String? localEx;
|
String? localEx;
|
||||||
|
|
||||||
@@ -140,7 +137,6 @@ class Message {
|
|||||||
this.senderNickname,
|
this.senderNickname,
|
||||||
this.senderFaceUrl,
|
this.senderFaceUrl,
|
||||||
this.groupID,
|
this.groupID,
|
||||||
this.channelID,
|
|
||||||
this.localEx,
|
this.localEx,
|
||||||
this.seq,
|
this.seq,
|
||||||
this.isRead,
|
this.isRead,
|
||||||
@@ -183,7 +179,6 @@ class Message {
|
|||||||
senderNickname = json['senderNickname'];
|
senderNickname = json['senderNickname'];
|
||||||
senderFaceUrl = json['senderFaceUrl'];
|
senderFaceUrl = json['senderFaceUrl'];
|
||||||
groupID = json['groupID'];
|
groupID = json['groupID'];
|
||||||
channelID = json['channelID'];
|
|
||||||
localEx = json['localEx'];
|
localEx = json['localEx'];
|
||||||
seq = json['seq'];
|
seq = json['seq'];
|
||||||
isRead = json['isRead'];
|
isRead = json['isRead'];
|
||||||
@@ -229,7 +224,6 @@ class Message {
|
|||||||
data['senderNickname'] = this.senderNickname;
|
data['senderNickname'] = this.senderNickname;
|
||||||
data['senderFaceUrl'] = this.senderFaceUrl;
|
data['senderFaceUrl'] = this.senderFaceUrl;
|
||||||
data['groupID'] = this.groupID;
|
data['groupID'] = this.groupID;
|
||||||
data['channelID'] = this.channelID;
|
|
||||||
data['localEx'] = this.localEx;
|
data['localEx'] = this.localEx;
|
||||||
data['seq'] = this.seq;
|
data['seq'] = this.seq;
|
||||||
data['isRead'] = this.isRead;
|
data['isRead'] = this.isRead;
|
||||||
@@ -281,7 +275,6 @@ class Message {
|
|||||||
senderNickname = message.senderNickname;
|
senderNickname = message.senderNickname;
|
||||||
senderFaceUrl = message.senderFaceUrl;
|
senderFaceUrl = message.senderFaceUrl;
|
||||||
groupID = message.groupID;
|
groupID = message.groupID;
|
||||||
channelID = message.channelID;
|
|
||||||
// content = message.content;
|
// content = message.content;
|
||||||
seq = message.seq;
|
seq = message.seq;
|
||||||
isRead = message.isRead;
|
isRead = message.isRead;
|
||||||
@@ -1123,82 +1116,6 @@ class RevokedInfo {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/// Message revocation details
|
|
||||||
class EditedInfo {
|
|
||||||
/// Editer's ID
|
|
||||||
String? editerID;
|
|
||||||
|
|
||||||
|
|
||||||
/// Message ID
|
|
||||||
String? clientMsgID;
|
|
||||||
|
|
||||||
/// Revocation time
|
|
||||||
int? editTime;
|
|
||||||
|
|
||||||
/// Message sending time
|
|
||||||
int? sourceMessageSendTime;
|
|
||||||
|
|
||||||
/// Message sender
|
|
||||||
String? sourceMessageSendID;
|
|
||||||
|
|
||||||
/// Message sender's nickname
|
|
||||||
String? sourceMessageSenderNickname;
|
|
||||||
|
|
||||||
/// Conversation type [ConversationType]
|
|
||||||
int? sessionType;
|
|
||||||
|
|
||||||
/// Message contentType
|
|
||||||
int? contentType;
|
|
||||||
|
|
||||||
/// Message content
|
|
||||||
String? content;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
EditedInfo({
|
|
||||||
this.editerID,
|
|
||||||
this.clientMsgID,
|
|
||||||
this.editTime,
|
|
||||||
this.sourceMessageSendTime,
|
|
||||||
this.sourceMessageSendID,
|
|
||||||
this.sourceMessageSenderNickname,
|
|
||||||
this.sessionType,
|
|
||||||
this.contentType,
|
|
||||||
this.content,
|
|
||||||
});
|
|
||||||
|
|
||||||
EditedInfo.fromJson(Map<String, dynamic> json) {
|
|
||||||
editerID = json['editerID'];
|
|
||||||
clientMsgID = json['clientMsgID'];
|
|
||||||
editTime = json['editTime'];
|
|
||||||
sourceMessageSendTime = json['sourceMessageSendTime'];
|
|
||||||
sourceMessageSendID = json['sourceMessageSendID'];
|
|
||||||
sourceMessageSenderNickname = json['sourceMessageSenderNickname'];
|
|
||||||
sessionType = json['sessionType'];
|
|
||||||
contentType = json['contentType'];
|
|
||||||
content = json['content'];
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
Map<String, dynamic> toJson() {
|
|
||||||
final data = Map<String, dynamic>();
|
|
||||||
data['editerID'] = this.editerID;
|
|
||||||
data['clientMsgID'] = this.clientMsgID;
|
|
||||||
data['editTime'] = this.editTime;
|
|
||||||
data['sourceMessageSendTime'] = this.sourceMessageSendTime;
|
|
||||||
data['sourceMessageSendID'] = this.sourceMessageSendID;
|
|
||||||
data['sourceMessageSenderNickname'] = this.sourceMessageSenderNickname;
|
|
||||||
data['sessionType'] = this.sessionType;
|
|
||||||
data['contentType'] = this.contentType;
|
|
||||||
data['content'] = this.content;
|
|
||||||
return data;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class AdvancedMessage {
|
class AdvancedMessage {
|
||||||
List<Message>? messageList;
|
List<Message>? messageList;
|
||||||
bool? isEnd;
|
bool? isEnd;
|
||||||
|
|||||||
@@ -1,7 +1,6 @@
|
|||||||
import '../../flutter_openim_sdk.dart';
|
import '../../flutter_openim_sdk.dart';
|
||||||
import 'channel_info.dart';
|
|
||||||
|
|
||||||
/// OA notification
|
/// OA Notification
|
||||||
class OANotification {
|
class OANotification {
|
||||||
/// Title
|
/// Title
|
||||||
String? notificationName;
|
String? notificationName;
|
||||||
@@ -59,57 +58,50 @@ class OANotification {
|
|||||||
text = json['text'];
|
text = json['text'];
|
||||||
externalUrl = json['externalUrl'];
|
externalUrl = json['externalUrl'];
|
||||||
mixType = json['mixType'];
|
mixType = json['mixType'];
|
||||||
pictureElem = json['pictureElem'] != null
|
pictureElem = json['pictureElem'] != null ? PictureElem.fromJson(json['pictureElem']) : null;
|
||||||
? PictureElem.fromJson(json['pictureElem'])
|
soundElem = json['soundElem'] != null ? SoundElem.fromJson(json['soundElem']) : null;
|
||||||
: null;
|
videoElem = json['videoElem'] != null ? VideoElem.fromJson(json['videoElem']) : null;
|
||||||
soundElem = json['soundElem'] != null
|
fileElem = json['fileElem'] != null ? FileElem.fromJson(json['fileElem']) : null;
|
||||||
? SoundElem.fromJson(json['soundElem'])
|
|
||||||
: null;
|
|
||||||
videoElem = json['videoElem'] != null
|
|
||||||
? VideoElem.fromJson(json['videoElem'])
|
|
||||||
: null;
|
|
||||||
fileElem =
|
|
||||||
json['fileElem'] != null ? FileElem.fromJson(json['fileElem']) : null;
|
|
||||||
ex = json['ex'];
|
ex = json['ex'];
|
||||||
}
|
}
|
||||||
|
|
||||||
Map<String, dynamic> toJson() {
|
Map<String, dynamic> toJson() {
|
||||||
final data = Map<String, dynamic>();
|
final data = Map<String, dynamic>();
|
||||||
data['notificationName'] = this.notificationName;
|
data['notificationName'] = notificationName;
|
||||||
data['notificationFaceURL'] = this.notificationFaceURL;
|
data['notificationFaceURL'] = notificationFaceURL;
|
||||||
data['notificationType'] = this.notificationType;
|
data['notificationType'] = notificationType;
|
||||||
data['text'] = this.text;
|
data['text'] = text;
|
||||||
data['externalUrl'] = this.externalUrl;
|
data['externalUrl'] = externalUrl;
|
||||||
data['mixType'] = this.mixType;
|
data['mixType'] = mixType;
|
||||||
if (this.pictureElem != null) {
|
if (pictureElem != null) {
|
||||||
data['pictureElem'] = this.pictureElem!.toJson();
|
data['pictureElem'] = pictureElem!.toJson();
|
||||||
}
|
}
|
||||||
if (this.soundElem != null) {
|
if (soundElem != null) {
|
||||||
data['soundElem'] = this.soundElem!.toJson();
|
data['soundElem'] = soundElem!.toJson();
|
||||||
}
|
}
|
||||||
if (this.videoElem != null) {
|
if (videoElem != null) {
|
||||||
data['videoElem'] = this.videoElem!.toJson();
|
data['videoElem'] = videoElem!.toJson();
|
||||||
}
|
}
|
||||||
if (this.fileElem != null) {
|
if (fileElem != null) {
|
||||||
data['fileElem'] = this.fileElem!.toJson();
|
data['fileElem'] = fileElem!.toJson();
|
||||||
}
|
}
|
||||||
data['ex'] = this.ex;
|
data['ex'] = ex;
|
||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// 群事件通知
|
/// Group Event Notification
|
||||||
class GroupNotification {
|
class GroupNotification {
|
||||||
/// 群信息
|
/// Group information
|
||||||
GroupInfo? group;
|
GroupInfo? group;
|
||||||
|
|
||||||
/// 当前事件操作者信息
|
/// Current event operator information
|
||||||
GroupMembersInfo? opUser;
|
GroupMembersInfo? opUser;
|
||||||
|
|
||||||
/// 群拥有者信息
|
/// Group owner information
|
||||||
GroupMembersInfo? groupOwnerUser;
|
GroupMembersInfo? groupOwnerUser;
|
||||||
|
|
||||||
/// 产生影响的群成员列表
|
/// List of affected group members
|
||||||
List<GroupMembersInfo>? memberList;
|
List<GroupMembersInfo>? memberList;
|
||||||
|
|
||||||
GroupNotification({
|
GroupNotification({
|
||||||
@@ -121,12 +113,8 @@ class GroupNotification {
|
|||||||
|
|
||||||
GroupNotification.fromJson(Map<String, dynamic> json) {
|
GroupNotification.fromJson(Map<String, dynamic> json) {
|
||||||
group = json['group'] != null ? GroupInfo.fromJson(json['group']) : null;
|
group = json['group'] != null ? GroupInfo.fromJson(json['group']) : null;
|
||||||
opUser = json['opUser'] != null
|
opUser = json['opUser'] != null ? GroupMembersInfo.fromJson(json['opUser']) : null;
|
||||||
? GroupMembersInfo.fromJson(json['opUser'])
|
groupOwnerUser = json['groupOwnerUser'] != null ? GroupMembersInfo.fromJson(json['groupOwnerUser']) : null;
|
||||||
: null;
|
|
||||||
groupOwnerUser = json['groupOwnerUser'] != null
|
|
||||||
? GroupMembersInfo.fromJson(json['groupOwnerUser'])
|
|
||||||
: null;
|
|
||||||
if (json['memberList'] != null) {
|
if (json['memberList'] != null) {
|
||||||
memberList = <GroupMembersInfo>[];
|
memberList = <GroupMembersInfo>[];
|
||||||
json['memberList'].forEach((v) {
|
json['memberList'].forEach((v) {
|
||||||
@@ -137,40 +125,42 @@ class GroupNotification {
|
|||||||
|
|
||||||
Map<String, dynamic> toJson() {
|
Map<String, dynamic> toJson() {
|
||||||
final data = Map<String, dynamic>();
|
final data = Map<String, dynamic>();
|
||||||
if (this.group != null) {
|
if (group != null) {
|
||||||
data['group'] = this.group!.toJson();
|
data['group'] = group!.toJson();
|
||||||
}
|
}
|
||||||
if (this.opUser != null) {
|
if (opUser != null) {
|
||||||
data['opUser'] = this.opUser!.toJson();
|
data['opUser'] = opUser!.toJson();
|
||||||
}
|
}
|
||||||
if (this.groupOwnerUser != null) {
|
if (groupOwnerUser != null) {
|
||||||
data['groupOwnerUser'] = this.groupOwnerUser!.toJson();
|
data['groupOwnerUser'] = groupOwnerUser!.toJson();
|
||||||
}
|
}
|
||||||
if (this.memberList != null) {
|
if (memberList != null) {
|
||||||
data['memberList'] = this.memberList!.map((v) => v.toJson()).toList();
|
data['memberList'] = memberList!.map((v) => v.toJson()).toList();
|
||||||
}
|
}
|
||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// 用户被邀请进群通知
|
/// User Invited to Join Group Notification
|
||||||
class InvitedJoinGroupNotification {
|
class InvitedJoinGroupNotification {
|
||||||
/// 群信息
|
/// Group information
|
||||||
GroupInfo? group;
|
GroupInfo? group;
|
||||||
|
|
||||||
/// 操作者信息
|
/// Operator information
|
||||||
GroupMembersInfo? opUser;
|
GroupMembersInfo? opUser;
|
||||||
|
|
||||||
/// 被邀请进群的成员信息
|
/// Inviter information
|
||||||
|
GroupMembersInfo? inviterUser;
|
||||||
|
|
||||||
|
/// List of members invited to join the group
|
||||||
List<GroupMembersInfo>? invitedUserList;
|
List<GroupMembersInfo>? invitedUserList;
|
||||||
|
|
||||||
InvitedJoinGroupNotification({this.group, this.opUser, this.invitedUserList});
|
InvitedJoinGroupNotification({this.group, this.opUser, this.invitedUserList});
|
||||||
|
|
||||||
InvitedJoinGroupNotification.fromJson(Map<String, dynamic> json) {
|
InvitedJoinGroupNotification.fromJson(Map<String, dynamic> json) {
|
||||||
group = json['group'] != null ? GroupInfo.fromJson(json['group']) : null;
|
group = json['group'] != null ? GroupInfo.fromJson(json['group']) : null;
|
||||||
opUser = json['opUser'] != null
|
opUser = json['opUser'] != null ? GroupMembersInfo.fromJson(json['opUser']) : null;
|
||||||
? GroupMembersInfo.fromJson(json['opUser'])
|
inviterUser = json['inviterUser'] != null ? GroupMembersInfo.fromJson(json['inviterUser']) : null;
|
||||||
: null;
|
|
||||||
if (json['invitedUserList'] != null) {
|
if (json['invitedUserList'] != null) {
|
||||||
invitedUserList = <GroupMembersInfo>[];
|
invitedUserList = <GroupMembersInfo>[];
|
||||||
json['invitedUserList'].forEach((v) {
|
json['invitedUserList'].forEach((v) {
|
||||||
@@ -180,40 +170,39 @@ class InvitedJoinGroupNotification {
|
|||||||
}
|
}
|
||||||
|
|
||||||
Map<String, dynamic> toJson() {
|
Map<String, dynamic> toJson() {
|
||||||
final Map<String, dynamic> data = new Map<String, dynamic>();
|
final Map<String, dynamic> data = <String, dynamic>{};
|
||||||
if (this.group != null) {
|
if (group != null) {
|
||||||
data['group'] = this.group!.toJson();
|
data['group'] = group!.toJson();
|
||||||
}
|
}
|
||||||
if (this.opUser != null) {
|
if (opUser != null) {
|
||||||
data['opUser'] = this.opUser!.toJson();
|
data['opUser'] = opUser!.toJson();
|
||||||
}
|
}
|
||||||
if (this.invitedUserList != null) {
|
if (inviterUser != null) {
|
||||||
data['invitedUserList'] =
|
data['inviterUser'] = inviterUser!.toJson();
|
||||||
this.invitedUserList!.map((v) => v.toJson()).toList();
|
}
|
||||||
|
if (invitedUserList != null) {
|
||||||
|
data['invitedUserList'] = invitedUserList!.map((v) => v.toJson()).toList();
|
||||||
}
|
}
|
||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// 组踢出成员通知
|
/// Group Member Kicked Notification
|
||||||
class KickedGroupMemeberNotification {
|
class KickedGroupMemeberNotification {
|
||||||
/// 群信息
|
/// Group information
|
||||||
GroupInfo? group;
|
GroupInfo? group;
|
||||||
|
|
||||||
/// 操作者信息
|
/// Operator information
|
||||||
GroupMembersInfo? opUser;
|
GroupMembersInfo? opUser;
|
||||||
|
|
||||||
/// 被踢出群的成员信息列表
|
/// List of members kicked from the group
|
||||||
List<GroupMembersInfo>? kickedUserList;
|
List<GroupMembersInfo>? kickedUserList;
|
||||||
|
|
||||||
KickedGroupMemeberNotification(
|
KickedGroupMemeberNotification({this.group, this.opUser, this.kickedUserList});
|
||||||
{this.group, this.opUser, this.kickedUserList});
|
|
||||||
|
|
||||||
KickedGroupMemeberNotification.fromJson(Map<String, dynamic> json) {
|
KickedGroupMemeberNotification.fromJson(Map<String, dynamic> json) {
|
||||||
group = json['group'] != null ? GroupInfo.fromJson(json['group']) : null;
|
group = json['group'] != null ? GroupInfo.fromJson(json['group']) : null;
|
||||||
opUser = json['opUser'] != null
|
opUser = json['opUser'] != null ? GroupMembersInfo.fromJson(json['opUser']) : null;
|
||||||
? GroupMembersInfo.fromJson(json['opUser'])
|
|
||||||
: null;
|
|
||||||
if (json['kickedUserList'] != null) {
|
if (json['kickedUserList'] != null) {
|
||||||
kickedUserList = <GroupMembersInfo>[];
|
kickedUserList = <GroupMembersInfo>[];
|
||||||
json['kickedUserList'].forEach((v) {
|
json['kickedUserList'].forEach((v) {
|
||||||
@@ -224,87 +213,82 @@ class KickedGroupMemeberNotification {
|
|||||||
|
|
||||||
Map<String, dynamic> toJson() {
|
Map<String, dynamic> toJson() {
|
||||||
final Map<String, dynamic> data = new Map<String, dynamic>();
|
final Map<String, dynamic> data = new Map<String, dynamic>();
|
||||||
if (this.group != null) {
|
if (group != null) {
|
||||||
data['group'] = this.group!.toJson();
|
data['group'] = group!.toJson();
|
||||||
}
|
}
|
||||||
if (this.opUser != null) {
|
if (opUser != null) {
|
||||||
data['opUser'] = this.opUser!.toJson();
|
data['opUser'] = opUser!.toJson();
|
||||||
}
|
}
|
||||||
if (this.kickedUserList != null) {
|
if (kickedUserList != null) {
|
||||||
data['kickedUserList'] =
|
data['kickedUserList'] = kickedUserList!.map((v) => v.toJson()).toList();
|
||||||
this.kickedUserList!.map((v) => v.toJson()).toList();
|
|
||||||
}
|
}
|
||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// 退出群通知
|
/// Quit Group Notification
|
||||||
class QuitGroupNotification {
|
class QuitGroupNotification {
|
||||||
/// 群信息
|
/// Group information
|
||||||
GroupInfo? group;
|
GroupInfo? group;
|
||||||
|
|
||||||
/// 退群的成员信息
|
/// Information of the member who quit the group
|
||||||
GroupMembersInfo? quitUser;
|
GroupMembersInfo? quitUser;
|
||||||
|
|
||||||
QuitGroupNotification({this.group, this.quitUser});
|
QuitGroupNotification({this.group, this.quitUser});
|
||||||
|
|
||||||
QuitGroupNotification.fromJson(Map<String, dynamic> json) {
|
QuitGroupNotification.fromJson(Map<String, dynamic> json) {
|
||||||
group = json['group'] != null ? GroupInfo.fromJson(json['group']) : null;
|
group = json['group'] != null ? GroupInfo.fromJson(json['group']) : null;
|
||||||
quitUser = json['quitUser'] != null
|
quitUser = json['quitUser'] != null ? GroupMembersInfo.fromJson(json['quitUser']) : null;
|
||||||
? GroupMembersInfo.fromJson(json['quitUser'])
|
|
||||||
: null;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Map<String, dynamic> toJson() {
|
Map<String, dynamic> toJson() {
|
||||||
final data = Map<String, dynamic>();
|
final data = Map<String, dynamic>();
|
||||||
if (this.group != null) {
|
if (group != null) {
|
||||||
data['group'] = this.group!.toJson();
|
data['group'] = group!.toJson();
|
||||||
}
|
}
|
||||||
if (this.quitUser != null) {
|
if (quitUser != null) {
|
||||||
data['quitUser'] = this.quitUser!.toJson();
|
data['quitUser'] = quitUser!.toJson();
|
||||||
}
|
}
|
||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// 进群通知
|
/// Enter Group Notification
|
||||||
class EnterGroupNotification {
|
class EnterGroupNotification {
|
||||||
/// 群信息
|
/// Group information
|
||||||
GroupInfo? group;
|
GroupInfo? group;
|
||||||
|
|
||||||
/// 进入群的成员信息
|
/// Information of the member who entered the group
|
||||||
GroupMembersInfo? entrantUser;
|
GroupMembersInfo? entrantUser;
|
||||||
|
|
||||||
EnterGroupNotification({this.group, this.entrantUser});
|
EnterGroupNotification({this.group, this.entrantUser});
|
||||||
|
|
||||||
EnterGroupNotification.fromJson(Map<String, dynamic> json) {
|
EnterGroupNotification.fromJson(Map<String, dynamic> json) {
|
||||||
group = json['group'] != null ? GroupInfo.fromJson(json['group']) : null;
|
group = json['group'] != null ? GroupInfo.fromJson(json['group']) : null;
|
||||||
entrantUser = json['entrantUser'] != null
|
entrantUser = json['entrantUser'] != null ? GroupMembersInfo.fromJson(json['entrantUser']) : null;
|
||||||
? GroupMembersInfo.fromJson(json['entrantUser'])
|
|
||||||
: null;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Map<String, dynamic> toJson() {
|
Map<String, dynamic> toJson() {
|
||||||
final data = Map<String, dynamic>();
|
final data = Map<String, dynamic>();
|
||||||
if (this.group != null) {
|
if (group != null) {
|
||||||
data['group'] = this.group!.toJson();
|
data['group'] = group!.toJson();
|
||||||
}
|
}
|
||||||
if (this.entrantUser != null) {
|
if (entrantUser != null) {
|
||||||
data['quitUser'] = this.entrantUser!.toJson();
|
data['entrantUser'] = entrantUser!.toJson();
|
||||||
}
|
}
|
||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// 群权转让通知
|
/// Group Rights Transfer Notification
|
||||||
class GroupRightsTransferNoticication {
|
class GroupRightsTransferNoticication {
|
||||||
/// 群信息
|
/// Group information
|
||||||
GroupInfo? group;
|
GroupInfo? group;
|
||||||
|
|
||||||
/// 操作者信息
|
/// Operator information
|
||||||
GroupMembersInfo? opUser;
|
GroupMembersInfo? opUser;
|
||||||
|
|
||||||
/// 群新的拥有者信息
|
/// New group owner information
|
||||||
GroupMembersInfo? newGroupOwner;
|
GroupMembersInfo? newGroupOwner;
|
||||||
|
|
||||||
GroupRightsTransferNoticication({
|
GroupRightsTransferNoticication({
|
||||||
@@ -315,41 +299,37 @@ class GroupRightsTransferNoticication {
|
|||||||
|
|
||||||
GroupRightsTransferNoticication.fromJson(Map<String, dynamic> json) {
|
GroupRightsTransferNoticication.fromJson(Map<String, dynamic> json) {
|
||||||
group = json['group'] != null ? GroupInfo.fromJson(json['group']) : null;
|
group = json['group'] != null ? GroupInfo.fromJson(json['group']) : null;
|
||||||
opUser = json['opUser'] != null
|
opUser = json['opUser'] != null ? GroupMembersInfo.fromJson(json['opUser']) : null;
|
||||||
? GroupMembersInfo.fromJson(json['opUser'])
|
newGroupOwner = json['newGroupOwner'] != null ? GroupMembersInfo.fromJson(json['newGroupOwner']) : null;
|
||||||
: null;
|
|
||||||
newGroupOwner = json['newGroupOwner'] != null
|
|
||||||
? GroupMembersInfo.fromJson(json['newGroupOwner'])
|
|
||||||
: null;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Map<String, dynamic> toJson() {
|
Map<String, dynamic> toJson() {
|
||||||
final data = Map<String, dynamic>();
|
final data = Map<String, dynamic>();
|
||||||
if (this.group != null) {
|
if (group != null) {
|
||||||
data['group'] = this.group!.toJson();
|
data['group'] = group!.toJson();
|
||||||
}
|
}
|
||||||
if (this.opUser != null) {
|
if (opUser != null) {
|
||||||
data['opUser'] = this.opUser!.toJson();
|
data['opUser'] = opUser!.toJson();
|
||||||
}
|
}
|
||||||
if (this.newGroupOwner != null) {
|
if (newGroupOwner != null) {
|
||||||
data['newGroupOwner'] = this.newGroupOwner!.toJson();
|
data['newGroupOwner'] = newGroupOwner!.toJson();
|
||||||
}
|
}
|
||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// 禁言成员通知
|
/// Mute Member Notification
|
||||||
class MuteMemberNotification {
|
class MuteMemberNotification {
|
||||||
/// 群信息
|
/// Group information
|
||||||
GroupInfo? group;
|
GroupInfo? group;
|
||||||
|
|
||||||
/// 操作者信息
|
/// Operator information
|
||||||
GroupMembersInfo? opUser;
|
GroupMembersInfo? opUser;
|
||||||
|
|
||||||
/// 被禁言的成员信息
|
/// Muted member information
|
||||||
GroupMembersInfo? mutedUser;
|
GroupMembersInfo? mutedUser;
|
||||||
|
|
||||||
/// 禁言时间s
|
/// Mute duration in seconds
|
||||||
int? mutedSeconds;
|
int? mutedSeconds;
|
||||||
|
|
||||||
MuteMemberNotification({
|
MuteMemberNotification({
|
||||||
@@ -361,40 +341,36 @@ class MuteMemberNotification {
|
|||||||
|
|
||||||
MuteMemberNotification.fromJson(Map<String, dynamic> json) {
|
MuteMemberNotification.fromJson(Map<String, dynamic> json) {
|
||||||
group = json['group'] != null ? GroupInfo.fromJson(json['group']) : null;
|
group = json['group'] != null ? GroupInfo.fromJson(json['group']) : null;
|
||||||
opUser = json['opUser'] != null
|
opUser = json['opUser'] != null ? GroupMembersInfo.fromJson(json['opUser']) : null;
|
||||||
? GroupMembersInfo.fromJson(json['opUser'])
|
mutedUser = json['mutedUser'] != null ? GroupMembersInfo.fromJson(json['mutedUser']) : null;
|
||||||
: null;
|
|
||||||
mutedUser = json['mutedUser'] != null
|
|
||||||
? GroupMembersInfo.fromJson(json['mutedUser'])
|
|
||||||
: null;
|
|
||||||
mutedSeconds = json['mutedSeconds'];
|
mutedSeconds = json['mutedSeconds'];
|
||||||
}
|
}
|
||||||
|
|
||||||
Map<String, dynamic> toJson() {
|
Map<String, dynamic> toJson() {
|
||||||
final data = Map<String, dynamic>();
|
final data = Map<String, dynamic>();
|
||||||
if (this.group != null) {
|
if (group != null) {
|
||||||
data['group'] = this.group!.toJson();
|
data['group'] = group!.toJson();
|
||||||
}
|
}
|
||||||
if (this.opUser != null) {
|
if (opUser != null) {
|
||||||
data['opUser'] = this.opUser!.toJson();
|
data['opUser'] = opUser!.toJson();
|
||||||
}
|
}
|
||||||
if (this.mutedUser != null) {
|
if (mutedUser != null) {
|
||||||
data['mutedUser'] = this.mutedUser!.toJson();
|
data['mutedUser'] = mutedUser!.toJson();
|
||||||
}
|
}
|
||||||
data['mutedSeconds'] = this.mutedSeconds;
|
data['mutedSeconds'] = mutedSeconds;
|
||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// 阅后即焚通知
|
/// Burn After Reading Notification
|
||||||
class BurnAfterReadingNotification {
|
class BurnAfterReadingNotification {
|
||||||
/// 接收者
|
/// Receiver
|
||||||
String? recvID;
|
String? recvID;
|
||||||
|
|
||||||
/// 发送者
|
/// Sender
|
||||||
String? sendID;
|
String? sendID;
|
||||||
|
|
||||||
/// 是否开启
|
/// Whether enabled
|
||||||
bool? isPrivate;
|
bool? isPrivate;
|
||||||
|
|
||||||
BurnAfterReadingNotification({this.recvID, this.sendID, this.isPrivate});
|
BurnAfterReadingNotification({this.recvID, this.sendID, this.isPrivate});
|
||||||
@@ -407,22 +383,22 @@ class BurnAfterReadingNotification {
|
|||||||
|
|
||||||
Map<String, dynamic> toJson() {
|
Map<String, dynamic> toJson() {
|
||||||
final data = Map<String, dynamic>();
|
final data = Map<String, dynamic>();
|
||||||
data['recvID'] = this.recvID;
|
data['recvID'] = recvID;
|
||||||
data['sendID'] = this.sendID;
|
data['sendID'] = sendID;
|
||||||
data['isPrivate'] = this.isPrivate;
|
data['isPrivate'] = isPrivate;
|
||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// 群成员信息发送变化通知
|
/// Group Member Information Changed Notification
|
||||||
class GroupMemberInfoChangedNotification {
|
class GroupMemberInfoChangedNotification {
|
||||||
/// 群信息
|
/// Group information
|
||||||
GroupInfo? group;
|
GroupInfo? group;
|
||||||
|
|
||||||
/// 操作者信息
|
/// Operator information
|
||||||
GroupMembersInfo? opUser;
|
GroupMembersInfo? opUser;
|
||||||
|
|
||||||
/// 资料发生改变的成员
|
/// Member with changed information
|
||||||
GroupMembersInfo? changedUser;
|
GroupMembersInfo? changedUser;
|
||||||
|
|
||||||
GroupMemberInfoChangedNotification({
|
GroupMemberInfoChangedNotification({
|
||||||
@@ -433,276 +409,21 @@ class GroupMemberInfoChangedNotification {
|
|||||||
|
|
||||||
GroupMemberInfoChangedNotification.fromJson(Map<String, dynamic> json) {
|
GroupMemberInfoChangedNotification.fromJson(Map<String, dynamic> json) {
|
||||||
group = json['group'] != null ? GroupInfo.fromJson(json['group']) : null;
|
group = json['group'] != null ? GroupInfo.fromJson(json['group']) : null;
|
||||||
opUser = json['opUser'] != null
|
opUser = json['opUser'] != null ? GroupMembersInfo.fromJson(json['opUser']) : null;
|
||||||
? GroupMembersInfo.fromJson(json['opUser'])
|
changedUser = json['changedUser'] != null ? GroupMembersInfo.fromJson(json['changedUser']) : null;
|
||||||
: null;
|
|
||||||
changedUser = json['changedUser'] != null
|
|
||||||
? GroupMembersInfo.fromJson(json['changedUser'])
|
|
||||||
: null;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Map<String, dynamic> toJson() {
|
Map<String, dynamic> toJson() {
|
||||||
final data = Map<String, dynamic>();
|
final data = Map<String, dynamic>();
|
||||||
if (this.group != null) {
|
if (group != null) {
|
||||||
data['group'] = this.group!.toJson();
|
data['group'] = group!.toJson();
|
||||||
}
|
}
|
||||||
if (this.opUser != null) {
|
if (opUser != null) {
|
||||||
data['opUser'] = this.opUser!.toJson();
|
data['opUser'] = opUser!.toJson();
|
||||||
}
|
}
|
||||||
if (this.changedUser != null) {
|
if (changedUser != null) {
|
||||||
data['changedUser'] = this.changedUser!.toJson();
|
data['changedUser'] = changedUser!.toJson();
|
||||||
}
|
}
|
||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
///todo 所有的聊天的操作者都没有,暂时没有处理
|
|
||||||
/// 聊天室事件通知
|
|
||||||
class ChannelNotification {
|
|
||||||
/// 聊天室信息
|
|
||||||
ChannelInfo? Channel;
|
|
||||||
|
|
||||||
/// 当前事件操作者信息
|
|
||||||
ChannelMembersInfo? opUser;
|
|
||||||
|
|
||||||
/// 聊天室拥有者信息
|
|
||||||
ChannelMembersInfo? ChannelOwnerUser;
|
|
||||||
|
|
||||||
/// 产生影响的聊天室成员列表
|
|
||||||
List<ChannelMembersInfo>? memberList;
|
|
||||||
|
|
||||||
ChannelNotification({
|
|
||||||
this.Channel,
|
|
||||||
this.opUser,
|
|
||||||
this.ChannelOwnerUser,
|
|
||||||
this.memberList,
|
|
||||||
});
|
|
||||||
|
|
||||||
ChannelNotification.fromJson(Map<String, dynamic> json) {
|
|
||||||
Channel = json['channel'] != null ? ChannelInfo.fromJson(json['channel']) : null;
|
|
||||||
opUser = json['opUser'] != null
|
|
||||||
? ChannelMembersInfo.fromJson(json['opUser'])
|
|
||||||
: null;
|
|
||||||
ChannelOwnerUser = json['channelOwnerUser'] != null
|
|
||||||
? ChannelMembersInfo.fromJson(json['channelOwnerUser'])
|
|
||||||
: null;
|
|
||||||
if (json['memberList'] != null) {
|
|
||||||
memberList = <ChannelMembersInfo>[];
|
|
||||||
json['memberList'].forEach((v) {
|
|
||||||
memberList!.add(ChannelMembersInfo.fromJson(v));
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Map<String, dynamic> toJson() {
|
|
||||||
final data = Map<String, dynamic>();
|
|
||||||
if (this.Channel != null) {
|
|
||||||
data['channel'] = this.Channel!.toJson();
|
|
||||||
}
|
|
||||||
if (this.opUser != null) {
|
|
||||||
data['opUser'] = this.opUser!.toJson();
|
|
||||||
}
|
|
||||||
if (this.ChannelOwnerUser != null) {
|
|
||||||
data['channelOwnerUser'] = this.ChannelOwnerUser!.toJson();
|
|
||||||
}
|
|
||||||
if (this.memberList != null) {
|
|
||||||
data['memberList'] = this.memberList!.map((v) => v.toJson()).toList();
|
|
||||||
}
|
|
||||||
return data;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/// 组踢出成员通知
|
|
||||||
class KickedChannelMemeberNotification {
|
|
||||||
/// 聊天室信息
|
|
||||||
ChannelInfo? Channel;
|
|
||||||
|
|
||||||
/// 操作者信息
|
|
||||||
ChannelMembersInfo? opUser;
|
|
||||||
|
|
||||||
/// 被踢出聊天室的成员信息列表
|
|
||||||
List<ChannelMembersInfo>? kickedUserList;
|
|
||||||
|
|
||||||
KickedChannelMemeberNotification(
|
|
||||||
{this.Channel, this.opUser, this.kickedUserList});
|
|
||||||
|
|
||||||
KickedChannelMemeberNotification.fromJson(Map<String, dynamic> json) {
|
|
||||||
Channel = json['channel'] != null ? ChannelInfo.fromJson(json['channel']) : null;
|
|
||||||
opUser = json['opUser'] != null
|
|
||||||
? ChannelMembersInfo.fromJson(json['opUser'])
|
|
||||||
: null;
|
|
||||||
if (json['kickedUserList'] != null) {
|
|
||||||
kickedUserList = <ChannelMembersInfo>[];
|
|
||||||
json['kickedUserList'].forEach((v) {
|
|
||||||
kickedUserList!.add(ChannelMembersInfo.fromJson(v));
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Map<String, dynamic> toJson() {
|
|
||||||
final Map<String, dynamic> data = new Map<String, dynamic>();
|
|
||||||
if (this.Channel != null) {
|
|
||||||
data['channel'] = this.Channel!.toJson();
|
|
||||||
}
|
|
||||||
if (this.opUser != null) {
|
|
||||||
data['opUser'] = this.opUser!.toJson();
|
|
||||||
}
|
|
||||||
if (this.kickedUserList != null) {
|
|
||||||
data['kickedUserList'] =
|
|
||||||
this.kickedUserList!.map((v) => v.toJson()).toList();
|
|
||||||
}
|
|
||||||
return data;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// 退出聊天室通知
|
|
||||||
class QuitChannelNotification {
|
|
||||||
/// 聊天室信息
|
|
||||||
ChannelInfo? Channel;
|
|
||||||
|
|
||||||
/// 退聊天室的成员信息
|
|
||||||
ChannelMembersInfo? quitUser;
|
|
||||||
|
|
||||||
QuitChannelNotification({this.Channel, this.quitUser});
|
|
||||||
|
|
||||||
QuitChannelNotification.fromJson(Map<String, dynamic> json) {
|
|
||||||
Channel = json['channel'] != null ? ChannelInfo.fromJson(json['channel']) : null;
|
|
||||||
quitUser = json['quitUser'] != null
|
|
||||||
? ChannelMembersInfo.fromJson(json['quitUser'])
|
|
||||||
: null;
|
|
||||||
}
|
|
||||||
|
|
||||||
Map<String, dynamic> toJson() {
|
|
||||||
final data = Map<String, dynamic>();
|
|
||||||
if (this.Channel != null) {
|
|
||||||
data['channel'] = this.Channel!.toJson();
|
|
||||||
}
|
|
||||||
if (this.quitUser != null) {
|
|
||||||
data['quitUser'] = this.quitUser!.toJson();
|
|
||||||
}
|
|
||||||
return data;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// 进聊天室通知
|
|
||||||
class EnterChannelNotification {
|
|
||||||
/// 聊天室信息
|
|
||||||
ChannelInfo? Channel;
|
|
||||||
|
|
||||||
/// 进入聊天室的成员信息
|
|
||||||
ChannelMembersInfo? entrantUser;
|
|
||||||
|
|
||||||
EnterChannelNotification({this.Channel, this.entrantUser});
|
|
||||||
|
|
||||||
EnterChannelNotification.fromJson(Map<String, dynamic> json) {
|
|
||||||
Channel = json['channel'] != null ? ChannelInfo.fromJson(json['channel']) : null;
|
|
||||||
entrantUser = json['entrantUser'] != null
|
|
||||||
? ChannelMembersInfo.fromJson(json['entrantUser'])
|
|
||||||
: null;
|
|
||||||
}
|
|
||||||
|
|
||||||
Map<String, dynamic> toJson() {
|
|
||||||
final data = Map<String, dynamic>();
|
|
||||||
if (this.Channel != null) {
|
|
||||||
data['channel'] = this.Channel!.toJson();
|
|
||||||
}
|
|
||||||
if (this.entrantUser != null) {
|
|
||||||
data['quitUser'] = this.entrantUser!.toJson();
|
|
||||||
}
|
|
||||||
return data;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/// 禁言成员通知
|
|
||||||
class MuteChannelMemberNotification {
|
|
||||||
/// 聊天室信息
|
|
||||||
ChannelInfo? Channel;
|
|
||||||
|
|
||||||
/// 操作者信息
|
|
||||||
ChannelMembersInfo? opUser;
|
|
||||||
|
|
||||||
/// 被禁言的成员信息
|
|
||||||
ChannelMembersInfo? mutedUser;
|
|
||||||
|
|
||||||
/// 禁言时间s
|
|
||||||
int? mutedSeconds;
|
|
||||||
|
|
||||||
MuteChannelMemberNotification({
|
|
||||||
this.Channel,
|
|
||||||
this.opUser,
|
|
||||||
this.mutedUser,
|
|
||||||
this.mutedSeconds,
|
|
||||||
});
|
|
||||||
|
|
||||||
MuteChannelMemberNotification.fromJson(Map<String, dynamic> json) {
|
|
||||||
Channel = json['channel'] != null ? ChannelInfo.fromJson(json['channel']) : null;
|
|
||||||
opUser = json['opUser'] != null
|
|
||||||
? ChannelMembersInfo.fromJson(json['opUser'])
|
|
||||||
: null;
|
|
||||||
mutedUser = json['mutedUser'] != null
|
|
||||||
? ChannelMembersInfo.fromJson(json['mutedUser'])
|
|
||||||
: null;
|
|
||||||
mutedSeconds = json['mutedSeconds'];
|
|
||||||
}
|
|
||||||
|
|
||||||
Map<String, dynamic> toJson() {
|
|
||||||
final data = Map<String, dynamic>();
|
|
||||||
if (this.Channel != null) {
|
|
||||||
data['channel'] = this.Channel!.toJson();
|
|
||||||
}
|
|
||||||
if (this.opUser != null) {
|
|
||||||
data['opUser'] = this.opUser!.toJson();
|
|
||||||
}
|
|
||||||
if (this.mutedUser != null) {
|
|
||||||
data['mutedUser'] = this.mutedUser!.toJson();
|
|
||||||
}
|
|
||||||
data['mutedSeconds'] = this.mutedSeconds;
|
|
||||||
return data;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// 聊天室成员信息发送变化通知
|
|
||||||
class ChannelMemberInfoChangedNotification {
|
|
||||||
/// 聊天室信息
|
|
||||||
ChannelInfo? Channel;
|
|
||||||
|
|
||||||
/// 操作者信息
|
|
||||||
ChannelMembersInfo? opUser;
|
|
||||||
|
|
||||||
/// 资料发生改变的成员
|
|
||||||
ChannelMembersInfo? changedUser;
|
|
||||||
|
|
||||||
ChannelMemberInfoChangedNotification({
|
|
||||||
this.Channel,
|
|
||||||
this.opUser,
|
|
||||||
this.changedUser,
|
|
||||||
});
|
|
||||||
|
|
||||||
ChannelMemberInfoChangedNotification.fromJson(Map<String, dynamic> json) {
|
|
||||||
Channel = json['channel'] != null ? ChannelInfo.fromJson(json['channel']) : null;
|
|
||||||
opUser = json['opUser'] != null
|
|
||||||
? ChannelMembersInfo.fromJson(json['opUser'])
|
|
||||||
: null;
|
|
||||||
changedUser = json['changedUser'] != null
|
|
||||||
? ChannelMembersInfo.fromJson(json['changedUser'])
|
|
||||||
: null;
|
|
||||||
}
|
|
||||||
|
|
||||||
Map<String, dynamic> toJson() {
|
|
||||||
final data = Map<String, dynamic>();
|
|
||||||
if (this.Channel != null) {
|
|
||||||
data['Channel'] = this.Channel!.toJson();
|
|
||||||
}
|
|
||||||
if (this.opUser != null) {
|
|
||||||
data['opUser'] = this.opUser!.toJson();
|
|
||||||
}
|
|
||||||
if (this.changedUser != null) {
|
|
||||||
data['changedUser'] = this.changedUser!.toJson();
|
|
||||||
}
|
|
||||||
return data;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -124,6 +124,6 @@ class SearchFriendsInfo extends FriendInfo {
|
|||||||
Map<String, dynamic> toJson() {
|
Map<String, dynamic> toJson() {
|
||||||
final data = super.toJson();
|
final data = super.toJson();
|
||||||
data['relationship'] = this.relationship;
|
data['relationship'] = this.relationship;
|
||||||
return data ?? {};
|
return data;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,41 +0,0 @@
|
|||||||
class SetChannelMemberInfo {
|
|
||||||
SetChannelMemberInfo({
|
|
||||||
required this.channelID,
|
|
||||||
required this.userID,
|
|
||||||
this.roleLevel,
|
|
||||||
this.nickname,
|
|
||||||
this.faceURL,
|
|
||||||
this.ex,
|
|
||||||
});
|
|
||||||
|
|
||||||
final String channelID;
|
|
||||||
final String userID;
|
|
||||||
final int? roleLevel;
|
|
||||||
final String? nickname;
|
|
||||||
final String? faceURL;
|
|
||||||
final String? ex;
|
|
||||||
|
|
||||||
SetChannelMemberInfo.fromJson(Map<String, dynamic> json)
|
|
||||||
: channelID = json['channelID'],
|
|
||||||
userID = json['userID'],
|
|
||||||
roleLevel = json['roleLevel'],
|
|
||||||
nickname = json['nickname'],
|
|
||||||
faceURL = json['faceURL'],
|
|
||||||
ex = json['ex'];
|
|
||||||
|
|
||||||
Map<String, dynamic> toJson() {
|
|
||||||
final data = Map<String, dynamic>();
|
|
||||||
data['channelID'] = channelID;
|
|
||||||
data['userID'] = userID;
|
|
||||||
data['roleLevel'] = roleLevel;
|
|
||||||
data['nickname'] = nickname;
|
|
||||||
data['faceURL'] = faceURL;
|
|
||||||
data['ex'] = ex;
|
|
||||||
return data;
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
String toString() {
|
|
||||||
return 'SetChannelMemberInfo{channelID: $channelID, userID: $userID, roleLevel: $roleLevel, nickname: $nickname, faceURL: $faceURL, ex: $ex}';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -47,8 +47,6 @@ class ConversationReq {
|
|||||||
final bool? isMsgDestruct;
|
final bool? isMsgDestruct;
|
||||||
final int? msgDestructTime;
|
final int? msgDestructTime;
|
||||||
final int? groupAtType;
|
final int? groupAtType;
|
||||||
final String? channelID;
|
|
||||||
final int? channelAtType;
|
|
||||||
|
|
||||||
ConversationReq({
|
ConversationReq({
|
||||||
this.userID,
|
this.userID,
|
||||||
@@ -61,8 +59,6 @@ class ConversationReq {
|
|||||||
this.isMsgDestruct,
|
this.isMsgDestruct,
|
||||||
this.msgDestructTime,
|
this.msgDestructTime,
|
||||||
this.groupAtType,
|
this.groupAtType,
|
||||||
this.channelID,
|
|
||||||
this.channelAtType,
|
|
||||||
});
|
});
|
||||||
|
|
||||||
ConversationReq.fromJson(Map<String, dynamic> json)
|
ConversationReq.fromJson(Map<String, dynamic> json)
|
||||||
@@ -75,11 +71,8 @@ class ConversationReq {
|
|||||||
burnDuration = json['burnDuration'],
|
burnDuration = json['burnDuration'],
|
||||||
isMsgDestruct = json['isMsgDestruct'],
|
isMsgDestruct = json['isMsgDestruct'],
|
||||||
msgDestructTime = json['msgDestructTime'],
|
msgDestructTime = json['msgDestructTime'],
|
||||||
channelID=json['channelID'],
|
|
||||||
channelAtType = json['channelAtType'],
|
|
||||||
groupAtType = json['groupAtType'];
|
groupAtType = json['groupAtType'];
|
||||||
|
|
||||||
|
|
||||||
Map<String, dynamic> toJson() {
|
Map<String, dynamic> toJson() {
|
||||||
final data = <String, dynamic>{};
|
final data = <String, dynamic>{};
|
||||||
data['userID'] = userID;
|
data['userID'] = userID;
|
||||||
@@ -92,8 +85,7 @@ class ConversationReq {
|
|||||||
data['isMsgDestruct'] = isMsgDestruct;
|
data['isMsgDestruct'] = isMsgDestruct;
|
||||||
data['msgDestructTime'] = msgDestructTime;
|
data['msgDestructTime'] = msgDestructTime;
|
||||||
data['groupAtType'] = groupAtType;
|
data['groupAtType'] = groupAtType;
|
||||||
data['channelID'] = channelID;
|
|
||||||
data['channelAtType'] = channelAtType;
|
|
||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -423,3 +423,78 @@ class UserStatusInfo {
|
|||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
class GetFriendApplicationListAsRecipientReq {
|
||||||
|
final List<int> handleResults;
|
||||||
|
final int offset;
|
||||||
|
final int count;
|
||||||
|
|
||||||
|
GetFriendApplicationListAsRecipientReq({
|
||||||
|
this.handleResults = const [],
|
||||||
|
required this.offset,
|
||||||
|
required this.count,
|
||||||
|
});
|
||||||
|
|
||||||
|
GetFriendApplicationListAsRecipientReq.fromJson(Map<String, dynamic> json)
|
||||||
|
: handleResults = json['handleResults'] == null ? [] : List<int>.from(json['handleResults'].map((x) => x)),
|
||||||
|
offset = json['offset'],
|
||||||
|
count = json['count'];
|
||||||
|
|
||||||
|
Map<String, dynamic> toJson() {
|
||||||
|
final data = <String, dynamic>{};
|
||||||
|
data['handleResults'] = handleResults;
|
||||||
|
data['offset'] = offset;
|
||||||
|
data['count'] = count;
|
||||||
|
return data;
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
String toString() {
|
||||||
|
return 'GetFriendApplicationListAsRecipientReq{handleResults: $handleResults, offset: $offset, count: $count}';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class GetFriendApplicationListAsApplicantReq {
|
||||||
|
final int offset;
|
||||||
|
final int count;
|
||||||
|
|
||||||
|
GetFriendApplicationListAsApplicantReq({
|
||||||
|
required this.offset,
|
||||||
|
required this.count,
|
||||||
|
});
|
||||||
|
|
||||||
|
GetFriendApplicationListAsApplicantReq.fromJson(Map<String, dynamic> json)
|
||||||
|
: offset = json['offset'],
|
||||||
|
count = json['count'];
|
||||||
|
|
||||||
|
Map<String, dynamic> toJson() {
|
||||||
|
final data = <String, dynamic>{};
|
||||||
|
data['offset'] = offset;
|
||||||
|
data['count'] = count;
|
||||||
|
return data;
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
String toString() {
|
||||||
|
return 'GetFriendApplicationListAsApplicantReq{offset: $offset, count: $count}';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class GetFriendApplicationUnhandledCountReq {
|
||||||
|
final int time;
|
||||||
|
|
||||||
|
GetFriendApplicationUnhandledCountReq({this.time = 0});
|
||||||
|
|
||||||
|
GetFriendApplicationUnhandledCountReq.fromJson(Map<String, dynamic> json) : time = json['time'];
|
||||||
|
|
||||||
|
Map<String, dynamic> toJson() {
|
||||||
|
final data = <String, dynamic>{};
|
||||||
|
data['time'] = time;
|
||||||
|
return data;
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
String toString() {
|
||||||
|
return 'GetSelfUnhandledApplyCountReq{time: $time}';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|||||||
@@ -2,7 +2,7 @@ import 'package:flutter/services.dart';
|
|||||||
import 'package:flutter_openim_sdk/flutter_openim_sdk.dart';
|
import 'package:flutter_openim_sdk/flutter_openim_sdk.dart';
|
||||||
|
|
||||||
class OpenIM {
|
class OpenIM {
|
||||||
static const version = '3.8.2+1';
|
static const version = '3.8.3+hotfix.7';
|
||||||
|
|
||||||
static const _channel = MethodChannel('flutter_openim_sdk');
|
static const _channel = MethodChannel('flutter_openim_sdk');
|
||||||
|
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
name: flutter_openim_sdk
|
name: flutter_openim_sdk
|
||||||
description: An instant messaging plug-in that supports Android and IOS. And the server is also all open source.
|
description: An instant messaging plug-in that supports Android and IOS. And the server is also all open source.
|
||||||
version: 3.8.2+1
|
version: 3.8.3+hotfix.7
|
||||||
homepage: https://www.openim.io
|
homepage: https://www.openim.io
|
||||||
repository: https://github.com/openimsdk/open-im-sdk-flutter
|
repository: https://github.com/openimsdk/open-im-sdk-flutter
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user