A free, open-source iOS Mastodon client.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Justin Mazzocchi 3a5ebddad5 Increment version number 7 hours ago
.github Update README, CONTRIBUTING, PR template 7 days ago
Activities Link preferences 2 years ago
App Icons Add Malow app icon 2 years ago
Assets.xcassets Add icon 2 years ago
Caches Set retry and continue in background image options 2 years ago
DB Remove cleaning limit 6 days ago
Data Sources Fix jumping when restoring scroll position 3 weeks ago
Extensions Announcements 2 years ago
HTTP Cancel uploads 2 years ago
Keychain Keychain items accessible after first unlock 2 years ago
Localizations CrowdIn updates 7 hours ago
Mastodon Parse dates without fractional seconds 2 years ago
MastodonAPI Resolve all searches 2 years ago
Metatext.xcodeproj Increment version number 7 hours ago
Notification Service Extension Escape unicode in all URLs from API 2 years ago
Secrets Extract Base16 package 2 years ago
ServiceLayer Do not clean on main thread 1 week ago
Share Extension Settings refactor 2 years ago
Supporting Files Increment build number 2 years ago
System Fix iOS 15 nav bar appearance 7 months ago
Tests Modularize view models 2 years ago
Transitions Fix deprecation 7 months ago
View Controllers Formatting 6 days ago
ViewModels Fix crash when muting account (#245) 9 hours ago
Views Add preference to override color scheme / appearance (#142) 2 weeks ago
.gitignore Import and refactor stuff from old UIKit project 2 years ago
.swiftlint.yml Change swiftlint config 2 years ago
CODE_OF_CONDUCT.md Create CODE_OF_CONDUCT.md 2 years ago
CONTRIBUTING.md Update README, CONTRIBUTING, PR template 7 days ago
LICENSE Create LICENSE 2 years ago
Metatext.xctestplan Add test plan 2 years ago
README.md Update README, CONTRIBUTING, PR template 7 days ago
SECURITY.md Update SECURITY.md 2 years ago

README.md

Metatext

A free, open-source iOS Mastodon client.

Download on the App Store

Contributing Bug Reports

GitHub is used for bug tracking. Please search existing issues and create a new one if the issue is not yet tracked.

Contributing Translations

You can help translate Metatext on CrowdIn.

Contributing Code

See the contribution guidelines.

Note that capacity for reviewing pull requests is currently very limited. For now, please limit the scope of proposed changes to fixing bugs and not added features, settings, or behavior, thanks. If you are interested in doing a larger scope change, please propose it via email at info@metabolist.org first.

Building

To build Metatext:

  • Clone the repository (git clone https://github.com/metabolist/metatext.git)
  • Open Metatext.xcodeproj in Xcode
  • Select the top-level "Metatext" item in Xcode and change the team in each target's "Signing & Capabilities" settings to your own

All dependencies are managed using Swift Package Manager and will automatically be installed by Xcode.

Push Notifications

Push notifications will not work in development builds of Metatext unless you host your own instance of metatext-apns and change the pushSubscriptionEndpointURL constants in IdentityService.swift to its URL.

Architecture

  • Metatext uses the Model–view–viewmodel (MVVM) architectural pattern.
  • View models are clients of a service layer that abstracts network and local database logic.
  • Different levels of the architecture are in different local Swift Packages. import DB and import MastodonAPI should generally only be done within the ServiceLayer package, and import ServiceLayer only within the ViewModels package.

Acknowledgements

Metatext uses the following third-party libraries:

Cryptography Notice

This distribution includes cryptographic software. The country in which you currently reside may have restrictions on the import, possession, use, and/or re-export to another country, of encryption software. BEFORE using any encryption software, please check your country's laws, regulations and policies concerning the import, possession, or use, and re-export of encryption software, to see if this is permitted. See http://www.wassenaar.org/ for more information.

The U.S. Government Department of Commerce, Bureau of Industry and Security (BIS), has classified this software as Export Commodity Control Number (ECCN) 5D002.C.1, which includes information security software using or performing cryptographic functions with asymmetric algorithms. The form and manner of this distribution makes it eligible for export under the License Exception ENC Technology Software Unrestricted (TSU) exception (see the BIS Export Administration Regulations, Section 740.13) for both object code and source code.

License

Copyright (C) 2021 Metabolist

This program is free software: you can redistribute it and/or modify it under the terms of the GNU 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 General Public License for more details.

You should have received a copy of the GNU General Public License along with this program. If not, see https://www.gnu.org/licenses/.